]> BookStack Code Mirror - bookstack/blob - resources/views/pages/form-toolbox.blade.php
71a4b637e246eb78e0f5cf47a22af34fd4301569
[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" style="width: 100%;">
18                 <transition-group name="test" 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><input autosuggest="{{ baseUrl('/ajax/tags/suggest/names') }}" autosuggest-type="name" class="outline" :name="getTagFieldName(i, 'name')"
22                                    v-model="tag.name" @change="tagChange(tag)" @blur="tagBlur(tag)" placeholder="{{ trans('entities.tag') }}"></div>
23                         <div><input autosuggest="{{ baseUrl('/ajax/tags/suggest/values') }}" autosuggest-type="value" class="outline" :name="getTagFieldName(i, 'value')"
24                                    v-model="tag.value" @change="tagChange(tag)" @blur="tagBlur(tag)" placeholder="{{ trans('entities.tag_value') }}"></div>
25                         <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>
26                     </div>
27                 </transition-group>
28             </draggable>
29
30             <table class="no-style" style="width: 100%;">
31                 <tbody>
32                 <tr class="unsortable">
33                     <td width="34"></td>
34                     <td @click="addEmptyTag">
35                         <button type="button" class="text-button">{{ trans('entities.tags_add') }}</button>
36                     </td>
37                     <td></td>
38                 </tr>
39                 </tbody>
40             </table>
41
42         </div>
43     </div>
44
45     @if(userCan('attachment-create-all'))
46         <div toolbox-tab-content="files" ng-controller="PageAttachmentController" page-id="{{ $page->id or 0 }}">
47             <h4>{{ trans('entities.attachments') }}</h4>
48             <div class="padded files">
49
50                 <div id="file-list" ng-show="!editFile">
51                     <p class="muted small">{{ trans('entities.attachments_explain') }} <span class="secondary">{{ trans('entities.attachments_explain_instant_save') }}</span></p>
52
53                     <div tab-container>
54                         <div class="nav-tabs">
55                             <div tab-button="list" class="tab-item">{{ trans('entities.attachments_items') }}</div>
56                             <div tab-button="file" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
57                             <div tab-button="link" class="tab-item">{{ trans('entities.attachments_link') }}</div>
58                         </div>
59                         <div tab-content="list">
60                             <table class="file-table" style="width: 100%;">
61                                 <tbody ui-sortable="sortOptions" ng-model="files" >
62                                 <tr ng-repeat="file in files track by $index">
63                                     <td width="20" ><i class="handle zmdi zmdi-menu"></i></td>
64                                     <td>
65                                         <a ng-href="@{{getFileUrl(file)}}" target="_blank" ng-bind="file.name"></a>
66                                         <div ng-if="file.deleting">
67                                             <span class="neg small">{{ trans('entities.attachments_delete_confirm') }}</span>
68                                             <br>
69                                             <span class="text-primary small" ng-click="file.deleting=false;">{{ trans('common.cancel') }}</span>
70                                         </div>
71                                     </td>
72                                     <td width="10" ng-click="startEdit(file)" class="text-center text-primary" style="padding: 0;"><i class="zmdi zmdi-edit"></i></td>
73                                     <td width="5"></td>
74                                     <td width="10" ng-click="deleteFile(file)" class="text-center text-neg" style="padding: 0;"><i class="zmdi zmdi-close"></i></td>
75                                 </tr>
76                                 </tbody>
77                             </table>
78                             <p class="small muted" ng-if="files.length == 0">
79                                 {{ trans('entities.attachments_no_files') }}
80                             </p>
81                         </div>
82                         <div tab-content="file">
83                             <drop-zone message="{{ trans('entities.attachments_dropzone') }}" upload-url="@{{getUploadUrl()}}" uploaded-to="@{{uploadedTo}}" event-success="uploadSuccess"></drop-zone>
84                         </div>
85                         <div tab-content="link" sub-form="attachLinkSubmit(file)">
86                             <p class="muted small">{{ trans('entities.attachments_explain_link') }}</p>
87                             <div class="form-group">
88                                 <label for="attachment-via-link">{{ trans('entities.attachments_link_name') }}</label>
89                                 <input placeholder="{{ trans('entities.attachments_link_name') }}" ng-model="file.name">
90                                 <p class="small neg" ng-repeat="error in errors.link.name" ng-bind="error"></p>
91                             </div>
92                             <div class="form-group">
93                                 <label for="attachment-via-link">{{ trans('entities.attachments_link_url') }}</label>
94                                 <input placeholder="{{ trans('entities.attachments_link_url_hint') }}" ng-model="file.link">
95                                 <p class="small neg" ng-repeat="error in errors.link.link" ng-bind="error"></p>
96                             </div>
97                             <button class="button pos">{{ trans('entities.attach') }}</button>
98
99                         </div>
100                     </div>
101
102                 </div>
103
104                 <div id="file-edit" ng-if="editFile" sub-form="updateFile(editFile)">
105                     <h5>{{ trans('entities.attachments_edit_file') }}</h5>
106
107                     <div class="form-group">
108                         <label for="attachment-name-edit">{{ trans('entities.attachments_edit_file_name') }}</label>
109                         <input type="text" id="attachment-name-edit" placeholder="{{ trans('entities.attachments_edit_file_name') }}" ng-model="editFile.name">
110                         <p class="small neg" ng-repeat="error in errors.edit.name" ng-bind="error"></p>
111                     </div>
112
113                     <div tab-container="@{{ editFile.external ? 'link' : 'file' }}">
114                         <div class="nav-tabs">
115                             <div tab-button="file" class="tab-item">{{ trans('entities.attachments_upload') }}</div>
116                             <div tab-button="link" class="tab-item">{{ trans('entities.attachments_set_link') }}</div>
117                         </div>
118                         <div tab-content="file">
119                             <drop-zone upload-url="@{{getUploadUrl(editFile)}}" uploaded-to="@{{uploadedTo}}" placeholder="{{ trans('entities.attachments_edit_drop_upload') }}" event-success="uploadSuccessUpdate"></drop-zone>
120                             <br>
121                         </div>
122                         <div tab-content="link">
123                             <div class="form-group">
124                                 <label for="attachment-link-edit">{{ trans('entities.attachments_link_url') }}</label>
125                                 <input id="attachment-link-edit" placeholder="{{ trans('entities.attachment_link') }}" ng-model="editFile.link">
126                                 <p class="small neg" ng-repeat="error in errors.edit.link" ng-bind="error"></p>
127                             </div>
128                         </div>
129                     </div>
130
131                     <button type="button" class="button" ng-click="cancelEdit()">{{ trans('common.back') }}</button>
132                     <button class="button pos">{{ trans('common.save') }}</button>
133                 </div>
134
135             </div>
136         </div>
137     @endif
138
139 </div>