Accounts.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  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. use app\admin\model\Office;
  9. class Accounts extends Base
  10. {
  11. // 会员列表
  12. public function index()
  13. {
  14. $toExcel = input('param.toExcel', 0);
  15. if(request()->isAjax()){
  16. $param = input('param.');
  17. $limit = $param['pageSize'];
  18. $offset = (($param['pageNumber'] - 1) * $limit);
  19. $where = [];
  20. if (strlen($param['searchText'])) {
  21. if($param['account'] == 'account_name'){
  22. $where['account_name'] = ['like', '%' . $param['searchText'] . '%'];
  23. }
  24. if($param['account'] == 'nick_name'){
  25. $where['nick_name'] = ['like', '%' . $param['searchText'] . '%'];
  26. }
  27. }
  28. //标签
  29. if ($param['label_id'] != '' && $param['label_id'] != 0) {
  30. $where['label_id'] = $param['label_id'];
  31. }
  32. if (strlen($param['start']) && strlen($param['end']) && $param['start'] <= $param['end']) {
  33. $start = strtotime($param['start']);
  34. $end = strtotime($param['end'] . ' 23:59:59');
  35. $return['total'] = db('accounts')->where($where)->whereBetween('add_time', [$start, $end])->count(); //总数据
  36. }
  37. $result = db('accounts')->whereBetween('add_time', [$start, $end])->where($where)->limit($offset, $limit)->order('add_time', 'desc')->select();
  38. //所有客服
  39. $users = db('users')->select();
  40. //所有标签
  41. $label = db('accountslabel')->select();
  42. foreach($result as $key=>$vo){
  43. $result[$key]['add_time'] = date('Y-m-d H:i:s',$result[$key]['add_time']);
  44. $result[$key]['last_login_time'] = date('Y-m-d H:i:s',$result[$key]['last_login_time']);
  45. for($i=0;$i<count($users);$i++){
  46. if($vo['user_id'] == $users[$i]['id']){
  47. $result[$key]['user_name'] = $users[$i]['user_name'];
  48. }
  49. }
  50. for($j=0;$j<count($label);$j++){
  51. if($vo['label_id'] == $label[$j]['id']){
  52. $result[$key]['label'] = $label[$j]['name'];
  53. }
  54. }
  55. // 生成操作按钮
  56. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  57. }
  58. //$return['total'] = db('accounts')->count(); //总数据
  59. $return['rows'] = $result;
  60. return json($return);
  61. }
  62. //所有标签
  63. $label = db('accountslabel')->select();
  64. if(!empty($label)){
  65. $option = '<option value="0">会员标签</option>';
  66. for($i=0;$i<count($label);$i++){
  67. $option = $option.'<option value="'.$label[$i]['id'].'">'.$label[$i]['name'].'</option>';
  68. }
  69. $labeloption = '<select lay-verify="required" lay-filter="label">'.$option.'</select>';
  70. }
  71. $this->assign([
  72. 'label' => $label,
  73. 'labeloption' => $labeloption,
  74. 'status' => config('kf_status')
  75. ]);
  76. return $this->fetch();
  77. }
  78. //用户信息导出
  79. public function toexcel()
  80. {
  81. $param = input('param.');
  82. $start = $param['start'];
  83. $end = $param['end'];
  84. $where = [];
  85. if(!empty($param['label_id'])){
  86. $where['label_id'] = $param['label_id'];
  87. }
  88. if($param['account'] == 'account_name'){
  89. if(!empty($param['username'])){
  90. $where['account_name'] = ['like', '%' . $param['username'] . '%'];
  91. }
  92. }
  93. if($param['account'] == 'nick_name'){
  94. if(!empty($param['username'])){
  95. $where['nick_name'] = ['like', '%' . $param['username'] . '%'];
  96. }
  97. }
  98. $result = db('accounts')->whereBetween('add_time', [strtotime($start), strtotime($end . ' 23:59:59')])->where($where)->order('add_time', 'desc')->select();
  99. //所有标签
  100. $label = db('accountslabel')->select();
  101. foreach($result as $key=>$vo){
  102. $result[$key]['add_time'] = date('Y-m-d H:i:s',$result[$key]['add_time']);
  103. $result[$key]['last_login_time'] = date('Y-m-d H:i:s',$result[$key]['last_login_time']);
  104. $result[$key]['label'] = '';
  105. for($j=0;$j<count($label);$j++){
  106. if($vo['label_id'] == $label[$j]['id']){
  107. $result[$key]['label'] = $label[$j]['name'];
  108. }
  109. }
  110. }
  111. $head = ['账号', '昵称', '邮箱', '电话', '注册时间', '最近一次访问时间', '标签', '备注'];
  112. $key = ['account_name', 'nick_name', 'account_email', 'account_phone', 'add_time', 'last_login_time', 'label', 'remark'];
  113. (new Office())->outdata('会员数据导出', $result, $head, $key);
  114. return true;
  115. }
  116. // 重置用户密码为 123456
  117. public function resetPwd()
  118. {
  119. if(request()->isAjax()){
  120. $id = input('param.id/d');
  121. $password = md5('123456' . config('salt'));
  122. try{
  123. db('accounts')->where('id', $id)->update(['password' => $password]);
  124. }catch(\Exception $e){
  125. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  126. }
  127. return json(['code' => 1, 'data' => 'accounts/index', 'msg' => '重置密码成功']);
  128. }
  129. }
  130. // 编辑用户
  131. public function edit()
  132. {
  133. if(request()->isAjax()){
  134. $param = input('post.');
  135. $info = array();
  136. $rules = '/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/';
  137. if(!empty($param['account_email'])){
  138. if(!preg_match($rules,$param['account_email'])){
  139. return json(['code' => -9, 'data' => '', 'msg' => '请输入正确的邮箱']);
  140. }
  141. }
  142. if(!empty($param['account_phone'])){
  143. if(!preg_match("/^1[34578]\d{9}$/", $param['account_phone'])){
  144. return json(['code' => -10, 'data' => '', 'msg' => '请输入正确的手机号码']);
  145. }
  146. }
  147. if($param['label_id'] == 0){
  148. return json(['code' => -10, 'data' => '', 'msg' => '请选择用户标签']);
  149. }
  150. $info['nick_name'] = $param['nick_name'];
  151. $info['account_email'] = $param['account_email'];
  152. $info['account_phone'] = $param['account_phone'];
  153. $info['address'] = $param['address'];
  154. $info['label_id'] = $param['label_id'];
  155. $info['remark'] = $param['remark'];
  156. if(!empty($param['user_id']) && $param['user_id'] != 0){
  157. $info['user_id'] = $param['user_id'];
  158. }
  159. $update = array();
  160. $update['nick_name'] = $param['nick_name'];
  161. $update['email'] = $param['account_email'];
  162. $update['phone'] = $param['account_phone'];
  163. try{
  164. db('accounts')->where('id', $param['id'])->update($info);
  165. $accounts = db('accountsmessage')->where('account_id', $param['id'])->select();
  166. if(!empty($accounts)){
  167. db('accountsmessage')->where('account_id', $param['id'])->update($update);
  168. }
  169. }catch(\Exception $e){
  170. return json(['code' => -6, 'data' => '', 'msg' => $e->getMessage()]);
  171. }
  172. return json(['code' => 1, 'data' => url('accounts/index'), 'msg' => '编辑用户成功']);
  173. }
  174. $id = input('param.id/d');
  175. $info = db('accounts')->where('id', $id)->find();
  176. $label = db('accountslabel')->where('id', $info['label_id'])->find();
  177. $info['label'] = $label['name'];
  178. //所有标签
  179. $label = db('accountslabel')->select();
  180. //服务记录
  181. //前一个月的时间戳
  182. $start = time()-2592000;
  183. //当前时间戳
  184. $end = time();
  185. $service_log = db('service_log a')->join('users b','a.kf_id=b.id')->field('a.servicelog_id,a.start_time,b.user_name')->whereBetween('a.start_time', [$start, $end])->where('a.user_id', $id)->order('a.start_time','desc')->select();
  186. for($i=0;$i<count($service_log);$i++){
  187. $service_log[$i]['start_time'] = date("Y-m-d H:i:s",$service_log[$i]['start_time']);
  188. }
  189. //转为日期时间格式
  190. $info['add_time'] = date('Y-m-d H:i:s',$info['add_time']);
  191. //所有客服
  192. $users = db('users')->select();
  193. $this->assign([
  194. 'info' => $info,
  195. 'users' => $users,
  196. 'label' => $label,
  197. 'service_log' => $service_log,
  198. 'status' => config('kf_status')
  199. ]);
  200. return $this->fetch();
  201. }
  202. // 删除用户
  203. public function delAccount()
  204. {
  205. if(request()->isAjax()){
  206. $id = input('param.id/d');
  207. try{
  208. db('accounts')->where('id', $id)->delete();
  209. }catch(\Exception $e){
  210. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  211. }
  212. return json(['code' => 1, 'data' => 'accounts/index', 'msg' => '删除客服成功']);
  213. }
  214. }
  215. // 生成按钮
  216. private function makeBtn($id)
  217. {
  218. //$operate = '<a href="javascript:resetPwd(' . $id . ')"><button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 重置密码</button></a>';
  219. $operate = '<a style="margin-left:5px;" href="' . url('Accounts/edit', ['id' => $id]) . '"><button type="button" class="btn btn-primary btn-sm"> 编辑</button></a> ';
  220. // $operate .= '<a href="javascript:accountDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  221. // $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  222. return $operate;
  223. }
  224. // 用户标签列表
  225. public function label()
  226. {
  227. if(request()->isAjax()){
  228. $param = input('param.');
  229. $limit = $param['pageSize'];
  230. $offset = (($param['pageNumber'] - 1) * $limit);
  231. $where = [];
  232. // if (strlen($param['searchText'])) {
  233. // $where['name'] = ['like', '%' . $param['searchText'] . '%'];
  234. // }
  235. $result = db('accountslabel')->where($where)->limit($offset, $limit)->order('id', 'asc')->select();
  236. foreach($result as $key=>$vo){
  237. $result[$key]['add_time'] = date('Y-m-d H:i:s',$result[$key]['add_time']);
  238. // 生成操作按钮
  239. if($vo['id'] != 1){
  240. $result[$key]['operate'] = $this->makeBtnLabel($vo['id']);
  241. }else{
  242. $result[$key]['operate'] = $operate = '<a style="margin-left:5px;" href="' . url('Accounts/editlabel', ['id' => $vo['id']]) . '"><button type="button" class="btn btn-primary btn-sm"> 编辑</button></a> ';
  243. }
  244. }
  245. $return['total'] = db('accountslabel')->count(); //总数据
  246. $return['rows'] = $result;
  247. return json($return);
  248. }
  249. $this->assign([
  250. 'socket' => config('socket'),
  251. ]);
  252. return $this->fetch();
  253. }
  254. // 添加用户标签
  255. public function addlabel()
  256. {
  257. if (request()->isAjax()) {
  258. $param = input('post.');
  259. $has = db('accountslabel')->where('name',$param['name'])->find();
  260. if(!empty($has)){
  261. return json(['code' => -1, 'data' => '', 'msg' => '此用户标签已存在']);
  262. }
  263. $info = array();
  264. $info['name'] = $param['name'];
  265. $info['add_time'] = time();
  266. try {
  267. db('accountslabel')->insert($info);
  268. } catch (\Exception $e) {
  269. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  270. }
  271. return json(['code' => 1, 'data' => '', 'msg' => '添加用户标签成功']);
  272. }
  273. $this->assign([
  274. 'status' => config('kf_status'),
  275. 'socket' => config('socket'),
  276. ]);
  277. return $this->fetch();
  278. }
  279. // 编辑用户标签
  280. public function editlabel()
  281. {
  282. // 菜单id
  283. $id = input('param.id/d');
  284. if (request()->isAjax()) {
  285. $param = input('post.');
  286. $has = db('accountslabel')->where('name',$param['name'])->where('id','<>',$id)->find();
  287. if(!empty($has)){
  288. return json(['code' => -1, 'data' => '', 'msg' => '此用户标签已存在']);
  289. }
  290. $info = array();
  291. $info['name'] = $param['name'];
  292. try {
  293. db('accountslabel')->where('id', $param['id'])->update($info);
  294. } catch (\Exception $e) {
  295. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  296. }
  297. return json(['code' => 1, 'data' => '', 'msg' => '编辑用户标签成功']);
  298. }
  299. $label = db('accountslabel')->where('id',$id)->find();
  300. $this->assign([
  301. 'label' => $label,
  302. 'id' => $id,
  303. 'socket' => config('socket'),
  304. 'status' => config('kf_status')
  305. ]);
  306. return $this->fetch();
  307. }
  308. // 删除用户标签
  309. public function delLabel()
  310. {
  311. if (request()->isAjax()) {
  312. //留言类型id
  313. $id = input('param.id/d');
  314. try {
  315. db('accounts')->where('label_id', $id)->update(['label_id'=>1]);
  316. db('accountslabel')->where('id', $id)->delete();
  317. } catch (\Exception $e) {
  318. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  319. }
  320. return json(['code' => 1, 'data' => '', 'msg' => '删除用户标签成功']);
  321. }
  322. }
  323. // 生成标签按钮
  324. private function makeBtnLabel($id)
  325. {
  326. $operate = '<a style="margin-left:5px;" href="' . url('Accounts/editlabel', ['id' => $id]) . '"><button type="button" class="btn btn-primary btn-sm"> 编辑</button></a> ';
  327. $operate .= '<a href="javascript:labelDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  328. $operate .= ' 删除</button></a> ';
  329. return $operate;
  330. }
  331. }