WorkOrderProcessLogService.php 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. namespace App\Services;
  3. use App\OrderIssue;
  4. use App\Traits\ServiceAppAop;
  5. use App\User;
  6. use App\WorkOrder;
  7. use App\WorkOrderDetail;
  8. use Illuminate\Database\Eloquent\Model;
  9. use Illuminate\Support\Facades\Auth;
  10. class WorkOrderProcessLogService
  11. {
  12. use ServiceAppAop;
  13. /**
  14. * 创建 处理日志
  15. * @param WorkOrderDetail $detail
  16. * @param $params
  17. * @param User|null $user
  18. * @return Model
  19. */
  20. public function createProcessLog(WorkOrderDetail $detail, $params, User $user = null): Model
  21. {
  22. $user = $user ?? Auth::user();
  23. $process_log = $detail->processLogs()->create([
  24. 'work_order_detail_id' => $detail->id,
  25. 'work_order_id' => $detail->work_order_id,
  26. 'content' => $params['content'],
  27. 'user_id' => Auth::id(),
  28. ]);
  29. /** @var WorkOrder $work_order */
  30. $work_order = $detail->workOrder;
  31. if (in_array($work_order->status, ['宝时处理', '宝时终审'])
  32. && $work_order->bao_shi_tag != WorkOrder::$NO_STATE_TAG) {
  33. $detail->workOrder()->whereIn('status', [1, 4])->update(['bao_shi_tag' => WorkOrder::$NO_STATE_TAG]);
  34. } else if (in_array($work_order->status, ['承运商处理'])
  35. && $work_order->logistic_tag != WorkOrder::$NO_STATE_TAG) {
  36. $detail->workOrder()->where('status', 3)->update(['logistic_tag' => WorkOrder::$NO_STATE_TAG]);
  37. } else if (in_array($work_order->status, ['货主处理', '待货主完结'])
  38. && $work_order->owner_tag != WorkOrder::$NO_STATE_TAG) {
  39. $detail->workOrder()->whereIn('status', [2, 6])->update(['owner_tag' => 1]);
  40. }
  41. $process_log->setAttribute('user', $user);
  42. return $process_log;
  43. }
  44. /**
  45. * 批量创建处理日志
  46. * @param $workOrders
  47. * @param $params
  48. * @return array
  49. */
  50. public function batchCreateProcessLog($workOrders, $params): array
  51. {
  52. $user = Auth::user();
  53. $process_logs = [];
  54. /** @var WorkOrder $workOrder */
  55. foreach ($workOrders as $workOrder) {
  56. /** @var WorkOrderDetail $detail */
  57. $detail = $workOrder->details()->where('order_issue_type_id',$workOrder->order_issue_type_id)->orderByDesc('created_at')->first();
  58. if (!$detail) continue;
  59. $process_logs[] = $this->createProcessLog($detail, $params, $user);
  60. }
  61. return $process_logs;
  62. }
  63. /**
  64. * 将工单的处理结果同步到问题件的处理结果
  65. * @param OrderIssue $orderIssue
  66. * @param WorkOrderDetail $detail
  67. */
  68. public function syncOrderIssue(OrderIssue $orderIssue, WorkOrderDetail $detail)
  69. {
  70. $logs = $detail->processLogs()->where('status', '未同步')->get();
  71. $orderIssue->logs()->insert($logs->map(function ($log) use ($orderIssue) {
  72. return [
  73. 'order_issue_id' => $orderIssue->id,
  74. 'context' => $log->context,
  75. 'user_id' => $log->user_id,
  76. 'create_at' => $log->created_at,
  77. ];
  78. })->toArray());
  79. }
  80. }