VerseTable.php
2.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?php
/**
 * Created by PhpStorm.
 * User: lishuai
 * Date: 2022/1/10
 * Time: 5:57 PM
 */
namespace App\Admin\Renderable;
use Dcat\Admin\Grid;
use Dcat\Admin\Grid\LazyRenderable;
use App\Models\Author;
use App\Models\Poetry;
use App\Models\Verse;
class VerseTable extends LazyRenderable
{
    public function grid(): Grid
    {
        return Grid::make(new Verse(), function (Grid $grid) {
            $grid->model()->with(['poetry']);
            $grid->column('id')->sortable();
            $grid->column('author_id')->display(function (){
                $id = $this->poetry_id;
                $poetry = Poetry::query()->find($id);
                $author_id = $poetry->author_id;
                $author = Author::query()->find($author_id);
                return $author->name;
            })->copyable();
            $grid->column('poetry.name')->copyable();
            $grid->column('stanza')->copyable();
            $grid->column('annotate')->copyable();
            $grid->column('spelling')->copyable();
            $grid->column('en')->copyable();
//            $grid->column('created_at');
//            $grid->column('updated_at')->sortable();
            $grid->withBorder();
            $grid->quickSearch(['stanza'])->placeholder('快捷搜索诗句(节)');
            $grid->paginate(5);
            $grid->simplePaginate();
            $grid->disableActions();
            $grid->disableCreateButton();
            $grid->expandFilter();  // 默认展开搜索
            $grid->filter(function (Grid\Filter $filter) {
//                $filter->where('author_id',function ($query){
//                    $author = Author::query()->where('name','like',"%{$this->input}%")->get()->pluck('id');
//                    $poetry =Poetry::query()->whereIn('author_id',$author)->get()->pluck('id');
//                    $query->whereIn('poetry_id',$poetry);
//                })->width(3);
                $filter->like('poetry.name')->width(6);
//                $filter->like('stanza')->width(4);
                $filter->panel();
            });
        });
    }
}