ViolationStore.php 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. <?php
  2. namespace App\Http\Controllers\Manager\Process;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Manager\Process\ViolationStore as Request;
  5. use App\Models\Manager\Process\ViolationStore as ViolationStoreModel;
  6. use App\Jobs\Manager\Process\ViolationStoreJobs;
  7. /**
  8. * 违规处理-违规店铺
  9. * @author 唐远望
  10. * @version 1.0
  11. * @date 2025-12-08
  12. */
  13. class ViolationStore extends Controller
  14. {
  15. /**
  16. * 列表
  17. * @author 唐远望
  18. * @version 1.0
  19. * @date 2025-12-08
  20. *
  21. */
  22. public function list(Request $request, ViolationStoreModel $ViolationStoreModel)
  23. {
  24. $request->scene('list')->validate();
  25. // 查询条件
  26. $map = [];
  27. $limit = request('limit', config('page_num', 10));
  28. $status = request('status', '');
  29. $start_time = request('start_time', '');
  30. $end_time = request('end_time', '');
  31. $first_responsible_person = request('first_responsible_person', '');
  32. $responsible_person = request('responsible_person', '');
  33. $platform = request('platform', '');
  34. $company_name = request('company_name', '');
  35. $store_name = request('store_name', '');
  36. $source_responsible_person = request('source_responsible_person', '');
  37. $processing_status = request('processing_status', '');
  38. // 时间条件
  39. if ($start_time) $map[] = ['insert_time', '>=', strtotime($start_time)];
  40. if ($end_time) $map[] = ['insert_time', '<=', strtotime($end_time)];
  41. // 其他条件
  42. if (is_numeric($status)) $map[] = ['status', '=', $status];
  43. if ($first_responsible_person) $map[] = ['first_responsible_person', 'like', "%$first_responsible_person%"];
  44. if ($responsible_person) $map[] = ['responsible_person', 'like', "%$responsible_person%"];
  45. if ($platform) $map[] = ['platform', 'like', "%$platform%"];
  46. if ($company_name) $map[] = ['company_name', 'like', "%$company_name%"];
  47. if ($store_name) $map[] = ['store_name', 'like', "%$store_name%"];
  48. if ($source_responsible_person) $map[] = ['source_responsible_person', 'like', "%$source_responsible_person%"];
  49. if ($processing_status) $map[] = ['processing_status', '=', $processing_status];
  50. // 查询数据
  51. $result = $ViolationStoreModel->query()
  52. ->where($map)
  53. ->orderByDesc('id')
  54. ->paginate($limit);
  55. // 分配数据
  56. if (!$result) return json_send(['code' => 'error', 'msg' => '暂无数据']);
  57. // 加载模板
  58. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => $result]);
  59. }
  60. /**
  61. * 详情
  62. * @author 唐远望
  63. * @version 1.0
  64. * @date 2025-12-08
  65. */
  66. public function detail(Request $request, ViolationStoreModel $ViolationStoreModel)
  67. {
  68. $request->scene('detail')->validate();
  69. // 接收参数
  70. $id = request('id', 0);
  71. $map = ['id' => $id];
  72. $data = $ViolationStoreModel->where($map)->first();
  73. if (!$data) return json_send(['code' => 'error', 'msg' => '记录不存在']);
  74. // 加载模板
  75. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => $data]);
  76. }
  77. /**
  78. * 添加
  79. * @author 唐远望
  80. * @version 1.0
  81. * @date 2025-12-08
  82. *
  83. */
  84. public function add(Request $request, ViolationStoreModel $ViolationStoreModel)
  85. {
  86. $request->scene('add')->validate();
  87. // 接收数据
  88. $all_data = request()->all();
  89. $store_scope = request('store_scope', '');
  90. $all_data['store_scope'] = $store_scope;
  91. //查询是否存在
  92. $map = ['store_name' => $all_data['store_name'], 'company_name' => $all_data['company_name']];
  93. $data = $ViolationStoreModel->where($map)->first();
  94. if ($data) return json_send(['code' => 'error', 'msg' => '记录已存在']);
  95. // 写入数据表
  96. $result = $ViolationStoreModel->addViolationStore($all_data);
  97. // 如果操作失败
  98. if (!$result) return json_send(['code' => 'error', 'msg' => '新增失败']);
  99. // 告知结果
  100. return json_send(['code' => 'success', 'msg' => '新增成功']);
  101. }
  102. /**
  103. * 修改
  104. * @author 唐远望
  105. * @version 1.0
  106. * @date 2025-12-08
  107. *
  108. */
  109. public function edit(Request $request, ViolationStoreModel $ViolationStoreModel)
  110. {
  111. $request->scene('edit')->validate();
  112. // 接收参数
  113. $id = request('id', 0);
  114. // 接收数据
  115. $all_data = request()->all();
  116. $store_scope = request('store_scope', '');
  117. $all_data['store_scope'] = $store_scope;
  118. //查询是否存在
  119. $map = ['store_name' => $all_data['store_name'], 'company_name' => $all_data['company_name']];
  120. $data = $ViolationStoreModel->where($map)->where('id', '!=', $id)->first();
  121. if ($data) return json_send(['code' => 'error', 'msg' => '记录已存在']);
  122. // 更新数据表
  123. $where = ['id' => $id];
  124. $result = $ViolationStoreModel->updateViolationStore($where, $all_data);
  125. // 如果操作失败
  126. if (!$result) return json_send(['code' => 'error', 'msg' => '修改失败']);
  127. // 告知结果
  128. return json_send(['code' => 'success', 'msg' => '修改成功']);
  129. }
  130. /**
  131. * 修改状态
  132. * @author 唐远望
  133. * @version 1.0
  134. * @date 2025-12-08
  135. *
  136. */
  137. public function set_status(Request $request, ViolationStoreModel $ViolationStoreModel)
  138. {
  139. // 验证参数
  140. $request->scene('set_status')->validate();
  141. // 接收数据
  142. $id = request('id', 0);
  143. $status = request('status', 0);
  144. // 查询用户
  145. $where = ['id' => $id];
  146. // 执行修改
  147. $result = $ViolationStoreModel->changeStatus($where, $status);
  148. // 提示新增失败
  149. if (!$result) return json_send(['code' => 'error', 'msg' => '设置失败']);
  150. // 告知结果
  151. return json_send(['code' => 'success', 'msg' => '设置成功']);
  152. }
  153. /**
  154. * 修改处理状态
  155. * @author 唐远望
  156. * @version 1.0
  157. * @date 2025-12-08
  158. *
  159. */
  160. public function set_processing_status(Request $request, ViolationStoreModel $ViolationStoreModel)
  161. {
  162. // 验证参数
  163. $request->scene('set_processing_status')->validate();
  164. // 接收数据
  165. $id = request('id', 0);
  166. $processing_status = request('processing_status', 0);
  167. // 查询用户
  168. $where = ['id' => $id];
  169. // 执行修改
  170. $result = $ViolationStoreModel->changeProcessingStatus($where, $processing_status);
  171. // 提示新增失败
  172. if (!$result) return json_send(['code' => 'error', 'msg' => '设置失败']);
  173. // 告知结果
  174. return json_send(['code' => 'success', 'msg' => '设置成功']);
  175. }
  176. /**
  177. * 删除
  178. * @author 唐远望
  179. * @version 1.0
  180. * @date 2025-12-08
  181. *
  182. */
  183. public function delete(Request $request, ViolationStoreModel $ViolationStoreModel)
  184. {
  185. // 验证参数
  186. $request->scene('delete')->validate();
  187. // 接收数据
  188. $id = request('id', 0);
  189. // 查询用户
  190. $where = ['id' => $id];
  191. // 执行删除
  192. $result = $ViolationStoreModel->deleteViolationStore($where);
  193. // 提示删除失败
  194. if (!$result) return json_send(['code' => 'error', 'msg' => '删除失败']);
  195. // 告知结果
  196. return json_send(['code' => 'success', 'msg' => '删除成功']);
  197. }
  198. /**
  199. * 执行数据清洗
  200. * @author 唐远望
  201. * @version 1.0
  202. * @date 2025-12-11
  203. *
  204. */
  205. public function data_cleaning(Request $request)
  206. {
  207. // 验证参数
  208. $request->scene('data_cleaning')->validate();
  209. $access_token = request('access_token', '');
  210. $admin_id=$access_token['uid'];
  211. $message_data =['page'=>'1','limit'=>50,'admin_id'=>$admin_id];
  212. ViolationStoreJobs::dispatch($message_data);
  213. // ViolationStoreJobs::dispatchSync($message_data);
  214. // 告知结果
  215. return json_send(['code' => 'success', 'msg' => '执行成功']);
  216. }
  217. }