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