FarmCropLogController.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  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('event_type', '事件类型')->select([
  98. FarmCropLog::EVENT_FRUIT_CONFIRMED => '确认果实种类',
  99. FarmCropLog::EVENT_OUTPUT_CALCULATED => '确认产出数量',
  100. FarmCropLog::EVENT_DISASTER_OCCURRED => '灾害产生',
  101. FarmCropLog::EVENT_DISASTER_CLEARED => '灾害清除',
  102. FarmCropLog::EVENT_HARVESTED => '收获',
  103. FarmCropLog::EVENT_FERTILIZED => '施肥',
  104. FarmCropLog::EVENT_PESTICIDE_USED => '使用杀虫剂',
  105. FarmCropLog::EVENT_WEEDICIDE_USED => '使用除草剂',
  106. FarmCropLog::EVENT_WATERING => '浇水',
  107. ]);
  108. $filter->equal('growth_stage', '生长阶段')->select(\App\Module\Farm\Enums\GROWTH_STAGE::getAll());
  109. $helper->betweenDatetime('created_at', '事件时间');
  110. });
  111. // 禁用新增、编辑、删除操作(只读日志)
  112. $grid->disableCreateButton();
  113. $grid->disableEditButton();
  114. $grid->disableDeleteButton();
  115. $grid->disableBatchDelete();
  116. // 设置默认排序
  117. $grid->model()->orderBy('created_at', 'desc');
  118. // 设置每页显示数量
  119. $grid->paginate(20);
  120. });
  121. }
  122. /**
  123. * 构建详情页
  124. *
  125. * @param mixed $id
  126. * @return Show
  127. */
  128. protected function detail($id)
  129. {
  130. return Show::make($id, new FarmCropLogRepository(['crop', 'seed', 'land']), function (Show $show) {
  131. $helper = new ShowHelper($show, $this);
  132. $show->field('id', 'ID');
  133. $show->field('user_id', '用户ID');
  134. $show->field('crop.id', '作物ID');
  135. $show->field('seed.name', '种子名称');
  136. $show->field('land.id', '土地ID');
  137. $show->field('event_type_name', '事件类型');
  138. $show->field('growth_stage_name', '生长阶段');
  139. $show->field('land_type', '土地类型');
  140. $show->field('event_data', '事件详细数据')->as(function ($value) {
  141. return FarmCropLog::parseEventDataDetail($this->event_type, $value);
  142. });
  143. $show->field('created_at', '创建时间');
  144. $show->field('updated_at', '更新时间');
  145. // 禁用编辑和删除按钮
  146. $show->disableEditButton();
  147. $show->disableDeleteButton();
  148. });
  149. }
  150. /**
  151. * 重写index方法,添加统计信息
  152. */
  153. public function index(Content $content)
  154. {
  155. return $content
  156. ->title($this->title())
  157. ->description($this->description())
  158. ->body($this->getStatsCards())
  159. ->body($this->grid());
  160. }
  161. /**
  162. * 获取统计卡片
  163. */
  164. protected function getStatsCards()
  165. {
  166. $stats = [
  167. '总事件数' => FarmCropLog::count(),
  168. '今日事件数' => FarmCropLog::whereDate('created_at', today())->count(),
  169. '确认果实事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_FRUIT_CONFIRMED)->count(),
  170. '产出计算事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_OUTPUT_CALCULATED)->count(),
  171. '灾害产生事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_DISASTER_OCCURRED)->count(),
  172. '灾害清除事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_DISASTER_CLEARED)->count(),
  173. '收获事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_HARVESTED)->count(),
  174. '施肥事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_FERTILIZED)->count(),
  175. '除虫事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_PESTICIDE_USED)->count(),
  176. '除草事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_WEEDICIDE_USED)->count(),
  177. '浇水事件' => FarmCropLog::byEventType(FarmCropLog::EVENT_WATERING)->count(),
  178. ];
  179. $cards = '';
  180. foreach ($stats as $title => $count) {
  181. $cards .= "
  182. <div class='col-md-3'>
  183. <div class='small-box bg-info'>
  184. <div class='inner'>
  185. <h3>{$count}</h3>
  186. <p>{$title}</p>
  187. </div>
  188. <div class='icon'>
  189. <i class='fa fa-list'></i>
  190. </div>
  191. </div>
  192. </div>
  193. ";
  194. }
  195. return "<div class='row'>{$cards}</div>";
  196. }
  197. }