From e88ffe14edd443f397e1f4b53420bebaa207d464 Mon Sep 17 00:00:00 2001
From: zhou zhou <3272660260@qq.com>
Date: 星期五, 12 十二月 2025 15:07:49 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java | 1273 +++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 1,055 insertions(+), 218 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
index 3648224..e03869e 100644
--- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
@@ -6,11 +6,15 @@
 import com.baomidou.mybatisplus.mapper.Wrapper;
 import com.core.common.*;
 import com.core.exception.CoolException;
+import com.zy.api.enums.MatLocType;
+import com.zy.api.enums.MatType;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.entity.param.*;
+import com.zy.asrs.entity.result.FindLocNoAttributeVo;
 import com.zy.asrs.entity.result.ForwardAGVTaskDTO;
 import com.zy.asrs.entity.result.HIKApiDTO;
 import com.zy.asrs.entity.result.HIKResultDTO;
+import com.zy.asrs.enums.*;
 import com.zy.asrs.enums.LocAreaType;
 import com.zy.asrs.enums.LocStsType;
 import com.zy.asrs.mapper.LocMastMapper;
@@ -22,7 +26,10 @@
 import com.zy.common.constant.MesConstant;
 import com.zy.common.entity.Parameter;
 import com.zy.common.model.DetlDto;
+import com.zy.common.model.LocTypeDto;
 import com.zy.common.model.MesCombParam;
+import com.zy.common.model.StartupDto;
+import com.zy.common.model.enums.IoWorkType;
 import com.zy.common.model.enums.WorkNoType;
 import com.zy.common.service.CommonService;
 import com.zy.common.utils.HttpHandler;
@@ -36,6 +43,7 @@
 import java.math.BigDecimal;
 import java.math.RoundingMode;
 import java.util.*;
