Groups.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  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 Groups extends Base
  9. {
  10. // 分组列表
  11. public function index()
  12. {
  13. if(request()->isAjax()){
  14. $result = db('groups')->select();
  15. foreach($result as $key=>$vo){
  16. // 优化显示状态
  17. if(1 == $vo['status']){
  18. $result[$key]['status'] = '<span style="color: #2fbe1b">启用</span>';
  19. }else{
  20. $result[$key]['status'] = '<span style="color: red">禁用</span>';
  21. }
  22. // // 优化显示状态
  23. // if(1 == $vo['status']){
  24. // $result[$key]['status'] = '<span class="label label-primary">启用</span>';
  25. // }else{
  26. // $result[$key]['status'] = '<span class="label label-danger">禁用</span>';
  27. // }
  28. // 统计分组人数
  29. $result[$key]['users_num'] = db('users')->where('group_id', $vo['id'])->count();
  30. // 生成操作按钮
  31. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  32. }
  33. $return['total'] = db('groups')->count(); //总数据
  34. $return['rows'] = $result;
  35. return json($return);
  36. }
  37. $this->assign([
  38. 'socket' => config('socket'),
  39. ]);
  40. return $this->fetch();
  41. }
  42. // 添加分组
  43. public function addGroup()
  44. {
  45. if(request()->isPost()){
  46. $param = input('post.');
  47. $has = db('groups')->field('id')->where('name', $param['name'])->find();
  48. if(!empty($has)){
  49. return json(['code' => -1, 'data' => '', 'msg' => '该分组已经存在']);
  50. }
  51. try{
  52. db('groups')->insert($param);
  53. }catch(\Exception $e){
  54. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  55. }
  56. return json(['code' => 1, 'data' => '', 'msg' => '添加分组成功']);
  57. }
  58. $this->assign([
  59. 'socket' => config('socket'),
  60. 'status' => config('kf_status')
  61. ]);
  62. return $this->fetch('addgroup');
  63. }
  64. // 编辑分组
  65. public function editGroup()
  66. {
  67. if(request()->isAjax()){
  68. $param = input('post.');
  69. // 检测用户修改的用户名是否重复
  70. $has = db('groups')->where('name', $param['name'])->where('id', '<>', $param['id'])->find();
  71. if(!empty($has)){
  72. return json(['code' => -1, 'data' => '', 'msg' => '该分组已经存在']);
  73. }
  74. try{
  75. db('groups')->where('id', $param['id'])->update($param);
  76. }catch(\Exception $e){
  77. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  78. }
  79. return json(['code' => 1, 'data' => '', 'msg' => '编辑分组成功']);
  80. }
  81. $id = input('param.id/d');
  82. $info = db('groups')->where('id', $id)->find();
  83. $this->assign([
  84. 'info' => $info,
  85. 'socket' => config('socket'),
  86. 'status' => config('kf_status')
  87. ]);
  88. return $this->fetch('editgroup');
  89. }
  90. // 删除分组
  91. public function delGroup()
  92. {
  93. if(request()->isAjax()){
  94. $id = input('param.id/d');
  95. // 查询该分组下是否有客服
  96. $has = db('users')->where('group_id', $id)->count();
  97. if($has > 0){
  98. return json(['code' => -2, 'data' => '', 'msg' => '该分组下有客服,不可删除']);
  99. }
  100. try{
  101. db('groups')->where('id', $id)->delete();
  102. }catch(\Exception $e){
  103. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  104. }
  105. return json(['code' => 1, 'data' => '', 'msg' => '删除分组成功']);
  106. }
  107. }
  108. // 管理组员
  109. public function manageUser()
  110. {
  111. return $this->fetch();
  112. }
  113. // 生成按钮
  114. private function makeBtn($id)
  115. {
  116. $operate = '<a href="' . url('groups/editgroup', ['id' => $id]) . '">';
  117. //$operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  118. $operate .= '<button type="button" class="btn btn-primary btn-sm"> 编辑</button></a> ';
  119. $operate .= '<a href="javascript:userGroup(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  120. // $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  121. $operate .= ' 删除</button></a> ';
  122. //$operate .= '<a href="' . url('groups/manageUser') . '">';
  123. //$operate .= '<button type="button" class="btn btn-info btn-sm"><i class="fa fa-user-plus"></i> 管理组员</button></a>';
  124. return $operate;
  125. }
  126. }