mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-11 12:03:35 +08:00
76d02cd472
Added a document to try to define things. Updated the loading so components are registed dynamically. Added some standardised ways to reference other elems & define options
90 lines
4.7 KiB
PHP
90 lines
4.7 KiB
PHP
<div class="page-editor flex-fill flex" id="page-editor"
|
|
drafts-enabled="{{ $draftsEnabled ? 'true' : 'false' }}"
|
|
@if(config('services.drawio'))
|
|
drawio-url="{{ is_string(config('services.drawio')) ? config('services.drawio') : 'https://www.draw.io/?embed=1&proto=json&spin=1' }}"
|
|
@endif
|
|
editor-type="{{ setting('app-editor') }}"
|
|
page-id="{{ $model->id ?? 0 }}"
|
|
text-direction="{{ config('app.rtl') ? 'rtl' : 'ltr' }}"
|
|
page-new-draft="{{ $model->draft ?? 0 }}"
|
|
page-update-draft="{{ $model->isDraft ?? 0 }}">
|
|
|
|
@exposeTranslations([
|
|
'entities.pages_editing_draft',
|
|
'entities.pages_editing_page',
|
|
'errors.page_draft_autosave_fail',
|
|
'entities.pages_editing_page',
|
|
'entities.pages_draft_discarded',
|
|
'entities.pages_edit_set_changelog',
|
|
])
|
|
|
|
{{--Header Bar--}}
|
|
<div class="primary-background-light toolbar page-edit-toolbar">
|
|
<div class="grid third no-break v-center">
|
|
|
|
<div class="action-buttons text-left px-m py-xs">
|
|
<a href="{{ back()->getTargetUrl() }}" class="text-button text-primary">@icon('back')<span class="hide-under-l">{{ trans('common.back') }}</span></a>
|
|
</div>
|
|
|
|
<div class="text-center px-m py-xs">
|
|
<div v-show="draftsEnabled"
|
|
component="dropdown"
|
|
option:dropdown:move-menu="true"
|
|
class="dropdown-container draft-display text">
|
|
<button type="button" refs="dropdown@toggle" aria-haspopup="true" aria-expanded="false" title="{{ trans('entities.pages_edit_draft_options') }}" class="text-primary text-button"><span class="faded-text" v-text="draftText"></span> @icon('more')</button>
|
|
@icon('check-circle', ['class' => 'text-pos draft-notification svg-icon', ':class' => '{visible: draftUpdated}'])
|
|
<ul refs="dropdown@menu" class="dropdown-menu" role="menu">
|
|
<li>
|
|
<button type="button" @click="saveDraft()" class="text-pos">@icon('save'){{ trans('entities.pages_edit_save_draft') }}</button>
|
|
</li>
|
|
<li v-if="isNewDraft">
|
|
<a href="{{ $model->getUrl('/delete') }}" class="text-neg">@icon('delete'){{ trans('entities.pages_edit_delete_draft') }}</a>
|
|
</li>
|
|
<li v-if="isUpdateDraft">
|
|
<button type="button" @click="discardDraft" class="text-neg">@icon('cancel'){{ trans('entities.pages_edit_discard_draft') }}</button>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="action-buttons px-m py-xs" v-cloak>
|
|
<div component="dropdown" dropdown-move-menu class="dropdown-container">
|
|
<button refs="dropdown@toggle" type="button" aria-haspopup="true" aria-expanded="false" class="text-primary text-button">@icon('edit') <span v-text="changeSummaryShort"></span></button>
|
|
<ul refs="dropdown@menu" class="wide dropdown-menu">
|
|
<li class="px-l py-m">
|
|
<p class="text-muted pb-s">{{ trans('entities.pages_edit_enter_changelog_desc') }}</p>
|
|
<input name="summary" id="summary-input" type="text" placeholder="{{ trans('entities.pages_edit_enter_changelog') }}" v-model="changeSummary" />
|
|
</li>
|
|
</ul>
|
|
<span>{{-- Prevents button jumping on menu show --}}</span>
|
|
</div>
|
|
|
|
<button type="submit" id="save-button" class="float-left text-primary text-button text-pos-hover hide-under-m">@icon('save')<span>{{ trans('entities.pages_save') }}</span></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
{{--Title input--}}
|
|
<div class="title-input page-title clearfix" v-pre>
|
|
<div class="input" @if($model->name === trans('entities.pages_initial_name')) is-default-value @endif>
|
|
@include('form.text', ['name' => 'name', 'model' => $model, 'placeholder' => trans('entities.pages_title')])
|
|
</div>
|
|
</div>
|
|
|
|
{{--Editors--}}
|
|
<div class="edit-area flex-fill flex">
|
|
|
|
{{--WYSIWYG Editor--}}
|
|
@if(setting('app-editor') === 'wysiwyg')
|
|
@include('pages.wysiwyg-editor', ['model' => $model])
|
|
@endif
|
|
|
|
{{--Markdown Editor--}}
|
|
@if(setting('app-editor') === 'markdown')
|
|
@include('pages.markdown-editor', ['model' => $model])
|
|
@endif
|
|
|
|
</div>
|
|
|
|
<button type="submit" id="save-button-mobile" title="{{ trans('entities.pages_save') }}" class="text-primary text-button hide-over-m page-save-mobile-button">@icon('save')</button>
|
|
</div> |