FarmUpgradeLogController.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Module\Farm\AdminControllers;
  3. use App\Module\Farm\AdminControllers\Helper\GridHelper;
  4. use App\Module\Farm\Enums\UPGRADE_TYPE;
  5. use App\Module\Farm\Repositories\FarmUpgradeLogRepository;
  6. use Dcat\Admin\Grid;
  7. use Dcat\Admin\Show;
  8. use UCore\DcatAdmin\AdminController;
  9. use Spatie\RouteAttributes\Attributes\Resource;
  10. /**
  11. * 升级记录管理控制器
  12. */
  13. #[Resource('farm-upgrade-logs', names: 'dcat.admin.farm-upgrade-logs')]
  14. class FarmUpgradeLogController extends AdminController
  15. {
  16. /**
  17. * 页面标题
  18. *
  19. * @var string
  20. */
  21. protected $title = '升级记录管理';
  22. /**
  23. * 页面描述
  24. *
  25. * @var string
  26. */
  27. protected $description = '查看用户的土地和房屋升级记录';
  28. /**
  29. * 构建表格
  30. *
  31. * @return Grid
  32. */
  33. protected function grid()
  34. {
  35. return Grid::make(new FarmUpgradeLogRepository(), function (Grid $grid) {
  36. $helper = new GridHelper($grid, $this);
  37. $grid->column('id', 'ID')->sortable();
  38. $grid->column('user_id', '用户ID')->sortable();
  39. $grid->column('upgrade_type', '升级类型')->display(function ($value) {
  40. return UPGRADE_TYPE::getName($value);
  41. })->sortable();
  42. $grid->column('target_id', '目标ID')->sortable();
  43. $grid->column('old_level', '旧等级/类型')->sortable();
  44. $grid->column('new_level', '新等级/类型')->sortable();
  45. $grid->column('upgrade_time', '升级时间')->sortable();
  46. $grid->column('created_at', '创建时间')->sortable();
  47. $grid->filter(function (Grid\Filter $filter) {
  48. $filter->equal('id', 'ID');
  49. $filter->equal('user_id', '用户ID');
  50. $filter->equal('upgrade_type', '升级类型')->select([
  51. UPGRADE_TYPE::LAND => UPGRADE_TYPE::getName(UPGRADE_TYPE::LAND),
  52. UPGRADE_TYPE::HOUSE => UPGRADE_TYPE::getName(UPGRADE_TYPE::HOUSE),
  53. ]);
  54. $filter->equal('target_id', '目标ID');
  55. $filter->between('upgrade_time', '升级时间')->datetime();
  56. $filter->between('created_at', '创建时间')->datetime();
  57. });
  58. $grid->disableCreateButton();
  59. $grid->disableEditButton();
  60. $grid->actions(function (Grid\Displayers\Actions $actions) {
  61. $actions->disableDelete();
  62. $actions->disableEdit();
  63. });
  64. });
  65. }
  66. /**
  67. * 构建详情页
  68. *
  69. * @param mixed $id
  70. * @return Show
  71. */
  72. protected function detail($id)
  73. {
  74. return Show::make($id, new FarmUpgradeLogRepository(), function (Show $show) {
  75. $show->field('id', 'ID');
  76. $show->field('user_id', '用户ID');
  77. $show->field('upgrade_type', '升级类型')->as(function ($value) {
  78. return UPGRADE_TYPE::getName($value);
  79. });
  80. $show->field('target_id', '目标ID');
  81. $show->field('old_level', '旧等级/类型');
  82. $show->field('new_level', '新等级/类型');
  83. $show->field('materials_consumed', '消耗的材料')->json();
  84. $show->field('upgrade_time', '升级时间');
  85. $show->field('created_at', '创建时间');
  86. });
  87. }
  88. }