+import java.util.concurrent.atomic.AtomicReference;
 import java.util.stream.Collectors;
 
 /**
@@ -120,11 +128,15 @@
     private BasContainerService basContainerService;
     @Autowired
     private BasAreasService basAreasService;
+    @Autowired
+    private StationRelaService stationRelaService;
+    @Autowired
+    private BasStationDetlService basStationDetlService;
 
     @Override
     @Transactional
     public R WarehouseOutPickMergeV1(WarehouseOutPickMergeParam param, Long hostId, Long userId) {
-        //鍒ゆ柇搴撲綅鐘舵��
+        // 鍒ゆ柇搴撲綅鐘舵��
         LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", param.getLocNo()));
         if (Cools.isEmpty(locMast)) {
             return R.error("璇ュ簱浣嶄笉瀛樺湪");
@@ -193,7 +205,10 @@
                 if (Cools.isEmpty(order)) {
                     continue;
                 }
-                OrderDetlPakin orderDetlPakin = orderDetlPakinService.selectItem(order.getId(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getBrand(), orderDetl.getStandby1(), orderDetl.getStandby2(), orderDetl.getStandby3(), orderDetl.getBoxType1(), orderDetl.getBoxType2(), orderDetl.getBoxType3());
+                OrderDetlPakin orderDetlPakin = orderDetlPakinService.selectItem(order.getId(), orderDetl.getMatnr(),
+                        orderDetl.getBatch(), orderDetl.getBrand(), orderDetl.getStandby1(), orderDetl.getStandby2(),
+                        orderDetl.getStandby3(), orderDetl.getBoxType1(), orderDetl.getBoxType2(),
+                        orderDetl.getBoxType3());
                 if (Cools.isEmpty(orderDetlPakin)) {
                     continue;
                 }
@@ -201,8 +216,11 @@
                     throw new CoolException("骞舵澘鏁伴噺鍑洪敊,璁㈠崟鍓╀綑鍑哄簱鏁伴噺灏忎簬宸插嚭搴撴暟閲忎笌灏嗗苟鏉挎暟閲忎箣鍜岋紒锛侊紒");
                 }
                 // 淇敼璁㈠崟鏄庣粏浣滀笟鏁伴噺
-                if (!orderDetlPakinService.increaseWorkQty(orderDetlPakin.getOrderId(), orderDetlPakin.getMatnr(), orderDetlPakin.getBatch(), orderDetlPakin.getBrand(),
-                        orderDetlPakin.getStandby1(), orderDetlPakin.getStandby2(), orderDetlPakin.getStandby3(), orderDetlPakin.getBoxType1(), orderDetlPakin.getBoxType2(), orderDetlPakin.getBoxType3(), orderDetl.getAnfme())) {
+                if (!orderDetlPakinService.increaseWorkQty(orderDetlPakin.getOrderId(), orderDetlPakin.getMatnr(),
+                        orderDetlPakin.getBatch(), orderDetlPakin.getBrand(),
+                        orderDetlPakin.getStandby1(), orderDetlPakin.getStandby2(), orderDetlPakin.getStandby3(),
+                        orderDetlPakin.getBoxType1(), orderDetlPakin.getBoxType2(), orderDetlPakin.getBoxType3(),
+                        orderDetl.getAnfme())) {
                     throw new CoolException("淇敼鍗曟嵁鏄庣粏宸ヤ綔鏁伴噺澶辫触");
                 }
 
@@ -238,17 +256,17 @@
             return R.error("绔欑偣涓嶅瓨鍦�");
         }
         OrderDetlPakin orderDetlPakin = null;
-        //妫�楠屼紶鍙傛槸鍚﹀拰璁㈠崟鏄庣粏鍖归厤
+        // 妫�楠屼紶鍙傛槸鍚﹀拰璁㈠崟鏄庣粏鍖归厤
         for (PickMatParam matParam : param.getList()) {
-            orderDetlPakin = orderDetlPakinService.selectItem
-                    (matParam.getOrderNo(), matParam.getMatnr(), matParam.getBatch(), matParam.getBrand(),
-                            matParam.getStandby1(), matParam.getStandby2(), matParam.getStandby3(),
-                            matParam.getBoxType1(), matParam.getBoxType2(), matParam.getBoxType3());
+            orderDetlPakin = orderDetlPakinService.selectItem(matParam.getOrderNo(), matParam.getMatnr(),
+                    matParam.getBatch(), matParam.getBrand(),
+                    matParam.getStandby1(), matParam.getStandby2(), matParam.getStandby3(),
+                    matParam.getBoxType1(), matParam.getBoxType2(), matParam.getBoxType3());
             if (orderDetlPakin == null) {
                 return R.error("鐗╂枡鏁版嵁涓嶅瓨鍦�");
             }
 
-            //鍓╀綑鍙敤鏁伴噺
+            // 鍓╀綑鍙敤鏁伴噺
             double count = orderDetlPakin.getAnfme() - orderDetlPakin.getWorkQty();
             if (matParam.getCount() != count) {
                 return R.error("鐗╂枡鏁版嵁宸茶繃鏈�");
@@ -314,14 +332,15 @@
                 throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
             }
 
-            //鏇存柊璁㈠崟宸ヤ綔鏁伴噺
+            // 鏇存柊璁㈠崟宸ヤ綔鏁伴噺
             orderDetlPakinService.increaseWorkQty(orderDetlPakin.getOrderId(), matParam.getMatnr(),
-                    matParam.getBatch(), matParam.getBrand(), matParam.getStandby1(), matParam.getStandby2(), matParam.getStandby3(),
+                    matParam.getBatch(), matParam.getBrand(), matParam.getStandby1(), matParam.getStandby2(),
+                    matParam.getStandby3(),
                     matParam.getBoxType1(), matParam.getBoxType2(), matParam.getBoxType3(), matParam.getUseCount());
             // 鏇存柊宸ヤ綔妗g姸鎬�
             orderPakinService.updateSettle(orderDetlPakin.getOrderId(), 2L, userId);
         }
-        // 淇敼搴撲綅鐘舵��:   F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
+        // 淇敼搴撲綅鐘舵��: F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
         locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", param.getLocNo()));
         if (locMast.getLocSts().equals("F")) {
             locMast.setLocSts("P");
@@ -340,7 +359,7 @@
     @Override
     @Transactional
     public R WarehouseOutV1(CombParam combParam, Long hostId, Long userId) {
-        //鍒ゆ柇搴撲綅鐘舵��
+        // 鍒ゆ柇搴撲綅鐘舵��
         LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", combParam.getLocNo()));
         if (Cools.isEmpty(locMast)) {
             return R.error("璇ュ簱浣嶄笉瀛樺湪");
@@ -348,12 +367,11 @@
         if (!locMast.getLocSts().equals("P")) {
             return R.error("璇ュ簱浣嶇姸鎬佷负锛�" + locMast.getLocSts() + ",涓嶆弧瓒冲苟鏉块�斾腑鎷i�夋潯浠讹紒锛侊紒");
         }
-        //鏌ヨ搴撳瓨鏁版嵁
+        // 鏌ヨ搴撳瓨鏁版嵁
         for (CombParam.CombMat combMat : combParam.getCombMats()) {
             List<LocDetl> locDetlList = locDetlService.selectList(new EntityWrapper<LocDetl>()
                     .eq("loc_no", combParam.getLocNo())
-                    .eq("matnr", combMat.getMatnr())
-            );
+                    .eq("matnr", combMat.getMatnr()));
             if (locDetlList.isEmpty()) {
                 return R.error("鏈煡璇㈠埌搴撳瓨鏁版嵁");
             }
@@ -372,8 +390,10 @@
                 if (orderPakout.getSettle() == 1) {
                     OrderInAndOutUtil.updateOrder(false, orderPakout.getId(), 2L, 9527L);
                 }
-                OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(orderPakout.getId(), combMat.getMatnr(), combMat.getBatch(),
-                        combMat.getBrand(), combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(), combMat.getBoxType1(), combMat.getBoxType2(), combMat.getBoxType3());
+                OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(orderPakout.getId(),
+                        combMat.getMatnr(), combMat.getBatch(),
+                        combMat.getBrand(), combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(),
+                        combMat.getBoxType1(), combMat.getBoxType2(), combMat.getBoxType3());
                 if (Cools.isEmpty(orderDetlPakout)) {
                     continue;
                 }
@@ -381,17 +401,22 @@
                     throw new CoolException("鎷i�夋暟閲忓嚭閿�,璁㈠崟鍓╀綑鍑哄簱鏁伴噺灏忎簬宸插嚭搴撴暟閲忎笌灏嗘嫞閫夋暟閲忎箣鍜岋紒锛侊紒");
                 }
                 // 淇敼璁㈠崟鏄庣粏浣滀笟鏁伴噺
-                if (!orderDetlPakoutService.increaseWorkQty(orderDetlPakout.getOrderId(), combMat.getMatnr(), combMat.getBatch(), combMat.getBrand(),
-                        combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(), combMat.getBoxType1(), combMat.getBoxType2(), combMat.getBoxType3(), combMat.getAnfme())) {
+                if (!orderDetlPakoutService.increaseWorkQty(orderDetlPakout.getOrderId(), combMat.getMatnr(),
+                        combMat.getBatch(), combMat.getBrand(),
+                        combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(), combMat.getBoxType1(),
+                        combMat.getBoxType2(), combMat.getBoxType3(), combMat.getAnfme())) {
                     throw new CoolException("淇敼鍗曟嵁鏄庣粏宸ヤ綔鏁伴噺澶辫触");
                 }
-//                // 淇敼璁㈠崟鏄庣粏瀹屾垚鏁伴噺
-//                if (!orderDetlPakoutService.increase(orderPakout.getId(),combMat.getMatnr(), combMat.getBatch(), combMat.getBrand(),
-//                        combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(), combMat.getBoxType1(), combMat.getBoxType2(), combMat.getBoxType3(),combMat.getAnfme())) {
-//                    throw new CoolException("淇敼鍗曟嵁鏄庣粏瀹屾垚鏁伴噺澶辫触");
-//                }
-//                // 淇敼璁㈠崟鐘舵�� 浣滀笟涓� ===>> 宸插畬鎴�
-//                orderPakoutService.checkComplete(combMat.getOrderNo());
+                // // 淇敼璁㈠崟鏄庣粏瀹屾垚鏁伴噺
+                // if (!orderDetlPakoutService.increase(orderPakout.getId(),combMat.getMatnr(),
+                // combMat.getBatch(), combMat.getBrand(),
+                // combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(),
+                // combMat.getBoxType1(), combMat.getBoxType2(),
+                // combMat.getBoxType3(),combMat.getAnfme())) {
+                // throw new CoolException("淇敼鍗曟嵁鏄庣粏瀹屾垚鏁伴噺澶辫触");
+                // }
+                // // 淇敼璁㈠崟鐘舵�� 浣滀笟涓� ===>> 宸插畬鎴�
+                // orderPakoutService.checkComplete(combMat.getOrderNo());
             }
             try {
                 Date now = new Date();
@@ -500,8 +525,7 @@
             List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>()
                     .like("barcode", barcode)
                     .eq("wrk_sts", 199L)
-                    .eq("io_type", 103)
-            );
+                    .eq("io_type", 103));
             wrkMastArrayList.addAll(wrkMasts);
             List<WrkMast> wrkMasts1 = wrkMastService.selectList(new EntityWrapper<WrkMast>()
                     .like("barcode", barcode)
@@ -530,7 +554,7 @@
             orderIds.add(order.getId());
         }
 
-        //鎼滅储鏄庣粏
+        // 鎼滅储鏄庣粏
         Wrapper<OrderDetl> wrapper1 = new EntityWrapper<>();
         wrapper1.eq("status", 1);
         wrapper1.in("order_id", orderIds);
@@ -545,7 +569,7 @@
 
         ArrayList<PickMatParam> maps = new ArrayList<>();
         for (OrderDetl orderDetl : list) {
-            //鍓╀綑鍙敤鏁伴噺
+            // 鍓╀綑鍙敤鏁伴噺
             double count = orderDetl.getAnfme() - orderDetl.getWorkQty();
             if (count <= 0) {
                 continue;
@@ -573,19 +597,26 @@
             throw new CoolException("璇锋彁鍙栦竴涓晢鍝侊紝鎴栬�呭埛鏂伴噸鏂扮粍鎵橈紒");
         }
         // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁
-        if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>().
-                eq("zpallet", param.getBarcode())
+        if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode())
                 .eq("io_status", "N")) > 0) {
             throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱");
         }
 
-        if (param.getBarcode().length() != 8) {
-            throw new CoolException("鏉$爜闀垮害涓嶆槸8浣�===>>" + param.getBarcode());
+        if (Objects.isNull(param.getBarcode())) {
+            throw new CoolException("鎵樼洏鐮佷笉鑳戒负绌猴紒锛�");
         }
+        // if (param.getBarcode().length() != 8) {
+        // throw new CoolException("鏉$爜闀垮害涓嶆槸8浣�===>>" + param.getBarcode());
+        // }
 
+        if (Objects.isNull(param.getType())) {
+            param.setType("0");
+        }
         int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet", param.getBarcode()));
         int countWrk = wrkDetlService.selectCount(new EntityWrapper<WrkDetl>().eq("zpallet", param.getBarcode()));
-        int countwait = waitPakinService.selectCount(new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode()));
+        int countwait = waitPakinService.selectCount(new EntityWrapper<WaitPakin>()
+                .eq(!Objects.isNull(param.getType()), "type", param.getType())
+                .eq("zpallet", param.getBarcode()));
         if (countLoc > 0 || countWrk > 0 || countwait > 0) {
             throw new CoolException("缁勬墭妗�/宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode());
         }
@@ -596,8 +627,10 @@
             // 鐢熸垚鍏ュ簱閫氱煡妗�
             List<DetlDto> detlDtos = new ArrayList<>();
             param.getCombMats().forEach(elem -> {
-                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
-                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme());
+                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(),
+                        elem.getStandby2(), elem.getStandby3(),
+                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme(),
+                        elem.getThreeCode());
                 if (DetlDto.has(detlDtos, detlDto)) {
                     DetlDto one = DetlDto.findDto(detlDtos, detlDto);
                     assert one != null;
@@ -621,7 +654,15 @@
                 waitPakin.setZpallet(param.getBarcode());
                 waitPakin.setIoStatus("N");
                 waitPakin.setAnfme(detlDto.getAnfme());
+                waitPakin.setThreeCode(detlDto.getThreeCode());
                 waitPakin.setStatus("Y");
+                waitPakin.setSuppCode(detlDto.getStandby1());
+                waitPakin.setStandby1(detlDto.getStandby1());
+                waitPakin.setStandby2(detlDto.getStandby2());
+                waitPakin.setStandby3(detlDto.getStandby3());
+                waitPakin.setBoxType1(detlDto.getBoxType1());
+                waitPakin.setBoxType2(detlDto.getBoxType2());
+                waitPakin.setBoxType3(detlDto.getBoxType3());
                 waitPakin.setAppeUser(userId);
                 waitPakin.setAppeTime(now);
                 waitPakin.setModiUser(userId);
@@ -632,7 +673,7 @@
             }
             // 鍏宠仈缁勬墭
         } else {
-//            Order order = orderService.selectByNo(param.getOrderNo());
+            // Order order = orderService.selectByNo(param.getOrderNo());
             // 鐢熸垚鍏ュ簱閫氱煡妗�
             List<DetlDto> detlDtos = new ArrayList<>();
             param.getCombMats().forEach(elem -> {
@@ -641,8 +682,10 @@
                     throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�");
                 }
                 // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙
-//                OrderDetl orderDetl = OrderInAndOutUtil.selectItem(Boolean.TRUE, order.getId(), elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
-//                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3());
+                // OrderDetl orderDetl = OrderInAndOutUtil.selectItem(Boolean.TRUE,
+                // order.getId(), elem.getMatnr(), elem.getBatch(), elem.getBrand(),
+                // elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
+                // elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3());
                 OrderDetlPakin detls = orderDetlPakinService.selectOne(new EntityWrapper<OrderDetlPakin>()
                         .eq("order_id", order.getId())
                         .eq("matnr", elem.getMatnr()));
@@ -652,12 +695,15 @@
                 }
 
                 if (elem.getAnfme() > detls.getEnableQty()) {
-                    throw new CoolException(detls.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�");
+                    throw new CoolException(detls.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎瑙勫垯");
                 }
-                OrderInAndOutUtil.increaseWorkQty(Boolean.TRUE, order.getId(), elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
+                OrderInAndOutUtil.increaseWorkQty(Boolean.TRUE, order.getId(), elem.getMatnr(), elem.getBatch(),
+                        elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
                         elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme());
-                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
-                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme());
+                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(),
+                        elem.getStandby2(), elem.getStandby3(),
+                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme(),
+                        elem.getThreeCode());
                 detlDto.setOrderId(order.getId());
                 detlDto.setOrderNo(order.getOrderNo());
                 if (DetlDto.has(detlDtos, detlDto)) {
@@ -669,49 +715,55 @@
                 }
             });
 
-            BasContainer container = basContainerService.selectOne(new EntityWrapper<BasContainer>().eq("barcode", param.getBarcode()));
-            if (Objects.isNull(container)) {
-                throw new CoolException("鏁版嵁閿欒锛氬鍣ㄧ爜涓嶅瓨鍦紒锛�");
-            }
-            if (container.getMixMax() < detlDtos.size()) {
-                throw new CoolException("瓒呭嚭瀹瑰櫒鏈�澶ф贩瑁呮暟閲忥紝褰撳墠瀹瑰櫒鏈�澶ф暟閲忎负锛�" + container.getMixMax() + "!!");
-            }
             Set<String> matnrs = detlDtos.stream().map(DetlDto::getMatnr).collect(Collectors.toSet());
             List<Mat> mats = matService.selectList(new EntityWrapper<Mat>().in("matnr", matnrs));
             Set<Long> tagIds = mats.stream().map(Mat::getTagId).collect(Collectors.toSet());
             if (tagIds.size() > 1) {
                 throw new CoolException("缁勬墭鐗╂枡绫诲瀷涓嶄竴鑷达紝鍙湁鐩稿悓鐨勭墿鏂欏垎绫绘墠鍙互缁勬墭锛侊紒");
             }
-            //杩樺彲浠ユ斁鍏ュ灏戠鐗╂枡
-            Integer suplus = container.getMixMax();
+
+            // BasContainer container = basContainerService.selectOne(new
+            // EntityWrapper<BasContainer>().eq("barcode", param.getBarcode()));
+            // if (Objects.isNull(container)) {
+            // throw new CoolException("鏁版嵁閿欒锛氬鍣ㄧ爜涓嶅瓨鍦紒锛�");
+            // }
+            // if (container.getMixMax() < detlDtos.size()) {
+            // throw new CoolException("瓒呭嚭瀹瑰櫒鏈�澶ф贩瑁呮暟閲忥紝褰撳墠瀹瑰櫒鏈�澶ф暟閲忎负锛�" + container.getMixMax() +
+            // "!!");
+            // }
+            // 杩樺彲浠ユ斁鍏ュ灏戠鐗╂枡
+            // Integer suplus = container.getMixMax();
             for (DetlDto detlDto : detlDtos) {
                 Mat mat = matService.selectByMatnr(detlDto.getMatnr());
                 if (Cools.isEmpty(mat)) {
                     throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
                 }
-                //鏈�澶氬彲鏀炬暟閲�
-                Double singleMax = mat.getUpQty() * suplus;
-                if (singleMax.compareTo(detlDto.getAnfme()) < 0) {
-                    throw new CoolException("鐗╂枡锛�" + detlDto.getMatnr() + "鍗曟缁勬墭涓婇檺涓猴細" + mat.getUpQty() + ",褰撳墠鎬婚噺瓒呭嚭鎵樼洏瑁呰浇涓婇檺!!");
-                }
-                BigDecimal decimal = new BigDecimal(detlDto.getAnfme() / mat.getUpQty());
-                //褰撳墠鐗╂枡闇�瑕佸崰鐢ㄦ枡绠辨牸鏁�
-                Integer curr = decimal.setScale(0, RoundingMode.CEILING).intValue();
-                suplus = suplus - curr;
-                if (suplus < 0) {
-                    throw new CoolException("鐗╂枡锛�" + detlDto.getMatnr() + ", 瓒呭嚭褰撳墠鎵樼洏瑁呰浇涓婇檺锛侊紒");
-                }
+                // //鏈�澶氬彲鏀炬暟閲�
+                // Double singleMax = mat.getUpQty() * suplus;
+                // if (singleMax.compareTo(detlDto.getAnfme()) < 0) {
+                // throw new CoolException("鐗╂枡锛�" + detlDto.getMatnr() + "鍗曟缁勬墭涓婇檺涓猴細" +
+                // mat.getUpQty() + ",褰撳墠鎬婚噺瓒呭嚭鎵樼洏瑁呰浇涓婇檺!!");
+                // }
+                // BigDecimal decimal = new BigDecimal(detlDto.getAnfme() / mat.getUpQty());
+                // //褰撳墠鐗╂枡闇�瑕佸崰鐢ㄦ枡绠辨牸鏁�
+                // Integer curr = decimal.setScale(0, RoundingMode.CEILING).intValue();
+                // suplus = suplus - curr;
+                // if (suplus < 0) {
+                // throw new CoolException("鐗╂枡锛�" + detlDto.getMatnr() + ", 瓒呭嚭褰撳墠鎵樼洏瑁呰浇涓婇檺锛侊紒");
+                // }
 
                 WaitPakin waitPakin = new WaitPakin();
                 BeanUtils.copyProperties(mat, waitPakin);
-//                waitPakin.sync(mat);
-                waitPakin.setOrderNo(detlDto.getOrderNo());   // 鍗曟嵁缂栧彿
+                waitPakin.setOrderNo(detlDto.getOrderNo()); // 鍗曟嵁缂栧彿
+                waitPakin.setType(param.getType());
                 waitPakin.setOrderId(detlDto.getOrderId());
-                waitPakin.setBatch(detlDto.getBatch());     // 搴忓垪鐮�
-                waitPakin.setZpallet(param.getBarcode());   // 鎵樼洏鐮�
-                waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
-                waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
-                waitPakin.setStatus("Y");    // 鐘舵��
+                waitPakin.setBatch(detlDto.getBatch()); // 搴忓垪鐮�
+                waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮�
+                waitPakin.setThreeCode(detlDto.getThreeCode());
+                waitPakin.setSuppCode(detlDto.getStandby1());
+                waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵��
+                waitPakin.setAnfme(detlDto.getAnfme()); // 鏁伴噺
+                waitPakin.setStatus("Y"); // 鐘舵��
                 waitPakin.setAppeUser(userId);
                 waitPakin.setAppeTime(now);
                 waitPakin.setModiUser(userId);
@@ -721,7 +773,8 @@
                 }
             }
 
-            Set<String> stringSet = param.getCombMats().stream().map(CombParam.CombMat::getOrderNo).collect(Collectors.toSet());
+            Set<String> stringSet = param.getCombMats().stream().map(CombParam.CombMat::getOrderNo)
+                    .collect(Collectors.toSet());
             stringSet.forEach(orderNo -> {
                 Order order = OrderInAndOutUtil.selectByNo(Boolean.TRUE, orderNo);
                 OrderInAndOutUtil.updateOrder(Boolean.TRUE, order.getId(), 2L, userId);
@@ -751,7 +804,7 @@
                 throw new CoolException(combMat.getMatnr() + ":鍟嗗搧鏁伴噺鏈夎锛�");
             }
             if (Cools.isEmpty(combMat.getBatch())) {
-//                throw new CoolException(combMat.getMatnr() + ":鍟嗗搧鎵瑰彿鏈夎锛�");
+                // throw new CoolException(combMat.getMatnr() + ":鍟嗗搧鎵瑰彿鏈夎锛�");
             }
             ManLocDetl manLocDetl = new ManLocDetl();
             manLocDetl.setLocNo(locno);
@@ -785,7 +838,6 @@
 
     // 鏌ユ壘鍟嗗搧
 
-
     @Override
     @Transactional
     public void adjust(MobileAdjustParam param, Long userId) {
@@ -815,12 +867,15 @@
                 if (wrkDetl1.getAnfme() == 0) {
                     iterator1.remove();
                 }
-                if (wrkDetl.getMatnr().equals(wrkDetl1.getMatnr()) && Cools.eq(wrkDetl.getBatch(), wrkDetl1.getBatch())) {
+                if (wrkDetl.getMatnr().equals(wrkDetl1.getMatnr())
+                        && Cools.eq(wrkDetl.getBatch(), wrkDetl1.getBatch())) {
                     if (!wrkDetl.getAnfme().equals(wrkDetl1.getAnfme())) {
                         // todo 鐩樼偣璁板綍銆佷繚瀛樿皟鏁磋褰�
                         // 淇敼鏄庣粏
-                        if (!wrkDetlService.updateAnfme(wrkDetl1.getAnfme(), wrkMast.getWrkNo(), wrkDetl.getMatnr(), wrkDetl.getBatch())) {
-                            throw new CoolException(wrkMast.getWrkNo() + "鐩樼偣浠诲姟锛�" + wrkDetl.getMatnr() + "鍟嗗搧锛�" + wrkDetl.getBatch() + "鎵瑰彿淇敼鏁伴噺澶辫触");
+                        if (!wrkDetlService.updateAnfme(wrkDetl1.getAnfme(), wrkMast.getWrkNo(), wrkDetl.getMatnr(),
+                                wrkDetl.getBatch())) {
+                            throw new CoolException(wrkMast.getWrkNo() + "鐩樼偣浠诲姟锛�" + wrkDetl.getMatnr() + "鍟嗗搧锛�"
+                                    + wrkDetl.getBatch() + "鎵瑰彿淇敼鏁伴噺澶辫触");
                         }
                     }
                     iterator.remove();
@@ -833,7 +888,8 @@
         for (WrkDetl wrkDetl : wrkDetls) {
             // todo 鐩樼偣璁板綍銆佷繚瀛樿皟鏁磋褰�
             if (!wrkDetlService.updateAnfme(-1.0D, wrkMast.getWrkNo(), wrkDetl.getMatnr(), wrkDetl.getBatch())) {
-                throw new CoolException("鍒犻櫎" + wrkMast.getWrkNo() + "鐩樼偣浠诲姟锛�" + wrkDetl.getMatnr() + "鍟嗗搧锛�" + wrkDetl.getBatch() + "鎵瑰彿浠诲姟鏄庣粏澶辫触");
+                throw new CoolException("鍒犻櫎" + wrkMast.getWrkNo() + "鐩樼偣浠诲姟锛�" + wrkDetl.getMatnr() + "鍟嗗搧锛�"
+                        + wrkDetl.getBatch() + "鎵瑰彿浠诲姟鏄庣粏澶辫触");
             }
         }
 
@@ -852,7 +908,8 @@
             wrkDetl.setAppeTime(now);
             wrkDetl.setAppeUser(userId);
             if (!wrkDetlService.insert(wrkDetl)) {
-                throw new CoolException("娣诲姞" + wrkMast.getWrkNo() + "鐩樼偣浠诲姟锛�" + wrkDetl.getMatnr() + "鍟嗗搧锛�" + wrkDetl.getBatch() + "鎵瑰彿浠诲姟鏄庣粏澶辫触");
+                throw new CoolException("娣诲姞" + wrkMast.getWrkNo() + "鐩樼偣浠诲姟锛�" + wrkDetl.getMatnr() + "鍟嗗搧锛�"
+                        + wrkDetl.getBatch() + "鎵瑰彿浠诲姟鏄庣粏澶辫触");
             }
         }
 
@@ -873,8 +930,8 @@
             throw new CoolException(BaseRes.PARAM);
         }
         // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁
-        if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>().
-                eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) {
+        if (waitPakinService.selectCount(
+                new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) {
             throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱");
         }
         Date now = new Date();
@@ -899,11 +956,15 @@
                 }
                 Mat analyse = MatUtils.analyseMat(elem.getMatnr());
                 // 鏉$爜銆佺墿鏂欎唬鐮併�佸簭鍒楀彿銆佹暟閲�
-                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), analyse.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(),
-                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme());
+                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), analyse.getBrand(), elem.getStandby1(),
+                        elem.getStandby2(), elem.getStandby3(),
+                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme(),
+                        elem.getThreeCode());
 
-//                DetlDto detlDto = new DetlDto(elem.getMatnr(), analyse.getMatnr(), analyse.getBarcode(), elem.getAnfme());
-//                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme());
+                // DetlDto detlDto = new DetlDto(elem.getMatnr(), analyse.getMatnr(),
+                // analyse.getBarcode(), elem.getAnfme());
+                // DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(),
+                // elem.getAnfme());
                 if (DetlDto.has(detlDtos, detlDto)) {
                     DetlDto one = DetlDto.findDto(detlDtos, detlDto);
                     assert one != null;
@@ -937,10 +998,12 @@
                     if (jsonObject.getInteger("code").equals(200)) {
                         success = true;
                     } else if (jsonObject.getInteger("code").equals(500)) {
-                        log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL + MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response);
+                        log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL + MesConstant.PACK_DOWN_URL,
+                                JSON.toJSONString(mesCombParam), response);
                         throw new CoolException(jsonObject.getString("msg"));
                     } else {
-                        log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL + MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response);
+                        log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL + MesConstant.PACK_DOWN_URL,
+                                JSON.toJSONString(mesCombParam), response);
                         throw new CoolException("涓婃姤mes绯荤粺澶辫触");
                     }
                 } catch (Exception e) {
@@ -956,8 +1019,7 @@
                                 "127.0.0.1",
                                 JSON.toJSONString(mesCombParam),
                                 response,
-                                success
-                        );
+                                success);
                     } catch (Exception e) {
                         log.error("", e);
                     }
@@ -972,15 +1034,15 @@
             openParam.setOrderType("鎵撳寘鍏ュ簱鍗�");
             openParam.setOrderDetails(detlDtos);
             openService.pakinOrderCreate(openParam);
-//            Order order = orderService.selectByNo(orderNo);
+            // Order order = orderService.selectByNo(orderNo);
             Order order = OrderInAndOutUtil.selectByNo(Boolean.TRUE, param.getOrderNo());
 
             if (null == order) {
                 throw new CoolException("鐢熸垚鍗曟嵁澶辫触");
             }
-//            if (!orderService.updateSettle(order.getId(), 2L, userId)) {
-//                throw new CoolException("淇敼鍗曟嵁鐘舵�佸け璐�");
-//            }
+            // if (!orderService.updateSettle(order.getId(), 2L, userId)) {
+            // throw new CoolException("淇敼鍗曟嵁鐘舵�佸け璐�");
+            // }
             OrderInAndOutUtil.updateOrder(Boolean.TRUE, order.getId(), 2L, userId);
 
             // 鐢熸垚鍏ュ簱閫氱煡妗�
@@ -988,18 +1050,22 @@
 
                 // 淇敼浣滀笟鏁伴噺 ----------------------------------------
                 // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙
-//                OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), detlDto.getMatnr(), detlDto.getBatch());
-                OrderDetl orderDetl = OrderInAndOutUtil.selectItem(Boolean.TRUE, order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3()
-                        , detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3());
+                // OrderDetl orderDetl = orderDetlService.selectItem(order.getId(),
+                // detlDto.getMatnr(), detlDto.getBatch());
+                OrderDetl orderDetl = OrderInAndOutUtil.selectItem(Boolean.TRUE, order.getId(), detlDto.getMatnr(),
+                        detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(),
+                        detlDto.getStandby3(), detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3());
                 if (detlDto.getAnfme() > orderDetl.getEnableQty()) {
                     throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�");
                 }
                 // 淇敼璁㈠崟浣滀笟鏁伴噺
-//                if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) {
-//                    throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触");
-//                }
-                OrderInAndOutUtil.increaseWorkQty(Boolean.TRUE, order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3()
-                        , detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3(), detlDto.getAnfme());
+                // if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(),
+                // detlDto.getBatch(), detlDto.getAnfme())) {
+                // throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触");
+                // }
+                OrderInAndOutUtil.increaseWorkQty(Boolean.TRUE, order.getId(), detlDto.getMatnr(), detlDto.getBatch(),
+                        detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3(),
+                        detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3(), detlDto.getAnfme());
                 // 淇濆瓨鍏ュ簱閫氱煡妗�
                 Mat mat = matService.selectByMatnr(detlDto.getMatnr());
                 if (Cools.isEmpty(mat)) {
@@ -1009,10 +1075,10 @@
                 BeanUtils.copyProperties(mat, waitPakin);
                 waitPakin.setOrderNo(orderNo);
                 waitPakin.setBatch(detlDto.getBatch());
-                waitPakin.setZpallet(param.getBarcode());   // 鎵樼洏鐮�
-                waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
-                waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
-                waitPakin.setStatus("Y");    // 鐘舵��
+                waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮�
+                waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵��
+                waitPakin.setAnfme(detlDto.getAnfme()); // 鏁伴噺
+                waitPakin.setStatus("Y"); // 鐘舵��
                 waitPakin.setAppeUser(userId);
                 waitPakin.setAppeTime(now);
                 waitPakin.setModiUser(userId);
@@ -1040,25 +1106,27 @@
         String orderNo = param.containsKey("orderNo") ? param.get("orderNo").toString() : "";
 
         BasDevp sta = basDevpService.checkSiteStatus(staNo);
-        //鏍规嵁璁㈠崟鍙风敓鎴愬嚭搴撲换鍔″伐浣滄。
+        // 鏍规嵁璁㈠崟鍙风敓鎴愬嚭搴撲换鍔″伐浣滄。
         Order order = OrderInAndOutUtil.selectByNo(Boolean.FALSE, orderNo);
-//        Order order = orderService.selectOne(new EntityWrapper<Order>().eq("order_no", orderNo));
+        // Order order = orderService.selectOne(new
+        // EntityWrapper<Order>().eq("order_no", orderNo));
         if (order.getSettle() != 1 && order.getSettle() != 2) {
             throw new CoolException("璇ヨ鍗曞凡澶勭悊");
         }
 
-//        List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", orderNo));
+        // List<OrderDetl> orderDetls = orderDetlService.selectList(new
+        // EntityWrapper<OrderDetl>().eq("order_no", orderNo));
         List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(Boolean.FALSE, order.getId());
 
         Date now = new Date();
         for (OrderDetl orderDetl : orderDetls) {
-            //鏌ヨ鎵�鏈夊簱浣嶇姸鎬佷负F鐨勫簱浣嶄俊鎭�
+            // 鏌ヨ鎵�鏈夊簱浣嶇姸鎬佷负F鐨勫簱浣嶄俊鎭�
             List<LocDetl> locDetls = locDetlService.queryStock(orderDetl.getMatnr(), orderDetl.getBatch(), null, null);
             if (locDetls.size() == 0) {
                 throw new CoolException("搴撳瓨涓病鏈夎鐗╂枡");
             }
             for (LocDetl locDetl : locDetls) {
-                //濡傛灉璇ュ簱浣嶅嚭搴撹矾绾挎墍鐢ㄧ殑鍫嗗灈鏈簅ut_enable涓嶄负Y,璺宠繃璇ュ惊鐜�
+                // 濡傛灉璇ュ簱浣嶅嚭搴撹矾绾挎墍鐢ㄧ殑鍫嗗灈鏈簅ut_enable涓嶄负Y,璺宠繃璇ュ惊鐜�
                 LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>()
                         .eq("loc_no", locDetl.getLocNo()));
                 if (Cools.isEmpty(locMast)) {
@@ -1070,23 +1138,24 @@
                     continue;
                 }
 
-                //鍙嚭搴撴暟閲� = 璁㈠崟鏁伴噺 - 浣滀笟涓暟閲�
+                // 鍙嚭搴撴暟閲� = 璁㈠崟鏁伴噺 - 浣滀笟涓暟閲�
                 Double outQty = orderDetl.getAnfme() - orderDetl.getWorkQty();
                 if (outQty <= 0) {
                     break;
                 }
                 // 鍒ゆ柇鍏ュ嚭搴撶被鍨嬶細101.鍏ㄦ澘鍑哄簱 or 103.鎷f枡鍑哄簱
                 Double sumCount = locDetlService.getLocDetlSumQty(locDetl.getLocNo());
-                Double curOutQty = outQty >= locDetl.getAnfme() ? locDetl.getAnfme() : outQty;   //鏈鍑哄簱閲�
+                Double curOutQty = outQty >= locDetl.getAnfme() ? locDetl.getAnfme() : outQty; // 鏈鍑哄簱閲�
                 int ioType = sumCount <= curOutQty ? 101 : 103;
 
                 stockOut(orderDetl, sta, locDetl, curOutQty, ioType, userId, now);
                 order.setSettle(2L);
                 order.setUpdateBy(userId);
                 order.setUpdateTime(now);
-//                if(!orderService.update(order, new EntityWrapper<Order>().eq("order_no", orderNo))){
-//                    throw new CoolException("鏇存柊璁㈠崟鐘舵�佸け璐�");
-//                }
+                // if(!orderService.update(order, new EntityWrapper<Order>().eq("order_no",
+                // orderNo))){
+                // throw new CoolException("鏇存柊璁㈠崟鐘舵�佸け璐�");
+                // }
                 OrderInAndOutUtil.updateOrder(order.getPakinPakoutStatus$(), order.getId(), 2L, userId);
                 orderDetl.setWorkQty(orderDetl.getWorkQty() + curOutQty);
                 orderDetl.setUpdateBy(userId);
@@ -1096,9 +1165,9 @@
                 if (!Cools.isEmpty(orderDetl.getBatch())) {
                     wrapper.eq("batch", orderDetl.getBatch());
                 }
-//                if(!orderDetlService.update(orderDetl, wrapper)){
-//                    throw new CoolException("鏇存柊璁㈠崟鏄庣粏澶辫触");
-//                }
+                // if(!orderDetlService.update(orderDetl, wrapper)){
+                // throw new CoolException("鏇存柊璁㈠崟鏄庣粏澶辫触");
+                // }
                 OrderInAndOutUtil.updateOrderDetl(order.getPakinPakoutStatus$(), order, orderDetl);
 
             }
@@ -1109,7 +1178,7 @@
     @Override
     @Transactional
     public void stockOut(OrderDetl orderDetl, BasDevp staNo, LocDetl locDetl,
-                         Double curOutQty, Integer ioType, Long userId, Date now) {
+            Double curOutQty, Integer ioType, Long userId, Date now) {
         // 鑾峰彇搴撲綅
         LocMast locMast = locMastService.selectById(locDetl.getLocNo());
         // 鑾峰彇璺緞
@@ -1163,7 +1232,7 @@
             throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
         }
 
-        // 淇敼搴撲綅鐘舵��:   F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
+        // 淇敼搴撲綅鐘舵��: F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
         locMast = locMastService.selectById(locDetl.getLocNo());
         if (locMast.getLocSts().equals("F")) {
             locMast.setLocSts(ioType == 101 ? "R" : "P");
@@ -1198,24 +1267,29 @@
      * @version 1.0
      */
     @Override
