pageRepo = $pageRepo; $this->bookRepo = $bookRepo; } /** * Display a listing of the resource. * * @return Response */ public function index() { // } /** * Show the form for creating a new resource. * * @param $bookSlug * @param bool $pageSlug * @return Response */ public function create($bookSlug, $pageSlug = false) { $book = $this->bookRepo->getBySlug($bookSlug); $page = $pageSlug ? $this->pageRepo->getBySlug($pageSlug, $book->id) : false; return view('pages/create', ['book' => $book, 'parentPage' => $page]); } /** * Store a newly created resource in storage. * * @param Request $request * @param $bookSlug * @return Response */ public function store(Request $request, $bookSlug) { $this->validate($request, [ 'name' => 'required|string|max:255', 'html' => 'required|string', 'parent' => 'integer|exists:pages,id' ]); $book = $this->bookRepo->getBySlug($bookSlug); $page = $this->pageRepo->newFromInput($request->all()); $slug = Str::slug($page->name); while($this->pageRepo->countBySlug($slug, $book->id) > 0) { $slug .= '1'; } $page->slug = $slug; $page->priority = $this->bookRepo->getNewPriority($book); if($request->has('parent')) { $page->page_id = $request->get('parent'); } $page->book_id = $book->id; $page->text = strip_tags($page->html); $page->save(); return redirect($page->getUrl()); } /** * Display the specified resource. * * @param $bookSlug * @param $pageSlug * @return Response */ public function show($bookSlug, $pageSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $page = $this->pageRepo->getBySlug($pageSlug, $book->id); $breadCrumbs = $this->pageRepo->getBreadCrumbs($page); //dd($sidebarBookTree); return view('pages/show', ['page' => $page, 'breadCrumbs' => $breadCrumbs, 'book' => $book]); } /** * Show the form for editing the specified resource. * * @param $bookSlug * @param $pageSlug * @return Response */ public function edit($bookSlug, $pageSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $page = $this->pageRepo->getBySlug($pageSlug, $book->id); return view('pages/edit', ['page' => $page]); } /** * Update the specified resource in storage. * * @param Request $request * @param $bookSlug * @param $pageSlug * @return Response */ public function update(Request $request, $bookSlug, $pageSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $page = $this->pageRepo->getBySlug($pageSlug, $book->id); $page->fill($request->all()); $slug = Str::slug($page->name); while($this->pageRepo->countBySlug($slug, $book->id) > 0 && $slug != $pageSlug) { $slug .= '1'; } $page->text = strip_tags($page->html); $page->save(); return redirect($page->getUrl()); } /** * Redirect from a special link url which * uses the page id rather than the name. * @param $pageId * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector */ public function redirectFromLink($pageId) { $page = $this->pageRepo->getById($pageId); return redirect($page->getUrl()); } /** * Search all available pages, Across all books. * @param Request $request * @return \Illuminate\Http\RedirectResponse|\Illuminate\View\View */ public function searchAll(Request $request) { $searchTerm = $request->get('term'); if(empty($searchTerm)) return redirect()->back(); $pages = $this->pageRepo->getBySearch($searchTerm); return view('pages/search-results', ['pages' => $pages, 'searchTerm' => $searchTerm]); } /** * Shows the view which allows pages to be re-ordered and sorted. * @param $bookSlug * @return \Illuminate\View\View */ public function sortPages($bookSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $tree = $this->bookRepo->getTree($book); return view('pages/sort', ['book' => $book, 'tree' => $tree]); } public function savePageSort($bookSlug, Request $request) { $book = $this->bookRepo->getBySlug($bookSlug); if(!$request->has('sort-tree')) { return redirect($book->getUrl()); } $sortMap = json_decode($request->get('sort-tree')); $this->pageRepo->applySortMap($sortMap, $book->id); return redirect($book->getUrl()); } public function showDelete($bookSlug, $pageSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $page = $this->pageRepo->getBySlug($pageSlug, $book->id); return view('pages/delete', ['book' => $book, 'page' => $page]); } /** * Remove the specified resource from storage. * * @param $bookSlug * @param $pageSlug * @return Response * @internal param int $id */ public function destroy($bookSlug, $pageSlug) { $book = $this->bookRepo->getBySlug($bookSlug); $page = $this->pageRepo->getBySlug($pageSlug, $book->id); $page->delete(); return redirect($book->getUrl()); } }