X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/88049476fe496de3a3b767a4305d985f78a96db8..refs/pull/63/head:/app/Http/Controllers/ChapterController.php diff --git a/app/Http/Controllers/ChapterController.php b/app/Http/Controllers/ChapterController.php index f7b4f6dab..fc13e8b58 100644 --- a/app/Http/Controllers/ChapterController.php +++ b/app/Http/Controllers/ChapterController.php @@ -10,6 +10,7 @@ use BookStack\Http\Requests; use BookStack\Http\Controllers\Controller; use BookStack\Repos\BookRepo; use BookStack\Repos\ChapterRepo; +use Views; class ChapterController extends Controller { @@ -32,7 +33,6 @@ class ChapterController extends Controller /** * Show the form for creating a new chapter. - * * @param $bookSlug * @return Response */ @@ -40,12 +40,12 @@ class ChapterController extends Controller { $this->checkPermission('chapter-create'); $book = $this->bookRepo->getBySlug($bookSlug); + $this->setPageTitle('Create New Chapter'); return view('chapters/create', ['book' => $book, 'current' => $book]); } /** * Store a newly created chapter in storage. - * * @param $bookSlug * @param Request $request * @return Response @@ -61,8 +61,8 @@ class ChapterController extends Controller $chapter = $this->chapterRepo->newFromInput($request->all()); $chapter->slug = $this->chapterRepo->findSuitableSlug($chapter->name, $book->id); $chapter->priority = $this->bookRepo->getNewPriority($book); - $chapter->created_by = Auth::user()->id; - $chapter->updated_by = Auth::user()->id; + $chapter->created_by = auth()->user()->id; + $chapter->updated_by = auth()->user()->id; $book->chapters()->save($chapter); Activity::add($chapter, 'chapter_create', $book->id); return redirect($chapter->getUrl()); @@ -70,7 +70,6 @@ class ChapterController extends Controller /** * Display the specified chapter. - * * @param $bookSlug * @param $chapterSlug * @return Response @@ -79,12 +78,14 @@ class ChapterController extends Controller { $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); - return view('chapters/show', ['book' => $book, 'chapter' => $chapter, 'current' => $chapter]); + $sidebarTree = $this->bookRepo->getChildren($book); + Views::add($chapter); + $this->setPageTitle($chapter->getShortName()); + return view('chapters/show', ['book' => $book, 'chapter' => $chapter, 'current' => $chapter, 'sidebarTree' => $sidebarTree]); } /** * Show the form for editing the specified chapter. - * * @param $bookSlug * @param $chapterSlug * @return Response @@ -94,12 +95,12 @@ class ChapterController extends Controller $this->checkPermission('chapter-update'); $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); + $this->setPageTitle('Edit Chapter' . $chapter->getShortName()); return view('chapters/edit', ['book' => $book, 'chapter' => $chapter, 'current' => $chapter]); } /** * Update the specified chapter in storage. - * * @param Request $request * @param $bookSlug * @param $chapterSlug @@ -112,7 +113,7 @@ class ChapterController extends Controller $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); $chapter->fill($request->all()); $chapter->slug = $this->chapterRepo->findSuitableSlug($chapter->name, $book->id, $chapter->id); - $chapter->updated_by = Auth::user()->id; + $chapter->updated_by = auth()->user()->id; $chapter->save(); Activity::add($chapter, 'chapter_update', $book->id); return redirect($chapter->getUrl()); @@ -129,12 +130,12 @@ class ChapterController extends Controller $this->checkPermission('chapter-delete'); $book = $this->bookRepo->getBySlug($bookSlug); $chapter = $this->chapterRepo->getBySlug($chapterSlug, $book->id); + $this->setPageTitle('Delete Chapter' . $chapter->getShortName()); return view('chapters/delete', ['book' => $book, 'chapter' => $chapter, 'current' => $chapter]); } /** * Remove the specified chapter from storage. - * * @param $bookSlug * @param $chapterSlug * @return Response @@ -144,15 +145,8 @@ class ChapterController extends Controller $this->checkPermission('chapter-delete'); $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(); - } - } - Activity::removeEntity($chapter); Activity::addMessage('chapter_delete', $book->id, $chapter->name); - $chapter->delete(); + $this->chapterRepo->destroy($chapter); return redirect($book->getUrl()); } }