5 <div class="page-content">
6 <h1>{{ $book->name }} <span class="subheader">Sort Pages</span></h1>
8 <ul class="sortable-page-list" id="sort-list">
9 @foreach($book->children() as $bookChild)
10 <li data-id="{{$bookChild->id}}" data-type="{{ is_a($bookChild, 'Oxbow\Chapter') ? 'chapter' : 'page' }}">
11 {{ $bookChild->name }}
12 @if(is_a($bookChild, 'Oxbow\Chapter'))
14 @foreach($bookChild->pages as $page)
15 <li data-id="{{$page->id}}" data-type="page">
25 <form action="{{$book->getUrl()}}/sort" method="POST">
27 <input type="hidden" name="_method" value="PUT">
28 <input type="hidden" id="sort-tree-input" name="sort-tree">
30 <a href="{{$book->getUrl()}}" class="button muted">Cancel</a>
31 <button class="button pos" type="submit">Save Ordering</button>
38 $(document).ready(function() {
40 var group = $('#sort-list').sortable({
41 group: 'serialization',
42 onDrop: function($item, container, _super) {
43 var data = group.sortable('serialize').get();
44 var pageMap = buildPageMap(data[0]);
45 $('#sort-tree-input').val(JSON.stringify(pageMap));
46 _super($item, container);
50 function buildPageMap(data) {
52 for(var i = 0; i < data.length; i++) {
53 var bookChild = data[i];
59 if(bookChild.type == 'chapter' && bookChild.children) {
60 var chapterId = bookChild.id;
61 var chapterChildren = bookChild.children[0];
62 for(var j = 0; j < chapterChildren.length; j++) {
63 var page = chapterChildren[j];
66 parentChapter: chapterId,