From b003a49794f49a329e2702918ecfc8d14b371d0d Mon Sep 17 00:00:00 2001
From: chen.lin <1442464845@qq.com>
Date: 星期三, 04 三月 2026 14:51:25 +0800
Subject: [PATCH] 云仓WMS接口流程

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReceiveMsgServiceImpl.java |  341 +++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 306 insertions(+), 35 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 1c2e00b..ca580c6 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
@@ -19,6 +19,7 @@
 import com.vincent.rsf.server.common.domain.BaseParam;
 import com.vincent.rsf.server.common.domain.PageParam;
 import com.vincent.rsf.server.common.utils.FieldsUtils;
+import com.vincent.rsf.server.common.utils.QuantityUtils;
 import com.vincent.rsf.server.manager.controller.dto.LocStockDto;
 import com.vincent.rsf.server.manager.entity.*;
 import com.vincent.rsf.server.manager.enums.*;
@@ -79,6 +80,10 @@
     @Autowired
     private LocService locService;
     @Autowired
+    private OrderWorkTypeService orderWorkTypeService;
+    @Autowired
+    private OrderTypeDictService orderTypeDictService;
+    @Autowired
     private WarehouseAreasService warehouseAreasService;
     @Autowired
     private WarehouseService warehouseService;
@@ -104,6 +109,10 @@
     private DictTypeService dictTypeService;
     @Autowired
     private LocItemService locItemService;
