No Description

CourseController.php 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Course;
  4. use App\Semester;
  5. use App\User;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\Auth;
  8. use Illuminate\Support\Facades\Redirect;
  9. use Illuminate\Support\Facades\Storage;
  10. class CourseController extends Controller
  11. {
  12. /**
  13. * Display a listing of the resource.
  14. *
  15. * @return \Illuminate\Http\Response
  16. */
  17. public function index(Request $request)
  18. {
  19. return view('courses.index', [
  20. 'courses' => Course::where('dept_id', '=', $request->session()->get('department'))->with('sections:id,course_id,semester_code')->get()->sort('cmpCourseCode'),
  21. 'semesters' => Semester::orderBy('code', 'asc')->get(),
  22. ]);
  23. }
  24. /**
  25. * Show the form for creating a new resource.
  26. *
  27. * @return \Illuminate\Http\Response
  28. */
  29. public function create()
  30. {
  31. }
  32. /**
  33. * Store a newly created resource in storage.
  34. *
  35. * @param \Illuminate\Http\Request $request
  36. * @return \Illuminate\Http\Response
  37. */
  38. public function store(Request $request)
  39. {
  40. // TODO: Validate syllabus is pdf
  41. $course = Course::create( $request->validate([
  42. 'code' => ['required','unique:courses','size:8','regex:/[A-Za-z]{4}[0-9]{4}/', 'string'],
  43. 'title' => ['required','max:255', 'string'],
  44. 'dept_id' => ['required','exists:departments,id', 'integer'],
  45. ]));
  46. if ($request->file('syllabus')) {
  47. $path = $request->file('syllabus')->store('course_syllabus');
  48. $course->update(['syllabus' => '/storage/'.$path]);
  49. }
  50. return redirect('/course/' . $course->id);
  51. }
  52. /**
  53. * Display the specified resource.
  54. *
  55. * @param \App\Course $course
  56. * @return \Illuminate\Http\Response
  57. */
  58. public function show(Course $course)
  59. {
  60. $course->loadMissing(['semesters.sections.professors']);
  61. return view('courses.show', [
  62. 'course' => $course,
  63. ]);
  64. }
  65. /**
  66. * Show the form for editing the specified resource.
  67. *
  68. * @param \App\Course $course
  69. * @return \Illuminate\Http\Response
  70. */
  71. public function edit(Course $course)
  72. {
  73. //
  74. }
  75. /**
  76. * Update the specified resource in storage.
  77. *
  78. * @param \Illuminate\Http\Request $request
  79. * @param \App\Course $course
  80. * @return \Illuminate\Http\Response
  81. */
  82. public function update(Request $request, Course $course)
  83. {
  84. $data = array_filter($request->validate([
  85. 'code' => ['nullable', 'unique:courses','size:8','regex:/[A-Za-z]{4}[0-9]{4}/', 'string'],
  86. 'title' => ['nullable', 'max:255', 'string'],
  87. 'dept_id' => ['nullable', 'exists:departments,id', 'integer'],
  88. ]));
  89. $course->update($data);
  90. if ($request->file('syllabus')) {
  91. $path = $request->file('syllabus')->store('course_syllabus');
  92. $course->update(['syllabus' => '/storage/'.$path]);
  93. }
  94. // dd($path);
  95. // dd(asset($path));
  96. // dd($course->syllabus);
  97. // return redirect($course->syllabus);
  98. return redirect()->back();
  99. }
  100. /**
  101. * Remove the specified resource from storage.
  102. *
  103. * @param \App\Course $course
  104. * @return \Illuminate\Http\Response
  105. */
  106. public function destroy(Course $course)
  107. {
  108. //
  109. }
  110. }