OrderRejectedBillRelationService.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  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. use Illuminate\Support\Facades\Http;
  11. class OrderRejectedBillRelationService
  12. {
  13. private $service;
  14. public function __construct(OrderRejectingStatusService $service)
  15. {
  16. $this->service = $service;
  17. }
  18. public function rejectedBillSyncOrder(RejectedBill $rejectedBill)
  19. {
  20. $order = $this->getOrder($rejectedBill);
  21. if (!$order) return;
  22. $order_issue = OrderIssue::query()->where('order_id', $order->id)->first();
  23. $item = OrderIssueRejectedBill::query()->where('logistic_number_return', $rejectedBill->logistic_number_return)->first();
  24. if ($item) {
  25. OrderIssueRejectedBill::query()->where('logistic_number_return', $rejectedBill->logistic_number_return)->update(
  26. ['order_id' => $order->id,'order_issue_id' => $order_issue->id ?? null]
  27. );
  28. } else {
  29. if($rejectedBill->logistic_number_return !== ''){
  30. OrderIssueRejectedBill::query()->create(
  31. ['order_id' => $order->id, 'order_issue_id' => $order_issue->id ?? null, 'logistic_number_return' => $rejectedBill->logistic_number_return]
  32. );
  33. }
  34. }
  35. $this->sendSWMSMessage($order);
  36. $this->service->syncRejectingStatus($order);
  37. }
  38. public function sendSWMSMessage($order){
  39. $items = OrderIssueRejectedBill::query()->select("logistic_number_return")
  40. ->whereNotNull("logistic_number_return")
  41. ->where("order_id",$order->id)->get();
  42. if(count($items) == 0){
  43. return;
  44. }
  45. $logisticNumbers = $items->map(function($item){
  46. return $item->logistic_number_return;
  47. })->toArray();
  48. // TODO 这里遗留待处理
  49. $url = config('api.java.base').config('api.java.reject.modifyStatus');
  50. $request = [
  51. "returnNos" => $logisticNumbers
  52. ];
  53. app('LogService')->log("通知问题件关联", "modifyStatus", '推送:'.json_encode($request));
  54. Http::post($url,$request);
  55. }
  56. private function getOrder(RejectedBill $rejectedBill)
  57. {
  58. return ($this->getOrderByLogisticNumber($rejectedBill) ?? $this->getOrderByOracleOrderHeader($rejectedBill)) ?? $this->getOrderByOrderIssueRejectedBill($rejectedBill);
  59. }
  60. private function getOrderByLogisticNumber(RejectedBill $rejectedBill)
  61. {
  62. return Order::query()->whereHas('packages', function ($query) use ($rejectedBill) {
  63. $query->where('logistic_number', $rejectedBill->logistic_number_return);
  64. })->first();
  65. }
  66. private function getOrderByOracleOrderHeader(RejectedBill $rejectedBill)
  67. {
  68. $order_header = OracleDOCOrderHeader::query()->selectRaw('OrderNO')->where('SoReference1', function ($query) use ($rejectedBill) {
  69. $query->select('AsnReference2')->from('DOC_ASN_HEADER')->where('AsnReference3', $rejectedBill->logistic_number_return)->first();
  70. })->first();
  71. return $order_header ? Order::query()->where('code', $order_header->orderno)->first() : null;
  72. }
  73. private function getOrderByOrderIssueRejectedBill(RejectedBill $rejectedBill){
  74. $query = OrderIssueRejectedBill::query()->select('order_id')->where('logistic_number_return',$rejectedBill['logistic_number_return']);
  75. return Order::query()->whereIn('id',$query)->first();
  76. }
  77. // 问题件同步
  78. public function orderSyncRejectedBill(Order $order)
  79. {
  80. $logistic_number_returns = array_unique(
  81. array_merge($this->getOrderPackagesLogisticNumbers($order), $this->getOracleOrderHeaderRelationLogisticNumbers($order))
  82. );
  83. $logistic_number_returns = $this->filtersCanBeJoinLogisticNumberReturns($order, $logistic_number_returns);
  84. $order_issue = OrderIssue::query()->where('order_id',$order->id)->first();
  85. OrderIssueRejectedBill::query()->insert(array_map(function($item)use($order,$order_issue){
  86. return ['order_id' => $order->id,'logistic_number_return' => $item,'order_issue_id' => $order_issue->id ?? ''];
  87. },$logistic_number_returns));
  88. if(!$order->id ?? null){
  89. return ;
  90. }
  91. OrderIssueRejectedBill::query()->where("order_id",$order->id)->update(['order_issue_id'=>$order_issue->id ?? null]);
  92. $this->service->syncRejectingStatus($order);
  93. $this->sendSWMSMessage($order);
  94. }
  95. private function getOrderPackagesLogisticNumbers(Order $order): array
  96. {
  97. return OrderPackage::query()->where('order_id', $order->id)->get()->map(function ($orderPackages) {
  98. return $orderPackages->logistic_number;
  99. })->toArray();
  100. }
  101. private function getOracleOrderHeaderRelationLogisticNumbers(Order $order): array
  102. {
  103. $query = OracleDOCOrderHeader::query()->select('SoReference1')->where('orderNo', $order->code);
  104. return OracleDOCASNHeader::query()->select('AsnReference3')->whereIn('AsnReference2', $query)->get()->map(function ($asnHeader) {
  105. return $asnHeader->asnreference3;
  106. })->toArray();
  107. }
  108. /**
  109. * @param Order $order
  110. * @param array $logistic_number_returns
  111. * @return array
  112. */
  113. public function filtersCanBeJoinLogisticNumberReturns(Order $order, array $logistic_number_returns): array
  114. {
  115. $order_issue_rejected_bill_logistic_number_returns = $this->geExistRelationLogisticNumberReturn($order, $logistic_number_returns);
  116. $logistic_number_returns = array_diff($logistic_number_returns, $order_issue_rejected_bill_logistic_number_returns);
  117. $rejected_bill_logistic_number_return = $this->getExistRejectedBIllLogisticNumberReturn($logistic_number_returns);
  118. return array_filter(array_intersect($logistic_number_returns, $rejected_bill_logistic_number_return),function($item){
  119. return $item != '';
  120. });
  121. }
  122. /**
  123. * @param Order $order
  124. * @param array $logistic_numbers
  125. * @return array
  126. */
  127. public function geExistRelationLogisticNumberReturn(Order $order, array $logistic_numbers): array
  128. {
  129. return OrderIssueRejectedBill::query()
  130. ->select('logistic_number_return')->where('order_id', $order->id)
  131. ->whereIn('logistic_number_return', $logistic_numbers)->get()
  132. ->where('logistic_number_return','!=','')
  133. ->map(function ($item) {
  134. return $item->logistic_number_return;
  135. })->toArray();
  136. }
  137. /**
  138. * @param array $logistic_numbers
  139. * @return array
  140. */
  141. public function getExistRejectedBIllLogisticNumberReturn(array $logistic_numbers): array
  142. {
  143. return RejectedBill::query()->select('logistic_number_return')
  144. ->whereIn('logistic_number_return', $logistic_numbers)
  145. ->where('logistic_number_return','!=','')->get()
  146. ->map(function ($item) {
  147. return $item->logistic_number_return;
  148. })->toArray();
  149. }
  150. }