UserController.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. <?php
  2. namespace App\Module\Game\AdminControllers;
  3. use App\Module\AppGame\AdminControllers\Actions\ResetLogin;
  4. use App\Module\User\AdminControllers\Actions\ChangePasswordAction;
  5. use App\Module\User\AdminControllers\Actions\UserRelatedPagesAction;
  6. use App\Module\Game\AdminControllers\Helper\FilterHelper;
  7. use App\Module\Game\AdminControllers\Helper\GridHelper;
  8. use App\Module\Game\AdminControllers\Helper\ShowHelper;
  9. use App\Module\User\Enums\STATUS2;
  10. use App\Module\User\Repositorys\UserRepository;
  11. use App\Module\User\Services\UserService;
  12. use Dcat\Admin\Form;
  13. use Dcat\Admin\Grid;
  14. use Dcat\Admin\Show;
  15. use Spatie\RouteAttributes\Attributes\Resource;
  16. use UCore\DcatAdmin\AdminController;
  17. use UCore\Helper\NumberWan;
  18. /**
  19. * 游戏用户管理控制器
  20. *
  21. * 专门用于管理游戏相关的用户信息,包括资金、物品、土地、神像buff、作物等游戏数据
  22. */
  23. #[Resource('game-users', names: 'dcat.admin.game-users')]
  24. class UserController extends AdminController
  25. {
  26. /**
  27. * 页面标题
  28. *
  29. * @var string
  30. */
  31. protected $title = '游戏用户管理';
  32. /**
  33. * 用户服务
  34. *
  35. * @var UserService
  36. */
  37. protected $service;
  38. /**
  39. * 构造函数
  40. */
  41. public function __construct()
  42. {
  43. $this->service = new UserService();
  44. }
  45. /**
  46. * 列表页面
  47. *
  48. * @return Grid
  49. */
  50. protected function grid()
  51. {
  52. return Grid::make(new UserRepository(['info', 'primaryPhone', 'farmUser', 'fundAccounts', 'fundAccounts.fund_config','items.item', 'lands.landType', 'crops.seed']), function (Grid $grid) {
  53. $helper = new GridHelper($grid, $this);
  54. $grid->model()->where('id','>',10000);
  55. // 基础列
  56. $grid->column('id', '用户ID');
  57. $grid->column('username', '用户名');
  58. // 用户活动时间
  59. $helper->columnUserActivityTimes(); // 组合列,显示最后登录时间和最后活动时间
  60. // 添加联系方式列
  61. $grid->column('contact', '联系方式')->display(function ($value) {
  62. // 获取当前行的模型数据
  63. $model = $this;
  64. $phone = $model->primaryPhone ? $model->primaryPhone->phone : '';
  65. $email = $model->email ?? '';
  66. $contacts = [];
  67. if ($phone) {
  68. $contacts[] = '<span class="badge badge-primary">' . $phone . '</span>';
  69. }
  70. if ($email) {
  71. $contacts[] = '<span class="badge badge-info">' . $email . '</span>';
  72. }
  73. return $contacts ? implode(' ', $contacts) : '<span class="text-muted">无</span>';
  74. });
  75. // 添加游戏状态列
  76. $grid->column('game_status', '游戏状态')->display(function () {
  77. $model = $this;
  78. $farmUser = $model->farmUser;
  79. $status = [];
  80. if ($farmUser) {
  81. $status[] = '<span class="badge badge-success">农场等级: ' . $farmUser->house_level . '</span>';
  82. } else {
  83. $status[] = '<span class="badge badge-secondary">未开通农场</span>';
  84. }
  85. return implode('<br>', $status);
  86. });
  87. // 添加资金账户列
  88. $grid->column('fund_accounts', '资金账户')->display(function () {
  89. $model = $this;
  90. $fundAccounts = $model->fundAccounts;
  91. if ($fundAccounts->isEmpty()) {
  92. return '<span class="text-muted">无账户</span>';
  93. }
  94. $accounts = [];
  95. foreach ($fundAccounts as $account) {
  96. // dd($account->fund_config);
  97. $fundName = $account->fund_config->name;
  98. $balance = NumberWan::formatToWan($account->balance);
  99. $accounts[] = '<span class="badge badge-primary">' . $fundName . ': ' . $balance . '</span>';
  100. }
  101. return implode('<br>', $accounts);
  102. });
  103. // 添加最后活跃时间列
  104. $grid->column('last_active', '最后活跃')->display(function () {
  105. $model = $this;
  106. $lastActive = $model->getAttribute('updated_at');
  107. if ($lastActive) {
  108. $diffInDays = intval($lastActive->diffInDays(now()));
  109. if ($diffInDays == 0) {
  110. return '<span class="badge badge-success">今天</span>';
  111. } elseif ($diffInDays <= 7) {
  112. return '<span class="badge badge-warning">' . $diffInDays . '天前</span>';
  113. } elseif ($diffInDays <= 30) {
  114. return '<span class="badge badge-info">' . $diffInDays . '天前</span>';
  115. } else {
  116. return '<span class="badge badge-secondary">' . $diffInDays . '天前</span>';
  117. }
  118. } else {
  119. return '<span class="text-muted">未知</span>';
  120. }
  121. });
  122. // 添加物品背包列
  123. $grid->column('items_summary', '物品背包')->display(function () {
  124. $model = $this;
  125. $items = $model->items;
  126. if ($items->isEmpty()) {
  127. return '<span class="text-muted">无物品</span>';
  128. }
  129. $totalItems = $items->count();
  130. $totalQuantity = $items->sum('quantity');
  131. return '<span class="badge badge-info">物品种类: ' . $totalItems . '</span><br>' .
  132. '<span class="badge badge-success">总数量: ' . $totalQuantity . '</span>';
  133. });
  134. // 添加土地状态列
  135. $grid->column('land_status', '土地状态')->display(function () {
  136. $model = $this;
  137. $lands = $model->lands;
  138. if ($lands->isEmpty()) {
  139. return '<span class="text-muted">无土地</span>';
  140. }
  141. $totalLands = $lands->count();
  142. $plantingLands = $lands->where('status', 1)->count(); // 种植中
  143. $harvestableLands = $lands->where('status', 3)->count(); // 可收获
  144. $status = [];
  145. $status[] = '<span class="badge badge-primary">总土地: ' . $totalLands . '</span>';
  146. if ($plantingLands > 0) {
  147. $status[] = '<span class="badge badge-warning">种植中: ' . $plantingLands . '</span>';
  148. }
  149. if ($harvestableLands > 0) {
  150. $status[] = '<span class="badge badge-success">可收获: ' . $harvestableLands . '</span>';
  151. }
  152. return implode('<br>', $status);
  153. });
  154. $grid->column('created_at', '创建时间');
  155. $grid->column('updated_at', '更新时间');
  156. // 行操作
  157. $grid->actions(function (Grid\Displayers\Actions $actions){
  158. // 禁用删除按钮
  159. $actions->disableDelete();
  160. // 添加修改密码操作
  161. $actions->append(new ChangePasswordAction());
  162. $actions->append(ResetLogin::make());
  163. // 添加相关页面链接操作
  164. $actions->append(new UserRelatedPagesAction());
  165. });
  166. // 筛选器
  167. $grid->filter(function (Grid\Filter $filter) {
  168. $helper = new FilterHelper($filter, $this);
  169. $helper->equalUserId();
  170. $helper->likeUsername(); // 用户名筛选
  171. $helper->likeEmail(); // 邮箱筛选
  172. });
  173. $grid->paginate(10);
  174. });
  175. }
  176. /**
  177. * 详情页面
  178. *
  179. * @param mixed $id
  180. * @return Show
  181. */
  182. protected function detail($id)
  183. {
  184. return Show::make($id, new UserRepository(), function (Show $show) {
  185. // 确保加载用户信息关联
  186. $show->model()->load('info');
  187. $helper = new ShowHelper($show, $this);
  188. // 使用高复用价值的面板方法
  189. $helper->show->divider('基本信息');
  190. $helper->fieldUserId();
  191. $helper->fieldUsername();
  192. $helper->show->field('nickname', '昵称');
  193. $helper->fieldAvatar();
  194. $helper->fieldStatus();
  195. $helper->show->divider('联系信息');
  196. $helper->show->field('phone', '手机号');
  197. $helper->show->field('email', '邮箱');
  198. $helper->show->field('wx_id', '微信号');
  199. $helper->show->divider('安全信息');
  200. $helper->fieldSecretPassword();
  201. $helper->show->field('last_check_at', '最后验证时间');
  202. $helper->show->divider('活动信息');
  203. $helper->fieldLastLoginTime();
  204. $helper->fieldLastActivityTime();
  205. $helper->show->divider('时间信息');
  206. $helper->show->field('created_at', '创建时间');
  207. $helper->show->field('updated_at', '更新时间');
  208. $helper->show->field('deleted_at', '删除时间');
  209. // 显示其他特殊字段
  210. $show->field('google2fa_secret', 'Google双因素密钥');
  211. });
  212. }
  213. /**
  214. * 表单页面
  215. *
  216. * @return Form
  217. */
  218. protected function form()
  219. {
  220. return Form::make(new UserRepository(), function (Form $form) {
  221. $form->display('id', 'ID');
  222. // 用户基本信息
  223. $form->text('username', '用户名')
  224. ->required()
  225. ->rules('required|max:100');
  226. $form->password('password', '密码')
  227. ->help('不修改请留空')
  228. ->saving(function ($value) {
  229. if ($value) {
  230. return \Illuminate\Support\Facades\Hash::make($value);
  231. }
  232. });
  233. $form->radio('status2', '状态')
  234. ->options([
  235. STATUS2::Normal->value => '正常',
  236. STATUS2::Restrict->value => '限制登录',
  237. STATUS2::Ban->value => '封禁',
  238. STATUS2::Hidden->value => '隐藏账户',
  239. STATUS2::Deleteing->value => '删除中',
  240. ])
  241. ->default(STATUS2::Normal->value);
  242. // 添加其他特殊字段
  243. $form->text('google2fa_secret', 'Google双因素密钥');
  244. $form->display('created_at', '创建时间');
  245. $form->display('updated_at', '更新时间');
  246. });
  247. }
  248. }