X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/a6633642232efd164d4708967ab59e498fbff896..refs/pull/3499/head:/app/Http/Controllers/BookshelfController.php diff --git a/app/Http/Controllers/BookshelfController.php b/app/Http/Controllers/BookshelfController.php index 32c22e185..a294bf731 100644 --- a/app/Http/Controllers/BookshelfController.php +++ b/app/Http/Controllers/BookshelfController.php @@ -1,21 +1,22 @@ -getForCurrentUser('bookshelves_view_type', config('app.views.bookshelves', 'grid')); + $view = setting()->getForCurrentUser('bookshelves_view_type'); $sort = setting()->getForCurrentUser('bookshelves_sort', 'name'); $order = setting()->getForCurrentUser('bookshelves_sort_order', 'asc'); $sortOptions = [ - 'name' => trans('common.sort_name'), + 'name' => trans('common.sort_name'), 'created_at' => trans('common.sort_created_at'), 'updated_at' => trans('common.sort_updated_at'), ]; @@ -48,14 +49,15 @@ class BookshelfController extends Controller $this->entityContextManager->clearShelfContext(); $this->setPageTitle(trans('entities.shelves')); + return view('shelves.index', [ - 'shelves' => $shelves, - 'recents' => $recents, - 'popular' => $popular, - 'new' => $new, - 'view' => $view, - 'sort' => $sort, - 'order' => $order, + 'shelves' => $shelves, + 'recents' => $recents, + 'popular' => $popular, + 'new' => $new, + 'view' => $view, + 'sort' => $sort, + 'order' => $order, 'sortOptions' => $sortOptions, ]); } @@ -68,48 +70,63 @@ class BookshelfController extends Controller $this->checkPermission('bookshelf-create-all'); $books = Book::hasPermission('update')->get(); $this->setPageTitle(trans('entities.shelves_create')); + return view('shelves.create', ['books' => $books]); } /** * Store a newly created bookshelf in storage. + * * @throws ValidationException * @throws ImageUploadException */ public function store(Request $request) { $this->checkPermission('bookshelf-create-all'); - $this->validate($request, [ - 'name' => 'required|string|max:255', - 'description' => 'string|max:1000', - 'image' => 'nullable|' . $this->getImageValidationRules(), + $validated = $this->validate($request, [ + 'name' => ['required', 'string', 'max:255'], + 'description' => ['string', 'max:1000'], + 'image' => array_merge(['nullable'], $this->getImageValidationRules()), + 'tags' => ['array'], ]); $bookIds = explode(',', $request->get('books', '')); - $shelf = $this->bookshelfRepo->create($request->all(), $bookIds); - $this->bookshelfRepo->updateCoverImage($shelf, $request->file('image', null)); + $shelf = $this->bookshelfRepo->create($validated, $bookIds); return redirect($shelf->getUrl()); } /** * Display the bookshelf of the given slug. + * * @throws NotFoundException */ - public function show(string $slug) + public function show(ActivityQueries $activities, string $slug) { $shelf = $this->bookshelfRepo->getBySlug($slug); $this->checkOwnablePermission('book-view', $shelf); - Views::add($shelf); + $sort = setting()->getForCurrentUser('shelf_books_sort', 'default'); + $order = setting()->getForCurrentUser('shelf_books_sort_order', 'asc'); + + $sortedVisibleShelfBooks = $shelf->visibleBooks()->get() + ->sortBy($sort === 'default' ? 'pivot.order' : $sort, SORT_REGULAR, $order === 'desc') + ->values() + ->all(); + + View::incrementFor($shelf); $this->entityContextManager->setShelfContext($shelf->id); - $view = setting()->getForCurrentUser('bookshelf_view_type', config('app.views.books')); + $view = setting()->getForCurrentUser('bookshelf_view_type'); $this->setPageTitle($shelf->getShortName()); + return view('shelves.show', [ - 'shelf' => $shelf, - 'view' => $view, - 'activity' => Activity::entityActivity($shelf, 20, 1) + 'shelf' => $shelf, + 'sortedVisibleShelfBooks' => $sortedVisibleShelfBooks, + 'view' => $view, + 'activity' => $activities->entityActivity($shelf, 20, 1), + 'order' => $order, + 'sort' => $sort, ]); } @@ -125,6 +142,7 @@ class BookshelfController extends Controller $books = Book::hasPermission('update')->whereNotIn('id', $shelfBookIds)->get(); $this->setPageTitle(trans('entities.shelves_edit_named', ['name' => $shelf->getShortName()])); + return view('shelves.edit', [ 'shelf' => $shelf, 'books' => $books, @@ -133,6 +151,7 @@ class BookshelfController extends Controller /** * Update the specified bookshelf in storage. + * * @throws ValidationException * @throws ImageUploadException * @throws NotFoundException @@ -141,23 +160,27 @@ class BookshelfController extends Controller { $shelf = $this->bookshelfRepo->getBySlug($slug); $this->checkOwnablePermission('bookshelf-update', $shelf); - $this->validate($request, [ - 'name' => 'required|string|max:255', - 'description' => 'string|max:1000', - 'image' => 'nullable|' . $this->getImageValidationRules(), + $validated = $this->validate($request, [ + 'name' => ['required', 'string', 'max:255'], + 'description' => ['string', 'max:1000'], + 'image' => array_merge(['nullable'], $this->getImageValidationRules()), + 'tags' => ['array'], ]); + if ($request->has('image_reset')) { + $validated['image'] = null; + } elseif (array_key_exists('image', $validated) && is_null($validated['image'])) { + unset($validated['image']); + } $bookIds = explode(',', $request->get('books', '')); - $shelf = $this->bookshelfRepo->update($shelf, $request->all(), $bookIds); - $resetCover = $request->has('image_reset'); - $this->bookshelfRepo->updateCoverImage($shelf, $request->file('image', null), $resetCover); + $shelf = $this->bookshelfRepo->update($shelf, $validated, $bookIds); return redirect($shelf->getUrl()); } /** - * Shows the page to confirm deletion + * Shows the page to confirm deletion. */ public function showDelete(string $slug) { @@ -165,11 +188,13 @@ class BookshelfController extends Controller $this->checkOwnablePermission('bookshelf-delete', $shelf); $this->setPageTitle(trans('entities.shelves_delete_named', ['name' => $shelf->getShortName()])); + return view('shelves.delete', ['shelf' => $shelf]); } /** * Remove the specified bookshelf from storage. + * * @throws Exception */ public function destroy(string $slug) @@ -206,6 +231,7 @@ class BookshelfController extends Controller $permissionsUpdater->updateFromPermissionsForm($shelf, $request); $this->showSuccessNotification(trans('entities.shelves_permissions_updated')); + return redirect($shelf->getUrl()); } @@ -219,6 +245,7 @@ class BookshelfController extends Controller $updateCount = $this->bookshelfRepo->copyDownPermissions($shelf); $this->showSuccessNotification(trans('entities.shelves_copy_permission_success', ['count' => $updateCount])); + return redirect($shelf->getUrl()); } }