From 91a2be4c5b6a700346f5024267a99e9e4ab9ca57 Mon Sep 17 00:00:00 2001
From: cl <1442464845@qq.com>
Date: 星期三, 29 四月 2026 16:30:53 +0800
Subject: [PATCH] 调整收货修改ztai

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java |   26 +++++++++++++++++++-------
 1 files changed, 19 insertions(+), 7 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
index da205ba..cbe2bd8 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java
@@ -551,10 +551,11 @@
                 .eq(WkOrder::getPoCode, syncOrder.getOrderInternalCode()));
         if (!Objects.isNull(order)) {
             assertWkOrderNoLinkedTask(order.getId());
-            assertWkOrderExceStatusUnexecuted(order, "淇敼");
             long pakinCount = waitPakinItemService.count(new LambdaQueryWrapper<WaitPakinItem>()
                     .eq(WaitPakinItem::getAsnId, order.getId()).eq(WaitPakinItem::getDeleted, 0));
             if (pakinCount > 0) {
+                // 宸茬粍鎵樻椂浠嶆寜鍘熻鍒欓檺鍒讹細浠呮湭鎵ц鐘舵�佸彲鏀瑰崟
+                assertWkOrderExceStatusUnexecuted(order, "淇敼");
                 String changeSummary = computeWkOrderModifyChangeSummaryOrNull(order, syncOrder, resolvedOrderType, typeCode, true);
                 if (changeSummary == null) {
                     return "淇敼鏃犲彉鍖�";
@@ -569,7 +570,9 @@
             if (changeSummary == null) {
                 return "淇敼鏃犲彉鍖�";
             }
-            updateOrderNoPakin(order, syncOrder, loginUserId);
+            // 鏈粍鎵樻椂鍏佽宸叉敹璐ф敼鍗曪紱鑷姩鏀惰揣鍦烘櫙涓嬪悓姝ヨ瀹屾垚鏁伴噺璺熻鍒掓暟閲忎竴鑷�
+            boolean alignQtyWithPlan = Objects.equals(order.getExceStatus(), AsnExceStatus.ASN_EXCE_STATUS_RECEIPT_DONE.val);
+            updateOrderNoPakin(order, syncOrder, loginUserId, alignQtyWithPlan);
             if (isDirectWaitPakin()) {
                 syncReceiptAreaByOrder(order.getId());
             }
@@ -883,7 +886,7 @@
     /**
      * 鏈粍鎵樺崟鎹殑淇敼锛氬湪鍘熷崟涓婃洿鏂颁富鍗�+鏄庣粏锛堟寜 lineId 鍖归厤锛夛紝淇濈暀 exceStatus銆乹ty銆亀orkQty锛岄伩鍏嶅垹鍗曢噸寤哄鑷村畾鏃朵换鍔″啀娆℃墽琛屻��
      */
-    private void updateOrderNoPakin(WkOrder order, SyncOrderParams syncOrder, Long loginUserId) {
+    private void updateOrderNoPakin(WkOrder order, SyncOrderParams syncOrder, Long loginUserId, boolean alignQtyWithPlan) {
         if (syncOrder.getOrderItems() == null || syncOrder.getOrderItems().isEmpty()) {
             throw new CoolException("淇敼鏃舵槑缁嗕笉鑳戒负绌猴紒锛�");
         }
@@ -923,7 +926,9 @@
             SyncOrdersItem inc = incomingByLineId.get(lineId);
             Double newAnfme = QuantityUtils.roundToScale(inc.getAnfme() != null ? inc.getAnfme() : existing.getAnfme());
             existing.setAnfme(newAnfme);
-            if (inc.getQty() != null) {
+            if (alignQtyWithPlan) {
+                existing.setQty(newAnfme);
+            } else if (inc.getQty() != null) {
                 existing.setQty(QuantityUtils.roundToScale(inc.getQty()));
             } else {
                 Double curQty = existing.getQty() != null ? existing.getQty() : 0.0;
@@ -954,6 +959,9 @@
             map.put("order_code", order.getCode());
             map.put("matnrCode", e.getValue().getMatnr());
             map.put("platItemId", e.getKey());
+            if (alignQtyWithPlan) {
+                map.put("qty", e.getValue().getAnfme());
+            }
             if (!asnOrderItemService.fieldsSave(map, loginUserId)) {
                 throw new CoolException("鏄庣粏淇濆瓨澶辫触锛侊紒");
             }
@@ -962,9 +970,13 @@
         Double sum = QuantityUtils.roundToScale(asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()))
                 .stream().mapToDouble(WkOrderItem::getAnfme).sum());
         order.setAnfme(sum);
-        List<WkOrderItem> afterItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()));
-        double qtySum = afterItems.stream().mapToDouble(oi -> oi.getQty() != null ? oi.getQty() : 0.0).sum();
-        order.setQty(QuantityUtils.roundToScale(qtySum));
+        if (alignQtyWithPlan) {
+            order.setQty(sum);
+        } else {
+            List<WkOrderItem> afterItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()));
+            double qtySum = afterItems.stream().mapToDouble(oi -> oi.getQty() != null ? oi.getQty() : 0.0).sum();
+            order.setQty(QuantityUtils.roundToScale(qtySum));
+        }
         asnOrderService.updateById(order);
     }
 

--
Gitblit v1.9.1