]> BookStack Code Mirror - bookstack/blob - resources/views/pages/form-toolbox.blade.php
Removes some unused code.
[bookstack] / resources / views / pages / form-toolbox.blade.php
1
2 <div toolbox class="floating-toolbox">
3
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>
9         @endif
10     </div>
11
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>
16
17             <draggable class="fake-table no-style tag-table" :options="{handle: '.handle'}" :list="tags" element="div">
18                 <transition-group tag="div">
19                     <div v-for="(tag, i) in tags" :key="tag.key">
20                         <div width="20" class="handle" ><i class="zmdi zmdi-menu"></i></div>
21                         <div>
22                             <autosuggest url="/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') }}"/>
24                         </div>
25                         <div>
26                             <autosuggest url="/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') }}"/>
28                         </div>
29                         <div width="10" v-show="tags.length !== 1" class="text-center text-neg" style="padding: 0;" @click="removeTag(tag)"><i class="zmdi zmdi-close"></i></div>
30                     </div>
31                 </transition-group>
32             </draggable>
33
34             <table class="no-style" style="width: 100%;">
35                 <tbody>
36                 <tr class="unsortable">
37                     <td width="34"></td>
38                     <td @click="addEmptyTag">
39                         <button type="button" class="text-button">{{ trans('entities.tags_add') }}</button>
40                     </td>
41                     <td></td>
42                 </tr>
43                 </tbody>
44             </table>
45
46         </div>
47     </div>
48
49     @if(userCan('attachment-create-all'))
50         <div toolbox-tab-content="files" id="attachment-manager" page-id="{{ $page->id or 0 }}">
51             <h4>{{ trans('entities.attachments') }}</h4>
52             <div class="padded files">
53
54                 <div id="file-list" v-show="!fileToEdit">
55                     <p class="muted small">{{ trans('entities.attachments_explain') }} <span class="secondary">{{ trans('entities.attachments_explain_instant_save') }}</span></p>
56
57                     <div class="tab-container">
58                         <div class="nav-tabs">
59                             <div @click="tab = 'list'" :class="{selected: tab === 'list'}" class="tab-item">{{ trans('entities.attachments_items') }}</div>
60                             <div @click="tab = 'file'" :class="{selected: tab === 'file'}" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
61                             <div @click="tab = 'link'" :class="{selected: tab === 'link'}" class="tab-item">{{ trans('entities.attachments_link') }}</div>
62                         </div>
63                         <div v-show="tab === 'list'">
64                             <draggable class="fake-table no-style " style="width: 100%;" :options="{handle: '.handle'}" @change="fileSortUpdate" :list="files" element="div">
65                                 <transition-group tag="div">
66                                 <div v-for="(file, index) in files" :key="file.id">
67                                     <div width="20" ><i class="handle zmdi zmdi-menu"></i></div>
68                                     <div>
69                                         <a :href="getFileUrl(file)" target="_blank" v-text="file.name"></a>
70                                         <div v-if="file.deleting">
71                                             <span class="neg small">{{ trans('entities.attachments_delete_confirm') }}</span>
72                                             <br>
73                                             <span class="text-primary small" @click="file.deleting = false;">{{ trans('common.cancel') }}</span>
74                                         </div>
75                                     </div>
76                                     <div width="10" @click="startEdit(file)" class="text-center text-primary" style="padding: 0;"><i class="zmdi zmdi-edit"></i></div>
77                                     <div width="5"></div>
78                                     <div width="10" @click="deleteFile(file)" class="text-center text-neg" style="padding: 0;"><i class="zmdi zmdi-close"></i></div>
79                                 </div>
80                                 </transition-group>
81                             </draggable>
82                             <p class="small muted" v-if="files.length === 0">
83                                 {{ trans('entities.attachments_no_files') }}
84                             </p>
85                         </div>
86                         <div v-show="tab === 'file'">
87                             <dropzone placeholder="{{ trans('entities.attachments_dropzone') }}" :upload-url="getUploadUrl()" :uploaded-to="pageId" @success="uploadSuccess"></dropzone>
88                         </div>
89                         <div v-show="tab === 'link'" @keypress.enter.prevent="attachNewLink(file)">
90                             <p class="muted small">{{ trans('entities.attachments_explain_link') }}</p>
91                             <div class="form-group">
92                                 <label for="attachment-via-link">{{ trans('entities.attachments_link_name') }}</label>
93                                 <input type="text" placeholder="{{ trans('entities.attachments_link_name') }}" v-model="file.name">
94                                 <p class="small neg" v-for="error in errors.link.name" v-text="error"></p>
95                             </div>
96                             <div class="form-group">
97                                 <label for="attachment-via-link">{{ trans('entities.attachments_link_url') }}</label>
98                                 <input type="text"  placeholder="{{ trans('entities.attachments_link_url_hint') }}" v-model="file.link">
99                                 <p class="small neg" v-for="error in errors.link.link" v-text="error"></p>
100                             </div>
101                             <button @click.prevent="attachNewLink(file)" class="button pos">{{ trans('entities.attach') }}</button>
102
103                         </div>
104                     </div>
105
106                 </div>
107
108                 <div id="file-edit" v-if="fileToEdit" @keypress.enter.prevent="updateFile(fileToEdit)">
109                     <h5>{{ trans('entities.attachments_edit_file') }}</h5>
110
111                     <div class="form-group">
112                         <label for="attachment-name-edit">{{ trans('entities.attachments_edit_file_name') }}</label>
113                         <input type="text" id="attachment-name-edit" placeholder="{{ trans('entities.attachments_edit_file_name') }}" v-model="fileToEdit.name">
114                         <p class="small neg" v-for="error in errors.edit.name" v-text="error"></p>
115                     </div>
116
117                     <div class="tab-container">
118                         <div class="nav-tabs">
119                             <div @click="editTab = 'file'" :class="{selected: editTab === 'file'}" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
120                             <div @click="editTab = 'link'" :class="{selected: editTab === 'link'}" class="tab-item">{{ trans('entities.attachments_set_link') }}</div>
121                         </div>
122                         <div v-if="editTab === 'file'">
123                             <dropzone :upload-url="getUploadUrl(fileToEdit)" :uploaded-to="pageId" placeholder="{{ trans('entities.attachments_edit_drop_upload') }}" @success="uploadSuccessUpdate"></dropzone>
124                             <br>
125                         </div>
126                         <div v-if="editTab === 'link'">
127                             <div class="form-group">
128                                 <label for="attachment-link-edit">{{ trans('entities.attachments_link_url') }}</label>
129                                 <input type="text" id="attachment-link-edit" placeholder="{{ trans('entities.attachment_link') }}" v-model="fileToEdit.link">
130                                 <p class="small neg" v-for="error in errors.edit.link" v-text="error"></p>
131                             </div>
132                         </div>
133                     </div>
134
135                     <button type="button" class="button" @click="cancelEdit">{{ trans('common.back') }}</button>
136                     <button @click.enter.prevent="updateFile(fileToEdit)" class="button pos">{{ trans('common.save') }}</button>
137                 </div>
138
139             </div>
140         </div>
141     @endif
142
143 </div>