mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-25 12:09:45 +08:00
42 lines
1.2 KiB
PHP
42 lines
1.2 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace BookStack\Entities\Queries;
|
||
|
|
||
|
use BookStack\Entities\Models\PageRevision;
|
||
|
use Illuminate\Database\Eloquent\Builder;
|
||
|
|
||
|
class PageRevisionQueries
|
||
|
{
|
||
|
public function start(): Builder
|
||
|
{
|
||
|
return PageRevision::query();
|
||
|
}
|
||
|
|
||
|
public function findLatestVersionBySlugs(string $bookSlug, string $pageSlug): ?PageRevision
|
||
|
{
|
||
|
return PageRevision::query()
|
||
|
->whereHas('page', function (Builder $query) {
|
||
|
$query->scopes('visible');
|
||
|
})
|
||
|
->where('slug', '=', $pageSlug)
|
||
|
->where('type', '=', 'version')
|
||
|
->where('book_slug', '=', $bookSlug)
|
||
|
->orderBy('created_at', 'desc')
|
||
|
->first();
|
||
|
}
|
||
|
|
||
|
public function findLatestCurrentUserDraftsForPageId(int $pageId): ?PageRevision
|
||
|
{
|
||
|
return $this->latestCurrentUserDraftsForPageId($pageId)->first();
|
||
|
}
|
||
|
|
||
|
public function latestCurrentUserDraftsForPageId(int $pageId): Builder
|
||
|
{
|
||
|
return $this->start()
|
||
|
->where('created_by', '=', user()->id)
|
||
|
->where('type', 'update_draft')
|
||
|
->where('page_id', '=', $pageId)
|
||
|
->orderBy('created_at', 'desc');
|
||
|
}
|
||
|
}
|