UserOutputCounterController.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <?php
  2. namespace App\Module\GameItems\AdminControllers;
  3. use App\Module\GameItems\Models\ItemUserOutputCounter;
  4. use App\Module\GameItems\Models\ItemOutputLimit;
  5. use Dcat\Admin\Grid;
  6. use Dcat\Admin\Show;
  7. use Dcat\Admin\Layout\Content;
  8. use Spatie\RouteAttributes\Attributes\Resource;
  9. use UCore\DcatAdmin\AdminController;
  10. #[Resource('game-items-user-output-counters', names: 'dcat.admin.game-items-user-output-counters')]
  11. class UserOutputCounterController extends AdminController
  12. {
  13. /**
  14. * 标题
  15. *
  16. * @var string
  17. */
  18. protected $title = '用户产出限制计数';
  19. /**
  20. * 禁用创建按钮
  21. *
  22. * @var bool
  23. */
  24. protected $showCreateButton = false;
  25. /**
  26. * 列表页
  27. *
  28. * @return Grid
  29. */
  30. protected function grid()
  31. {
  32. return Grid::make(new ItemUserOutputCounter(), function (Grid $grid) {
  33. // 禁用创建、编辑和删除按钮
  34. $grid->disableCreateButton();
  35. $grid->disableActions();
  36. $grid->disableBatchDelete();
  37. $grid->disableDeleteButton();
  38. $grid->disableEditButton();
  39. // 只保留详情按钮
  40. $grid->actions(function (Grid\Displayers\Actions $actions) {
  41. $actions->disableDelete();
  42. $actions->disableEdit();
  43. $actions->disableQuickEdit();
  44. });
  45. $grid->column('id', 'ID')->sortable();
  46. $grid->column('user_id', '用户ID');
  47. $grid->column('outputLimit.item.name', '物品名称');
  48. $grid->column('current_count', '当前计数');
  49. $grid->column('last_reset_time', '上次重置时间');
  50. $grid->column('created_at', '创建时间');
  51. $grid->column('updated_at', '更新时间');
  52. // 筛选
  53. $grid->filter(function ($filter) {
  54. $filter->equal('id', 'ID');
  55. $filter->equal('user_id', '用户ID');
  56. $filter->equal('limit_id', '限制ID')->select(
  57. ItemOutputLimit::with('item')->get()->pluck('item.name', 'id')
  58. );
  59. $filter->between('current_count', '当前计数');
  60. $filter->between('last_reset_time', '上次重置时间')->datetime();
  61. });
  62. });
  63. }
  64. /**
  65. * 详情页
  66. *
  67. * @param mixed $id
  68. * @param Content $content
  69. * @return Content
  70. */
  71. public function show($id, Content $content)
  72. {
  73. return $content
  74. ->header($this->title)
  75. ->description('详情')
  76. ->body($this->detail($id));
  77. }
  78. /**
  79. * 详情页
  80. *
  81. * @param mixed $id
  82. * @return Show
  83. */
  84. protected function detail($id)
  85. {
  86. return Show::make(ItemUserOutputCounter::findOrFail($id), function (Show $show) {
  87. // 禁用编辑和删除按钮
  88. $show->panel()->tools(function ($tools) {
  89. $tools->disableEdit();
  90. $tools->disableDelete();
  91. });
  92. $show->field('id', 'ID');
  93. $show->field('user_id', '用户ID');
  94. // 显示限制信息
  95. $show->field('limit_id', '限制ID');
  96. $show->field('outputLimit.item.name', '物品名称');
  97. $show->field('outputLimit.limit_type', '限制类型')->as(function ($value) {
  98. $types = [
  99. ItemOutputLimit::LIMIT_TYPE_GLOBAL => '全局限制',
  100. ItemOutputLimit::LIMIT_TYPE_USER => '用户限制',
  101. ItemOutputLimit::LIMIT_TYPE_DAILY => '每日限制',
  102. ItemOutputLimit::LIMIT_TYPE_WEEKLY => '每周限制',
  103. ItemOutputLimit::LIMIT_TYPE_MONTHLY => '每月限制',
  104. ];
  105. return $types[$value] ?? '未知';
  106. });
  107. $show->field('outputLimit.max_quantity', '最大数量');
  108. $show->field('current_count', '当前计数');
  109. // 计算剩余可获取数量
  110. $show->field('remaining_count', '剩余可获取数量')->as(function () {
  111. if (!$this->outputLimit) {
  112. return '未知';
  113. }
  114. $remaining = max(0, $this->outputLimit->max_quantity - $this->current_count);
  115. return $remaining;
  116. });
  117. $show->field('last_reset_time', '上次重置时间');
  118. $show->field('created_at', '创建时间');
  119. $show->field('updated_at', '更新时间');
  120. });
  121. }
  122. }