]> BookStack Code Mirror - bookstack/blob - resources/views/pages/form-toolbox.blade.php
d69be20c154702c2a64fd9083643cc806c8f8c6d
[bookstack] / resources / views / pages / form-toolbox.blade.php
1
2 <div editor-toolbox class="floating-toolbox">
3
4     <div class="tabs primary-background-light">
5         <span toolbox-toggle>@icon('caret-left-circle')</span>
6         <span toolbox-tab-button="tags" title="{{ trans('entities.page_tags') }}" class="active">@icon('tag')</span>
7         @if(userCan('attachment-create-all'))
8             <span toolbox-tab-button="files" title="{{ trans('entities.attachments') }}">@icon('attach')</span>
9         @endif
10     </div>
11
12     <div toolbox-tab-content="tags">
13         <h4>{{ trans('entities.page_tags') }}</h4>
14         <div class="px-l">
15             @include('components.tag-manager', ['entity' => $page, 'entityType' => 'page'])
16         </div>
17     </div>
18
19     @if(userCan('attachment-create-all'))
20         <div toolbox-tab-content="files" id="attachment-manager" page-id="{{ $page->id ?? 0 }}">
21
22             @exposeTranslations([
23                 'entities.attachments_file_uploaded',
24                 'entities.attachments_file_updated',
25                 'entities.attachments_link_attached',
26                 'entities.attachments_updated_success',
27                 'errors.server_upload_limit',
28                 'components.image_upload_remove',
29                 'components.file_upload_timeout',
30             ])
31
32             <h4>{{ trans('entities.attachments') }}</h4>
33             <div class="px-l files">
34
35                 <div id="file-list" v-show="!fileToEdit">
36                     <p class="text-muted small">{{ trans('entities.attachments_explain') }} <span class="text-warn">{{ trans('entities.attachments_explain_instant_save') }}</span></p>
37
38                     <div class="tab-container">
39                         <div class="nav-tabs">
40                             <div @click="tab = 'list'" :class="{selected: tab === 'list'}" class="tab-item">{{ trans('entities.attachments_items') }}</div>
41                             <div @click="tab = 'file'" :class="{selected: tab === 'file'}" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
42                             <div @click="tab = 'link'" :class="{selected: tab === 'link'}" class="tab-item">{{ trans('entities.attachments_link') }}</div>
43                         </div>
44                         <div v-show="tab === 'list'">
45                             <draggable style="width: 100%;" :options="{handle: '.handle'}" @change="fileSortUpdate" :list="files" element="div">
46                                 <div v-for="(file, index) in files" :key="file.id" class="card drag-card">
47                                     <div class="handle">@icon('grip')</div>
48                                     <div class="py-s">
49                                         <a :href="getFileUrl(file)" target="_blank" v-text="file.name"></a>
50                                         <div v-if="file.deleting">
51                                             <span class="text-neg small">{{ trans('entities.attachments_delete_confirm') }}</span>
52                                             <br>
53                                             <span class="text-primary small" @click="file.deleting = false;">{{ trans('common.cancel') }}</span>
54                                         </div>
55                                     </div>
56                                     <div @click="startEdit(file)" class="drag-card-action text-center text-primary">@icon('edit')</div>
57                                     <div @click="deleteFile(file)" class="drag-card-action text-center text-neg">@icon('close')</div>
58                                 </div>
59                             </draggable>
60                             <p class="small text-muted" v-if="files.length === 0">
61                                 {{ trans('entities.attachments_no_files') }}
62                             </p>
63                         </div>
64                         <div v-show="tab === 'file'">
65                             <dropzone placeholder="{{ trans('entities.attachments_dropzone') }}" :upload-url="getUploadUrl()" :uploaded-to="pageId" @success="uploadSuccess"></dropzone>
66                         </div>
67                         <div v-show="tab === 'link'" @keypress.enter.prevent="attachNewLink(file)">
68                             <p class="text-muted small">{{ trans('entities.attachments_explain_link') }}</p>
69                             <div class="form-group">
70                                 <label for="attachment-via-link">{{ trans('entities.attachments_link_name') }}</label>
71                                 <input type="text" placeholder="{{ trans('entities.attachments_link_name') }}" v-model="file.name">
72                                 <p class="small text-neg" v-for="error in errors.link.name" v-text="error"></p>
73                             </div>
74                             <div class="form-group">
75                                 <label for="attachment-via-link">{{ trans('entities.attachments_link_url') }}</label>
76                                 <input type="text"  placeholder="{{ trans('entities.attachments_link_url_hint') }}" v-model="file.link">
77                                 <p class="small text-neg" v-for="error in errors.link.link" v-text="error"></p>
78                             </div>
79                             <button @click.prevent="attachNewLink(file)" class="button primary">{{ trans('entities.attach') }}</button>
80
81                         </div>
82                     </div>
83
84                 </div>
85
86                 <div id="file-edit" v-if="fileToEdit" @keypress.enter.prevent="updateFile(fileToEdit)">
87                     <h5>{{ trans('entities.attachments_edit_file') }}</h5>
88
89                     <div class="form-group">
90                         <label for="attachment-name-edit">{{ trans('entities.attachments_edit_file_name') }}</label>
91                         <input type="text" id="attachment-name-edit" placeholder="{{ trans('entities.attachments_edit_file_name') }}" v-model="fileToEdit.name">
92                         <p class="small text-neg" v-for="error in errors.edit.name" v-text="error"></p>
93                     </div>
94
95                     <div class="tab-container">
96                         <div class="nav-tabs">
97                             <div @click="editTab = 'file'" :class="{selected: editTab === 'file'}" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
98                             <div @click="editTab = 'link'" :class="{selected: editTab === 'link'}" class="tab-item">{{ trans('entities.attachments_set_link') }}</div>
99                         </div>
100                         <div v-if="editTab === 'file'">
101                             <dropzone :upload-url="getUploadUrl(fileToEdit)" :uploaded-to="pageId" placeholder="{{ trans('entities.attachments_edit_drop_upload') }}" @success="uploadSuccessUpdate"></dropzone>
102                             <br>
103                         </div>
104                         <div v-if="editTab === 'link'">
105                             <div class="form-group">
106                                 <label for="attachment-link-edit">{{ trans('entities.attachments_link_url') }}</label>
107                                 <input type="text" id="attachment-link-edit" placeholder="{{ trans('entities.attachment_link') }}" v-model="fileToEdit.link">
108                                 <p class="small text-neg" v-for="error in errors.edit.link" v-text="error"></p>
109                             </div>
110                         </div>
111                     </div>
112
113                     <button type="button" class="button outline" @click="cancelEdit">{{ trans('common.back') }}</button>
114                     <button @click.enter.prevent="updateFile(fileToEdit)" class="button primary">{{ trans('common.save') }}</button>
115                 </div>
116
117             </div>
118         </div>
119     @endif
120
121 </div>