先参考Laravel文档实现模型的软删除:
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Post extends Model
{
use SoftDeletes;
}
这样在table列表中显示的数据都是未被删除的数据
$table = new Table(new Post);
$table->id('ID')->sortable();
$table->title('Title');
$table->created_at('Created at');
$table->updated_at('Updated at');
return $table;
接下来需要增加一个入口,能让我们看到被软删除的数据,这里可以使用model-table
的范围过滤器
来实现
$table->filter(function () {
// 范围过滤器,调用模型的`onlyTrashed`方法,查询出被软删除的数据。
$filter->scope('trashed', '回收站')->onlyTrashed();
});
在表头的筛选按钮的下拉菜单中就会出现一个回收站
按钮,点击它,就会调用模型的onlyTrashed
方法,从表中查询出被删除的数据,也就是回收站中的数据。
按照下面的方法,我们可以在回收站中的每一行数据加上一个恢复操作,方便恢复数据
先定义操作类app/Admin/Actions/Post/Restore.php
:
<?php
namespace App\Admin\Actions\Post;
use Encore\Admin\Actions\RowAction;
use Illuminate\Database\Eloquent\Model;
class Restore extends RowAction
{
public $name = '恢复';
public function handle(Model $model)
{
$model->restore();
return $this->response()->success('已恢复')->refresh();
}
public function dialog()
{
$this->confirm('确定恢复吗?');
}
}
添加到行操作:
use App\Admin\Actions\Post\Restore;
$table->actions(function ($actions) {
if (\request('_scope_') == 'trashed') {
$actions->add(new Restore());
}
});
先定义操作类app/Admin/Actions/Post/BatchRestore.php
:
<?php
namespace App\Admin\Actions\Post;
use Encore\Admin\Actions\BatchAction;
use Illuminate\Database\Eloquent\Collection;
class BatchRestore extends BatchAction
{
public $name = '恢复';
public function handle(Collection $collection)
{
$collection->each->restore();
return $this->response()->success('已恢复')->refresh();
}
public function dialog()
{
$this->confirm('确定恢复吗?');
}
}
添加到批量操作:
use App\Admin\Actions\Post\BatchRestore;
$table->batchActions(function ($batch) {
if (\request('_scope_') == 'trashed') {
$batch->add(new BatchRestore());
}
});