james.xue / laravel-sortable
Sortable behaviour for eloquent models
                                    Fund package maintenance!
                                                                            
                                                                                                                                        james.dmzfa.com/about#pay
                                                                                    
                                                                
Installs: 9 783
Dependents: 2
Suggesters: 0
Security: 0
Stars: 2
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/james.xue/laravel-sortable
Requires
- php: >=7.0.0
README
This package provides a trait that adds sortable behaviour to an Eloquent model.
The value of the order column of a new record of a model is determined by the maximum value of the order column of all records of that model + 1.
Installation
This package can be installed through Composer.
composer require james.xue/laravel-sortable
Usage
To add sortable behaviour to your model you must:
- 
Use the trait James\Sortable\SortableTrait;;Use the trait James\Sortable\Sortable;
- 
Optionally specify which column will be used as the order column. The default is sort_field.
Example
use James\Sortable\SortableTrait; use James\Sortable\Sortable; class MyModel extends Eloquent implements Sortable { use SortableTrait; public $sortable = [ 'sort_field' => 'view', 'sort_when_creating' => true, ]; ... }
If you don't set a value $sortable['sort_field'] the package will assume that your order column name will be named sort_field.
If you don't set a value $sortable['sort_when_creating'] the package will automatically assign the highest order number to a new model;
Assuming that the db-table for MyModel is empty:
$myModel = new MyModel(); $myModel->save(); // sort_field for this record will be set to 1 $myModel = new MyModel(); $myModel->save(); // sort_field for this record will be set to 2 $myModel = new MyModel(); $myModel->save(); // sort_field for this record will be set to 3
You can also move a model:
$myModel = new MyModel(); $myModel->where('id', $id)->first()->move('up'); // up、down、top、end
License
The MIT License (MIT). Please see License File for more information.