]> BookStack Code Mirror - bookstack/blob - resources/views/books/sort.blade.php
Updated all application urls to allow path prefix.
[bookstack] / resources / views / books / sort.blade.php
1 @extends('base')
2
3 @section('head')
4     <script src="{{ baseUrl("/libs/jquery-sortable/jquery-sortable.min.js") }}"></script>
5 @stop
6
7 @section('content')
8
9     <div class="container" ng-non-bindable>
10         <h1>Sorting Pages & Chapters<span class="subheader">For {{ $book->name }}</span></h1>
11         <div class="row">
12             <div class="col-md-8" id="sort-boxes">
13
14                 @include('books/sort-box', ['book' => $book, 'bookChildren' => $bookChildren])
15
16             </div>
17
18             @if(count($books) > 1)
19                 <div class="col-md-4">
20                     <h3>Show Other Books</h3>
21                     <div id="additional-books">
22                     @foreach($books as $otherBook)
23                         @if($otherBook->id !== $book->id)
24                         <div>
25                             <a href="{{ $otherBook->getUrl('/sort-item') }}" class="text-book"><i class="zmdi zmdi-book"></i>{{ $otherBook->name }}</a>
26                         </div>
27                         @endif
28                     @endforeach
29                     </div>
30                 </div>
31             @endif
32
33         </div>
34
35         <form action="{{ $book->getUrl('/sort') }}" method="POST">
36             {!! csrf_field() !!}
37             <input type="hidden" name="_method" value="PUT">
38             <input type="hidden" id="sort-tree-input" name="sort-tree">
39             <div class="list">
40                 <a href="{{ $book->getUrl() }}" class="button muted">Cancel</a>
41                 <button class="button pos" type="submit">Save Order</button>
42             </div>
43         </form>
44
45     </div>
46
47     <script>
48         $(document).ready(function() {
49
50             var sortableOptions = {
51                 group: 'serialization',
52                 onDrop: function($item, container, _super) {
53                     var pageMap = buildPageMap();
54                     $('#sort-tree-input').val(JSON.stringify(pageMap));
55                     _super($item, container);
56                 },
57                 isValidTarget: function  ($item, container) {
58                     // Prevent nested chapters
59                     return !($item.is('[data-type="chapter"]') && container.target.closest('li').attr('data-type') == 'chapter');
60                 }
61             };
62
63             var group = $('.sort-list').sortable(sortableOptions);
64
65             $('#additional-books').on('click', 'a', function(e) {
66                 e.preventDefault();
67                 var $link = $(this);
68                 var url = $link.attr('href');
69                 $.get(url, function(data) {
70                     $('#sort-boxes').append(data);
71                     group.sortable("destroy");
72                     $('.sort-list').sortable(sortableOptions);
73                 });
74                 $link.remove();
75             });
76
77             function buildPageMap() {
78                 var pageMap = [];
79                 var $lists = $('.sort-list');
80                 $lists.each(function(listIndex) {
81                     var list = $(this);
82                     var bookId = list.closest('[data-type="book"]').attr('data-id');
83                     var $childElements = list.find('[data-type="page"], [data-type="chapter"]');
84                     $childElements.each(function(childIndex) {
85                         var $childElem = $(this);
86                         var type = $childElem.attr('data-type');
87                         var parentChapter = false;
88                         if(type === 'page' && $childElem.closest('[data-type="chapter"]').length === 1) {
89                             parentChapter = $childElem.closest('[data-type="chapter"]').attr('data-id');
90                         }
91                         pageMap.push({
92                             id: $childElem.attr('data-id'),
93                             parentChapter: parentChapter,
94                             type: type,
95                             book: bookId
96                         });
97                     });
98                 });
99                 return pageMap;
100             }
101
102         });
103     </script>
104 @stop