WorkOrderController.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Filters\WorkOrderFilters;
  4. use App\Logistic;
  5. use App\OrderIssue;
  6. use App\Services\OrderIssueTypeService;
  7. use App\Services\OrderService;
  8. use App\Services\OwnerService;
  9. use App\Services\WorkOrderCommoditiesService;
  10. use App\Services\WorkOrderDetailService;
  11. use App\Services\WorkOrderLogService;
  12. use App\Services\WorkOrderService;
  13. use App\UserOwnerGroup;
  14. use App\UserWorkgroup;
  15. use App\WorkOrder;
  16. use App\WorkOrderDetail;
  17. use Illuminate\Http\Request;
  18. use Illuminate\Support\Facades\Gate;
  19. use Oursdreams\Export\Export;
  20. class WorkOrderController extends Controller
  21. {
  22. public $service;
  23. public $detailService;
  24. public $commoditiesService;
  25. public $logService;
  26. public $orderService;
  27. public $ownerService;
  28. public $orderIssueTypeService;
  29. public function __construct(
  30. WorkOrderService $service,
  31. WorkOrderCommoditiesService $commoditiesService,
  32. WorkOrderDetailService $detailService,
  33. WorkOrderLogService $logService,
  34. OrderService $orderService,
  35. OwnerService $ownerService,
  36. OrderIssueTypeService $orderIssueTypeService
  37. )
  38. {
  39. $this->service = $service;
  40. $this->detailService = $detailService;
  41. $this->commoditiesService = $commoditiesService;
  42. $this->logService = $logService;
  43. $this->orderService = $orderService;
  44. $this->ownerService = $ownerService;
  45. $this->orderIssueTypeService = $orderIssueTypeService;
  46. }
  47. /**
  48. * 承运商标记处理中
  49. * @param Request $request
  50. * @return array
  51. */
  52. public function logisticHandlerTagApi(Request $request): array
  53. {
  54. if (Gate::denies('订单管理-工单处理-承运商编辑'))
  55. return ['success' => false, 'message' => '没有对应权限'];
  56. $detail = WorkOrderDetail::query()->with('workOrder')->find($request->input('detail_id'));
  57. if ($detail->status === '完成') return ['success' => false, 'message' => '工单已完成,请刷新重试'];
  58. $this->service->logisticHandlerTag($detail);
  59. $data = $this->service->getDefaultWith($detail->work_order_id);
  60. return ['success' => true, 'data' => $data];
  61. }
  62. public function index(Request $request, WorkOrderFilters $filters)
  63. {
  64. if (Gate::denies('订单管理-工单处理-查询')) return redirect('/');
  65. $workOrders = WorkOrder::query()->filter($filters)->defaultWith()->paginate($request['paginate'] ?? 50);
  66. $logistics = Logistic::all();
  67. $orderIssueTypes = $this->orderIssueTypeService->getWorkOrderIssueType();
  68. $owners = $this->ownerService->getAuthorizedOwners();
  69. $userWorkgroup = UserWorkgroup::query()->select('id', 'name')->get();
  70. $userOwnerGroup = UserOwnerGroup::query()->select('id', 'name')->get();
  71. $this->service->tags($workOrders);
  72. return view('order.workOrder.index', compact('workOrders', 'logistics', 'orderIssueTypes', 'owners', 'userWorkgroup', 'userOwnerGroup'));
  73. }
  74. /**
  75. * 工单生成问题件
  76. * @param Request $request
  77. * @return array
  78. */
  79. public function buildOrderIssueApi(Request $request): array
  80. {
  81. if (Gate::denies('订单管理-订单问题件生成'))
  82. return ['success' => false, 'message' => '没有对应权限'];
  83. $work_orders = WorkOrder::query()->whereIn('id', $request['ids'])->get();
  84. if (count($work_orders) == 0) return ['success' => false, 'message' => '刷新当前页面重试'];
  85. if (OrderIssue::query()->whereIn('order_id', $work_orders->map(function ($item) {
  86. return $item['order_id'];
  87. }))->exists()) {
  88. return ['success' => false, 'message' => '已有对应的问题件'];
  89. }
  90. $result = $this->service->buildOrderIssue($work_orders);
  91. if (!$result['success']) return $result;
  92. $workOrders = WorkOrder::query()->defaultWith()->whereIn('id', $request['ids'])->get();
  93. $this->service->tags($workOrders);
  94. return ['success' => true, 'data' => $workOrders];
  95. }
  96. /**
  97. * 删除工单
  98. * @param $id
  99. * @return array|bool[]
  100. */
  101. public function destroyApi($id): array
  102. {
  103. if (Gate::denies('订单管理-工单处理-删除'))
  104. return ['success' => false, 'message' => '没有对应权限'];
  105. $workOrder = $this->service->find($id);
  106. if (!$workOrder) {
  107. return ['success' => false, 'message' => '对应工单信息未找到'];
  108. } else {
  109. if ($workOrder->status == '已处理') {
  110. return ['success' => false, 'message' => '对应工单已处理,拒绝删除'];
  111. }
  112. }
  113. WorkOrder::query()->where('id', $id)->Delete();
  114. return ['success' => true];
  115. }
  116. /**
  117. * 校验工单是否存在
  118. * @param Request $request
  119. * @return array
  120. */
  121. public function checkWorkOrderApi(Request $request): array
  122. {
  123. $nos = $request->input('no', '');
  124. if (is_string($nos)) {
  125. $nos = [$nos];
  126. }
  127. $data = $this->service->checkWorkOrder($nos);
  128. return ['success' => true, 'data' => $data];
  129. }
  130. /**
  131. * 货主完结工单
  132. * @param Request $request
  133. * @return array
  134. */
  135. public function ownerEndWorkOrderApi(Request $request): array
  136. {
  137. if (Gate::denies('订单管理-工单处理-货主编辑'))
  138. return ['success' => false, 'message' => '没有对应权限'];
  139. $detail_id = $request->input('detail_id');
  140. $detail = WorkOrderDetail::query()->with('workOrder')->where('id', $detail_id)->first();
  141. if (!$detail || !$detail->workOrder) {
  142. return ['success' => false, 'message' => '参数异常'];
  143. }
  144. try {
  145. $this->service->ownerEndWorkOrderDetail($detail);
  146. return ['success' => true];
  147. } catch (\Exception $e) {
  148. return ['success' => false, 'message' => '工单完结异常'];
  149. }
  150. }
  151. /**
  152. * 货主批量完结工单
  153. * @param Request $request
  154. * @return array
  155. */
  156. public function ownerBatchEndWorkOrderApi(Request $request): array
  157. {
  158. if (Gate::denies('订单管理-工单处理-货主编辑'))
  159. return ['success' => false, 'message' => '没有对应权限'];
  160. $detail_ids = $request->input('detail_ids', []);
  161. if (count($detail_ids) == 0) return ['success' => false, 'message' => '参数异常'];
  162. $details = WorkOrderDetail::query()->find($detail_ids);
  163. if (count($details) == 0) return ['success' => false, 'message' => '参数异常'];
  164. try {
  165. $this->service->ownerBatchEndWorkOrderDetails($details);
  166. return ['success' => true];
  167. } catch (\Exception $e) {
  168. return ['success' => false, 'message' => '工单完结异常,请刷新后重试'];
  169. }
  170. }
  171. public function updateRemissionApi(Request $request): array
  172. {
  173. if (Gate::denies('订单管理-工单处理-宝时编辑')) {
  174. return ['success' => false, 'message' => '没有对应权限'];
  175. }
  176. if (!$request->has(['id', 'column'])) {
  177. return ['success' => false, 'message' => '参数异常'];
  178. }
  179. /** @var WorkOrder $workOrder */
  180. $workOrder = WorkOrder::query()->find($request->input('id'));
  181. if (!$workOrder) {
  182. return ['success' => false, 'message' => '未找到对应的工单'];
  183. }
  184. $column = $request->input('column');
  185. $workOrder->update(["{$column}" => $request->input('value') ?? null]);
  186. return ['success' => true];
  187. }
  188. public function updateUserOwnerGroupApi(Request $request): array
  189. {
  190. if (Gate::denies('订单管理-工单处理-宝时编辑')) {
  191. return ['success' => false, 'message' => '没有对应权限'];
  192. }
  193. if (!$request->has(['id', 'user_owner_group_id'])) {
  194. return ['success' => false, 'message' => '参数异常'];
  195. }
  196. /** @var WorkOrder $workOrder */
  197. $workOrder = WorkOrder::query()->find($request->input('id'));
  198. if (!$workOrder) {
  199. return ['success' => false, 'message' => '未找到对应的工单'];
  200. }
  201. $workOrder->update(['user_owner_group_id' => $request->input('user_owner_group_id')]);
  202. return ['success' => true];
  203. }
  204. public function storeUserWorkGroupApi(Request $request): array
  205. {
  206. if (Gate::denies('订单管理-工单处理-宝时编辑')) {
  207. return ['success' => false, 'message' => '没有对应权限'];
  208. }
  209. if (!$request->has(['id', 'user_workgroup_id'])) {
  210. return ['success' => false, 'message' => '参数异常'];
  211. }
  212. /** @var WorkOrder $workOrder */
  213. $workOrder = WorkOrder::query()->find($request->input('id'));
  214. if (!$workOrder) {
  215. return ['success' => false, 'message' => '未找到对应的工单'];
  216. }
  217. $hasExists = $workOrder->userWorkGroups()->where('user_workgroup_id', $request->input('user_workgroup_id'))->exists();
  218. if ($hasExists) return ['success' => false, 'message' => '已有对应的关系'];
  219. $workOrder->userWorkGroups()->attach($request->input('user_workgroup_id'));
  220. return ['success' => true, 'data' => $workOrder->userWorkGroups];
  221. }
  222. public function destroyUserWorkGroupApi(Request $request): array
  223. {
  224. if (Gate::denies('订单管理-工单处理-宝时编辑')) {
  225. return ['success' => false, 'message' => '没有对应权限'];
  226. }
  227. if (!$request->has(['id', 'user_workgroup_id'])) {
  228. return ['success' => false, 'message' => '参数异常'];
  229. }
  230. /** @var WorkOrder $workOrder */
  231. $workOrder = WorkOrder::query()->find($request->input('id'));
  232. if (!$workOrder) {
  233. return ['success' => false, 'message' => '未找到对应的工单'];
  234. }
  235. $workOrder->userWorkGroups()->detach($request->input('user_workgroup_id'));
  236. return ['success' => true];
  237. }
  238. public function exportJsonExcel(Request $request, WorkOrderFilters $filters)
  239. {
  240. $work_orders = WorkOrder::query()->filter($filters)->defaultWith()->get();
  241. return $this->exportJson($work_orders);
  242. }
  243. public function exportJson($workOrders)
  244. {
  245. $json = [];
  246. $row = [
  247. '工单类型', '当前进度', '客户', '店铺名称', '客户订单号','承运人', '快递单号', '创建时间', '当前处理人', '创建人', '情况说明', '退回单号', '退回商品', '退回商品名称', '退回商品数量', '是否正品', '操作类型', '操作人', '内容'
  248. ];
  249. $workOrders->each(function ($item) use (&$json) {
  250. $logistic_numbers = $item->order->packages->implode('logistic_number', ",\r\n");
  251. $logistic_numbers_return = $item->orderIssueRejectedBills->implode('logistic_number_return',",\r\n");
  252. $rejected_item_name = '';
  253. $rejected_item_sku = '';
  254. $rejected_item_label = '';
  255. $rejected_item_amount = '';
  256. $item->orderIssueRejectedBills->each(function ($item) use (&$rejected_item_name, &$rejected_item_sku, &$rejected_item_label, &$rejected_item_amount) {
  257. if($item->rejectedBill)
  258. $item->rejectedBill->items->each(function ($item) use (&$rejected_item_name, &$rejected_item_sku, &$rejected_item_label, &$rejected_item_amount) {
  259. $rejected_item_name = $rejected_item_name . $item->name_goods . ",\r\n";
  260. $rejected_item_sku = $rejected_item_sku . $item->barcode_goods . ",\r\n";
  261. $rejected_item_label = $rejected_item_label . $item->quality_label . ",\r\n";
  262. $rejected_item_amount = $rejected_item_amount . $item->amount . ",\r\n";
  263. });
  264. });
  265. $work_order_process_logs_type = '';
  266. $work_order_process_logs_user = '';
  267. $work_order_process_logs = '';
  268. $work_order_details = $item->details->filter(function ($detail) use ($item) {
  269. return $detail->order_issue_type_id == $item->order_issue_type_id;
  270. });
  271. if(count($work_order_details) > 0){
  272. $work_order_details->first()->processLogs->each(function ($log) use (&$work_order_process_logs_type,&$work_order_process_logs_user,&$work_order_process_logs) {
  273. $work_order_process_logs_type .= $log->type. ",\r\n";
  274. $work_order_process_logs_user .= ($log->user->name ?? ''). ",\r\n";
  275. $work_order_process_logs .= $log->content. ",\r\n";
  276. });
  277. }
  278. $json[] = [
  279. $item->issueType->name ?? '',
  280. $item->process_progress,
  281. $item->owner->name ?? '',
  282. $item->order->shop->name ?? '',
  283. $item->order->client_code ?? '',
  284. $item->logistic->name ?? '',
  285. rtrim($logistic_numbers, ",\r\n"),
  286. isset($item->created_at) ? str_split($item->created_at, 10)[0] : '',
  287. $item->status,
  288. $item->creator->name ?? '',
  289. $item->remark,
  290. rtrim($logistic_numbers_return, ",\r\n"),
  291. rtrim($rejected_item_sku, ",\r\n"),
  292. rtrim($rejected_item_name, ",\r\n"),
  293. rtrim($rejected_item_amount, ",\r\n"),
  294. rtrim($rejected_item_label, ",\r\n"),
  295. rtrim($work_order_process_logs_type, ",\r\n"),
  296. rtrim($work_order_process_logs_user, ",\r\n"),
  297. rtrim($work_order_process_logs, ",\r\n"),
  298. ];
  299. });
  300. return Export::make($row, $json, "工单");
  301. }
  302. }