Users.php 9.4 KB

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