-    public R callAgvMove(AgvCallParams params, Long userId) {
-        if (Objects.isNull(params.getTarSite())) {
-            throw new CoolException("鐩爣鍙傛暟涓嶈兘涓虹┖锛侊紒");
-        }
+    @Transactional
+    public synchronized R callAgvMove(AgvCallParams params, Long userId) {
         if (Objects.isNull(params.getOrgSite())) {
             throw new CoolException("婧愮珯鐐逛笉鑳戒负绌猴紒锛�");
         }
+        BasAreas basAreas = basAreasService
+                .selectOne(new EntityWrapper<BasAreas>().eq("whs_type_id", LocAreaType.LOC_AREA_TYPE_IN_CACHE.type));
         LocCache locCache = locCacheService.selectOne(new EntityWrapper<LocCache>()
+                .eq("area_id", basAreas.getId())
                 .eq("frozen", 0)
                 .eq("loc_sts", LocStsType.LOC_STS_TYPE_O.type)
-                .eq("loc_no", params.getTarSite())
+                // .eq("loc_no", params.getTarSite())
                 .orderAsc(Arrays.asList("loc_no"))
                 .last("OFFSET 0 ROWS FETCH NEXT 1 ROWS ONLY"));
         if (Objects.isNull(locCache)) {
             throw new CoolException("璇锋鏌ョ洰鏍囧簱浣嶆槸鍚﹂棽缃腑锛侊紒");
         }
 
-        generateAgvTask("agv", locCache, params.getOrgSite(), params.getBarcode(), userId);
+        try {
+            generateAgvTask("agv", locCache, params.getOrgSite(), params.getBarcode(), userId);
+        } catch (Exception e) {
+            throw new CoolException(e.getMessage());
+        }
 
         return R.ok();
     }
@@ -1234,7 +1308,8 @@
         if (Objects.isNull(params.getOrderNo())) {
             throw new CoolException("鍗曞彿涓嶈兘涓虹┖锛侊紒");
         }
-        OrderPakin orderPakin = orderPakinService.selectOne(new EntityWrapper<OrderPakin>().eq("order_no", params.getOrderNo()));
+        OrderPakin orderPakin = orderPakinService
+                .selectOne(new EntityWrapper<OrderPakin>().eq("order_no", params.getOrderNo()));
         if (Objects.isNull(orderPakin)) {
             throw new CoolException("鏁版嵁閿欒锛氬崟鎹笉瀛樺湪锛侊紒");
         }
@@ -1255,30 +1330,62 @@
      * @version 1.0
      */
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public R OutCallAgv(AgvCallParams params, Long userId) {
+
         /**鑾峰彇鍏ュ簱鏈�鏃╃殑涓�鏉℃暟鎹�**/
-        LocCache locCaches = locCacheService.selectOne(new EntityWrapper<LocCache>()
+        List<LocCache> locCaches = locCacheService.selectList(new EntityWrapper<LocCache>()
                 .eq("loc_sts", LocStsType.LOC_STS_TYPE_F.type)
                 .eq("frozen", 0)
-                .orderDesc(Arrays.asList("sort", "first_time"))
-                .last("OFFSET 0 ROWS FETCH NEXT 1 ROWS ONLY"));
-        if (Objects.isNull(locCaches)) {
+                .orderDesc(Arrays.asList("sort", "first_time")));
+
+        if (locCaches.isEmpty()) {
             throw new CoolException("鏆傛棤婊¤冻闇�姹傚簱浣嶏紒");
         }
-        BasStation station = basStationService.selectOne(new EntityWrapper<BasStation>()
-                .eq("loc_sts", LocStsType.LOC_STS_TYPE_O.type)
-                .eq("dev_no", params.getTarSite()));
-        if (Objects.isNull(station)) {
-            throw new CoolException("绔欑偣姝e湪鎵ц浠诲姟锛侊紒");
+
+        for (LocCache locCache : locCaches) {
+            //鑾峰彇缂撳瓨鍖轰俊鎭�
+            BasAreas basAreas = basAreasService.selectOne(new EntityWrapper<BasAreas>().eq("whs_type_id", LocAreaType.LOC_AREA_TYPE_IN_CACHE.type));
+            if (Objects.isNull(basAreas)) {
+                throw new CoolException("搴撳尯涓嶅瓨鍦紒锛�");
+            }
+
+            List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>()
+                    .eq("area_id", basAreas.getId())
+                    .eq("loc_no", locCache.getLocNo()));
+            if (Objects.isNull(locDetls) || locDetls.isEmpty()) {
+                throw new CoolException("搴撳瓨鏄庣粏涓嶅瓨鍦紒锛�");
+            }
+
+            Set<String> set = locDetls.stream().map(LocDetl::getMatnr).collect(Collectors.toSet());
+            List<Mat> matList = matService.selectList(new EntityWrapper<Mat>().in("matnr", set));
+            if (Objects.isNull(matList) || matList.isEmpty()) {
+                throw new CoolException("鐗╂枡搴撲笉瀛樺湪璇ョ墿鏂�!!");
+            }
+            Set<Long> longs = matList.stream().map(Mat::getTagId).collect(Collectors.toSet());
+            if (!longs.isEmpty() && longs.size() > 1) {
+                throw new CoolException("鐗╂枡绫诲瀷涓嶄竴鑷�,璇锋鏌ユ暟鎹槸鍚︽纭�!!");
+            }
+
+            Mat mat = matList.stream().findFirst().get();
+
+            BasStation station = basStationService.selectOne(new EntityWrapper<BasStation>()
+                    .eq("loc_sts", LocStsType.LOC_STS_TYPE_O.type)
+                    .eq("ctn_type", mat.getTagId())
+                    .eq("dev_no", params.getTarSite()));
+            if (Objects.isNull(station)) {
+                continue;
+            }
+
+            /**鐢熸垚缂撳瓨鍖哄嚭搴撲换鍔�*/
+            generateCacheOutTask(station, locCache, userId);
+
+            /**鐢熸垚绔嬪簱鍑哄簱浠诲姟*/
+            generateCRNOutTask(station, locCache, userId);
+
+            return R.ok();
         }
-
-        /**鐢熸垚缂撳瓨鍖哄嚭搴撲换鍔�*/
-        generateCacheOutTask(station, locCaches, userId);
-
-        /**鐢熸垚绔嬪簱鍑哄簱浠诲姟*/
-        generateCRNOutTask(locCaches);
-
-        return R.ok();
+        return R.error("鏈壘鍒颁笌绔欑偣绫诲瀷鍖归厤鐨勫簱瀛�");
     }
 
     @Override
@@ -1286,12 +1393,10 @@
 
         BasAreas basAreas = basAreasService.selectOne(new EntityWrapper<BasAreas>().eq("name", params.getOrgSite()));
 
-
         List<LocCache> locCaches = locCacheService.selectList(new EntityWrapper<LocCache>()
                 .eq("loc_sts", LocStsType.LOC_STS_TYPE_D.type)
-                .eq("area_id", basAreas.getId())
-        );
-        if (locCaches.isEmpty()){
+                .eq("area_id", basAreas.getId()));
+        if (locCaches.isEmpty()) {
             throw new CoolException("鏆傛棤绌烘澘搴撲綅");
         }
 
@@ -1303,84 +1408,808 @@
         }
         generateCacheOutTask(station, locCaches.get(0), userId);
 
-
-//        HIKApiDTO hikApiDTO =new HIKApiDTO()
-//                .setOrg(locCaches.get(0).getLocNo())
-//                .setOrgType("05")
-//                .setTar(params.getTarSite())
-//                .setTarType("05")
-//                .setTaskType("GT5")
-//                .setPriority("1")
-//                .setCtnrType("2")
-//                ;
-//        HIKResultDTO hikResultDTO = sendAgvTask(hikApiDTO, HIKApiConstant.AGV_CALL_IN_PATH);
-//        if (!hikResultDTO.isSuccess()){
-//            return R.error(hikResultDTO.getMessage());
-//        }
+        // HIKApiDTO hikApiDTO =new HIKApiDTO()
+        // .setOrg(locCaches.get(0).getLocNo())
+        // .setOrgType("05")
+        // .setTar(params.getTarSite())
+        // .setTarType("05")
+        // .setTaskType("GT5")
+        // .setPriority("1")
+        // .setCtnrType("2")
+        // ;
+        // HIKResultDTO hikResultDTO = sendAgvTask(hikApiDTO,
+        // HIKApiConstant.AGV_CALL_IN_PATH);
+        // if (!hikResultDTO.isSuccess()){
+        // return R.error(hikResultDTO.getMessage());
+        // }
 
         return R.ok();
     }
 
     @Override
