Users.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  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. if($param['user'] == 'user_account'){
  20. $where['user_account'] = ['like', '%' . $param['searchText'] . '%'];
  21. }
  22. if($param['user'] == 'user_name'){
  23. $where['user_name'] = ['like', '%' . $param['searchText'] . '%'];
  24. }
  25. // $where['user_account|user_name|user_job_number|fullname'] = ['like', '%' . $param['searchText'] . '%'];
  26. }else{
  27. return 1;
  28. }
  29. //客服组
  30. if ($param['group_id'] != '' && $param['group_id'] != 0) {
  31. $where['group_id'] = $param['group_id'];
  32. }
  33. $result = db('users')->where($where)->limit($offset, $limit)->order('id', 'desc')->select();
  34. foreach($result as $key=>$vo){
  35. // 优化显示头像
  36. $result[$key]['user_avatar'] = '<img src="' . $vo['user_avatar'] . '" height="40px">';
  37. // 优化显示状态
  38. if(0 == $vo['gender']){
  39. $result[$key]['gender'] = '保密';
  40. }
  41. if(1 == $vo['gender']){
  42. $result[$key]['gender'] = '男';
  43. }
  44. if(2 == $vo['gender']){
  45. $result[$key]['gender'] = '女';
  46. }
  47. // 优化显示状态
  48. if(1 == $vo['status']){
  49. $result[$key]['status'] = '<span style="color: #2fbe1b">启用</span>';
  50. }else{
  51. $result[$key]['status'] = '<span style="color: red">禁用</span>';
  52. }
  53. // 优化显示状态
  54. if(1 == $vo['user_overview']){
  55. $result[$key]['user_overview'] = '<span style="color: #2fbe1b">启用</span>';
  56. }else{
  57. $result[$key]['user_overview'] = '<span style="color: red">禁用</span>';
  58. }
  59. // 查询分组
  60. $result[$key]['group'] = '-';
  61. $groups = db('groups')->field('name')->where('id', $vo['group_id'])->find();
  62. if(!empty($groups)){
  63. $result[$key]['group'] = $groups['name'];
  64. }
  65. // 优化显示在线状态
  66. /*if(1 == $vo['online']){
  67. $result[$key]['online'] = '<span class="label label-primary">在线</span>';
  68. }else{
  69. $result[$key]['online'] = '<span class="label label-danger">离线</span>';
  70. }*/
  71. // 生成操作按钮
  72. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  73. }
  74. $return['total'] = db('users')->where($where)->count(); //总数据
  75. $return['rows'] = $result;
  76. return json($return);
  77. }
  78. //所有客服组
  79. $users = db('groups')->select();
  80. $groupsoption = '';
  81. if(!empty($users)){
  82. $option = '<option value="0">所有客服组</option>';
  83. for($i=0;$i<count($users);$i++){
  84. $option = $option.'<option value="'.$users[$i]['id'].'">'.$users[$i]['name'].'</option>';
  85. }
  86. $groupsoption = '<select lay-verify="required" lay-filter="group">'.$option.'</select>';
  87. }
  88. $this->assign([
  89. 'socket' => config('socket'),
  90. 'groupsoption' => $groupsoption
  91. ]);
  92. return $this->fetch();
  93. }
  94. // 添加客服
  95. public function addUser()
  96. {
  97. if(request()->isPost()){
  98. $param = input('post.');
  99. unset($param['file']); // 删除layui头像上传隐藏字段
  100. // 检测账号
  101. if(!empty($param['user_account'])){
  102. $user = db('users')->where('user_account', $param['user_account'])->find();
  103. if(!empty($user)){
  104. return json(['code' => -1, 'data' => '', 'msg' => '该账号已存在']);
  105. }
  106. }
  107. // 检测客服工号
  108. if(!empty($param['user_job_number'])){
  109. $user_job_number = db('users')->where('user_job_number', $param['user_job_number'])->find();
  110. if(!empty($user_job_number)){
  111. return json(['code' => -2, 'data' => '', 'msg' => '该工号已经存在']);
  112. }
  113. }
  114. if(empty($param['group_id'])){
  115. return json(['code' => -3, 'data' => '', 'msg' => '请选择分组']);
  116. }
  117. // 检测密码
  118. $n = preg_match_all("/^[a-zA-Z\d_]{6,}$/",$param['user_pwd'],$array);
  119. if($n != 1){
  120. return json(['code' => -8, 'data' => '', 'msg' => '密码长度不够,请重新输入']);
  121. }
  122. // 检测头像
  123. // if(empty($param['user_avatar'])){
  124. // return json(['code' => -4, 'data' => '', 'msg' => '请上传头像']);
  125. // }
  126. $param['user_pwd'] = md5($param['user_pwd'] . config('salt'));
  127. $param['online'] = 2; // 离线状态
  128. try{
  129. db('users')->insert($param);
  130. }catch(\Exception $e){
  131. return json(['code' => -5, 'data' => '', 'msg' => $e->getMessage()]);
  132. }
  133. return json(['code' => 1, 'data' => 'users/index', 'msg' => '添加客服成功']);
  134. }
  135. $this->assign([
  136. 'groups' => db('groups')->select(),
  137. 'status' => config('kf_status')
  138. ]);
  139. return $this->fetch('adduser');
  140. }
  141. // 编辑客服
  142. public function editUser()
  143. {
  144. if(request()->isAjax()){
  145. $param = input('post.');
  146. unset($param['file']); // 删除layui头像上传隐藏字段
  147. // 检测客服工号
  148. if(!empty($param['user_job_number'])){
  149. $user_job_number = db('users')->where('user_job_number', $param['user_job_number'])->where('id','<>',$param['id'])->find();
  150. if(!empty($user_job_number)){
  151. return json(['code' => -2, 'data' => '', 'msg' => '该工号已经存在']);
  152. }
  153. }
  154. if(empty($param['group_id'])){
  155. return json(['code' => -3, 'data' => '', 'msg' => '请选择分组']);
  156. }
  157. // 检测密码
  158. if(!empty($param['user_pwd'])){
  159. $n = preg_match_all("/^[a-zA-Z\d_]{6,}$/",$param['user_pwd'],$array);
  160. if($n != 1){
  161. return json(['code' => -8, 'data' => '', 'msg' => '密码长度不够,请重新输入']);
  162. }
  163. }
  164. if(empty($param['group_id'])){
  165. return json(['code' => -2, 'data' => '', 'msg' => '请选择分组']);
  166. }
  167. $addar = array();
  168. $addar['user_name'] = $param['user_name'];
  169. $addar['gender'] = $param['gender'];
  170. $addar['user_job_number'] = $param['user_job_number'];
  171. if(!empty($param['user_pwd'])){
  172. $addar['user_pwd'] = md5($param['user_pwd'] . config('salt'));
  173. }
  174. $addar['user_email'] = $param['user_email'];
  175. $addar['phone'] = $param['phone'];
  176. $addar['fullname'] = $param['fullname'];
  177. $addar['signature'] = $param['signature'];
  178. $addar['group_id'] = $param['group_id'];
  179. $addar['status'] = $param['status'];
  180. $addar['user_overview'] = $param['user_overview'];
  181. if(!empty($param['user_avatar'])){
  182. $addar['user_avatar'] = $param['user_avatar'];
  183. }
  184. try{
  185. db('users')->where('id', $param['id'])->update($addar);
  186. }catch(\Exception $e){
  187. return json(['code' => -6, 'data' => '', 'msg' => $e->getMessage()]);
  188. }
  189. return json(['code' => 1, 'data' => 'users/index', 'msg' => '编辑客服成功']);
  190. }
  191. $id = input('param.id/d');
  192. $info = db('users')->where('id', $id)->find();
  193. $this->assign([
  194. 'info' => $info,
  195. 'socket' => config('socket'),
  196. 'status' => config('kf_status'),
  197. 'groups' => db('groups')->select()
  198. ]);
  199. return $this->fetch('edituser');
  200. }
  201. //重置密码为123456
  202. public function resetPwd(){
  203. if(request()->isAjax()){
  204. $id = input('param.id/d');
  205. $password = md5('123456' . config('salt'));
  206. try{
  207. db('users')->where('id', $id)->update(['user_pwd' => $password]);
  208. }catch(\Exception $e){
  209. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  210. }
  211. return json(['code' => 1, 'data' => 'accounts/index', 'msg' => '重置密码成功']);
  212. }
  213. }
  214. // 删除客服
  215. public function delUser()
  216. {
  217. if(request()->isAjax()){
  218. $id = input('param.id/d');
  219. try{
  220. db('users')->where('id', $id)->delete();
  221. }catch(\Exception $e){
  222. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  223. }
  224. return json(['code' => 1, 'data' => '', 'msg' => '删除客服成功']);
  225. }
  226. }
  227. // 上传客服头像
  228. public function upAvatar()
  229. {
  230. if(request()->isAjax()) {
  231. $file = request()->file('file');
  232. if (!empty($file)) {
  233. $fileInfo = $file->getInfo();
  234. //return $fileInfo;
  235. if ($fileInfo['size'] > 1024 * 512 * 2) {
  236. // 上传失败获取错误信息.
  237. return json(['code' => -2, 'data' => '', 'msg' => '文件超过0.5M'] );
  238. }
  239. //检测图片格式
  240. $ext = explode('/', $fileInfo['type']);
  241. $ext = array_pop($ext);
  242. $extArr = explode('|', 'jpg|png|gif|jpeg');
  243. if(!in_array($ext, $extArr)){
  244. return json(['code' => -3, 'data' => '', 'msg' => '只能上传jpg|png|gif|jpeg的文件']);
  245. }
  246. // 移动到框架应用根目录/public/uploads/ 目录下
  247. $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
  248. if ($info) {
  249. $src = '/uploads' . '/' . date('Ymd') . '/' . $info->getFilename();
  250. return json(['code' => 0, 'data' => ['src' => $src], 'msg' => 'ok']);
  251. } else {
  252. // 上传失败获取错误信息
  253. return json(['code' => -1, 'data' => '', 'msg' => $file->getError()]);
  254. }
  255. } else {
  256. return json(['code' => -2, 'data' => '', 'msg' => '文件超过0.5M'] );
  257. }
  258. }
  259. }
  260. // 生成按钮
  261. private function makeBtn($id)
  262. {
  263. // $operate = '<a href="javascript:resetPwd(' . $id . ')"><button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 重置密码</button></a>';
  264. $operate = '<a href="' . url('users/editUser', ['id' => $id]) . '">';
  265. // $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  266. $operate .= '<button type="button" class="btn btn-primary btn-sm"> 编辑</button></a> ';
  267. $operate .= '<a href="javascript:userDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  268. // $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  269. $operate .= ' 删除</button></a> ';
  270. //$operate .= '<a href="javascript:;">';
  271. //$operate .= '<button type="button" class="btn btn-info btn-sm"><i class="fa fa-institution"></i> 详情</button></a>';
  272. return $operate;
  273. }
  274. }