X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/712ccd23c4738e6a59a10f31ff654743fbc61879..1c859e94e03d0407daf55ade43ced245f208f971:/app/Http/Controllers/BookSortController.php diff --git a/app/Http/Controllers/BookSortController.php b/app/Http/Controllers/BookSortController.php index 9375b618a..8aac2b769 100644 --- a/app/Http/Controllers/BookSortController.php +++ b/app/Http/Controllers/BookSortController.php @@ -3,22 +3,19 @@ namespace BookStack\Http\Controllers; use BookStack\Actions\ActivityType; -use BookStack\Entities\Book; -use BookStack\Entities\Managers\BookContents; use BookStack\Entities\Repos\BookRepo; -use BookStack\Exceptions\SortOperationException; +use BookStack\Entities\Tools\BookContents; +use BookStack\Entities\Tools\BookSortMap; use BookStack\Facades\Activity; use Illuminate\Http\Request; class BookSortController extends Controller { - protected $bookRepo; public function __construct(BookRepo $bookRepo) { $this->bookRepo = $bookRepo; - parent::__construct(); } /** @@ -32,6 +29,7 @@ class BookSortController extends Controller $bookChildren = (new BookContents($book))->getTree(false); $this->setPageTitle(trans('entities.books_sort_named', ['bookName'=>$book->getShortName()])); + return view('books.sort', ['book' => $book, 'current' => $book, 'bookChildren' => $bookChildren]); } @@ -43,7 +41,8 @@ class BookSortController extends Controller { $book = $this->bookRepo->getBySlug($bookSlug); $bookChildren = (new BookContents($book))->getTree(); - return view('books.sort-box', ['book' => $book, 'bookChildren' => $bookChildren]); + + return view('books.parts.sort-box', ['book' => $book, 'bookChildren' => $bookChildren]); } /** @@ -59,20 +58,14 @@ class BookSortController extends Controller return redirect($book->getUrl()); } - $sortMap = collect(json_decode($request->get('sort-tree'))); + $sortMap = BookSortMap::fromJson($request->get('sort-tree')); $bookContents = new BookContents($book); - $booksInvolved = collect(); - - try { - $booksInvolved = $bookContents->sortUsingMap($sortMap); - } catch (SortOperationException $exception) { - $this->showPermissionError(); - } + $booksInvolved = $bookContents->sortUsingMap($sortMap); // Rebuild permissions and add activity for involved books. - $booksInvolved->each(function (Book $book) { - Activity::addForEntity($book, ActivityType::BOOK_SORT); - }); + foreach ($booksInvolved as $bookInvolved) { + Activity::add(ActivityType::BOOK_SORT, $bookInvolved); + } return redirect($book->getUrl()); }