Kfnotice.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  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 = trim(input('post.atext'));
  133. $title = trim(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. $sendtime = date("Y-m-d H:i:s", time() + 10);
  145. //return json(['code' => -1, 'data' => '', 'msg' => '时间不能小于当前时间!']);
  146. }
  147. if ($uid) {
  148. $arr = [
  149. 'uid' => $uid,
  150. 'title' => $title,
  151. 'atext' => $atext,
  152. 'sendtime' => $sendtime,
  153. 'sendtype' => $sendtype,
  154. 'admin_id' => session('user_id'),
  155. ];
  156. $datas[] = $arr;
  157. } else {
  158. $where = $group ? ['status' => 1, 'group_id' => $group] : ['status' => 1];
  159. $Users = (new Usersmodel())->where($where)->select();
  160. if (!$Users) {
  161. return json(['code' => -2, 'data' => '', 'msg' => '没有可用客服']);
  162. }
  163. $datas = [];
  164. foreach ($Users as $val) {
  165. $arr = [
  166. 'uid' => $val->id,
  167. 'title' => $title,
  168. 'atext' => $atext,
  169. 'sendtime' => $sendtime,
  170. 'sendtype' => $sendtype,
  171. 'admin_id' => session('user_id'),
  172. ];
  173. $datas[] = $arr;
  174. }
  175. }
  176. try {
  177. db('servicenotice')->insertAll($datas);
  178. } catch (\Exception $e) {
  179. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  180. }
  181. return json(['code' => 1, 'data' => '', 'msg' => '添加公告成功']);
  182. }
  183. $goups = (new GroupsModel)->where(['status' => 1])->select();
  184. $this->assign('groups', $goups);
  185. $this->assign('userid', $uid);
  186. return $this->fetch();
  187. }
  188. // 删除留言
  189. public function del()
  190. {
  191. if (request()->isAjax()) {
  192. $id = input('param.id/d');
  193. //return $id;
  194. try {
  195. db('servicenotice')->where('id', $id)->delete();
  196. } catch (\Exception $e) {
  197. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  198. }
  199. return json(['code' => 1, 'data' => '', 'msg' => '删除成功']);
  200. }
  201. }
  202. // 生成按钮
  203. private function makeBtn($id)
  204. {
  205. $operate = '<a href="javascript:View(' . $id . ')"><button type="button" class="btn btn-info btn-sm">详细内容 </button></a>';
  206. $operate .= ' <a href="javascript:Del(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  207. $operate .= ' 删除</button></a> ';
  208. return $operate;
  209. }
  210. }