Users.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. <?php
  2. /**
  3. * User: nickbai
  4. * Date: 2017/10/23 13:33
  5. * Email: 1902822973@qq.com
  6. */
  7. namespace app\admin\controller;
  8. class Users extends Base
  9. {
  10. // 客服列表
  11. public function index()
  12. {
  13. if(request()->isAjax()){
  14. $result = db('users')->order('id', 'desc')->select();
  15. foreach($result as $key=>$vo){
  16. // 优化显示头像
  17. $result[$key]['user_avatar'] = '<img src="' . $vo['user_avatar'] . '" width="40px" height="40px">';
  18. // 优化显示状态
  19. if(1 == $vo['status']){
  20. $result[$key]['status'] = '<span class="label label-primary">启用</span>';
  21. }else{
  22. $result[$key]['status'] = '<span class="label label-danger">禁用</span>';
  23. }
  24. // 查询分组
  25. $result[$key]['group'] = '-';
  26. $groups = db('groups')->field('name')->where('id', $vo['group_id'])->find();
  27. if(!empty($groups)){
  28. $result[$key]['group'] = $groups['name'];
  29. }
  30. // 优化显示在线状态
  31. /*if(1 == $vo['online']){
  32. $result[$key]['online'] = '<span class="label label-primary">在线</span>';
  33. }else{
  34. $result[$key]['online'] = '<span class="label label-danger">离线</span>';
  35. }*/
  36. // 生成操作按钮
  37. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  38. }
  39. $return['total'] = db('users')->count(); //总数据
  40. $return['rows'] = $result;
  41. return json($return);
  42. }
  43. return $this->fetch();
  44. }
  45. // 添加客服
  46. public function addUser()
  47. {
  48. if(request()->isPost()){
  49. $param = input('post.');
  50. unset($param['file']); // 删除layui头像上传隐藏字段
  51. // 检测头像
  52. if(empty($param['user_avatar'])){
  53. return json(['code' => -1, 'data' => '', 'msg' => '请上传头像']);
  54. }
  55. if(empty($param['group_id'])){
  56. return json(['code' => -4, 'data' => '', 'msg' => '请选择分组']);
  57. }
  58. $has = db('users')->field('id')->where('user_name', $param['user_name'])->find();
  59. if(!empty($has)){
  60. return json(['code' => -2, 'data' => '', 'msg' => '该客服已经存在']);
  61. }
  62. $param['user_pwd'] = md5($param['user_pwd'] . config('salt'));
  63. $param['online'] = 2; // 离线状态
  64. try{
  65. db('users')->insert($param);
  66. }catch(\Exception $e){
  67. return json(['code' => -3, 'data' => '', 'msg' => $e->getMessage()]);
  68. }
  69. return json(['code' => 1, 'data' => '', 'msg' => '添加客服成功']);
  70. }
  71. $this->assign([
  72. 'groups' => db('groups')->select(),
  73. 'status' => config('kf_status')
  74. ]);
  75. return $this->fetch();
  76. }
  77. // 编辑客服
  78. public function editUser()
  79. {
  80. if(request()->isAjax()){
  81. $param = input('post.');
  82. unset($param['file']); // 删除layui头像上传隐藏字段
  83. if(empty($param['group_id'])){
  84. return json(['code' => -4, 'data' => '', 'msg' => '请选择分组']);
  85. }
  86. // 检测用户修改的用户名是否重复
  87. $has = db('users')->where('user_name', $param['user_name'])->where('id', '<>', $param['id'])->find();
  88. if(!empty($has)){
  89. return json(['code' => -1, 'data' => '', 'msg' => '该客服已经存在']);
  90. }
  91. // 修改用户头像
  92. if(empty($param['user_avatar'])){
  93. unset($param['user_avatar']);
  94. }
  95. // 修改用户密码
  96. if(empty($param['user_pwd'])){
  97. unset($param['user_pwd']);
  98. }else{
  99. $param['user_pwd'] = md5($param['user_pwd'] . config('salt'));
  100. }
  101. try{
  102. db('users')->where('id', $param['id'])->update($param);
  103. }catch(\Exception $e){
  104. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  105. }
  106. return json(['code' => 1, 'data' => '', 'msg' => '编辑客服成功']);
  107. }
  108. $id = input('param.id/d');
  109. $info = db('users')->where('id', $id)->find();
  110. $this->assign([
  111. 'info' => $info,
  112. 'status' => config('kf_status'),
  113. 'groups' => db('groups')->select()
  114. ]);
  115. return $this->fetch();
  116. }
  117. // 删除客服
  118. public function delUser()
  119. {
  120. if(request()->isAjax()){
  121. $id = input('param.id/d');
  122. try{
  123. db('users')->where('id', $id)->delete();
  124. }catch(\Exception $e){
  125. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  126. }
  127. return json(['code' => 1, 'data' => '', 'msg' => '删除客服成功']);
  128. }
  129. }
  130. // 上传客服头像
  131. public function upAvatar()
  132. {
  133. if(request()->isAjax()) {
  134. $file = request()->file('file');
  135. if (!empty($file)) {
  136. // 移动到框架应用根目录/public/uploads/ 目录下
  137. $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
  138. if ($info) {
  139. $src = '/uploads' . '/' . date('Ymd') . '/' . $info->getFilename();
  140. return json(['code' => 0, 'data' => ['src' => $src], 'msg' => 'ok']);
  141. } else {
  142. // 上传失败获取错误信息
  143. return json(['code' => -1, 'data' => '', 'msg' => $file->getError()]);
  144. }
  145. }
  146. }
  147. }
  148. // 生成按钮
  149. private function makeBtn($id)
  150. {
  151. $operate = '<a href="' . url('users/edituser', ['id' => $id]) . '">';
  152. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  153. $operate .= '<a href="javascript:userDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  154. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  155. //$operate .= '<a href="javascript:;">';
  156. //$operate .= '<button type="button" class="btn btn-info btn-sm"><i class="fa fa-institution"></i> 详情</button></a>';
  157. return $operate;
  158. }
  159. }