Kfnotice.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  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\Servicenotice as ServicenoticeModel;
  9. use app\admin\model\Users as Usersmodel;
  10. use app\admin\model\Groups as GroupsModel;
  11. class Kfnotice extends Base
  12. {
  13. // 管理员列表
  14. public function index()
  15. {
  16. if (request()->isAjax()) {
  17. $param = input('param.');
  18. $limit = $param['pageSize'];
  19. $offset = ($param['pageNumber'] - 1) * $limit;
  20. $where = [];
  21. $bibao = false;
  22. if (strlen($param['searchText'])) {
  23. $arr = explode("|", $param['searchText']);
  24. if (count($arr) == 5) {
  25. list($timerang, $sendtype, $groupid, $txttype, $txttext) = $arr;
  26. if (strlen($timerang)) {
  27. list($tbegin, $tend) = explode(",", $timerang);
  28. $bibao = true;
  29. $biaaodata = [trim($tbegin . '00:00:00'), trim($tend . ' 23:59:59')];
  30. }
  31. if (intval($sendtype)) {
  32. $where['sendtype'] = intval($sendtype);
  33. }
  34. if ($groupid) {
  35. $gm = (new GroupsModel())->with('users')->where(['id' => $groupid])->find();
  36. $uids = [0];
  37. if ($gm && count($gm->users)) {
  38. foreach ($gm->users as $u) {
  39. $uids[] = $u->id;
  40. }
  41. }
  42. $where['uid'] = ['IN', $uids];
  43. }
  44. if (strlen($txttext)) {
  45. if ($txttype == 1) {
  46. $where['title'] = ['like', '%' . $txttext . '%'];
  47. } else {
  48. $where['atext'] = ['like', '%' . $txttext . '%'];
  49. }
  50. }
  51. }
  52. }
  53. $model = new ServicenoticeModel();
  54. if (!$bibao) {
  55. $result = $model->where($where)->limit($offset, $limit)->order('sendtime', 'desc')->select();
  56. } else {
  57. $result = $model->where($where)->where(function ($query) use ($biaaodata) {
  58. $query->where(['sendtime' => ['>=', $biaaodata['0']]])->where(['sendtime' => ['<=', $biaaodata['1']]]);
  59. })->limit($offset, $limit)->order('sendtime', 'desc')->select();
  60. }
  61. //管理员
  62. $admins = db('admins')->select();
  63. $adminKey = [] ;
  64. foreach ($admins as $nowadmin){
  65. $adminKey[$nowadmin['id']] = $nowadmin;
  66. }
  67. //客服
  68. $users = db('users')->select();
  69. $userKey = [] ;
  70. foreach ($users as $nowuser){
  71. $userKey[$nowuser['id']] = $nowuser;
  72. }
  73. foreach ($result as $key => $vo) {
  74. $vo->readtime = empty($vo->readtime) ? '' : date('Y-m-d H:i:s', $vo->readtime);
  75. $vo->sendtype = $vo->sendtype == 1 ? '即时发送' : '预约发送';
  76. $result[$key] = array_merge($vo->toArray(), ['operate' => $this->makeBtn($vo->id)]);
  77. $result[$key]['admin_name'] = isset($adminKey[$vo['admin_id']]) ? $adminKey[$vo['admin_id']]['user_name'] : '-err' ;
  78. $result[$key]['user_name'] = isset($userKey[$vo['uid']]) ? $userKey[$vo['uid']]['user_name'] : $result[$key]['uid'] ;
  79. $date = explode(' ',$vo->ctime);
  80. $year = explode('-',$vo->ctime);
  81. if($date[0] == date('Y-m-d',time())){
  82. $result[$key]['ctime'] = '<span style="float: right;">'.$date[1].'</span>';
  83. }else if($date[0] == date('Y-m-d',strtotime("-1 day"))){
  84. $result[$key]['ctime'] = '<span style="float: right;">'.'昨天 '.$date[1].'</span>';
  85. }else{
  86. if($year[0] == date('Y',time())){
  87. $result[$key]['ctime'] = '<span style="float: right;">'.date('m-d H:i:s',strtotime($vo->ctime)).'</span>';
  88. }
  89. }
  90. $date = explode(' ',$vo->readtime);
  91. $year = explode('-',$vo->readtime);
  92. if($date[0] == date('Y-m-d',time())){
  93. $result[$key]['readtime'] = '<span style="float: right;">'.$date[1].'</span>';
  94. }else if($date[0] == date('Y-m-d',strtotime("-1 day"))){
  95. $result[$key]['readtime'] = '<span style="float: right;">'.'昨天 '.$date[1].'</span>';
  96. }else{
  97. if($year[0] == date('Y',time())){
  98. $result[$key]['readtime'] = '<span style="float: right;">'.date('m-d H:i:s',strtotime($vo->readtime)).'</span>';
  99. }
  100. }
  101. $date = explode(' ',$vo->sendtime);
  102. $year = explode('-',$vo->sendtime);
  103. if($date[0] == date('Y-m-d',time())){
  104. $result[$key]['sendtime'] = '<span style="float: right;">'.$date[1].'</span>';
  105. }else if($date[0] == date('Y-m-d',strtotime("-1 day"))){
  106. $result[$key]['sendtime'] = '<span style="float: right;">'.'昨天 '.$date[1].'</span>';
  107. }else{
  108. if($year[0] == date('Y',time())){
  109. $result[$key]['sendtime'] = '<span style="float: right;">'.date('m-d H:i:s',strtotime($vo->sendtime)).'</span>';
  110. }
  111. }
  112. }
  113. if (!$bibao) {
  114. $return['total'] = db('servicenotice')->where($where)->count(); //总数据
  115. } else {
  116. $return['total'] = $model->where($where)->where(function ($query) use ($biaaodata) {
  117. $query->where(['sendtime' => ['>=', $biaaodata['0']]])->where(['sendtime' => ['<=', $biaaodata['1']]]);
  118. })->count();
  119. }
  120. $return['rows'] = $result;
  121. return json($return);
  122. }
  123. $goups = (new GroupsModel)->where(['status' => 1])->select();
  124. $this->assign('groups', $goups);
  125. return $this->fetch();
  126. }
  127. // 添加留言
  128. public function add()
  129. {
  130. $uid = intval(input('param.uid', 0));
  131. if (request()->isPost()) {
  132. $atext = input('post.atext');
  133. $title = input('post.title', 0);
  134. $group = intval(input('post.groupid', 0));
  135. if (!strlen($atext) || !strlen($title)) {
  136. return json(['code' => -1, 'data' => '', 'msg' => '标题和内容不能为空']);
  137. }
  138. $sendtime = input('post.sendtime');
  139. if (!strlen($sendtime)) {
  140. $sendtime = date("Y-m-d H:i:s", time() + 10);
  141. }
  142. $sendtype = (strtotime($sendtime) >= (time() + 60)) ? 2 : 1;
  143. if (strtotime($sendtime) < time()) {
  144. return json(['code' => -1, 'data' => '', 'msg' => '时间不能小于当前时间!']);
  145. }
  146. if ($uid) {
  147. $arr = [
  148. 'uid' => $uid,
  149. 'title' => $title,
  150. 'atext' => $atext,
  151. 'sendtime' => $sendtime,
  152. 'sendtype' => $sendtype,
  153. 'admin_id' => session('user_id'),
  154. ];
  155. $datas[] = $arr;
  156. } else {
  157. $where = $group ? ['status' => 1, 'group_id' => $group] : ['status' => 1];
  158. $Users = (new Usersmodel())->where($where)->select();
  159. if (!$Users) {
  160. return json(['code' => -2, 'data' => '', 'msg' => '没有可用客服']);
  161. }
  162. $datas = [];
  163. foreach ($Users as $val) {
  164. $arr = [
  165. 'uid' => $val->id,
  166. 'title' => $title,
  167. 'atext' => $atext,
  168. 'sendtime' => $sendtime,
  169. 'sendtype' => $sendtype,
  170. 'admin_id' => session('user_id'),
  171. ];
  172. $datas[] = $arr;
  173. }
  174. }
  175. try {
  176. db('servicenotice')->insertAll($datas);
  177. } catch (\Exception $e) {
  178. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  179. }
  180. return json(['code' => 1, 'data' => '', 'msg' => '添加公告成功']);
  181. }
  182. $goups = (new GroupsModel)->where(['status' => 1])->select();
  183. $this->assign('groups', $goups);
  184. $this->assign('userid', $uid);
  185. return $this->fetch();
  186. }
  187. // 删除留言
  188. public function del()
  189. {
  190. if (request()->isAjax()) {
  191. $id = input('param.id/d');
  192. //return $id;
  193. try {
  194. db('servicenotice')->where('id', $id)->delete();
  195. } catch (\Exception $e) {
  196. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  197. }
  198. return json(['code' => 1, 'data' => '', 'msg' => '删除成功']);
  199. }
  200. }
  201. // 生成按钮
  202. private function makeBtn($id)
  203. {
  204. $operate = '<a href="javascript:View(' . $id . ')"><button type="button" class="btn btn-info btn-sm">详细内容 </button></a>';
  205. $operate .= '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<a href="javascript:Del(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  206. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  207. return $operate;
  208. }
  209. }