ActivityConditionController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. namespace App\Module\Activity\AdminControllers;
  3. use App\Module\Activity\Enums\CONDITION_TYPE;
  4. use App\Module\Activity\Models\ActivityConfig;
  5. use App\Module\Activity\Repositorys\ActivityConditionRepository;
  6. use Dcat\Admin\Form;
  7. use Dcat\Admin\Grid;
  8. use Dcat\Admin\Show;
  9. use Dcat\Admin\Http\Controllers\AdminController;
  10. /**
  11. * 活动条件控制器
  12. */
  13. class ActivityConditionController extends AdminController
  14. {
  15. /**
  16. * 标题
  17. *
  18. * @return string
  19. */
  20. protected function title()
  21. {
  22. return '活动条件';
  23. }
  24. /**
  25. * 创建表格
  26. *
  27. * @return Grid
  28. */
  29. protected function grid()
  30. {
  31. return Grid::make(new ActivityConditionRepository(), function (Grid $grid) {
  32. $grid->column('id', 'ID')->sortable();
  33. $grid->column('activity_id', '活动')->display(function ($activityId) {
  34. $activity = ActivityConfig::find($activityId);
  35. return $activity ? $activity->name : "未知活动({$activityId})";
  36. });
  37. $grid->column('condition_type', '条件类型')->display(function ($type) {
  38. return CONDITION_TYPE::getName($type);
  39. });
  40. $grid->column('is_participation_condition', '参与条件')->switch();
  41. $grid->column('is_completion_condition', '完成条件')->switch();
  42. $grid->column('display_order', '显示顺序');
  43. $grid->column('created_at', '创建时间');
  44. $grid->column('updated_at', '更新时间');
  45. $grid->filter(function (Grid\Filter $filter) {
  46. $filter->equal('id', 'ID');
  47. $filter->equal('activity_id', '活动')->select(
  48. ActivityConfig::pluck('name', 'id')
  49. );
  50. $filter->equal('condition_type', '条件类型')->select(CONDITION_TYPE::getAll());
  51. $filter->equal('is_participation_condition', '参与条件')->select([0 => '否', 1 => '是']);
  52. $filter->equal('is_completion_condition', '完成条件')->select([0 => '否', 1 => '是']);
  53. });
  54. });
  55. }
  56. /**
  57. * 创建详情页
  58. *
  59. * @param mixed $id
  60. * @return Show
  61. */
  62. protected function detail($id)
  63. {
  64. return Show::make($id, new ActivityConditionRepository(), function (Show $show) {
  65. $show->field('id', 'ID');
  66. $show->field('activity_id', '活动')->as(function ($activityId) {
  67. $activity = ActivityConfig::find($activityId);
  68. return $activity ? $activity->name : "未知活动({$activityId})";
  69. });
  70. $show->field('condition_type', '条件类型')->as(function ($type) {
  71. return CONDITION_TYPE::getName($type);
  72. });
  73. $show->field('condition_params', '条件参数')->json();
  74. $show->field('is_participation_condition', '参与条件')->as(function ($value) {
  75. return $value ? '是' : '否';
  76. });
  77. $show->field('is_completion_condition', '完成条件')->as(function ($value) {
  78. return $value ? '是' : '否';
  79. });
  80. $show->field('display_order', '显示顺序');
  81. $show->field('created_at', '创建时间');
  82. $show->field('updated_at', '更新时间');
  83. });
  84. }
  85. /**
  86. * 创建表单
  87. *
  88. * @return Form
  89. */
  90. protected function form()
  91. {
  92. return Form::make(new ActivityConditionRepository(), function (Form $form) {
  93. $form->display('id', 'ID');
  94. $form->select('activity_id', '活动')
  95. ->options(ActivityConfig::pluck('name', 'id'))
  96. ->required();
  97. $form->select('condition_type', '条件类型')
  98. ->options(CONDITION_TYPE::getAll())
  99. ->required();
  100. $form->textarea('condition_params', '条件参数')
  101. ->help('JSON格式,根据条件类型填写不同的参数');
  102. $form->switch('is_participation_condition', '参与条件')
  103. ->default(false);
  104. $form->switch('is_completion_condition', '完成条件')
  105. ->default(false);
  106. $form->number('display_order', '显示顺序')
  107. ->default(0);
  108. $form->display('created_at', '创建时间');
  109. $form->display('updated_at', '更新时间');
  110. });
  111. }
  112. }