FarmCropLogController.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. <?php
  2. namespace App\Module\Farm\AdminControllers;
  3. use App\Module\Farm\Models\FarmCropLog;
  4. use App\Module\Farm\Repositories\FarmCropLogRepository;
  5. use UCore\DcatAdmin\AdminController;
  6. use App\Module\Farm\AdminControllers\Helper\GridHelper;
  7. use App\Module\Farm\AdminControllers\Helper\ShowHelper;
  8. use App\Module\Farm\AdminControllers\Helper\FilterHelper;
  9. use Dcat\Admin\Grid;
  10. use Dcat\Admin\Show;
  11. use Dcat\Admin\Http\Controllers\AdminController as BaseAdminController;
  12. use Dcat\Admin\Layout\Content;
  13. use Dcat\Admin\Widgets\Alert;
  14. use Spatie\RouteAttributes\Attributes\Resource;
  15. /**
  16. * 作物事件日志管理控制器
  17. */
  18. #[Resource('farm-crop-logs', names: 'dcat.admin.farm-crop-logs')]
  19. class FarmCropLogController extends AdminController
  20. {
  21. /**
  22. * 页面标题
  23. *
  24. * @var string
  25. */
  26. protected $title = '作物事件日志管理';
  27. /**
  28. * 页面描述
  29. *
  30. * @var string
  31. */
  32. protected $description = '查看作物生长过程中的各种事件记录';
  33. /**
  34. * 构建表格
  35. *
  36. * @return Grid
  37. */
  38. protected function grid()
  39. {
  40. return Grid::make(new FarmCropLogRepository(['crop', 'seed', 'land']), function (Grid $grid) {
  41. $helper = new GridHelper($grid, $this);
  42. $helper->columnId();
  43. $grid->column('user_id', '用户ID')->sortable();
  44. $grid->column('crop.id', '作物ID')->display(function ($value) {
  45. return "<span class='badge badge-primary'>作物#{$value}</span>";
  46. });
  47. $grid->column('seed.name', '种子名称')->display(function ($value) {
  48. return "<span class='badge badge-info'>{$value}</span>";
  49. });
  50. $grid->column('land.id', '土地ID')->display(function ($value) {
  51. return "<span class='badge badge-secondary'>土地#{$value}</span>";
  52. });
  53. $grid->column('event_type', '事件类型')->display(function ($value) {
  54. $colors = [
  55. FarmCropLog::EVENT_FRUIT_CONFIRMED => 'success',
  56. FarmCropLog::EVENT_OUTPUT_CALCULATED => 'info',
  57. FarmCropLog::EVENT_DISASTER_OCCURRED => 'danger',
  58. FarmCropLog::EVENT_DISASTER_CLEARED => 'warning',
  59. FarmCropLog::EVENT_HARVESTED => 'primary',
  60. FarmCropLog::EVENT_FERTILIZED => 'success',
  61. FarmCropLog::EVENT_PESTICIDE_USED => 'warning',
  62. FarmCropLog::EVENT_WEEDICIDE_USED => 'warning',
  63. FarmCropLog::EVENT_WATERING => 'info',
  64. ];
  65. $color = $colors[$value] ?? 'secondary';
  66. $names = [
  67. FarmCropLog::EVENT_FRUIT_CONFIRMED => '确认果实种类',
  68. FarmCropLog::EVENT_OUTPUT_CALCULATED => '确认产出数量',
  69. FarmCropLog::EVENT_DISASTER_OCCURRED => '灾害产生',
  70. FarmCropLog::EVENT_DISASTER_CLEARED => '灾害清除',
  71. FarmCropLog::EVENT_HARVESTED => '收获',
  72. FarmCropLog::EVENT_FERTILIZED => '施肥',
  73. FarmCropLog::EVENT_PESTICIDE_USED => '使用杀虫剂',
  74. FarmCropLog::EVENT_WEEDICIDE_USED => '使用除草剂',
  75. FarmCropLog::EVENT_WATERING => '浇水',
  76. ];
  77. $name = $names[$value] ?? '未知事件';
  78. return "<span class='badge badge-{$color}'>{$name}</span>";
  79. });
  80. $grid->column('growth_stage_name', '生长阶段')->display(function ($value) {
  81. return "<span class='badge badge-info'>{$value}</span>";
  82. });
  83. $grid->column('event_data', '事件数据')->display(function ($value) {
  84. if (empty($value)) {
  85. return '<span class="text-muted">无数据</span>';
  86. }
  87. // 使用静态方法解析数据
  88. $summary = FarmCropLog::parseEventDataSummary($this->event_type, $value);
  89. return "<small class='text-info'>{$summary}</small>";
  90. });
  91. $helper->columnCreatedAt();
  92. // 筛选器
  93. $grid->filter(function (Grid\Filter $filter) {
  94. $helper = new FilterHelper($filter, $this);
  95. $filter->equal('user_id', '用户ID');
  96. $filter->equal('crop_id', '作物ID');
  97. $filter->equal('land_id','土地ID');
  98. $filter->equal('event_type', '事件类型')->select([
  99. FarmCropLog::EVENT_FRUIT_CONFIRMED => '确认果实种类',
  100. FarmCropLog::EVENT_OUTPUT_CALCULATED => '确认产出数量',
  101. FarmCropLog::EVENT_DISASTER_OCCURRED => '灾害产生',
  102. FarmCropLog::EVENT_DISASTER_CLEARED => '灾害清除',
  103. FarmCropLog::EVENT_HARVESTED => '收获',
  104. FarmCropLog::EVENT_FERTILIZED => '施肥',
  105. FarmCropLog::EVENT_PESTICIDE_USED => '使用杀虫剂',
  106. FarmCropLog::EVENT_WEEDICIDE_USED => '使用除草剂',
  107. FarmCropLog::EVENT_WATERING => '浇水',
  108. ]);
  109. $filter->equal('growth_stage', '生长阶段')->select(\App\Module\Farm\Enums\GROWTH_STAGE::getAll());
  110. $helper->betweenDatetime('created_at', '事件时间');
  111. });
  112. // 禁用新增、编辑、删除操作(只读日志)
  113. $grid->disableCreateButton();
  114. $grid->disableEditButton();
  115. $grid->disableDeleteButton();
  116. $grid->disableBatchDelete();
  117. // 设置默认排序
  118. $grid->model()->orderBy('created_at', 'desc');
  119. // 设置每页显示数量
  120. $grid->paginate(20);
  121. });
  122. }
  123. /**
  124. * 构建详情页
  125. *
  126. * @param mixed $id
  127. * @return Show
  128. */
  129. protected function detail($id)
  130. {
  131. return Show::make($id, new FarmCropLogRepository(['crop', 'seed', 'land']), function (Show $show) {
  132. $helper = new ShowHelper($show, $this);
  133. $show->field('id', 'ID');
  134. $show->field('user_id', '用户ID');
  135. $show->field('crop.id', '作物ID');
  136. $show->field('seed.name', '种子名称');
  137. $show->field('land.id', '土地ID');
  138. $show->field('event_type_name', '事件类型');
  139. $show->field('growth_stage_name', '生长阶段');
  140. $show->field('land_type', '土地类型');
  141. $show->field('event_data', '事件详细数据')->as(function ($value) {
  142. return FarmCropLog::parseEventDataDetail($this->event_type, $value);
  143. });
  144. $show->field('created_at', '创建时间');
  145. $show->field('updated_at', '更新时间');
  146. // 禁用编辑和删除按钮
  147. $show->disableEditButton();
  148. $show->disableDeleteButton();
  149. });
  150. }
  151. /**
  152. * 重写index方法,添加统计信息
  153. */
  154. public function index(Content $content)
  155. {
  156. return $content
  157. ->title($this->title())
  158. ->description($this->description())
  159. ->body($this->getStatsCards())
  160. ->body($this->grid());
  161. }
  162. /**
  163. * 获取统计卡片
  164. */
  165. protected function getStatsCards()
  166. {
  167. $stats = [
  168. '总事件数' => FarmCropLog::count(),
  169. '今日事件数' => FarmCropLog::whereDate('created_at', today())->count(),
  170. '确认果实事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_FRUIT_CONFIRMED)->count(),
  171. '产出计算事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_OUTPUT_CALCULATED)->count(),
  172. '灾害产生事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_DISASTER_OCCURRED)->count(),
  173. '灾害清除事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_DISASTER_CLEARED)->count(),
  174. '收获事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_HARVESTED)->count(),
  175. '施肥事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_FERTILIZED)->count(),
  176. '除虫事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_PESTICIDE_USED)->count(),
  177. '除草事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_WEEDICIDE_USED)->count(),
  178. '浇水事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_WATERING)->count(),
  179. ];
  180. $cards = '';
  181. foreach ($stats as $title => $count) {
  182. $cards .= "
  183. <div class='col-md-3'>
  184. <div class='small-box bg-info'>
  185. <div class='inner'>
  186. <h3>{$count}</h3>
  187. <p>{$title}</p>
  188. </div>
  189. <div class='icon'>
  190. <i class='fa fa-list'></i>
  191. </div>
  192. </div>
  193. </div>
  194. ";
  195. }
  196. return "<div class='row'>{$cards}</div>";
  197. }
  198. }