mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-22 19:46:16 +08:00
54 lines
1.5 KiB
PHP
54 lines
1.5 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace BookStack\Entities\Queries;
|
||
|
|
||
|
use BookStack\Entities\Models\Chapter;
|
||
|
use BookStack\Exceptions\NotFoundException;
|
||
|
use Illuminate\Database\Eloquent\Builder;
|
||
|
|
||
|
class ChapterQueries implements ProvidesEntityQueries
|
||
|
{
|
||
|
protected static array $listAttributes = [
|
||
|
'id', 'slug', 'name', 'description', 'priority',
|
||
|
'created_at', 'updated_at',
|
||
|
'created_by', 'updated_by', 'owned_by',
|
||
|
];
|
||
|
|
||
|
public function start(): Builder
|
||
|
{
|
||
|
return Chapter::query();
|
||
|
}
|
||
|
|
||
|
public function findVisibleById(int $id): ?Chapter
|
||
|
{
|
||
|
return $this->start()->scopes('visible')->find($id);
|
||
|
}
|
||
|
|
||
|
public function findVisibleBySlugs(string $bookSlug, string $chapterSlug): Chapter
|
||
|
{
|
||
|
/** @var ?Chapter $chapter */
|
||
|
$chapter = $this->start()->with('book')
|
||
|
->whereHas('book', function (Builder $query) use ($bookSlug) {
|
||
|
$query->where('slug', '=', $bookSlug);
|
||
|
})
|
||
|
->where('slug', '=', $chapterSlug)
|
||
|
->first();
|
||
|
|
||
|
if ($chapter === null) {
|
||
|
throw new NotFoundException(trans('errors.chapter_not_found'));
|
||
|
}
|
||
|
|
||
|
return $chapter;
|
||
|
}
|
||
|
|
||
|
public function visibleForList(): Builder
|
||
|
{
|
||
|
return $this->start()
|
||
|
->select(array_merge(static::$listAttributes, ['book_slug' => function ($builder) {
|
||
|
$builder->select('slug')
|
||
|
->from('books')
|
||
|
->whereColumn('books.id', '=', 'chapters.book_id');
|
||
|
}]));
|
||
|
}
|
||
|
}
|