-//    @Transactional(rollbackFor = Exception.class)
+    @Transactional(rollbackFor = Exception.class)
     public R collectionInCall(AgvCallParams params, Long userId) {
         if (Objects.isNull(params.getOrgSite())) {
             throw new CoolException("婧愮珯鐐逛笉鑳戒负绌猴紒锛�");
         }
 
-        List<Task> tasks = taskService.selectList(new EntityWrapper<Task>().eq("barcode", params.getBarcode()));
-        if (!tasks.isEmpty()){
-            throw new CoolException("鎵樼洏鐮佸凡鐢熸垚浠诲姟");
-        }
-
         BasAreas basAreas = basAreasService.selectOne(new EntityWrapper<BasAreas>().eq("name", params.getTarSite()));
 
         List<LocCache> locCaches = locCacheService.selectList(new EntityWrapper<LocCache>()
-                .in("loc_sts", LocStsType.LOC_STS_TYPE_O.type, LocStsType.LOC_STS_TYPE_D.type)
-                .eq("area_id", basAreas.getId())
-        );
+                .in("loc_sts", LocStsType.LOC_STS_TYPE_O.type)
+                .eq("area_id", basAreas.getId()));
         if (locCaches.isEmpty()) {
             throw new CoolException("褰撳墠鏆傛棤绌哄簱浣嶏紒锛�");
         }
 