+    @Autowired
+    private WaitPakinItemService waitPakinItemService;
+    @Autowired
+    private WarehouseAreasItemService warehouseAreasItemService;
 
 
     /**
@@ -408,11 +417,37 @@
     public R syncCheckOrder(List<SyncOrderParams> syncOrders, Long loginUserId) {
         if (!syncOrders.isEmpty()) {
             syncOrders.forEach(syncOrder -> {
+                if (StringUtils.isBlank(syncOrder.getOrderInternalCode())) {
+                    throw new CoolException("鍗曟嵁鍐呯爜涓嶈兘涓虹┖锛侊紒");
+                }
+                // 鏄庣粏 lineId锛堝搴� platItemId锛変笉鑳戒负绌猴紝涓斿悓涓�璁㈠崟鍐呬笉鑳介噸澶�
+                if (syncOrder.getOrderItems() != null) {
+                    Set<String> lineIds = new HashSet<>();
+                    for (SyncOrdersItem item : syncOrder.getOrderItems()) {
+                        if (StringUtils.isBlank(item.getPlatItemId())) {
+                            throw new CoolException("鏄庣粏 lineId 涓嶈兘涓虹┖锛侊紒");
+                        }
+                        String lineId = item.getPlatItemId().trim();
+                        if (!lineIds.add(lineId)) {
+                            throw new CoolException("鍚屼竴璁㈠崟鍐呮槑缁� lineId 涓嶈兘閲嶅锛�" + lineId);
+                        }
+                    }
+                }
                 WkOrder wkOrder = new WkOrder();
-                DictData one = dictDataService.getOne(new LambdaQueryWrapper<DictData>().eq(DictData::getDictTypeCode, DictTypeCode.DICT_SYS_BUSINESS_TYPE)
-                        .eq(DictData::getValue, syncOrder.getWkType()), false);
-                if (Objects.isNull(one)) {
+                // 鍏煎 wkType 浼犳暟瀛楋紙绫诲瀷鐮侊級鎴栦腑鏂囷紙鏄剧ず鍚嶏級锛氬厛鎸� label 鍙嶆煡 type锛屽惁鍒欐寜鍘熷�煎綋 type
+                String wkTypeInput = syncOrder.getWkType();
+                String typeCode = StringUtils.isBlank(wkTypeInput) ? null : orderWorkTypeService.getTypeByLabel(wkTypeInput);
+                if (typeCode == null) {
+                    typeCode = wkTypeInput;
+                }
+                if (StringUtils.isBlank(typeCode) || orderWorkTypeService.getLabelByType(typeCode) == null) {
                     throw new CoolException("鍗曟嵁锛�" + syncOrder.getOrderNo() + ", 涓氬姟绫诲瀷涓嶅瓨鍦紒锛�");
+                }
+                // 璁㈠崟绫诲瀷锛氭敮鎸佹暟瀛� 1/2/3銆佷腑鏂囥�屽嚭搴撳崟銆�/銆屽叆搴撳崟銆�/銆岃皟鎷ㄥ崟銆嶆垨鍐呴儴鐮� out/in/transfer锛堟潵鑷瓧鍏革級
+                String typeInput = syncOrder.getType();
+                String resolvedOrderType = orderTypeDictService.resolveType(typeInput);
+                if (typeInput != null && !typeInput.trim().isEmpty() && resolvedOrderType == null) {
+                    throw new CoolException("鍗曟嵁锛�" + syncOrder.getOrderNo() + ", 璁㈠崟绫诲瀷涓嶅瓨鍦紒锛�");
                 }
                 Loc serviceOne = null;
                 if (!Objects.isNull(syncOrder.getOrgLoc())) {
@@ -421,42 +456,56 @@
                 if (!Objects.isNull(serviceOne)) {
                     //TODO 娣诲姞璋冩嫈绉诲簱鍗曞姛鑳�
                 } else {
+                    // operateType=2 瀛樺湪鍒欎慨鏀广�佷笉瀛樺湪鍒欐姤閿欙紱operateType=1 瀛樺湪鍒欎慨鏀广�佷笉瀛樺湪鍒欐柊澧�
                     WkOrder order = asnOrderService.getOne(new LambdaQueryWrapper<WkOrder>()
-                            .eq(!Objects.isNull(syncOrder.getOrderId()), WkOrder::getPoId, syncOrder.getOrderId())
-                            .eq(WkOrder::getPoCode, syncOrder.getOrderNo()));
+                            .eq(WkOrder::getPoCode, syncOrder.getOrderInternalCode()));
                     if (!Objects.isNull(order)) {
-                        if (order.getExceStatus().equals(AsnExceStatus.ASN_EXCE_STATUS_UN_EXCE.val) ||
-                                order.getExceStatus().equals(AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)) {
-                            /**鍒犻櫎鍗曟嵁鏄庣粏*/
-                            asnOrderItemService.remove(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()));
-                            /**鍒犻櫎涓诲崟*/
-                            asnOrderService.removeById(order.getId());
-                        } else {
-                            throw new CoolException("鍗曟嵁宸叉坊鍔狅紝涓嶅彲鎵ц淇敼鎴栨坊鍔犳搷浣滐紒锛�");
+                        // 浠呮湭鎵ц鐘舵�佸彲琚� order/add 淇敼锛堝叆搴撴湭鎵ц銆佸嚭搴撲换鍔″垵濮嬶級
+                        List<Short> editableStatus = Arrays.asList(AsnExceStatus.ASN_EXCE_STATUS_UN_EXCE.val, AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val);
+                        if (!editableStatus.contains(order.getExceStatus())) {
+                            throw new CoolException("浠呮湭鎵ц鐘舵�佺殑鍗曟嵁鍙慨鏀癸紒锛�");
                         }
+                        // 瀛樺湪鍒欎慨鏀癸紙1 鍜� 2 鍧囪蛋姝ゅ锛夛紝缁勬墭鏍¢獙鍦� mergeOrderWithPakin/updateOrderNoPakin 鍐�
+                        long pakinCount = waitPakinItemService.count(new LambdaQueryWrapper<WaitPakinItem>()
+                                .eq(WaitPakinItem::getAsnId, order.getId()));
+                        if (pakinCount > 0) {
+                            // 宸茬粍鎵橈細鎸� lineId锛坧latItemId锛夊悎骞讹紝鏍¢獙鏁伴噺涓庡垹闄�
+                            mergeOrderWithPakin(order, syncOrder, resolvedOrderType, typeCode, loginUserId);
+                            // 鏀惰揣鍖哄凡鍋滅敤 // syncReceiptAreaByOrder(order.getId());
+                            return; // 鏈崟宸插鐞嗭紝璺宠繃涓嬫柟鈥滄柊寤轰富鍗�+鏄庣粏鈥�
+                        }
+                        // 鏈粍鎵橈細鍦ㄥ師鍗曚笂鏇存柊涓诲崟+鏄庣粏锛屼繚鐣� exceStatus/qty/workQty锛岄伩鍏嶅啀娆¤Е鍙戝畾鏃朵换鍔″鑷撮噸澶嶆敹璐�
+                        updateOrderNoPakin(order, syncOrder, loginUserId);
+                        // 鏀惰揣鍖哄凡鍋滅敤 // syncReceiptAreaByOrder(order.getId());
+                        return;
+                    } else if (Integer.valueOf(2).equals(syncOrder.getOperateType())) {
+                        // 浠� operateType=2 鏃惰姹傚崟鎹繀椤诲瓨鍦�
+                        throw new CoolException("鍗曟嵁涓嶅瓨鍦紝鏃犳硶淇敼锛侊紒");
                     }
                     String rule = SerialRuleCode.SYS_ASN_ORDER;
