SettingsOld.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  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 Settings 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. // }
  21. //客服组
  22. // if ($param['group_id'] != '' && $param['group_id'] != 0) {
  23. // $where['group_id'] = $param['group_id'];
  24. // }
  25. $result = db('guestenter')->where($where)->limit($offset, $limit)->order('sort', 'asc')->select();
  26. //客服组
  27. $group = db('groups')->select();
  28. foreach($result as $key=>$vo){
  29. // 优化显示头像
  30. $result[$key]['image'] = '<img src="' . $vo['image'] . '" height="40px">';
  31. if($vo['group_id'] == 'all'){
  32. $result[$key]['user_group'] = '所有客服组';
  33. }
  34. for($i=0;$i<count($group);$i++){
  35. if($vo['group_id'] == $group[$i]['id']){
  36. $result[$key]['user_group'] = $group[$i]['name'];
  37. }
  38. }
  39. // 生成操作按钮
  40. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  41. }
  42. $return['total'] = db('guestenter')->where($where)->count(); //总数据
  43. $return['rows'] = $result;
  44. return json($return);
  45. }
  46. $settings = db('settings')->where('id',1)->find();
  47. $this->assign([
  48. 'settings' => $settings,
  49. 'status' => config('kf_status')
  50. ]);
  51. return $this->fetch();
  52. }
  53. // 添加访客端入口
  54. public function add()
  55. {
  56. if(request()->isPost()){
  57. $param = input('post.');
  58. unset($param['file']); // 删除layui头像上传隐藏字段
  59. // 检测账号
  60. if(!empty($param['name'])){
  61. $user = db('guestenter')->where('name', $param['name'])->find();
  62. if(!empty($user)){
  63. return json(['code' => -1, 'data' => '', 'msg' => '该名称已存在']);
  64. }
  65. }
  66. if(strlen($param['name'])>12) {
  67. return json(['code' => -8, 'data' => '', 'msg' => '名称字数超过限制']);
  68. }
  69. if(!is_numeric($param['sort'])) {
  70. return json(['code' => -6, 'data' => '', 'msg' => '排序未输入整数']);
  71. }
  72. if(empty($param['group_id'])){
  73. return json(['code' => -3, 'data' => '', 'msg' => '请选择分组']);
  74. }
  75. //检测头像
  76. if(empty($param['image'])){
  77. return json(['code' => -4, 'data' => '', 'msg' => '请上传图片']);
  78. }
  79. try{
  80. db('guestenter')->insert($param);
  81. }catch(\Exception $e){
  82. return json(['code' => -5, 'data' => '', 'msg' => $e->getMessage()]);
  83. }
  84. return json(['code' => 1, 'data' => 'settings/index', 'msg' => '添加功能菜单成功']);
  85. }
  86. $this->assign([
  87. 'groups' => db('groups')->select(),
  88. 'status' => config('kf_status')
  89. ]);
  90. return $this->fetch('add');
  91. }
  92. // 编辑访客端入口
  93. public function edit()
  94. {
  95. if(request()->isAjax()){
  96. $param = input('post.');
  97. unset($param['file']); // 删除layui头像上传隐藏字段
  98. if(strlen($param['name'])>12) {
  99. return json(['code' => -8, 'data' => '', 'msg' => '名称字数超过限制']);
  100. }
  101. if(!is_numeric($param['sort'])) {
  102. return json(['code' => -6, 'data' => '', 'msg' => '排序未输入整数']);
  103. }
  104. if(empty($param['group_id'])){
  105. return json(['code' => -2, 'data' => '', 'msg' => '请选择分组']);
  106. }
  107. $name = db('guestenter')->where('name',$param['name'])->where('id','<>',$param['id'])->select();
  108. if(!empty($name)){
  109. return json(['code' => -3, 'data' => '', 'msg' => '此名称已存在']);
  110. }
  111. $info = array();
  112. $info['name'] = $param['name'];
  113. $info['image'] = $param['image'];
  114. $info['group_id'] = $param['group_id'];
  115. $info['sort'] = $param['sort'];
  116. try{
  117. db('guestenter')->where('id', $param['id'])->update($info);
  118. }catch(\Exception $e){
  119. return json(['code' => -6, 'data' => '', 'msg' => $e->getMessage()]);
  120. }
  121. return json(['code' => 1, 'data' => 'settings/index', 'msg' => '编辑功能菜单成功']);
  122. }
  123. $id = input('param.id/d');
  124. $info = db('guestenter')->where('id', $id)->find();
  125. $this->assign([
  126. 'info' => $info,
  127. 'status' => config('kf_status'),
  128. 'groups' => db('groups')->select()
  129. ]);
  130. return $this->fetch('edit');
  131. }
  132. // 删除访客端入口
  133. public function del()
  134. {
  135. if(request()->isAjax()){
  136. $id = input('param.id/d');
  137. try{
  138. db('guestenter')->where('id', $id)->delete();
  139. }catch(\Exception $e){
  140. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  141. }
  142. return json(['code' => 1, 'data' => '', 'msg' => '删除功能菜单成功']);
  143. }
  144. }
  145. // 上传客服头像
  146. public function upAvatar()
  147. {
  148. if(request()->isAjax()) {
  149. $file = request()->file('file');
  150. if (!empty($file)) {
  151. // 移动到框架应用根目录/public/uploads/ 目录下
  152. $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
  153. if ($info) {
  154. $src = '/uploads' . '/' . date('Ymd') . '/' . $info->getFilename();
  155. return json(['code' => 0, 'data' => ['src' => $src], 'msg' => 'ok']);
  156. } else {
  157. // 上传失败获取错误信息
  158. return json(['code' => -1, 'data' => '', 'msg' => $file->getError()]);
  159. }
  160. }
  161. }
  162. }
  163. // 生成按钮
  164. private function makeBtn($id)
  165. {
  166. $operate = '<a style="margin-left:5px;" href="' . url('settings/edit', ['id' => $id]) . '">';
  167. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  168. $operate .= '<a style="margin-left:5px;" href="javascript:Del(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  169. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  170. return $operate;
  171. }
  172. //自动邀请设置
  173. public function update(){
  174. if(request()->isPost()){
  175. $param = input('post.');
  176. $info['stop_time'] = $param['overtime'];
  177. $info['copywriting'] = $param['overtimeInfo'];
  178. try{
  179. db('settings')->where('id', $param['id'])->update($info);
  180. }catch(\Exception $e){
  181. return json(['code' => -5, 'data' => 'settings/index', 'msg' => $e->getMessage()]);
  182. }
  183. return json(['code' => 1, 'data' => $this->redirect('settings/index'), 'msg' => '自动邀请设置成功']);
  184. }
  185. }
  186. //访客端入口上边距设置
  187. public function margin(){
  188. if(request()->isPost()){
  189. $param = input('post.');
  190. $info['margin_top'] = $param['margin-top'];
  191. try{
  192. db('settings')->where('id', $param['id'])->update($info);
  193. }catch(\Exception $e){
  194. return json(['code' => -6, 'data' => 'settings/index', 'msg' => $e->getMessage()]);
  195. }
  196. return json(['code' => 1, 'data' => $this->redirect('settings/index'), 'msg' => '自动邀请设置成功']);
  197. }
  198. }
  199. }