-        generateAgvTask("agv", locCaches.get(0), params.getOrgSite(), params.getBarcode(), userId);
+        BasStation station = basStationService
+                .selectOne(new EntityWrapper<BasStation>().eq("dev_no", params.getOrgSite()));
+        if (Objects.isNull(station)) {
+            throw new CoolException("婧愮珯鐐规湭妫�绱㈠埌鏁版嵁锛侊紒");
+        }
+
+        generateSOEOInTask("agv", locCaches.get(0), params.getOrgSite(), station.getBarcode(), userId);
+
+        return R.ok();
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    public void generateSOEOInTask(String type, LocCache loc, String orgSite, String barcode, Long userId) {
+        List<BasStationDetl> basStationDetls = basStationDetlService
+                .selectList(new EntityWrapper<BasStationDetl>().eq("dev_no", orgSite));
+        if (Objects.isNull(basStationDetls) || basStationDetls.isEmpty()) {
+            throw new CoolException("绔欑偣淇℃伅涓嶅瓨鍦紒锛�");
+        }
+
+        List<Task> tasks = taskService.selectList(new EntityWrapper<Task>().eq("barcode", barcode));
+        if (!tasks.isEmpty()) {
+            throw new CoolException("鎵樼洏宸插湪浠诲姟鎵ц涓�..");
+        }
+        // 鑾峰彇宸ヤ綔鍙�
+        int workNo = commonService.getWorkNo(WorkNoType.PICK.type);
+        // 淇濆瓨宸ヤ綔妗�
+        Task task = new Task();
+        task.setWrkNo(workNo)
+                .setIoTime(new Date())
+                .setWrkSts(1L) // 宸ヤ綔鐘舵�侊細11.鐢熸垚鍑哄簱ID
+                .setIoType(1) // 鍏ュ嚭搴撶姸鎬侊細 11.搴撴牸绉昏浇
+                .setTaskType("agv")
+                .setIoPri(10D)
+                .setLocNo(loc.getLocNo()) // 鐩爣搴撲綅
+                .setFullPlt("Y") // 婊℃澘锛歒
+                .setPicking("N") // 鎷f枡
+                .setExitMk("N")// 閫�鍑�
+                .setSourceStaNo(orgSite)
+                .setEmptyMk(loc.getLocSts().equals("D") ? "Y" : "N")// 绌烘澘
+                .setBarcode(barcode)// 鎵樼洏鐮�
+                .setLinkMis("N")
+                .setAppeUser(userId)
+                .setAppeTime(new Date())
+                .setModiUser(userId)
+                .setModiTime(new Date());
+        if (!taskService.insert(task)) {
+            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+        }
+
+        for (BasStationDetl basStationDetl : basStationDetls) {
+            TaskDetl wrkDetl = new TaskDetl();
+            BeanUtils.copyProperties(basStationDetl, wrkDetl);
+            wrkDetl.setWrkNo(workNo)
+                    .setIoTime(new Date())
+                    .setOrderNo(basStationDetl.getOrderNo())
+                    .setAnfme(basStationDetl.getAnfme())
+                    .setZpallet(basStationDetl.getBarcode())
+                    .setBatch(basStationDetl.getBatch())
+                    .setMatnr(basStationDetl.getMatnr())
+                    .setMaktx(basStationDetl.getMaktx())
+                    .setStandby1(basStationDetl.getStandby1())
+                    .setAppeUser(userId)
+                    .setUnit(basStationDetl.getUnit())
+                    .setModel(basStationDetl.getModel())
+                    .setAppeTime(new Date())
+                    .setModiUser(userId);
+
+            // 淇濆瓨宸ヤ綔妗f槑缁�
+            if (!taskDetlService.insert(wrkDetl)) {
+                throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+            }
+        }
+
+        // 淇敼鐩爣搴撲綅鐘舵��
+        if (loc.getLocSts().equals(LocStsType.LOC_STS_TYPE_O.type)) {
+            loc.setLocSts(LocStsType.LOC_STS_TYPE_S.type); // S.鍏ュ簱棰勭害
+            loc.setModiTime(new Date());
+            loc.setModiUser(userId);
+            if (!locCacheService.updateById(loc)) {
+                throw new CoolException("鏇存柊鐩爣搴撲綅鐘舵�佸け璐�");
+            }
+        } else {
+            throw new CoolException("绉昏浆澶辫触锛岀洰鏍囧簱浣嶇姸鎬侊細" + loc.getLocSts$());
+        }
+
+        // 淇敼鐩爣绔欑偣淇℃伅
+        BasStation station = basStationService.selectOne(new EntityWrapper<BasStation>().eq("dev_no", orgSite));
+        if (Objects.isNull(station)) {
+            throw new CoolException("绔欑偣涓嶅瓨鍦�!!");
+        }
+
+        if (station.getLocSts().equals(LocStsType.LOC_STS_TYPE_F.type)) {
+            station.setLocSts("R"); // S.鍏ュ簱棰勭害
+            station.setBarcode(barcode);
+            station.setModiTime(new Date());
+            station.setModiUser(userId);
+            if (!basStationService.updateById(station)) {
+                throw new CoolException("鏇存柊鐩爣搴撲綅鐘舵�佸け璐�");
+            }
+        } else {
+            throw new CoolException("绉昏浆澶辫触锛岀洰鏍囧簱浣嶇姸鎬侊細" + station.getLocSts());
+        }
+    }
+
+    /**
+     * 缂撳瓨鍑哄簱缁勬墭涓婃灦
+     *
+     * @param params
+     * @return com.core.common.R
+     * @author Ryan
+     * @date 2025/12/8 13:47
+     */
+    @Override
+    public R combOutPub(AgvCallParams params) {
 
         return R.ok();
     }
 
     /**
-     * 鐢熸垚绔嬪簱鍑哄簱浠诲姟
+     * 缂撳瓨缁勬墭鏁版嵁
+     *
+     * @param params
+     * @return com.core.common.R
      * @author Ryan
-     * @date 2025/12/3 8:06
-     * @param locCaches
+     * @date 2025/12/8 15:37
+     */
+    @Override
+    public R combCacehList(AgvCallParams params) {
+        if (Objects.isNull(params.getCarBarcode())) {
+            throw new CoolException("鍙拌溅鎵樼洏鐮佷笉鑳戒负绌猴紒锛�");
+        }
+        if (Objects.isNull(params.getBsCode())) {
+            throw new CoolException("BS鐮佷笉鑳戒负绌猴紒锛�");
+        }
+//        Task task = taskService.selectOne(new EntityWrapper<Task>()
+//                .eq("io_type", TaskIOType.PICK_OUT.type)
+//                .eq("wrk_sts", 14)
+//                .eq("barcode", params.getCarBarcode()));
+//        if (Objects.isNull(task)) {
+//            throw new CoolException("鏁版嵁閿欒锛氫换鍔′俊鎭瓨鍦紒锛�");
+//        }
+
+        List<BasStationDetl> taskDetl = basStationDetlService.selectList(new EntityWrapper<BasStationDetl>()
+                .eq("three_code", params.getBsCode())
+                .eq("zpallet", params.getCarBarcode()));
+
+        if (Objects.isNull(taskDetl) || taskDetl.isEmpty()) {
+            throw new CoolException("褰撳墠BS缂栫爜涓嶅瓨鍦紒锛�");
+        }
+
+        return R.ok().add(taskDetl);
+    }
+
+    /**
+     * 缂撳瓨鍖轰笂鏋剁粍鎵�
+     *
+     * @param param
+     * @param userId
+     * @author Ryan
+     * @date 2025/12/9 13:45
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public void generateCRNOutTask(LocCache locCaches) {
+    public void cacheComb(CombParam param, Long userId) {
+        if (Objects.isNull(param.getBarcode())) {
+            throw new CoolException("鎵樼洏鐮佷笉鑳戒负绌猴紒锛�");
+        }
+        if (Objects.isNull(param.getCombMats()) || param.getCombMats().isEmpty()) {
+            throw new CoolException("缁勬墭鏄庣粏涓嶈兘涓虹┖锛侊紒");
+        }
+        // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁
+        if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode())
+                .eq("io_status", "N")) > 0) {
+            throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱");
+        }
+
+        int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet", param.getBarcode()));
+        int countWrk = wrkDetlService.selectCount(new EntityWrapper<WrkDetl>().eq("zpallet", param.getBarcode()));
+        int countwait = waitPakinService.selectCount(new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode()));
+        if (countLoc > 0 || countWrk > 0 || countwait > 0) {
+            throw new CoolException("缁勬墭妗�/宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode());
+        }
+
+        // 鐢熸垚鍏ュ簱閫氱煡妗�
+        List<DetlDto> detlDtos = new ArrayList<>();
+        param.getCombMats().forEach(elem -> {
+            DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(),
+                    elem.getStandby2(), elem.getStandby3(),
+                    elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme(), elem.getThreeCode());
+            if (DetlDto.has(detlDtos, detlDto)) {
+                DetlDto one = DetlDto.findDto(detlDtos, detlDto);
+                assert one != null;
+                one.setAnfme(one.getAnfme() + detlDto.getAnfme());
+            } else {
+                detlDtos.add(detlDto);
+            }
+        });
+        BasContainer container = basContainerService
+                .selectOne(new EntityWrapper<BasContainer>().eq("barcode", param.getBarcode()));
+        if (Objects.isNull(container)) {
+            throw new CoolException("鏁版嵁閿欒锛氬鍣ㄧ爜涓嶅瓨鍦紒锛�");
+        }
+        if (container.getMixMax() < detlDtos.size()) {
+            throw new CoolException("瓒呭嚭瀹瑰櫒鏈�澶ф贩瑁呮暟閲忥紝褰撳墠瀹瑰櫒鏈�澶ф暟閲忎负锛�" + container.getMixMax() + "!!");
+        }
+        Set<String> matnrs = detlDtos.stream().map(DetlDto::getMatnr).collect(Collectors.toSet());
+        List<Mat> mats = matService.selectList(new EntityWrapper<Mat>().in("matnr", matnrs));
+        Set<Long> tagIds = mats.stream().map(Mat::getTagId).collect(Collectors.toSet());
+        if (tagIds.size() > 1) {
+            throw new CoolException("缁勬墭鐗╂枡绫诲瀷涓嶄竴鑷达紝鍙湁鐩稿悓鐨勭墿鏂欏垎绫绘墠鍙互缁勬墭锛侊紒");
+        }
+        // 杩樺彲浠ユ斁鍏ュ灏戠鐗╂枡
+        Integer suplus = container.getMixMax();
+        Date now = new Date();
+        for (DetlDto detlDto : detlDtos) {
+            Mat mat = matService.selectByMatnr(detlDto.getMatnr());
+            if (Cools.isEmpty(mat)) {
+                throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
+            }
+            // 鏈�澶氬彲鏀炬暟閲�
+            Double singleMax = mat.getUpQty() * suplus;
+            if (singleMax.compareTo(detlDto.getAnfme()) < 0) {
+                throw new CoolException("鐗╂枡锛�" + detlDto.getMatnr() + "鍗曟缁勬墭涓婇檺涓猴細" + mat.getUpQty() + ",褰撳墠鎬婚噺瓒呭嚭鎵樼洏瑁呰浇涓婇檺!!");
+            }
+            BigDecimal decimal = new BigDecimal(detlDto.getAnfme() / mat.getUpQty());
+            // 褰撳墠鐗╂枡闇�瑕佸崰鐢ㄦ枡绠辨牸鏁�
+            Integer curr = decimal.setScale(0, RoundingMode.CEILING).intValue();
+            suplus = suplus - curr;
+            if (suplus < 0) {
+                throw new CoolException("鐗╂枡锛�" + detlDto.getMatnr() + ", 瓒呭嚭褰撳墠鎵樼洏瑁呰浇涓婇檺锛侊紒");
+            }
+
+            BasStationDetl stationDetl = basStationDetlService.selectOne(new EntityWrapper<BasStationDetl>()
+                    .eq("zpallet", param.getCarBarcode())
+                    .eq("three_code", detlDto.getThreeCode()));
+            if (Objects.isNull(stationDetl)) {
+                throw new CoolException("鏄庣粏鍐呭涓嶅瓨鍦紒锛�");
+            }
+
+            Double v = stationDetl.getAnfme() - stationDetl.getWorkQty();
+            if (detlDto.getAnfme().compareTo(v) > 0) {
+                throw new CoolException("缁勬墭涓婇檺涓猴細" + stationDetl.getAnfme() + ", 宸茬粍鎵橈細" + stationDetl.getWorkQty() + ", 杩樺彲缁勬墭锛�" + v);
+            }
+
+            WaitPakin waitPakin = new WaitPakin();
+            BeanUtils.copyProperties(mat, waitPakin);
+            waitPakin.setBatch(detlDto.getBatch());
+            waitPakin.setType(param.getType());
+            waitPakin.setZpallet(param.getBarcode());
+            // 璁剧疆缁勬墭绫诲瀷
+            waitPakin.setType(param.getType());
+            waitPakin.setIoStatus("N");
+            waitPakin.setAnfme(detlDto.getAnfme());
+            waitPakin.setThreeCode(detlDto.getThreeCode());
+            waitPakin.setStatus("Y");
+            waitPakin.setSuppCode(detlDto.getStandby1());
+            waitPakin.setStandby1(detlDto.getStandby1());
+            waitPakin.setStandby2(detlDto.getStandby2());
+            waitPakin.setStandby3(detlDto.getStandby3());
+            waitPakin.setBoxType1(detlDto.getBoxType1());
+            waitPakin.setBoxType2(detlDto.getBoxType2());
+            waitPakin.setBoxType3(detlDto.getBoxType3());
+            waitPakin.setAppeUser(userId);
+            waitPakin.setAppeTime(now);
+            waitPakin.setModiUser(userId);
+            waitPakin.setModiTime(now);
+            if (!waitPakinService.insert(waitPakin)) {
+                throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
+            }
+
+            Double v1 = stationDetl.getWorkQty() + detlDto.getAnfme();
+            stationDetl.setWorkQty(v1);
+
+            if (!basStationDetlService.updateById(stationDetl)) {
+                throw new CoolException("绔欑偣鏄庣粏淇敼澶辫触");
+            }
+
+            if (v1.compareTo(stationDetl.getWorkQty()) >= 0) {
+                if (!basStationDetlService.deleteById(stationDetl)) {
+                    throw new CoolException("鍘熷鏁版嵁绉婚櫎澶辫触锛�");
+                }
+            }
+
+        }
+    }
+
+    /**
+     * 缂撳瓨鍏ュ簱涓婃灦
+     *
+     * @param param
+     * @param userId
+     * @author Ryan
+     * @date 2025/12/9 15:05
+     */
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void combInPub(CompleteParam param, Long userId) {
+        if (Objects.isNull(param.getBarcode())) {
+            throw new CoolException("鎵樼洏鐮佷笉鑳戒负绌猴紒锛�");
+        }
+        if (Objects.isNull(param.getStation())) {
+            throw new CoolException("绔欑偣涓嶈兘涓虹┖!!");
+        }
+//        // TODO 淇敼缂撳瓨绔欑偣鐘舵�佸強鏁版嵁
+//        Task task = taskService.selectOne(new EntityWrapper<Task>()
+//                .eq("wrk_sts", 14L)
+//                .eq("barcode", param.getCarBarcode()));
+//        if (Objects.isNull(task)) {
+//            throw new CoolException("鏁版嵁閿欒,浠诲姟涓嶅瓨鍦�!!");
+//        }
+//        List<TaskDetl> taskDetls = taskDetlService
+//                .selectList(new EntityWrapper<TaskDetl>().eq("wrk_no", task.getWrkNo()));
+//        if (Objects.isNull(taskDetls) || taskDetls.isEmpty()) {
+//            throw new CoolException("鏁版嵁閿欒,浠诲姟鏄庣粏涓嶅瓨鍦�!!");
+//        }
+
+        BasStation station = basStationService.selectOne(new EntityWrapper<BasStation>()
+                .eq("dev_no", param.getStation()));
+        if (Objects.isNull(station)) {
+            throw new CoolException("绔欑偣涓嶅瓨鍦�!!");
+        }
+
+        station.setLocSts(LocStsType.LOC_STS_TYPE_O.type);
+        if (!basStationService.updateById(station)) {
+            throw new CoolException("绔欑偣鐘舵�佷慨鏀瑰け璐�!");
+        }
+        basStationDetlService.delete(new EntityWrapper<BasStationDetl>().eq("dev_no", station.getDevNo()));
+
+//        // 浠诲姟瀹屾垚
+//        task.setWrkSts(15L);
+//
+//        if (!taskService.updateById(task)) {
+//            throw new CoolException("AGV浠诲姟瀹屾垚澶辫触!!");
+//        }
+
+        List<WaitPakin> waitPakins = waitPakinService
+                .selectList(new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode()));
+        if (Objects.isNull(waitPakins) || waitPakins.isEmpty()) {
+            throw new CoolException("鏁版嵁閿欒,缁勬嫋妗e凡涓嶅瓨鍦�!!");
+        }
+
+        generateCrnInTask(waitPakins, station, param.getLocType1(), userId);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public R collectionPakin(CollectionPakinParams params, Long userId) {
+        List<BasStation> basStations = basStationService
+                .selectList(new EntityWrapper<BasStation>().eq("barcode", params.getTarBarcode()));
+        if (basStations.isEmpty() && Cools.isEmpty(params.getDevNo())) {
+            throw new CoolException("璇疯緭鍏ョ珯鐐瑰彿");
+        }
+        BasStation basStation = null;
+        if (!basStations.isEmpty()) {
+            basStation = basStations.get(0);
+        } else {
+            basStation = basStationService.selectOne(new EntityWrapper<BasStation>().eq("dev_no", params.getDevNo()));
+        }
+        if (Cools.isEmpty(basStation)) {
+            throw new CoolException("璇疯緭鍏ユ纭殑绔欑偣鍙�");
+        }
+        for (CollectionPakinParams.CombMat combMat : params.getCombMats()) {
+            if (combMat.getWorkQty().compareTo(BigDecimal.ZERO) == 0) {
+                continue;
+            }
+
+            OrderPakin orderPakin = orderPakinService.selectByNo(combMat.getOrderNo());
+            if (Cools.isEmpty(orderPakin)) {
+                throw new CoolException("鏈壘鍒板璐у叆搴撳崟");
+            }
+
+            UpdateDetailsOfPakin(orderPakin, combMat);
+
+            BasStationDetl basStationDetl = basStationDetlService.selectOne(new EntityWrapper<BasStationDetl>()
+                    .eq("dev_no", basStation.getDevNo())
+                    .eq("matnr", combMat.getMatnr())
+                    .eq("batch", combMat.getBatch())
+                    .eq("standby1", combMat.getStandby1()));
+            if (Cools.isEmpty(basStationDetl)) {
+                basStationDetl = new BasStationDetl();
+                Mat mat = matService.selectByMatnr(combMat.getMatnr());
+                BeanUtils.copyProperties(mat, basStationDetl);
+                basStationDetl
+                        .setOrderNo(orderPakin.getOrderNo())
+                        .setDevNo(basStation.getDevNo())
+                        .setBarcode(params.getTarBarcode())
+                        .setZpallet(params.getTarBarcode())
+                        .setBatch(combMat.getBatch())
+                        .setStandby1(combMat.getStandby1())
+                        .setAnfme(combMat.getWorkQty().doubleValue());
+                if (!basStationDetlService.insert(basStationDetl)) {
+                    throw new CoolException("鎻掑叆鏄庣粏澶辫触");
+                }
+
+            } else {
+                BigDecimal anfme = new BigDecimal(basStationDetl.getAnfme().toString()).add(combMat.getWorkQty());
+                basStationDetl.setAnfme(anfme.doubleValue());
+                if (!basStationDetlService.updateById(basStationDetl)) {
+                    throw new CoolException("鏇存柊鏄庣粏鏁版嵁澶辫触");
+                }
+
+            }
+        }
+        if (basStation.getLocSts().equals(LocStsType.LOC_STS_TYPE_D.type)
+                || basStation.getLocSts().equals(LocStsType.LOC_STS_TYPE_O.type)) {
+            basStation.setBarcode(params.getTarBarcode());
+            basStation.setLocSts(LocStsType.LOC_STS_TYPE_F.type);
+            basStationService.updateById(basStation);
+        }
+
+        return R.ok();
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    public void UpdateDetailsOfPakin(OrderPakin orderPakin, CollectionPakinParams.CombMat combMat) {
+        OrderDetlPakin orderDetlPakin = orderDetlPakinService.selectOne(new EntityWrapper<OrderDetlPakin>()
+                .eq("order_id", orderPakin.getId())
+                .eq("matnr", combMat.getMatnr())
+                .eq("batch", combMat.getBatch())
+                .eq("standby1", combMat.getStandby1()));
+        if (Cools.isEmpty(orderDetlPakin)) {
+            throw new CoolException("妫�绱㈠崟鎹槑缁嗘暟鎹け璐�");
+        }
+        if (orderDetlPakin.getWorkQty() >= orderDetlPakin.getAnfme()) {
+            throw new CoolException("璇峰嬁瓒呭嚭璁㈠崟鏄庣粏鏁伴噺");
+        }
+        BigDecimal workQty = new BigDecimal(orderDetlPakin.getWorkQty().toString()).add(combMat.getWorkQty());
+        orderDetlPakin.setWorkQty(workQty.doubleValue());
+        if (!orderDetlPakinService.updateById(orderDetlPakin)) {
+            throw new CoolException("鏇存柊鍗曟嵁鏄庣粏鏁版嵁澶辫触");
+        }
+        if (!orderPakin.getSettle().equals(2L)) {
+            orderPakin.setSettle(2L);
+            if (!orderPakinService.updateById(orderPakin)) {
+                throw new CoolException("鏇存柊鍗曟嵁鐘舵�佸け璐�");
+            }
+        }
+
+    }
+
+    @Override
+    public R collectionPakinView(CollectionPakinParams params) {
+
+        WrkMast wrkMast = wrkMastService.selectByBarcode(params.getOrgBarcode());
+        if (Cools.isEmpty(wrkMast)) {
+            throw new CoolException("鏈壘鍒颁换鍔�");
+        }
+
+        if (wrkMast.getIoType().equals(TaskIOType.ALL_OUT.type)
+                && wrkMast.getIoType().equals(TaskIOType.PICK_OUT.type)) {
+            throw new CoolException("浜虹墿绫诲瀷閿欒");
+        }
+
+        List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo());
+        if (Cools.isEmpty(wrkDetls)) {
+            throw new CoolException("鏈壘鍒颁换鍔℃槑缁�");
+        }
+
+        return R.ok(wrkDetls);
+    }
+
+    /**
+     * 鐢熸垚鍫嗗灈鏈哄叆搴撲换鍔�
+     *
+     * @param station
+     * @author Ryan
+     * @date 2025/12/9 13:54
+     */
+    @Transactional(rollbackFor = Exception.class)
+    public void generateCrnInTask(List<WaitPakin> waitPakins, BasStation station, Short locType, Long userId) {
+        Date now = new Date();
+        StationRela rela = stationRelaService.selectOne(new EntityWrapper<StationRela>()
+                .eq("agv_sta", station.getDevNo())
+                .orderAsc(Arrays.asList("crn_sta"))
+                .last("OFFSET 0 ROWS FETCH NEXT 1 ROWS ONLY"));
+
+        if (Objects.isNull(rela)) {
+            throw new CoolException("鏈粦瀹氫綔涓氱珯鐐�!!");
+        }
+
+        BasDevp sourceStaNo = basDevpService.checkSiteStatus(Integer.parseInt(rela.getCrnSta()), true);
+
+        sourceStaNo.setLocType1(locType);
+        LocTypeDto locTypeDto = new LocTypeDto(sourceStaNo);
+        WaitPakin pakin = waitPakins.stream().findFirst().get();
+        FindLocNoAttributeVo findLocNoAttributeVo = new FindLocNoAttributeVo(pakin);
+        StartupDto dto = commonService.getLocNo(1, sourceStaNo.getDevNo(), findLocNoAttributeVo, locTypeDto);
+        int workNo = dto.getWorkNo();
+        // 鐢熸垚宸ヤ綔妗�
+        WrkMast wrkMast = new WrkMast();
+        wrkMast.setWrkNo(workNo);
+        wrkMast.setIoTime(new Date());
+        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵�侊細鐢熸垚鍏ュ簱ID
+        wrkMast.setIoType(1); // 鍏ュ嚭搴撶姸鎬侊細1.鍏ュ簱
+        wrkMast.setIoPri(13D); // 浼樺厛绾�
+        wrkMast.setCrnNo(dto.getCrnNo());
+        wrkMast.setSourceStaNo(dto.getSourceStaNo() + "");
+        wrkMast.setStaNo(dto.getStaNo() + "");
+        wrkMast.setLocNo(dto.getLocNo());
+        wrkMast.setBarcode(pakin.getBarcode()); // 鎵樼洏鐮�
+        wrkMast.setFullPlt("Y"); // 婊℃澘锛歒
+        wrkMast.setPicking("N"); // 鎷f枡
+        wrkMast.setExitMk("N"); // 閫�鍑�
+        wrkMast.setEmptyMk("N"); // 绌烘澘
+        wrkMast.setLinkMis("Y");
+        wrkMast.setModiUser(userId);
+        wrkMast.setAppeUser(userId);
+        wrkMast.setCtnType(sourceStaNo.getCtnType()); // 瀹瑰櫒绫诲瀷
+        // 鎿嶄綔浜哄憳鏁版嵁
+        wrkMast.setAppeTime(now);
+        wrkMast.setModiTime(now);
+        boolean res = wrkMastService.insert(wrkMast);
+        if (!res) {
+            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+        }
+        // 鐢熸垚宸ヤ綔妗f槑缁�
+        waitPakins.forEach(waitPakin -> {
+            WrkDetl wrkDetl = new WrkDetl();
+            wrkDetl.sync(waitPakin);
+            wrkDetl.setWrkNo(wrkMast.getWrkNo());
+            wrkDetl.setIoTime(wrkMast.getIoTime());
+            wrkDetl.setAppeTime(now);
+            wrkDetl.setModiTime(now);
+            if (!wrkDetlService.insert(wrkDetl)) {
+                throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触");
+            }
+        });
+//        // 鏇存柊鍏ュ簱閫氱煡妗� ioStatus ===>> Y
+//        Wrapper<WaitPakin> wrapper = new EntityWrapper<WaitPakin>()
+//                .eq("zpallet", pakin.getZpallet());
+//        WaitPakin setParam = new WaitPakin();
+//        setParam.setLocNo(dto.getLocNo());
+//        setParam.setIoStatus("Y");
+//        setParam.setModiTime(now);
+//        if (!waitPakinService.update(setParam, wrapper)) {
+//            throw new CoolException("鏇存柊閫氱煡妗eけ璐�");
+//        }
+        // 鏇存柊婧愮珯鐐逛俊鎭�
+        sourceStaNo.setWrkNo(workNo);
+        sourceStaNo.setModiTime(now);
+        if (!basDevpService.updateById(sourceStaNo)) {
+            throw new CoolException("鏇存柊婧愮珯澶辫触");
+        }
+        // 鏇存柊鐩爣搴撲綅鐘舵��
+        LocMast locMast = locMastService.selectById(dto.getLocNo());
+        if (locMast.getLocSts().equals("O")) {
+            locMast.setLocSts("S"); // S.鍏ュ簱棰勭害
+            locMast.setModiTime(now);
+            if (!locMastService.updateById(locMast)) {
+                throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�");
+            }
+        } else {
+            throw new CoolException(dto.getLocNo() + "鐩爣搴撲綅宸茶鍗犵敤");
+        }
+
+    }
+
+    /**
+     * 鐢熸垚绔嬪簱鍑哄簱浠诲姟
+     * 鍙拌溅杩囨潵榛樿鏄悓涓�绉嶇墿鏂欑被鍨�
+     *
+     * @param locCaches
+     * @author Ryan
+     * @date 2025/12/3 8:06
+     */
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void generateCRNOutTask(BasStation station, LocCache locCaches, Long userId) {
         if (Objects.isNull(locCaches)) {
             throw new CoolException("搴撲綅涓嶈兘涓虹┖锛侊紒");
         }
-        BasAreas basAreas = basAreasService.selectOne(new EntityWrapper<BasAreas>().eq("whs_type_id", LocAreaType.LOC_AREA_TYPE_IN_CACHE.type));
+        // 鑾峰彇缂撳瓨鍖轰俊鎭�
+        BasAreas basAreas = basAreasService
+                .selectOne(new EntityWrapper<BasAreas>().eq("whs_type_id", LocAreaType.LOC_AREA_TYPE_IN_CACHE.type));
         if (Objects.isNull(basAreas)) {
             throw new CoolException("搴撳尯涓嶅瓨鍦紒锛�");
         }
         List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>()
-                .eq("area_id", basAreas.getAreaNo())
-                .eq("loc_id", locCaches.getId()));
-
-        if (Objects.isNull(locDetls)) {
+                .eq("area_id", basAreas.getId())
+                .eq("loc_no", locCaches.getLocNo()));
+        if (Objects.isNull(locDetls) || locDetls.isEmpty()) {
             throw new CoolException("搴撳瓨鏄庣粏涓嶅瓨鍦紒锛�");
         }
 
