X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/c429cf78187e80deb63982a282a1c6889f30291a..refs/pull/5685/head:/app/Entities/Tools/PageEditActivity.php diff --git a/app/Entities/Tools/PageEditActivity.php b/app/Entities/Tools/PageEditActivity.php index a88dea830..646b200f1 100644 --- a/app/Entities/Tools/PageEditActivity.php +++ b/app/Entities/Tools/PageEditActivity.php @@ -9,7 +9,7 @@ use Illuminate\Database\Eloquent\Builder; class PageEditActivity { - protected $page; + protected Page $page; /** * PageEditActivity constructor. @@ -21,8 +21,6 @@ class PageEditActivity /** * Check if there's active editing being performed on this page. - * - * @return bool */ public function hasActiveEditing(): bool { @@ -37,18 +35,50 @@ class PageEditActivity $pageDraftEdits = $this->activePageEditingQuery(60)->get(); $count = $pageDraftEdits->count(); - $userMessage = $count > 1 ? trans('entities.pages_draft_edit_active.start_a', ['count' => $count]) : trans('entities.pages_draft_edit_active.start_b', ['userName' => $pageDraftEdits->first()->createdBy->name]); - $timeMessage = trans('entities.pages_draft_edit_active.time_b', ['minCount'=> 60]); + $userMessage = trans('entities.pages_draft_edit_active.start_a', ['count' => $count]); + if ($count === 1) { + /** @var PageRevision $firstDraft */ + $firstDraft = $pageDraftEdits->first(); + $userMessage = trans('entities.pages_draft_edit_active.start_b', ['userName' => $firstDraft->createdBy->name ?? '']); + } + + $timeMessage = trans('entities.pages_draft_edit_active.time_b', ['minCount' => 60]); return trans('entities.pages_draft_edit_active.message', ['start' => $userMessage, 'time' => $timeMessage]); } /** - * Get the message to show when the user will be editing one of their drafts. + * Get any editor clash warning messages to show for the given draft revision. * - * @param PageRevision $draft + * @param PageRevision|Page $draft * - * @return string + * @return string[] + */ + public function getWarningMessagesForDraft($draft): array + { + $warnings = []; + + if ($this->hasActiveEditing()) { + $warnings[] = $this->activeEditingMessage(); + } + + if ($draft instanceof PageRevision && $this->hasPageBeenUpdatedSinceDraftCreated($draft)) { + $warnings[] = trans('entities.pages_draft_page_changed_since_creation'); + } + + return $warnings; + } + + /** + * Check if the page has been updated since the draft has been saved. + */ + protected function hasPageBeenUpdatedSinceDraftCreated(PageRevision $draft): bool + { + return $draft->page->updated_at->timestamp > $draft->created_at->timestamp; + } + + /** + * Get the message to show when the user will be editing one of their drafts. */ public function getEditingActiveDraftMessage(PageRevision $draft): string {