Users.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  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. $param = input('param.');
  15. $limit = $param['pageSize'];
  16. $offset = (($param['pageNumber'] - 1) * $limit);
  17. $where = [];
  18. if (empty($param['searchText']) === false || intval($param['searchText']) == 0) {
  19. $where['user_account|user_name|user_job_number|fullname'] = ['like', '%' . $param['searchText'] . '%'];
  20. }else{
  21. return 1;
  22. }
  23. //客服组
  24. if ($param['group_id'] != '' && $param['group_id'] != 0) {
  25. $where['group_id'] = $param['group_id'];
  26. }
  27. $result = db('users')->where($where)->limit($offset, $limit)->order('id', 'desc')->select();
  28. foreach($result as $key=>$vo){
  29. // 优化显示头像
  30. $result[$key]['user_avatar'] = '<img src="' . $vo['user_avatar'] . '" width="40px" height="40px">';
  31. // 优化显示状态
  32. if(1 == $vo['status']){
  33. $result[$key]['status'] = '<span class="label label-primary">启用</span>';
  34. }else{
  35. $result[$key]['status'] = '<span class="label label-danger">禁用</span>';
  36. }
  37. // 查询分组
  38. $result[$key]['group'] = '-';
  39. $groups = db('groups')->field('name')->where('id', $vo['group_id'])->find();
  40. if(!empty($groups)){
  41. $result[$key]['group'] = $groups['name'];
  42. }
  43. // 优化显示在线状态
  44. /*if(1 == $vo['online']){
  45. $result[$key]['online'] = '<span class="label label-primary">在线</span>';
  46. }else{
  47. $result[$key]['online'] = '<span class="label label-danger">离线</span>';
  48. }*/
  49. // 生成操作按钮
  50. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  51. }
  52. $return['total'] = db('users')->where($where)->count(); //总数据
  53. $return['rows'] = $result;
  54. return json($return);
  55. }
  56. //所有客服组
  57. $users = db('groups')->select();
  58. $groupsoption = '';
  59. if(!empty($users)){
  60. $option = '<option value="0">所有客服组</option>';
  61. for($i=0;$i<count($users);$i++){
  62. $option = $option.'<option value="'.$users[$i]['id'].'">'.$users[$i]['name'].'</option>';
  63. }
  64. $groupsoption = '<select lay-verify="required" lay-filter="group">'.$option.'</select>';
  65. }
  66. $this->assign([
  67. 'groupsoption' => $groupsoption
  68. ]);
  69. return $this->fetch();
  70. }
  71. // 添加客服
  72. public function addUser()
  73. {
  74. if(request()->isPost()){
  75. $param = input('post.');
  76. unset($param['file']); // 删除layui头像上传隐藏字段
  77. // 检测账号
  78. if(!empty($param['user_account'])){
  79. $user = db('users')->where('user_account', $param['user_account'])->find();
  80. if(!empty($user)){
  81. return json(['code' => -1, 'data' => '', 'msg' => '该账号已存在']);
  82. }
  83. }
  84. // 检测客服工号
  85. if(!empty($param['user_job_number'])){
  86. $user_job_number = db('users')->where('user_job_number', $param['user_job_number'])->find();
  87. if(!empty($user_job_number)){
  88. return json(['code' => -2, 'data' => '', 'msg' => '该工号已经存在']);
  89. }
  90. }
  91. if(empty($param['group_id'])){
  92. return json(['code' => -3, 'data' => '', 'msg' => '请选择分组']);
  93. }
  94. // 检测头像
  95. // if(empty($param['user_avatar'])){
  96. // return json(['code' => -4, 'data' => '', 'msg' => '请上传头像']);
  97. // }
  98. $param['user_pwd'] = md5('123456' . config('salt'));
  99. $param['online'] = 2; // 离线状态
  100. try{
  101. db('users')->insert($param);
  102. }catch(\Exception $e){
  103. return json(['code' => -5, 'data' => '', 'msg' => $e->getMessage()]);
  104. }
  105. return json(['code' => 1, 'data' => 'users/index', 'msg' => '添加客服成功']);
  106. }
  107. $this->assign([
  108. 'groups' => db('groups')->select(),
  109. 'status' => config('kf_status')
  110. ]);
  111. return $this->fetch('adduser');
  112. }
  113. // 编辑客服
  114. public function editUser()
  115. {
  116. if(request()->isAjax()){
  117. $param = input('post.');
  118. unset($param['file']); // 删除layui头像上传隐藏字段
  119. if(empty($param['group_id'])){
  120. return json(['code' => -2, 'data' => '', 'msg' => '请选择分组']);
  121. }
  122. $addar = array();
  123. $where = array();
  124. $where['id'] = $param['id'];
  125. $addar['group_id'] = $param['group_id'];
  126. $addar['status'] = $param['status'];
  127. $addar['user_avatar'] = $param['user_avatar'];
  128. try{
  129. db('users')->where('id', $param['id'])->update($addar);
  130. }catch(\Exception $e){
  131. return json(['code' => -6, 'data' => '', 'msg' => $e->getMessage()]);
  132. }
  133. return json(['code' => 1, 'data' => 'users/index', 'msg' => '编辑客服成功']);
  134. }
  135. $id = input('param.id/d');
  136. $info = db('users')->where('id', $id)->find();
  137. $this->assign([
  138. 'info' => $info,
  139. 'status' => config('kf_status'),
  140. 'groups' => db('groups')->select()
  141. ]);
  142. return $this->fetch('edituser');
  143. }
  144. //重置密码为123456
  145. public function resetPwd(){
  146. if(request()->isAjax()){
  147. $id = input('param.id/d');
  148. $password = md5('123456' . config('salt'));
  149. try{
  150. db('users')->where('id', $id)->update(['user_pwd' => $password]);
  151. }catch(\Exception $e){
  152. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  153. }
  154. return json(['code' => 1, 'data' => 'accounts/index', 'msg' => '重置密码成功']);
  155. }
  156. }
  157. // 删除客服
  158. public function delUser()
  159. {
  160. if(request()->isAjax()){
  161. $id = input('param.id/d');
  162. try{
  163. db('users')->where('id', $id)->delete();
  164. }catch(\Exception $e){
  165. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  166. }
  167. return json(['code' => 1, 'data' => '', 'msg' => '删除客服成功']);
  168. }
  169. }
  170. // 上传客服头像
  171. public function upAvatar()
  172. {
  173. if(request()->isAjax()) {
  174. $file = request()->file('file');
  175. if (!empty($file)) {
  176. // 移动到框架应用根目录/public/uploads/ 目录下
  177. $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
  178. if ($info) {
  179. $src = '/uploads' . '/' . date('Ymd') . '/' . $info->getFilename();
  180. return json(['code' => 0, 'data' => ['src' => $src], 'msg' => 'ok']);
  181. } else {
  182. // 上传失败获取错误信息
  183. return json(['code' => -1, 'data' => '', 'msg' => $file->getError()]);
  184. }
  185. }
  186. }
  187. }
  188. // 生成按钮
  189. private function makeBtn($id)
  190. {
  191. // $operate = '<a href="' . url('users/edituser', ['id' => $id]) . '">';
  192. // $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  193. $operate = '<a href="javascript:resetPwd(' . $id . ')"><button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 重置密码</button></a>';
  194. $operate .= '<a style="margin-left:5px;" href="' . url('users/editUser', ['id' => $id]) . '">';
  195. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  196. $operate .= '<a style="margin-left:5px;" href="javascript:userDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  197. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  198. //$operate .= '<a href="javascript:;">';
  199. //$operate .= '<button type="button" class="btn btn-info btn-sm"><i class="fa fa-institution"></i> 详情</button></a>';
  200. return $operate;
  201. }
  202. }