mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-28 03:12:01 +08:00
79 lines
3.1 KiB
PHP
79 lines
3.1 KiB
PHP
@extends('base')
|
|
|
|
@section('content')
|
|
|
|
<div class="container small">
|
|
<h1>Sorting Pages & Chapters<span class="subheader">For {{ $book->name }}</span></h1>
|
|
|
|
<ul class="sortable-page-list" id="sort-list">
|
|
@foreach($book->children() as $bookChild)
|
|
<li data-id="{{$bookChild->id}}" data-type="{{ $bookChild->getName() }}" class="text-{{ $bookChild->getName() }}">
|
|
<i class="zmdi {{ $bookChild->isA('chapter') ? 'zmdi-collection-bookmark':'zmdi-file-text'}}"></i>{{ $bookChild->name }}
|
|
@if($bookChild->isA('chapter'))
|
|
<ul>
|
|
@foreach($bookChild->pages as $page)
|
|
<li data-id="{{$page->id}}" class="text-page" data-type="page">
|
|
<i class="zmdi zmdi-file-text"></i>
|
|
{{ $page->name }}
|
|
</li>
|
|
@endforeach
|
|
</ul>
|
|
@endif
|
|
</li>
|
|
@endforeach
|
|
</ul>
|
|
|
|
<form action="{{$book->getUrl()}}/sort" method="POST">
|
|
{!! csrf_field() !!}
|
|
<input type="hidden" name="_method" value="PUT">
|
|
<input type="hidden" id="sort-tree-input" name="sort-tree">
|
|
<div class="list">
|
|
<a href="{{$book->getUrl()}}" class="button muted">Cancel</a>
|
|
<button class="button pos" type="submit">Save Order</button>
|
|
</div>
|
|
</form>
|
|
|
|
</div>
|
|
|
|
<script>
|
|
$(document).ready(function() {
|
|
|
|
var group = $('#sort-list').sortable({
|
|
group: 'serialization',
|
|
onDrop: function($item, container, _super) {
|
|
var data = group.sortable('serialize').get();
|
|
var pageMap = buildPageMap(data[0]);
|
|
$('#sort-tree-input').val(JSON.stringify(pageMap));
|
|
_super($item, container);
|
|
}
|
|
});
|
|
|
|
function buildPageMap(data) {
|
|
var pageMap = [];
|
|
for(var i = 0; i < data.length; i++) {
|
|
var bookChild = data[i];
|
|
pageMap.push({
|
|
id: bookChild.id,
|
|
parentChapter: false,
|
|
type: bookChild.type
|
|
});
|
|
if(bookChild.type == 'chapter' && bookChild.children) {
|
|
var chapterId = bookChild.id;
|
|
var chapterChildren = bookChild.children[0];
|
|
for(var j = 0; j < chapterChildren.length; j++) {
|
|
var page = chapterChildren[j];
|
|
pageMap.push({
|
|
id: page.id,
|
|
parentChapter: chapterId,
|
|
type: 'page'
|
|
});
|
|
}
|
|
}
|
|
}
|
|
return pageMap;
|
|
}
|
|
|
|
});
|
|
</script>
|
|
@stop
|