Notice.php 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. <?php
  2. namespace App\Http\Controllers\Manager\Process;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Manager\Process\Notices as Request;
  5. use App\Models\Manager\Process\Notices as NoticesModel;
  6. /**
  7. * 通知服务
  8. * @author: 唐远望
  9. * @version: 1.0
  10. * @date: 2026-03-21
  11. */
  12. class Notice extends Controller
  13. {
  14. /**
  15. * 列表
  16. * @author: 唐远望
  17. * @version: 1.0
  18. * @date: 2026-03-21
  19. */
  20. public function list(Request $Request, NoticesModel $NoticesModel)
  21. {
  22. // 验证规则
  23. $Request->scene('list')->validate();
  24. $admin_company_id = request('admin_company_id', '0');
  25. $company_id = request('access_token.company_id', '0');
  26. $is_admin = request('access_token.is_admin', '0'); //是否管理员操作 0=是1=否
  27. // 接收参数
  28. $uid = request('access_token.uid', 0);
  29. $map = [];
  30. // 权限判断
  31. if ($is_admin != 1 && $company_id != 0) {
  32. $map['company_id'] = $company_id;
  33. $map['custom_uid'] = $uid;
  34. } else {
  35. $map['company_id'] = $admin_company_id;
  36. }
  37. // 接收参数
  38. $status = request('status');
  39. $limit = request('limit', config('page_num', 10));
  40. $start_time = request('start_time', '');
  41. $end_time = request('end_time', '');
  42. // 时间条件
  43. if ($start_time) $map[] = ['insert_time', '>=', strtotime($start_time . ' 00:00:00')];
  44. if ($end_time) $map[] = ['insert_time', '<=', strtotime($end_time . ' 23:59:59')];
  45. if (!is_null($status)) $map[] = ['status', '=', $status];
  46. // 查询系统用户
  47. $result = $NoticesModel->where($map)->orderByDesc('id')->paginate($limit);
  48. // 告知结果
  49. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => $result]);
  50. }
  51. /**
  52. * 修改状态
  53. * @author: 唐远望
  54. * @version: 1.0
  55. * @date: 2026-03-21
  56. */
  57. public function set_status(Request $request, NoticesModel $NoticesModel)
  58. {
  59. // 验证参数
  60. $request->scene('set_status')->validate();
  61. $admin_company_id = request('admin_company_id', '0');
  62. $company_id = request('access_token.company_id', '0');
  63. $is_admin = request('access_token.is_admin', '0'); //是否管理员操作 0=是1=否
  64. // 接收参数
  65. $uid = request('access_token.uid', 0);
  66. $map = [];
  67. // 权限判断
  68. if ($is_admin != 1 && $company_id != 0) {
  69. $map['company_id'] = $company_id;
  70. $map['custom_uid'] = $uid;
  71. } else {
  72. $map['company_id'] = $admin_company_id;
  73. }
  74. // 设置状态
  75. $id = request('id', 0);
  76. $status = request('status', 0);
  77. $map[] = ['id', '=', $id];
  78. // 查询用户
  79. $oldData = $NoticesModel->where($map)->first();
  80. // 如果用户不存在
  81. if (!$oldData) return json_send(['code' => 'error', 'msg' => '通知消息记录不存在']);
  82. // 执行修改
  83. $result = $NoticesModel->where($map)->update(['status' => $status, 'update_time' => time()]);
  84. // 提示新增失败
  85. if (!$result) return json_send(['code' => 'error', 'msg' => '设置失败']);
  86. // 记录行为
  87. $admin_id = request('access_token.uid', 0); //用户ID
  88. $table_name = $NoticesModel->getTable();
  89. $notes_type = 2; //操作类型,1添加,2修改,3=删除
  90. $this->addAdminHistory('系统通知', 0, $admin_id, $is_admin, $table_name, $notes_type, [], ['status' => $status], "修改了记录ID为:$id 的通知状态");
  91. // 告知结果
  92. return json_send(['code' => 'success', 'msg' => '设置成功', 'data' => '']);
  93. }
  94. /**
  95. * 消息数统计
  96. * @author: 唐远望
  97. * @version: 1.0
  98. * @date: 2026-03-21
  99. */
  100. public function message_count(Request $Request, NoticesModel $NoticesModel)
  101. {
  102. // 验证规则
  103. $Request->scene('message_count')->validate();
  104. $admin_company_id = request('admin_company_id', '0');
  105. $company_id = request('access_token.company_id', '0');
  106. $is_admin = request('access_token.is_admin', '0'); //是否管理员操作 0=是1=否
  107. // 接收参数
  108. $uid = request('access_token.uid', 0);
  109. $map = [];
  110. // 权限判断
  111. if ($is_admin != 1 && $company_id != 0) {
  112. $map['company_id'] = $company_id;
  113. $map['custom_uid'] = $uid;
  114. } else {
  115. $map['company_id'] = $admin_company_id;
  116. }
  117. $map[] = ['status', '=', 0];
  118. // 查询未读消息总数
  119. $unread_count = $NoticesModel->where($map)->orderByDesc('id')->count();
  120. // 告知结果
  121. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => ['unread_count' => $unread_count]]);
  122. }
  123. /**
  124. * 消息类型数统计
  125. * @author: 唐远望
  126. * @version: 1.0
  127. * @date: 2026-04-09
  128. */
  129. public function message_type_count(Request $Request, NoticesModel $NoticesModel)
  130. {
  131. // 验证规则
  132. $Request->scene('message_type_count')->validate();
  133. $admin_company_id = request('admin_company_id', '0');
  134. $company_id = request('access_token.company_id', '0');
  135. $is_admin = request('access_token.is_admin', '0'); //是否管理员操作 0=是1=否
  136. // 接收参数
  137. $uid = request('access_token.uid', 0);
  138. $map1 = [];
  139. $map2 = [];
  140. $map3 = [];
  141. // 权限判断
  142. if ($is_admin != 1 && $company_id != 0) {
  143. $map1['company_id'] = $company_id;
  144. $map1['custom_uid'] = $uid;
  145. $map1['content_type'] = 1; //低价挂网
  146. $map2['company_id'] = $company_id;
  147. $map2['custom_uid'] = $uid;
  148. $map2['content_type'] = 2; //低禁止挂网
  149. $map3['company_id'] = $company_id;
  150. $map3['custom_uid'] = $uid;
  151. $map3['content_type'] = 3; //违规店铺
  152. } else {
  153. $map1['company_id'] = $admin_company_id;
  154. $map2['company_id'] = $admin_company_id;
  155. $map3['company_id'] = $admin_company_id;
  156. }
  157. // 查询低价挂网消息总数
  158. $low_price_product_count = $NoticesModel->where($map1)->orderByDesc('id')->count();
  159. // 查询低禁止网消息总数
  160. $low_forbid_product_count = $NoticesModel->where($map2)->orderByDesc('id')->count();
  161. // 查询违规店铺数量
  162. $illegal_store_count = $NoticesModel->where($map3)->orderByDesc('id')->count();
  163. $result_data = [
  164. 'low_price_product_count' => $low_price_product_count,
  165. 'low_forbid_product_count' => $low_forbid_product_count,
  166. 'illegal_store_count' => $illegal_store_count
  167. ];
  168. // 告知结果
  169. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => $result_data]);
  170. }
  171. }