-                    if (syncOrder.getType().equals(OrderType.ORDER_OUT.type)) {
+                    if (resolvedOrderType != null && resolvedOrderType.equals(OrderType.ORDER_OUT.type)) {
                         rule = SerialRuleCode.SYS_OUT_STOCK_CODE;
                     }
-
-                    String ruleCode = SerialRuleUtils.generateRuleCode(rule, null);
-                    wkOrder.setType(syncOrder.getType())
-                            .setWkType(one.getValue())
-                            .setAnfme(syncOrder.getAnfme())
-                            .setPoCode(syncOrder.getOrderNo())
+                    // 鏈� orderNo 鍒欑洿鎺ヤ綔涓� WMS 鍗曞彿 code锛屽惁鍒欐寜瑙勫垯鐢熸垚锛沺o_code 瀛樺崟鎹唴鐮侊紙orderInternalCode 宸叉牎楠岄潪绌猴級
+                    String wmsCode = StringUtils.isNotBlank(syncOrder.getOrderNo()) ? syncOrder.getOrderNo() : SerialRuleUtils.generateRuleCode(rule, null);
+                    String poCodeVal = syncOrder.getOrderInternalCode();
+                    wkOrder.setType(resolvedOrderType != null ? resolvedOrderType : syncOrder.getType())
+                            .setWkType(typeCode)
+                            .setAnfme(QuantityUtils.roundToScale(syncOrder.getAnfme()))
+                            .setPoCode(poCodeVal)
                             .setWorkQty(0.0)
                             .setQty(0.0)
                             .setPoId(syncOrder.getOrderId())
-                            .setCode(ruleCode)
+                            .setCode(wmsCode)
                             .setArrTime(syncOrder.getArrTime())
+                            .setStationId(syncOrder.getStationId())
                             .setId(null)
                             .setCreateTime(new Date())
                             .setUpdateTime(new Date())
                             .setCreateBy(loginUserId)
                             .setUpdateBy(loginUserId);
 
-                    if (syncOrder.getType().equals(OrderType.ORDER_OUT.type)){
+                    if (resolvedOrderType != null && resolvedOrderType.equals(OrderType.ORDER_OUT.type)) {
                         wkOrder.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val);
                     }
 
@@ -478,7 +527,7 @@
                     });
                     List<WkOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>()
                             .eq(WkOrderItem::getOrderId, wkOrder.getId()));
