Sorting: Connected up default sort setting for books
This commit is contained in:
parent
b897af2ed0
commit
7093daa49d
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
namespace BookStack\Entities\Models;
|
namespace BookStack\Entities\Models;
|
||||||
|
|
||||||
|
use BookStack\Sorting\SortSet;
|
||||||
use BookStack\Uploads\Image;
|
use BookStack\Uploads\Image;
|
||||||
use Exception;
|
use Exception;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
@ -16,12 +17,14 @@ use Illuminate\Support\Collection;
|
||||||
* @property string $description
|
* @property string $description
|
||||||
* @property int $image_id
|
* @property int $image_id
|
||||||
* @property ?int $default_template_id
|
* @property ?int $default_template_id
|
||||||
|
* @property ?int $sort_set_id
|
||||||
* @property Image|null $cover
|
* @property Image|null $cover
|
||||||
* @property \Illuminate\Database\Eloquent\Collection $chapters
|
* @property \Illuminate\Database\Eloquent\Collection $chapters
|
||||||
* @property \Illuminate\Database\Eloquent\Collection $pages
|
* @property \Illuminate\Database\Eloquent\Collection $pages
|
||||||
* @property \Illuminate\Database\Eloquent\Collection $directPages
|
* @property \Illuminate\Database\Eloquent\Collection $directPages
|
||||||
* @property \Illuminate\Database\Eloquent\Collection $shelves
|
* @property \Illuminate\Database\Eloquent\Collection $shelves
|
||||||
* @property ?Page $defaultTemplate
|
* @property ?Page $defaultTemplate
|
||||||
|
* @property ?SortSet $sortSet
|
||||||
*/
|
*/
|
||||||
class Book extends Entity implements HasCoverImage
|
class Book extends Entity implements HasCoverImage
|
||||||
{
|
{
|
||||||
|
@ -82,6 +85,14 @@ class Book extends Entity implements HasCoverImage
|
||||||
return $this->belongsTo(Page::class, 'default_template_id');
|
return $this->belongsTo(Page::class, 'default_template_id');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the sort set assigned to this book, if existing.
|
||||||
|
*/
|
||||||
|
public function sortSet(): BelongsTo
|
||||||
|
{
|
||||||
|
return $this->belongsTo(SortSet::class);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all pages within this book.
|
* Get all pages within this book.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -8,6 +8,7 @@ use BookStack\Entities\Models\Book;
|
||||||
use BookStack\Entities\Tools\TrashCan;
|
use BookStack\Entities\Tools\TrashCan;
|
||||||
use BookStack\Exceptions\ImageUploadException;
|
use BookStack\Exceptions\ImageUploadException;
|
||||||
use BookStack\Facades\Activity;
|
use BookStack\Facades\Activity;
|
||||||
|
use BookStack\Sorting\SortSet;
|
||||||
use BookStack\Uploads\ImageRepo;
|
use BookStack\Uploads\ImageRepo;
|
||||||
use Exception;
|
use Exception;
|
||||||
use Illuminate\Http\UploadedFile;
|
use Illuminate\Http\UploadedFile;
|
||||||
|
@ -33,6 +34,12 @@ class BookRepo
|
||||||
$this->baseRepo->updateDefaultTemplate($book, intval($input['default_template_id'] ?? null));
|
$this->baseRepo->updateDefaultTemplate($book, intval($input['default_template_id'] ?? null));
|
||||||
Activity::add(ActivityType::BOOK_CREATE, $book);
|
Activity::add(ActivityType::BOOK_CREATE, $book);
|
||||||
|
|
||||||
|
$defaultBookSortSetting = intval(setting('sorting-book-default', '0'));
|
||||||
|
if ($defaultBookSortSetting && SortSet::query()->find($defaultBookSortSetting)) {
|
||||||
|
$book->sort_set_id = $defaultBookSortSetting;
|
||||||
|
$book->save();
|
||||||
|
}
|
||||||
|
|
||||||
return $book;
|
return $book;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,8 +3,10 @@
|
||||||
namespace BookStack\Sorting;
|
namespace BookStack\Sorting;
|
||||||
|
|
||||||
use BookStack\Activity\Models\Loggable;
|
use BookStack\Activity\Models\Loggable;
|
||||||
|
use BookStack\Entities\Models\Book;
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Illuminate\Database\Eloquent\Relations\HasMany;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @property int $id
|
* @property int $id
|
||||||
|
@ -41,4 +43,9 @@ class SortSet extends Model implements Loggable
|
||||||
{
|
{
|
||||||
return url("/settings/sorting/sets/{$this->id}");
|
return url("/settings/sorting/sets/{$this->id}");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function books(): HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(Book::class);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,7 +62,7 @@ class SortSetController extends Controller
|
||||||
$set = SortSet::query()->findOrFail($id);
|
$set = SortSet::query()->findOrFail($id);
|
||||||
$operations = SortSetOperation::fromSequence($request->input('sequence'));
|
$operations = SortSetOperation::fromSequence($request->input('sequence'));
|
||||||
if (count($operations) === 0) {
|
if (count($operations) === 0) {
|
||||||
return redirect()->withInput()->withErrors(['sequence' => 'No operations set.']);
|
return redirect($set->getUrl())->withInput()->withErrors(['sequence' => 'No operations set.']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$set->name = $request->input('name');
|
$set->name = $request->input('name');
|
||||||
|
@ -78,7 +78,16 @@ class SortSetController extends Controller
|
||||||
{
|
{
|
||||||
$set = SortSet::query()->findOrFail($id);
|
$set = SortSet::query()->findOrFail($id);
|
||||||
|
|
||||||
// TODO - Check if it's in use
|
if ($set->books()->count() > 0) {
|
||||||
|
$this->showErrorNotification(trans('settings.sort_set_delete_fail_books'));
|
||||||
|
return redirect($set->getUrl());
|
||||||
|
}
|
||||||
|
|
||||||
|
$defaultBookSortSetting = intval(setting('sorting-book-default', '0'));
|
||||||
|
if ($defaultBookSortSetting === intval($id)) {
|
||||||
|
$this->showErrorNotification(trans('settings.sort_set_delete_fail_default'));
|
||||||
|
return redirect($set->getUrl());
|
||||||
|
}
|
||||||
|
|
||||||
$set->delete();
|
$set->delete();
|
||||||
$this->logActivity(ActivityType::SORT_SET_DELETE, $set);
|
$this->logActivity(ActivityType::SORT_SET_DELETE, $set);
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::table('books', function (Blueprint $table) {
|
||||||
|
$table->unsignedInteger('sort_set_id')->nullable()->default(null);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::table('books', function (Blueprint $table) {
|
||||||
|
$table->dropColumn('sort_set_id');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
|
@ -84,6 +84,8 @@ return [
|
||||||
'sort_set_edit' => 'Edit Sort Set',
|
'sort_set_edit' => 'Edit Sort Set',
|
||||||
'sort_set_delete' => 'Delete Sort Set',
|
'sort_set_delete' => 'Delete Sort Set',
|
||||||
'sort_set_delete_desc' => 'Remove this sort set from the system. Deletion will only go ahead if the sort is not in active use.',
|
'sort_set_delete_desc' => 'Remove this sort set from the system. Deletion will only go ahead if the sort is not in active use.',
|
||||||
|
'sort_set_delete_fail_books' => 'Unable to delete this sort set since it has books assigned.',
|
||||||
|
'sort_set_delete_fail_default' => 'Unable to delete this sort set since it\'s used as the default book sort.',
|
||||||
'sort_set_details' => 'Sort Set Details',
|
'sort_set_details' => 'Sort Set Details',
|
||||||
'sort_set_details_desc' => 'Set a name for this sort set, which will appear in lists when users are selecting a sort.',
|
'sort_set_details_desc' => 'Set a name for this sort set, which will appear in lists when users are selecting a sort.',
|
||||||
'sort_set_operations' => 'Sort Operations',
|
'sort_set_operations' => 'Sort Operations',
|
||||||
|
|
|
@ -1,5 +1,9 @@
|
||||||
@extends('settings.layout')
|
@extends('settings.layout')
|
||||||
|
|
||||||
|
@php
|
||||||
|
$sortSets = \BookStack\Sorting\SortSet::query()->orderBy('name', 'asc')->get();
|
||||||
|
@endphp
|
||||||
|
|
||||||
@section('card')
|
@section('card')
|
||||||
<h1 id="sorting" class="list-heading">{{ trans('settings.sorting') }}</h1>
|
<h1 id="sorting" class="list-heading">{{ trans('settings.sorting') }}</h1>
|
||||||
<form action="{{ url("/settings/sorting") }}" method="POST">
|
<form action="{{ url("/settings/sorting") }}" method="POST">
|
||||||
|
@ -19,15 +23,13 @@
|
||||||
<option value="0" @if(intval(setting('sorting-book-default', '0')) === 0) selected @endif>
|
<option value="0" @if(intval(setting('sorting-book-default', '0')) === 0) selected @endif>
|
||||||
-- {{ trans('common.none') }} --
|
-- {{ trans('common.none') }} --
|
||||||
</option>
|
</option>
|
||||||
{{-- TODO--}}
|
@foreach($sortSets as $set)
|
||||||
{{-- @foreach(\BookStack\Users\Models\Role::all() as $role)--}}
|
<option value="{{$set->id}}"
|
||||||
{{-- <option value="{{$role->id}}"--}}
|
@if(intval(setting('sorting-book-default', '0')) === $set->id) selected @endif
|
||||||
{{-- data-system-role-name="{{ $role->system_name ?? '' }}"--}}
|
>
|
||||||
{{-- @if(intval(setting('registration-role', '0')) === $role->id) selected @endif--}}
|
{{ $set->name }}
|
||||||
{{-- >--}}
|
</option>
|
||||||
{{-- {{ $role->display_name }}--}}
|
@endforeach
|
||||||
{{-- </option>--}}
|
|
||||||
{{-- @endforeach--}}
|
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -52,9 +54,6 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@php
|
|
||||||
$sortSets = \BookStack\Sorting\SortSet::query()->orderBy('name', 'asc')->get();
|
|
||||||
@endphp
|
|
||||||
@if(empty($sortSets))
|
@if(empty($sortSets))
|
||||||
<p class="italic text-muted">{{ trans('common.no_items') }}</p>
|
<p class="italic text-muted">{{ trans('common.no_items') }}</p>
|
||||||
@else
|
@else
|
||||||
|
|
Loading…
Reference in New Issue