FarmLandController.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. <?php
  2. namespace App\Module\Farm\AdminControllers;
  3. use App\Module\Farm\AdminControllers\Helper\FilterHelper;
  4. use App\Module\Farm\AdminControllers\Helper\FormHelper;
  5. use App\Module\Farm\AdminControllers\Helper\GridHelper;
  6. use App\Module\Farm\AdminControllers\Helper\ShowHelper;
  7. use App\Module\Farm\Repositories\FarmLandRepository;
  8. use Dcat\Admin\Form;
  9. use Dcat\Admin\Grid;
  10. use Dcat\Admin\Show;
  11. use UCore\DcatAdmin\AdminController;
  12. use Spatie\RouteAttributes\Attributes\Resource;
  13. /**
  14. * 土地管理控制器
  15. */
  16. #[Resource('farm-lands', names: 'dcat.admin.farm-lands')]
  17. class FarmLandController extends AdminController
  18. {
  19. /**
  20. * 页面标题
  21. *
  22. * @var string
  23. */
  24. protected $title = '土地管理';
  25. /**
  26. * 页面描述
  27. *
  28. * @var string
  29. */
  30. protected $description = '管理用户的土地信息';
  31. /**
  32. * 构建表格
  33. *
  34. * @return Grid
  35. */
  36. protected function grid()
  37. {
  38. return Grid::make(new FarmLandRepository(), function (Grid $grid) {
  39. $helper = new GridHelper($grid, $this);
  40. $helper->columnId();
  41. $helper->columnUserId();
  42. $grid->column('position', '位置')->sortable();
  43. $helper->columnLandType();
  44. $helper->columnLandStatus();
  45. $grid->column('has_crop', '是否有作物')->display(function ($value) {
  46. return $value ? '有作物' : '无作物';
  47. });
  48. // 关联显示种子状态
  49. $grid->column('crop.seed_id', '种子ID')->display(function ($seedId) {
  50. return $seedId ?: '-';
  51. });
  52. $grid->column('crop.seed.name', '种子名称')->display(function ($name) {
  53. return $name ?: '-';
  54. });
  55. $helper->columnUseingEnmu('crop.growth_stage', \App\Module\Farm\Enums\GROWTH_STAGE::class,'生长阶段');
  56. $grid->column('crop.stage_end_time', '阶段结束时间')->display(function ($time) {
  57. if (!$time) return '-';
  58. return $time;
  59. });
  60. $grid->column('crop.disasters', '灾害情况')->display(function ($disasters) {
  61. if (!$disasters) return '无';
  62. $result = [];
  63. $disasterData = is_string($disasters) ? json_decode($disasters, true) : $disasters;
  64. foreach ($disasterData ?: [] as $disaster) {
  65. if (isset($disaster['type'])) {
  66. $typeName = \App\Module\Farm\Enums\DISASTER_TYPE::getName($disaster['type']);
  67. $status = $disaster['status'] ?? 'active';
  68. if ($status === 'active') {
  69. $result[] = '<span class="badge badge-danger">' . $typeName . '</span>';
  70. } else {
  71. $result[] = '<span class="badge badge-secondary">' . $typeName . '(已处理)</span>';
  72. }
  73. }
  74. }
  75. return empty($result) ? '无' : implode(' ', $result);
  76. });
  77. $grid->column('crop.fertilized', '是否施肥')->bool();
  78. $helper->columnCreatedAt();
  79. $helper->columnUpdatedAt();
  80. $grid->filter(function (Grid\Filter $filter) {
  81. $filterHelper = new FilterHelper($filter, $this);
  82. $filterHelper->equalId();
  83. $filterHelper->equalUserId();
  84. $filter->equal('position', '位置');
  85. $filterHelper->equalLandType();
  86. $filterHelper->equalLandStatus();
  87. $filter->equal('has_crop', '是否有作物')->select([0 => '无作物', 1 => '有作物']);
  88. $filter->equal('crop.seed_id', '种子ID');
  89. $filter->equal('crop.growth_stage', '生长阶段')->select(\App\Module\Farm\Enums\GROWTH_STAGE::getAll());
  90. $filterHelper->betweenDatetime('created_at', '创建时间');
  91. });
  92. $grid->actions(function (Grid\Displayers\Actions $actions){
  93. $actions->disableDelete();
  94. });
  95. // 默认按ID倒序排列
  96. $grid->model()->orderBy('id', 'desc');
  97. });
  98. }
  99. /**
  100. * 构建详情页
  101. *
  102. * @param mixed $id
  103. * @return Show
  104. */
  105. protected function detail($id)
  106. {
  107. return Show::make($id, new FarmLandRepository(), function (Show $show) {
  108. $helper = new ShowHelper($show, $this);
  109. $show->field('id', 'ID');
  110. $helper->fieldUserId('user_id', '用户ID');
  111. $show->field('position', '位置');
  112. $helper->fieldLandType('land_type', '土地类型');
  113. $helper->fieldLandStatus('status', '状态');
  114. $show->field('created_at', '创建时间');
  115. $show->field('updated_at', '更新时间');
  116. });
  117. }
  118. /**
  119. * 构建表单
  120. *
  121. * @return Form
  122. */
  123. protected function form()
  124. {
  125. return Form::make(new FarmLandRepository(), function (Form $form) {
  126. $helper = new FormHelper($form, $this);
  127. $form->display('id', 'ID');
  128. $helper->selectTableUserID('user_id', '用户ID');
  129. $form->number('position', '位置')->min(1)->max(20)->required();
  130. $helper->selectLandType('land_type', '土地类型');
  131. // 直接使用select方法而不是selectOptionCast,避免枚举类型转换问题
  132. $form->select('status', '状态')->options(\App\Module\Farm\Enums\LAND_STATUS::getValueDescription());
  133. $form->display('has_crop', '是否有作物')->with(function ($value) {
  134. return $value ? '有作物' : '无作物';
  135. });
  136. $form->display('created_at', '创建时间');
  137. $form->display('updated_at', '更新时间');
  138. // 添加保存前的回调函数,确保status字段是整数类型
  139. $form->saving(function (Form $form) {
  140. // 确保status是整数
  141. if ($form->status !== null) {
  142. $form->status = (int)$form->status;
  143. }
  144. // 根据状态自动更新has_crop字段
  145. $status = (int)$form->status;
  146. $form->has_crop = in_array($status, [1, 2, 3, 4]) ? 1 : 0;
  147. });
  148. });
  149. }
  150. }