$templates = $this->queries->pages->visibleTemplates()
->orderBy('name', 'asc')
->take(10)
- ->get();
+ ->paginate()
+ ->withPath('/templates');
$draftsEnabled = auth()->check();
}
// Check for a current draft version for this user
- $userDraft = $this->queries->revisions->findLatestCurrentUserDraftsForPageId($page->id)->first();
+ $userDraft = $this->queries->revisions->findLatestCurrentUserDraftsForPageId($page->id);
if (!is_null($userDraft)) {
$page->forceFill($userDraft->only(['name', 'html', 'markdown']));
$isDraftRevision = true;
];
}
- protected function updateContentForEditor(Page $page, string $editorType): void
+ protected function updateContentForEditor(Page $page, PageEditorType $editorType): void
{
$isHtml = !empty($page->html) && empty($page->markdown);
// HTML to markdown-clean conversion
- if ($editorType === 'markdown' && $isHtml && $this->requestedEditor === 'markdown-clean') {
+ if ($editorType === PageEditorType::Markdown && $isHtml && $this->requestedEditor === 'markdown-clean') {
$page->markdown = (new HtmlToMarkdown($page->html))->convert();
}
// Markdown to HTML conversion if we don't have HTML
- if ($editorType === 'wysiwyg' && !$isHtml) {
+ if ($editorType->isHtmlBased() && !$isHtml) {
$page->html = (new MarkdownToHtml($page->markdown))->convert();
}
}
* Defaults based upon the current content of the page otherwise will fall back
* to system default but will take a requested type (if provided) if permissions allow.
*/
- protected function getEditorType(Page $page): string
+ protected function getEditorType(Page $page): PageEditorType
{
- $editorType = $page->editor ?: self::getSystemDefaultEditor();
+ $editorType = PageEditorType::forPage($page) ?: PageEditorType::getSystemDefault();
// Use requested editor if valid and if we have permission
- $requestedType = explode('-', $this->requestedEditor)[0];
- if (($requestedType === 'markdown' || $requestedType === 'wysiwyg') && userCan('editor-change')) {
+ $requestedType = PageEditorType::fromRequestValue($this->requestedEditor);
+ if ($requestedType && userCan('editor-change')) {
$editorType = $requestedType;
}
return $editorType;
}
-
- /**
- * Get the configured system default editor.
- */
- public static function getSystemDefaultEditor(): string
- {
- return setting('app-editor') === 'markdown' ? 'markdown' : 'wysiwyg';
- }
}