TeamUserTalentController.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. namespace App\Module\Promotion\AdminControllers;
  3. use App\Module\Promotion\AdminControllers\Helper\FilterHelper;
  4. use App\Module\Promotion\AdminControllers\Helper\FormHelper;
  5. use App\Module\Promotion\AdminControllers\Helper\GridHelper;
  6. use App\Module\Promotion\AdminControllers\Helper\ShowHelper;
  7. use App\Module\Promotion\Repositorys\PromotionUserTalentRepository;
  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. * @package App\Module\Promotion\AdminControllers
  17. */
  18. #[Resource('promotion-user-talents', names: 'dcat.admin.promotion-user-talents')]
  19. class PromotionUserTalentController extends AdminController
  20. {
  21. /**
  22. * 标题
  23. *
  24. * @var string
  25. */
  26. protected $title = '用户达人等级管理';
  27. /**
  28. * 列表页
  29. *
  30. * @return Grid
  31. */
  32. protected function grid()
  33. {
  34. return Grid::make(new PromotionUserTalentRepository(['user']), function (Grid $grid) {
  35. $helper = new GridHelper($grid, $this);
  36. $grid->column('id', 'ID')->sortable();
  37. $grid->column('user.username', '用户名');
  38. $grid->column('user.nickname', '用户昵称');
  39. $grid->column('talent_level', '达人等级')->sortable();
  40. $grid->column('direct_count', '直推人数')->sortable();
  41. $grid->column('promotion_count', '团队总人数')->sortable();
  42. $grid->column('created_at', '创建时间');
  43. $grid->column('updated_at', '更新时间');
  44. // 筛选
  45. $grid->filter(function ($filter) {
  46. $helper = new FilterHelper($filter, $this);
  47. $helper->equal('id', 'ID');
  48. $filter->equal('user_id', '用户ID');
  49. $filter->whereLike('user.username', '用户名');
  50. $filter->whereLike('user.nickname', '用户昵称');
  51. $filter->equal('talent_level', '达人等级');
  52. $filter->between('direct_count', '直推人数');
  53. $filter->between('promotion_count', '团队总人数');
  54. $filter->between('created_at', '创建时间')->datetime();
  55. });
  56. return $grid;
  57. });
  58. }
  59. /**
  60. * 详情页
  61. *
  62. * @param mixed $id
  63. * @return Show
  64. */
  65. protected function detail($id)
  66. {
  67. return Show::make($id, new PromotionUserTalentRepository(['user']), function (Show $show) {
  68. $helper = new ShowHelper($show, $this);
  69. $helper->field('id', 'ID');
  70. $show->field('user_id', '用户ID');
  71. $show->field('user.username', '用户名');
  72. $show->field('user.nickname', '用户昵称');
  73. $show->field('talent_level', '达人等级');
  74. $show->field('direct_count', '直推人数');
  75. $show->field('promotion_count', '团队总人数');
  76. $show->field('created_at', '创建时间');
  77. $show->field('updated_at', '更新时间');
  78. return $show;
  79. });
  80. }
  81. /**
  82. * 表单
  83. *
  84. * @return Form
  85. */
  86. protected function form()
  87. {
  88. return Form::make(new PromotionUserTalentRepository(), function (Form $form) {
  89. $helper = new FormHelper($form, $this);
  90. $form->display('id', 'ID');
  91. $form->text('user_id', '用户ID')->required();
  92. $form->number('talent_level', '达人等级')->min(0)->default(0)->required();
  93. $form->number('direct_count', '直推人数')->min(0)->default(0)->required();
  94. $form->number('promotion_count', '团队总人数')->min(0)->default(0)->required();
  95. $form->display('created_at', '创建时间');
  96. $form->display('updated_at', '更新时间');
  97. return $form;
  98. });
  99. }
  100. }