From db91e03deeaac1bb3344d0b5cb9e1240f1f8caac Mon Sep 17 00:00:00 2001
From: lty <876263681@qq.com>
Date: 星期六, 16 八月 2025 10:39:15 +0800
Subject: [PATCH] #计划组货单下发上报

---
 src/main/java/com/zy/asrs/controller/OutController.java |   30 ++++++++++++++++++++++++------
 1 files changed, 24 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OutController.java b/src/main/java/com/zy/asrs/controller/OutController.java
index 862bff4..379b1a9 100644
--- a/src/main/java/com/zy/asrs/controller/OutController.java
+++ b/src/main/java/com/zy/asrs/controller/OutController.java
@@ -5,6 +5,7 @@
 import com.core.common.*;
 import com.core.exception.CoolException;
 import com.zy.asrs.entity.*;
+import com.zy.asrs.entity.param.PakoutRequest;
 import com.zy.asrs.entity.param.StockOutParam;
 import com.zy.asrs.service.*;
 import com.zy.common.model.LocDetlDto;
@@ -55,7 +56,12 @@
         Thread.sleep(200);
         return R.ok().add(orderDetlService.selectByOrderId(orderId).stream().map(OrderDetl::getId).distinct().collect(Collectors.toList()));
     }
-
+    @PostMapping("/getMesOrder/auth")
+    @ManagerAuth
+    public R getMesOrder() {
+        List<String> orderNoList = orderService.getOrderNosByDocType(25L);
+        return R.ok().add(orderNoList);
+    }
     @PostMapping("/out/pakout/preview/auth")
     @ManagerAuth
     public R pakoutPreview(@RequestBody List<Long> ids) {
@@ -77,7 +83,11 @@
 
         // 鎸夊寘瑁呯粍鍙峰垎缁勫鐞�
         Map<String, List<OrderDetl>> brandGroup = orderDetls.stream()
-                .collect(Collectors.groupingBy(OrderDetl::getBrand));
+                .collect(Collectors.groupingBy(o -> {
+                    String brand = o.getBrand();
+                    return brand != null ? brand : "璺ㄥ贩閬�";
+                }));
+
 
         List<LocDto> locDtos = new ArrayList<>();
 
@@ -155,7 +165,9 @@
 
     @PostMapping("/out/pakout/auth")
     @ManagerAuth(memo = "璁㈠崟鍑哄簱")
-    public synchronized R pakout(@RequestBody List<LocDto> locDtos) throws InterruptedException {
+    public synchronized R pakout(@RequestBody PakoutRequest request) throws InterruptedException {
+        List<LocDto> locDtos = request.getTableCache();
+        String optionValue = request.getOptionValue();
         if (Cools.isEmpty(locDtos)) {
             return R.parse(BaseRes.PARAM);
         }
@@ -221,11 +233,17 @@
                         .eq("model", paramLocDetl.getModel()));
 
                 if (one != null) {
-                    if (!"鍚堟牸".equals(one.getThreeCode())) {
-                        throw new CoolException(one.getModel() + "鍗蜂笉鍚堟牸: " + one.getThreeCode());
+                    // 鍒ゆ柇鏄惁涓虹洏鐐瑰崟锛坉ocType == 23锛夛紝濡傛灉涓嶆槸鍒欐牎楠屽悎鏍兼��
+                    Order order = orderService.selectByNo(stockOutParam.getOrderNo());
+                    if ( order.getDocType() != 23) {
+                        if (!"鍚堟牸".equals(one.getThreeCode())) {
+                            throw new CoolException(one.getModel() + "鍗蜂笉鍚堟牸: " + one.getThreeCode());
+                        }
                     }
+
                     locDetlDtos.add(new LocDetlDto(one, paramLocDetl.getCount(), stockOutParam.getOrderNo()));
                 }
+
             }
 
             if (!locDetlDtos.isEmpty()) {
@@ -236,7 +254,7 @@
                     workService.stockOut(staNo, locDetlDtos,
                             order.getDocType() != null && order.getDocType() == 23
                                     ? IoWorkType.CHECK_OUT : null,
-                            getUserId());
+                            getUserId(),optionValue);
                 } else {
                     throw new CoolException("鎵�閫夊簱浣嶇姸鎬佷笉涓篎/D锛屽簱浣嶅彿锛�" +
                             locMast.getLocNo() + "锛屽綋鍓嶇姸鎬侊細" +

--
Gitblit v1.9.1