bookRepo = $bookRepo; $this->chapterRepo = $chapterRepo; } /** * Show the form for creating a new chapter. * * @param $bookSlug * @return Response */ public function create($bookSlug) { $book = $this->bookRepo->getBySlug($bookSlug); return view('chapters/create', ['book' => $book]); } /** * Store a newly created chapter in storage. * * @param $bookSlug * @param Request $request * @return Response */ public function store($bookSlug, Request $request) { $this->validate($request, [ 'name' => 'required|string|max:255' ]); $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->newFromInput($request->all()); $chapter->slug = $this->chapterRepo->findSuitableSlug($chapter->name, $book->id); $chapter->priority = $this->bookRepo->getNewPriority($book); $book->chapters()->save($chapter); return redirect($book->getUrl()); } /** * Display the specified chapter. * * @param $bookSlug * @param $chapterSlug * @return Response */ public function show($bookSlug, $chapterSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); return view('chapters/show', ['book' => $book, 'chapter' => $chapter]); } /** * Show the form for editing the specified chapter. * * @param $bookSlug * @param $chapterSlug * @return Response */ public function edit($bookSlug, $chapterSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); return view('chapters/edit', ['book' => $book, 'chapter' => $chapter]); } /** * Update the specified chapter in storage. * * @param Request $request * @param $bookSlug * @param $chapterSlug * @return Response */ public function update(Request $request, $bookSlug, $chapterSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); $chapter->fill($request->all()); $chapter->slug = $this->chapterRepo->findSuitableSlug($chapter->name, $book->id, $chapter->id); $chapter->save(); return redirect($chapter->getUrl()); } /** * Shows the page to confirm deletion of this chapter. * @param $bookSlug * @param $chapterSlug * @return \Illuminate\View\View */ public function showDelete($bookSlug, $chapterSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); return view('chapters/delete', ['book' => $book, 'chapter' => $chapter]); } /** * Remove the specified chapter from storage. * * @param $bookSlug * @param $chapterSlug * @return Response */ public function destroy($bookSlug, $chapterSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); if(count($chapter->pages) > 0) { foreach($chapter->pages as $page) { $page->chapter_id = 0; $page->save(); } } $chapter->delete(); return redirect($book->getUrl()); } }