-        //鎸夌墿鏂欑紪鐮佸垎绫�
+        // Set<String> set =
+        // locDetls.stream().map(LocDetl::getMatnr).collect(Collectors.toSet());
+        // List<Mat> matList = matService.selectList(new
+        // EntityWrapper<Mat>().in("matnr", set));
+        //
+        // if (Objects.isNull(matList) || matList.isEmpty()) {
+        // throw new CoolException("鐗╂枡搴撲笉瀛樺湪璇ョ墿鏂�!!");
+        // }
+        // Set<Long> longs =
+        // matList.stream().map(Mat::getTagId).collect(Collectors.toSet());
+        // if (!longs.isEmpty() && longs.size() > 1) {
+        // throw new CoolException("鐗╂枡绫诲瀷涓嶄竴鑷�,璇锋鏌ユ暟鎹槸鍚︽纭�!!");
+        // }
+
+        // 鑾峰彇绔嬪簱鍖轰俊鎭�
+        BasAreas one = basAreasService
+                .selectOne(new EntityWrapper<BasAreas>().eq("whs_type_id", LocAreaType.LOC_AREA_TYPE_CRN.type));
+        if (Objects.isNull(one)) {
+            throw new CoolException("鏁版嵁閿欒锛氬簱鍖轰笉瀛樺湪锛侊紒");
+        }
+
+        List<StationRela> relas = stationRelaService
+                .selectList(new EntityWrapper<StationRela>().eq("agv_sta", station.getDevNo()));
+        if (Objects.isNull(relas) || relas.isEmpty()) {
+            throw new CoolException("绔欑偣鏈叧鑱斿爢鍨涙満浣滀笟绔欑偣锛侊紒");
+        }
+
+        Set<String> crnStas = relas.stream().map(StationRela::getCrnSta).collect(Collectors.toSet());
+
+        List<BasDevp> devps = basDevpService.selectList(
+                new EntityWrapper<BasDevp>().in("dev_no", crnStas).eq("loading", CommonStation.COMMON_STATION_Y.type));
+        if (Objects.isNull(devps) || devps.isEmpty()) {
+            throw new CoolException("鏃犵珯鐐瑰彲鐢紒");
+        }
+        Collections.shuffle(devps);
+        BasDevp basDevp = devps.stream().findFirst().get();
+        List<LocMast> locMasts = new ArrayList<>();
         Map<String, List<LocDetl>> listMap = locDetls.stream().collect(Collectors.groupingBy(LocDetl::getMatnr));
