<?php namespace BookStack\Entities\Models;
use BookStack\Uploads\Image;
+use Illuminate\Database\Eloquent\Collection;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
return $this->books()->visible();
}
+ /**
+ * Get the books in this shelf that are visible to the current user with sorted by custom parameter
+ * @param string $sort - Chosen Column to be sorted
+ * @param string $order - Order of the sort
+ * @return Collection
+ */
+ public function visibleBooksByCustomSorting(string $sort = 'name', string $order = 'asc'): Collection
+ {
+ return $this->belongsToMany(Book::class, 'bookshelves_books', 'bookshelf_id', 'book_id')
+ ->orderBy($sort, $order)
+ ->visible()
+ ->get();
+ }
+
/**
* Get the url for this bookshelf.
*/
$shelf = $this->bookshelfRepo->getBySlug($slug);
$this->checkOwnablePermission('book-view', $shelf);
+ $sort = setting()->getForCurrentUser('books_sort', 'name');
+ $order = setting()->getForCurrentUser('books_sort_order', 'asc');
+
Views::add($shelf);
$this->entityContextManager->setShelfContext($shelf->id);
$view = setting()->getForCurrentUser('bookshelf_view_type', config('app.views.books'));
return view('shelves.show', [
'shelf' => $shelf,
'view' => $view,
- 'activity' => Activity::entityActivity($shelf, 20, 1)
+ 'activity' => Activity::entityActivity($shelf, 20, 1),
+ 'order' => $order,
+ 'sort' => $sort
]);
}
</div>
<main class="card content-wrap">
- <h1 class="break-text">{{$shelf->name}}</h1>
+
+ <div class="grid half v-center">
+ <h1 class="break-text">{{$shelf->name}}</h1>
+ <div class="text-m-right my-m">
+ @include('partials.sort', ['options' => [
+ 'name' => trans('common.sort_name'),
+ 'created_at' => trans('common.sort_created_at'),
+ 'updated_at' => trans('common.sort_updated_at'),
+ ], 'order' => $order, 'sort' => $sort, 'type' => 'books'])
+ </div>
+ </div>
+
<div class="book-content">
<p class="text-muted">{!! nl2br(e($shelf->description)) !!}</p>
- @if(count($shelf->visibleBooks) > 0)
+ @if(count($shelf->visibleBooksByCustomSorting($sort, $order)) > 0)
@if($view === 'list')
<div class="entity-list">
- @foreach($shelf->visibleBooks as $book)
+ @foreach($shelf->visibleBooksByCustomSorting($sort, $order) as $book)
@include('books.list-item', ['book' => $book])
@endforeach
</div>
@else
<div class="grid third">
- @foreach($shelf->visibleBooks as $key => $book)
+ @foreach($shelf->visibleBooksByCustomSorting($sort, $order) as $key => $book)
@include('partials.entity-grid-item', ['entity' => $book])
@endforeach
</div>