mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-26 17:04:01 +08:00
73 lines
1.8 KiB
PHP
73 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace BookStack\Entities\Queries;
|
|
|
|
use BookStack\Entities\Models\Book;
|
|
use BookStack\Exceptions\NotFoundException;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
|
|
class BookQueries implements ProvidesEntityQueries
|
|
{
|
|
protected static array $listAttributes = [
|
|
'id', 'slug', 'name', 'description',
|
|
'created_at', 'updated_at', 'image_id', 'owned_by',
|
|
];
|
|
|
|
public function start(): Builder
|
|
{
|
|
return Book::query();
|
|
}
|
|
|
|
public function findVisibleById(int $id): ?Book
|
|
{
|
|
return $this->start()->scopes('visible')->find($id);
|
|
}
|
|
|
|
public function findVisibleByIdOrFail(int $id): Book
|
|
{
|
|
return $this->start()->scopes('visible')->findOrFail($id);
|
|
}
|
|
|
|
public function findVisibleBySlugOrFail(string $slug): Book
|
|
{
|
|
/** @var ?Book $book */
|
|
$book = $this->start()
|
|
->scopes('visible')
|
|
->where('slug', '=', $slug)
|
|
->first();
|
|
|
|
if ($book === null) {
|
|
throw new NotFoundException(trans('errors.book_not_found'));
|
|
}
|
|
|
|
return $book;
|
|
}
|
|
|
|
public function visibleForList(): Builder
|
|
{
|
|
return $this->start()->scopes('visible')
|
|
->select(static::$listAttributes);
|
|
}
|
|
|
|
public function visibleForListWithCover(): Builder
|
|
{
|
|
return $this->visibleForList()->with('cover');
|
|
}
|
|
|
|
public function recentlyViewedForCurrentUser(): Builder
|
|
{
|
|
return $this->visibleForList()
|
|
->scopes('withLastView')
|
|
->having('last_viewed_at', '>', 0)
|
|
->orderBy('last_viewed_at', 'desc');
|
|
}
|
|
|
|
public function popularForList(): Builder
|
|
{
|
|
return $this->visibleForList()
|
|
->scopes('withViewCount')
|
|
->having('view_count', '>', 0)
|
|
->orderBy('view_count', 'desc');
|
|
}
|
|
}
|