-        listMap.forEach((key, detls) -> {
-
+        AtomicReference<Double> totalOut = new AtomicReference<>(
+                locDetls.stream().mapToDouble(LocDetl::getAnfme).sum());
+        listMap.forEach((matnr, detls) -> {
+            // 鏍规嵁supId(渚涘簲鍟�)鍒嗙被锛屽緱鍒板嚭搴撴�绘暟
+            Map<String, List<LocDetl>> supIds = detls.stream().collect(Collectors.groupingBy(LocDetl::getStandby1));
+            supIds.forEach((supId, sups) -> {
+                Double sum = sups.stream().mapToDouble(LocDetl::getAnfme).sum();
+                // 鑾峰彇褰撳墠渚涘簲鍟�+ 鐗╂枡鍦ㄥ簱
+                List<LocDetl> detlList = locDetlService.selectList(new EntityWrapper<LocDetl>()
+                        .eq("matnr", matnr)
+                        .eq("area_id", one.getId())
+                        .eq("standby1", supId).orderAsc(Arrays.asList("appe_time")));
+                // TODO 鍒ゆ柇鏄惁鏈夋柊搴撲綅锛屾病鏈夋柊搴撲綅锛屽啀鎵炬湁绌烘牸鐨勪綅缃斁 1. 鍒ゆ柇褰撳墠鐗╂枡鏄惁鏈夊簱瀛� 2. 娌℃湁浣欐枡鏌ヨ鏂板簱浣�
+                if (!Objects.isNull(detlList) && !detlList.isEmpty()) {
+                    Map<String, List<LocDetl>> locMaps = detlList.stream()
+                            .collect(Collectors.groupingBy(LocDetl::getLocNo));
+                    locMaps.forEach((locNo, adetls) -> {
+                        LocMast locMast = locMastService.selectById(locNo);
+                        if (Objects.isNull(locMast)) {
+                            throw new CoolException("鏁版嵁閿欒锛屽簱浣嶄俊鎭笉瀛樺湪锛侊紒");
+                        }
+                        BasContainer container = basContainerService
+                                .selectOne(new EntityWrapper<BasContainer>().eq("barcode", locMast.getBarcode()));
+                        if (Objects.isNull(container)) {
+                            throw new CoolException("鏁版嵁閿欒锛屽鍣ㄤ笉瀛樺湪锛侊紒");
+                        }
+                        Set<String> sets = adetls.stream().map(LocDetl::getMatnr).collect(Collectors.toSet());
+                        // 鍒ゆ柇瀹瑰櫒鏄惁杩樺彲娣锋斁,鍙婂綋鍓嶇墿鏂欏彲鏀惧灏�
+                        if (container.getMixMax() > sets.size()) {
+                            int suplus = container.getMixMax() - sets.size();
+                            Mat mats = matService.selectOne(new EntityWrapper<Mat>().eq("matnr", matnr));
+                            if (Objects.isNull(mats)) {
+                                throw new CoolException("鐗╂枡涓嶅瓨鍦紒锛�");
+                            }
+                            Double v = mats.getUpQty() * suplus;
+                            // 灏忎簬闆�
+                            if (sum.compareTo(v) <= 0) {
+                                // 鍙斁涓�
+                                locMasts.add(locMast);
+                                totalOut.set(Math.round((totalOut.get() - sum) * 10000) / 10000.0);
+                            }
+                        }
+                    });
+                }
+            });
         });
 
-        locDetls.forEach(locDetl -> {
+        // 鍒ゆ柇鏍规嵁鍒嗘嫞鍑哄簱鍚�,杩橀渶瑕佸嚭澶氬皯鎵樼洏鎴栨枡绠�;濡傛灉浣欐枡澶т簬0, 鍑烘柊鎵樼洏鎴栨枡绠�
+        if (totalOut.get().compareTo(0.0) > 0) {
+            // Set<String> matnrs =
+            // locDetls.stream().map(LocDetl::getMatnr).collect(Collectors.toSet());
+            // List<Mat> mats = matService.selectList(new EntityWrapper<Mat>().in("matnr",
+            // matnrs));
+            LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>()
+                    // todo 鏍规嵁鐗╂枡绉嶇被,鍖哄垎搴撳尯绫诲瀷
+                    .eq("loc_sts", LocStsType.LOC_STS_TYPE_D.type)
+                    .orderAsc(Arrays.asList("row1", "bay1", "lev1"))
+                    .last("OFFSET 0 ROWS FETCH NEXT 1 ROWS ONLY"));
+            locMasts.add(locMast);
+            // 绌烘澘鍑哄簱
+            generateTask(locMasts, TaskIOType.EMPTY_OUT.type, basDevp, userId);
+        } else {
+            // 鐢熸垚鍫嗗灈鏈哄嚭搴撲换鍔�
+            generateTask(locMasts, TaskIOType.MERGE_OUT.type, basDevp, userId);
+            // if (!locMasts.isEmpty()) {
+            //
+            // }
+        }
+    }
 
-        });
+    /**
+     * 鐢熸垚鍫嗗灈鏈哄嚭搴撲换鍔�
+     *
+     * @param locMasts
+     * @author Ryan
+     * @date 2025/12/6 14:44
+     */
+    @Transactional(rollbackFor = Exception.class)
+    public void generateTask(List<LocMast> locMasts, Integer ioType, BasDevp devp, Long userId) {
+        Date now = new Date();
+        for (LocMast locMast : locMasts) {
+            if (Objects.isNull(ioType)) {
+                continue;
+            }
+            Integer outSta = devp.getDevNo();
+            // 鑾峰彇璺緞
+            StaDesc staDesc = staDescService.queryCrnStn(ioType, locMast.getCrnNo(), outSta);
+            // 鐢熸垚宸ヤ綔鍙�
+            int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType));
+            // 鐢熸垚宸ヤ綔妗�
+            WrkMast wrkMast = new WrkMast();
+            wrkMast.setWrkNo(workNo);
+            wrkMast.setIoTime(now);
+            wrkMast.setWrkSts(11L); // 宸ヤ綔鐘舵�侊細11.鐢熸垚鍑哄簱ID
+            wrkMast.setIoType(ioType); // 鍏ュ嚭搴撶被鍨�
+            wrkMast.setIoPri(13D); // 浼樺厛绾э細13
+            wrkMast.setCrnNo(locMast.getCrnNo());
+            wrkMast.setSourceStaNo(staDesc.getCrnStn() + ""); // 婧愮珯
+            wrkMast.setStaNo(staDesc.getStnNo() + ""); // 鐩爣绔�
+            wrkMast.setSourceLocNo(locMast.getLocNo()); // 婧愬簱浣�
+            wrkMast.setFullPlt("Y"); // 婊℃澘锛歒
+            wrkMast.setPicking("N"); // 鎷f枡
+            wrkMast.setExitMk("N"); // 閫�鍑�
+            wrkMast.setEmptyMk("N"); // 绌烘澘
+            wrkMast.setLinkMis("N");
+            wrkMast.setBarcode(locMast.getBarcode());
+            wrkMast.setAppeUser(userId); // 鎿嶄綔浜哄憳鏁版嵁
+            wrkMast.setAppeTime(now);
+            wrkMast.setModiUser(userId);
+            wrkMast.setModiTime(now);
+            if (!wrkMastService.insert(wrkMast)) {
+                throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐ワ紝鍑哄簱搴撲綅鍙凤細" + locMast.getLocNo());
+            }
+
+            List<LocDetl> locDetls = locDetlService
+                    .selectList(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()));
+
+            // 鐢熸垚宸ヤ綔妗f槑缁�
+            for (LocDetl detlDto : locDetls) {
+                WrkDetl wrkDetl = new WrkDetl();
+                BeanUtils.copyProperties(detlDto, wrkDetl);
+                wrkDetl.setOrderNo(""); // 鎵嬪姩鍑哄簱涓嶉渶瑕佸甫鍑哄簱瀛樹腑鐨勫崟鎹紪鍙�
+                wrkDetl.setWrkNo(workNo);
+                wrkDetl.setIoTime(now);
+                wrkDetl.setAppeTime(now);
+                wrkDetl.setAppeUser(userId);
+                wrkDetl.setModiTime(now);
+                wrkDetl.setModiUser(userId);
+                if (!wrkDetlService.insert(wrkDetl)) {
+                    throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+                }
+            }
+            // 淇敼搴撲綅鐘舵��: F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
+            locMast = locMastService.selectById(locMast.getLocNo());
+            if (locMast.getLocSts().equals(LocStsType.LOC_STS_TYPE_F.type)
+                    || locMast.getLocSts().equals(LocStsType.LOC_STS_TYPE_D.type)) {
+                locMast.setLocSts(ioType == 101 ? "R" : "P");
+                locMast.setModiUser(userId);
+                locMast.setModiTime(now);
+                if (!locMastService.updateById(locMast)) {
+                    throw new CoolException("棰勭害搴撲綅鐘舵�佸け璐ワ紝搴撲綅鍙凤細" + locMast.getLocNo());
+                }
+            } else {
+                throw new CoolException(locMast.getLocNo() + "搴撲綅涓嶆槸鍦ㄥ簱鐘舵��");
+            }
+        }
     }
 
     /**
@@ -1416,7 +2245,9 @@
         if (!taskService.insert(task)) {
             throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
         }
-        List<LocDetl> detls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_id", loc.getId()));
+
+        List<LocDetl> detls = locDetlService.selectList(new EntityWrapper<LocDetl>()
+                .eq("loc_no", loc.getLocNo()));
         if (!detls.isEmpty()) {
             List<TaskDetl> taskDetls = new ArrayList<>();
             detls.forEach(pakin -> {
@@ -1430,19 +2261,18 @@
                         .setBatch(pakin.getBatch())
                         .setMatnr(pakin.getMatnr())
                         .setMaktx(pakin.getMaktx())
+                        .setThreeCode(pakin.getThreeCode())
                         .setAppeUser(userId)
                         .setUnit(pakin.getUnit())
                         .setModel(pakin.getModel())
                         .setAppeTime(new Date())
                         .setModiUser(userId);
-                taskDetls.add(wrkDetl);
+                // 淇濆瓨宸ヤ綔妗f槑缁�
+                if (!taskDetlService.insert(wrkDetl)) {
+                    throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+                }
             });
-            //淇濆瓨宸ヤ綔妗f槑缁�
-            if (!taskDetlService.insertBatch(taskDetls)) {
-                throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
-            }
         }
-
 
         loc.setLocSts(LocStsType.LOC_STS_TYPE_R.type);
         loc.setModiUser(userId);
@@ -1453,8 +2283,8 @@
         }
 
         // 淇敼鐩爣绔欑偣淇℃伅
-        if (station.getLocSts().equals("O")) {
-            station.setLocSts("S"); // S.鍏ュ簱棰勭害
+        if (station.getLocSts().equals(LocStsType.LOC_STS_TYPE_O.type)) {
+            station.setLocSts(LocStsType.LOC_STS_TYPE_S.type); // S.鍏ュ簱棰勭害
             station.setModiTime(new Date());
             station.setModiUser(userId);
             if (!basStationService.updateById(station)) {
@@ -1476,6 +2306,11 @@
         List<WaitPakin> pakins = waitPakinService.selectList(new EntityWrapper<WaitPakin>().eq("zpallet", barcode));
         if (Objects.isNull(pakins) || pakins.isEmpty()) {
             throw new CoolException("缁勬墭淇℃伅涓嶅瓨鍦紒锛�");
+        }
+
+        List<Task> tasks = taskService.selectList(new EntityWrapper<Task>().eq("barcode", barcode));
+        if (!tasks.isEmpty()) {
+            throw new CoolException("鎵樼洏宸插湪浠诲姟鎵ц涓�..");
         }
         // 鑾峰彇宸ヤ綔鍙�
         int workNo = commonService.getWorkNo(WorkNoType.PICK.type);
@@ -1503,11 +2338,10 @@
             throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
         }
 
-        List<TaskDetl> taskDetls = new ArrayList<>();
-        pakins.forEach(pakin -> {
+        for (WaitPakin pakin : pakins) {
             TaskDetl wrkDetl = new TaskDetl();
             BeanUtils.copyProperties(pakin, wrkDetl);
-            wrkDetl.setWrkNo(workNo)
+            wrkDetl.setId(null).setWrkNo(workNo)
                     .setIoTime(new Date())
                     .setOrderNo(pakin.getOrderNo())
                     .setAnfme(pakin.getAnfme())
@@ -1520,18 +2354,17 @@
                     .setModel(pakin.getModel())
                     .setAppeTime(new Date())
                     .setModiUser(userId);
-            taskDetls.add(wrkDetl);
-        });
+            if (!taskDetlService.insert(wrkDetl)) {
+                throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+            }
 
-        //淇濆瓨宸ヤ綔妗f槑缁�
-        if (!taskDetlService.insertBatch(taskDetls)) {
-            throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
         }
 
-        pakins.forEach(pakin -> {pakin.setIoStatus("Y");});
-
-        if (!waitPakinService.updateBatchById(pakins)) {
-            throw new CoolException("鏇存柊缁勬墭淇℃伅澶辫触");
+        for (WaitPakin pakin : pakins) {
+            pakin.setIoStatus("Y");
+            if (!waitPakinService.updateById(pakin)) {
+                throw new CoolException("鏇存柊缁勬墭淇℃伅澶辫触");
+            }
         }
 
         // 淇敼鐩爣搴撲綅鐘舵��
@@ -1548,7 +2381,11 @@
 
         // 淇敼鐩爣绔欑偣淇℃伅
         BasStation station = basStationService.selectOne(new EntityWrapper<BasStation>().eq("dev_no", orgSite));
-        if (station.getLocSts().equals("O")) {
+        if (Objects.isNull(station)) {
+            throw new CoolException("绔欑偣涓嶅瓨鍦�!!");
+        }
+
+        if (station.getLocSts().equals(LocStsType.LOC_STS_TYPE_O.type)) {
             station.setLocSts("R"); // S.鍏ュ簱棰勭害
             station.setBarcode(barcode);
             station.setModiTime(new Date());
@@ -1561,8 +2398,7 @@
         }
     }
 
-
-    public HIKResultDTO sendAgvTask(HIKApiDTO haiKangApiDTO,String path){
+    public HIKResultDTO sendAgvTask(HIKApiDTO haiKangApiDTO, String path) {
         HIKResultDTO result = new HIKResultDTO();
 
         ForwardAGVTaskDTO forwardAGVTaskParam = new ForwardAGVTaskDTO();
@@ -1572,8 +2408,10 @@
         forwardAGVTaskParam.setCtnrTyp(haiKangApiDTO.getCtnrType());
         forwardAGVTaskParam.setPriority(haiKangApiDTO.getPriority());
         List<ForwardAGVTaskDTO.PositionCodePaths> positionCodePathsList = new ArrayList<>();
-        positionCodePathsList.add(new ForwardAGVTaskDTO.PositionCodePaths(haiKangApiDTO.getOrg(), haiKangApiDTO.getOrgType()));
-        positionCodePathsList.add(new ForwardAGVTaskDTO.PositionCodePaths(haiKangApiDTO.getTar(), haiKangApiDTO.getTarType()));
+        positionCodePathsList
+                .add(new ForwardAGVTaskDTO.PositionCodePaths(haiKangApiDTO.getOrg(), haiKangApiDTO.getOrgType()));
+        positionCodePathsList
+                .add(new ForwardAGVTaskDTO.PositionCodePaths(haiKangApiDTO.getTar(), haiKangApiDTO.getTarType()));
         forwardAGVTaskParam.setPositionCodePath(positionCodePathsList);
 
         String body = JSON.toJSONString(forwardAGVTaskParam);
@@ -1592,7 +2430,7 @@
                 result.setMessage(jsonObject.getString("message"));
                 log.error("鍙戦�乤gv浠诲姟澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", HIKApiConstant.AGV_IP + path, body, response);
             }
-//            {"code":"1","data":"","interrupt":false,"message":"閲嶅鎻愪氦","msgErrCode":"0x3a80D012","reqCode":"fa92b49481a44627ae4d80c1400f28f6"}
+            // {"code":"1","data":"","interrupt":false,"message":"閲嶅鎻愪氦","msgErrCode":"0x3a80D012","reqCode":"fa92b49481a44627ae4d80c1400f28f6"}
         } catch (Exception e) {
             result.setMessage(e.getMessage());
             log.error("鍙戦�乤gv浠诲姟寮傚父", e);
@@ -1606,8 +2444,7 @@
                         "127.0.0.1",
                         body,
                         response,
-                        result.isSuccess()
-                );
+                        result.isSuccess());
             } catch (Exception e) {
                 log.error("", e);
             }

--
Gitblit v1.9.1