-                    double sum = orderItems.stream().mapToDouble(WkOrderItem::getAnfme).sum();
+                    Double sum = QuantityUtils.roundToScale(orderItems.stream().mapToDouble(WkOrderItem::getAnfme).sum());
                     wkOrder.setAnfme(sum);
                     if (!asnOrderService.updateById(wkOrder)) {
                         throw new CoolException("璁″垝鏀惰揣鏁伴噺淇敼澶辫触锛侊紒");
@@ -488,6 +537,203 @@
         }
         return R.ok();
     }
+
+    /**
+     * 宸茬粍鎵樺崟鎹殑淇敼鍚堝苟锛氭寜 lineId锛坧latItemId锛夊尮閰嶃��
+     * 瑙勫垯锛氱粍鎵樻暟閲忎笉浼氬洜鏀瑰崟鑰屽彉锛涘凡缁勬墭 100 鏃讹紝淇敼涓� 99 浼氭姤閿欙紝淇敼涓� 101 鍏佽涓斿鍑虹殑 1 鍙啀缁勬墭銆�
+     */
+    private void mergeOrderWithPakin(WkOrder order, SyncOrderParams syncOrder, String resolvedOrderType, String typeCode, Long loginUserId) {
+        if (syncOrder.getOrderItems() != null) {
+            for (SyncOrdersItem it : syncOrder.getOrderItems()) {
+                if (StringUtils.isBlank(it.getPlatItemId())) {
+                    throw new CoolException("鏄庣粏 lineId 涓嶈兘涓虹┖锛侊紒");
+                }
+            }
+        }
+        List<WkOrderItem> existingItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()));
+        List<WaitPakinItem> pakinItems = waitPakinItemService.list(new LambdaQueryWrapper<WaitPakinItem>().eq(WaitPakinItem::getAsnId, order.getId()));
+        Map<Long, Double> palletizedByItemId = pakinItems.stream()
+                .collect(Collectors.groupingBy(WaitPakinItem::getAsnItemId, Collectors.summingDouble(w -> w.getAnfme() != null ? w.getAnfme() : 0.0)));
+        palletizedByItemId.replaceAll((k, v) -> QuantityUtils.roundToScale(v));
+
+        Map<String, SyncOrdersItem> incomingByLineId = new HashMap<>();
+        if (syncOrder.getOrderItems() != null) {
+            for (SyncOrdersItem it : syncOrder.getOrderItems()) {
+                incomingByLineId.put(it.getPlatItemId().trim(), it);
+            }
+        }
+
+        Set<String> existingLineIds = existingItems.stream()
+                .map(e -> StringUtils.isNotBlank(e.getPlatItemId()) ? e.getPlatItemId().trim() : null)
+                .filter(Objects::nonNull)
+                .collect(Collectors.toSet());
+
+        for (WkOrderItem existing : existingItems) {
+            String lineId = StringUtils.isNotBlank(existing.getPlatItemId()) ? existing.getPlatItemId().trim() : null;
+            double palletized = palletizedByItemId.getOrDefault(existing.getId(), 0.0);
+            if (lineId == null || !incomingByLineId.containsKey(lineId)) {
+                if (palletized > 0) {
+                    throw new CoolException("璇ユ槑缁嗗凡缁勬墭锛岄渶瑙i櫎缁勬墭鍚庢墠鑳藉垹闄わ紒锛�");
+                }
+            } else {
+                SyncOrdersItem inc = incomingByLineId.get(lineId);
+                Double newAnfme = QuantityUtils.roundToScale(inc.getAnfme() != null ? inc.getAnfme() : 0.0);
+                // 宸茬粍鎵樻暟閲忎笉鍙橈細鏀瑰皬锛堝 100 鏀逛负 99锛夋姤閿欙紱鏀瑰ぇ锛堝 100 鏀逛负 101锛夊厑璁革紝澶氬嚭鐨勫彲鍐嶇粍鎵�
+                if (QuantityUtils.compare(newAnfme, palletized) < 0) {
+                    throw new CoolException("璇ユ槑缁嗘暟閲忎笉鑳藉皬浜庡凡缁勬墭鏁伴噺锛堝凡缁勬墭 " + palletized + "锛夛紝闇�瑙i櫎缁勬墭鍚庢墠鑳戒慨鏀癸紒锛�");
+                }
+            }
+        }
+
+        order.setAnfme(QuantityUtils.roundToScale(syncOrder.getAnfme() != null ? syncOrder.getAnfme() : 0.0));
+        if (syncOrder.getArrTime() != null) {
+            order.setArrTime(syncOrder.getArrTime());
+        }
+        if (StringUtils.isNotBlank(syncOrder.getStationId())) {
+            order.setStationId(syncOrder.getStationId());
+        }
+        order.setUpdateBy(loginUserId);
+        order.setUpdateTime(new Date());
+        asnOrderService.updateById(order);
+
+        for (WkOrderItem existing : existingItems) {
+            String lineId = StringUtils.isNotBlank(existing.getPlatItemId()) ? existing.getPlatItemId().trim() : null;
+            if (lineId == null || !incomingByLineId.containsKey(lineId)) {
+                asnOrderItemService.removeById(existing.getId());
+                continue;
+            }
+            SyncOrdersItem inc = incomingByLineId.get(lineId);
+            existing.setAnfme(QuantityUtils.roundToScale(inc.getAnfme() != null ? inc.getAnfme() : existing.getAnfme()));
+            existing.setMaktx(inc.getMaktx());
+            existing.setSpec(inc.getSpec());
+            existing.setModel(inc.getModel());
+            existing.setStockUnit(inc.getUnit());
+            existing.setBatch(inc.getBatch());
+            existing.setPlanNo(inc.getPlanNo());
+            existing.setPalletId(inc.getPalletId());
+            existing.setUpdateBy(loginUserId);
+            existing.setUpdateTime(new Date());
+            asnOrderItemService.updateById(existing);
+        }
+
+        for (Map.Entry<String, SyncOrdersItem> e : incomingByLineId.entrySet()) {
+            String key = e.getKey();
+            if (!existingLineIds.contains(key)) {
+                Map<String, Object> map = new ObjectMapper().convertValue(e.getValue(), Map.class);
+                map.put("orderId", order.getId());
+                map.put("poId", order.getPoId());
+                map.put("poCode", order.getPoCode());
+                map.put("order_code", order.getCode());
+                map.put("matnrCode", e.getValue().getMatnr());
+                map.put("platItemId", key);
+                if (!asnOrderItemService.fieldsSave(map, loginUserId)) {
+                    throw new CoolException("鏄庣粏淇濆瓨澶辫触锛侊紒");
+                }
+            }
+        }
+
+        Double sum = QuantityUtils.roundToScale(asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()))
+                .stream().mapToDouble(WkOrderItem::getAnfme).sum());
+        order.setAnfme(sum);
+        asnOrderService.updateById(order);
+    }
+
+    /**
+     * 鏈粍鎵樺崟鎹殑淇敼锛氬湪鍘熷崟涓婃洿鏂颁富鍗�+鏄庣粏锛堟寜 lineId 鍖归厤锛夛紝淇濈暀 exceStatus銆乹ty銆亀orkQty锛岄伩鍏嶅垹鍗曢噸寤哄鑷村畾鏃朵换鍔″啀娆℃墽琛屻��
+     */
+    private void updateOrderNoPakin(WkOrder order, SyncOrderParams syncOrder, Long loginUserId) {
+        if (syncOrder.getOrderItems() == null || syncOrder.getOrderItems().isEmpty()) {
+            throw new CoolException("淇敼鏃舵槑缁嗕笉鑳戒负绌猴紒锛�");
+        }
+        Map<String, SyncOrdersItem> incomingByLineId = new HashMap<>();
+        for (SyncOrdersItem it : syncOrder.getOrderItems()) {
+            if (StringUtils.isBlank(it.getPlatItemId())) {
+                throw new CoolException("鏄庣粏 lineId 涓嶈兘涓虹┖锛侊紒");
+            }
+            incomingByLineId.put(it.getPlatItemId().trim(), it);
+        }
+        List<WkOrderItem> existingItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()));
+        Set<String> existingLineIds = existingItems.stream()
+                .map(e -> StringUtils.isNotBlank(e.getPlatItemId()) ? e.getPlatItemId().trim() : null)
+                .filter(Objects::nonNull)
+                .collect(Collectors.toSet());
+
+        order.setAnfme(QuantityUtils.roundToScale(syncOrder.getAnfme() != null ? syncOrder.getAnfme() : 0.0));
+        if (syncOrder.getArrTime() != null) {
+            order.setArrTime(syncOrder.getArrTime());
+        }
+        if (StringUtils.isNotBlank(syncOrder.getStationId())) {
+            order.setStationId(syncOrder.getStationId());
+        }
+        order.setUpdateBy(loginUserId);
+        order.setUpdateTime(new Date());
+        asnOrderService.updateById(order);
+
+        for (WkOrderItem existing : existingItems) {
+            String lineId = StringUtils.isNotBlank(existing.getPlatItemId()) ? existing.getPlatItemId().trim() : null;
+            if (lineId == null || !incomingByLineId.containsKey(lineId)) {
+                // 鏀惰揣鍖哄凡鍋滅敤 // warehouseAreasItemService.remove(new LambdaQueryWrapper<WarehouseAreasItem>().eq(WarehouseAreasItem::getAsnItemId, existing.getId()));
+                asnOrderItemService.removeById(existing.getId());
+                continue;
+            }
+            SyncOrdersItem inc = incomingByLineId.get(lineId);
+            existing.setAnfme(QuantityUtils.roundToScale(inc.getAnfme() != null ? inc.getAnfme() : existing.getAnfme()));
+            existing.setMaktx(inc.getMaktx());
+            existing.setSpec(inc.getSpec());
+            existing.setModel(inc.getModel());
+            existing.setStockUnit(inc.getUnit());
+            existing.setBatch(inc.getBatch());
+            existing.setPlanNo(inc.getPlanNo());
+            existing.setPalletId(inc.getPalletId());
+            existing.setUpdateBy(loginUserId);
+            existing.setUpdateTime(new Date());
+            asnOrderItemService.updateById(existing);
+        }
+
+        for (Map.Entry<String, SyncOrdersItem> e : incomingByLineId.entrySet()) {
+            if (existingLineIds.contains(e.getKey())) {
+                continue;
+            }
+            Map<String, Object> map = new ObjectMapper().convertValue(e.getValue(), Map.class);
+            map.put("orderId", order.getId());
+            map.put("poId", order.getPoId());
+            map.put("poCode", order.getPoCode());
+            map.put("order_code", order.getCode());
+            map.put("matnrCode", e.getValue().getMatnr());
+            map.put("platItemId", e.getKey());
+            if (!asnOrderItemService.fieldsSave(map, loginUserId)) {
+                throw new CoolException("鏄庣粏淇濆瓨澶辫触锛侊紒");
+            }
+        }
+
+        Double sum = QuantityUtils.roundToScale(asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId()))
+                .stream().mapToDouble(WkOrderItem::getAnfme).sum());
+        order.setAnfme(sum);
+        asnOrderService.updateById(order);
+    }
+
+    /** 鏀惰揣鍖哄凡鍋滅敤锛屾柟娉曟暣浣撴敞閲�
+     * 璁㈠崟淇敼鍚庡悓姝ユ敹璐у尯锛氭寜 asnItemId 灏嗘敹璐у尯璁板綍鐨� anfme 鏇存柊涓鸿鍗曟槑缁嗙殑 anfme銆�
+     */
+//    private void syncReceiptAreaByOrder(Long orderId) {
+//        List<WkOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, orderId));
+//        if (orderItems.isEmpty()) {
+//            return;
+//        }
+//        List<WarehouseAreasItem> areaItems = warehouseAreasItemService.list(new LambdaQueryWrapper<WarehouseAreasItem>().eq(WarehouseAreasItem::getAsnId, orderId));
+//        Map<Long, Double> itemAnfme = orderItems.stream().collect(Collectors.toMap(WkOrderItem::getId, i -> i.getAnfme() != null ? i.getAnfme() : 0.0, (a, b) -> b));
+//        for (WarehouseAreasItem area : areaItems) {
+//            if (area.getAsnItemId() == null || !itemAnfme.containsKey(area.getAsnItemId())) {
+//                continue;
+//            }
+//            Double anfme = itemAnfme.get(area.getAsnItemId());
+//            if (area.getAnfme() != null && area.getAnfme().equals(anfme)) {
+//                continue;
+//            }
+//            area.setAnfme(anfme);
+//            warehouseAreasItemService.updateById(area);
+//        }
+//    }
 
     /**
      * @author Ryan
@@ -660,7 +906,7 @@
                             .eq(WkOrderItem::getMatnrCode, orderItem.getMatnr())
                             .eq(StringUtils.isNotEmpty(orderItem.getBatch()), WkOrderItem::getSplrBatch, orderItem.getBatch())
                             .eq(StringUtils.isNotEmpty(orderItem.getPlatItemId()), WkOrderItem::getPlatItemId, orderItem.getPlatItemId())
-                            .set(WkOrderItem::getAnfme, orderItem.getAnfme()))) {
+                            .set(WkOrderItem::getAnfme, QuantityUtils.roundToScale(orderItem.getAnfme())))) {
                         throw new CoolException("鍗曟嵁淇敼澶辫触锛侊紒");
                     }
                 } else {
@@ -673,7 +919,7 @@
                     }
                 }
             });
-            wkOrder.setAnfme(order.getAnfme());
+            wkOrder.setAnfme(QuantityUtils.roundToScale(order.getAnfme()));
             if (!asnOrderService.updateById(wkOrder)) {
                 throw new CoolException("涓诲崟鎹慨鏀瑰け璐ワ紒锛�");
             }
@@ -691,31 +937,56 @@
     @Transactional(timeout = 60, rollbackFor = Exception.class)
     public R syncOrderDelete(List<SyncOrderParams> orders) {
         orders.forEach(order -> {
+            // operateType=3锛氬瓨鍦ㄥ垯鍒ゆ柇鏄惁鍙互鍙栨秷锛涗富瑕佹牎楠屽崟鎹唴鐮�(orderInternalCode)锛宱rderNo 鏌ュ埌 1 鏉$户缁紝鏌ュ埌澶氭潯鍒欐姤閿欏己璋冧娇鐢� orderInternalCode
+            WkOrder wkOrder = null;
+            if (StringUtils.isNotEmpty(order.getOrderInternalCode())) {
+                wkOrder = asnOrderService.getOne(new LambdaQueryWrapper<WkOrder>()
+                        .eq(WkOrder::getPoCode, order.getOrderInternalCode()));
+            }
+            if (wkOrder == null && StringUtils.isNotEmpty(order.getOrderNo())) {
+                List<WkOrder> list = asnOrderService.list(new LambdaQueryWrapper<WkOrder>()
+                        .eq(WkOrder::getCode, order.getOrderNo()));
+                if (list.isEmpty()) {
+                    throw new CoolException("鍗曟嵁涓嶅瓨鍦紝鏃犳硶鍙栨秷锛侊紒");
+                }
+                if (list.size() > 1) {
+                    throw new CoolException("鍗曞彿瀵瑰簲澶氭潯鍗曟嵁锛岃浣跨敤鍗曟嵁鍐呯爜(orderInternalCode)鍞竴鎸囧畾鍚庡啀鍙栨秷锛侊紒");
+                }
+                wkOrder = list.get(0);
+            }
+            if (wkOrder == null) {
+                throw new CoolException("鍗曟嵁涓嶅瓨鍦紝鏃犳硶鍙栨秷锛侊紒璇锋彁渚涘崟鎹唴鐮�(orderInternalCode)鎴栧崟鍙�(orderNo)銆�");
+            }
+            final WkOrder finalWkOrder = wkOrder;
+            // 宸茬粍鎵樹笉鍙彇娑�
+            long pakinCount = waitPakinItemService.count(new LambdaQueryWrapper<WaitPakinItem>()
+                    .eq(WaitPakinItem::getAsnId, finalWkOrder.getId()));
+            if (pakinCount > 0) {
+                throw new CoolException("鍗曟嵁宸茬粍鎵橈紝浠呮湭缁勬墭鐘舵�佸彲鍙栨秷锛岃鍏堣В闄ょ粍鎵橈紒锛�");
+            }
+            // 浠呮湭鎵ц鐘舵�佸彲鍙栨秷锛堝叆搴撴湭鎵ц銆佸嚭搴撲换鍔″垵濮嬶級
             List<Short> list = Arrays.asList(AsnExceStatus.ASN_EXCE_STATUS_UN_EXCE.val,
                     AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val);
-            WkOrder wkOrder = asnOrderService.getOne(new LambdaQueryWrapper<WkOrder>()
-                    .in(WkOrder::getExceStatus, list)
-                    .eq(WkOrder::getCode, order.getOrderNo()));
-            if (Objects.isNull(wkOrder)) {
-                throw new CoolException("璁㈠崟锛�" + wkOrder.getCode() + "锛屽綋鍓嶇姸鎬侊紝涓嶅彲鎵ц鍒犻櫎鎿嶄綔锛侊紒");
+            if (!list.contains(finalWkOrder.getExceStatus())) {
+                throw new CoolException("浠呮湭鎵ц鐘舵�佺殑鍗曟嵁鍙彇娑堬紒锛�");
             }
             order.getOrderItems().forEach(orderItem -> {
                 if (!asnOrderItemService.remove(new LambdaQueryWrapper<WkOrderItem>()
                         .eq(WkOrderItem::getMatnrCode, orderItem.getMatnr())
                         .eq(StringUtils.isNotEmpty(orderItem.getBatch()), WkOrderItem::getSplrBatch, orderItem.getBatch())
                         .eq(StringUtils.isNotEmpty(orderItem.getPlatItemId()), WkOrderItem::getPlatItemId, orderItem.getPlatItemId())
-                        .eq(WkOrderItem::getOrderCode, wkOrder.getCode()))) {
+                        .eq(WkOrderItem::getOrderCode, finalWkOrder.getCode()))) {
                     throw new CoolException("鍗曟嵁鏄庣粏鍒犻櫎澶辫触锛侊紒");
                 }
-                List<WkOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, wkOrder.getId()));
+                List<WkOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, finalWkOrder.getId()));
                 if (orderItems.isEmpty()) {
-                    if (!asnOrderService.removeById(wkOrder.getId())) {
+                    if (!asnOrderService.removeById(finalWkOrder.getId())) {
                         throw new CoolException("鍗曟嵁鍒犻櫎澶辫触锛侊紒");
                     }
                 } else {
-                    Double sum = orderItems.stream().mapToDouble(WkOrderItem::getAnfme).sum();
+                    Double sum = QuantityUtils.roundToScale(orderItems.stream().mapToDouble(WkOrderItem::getAnfme).sum());
                     if (!asnOrderService.update(new LambdaUpdateWrapper<WkOrder>()
-                            .eq(WkOrder::getId, wkOrder.getId())
+                            .eq(WkOrder::getId, finalWkOrder.getId())
                             .set(WkOrder::getAnfme, sum))) {
                         throw new CoolException("涓诲崟鏁伴噺淇敼澶辫触锛侊紒");
                     }

--
Gitblit v1.9.1