System.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. /**
  3. * User: nickbai
  4. * Date: 2017/10/31 12:47
  5. * Email: 1902822973@qq.com
  6. */
  7. namespace app\admin\controller;
  8. class System extends Base
  9. {
  10. // 自动回复设置
  11. public function reply()
  12. {
  13. if(request()->isPost()){
  14. $param = input('post.');
  15. if(empty($param['word'])){
  16. return json(['code' => -1, 'data' => '', 'msg' => '回复内容不能为空']);
  17. }
  18. try{
  19. db('reply')->where('id', 1)->update($param);
  20. }catch(\Exception $e){
  21. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  22. }
  23. return json(['code' => 1, 'data' => '', 'msg' => '设置成功']);
  24. }
  25. $info = db('reply')->where('id', 1)->find();
  26. $this->assign([
  27. 'info' => $info,
  28. 'status' => config('kf_status')
  29. ]);
  30. return $this->fetch();
  31. }
  32. // 客服设置
  33. public function customerService()
  34. {
  35. if(request()->isPost()){
  36. $param = input('post.');
  37. db('kf_config')->where('id', 1)->update($param);
  38. return json(['code' => 1, 'data' => '', 'msg' => '设置成功']);
  39. }
  40. $this->assign([
  41. 'config' => db('kf_config')->where('id', 1)->find(),
  42. 'status' => config('kf_status')
  43. ]);
  44. return $this->fetch();
  45. }
  46. // 历史会话记录
  47. public function wordsLog()
  48. {
  49. if(request()->isAjax()){
  50. $param = input('param.');
  51. $limit = $param['pageSize'];
  52. $offset = ($param['pageNumber'] - 1) * $limit;
  53. // 默认显示最近7天
  54. $start = input('param.start');
  55. $end = input('param.end');
  56. $temp = db('service_log');
  57. $countTmp = db('service_log');
  58. if(!empty($param['searchText'])){
  59. $user = db('users')->where('user_name', $param['searchText'])->find();
  60. $temp = $temp->where('kf_id', $user['id']);
  61. $countTmp = $countTmp->where('kf_id', $user['id']);
  62. }
  63. if(!empty($start) && !empty($end) && $start <= $end){
  64. $temp = $temp->whereBetween('start_time', [strtotime($start), strtotime($end . ' 23:59:59')]);
  65. $countTmp = $countTmp->whereBetween('start_time', [strtotime($start), strtotime($end . ' 23:59:59')]);
  66. }
  67. $result = $temp->limit($offset, $limit)->order('start_time', 'desc')->select();
  68. foreach($result as $key=>$vo){
  69. if($result[$key]['start_time'] != 0){
  70. $result[$key]['start_time'] = date('Y-m-d H:i:s', $vo['start_time']);
  71. }else{
  72. $result[$key]['start_time'] = '-';
  73. }
  74. if($result[$key]['end_time'] != 0){
  75. $result[$key]['end_time'] = date('Y-m-d H:i:s', $vo['start_time']);
  76. }else{
  77. $result[$key]['end_time'] = '-';
  78. }
  79. //客服名称
  80. $kefu = db('users')->where('id', $result[$key]['kf_id'])->find();
  81. $result[$key]['kefu_name'] = $kefu['user_name'];
  82. //满意度
  83. $evaluate = db('evaluate')->where('evaluate_id', $result[$key]['evaluate_id'])->find();
  84. $result[$key]['evaluate_name'] = $evaluate['evaluate_name'];
  85. }
  86. $return['total'] = $countTmp->count(); //总数据
  87. $return['rows'] = $result;
  88. return json($return);
  89. }
  90. $users = db('users')->select();
  91. $this->assign([
  92. 'users' => $users
  93. ]);
  94. return $this->fetch();
  95. }
  96. }