VerseTable.php 2.06 KB
<?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();

            });
        });
    }
}