OrderRejectedBillRelationService.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. namespace App\Services;
  3. use App\OracleDOCASNHeader;
  4. use App\OracleDOCOrderHeader;
  5. use App\Order;
  6. use App\OrderIssue;
  7. use App\OrderIssueRejectedBill;
  8. use App\OrderPackage;
  9. use App\RejectedBill;
  10. class OrderRejectedBillRelationService
  11. {
  12. private $service;
  13. public function __construct(OrderRejectingStatusService $service)
  14. {
  15. $this->service = $service;
  16. }
  17. public function rejectedBillSyncOrder(RejectedBill $rejectedBill)
  18. {
  19. $order = $this->getOrder($rejectedBill);
  20. if (!$order) return;
  21. $order_issue = OrderIssue::query()->where('order_id', $order->id)->first();
  22. $item = OrderIssueRejectedBill::query()->where('logistic_number_return', $rejectedBill->logistic_number_return)->first();
  23. if ($item) {
  24. OrderIssueRejectedBill::query()->where('logistic_number_return', $rejectedBill->logistic_number_return)->update(
  25. ['order_id' => $order->id,'order_issue_id' => $order_issue->id ?? null]
  26. );
  27. } else {
  28. if($rejectedBill->logistic_number_return !== ''){
  29. OrderIssueRejectedBill::query()->create(
  30. ['order_id' => $order->id, 'order_issue_id' => $order_issue->id ?? null, 'logistic_number_return' => $rejectedBill->logistic_number_return]
  31. );
  32. }
  33. }
  34. $this->service->syncRejectingStatus($order);
  35. }
  36. private function getOrder(RejectedBill $rejectedBill)
  37. {
  38. return ($this->getOrderByLogisticNumber($rejectedBill) ?? $this->getOrderByOracleOrderHeader($rejectedBill)) ?? $this->getOrderByOrderIssueRejectedBill($rejectedBill);
  39. }
  40. private function getOrderByLogisticNumber(RejectedBill $rejectedBill)
  41. {
  42. return Order::query()->whereHas('packages', function ($query) use ($rejectedBill) {
  43. $query->where('logistic_number', $rejectedBill->logistic_number_return);
  44. })->first();
  45. }
  46. private function getOrderByOracleOrderHeader(RejectedBill $rejectedBill)
  47. {
  48. $order_header = OracleDOCOrderHeader::query()->selectRaw('OrderNO')->where('SoReference1', function ($query) use ($rejectedBill) {
  49. $query->select('AsnReference2')->from('DOC_ASN_HEADER')->where('AsnReference3', $rejectedBill->logistic_number_return)->first();
  50. })->first();
  51. return $order_header ? Order::query()->where('code', $order_header->orderno)->first() : null;
  52. }
  53. private function getOrderByOrderIssueRejectedBill(RejectedBill $rejectedBill){
  54. $query = OrderIssueRejectedBill::query()->select('order_id')->where('logistic_number_return',$rejectedBill['logistic_number_return']);
  55. return Order::query()->whereIn('id',$query)->first();
  56. }
  57. // 问题件同步
  58. public function orderSyncRejectedBill(Order $order)
  59. {
  60. $logistic_number_returns = array_unique(
  61. array_merge($this->getOrderPackagesLogisticNumbers($order), $this->getOracleOrderHeaderRelationLogisticNumbers($order))
  62. );
  63. $logistic_number_returns = $this->filtersCanBeJoinLogisticNumberReturns($order, $logistic_number_returns);
  64. $order_issue = OrderIssue::query()->where('order_id',$order->id)->first();
  65. OrderIssueRejectedBill::query()->insert(array_map(function($item)use($order,$order_issue){
  66. return ['order_id' => $order->id,'logistic_number_return' => $item,'order_issue_id' => $order_issue->id ?? ''];
  67. },$logistic_number_returns));
  68. if(!$order->id ?? null){
  69. return ;
  70. }
  71. OrderIssueRejectedBill::query()->where("order_id",$order->id)->update(['order_issue_id'=>$order_issue->id ?? null]);
  72. $this->service->syncRejectingStatus($order);
  73. }
  74. private function getOrderPackagesLogisticNumbers(Order $order): array
  75. {
  76. return OrderPackage::query()->where('order_id', $order->id)->get()->map(function ($orderPackages) {
  77. return $orderPackages->logistic_number;
  78. })->toArray();
  79. }
  80. private function getOracleOrderHeaderRelationLogisticNumbers(Order $order): array
  81. {
  82. $query = OracleDOCOrderHeader::query()->select('SoReference1')->where('orderNo', $order->code);
  83. return OracleDOCASNHeader::query()->select('AsnReference3')->whereIn('AsnReference2', $query)->get()->map(function ($asnHeader) {
  84. return $asnHeader->asnreference3;
  85. })->toArray();
  86. }
  87. /**
  88. * @param Order $order
  89. * @param array $logistic_number_returns
  90. * @return array
  91. */
  92. public function filtersCanBeJoinLogisticNumberReturns(Order $order, array $logistic_number_returns): array
  93. {
  94. $order_issue_rejected_bill_logistic_number_returns = $this->geExistRelationLogisticNumberReturn($order, $logistic_number_returns);
  95. $logistic_number_returns = array_diff($logistic_number_returns, $order_issue_rejected_bill_logistic_number_returns);
  96. $rejected_bill_logistic_number_return = $this->getExistRejectedBIllLogisticNumberReturn($logistic_number_returns);
  97. return array_filter(array_intersect($logistic_number_returns, $rejected_bill_logistic_number_return),function($item){
  98. return $item != '';
  99. });
  100. }
  101. /**
  102. * @param Order $order
  103. * @param array $logistic_numbers
  104. * @return array
  105. */
  106. public function geExistRelationLogisticNumberReturn(Order $order, array $logistic_numbers): array
  107. {
  108. return OrderIssueRejectedBill::query()
  109. ->select('logistic_number_return')->where('order_id', $order->id)
  110. ->whereIn('logistic_number_return', $logistic_numbers)->get()
  111. ->where('logistic_number_return','!=','')
  112. ->map(function ($item) {
  113. return $item->logistic_number_return;
  114. })->toArray();
  115. }
  116. /**
  117. * @param array $logistic_numbers
  118. * @return array
  119. */
  120. public function getExistRejectedBIllLogisticNumberReturn(array $logistic_numbers): array
  121. {
  122. return RejectedBill::query()->select('logistic_number_return')
  123. ->whereIn('logistic_number_return', $logistic_numbers)
  124. ->where('logistic_number_return','!=','')->get()
  125. ->map(function ($item) {
  126. return $item->logistic_number_return;
  127. })->toArray();
  128. }
  129. }