Balance.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace app\data\controller\user;
  3. use app\data\model\DataUser;
  4. use app\data\model\DataUserBalance;
  5. use app\data\service\UserAdminService;
  6. use app\data\service\UserBalanceService;
  7. use app\data\service\UserUpgradeService;
  8. use think\admin\Controller;
  9. use think\admin\extend\CodeExtend;
  10. use think\admin\model\SystemUser;
  11. use think\admin\service\AdminService;
  12. /**
  13. * 余额充值记录
  14. * Class Balance
  15. * @package app\data\controller\user
  16. */
  17. class Balance extends Controller
  18. {
  19. /**
  20. * 余额充值管理
  21. * @auth true
  22. * @menu true
  23. * @throws \think\db\exception\DataNotFoundException
  24. * @throws \think\db\exception\DbException
  25. * @throws \think\db\exception\ModelNotFoundException
  26. */
  27. public function index()
  28. {
  29. $this->title = '余额充值记录';
  30. // 统计用户余额
  31. $this->balance = UserBalanceService::instance()->amount(0);
  32. // 现有余额类型
  33. $this->names = DataUserBalance::mk()->group('name')->column('name');
  34. // 创建查询对象
  35. $query = DataUserBalance::mQuery()->equal('name,upgrade');
  36. // 用户搜索查询
  37. $db = DataUser::mQuery()->like('phone#user_phone,nickname#user_nickname')->db();
  38. if ($db->getOptions('where')) $query->whereRaw("uuid in {$db->field('id')->buildSql()}");
  39. // 数据查询分页
  40. $query->where(['deleted' => 0])->like('code,remark')->dateBetween('create_at')->order('id desc')->page();
  41. }
  42. /**
  43. * 数据列表处理
  44. * @param array $data
  45. */
  46. protected function _index_page_filter(array &$data)
  47. {
  48. UserAdminService::instance()->buildByUid($data);
  49. $uids = array_unique(array_column($data, 'create_by'));
  50. $users = SystemUser::mk()->whereIn('id', $uids)->column('username', 'id');
  51. $this->upgrades = UserUpgradeService::instance()->levels();
  52. foreach ($data as &$vo) {
  53. $vo['upgradeinfo'] = $this->upgrades[$vo['upgrade']] ?? [];
  54. $vo['create_byname'] = $users[$vo['create_by']] ?? '';
  55. }
  56. }
  57. /**
  58. * 添加余额充值
  59. * @auth true
  60. * @throws \think\db\exception\DataNotFoundException
  61. * @throws \think\db\exception\DbException
  62. * @throws \think\db\exception\ModelNotFoundException
  63. */
  64. public function add()
  65. {
  66. $data = $this->_vali(['uuid.require' => '用户UID不能为空!']);
  67. $this->user = DataUser::mk()->where(['id' => $data['uuid']])->find();
  68. if (empty($this->user)) $this->error('待充值的用户不存在!');
  69. DataUserBalance::mForm('form');
  70. }
  71. /**
  72. * 表单数据处理
  73. * @param array $data
  74. */
  75. protected function _form_filter(array &$data)
  76. {
  77. if (empty($data['code'])) {
  78. $data['code'] = CodeExtend::uniqidDate('20', 'B');
  79. }
  80. if ($this->request->isGet()) {
  81. $this->upgrades = UserUpgradeService::instance()->levels();
  82. }
  83. if ($this->request->isPost()) {
  84. $data['create_by'] = AdminService::instance()->getUserId();
  85. if (empty(floatval($data['amount'])) && empty($data['upgrade'])) {
  86. $this->error('金额为零并且没有升级行为!');
  87. }
  88. }
  89. }
  90. /**
  91. * 表单结果处理
  92. * @param bool $state
  93. * @param array $data
  94. * @throws \think\db\exception\DbException
  95. */
  96. protected function _form_result(bool $state, array $data)
  97. {
  98. if ($state && isset($data['uuid'])) {
  99. UserBalanceService::instance()->amount($data['uuid']);
  100. UserUpgradeService::instance()->upgrade($data['uuid']);
  101. }
  102. }
  103. /**
  104. * 删除充值记录
  105. * @auth true
  106. */
  107. public function remove()
  108. {
  109. DataUserBalance::mDelete('', [['code', 'like', 'B%']]);
  110. }
  111. /**
  112. * 删除结果处理
  113. * @param bool $state
  114. * @throws \think\db\exception\DbException
  115. */
  116. protected function _delete_result(bool $state)
  117. {
  118. if ($state) {
  119. $map = [['id', 'in', str2arr(input('id', ''))]];
  120. foreach ($this->app->db->name($this->table)->where($map)->cursor() as $vo) {
  121. UserBalanceService::instance()->amount($vo['uuid']);
  122. UserUpgradeService::instance()->upgrade($vo['uuid']);
  123. }
  124. }
  125. }
  126. }