]> BookStack Code Mirror - bookstack/blob - resources/views/books/sort.blade.php
translated
[bookstack] / resources / views / books / sort.blade.php
1 @extends('simple-layout')
2
3 @section('toolbar')
4     <div class="col-sm-12 faded">
5         @include('books._breadcrumbs', ['book' => $book])
6     </div>
7 @stop
8
9 @section('body')
10
11     <div class="container">
12
13         <div class="row">
14             <div class="col-md-8">
15                 <div class="card">
16                     <h3>@icon('sort') {{ trans('entities.books_sort') }}</h3>
17                     <div class="body">
18                         <div id="sort-boxes">
19                             @include('books/sort-box', ['book' => $book, 'bookChildren' => $bookChildren])
20                         </div>
21
22                         <form action="{{ $book->getUrl('/sort') }}" method="POST">
23                             {!! csrf_field() !!}
24                             <input type="hidden" name="_method" value="PUT">
25                             <input type="hidden" id="sort-tree-input" name="sort-tree">
26                             <div class="list">
27                                 <a href="{{ $book->getUrl() }}" class="button outline">{{ trans('common.cancel') }}</a>
28                                 <button class="button pos" type="submit">{{ trans('entities.books_sort_save') }}</button>
29                             </div>
30                         </form>
31                     </div>
32                 </div>
33             </div>
34             @if(count($books) > 1)
35             <div class="col-md-4">
36                 <div class="card">
37                     <h3>@icon('book') {{ trans('entities.books_sort_show_other') }}</h3>
38                     <div class="body" id="additional-books">
39                         @foreach($books as $otherBook)
40                             @if($otherBook->id !== $book->id)
41                                 <div>
42                                     <a href="{{ $otherBook->getUrl('/sort-item') }}" class="text-book">@icon('book'){{ $otherBook->name }}</a>
43                                 </div>
44                             @endif
45                         @endforeach
46                     </div>
47                 </div>
48             </div>
49             @endif
50         </div>
51     </div>
52
53 @stop
54
55 @section('scripts')
56     <script src="{{ baseUrl("/libs/jquery-sortable/jquery-sortable.min.js") }}"></script>
57     <script>
58         $(document).ready(function() {
59
60             var sortableOptions = {
61                 group: 'serialization',
62                 onDrop: function($item, container, _super) {
63                     var pageMap = buildEntityMap();
64                     $('#sort-tree-input').val(JSON.stringify(pageMap));
65                     _super($item, container);
66                 },
67                 isValidTarget: function  ($item, container) {
68                     // Prevent nested chapters
69                     return !($item.is('[data-type="chapter"]') && container.target.closest('li').attr('data-type') == 'chapter');
70                 }
71             };
72
73             var group = $('.sort-list').sortable(sortableOptions);
74
75             $('#additional-books').on('click', 'a', function(e) {
76                 e.preventDefault();
77                 var $link = $(this);
78                 var url = $link.attr('href');
79                 $.get(url, function(data) {
80                     $('#sort-boxes').append(data);
81                     group.sortable("destroy");
82                     $('.sort-list').sortable(sortableOptions);
83                 });
84                 $link.remove();
85             });
86
87             /**
88              * Build up a mapping of entities with their ordering and nesting.
89              * @returns {Array}
90              */
91             function buildEntityMap() {
92                 var entityMap = [];
93                 var $lists = $('.sort-list');
94                 $lists.each(function(listIndex) {
95                     var list = $(this);
96                     var bookId = list.closest('[data-type="book"]').attr('data-id');
97                     var $directChildren = list.find('> [data-type="page"], > [data-type="chapter"]');
98                     $directChildren.each(function(directChildIndex) {
99                         var $childElem = $(this);
100                         var type = $childElem.attr('data-type');
101                         var parentChapter = false;
102                         var childId = $childElem.attr('data-id');
103                         entityMap.push({
104                             id: childId,
105                             sort: directChildIndex,
106                             parentChapter: parentChapter,
107                             type: type,
108                             book: bookId
109                         });
110                         $chapterChildren = $childElem.find('[data-type="page"]').each(function(pageIndex) {
111                             var $chapterChild = $(this);
112                             entityMap.push({
113                                 id: $chapterChild.attr('data-id'),
114                                 sort: pageIndex,
115                                 parentChapter: childId,
116                                 type: 'page',
117                                 book: bookId
118                             });
119                         });
120                     });
121                 });
122                 return entityMap;
123             }
124
125         });
126     </script>
127 @stop