2 <div editor-toolbox class="floating-toolbox">
4 <div class="tabs primary-background-light">
5 <span toolbox-toggle><i class="zmdi zmdi-caret-left-circle"></i></span>
6 <span toolbox-tab-button="tags" title="{{ trans('entities.page_tags') }}" class="active"><i class="zmdi zmdi-tag"></i></span>
7 @if(userCan('attachment-create-all'))
8 <span toolbox-tab-button="files" title="{{ trans('entities.attachments') }}"><i class="zmdi zmdi-attachment"></i></span>
12 <div toolbox-tab-content="tags" id="tag-manager" page-id="{{ $page->id or 0 }}">
13 <h4>{{ trans('entities.page_tags') }}</h4>
14 <div class="padded tags">
15 <p class="muted small">{!! nl2br(e(trans('entities.tags_explain'))) !!}</p>
18 <draggable :options="{handle: '.handle'}" :list="tags" element="div">
19 <div v-for="(tag, i) in tags" :key="tag.key" class="card drag-card">
20 <div class="handle" ><i class="zmdi zmdi-menu"></i></div>
22 <autosuggest url="{{ baseUrl('/ajax/tags/suggest/names') }}" type="name" class="outline" :name="getTagFieldName(i, 'name')"
23 v-model="tag.name" @input="tagChange(tag)" @blur="tagBlur(tag)" placeholder="{{ trans('entities.tag') }}"/>
26 <autosuggest url="{{ baseUrl('/ajax/tags/suggest/values') }}" type="value" class="outline" :name="getTagFieldName(i, 'value')"
27 v-model="tag.value" @change="tagChange(tag)" @blur="tagBlur(tag)" placeholder="{{ trans('entities.tag_value') }}"/>
29 <div v-show="tags.length !== 1" class="text-center drag-card-action text-neg" @click="removeTag(tag)"><i class="zmdi zmdi-close"></i></div>
33 <button @click="addEmptyTag" type="button" class="text-button">{{ trans('entities.tags_add') }}</button>
38 @if(userCan('attachment-create-all'))
39 <div toolbox-tab-content="files" id="attachment-manager" page-id="{{ $page->id or 0 }}">
40 <h4>{{ trans('entities.attachments') }}</h4>
41 <div class="padded files">
43 <div id="file-list" v-show="!fileToEdit">
44 <p class="muted small">{{ trans('entities.attachments_explain') }} <span class="secondary">{{ trans('entities.attachments_explain_instant_save') }}</span></p>
46 <div class="tab-container">
47 <div class="nav-tabs">
48 <div @click="tab = 'list'" :class="{selected: tab === 'list'}" class="tab-item">{{ trans('entities.attachments_items') }}</div>
49 <div @click="tab = 'file'" :class="{selected: tab === 'file'}" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
50 <div @click="tab = 'link'" :class="{selected: tab === 'link'}" class="tab-item">{{ trans('entities.attachments_link') }}</div>
52 <div v-show="tab === 'list'">
53 <draggable style="width: 100%;" :options="{handle: '.handle'}" @change="fileSortUpdate" :list="files" element="div">
54 <div v-for="(file, index) in files" :key="file.id" class="card drag-card">
55 <div class="handle"><i class="zmdi zmdi-menu"></i></div>
57 <a :href="getFileUrl(file)" target="_blank" v-text="file.name"></a>
58 <div v-if="file.deleting">
59 <span class="neg small">{{ trans('entities.attachments_delete_confirm') }}</span>
61 <span class="text-primary small" @click="file.deleting = false;">{{ trans('common.cancel') }}</span>
64 <div @click="startEdit(file)" class="drag-card-action text-center text-primary" style="padding: 0;"><i class="zmdi zmdi-edit"></i></div>
65 <div @click="deleteFile(file)" class="drag-card-action text-center text-neg" style="padding: 0;"><i class="zmdi zmdi-close"></i></div>
68 <p class="small muted" v-if="files.length === 0">
69 {{ trans('entities.attachments_no_files') }}
72 <div v-show="tab === 'file'">
73 <dropzone placeholder="{{ trans('entities.attachments_dropzone') }}" :upload-url="getUploadUrl()" :uploaded-to="pageId" @success="uploadSuccess"></dropzone>
75 <div v-show="tab === 'link'" @keypress.enter.prevent="attachNewLink(file)">
76 <p class="muted small">{{ trans('entities.attachments_explain_link') }}</p>
77 <div class="form-group">
78 <label for="attachment-via-link">{{ trans('entities.attachments_link_name') }}</label>
79 <input type="text" placeholder="{{ trans('entities.attachments_link_name') }}" v-model="file.name">
80 <p class="small neg" v-for="error in errors.link.name" v-text="error"></p>
82 <div class="form-group">
83 <label for="attachment-via-link">{{ trans('entities.attachments_link_url') }}</label>
84 <input type="text" placeholder="{{ trans('entities.attachments_link_url_hint') }}" v-model="file.link">
85 <p class="small neg" v-for="error in errors.link.link" v-text="error"></p>
87 <button @click.prevent="attachNewLink(file)" class="button pos">{{ trans('entities.attach') }}</button>
94 <div id="file-edit" v-if="fileToEdit" @keypress.enter.prevent="updateFile(fileToEdit)">
95 <h5>{{ trans('entities.attachments_edit_file') }}</h5>
97 <div class="form-group">
98 <label for="attachment-name-edit">{{ trans('entities.attachments_edit_file_name') }}</label>
99 <input type="text" id="attachment-name-edit" placeholder="{{ trans('entities.attachments_edit_file_name') }}" v-model="fileToEdit.name">
100 <p class="small neg" v-for="error in errors.edit.name" v-text="error"></p>
103 <div class="tab-container">
104 <div class="nav-tabs">
105 <div @click="editTab = 'file'" :class="{selected: editTab === 'file'}" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
106 <div @click="editTab = 'link'" :class="{selected: editTab === 'link'}" class="tab-item">{{ trans('entities.attachments_set_link') }}</div>
108 <div v-if="editTab === 'file'">
109 <dropzone :upload-url="getUploadUrl(fileToEdit)" :uploaded-to="pageId" placeholder="{{ trans('entities.attachments_edit_drop_upload') }}" @success="uploadSuccessUpdate"></dropzone>
112 <div v-if="editTab === 'link'">
113 <div class="form-group">
114 <label for="attachment-link-edit">{{ trans('entities.attachments_link_url') }}</label>
115 <input type="text" id="attachment-link-edit" placeholder="{{ trans('entities.attachment_link') }}" v-model="fileToEdit.link">
116 <p class="small neg" v-for="error in errors.edit.link" v-text="error"></p>
121 <button type="button" class="button outline" @click="cancelEdit">{{ trans('common.back') }}</button>
122 <button @click.enter.prevent="updateFile(fileToEdit)" class="button pos">{{ trans('common.save') }}</button>