User.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <?php
  2. namespace app\admin\controller\user;
  3. use app\common\controller\Backend;
  4. use think\Db;
  5. /**
  6. * 会员管理
  7. *
  8. * @icon fa fa-user
  9. */
  10. class User extends Backend
  11. {
  12. protected $searchFields = 'id,username,nickname';
  13. protected $selectpageFields = 'id,username,nickname,mobile';
  14. /**
  15. * User模型对象
  16. * @var \app\admin\model\User
  17. */
  18. protected $model = null;
  19. public function _initialize()
  20. {
  21. parent::_initialize();
  22. $this->model = new \app\admin\model\User;
  23. $this->view->assign("genderList", $this->model->getGenderList());
  24. $this->view->assign("idcardStatusList", $this->model->getIdcardStatusList());
  25. $this->view->assign("realStatusList", $this->model->getRealStatusList());
  26. $this->view->assign("statusList", $this->model->getStatusList());
  27. $this->view->assign("hideIsFinishinfoList", $this->model->getHideIsFinishinfoList());
  28. $this->view->assign("isActiveList", $this->model->getIsActiveList());
  29. $this->view->assign("openMatchVideoList", $this->model->getOpenMatchVideoList());
  30. $this->view->assign("openMatchAudioList", $this->model->getOpenMatchAudioList());
  31. $this->view->assign("jinyantypeList", $this->model->getJinyantypeList());
  32. $this->view->assign("isShouchongList", $this->model->getIsShouchongList());
  33. $groupIdList = Db::name('user_group')->order('id asc')->column('id,name');
  34. $this->view->assign("groupIdList", $groupIdList);
  35. }
  36. public function import()
  37. {
  38. parent::import();
  39. }
  40. /**
  41. * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
  42. * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
  43. * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
  44. */
  45. /**
  46. * 查看
  47. */
  48. public function index()
  49. {
  50. //当前是否为关联查询
  51. $this->relationSearch = true;
  52. //设置过滤方法
  53. $this->request->filter(['strip_tags', 'trim']);
  54. if ($this->request->isAjax()) {
  55. //如果发送的来源是Selectpage,则转发到Selectpage
  56. if ($this->request->request('keyField')) {
  57. return $this->selectpage();
  58. }
  59. list($where, $sort, $order, $offset, $limit) = $this->buildparams();
  60. $list = $this->model
  61. ->with(['usergroup','userwallet'])
  62. ->where($where)
  63. ->order($sort, $order)
  64. ->paginate($limit);
  65. foreach ($list as $row) {
  66. $row->getRelation('usergroup')->visible(['name']);
  67. $row->getRelation('userwallet')->visible(['gold','jewel']);
  68. }
  69. $result = array("total" => $list->total(), "rows" => $list->items());
  70. return json($result);
  71. }
  72. return $this->view->fetch();
  73. }
  74. /**
  75. * 充值金币
  76. */
  77. public function updatemoney(){
  78. $id = input('id');
  79. $info = Db::name('user_wallet')
  80. ->where('id',$id)
  81. ->find();
  82. if ($this->request->isPost()) {
  83. $user_id = input('user_id');
  84. $gold = input('gold');
  85. $remark = input('remark','后台调节');
  86. Db::startTrans();
  87. $rs = model('wallet')->lockChangeAccountRemain($user_id,'gold',$gold,1,$remark);
  88. if($rs['status'] === false){
  89. Db::rollback();
  90. $this->error($rs['msg']);
  91. }
  92. Db::commit();
  93. $this->success('充值完成');
  94. }
  95. $this->assign('row',$info);
  96. return $this->view->fetch();
  97. }
  98. /**
  99. * 收益金币
  100. */
  101. public function updatejewel(){
  102. $id = input('id');
  103. $info = Db::name('user_wallet')
  104. ->where('id',$id)
  105. ->find();
  106. if ($this->request->isPost()) {
  107. $user_id = input('user_id');
  108. $jewel = input('jewel');
  109. $remark = input('remark','后台调节');
  110. Db::startTrans();
  111. $rs = model('wallet')->lockChangeAccountRemain($user_id,'jewel',$jewel,2,$remark);
  112. if($rs['status'] === false){
  113. Db::rollback();
  114. $this->error($rs['msg']);
  115. }
  116. Db::commit();
  117. $this->success('充值完成');
  118. }
  119. $this->assign('row',$info);
  120. return $this->view->fetch();
  121. }
  122. /**
  123. * 清空手机号+身份证
  124. */
  125. public function cleanmobile(){
  126. if ($this->request->isAjax()) {
  127. $user_id = input('id');
  128. $userinfo = Db::name('user')->where('id',$user_id)->find();
  129. if($userinfo['status'] != '-1'){
  130. $this->error('请先将用户注销');
  131. }
  132. Db::name('user')->where('id',$user_id)->update(['mobile'=>'']);
  133. Db::name('user_idconfirm')->where('user_id',$user_id)->delete();
  134. $this->success('已清空');
  135. }
  136. }
  137. }