From 55eb3d480594f4c0dd382eaeeb8548bf911d6ad7 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期四, 23 十月 2025 08:28:08 +0800
Subject: [PATCH] 13

---
 src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java |   90 ++++++++++++++++----------------------------
 1 files changed, 33 insertions(+), 57 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
index 5d4101b..0897fc2 100644
--- a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
@@ -69,9 +69,13 @@
     @Autowired
     private SnowflakeIdWorker snowflakeIdWorker;
     @Autowired
-    private OrderService orderService;
+    private OrderPakoutService orderPakoutService;
     @Autowired
-    private OrderDetlService orderDetlService;
+    private OrderPakinService orderPakinService;
+    @Autowired
+    private OrderDetlPakoutService orderDetlPakoutService;
+    @Autowired
+    private OrderDetlPakinService orderDetlPakinService;
     @Autowired
     private WcsController wcsController;
     @Autowired
@@ -80,8 +84,6 @@
     private SlaveProperties slaveProperties;
     @Autowired
     private WaitPakinService waitPakinService;
-    @Autowired
-    private InventoryCheckOrderDetlService inventoryCheckOrderDetlService;
 
     @Override
     @Transactional
@@ -184,10 +186,10 @@
                 if (staNo.getDevNo() == 1135 && locMast.getLocType1() == 2) {
                     throw new CoolException("鎵�閫夊簱浣嶄笉鏄綆搴撲綅鏃犳硶璋冩嫧锛屽簱浣嶅彿锛歿}" + locMast.getLocNo());
                 }
-                if(staNo.getDevNo()>=1100){
+                if (staNo.getDevNo() >= 1100) {
                     // 鍚姩鍑哄簱寮�濮� 101.鍑哄簱
                     stockOut(staNo, locDetlDtos, null, userId);
-                }else {
+                } else {
                     stockOutSXK(staNo, locDetlDtos, null, userId);
                 }
             } else {
@@ -386,19 +388,6 @@
             // 鐢熸垚宸ヤ綔妗f槑缁�
             for (LocDetlDto detlDto : dto.getLocDetlDtos()) {
 
-                InventoryCheckOrderDetl inventoryCheckOrderDetl = new InventoryCheckOrderDetl();
-                inventoryCheckOrderDetl.setOrderNo(param.getOrderNo());
-                inventoryCheckOrderDetl.setMatnr(detlDto.getLocDetl().getMatnr());
-                inventoryCheckOrderDetl.setMaktx(detlDto.getLocDetl().getMaktx());
-                inventoryCheckOrderDetl.setBatch(detlDto.getLocDetl().getBatch());
-                inventoryCheckOrderDetl.setLocNo(detlDto.getLocDetl().getLocNo());
-                inventoryCheckOrderDetl.setArea(detlDto.getLocDetl().getOrigin());
-                inventoryCheckOrderDetl.setAnfme(detlDto.getLocDetl().getAnfme());
-                inventoryCheckOrderDetl.setIoTime(now);
-                inventoryCheckOrderDetl.setStatus("1");
-                if (!inventoryCheckOrderDetlService.insert(inventoryCheckOrderDetl)) {
-                    throw new CoolException("淇濆瓨鐩樼偣鏄庣粏澶辫触");
-                }
 
                 if (detlDto.getCount() == null || detlDto.getCount() <= 0.0D) {
                     continue;
@@ -485,12 +474,12 @@
             if (locDto.getAnfme() == null || locDto.getAnfme() <= 0.0D) {
                 continue;
             }
-            OrderDetl orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch());
-            if (orderDetl == null) {
-                orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), null);
+            OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch());
+            if (orderDetlPakout == null) {
+                orderDetlPakout = orderDetlPakoutService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), null);
             }
             WrkDetl wrkDetl = new WrkDetl();
-            wrkDetl.sync(orderDetl);
+            wrkDetl.sync(orderDetlPakout);
             wrkDetl.setZpallet(wrkMast.getBarcode());
             wrkDetl.setIoTime(now);
             wrkDetl.setWrkNo(workNo);
@@ -505,10 +494,10 @@
                 throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
             }
             // 淇敼璁㈠崟鏄庣粏
-            if (!orderDetlService.increaseWorkQty(orderDetl.getOrderId(), orderDetl.getMatnr(), orderDetl.getBatch(), locDto.getAnfme())) {
+            if (!orderDetlPakoutService.increaseWorkQtyById(orderDetlPakout.getId(), locDto.getAnfme())) {
                 throw new CoolException("淇敼璁㈠崟鏄庣粏鏁伴噺澶辫触");
             }
-            orderService.updateSettle(orderDetl.getOrderId(), 2L, userId);
+            orderPakoutService.updateSettle(orderDetlPakout.getOrderId(), 2L, userId);
         }
         // 淇敼搴撲綅鐘舵��:   F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
         locMast = locMastService.selectById(taskDto.getLocNo());
@@ -538,10 +527,10 @@
         LocMast locMast = locMastService.selectById(taskDto.getLocNo());
 
         List<LocMast> locMasts = new ArrayList<>();
-        if ((locMast.getBay1() >= 3 && locMast.getBay1() <= 6) ) {
+        if ((locMast.getBay1() >= 3 && locMast.getBay1() <= 6)) {
             locMasts = locMastService.selectList(new EntityWrapper<LocMast>()
                     .eq("row1", locMast.getBay1())
-                    .in("bay1", 3,4,5,6)
+                    .in("bay1", 3, 4, 5, 6)
                     .eq("crn_no", 7)
                     .eq("loc_type1", locMast.getLocType1())
                     .orderBy("bay1", true));
@@ -593,12 +582,12 @@
             if (locDto.getAnfme() == null || locDto.getAnfme() <= 0.0D) {
                 continue;
             }
-            OrderDetl orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch());
-            if (orderDetl == null) {
-                orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), null);
+            OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch());
+            if (orderDetlPakout == null) {
+                orderDetlPakout = orderDetlPakoutService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), null);
             }
             WrkDetl wrkDetl = new WrkDetl();
-            wrkDetl.sync(orderDetl);
+            wrkDetl.sync(orderDetlPakout);
             wrkDetl.setZpallet(wrkMast.getBarcode());
             wrkDetl.setIoTime(now);
             wrkDetl.setWrkNo(workNo);
@@ -613,10 +602,10 @@
                 throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
             }
             // 淇敼璁㈠崟鏄庣粏
-            if (!orderDetlService.increaseWorkQty(orderDetl.getOrderId(), orderDetl.getMatnr(), orderDetl.getBatch(), locDto.getAnfme())) {
+            if (!orderDetlPakoutService.increaseWorkQty(orderDetlPakout.getOrderId(), orderDetlPakout.getMatnr(), orderDetlPakout.getBatch(), locDto.getAnfme())) {
                 throw new CoolException("淇敼璁㈠崟鏄庣粏鏁伴噺澶辫触");
             }
-            orderService.updateSettle(orderDetl.getOrderId(), 2L, userId);
+            orderPakoutService.updateSettle(orderDetlPakout.getOrderId(), 2L, userId);
         }
         // 淇敼搴撲綅鐘舵��:   F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害/P.鎷f枡/鐩樼偣/骞舵澘鍑哄簱涓�
         locMast = locMastService.selectById(taskDto.getLocNo());
@@ -1058,19 +1047,6 @@
             // 鐢熸垚宸ヤ綔妗f槑缁�
             for (LocDetlDto detlDto : dto.getLocDetlDtos()) {
 
-                InventoryCheckOrderDetl inventoryCheckOrderDetl = new InventoryCheckOrderDetl();
-                inventoryCheckOrderDetl.setOrderNo(param.getOrderNo());
-                inventoryCheckOrderDetl.setMatnr(detlDto.getLocDetl().getMatnr());
-                inventoryCheckOrderDetl.setMaktx(detlDto.getLocDetl().getMaktx());
-                inventoryCheckOrderDetl.setBatch(detlDto.getLocDetl().getBatch());
-                inventoryCheckOrderDetl.setLocNo(detlDto.getLocDetl().getLocNo());
-                inventoryCheckOrderDetl.setArea(detlDto.getLocDetl().getOrigin());
-                inventoryCheckOrderDetl.setAnfme(detlDto.getLocDetl().getAnfme());
-                inventoryCheckOrderDetl.setIoTime(now);
-                inventoryCheckOrderDetl.setStatus("1");
-                if (!inventoryCheckOrderDetlService.insert(inventoryCheckOrderDetl)) {
-                    throw new CoolException("淇濆瓨鐩樼偣鏄庣粏澶辫触");
-                }
 
                 if (detlDto.getCount() == null || detlDto.getCount() <= 0.0D) {
                     continue;
@@ -1196,7 +1172,7 @@
         if (Cools.isEmpty(wrkMast)) {
             throw new CoolException(workNo + "宸ヤ綔妗d笉瀛樺湪");
         }
-        if (wrkMast.getWrkSts() == 4 || wrkMast.getWrkSts() == 14) {
+        if (wrkMast.getWrkSts() == 4 || wrkMast.getWrkSts() == 5 || wrkMast.getWrkSts() == 14 || wrkMast.getWrkSts() == 15) {
             throw new CoolException("褰撳墠宸ヤ綔妗e凡瀹屾垚");
         }
         // 鍏ュ簱 + 搴撲綅杞Щ
@@ -1226,7 +1202,7 @@
         if (Cools.isEmpty(locMast)) {
             throw new CoolException("搴撲綅涓嶅瓨鍦�");
         }
-        if (!(locMast.getLocSts().equals("P") ||locMast.getLocSts().equals("F") || locMast.getLocSts().equals("D") || locMast.getLocSts().equals("O"))) {
+        if (!(locMast.getLocSts().equals("P") || locMast.getLocSts().equals("F") || locMast.getLocSts().equals("D") || locMast.getLocSts().equals("O"))) {
             throw new CoolException("褰撳墠搴撲綅涓嶅彲璋冩暣锛佸簱浣嶇姸鎬侊細" + locMast.getLocSts$());
         }
 
@@ -1338,7 +1314,7 @@
         }
         locMast.setModiUser(userId);
         locMast.setModiTime(now);
-        if (locMast.getLocSts().equals("O")){
+        if (locMast.getLocSts().equals("O")) {
             locMast.setBarcode("");
         }
         if (!locMastService.updateById(locMast)) {
@@ -1423,26 +1399,26 @@
             List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo());
             for (WrkDetl wrkDetl : wrkDetls) {
                 if (!Cools.isEmpty(wrkDetl.getOrderNo())) {
-                    if (!orderDetlService.decrease(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getAnfme())) {
+                    if (!orderDetlPakoutService.decrease(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getAnfme())) {
                         throw new CoolException("璁㈠崟鏁版嵁鍥炴粴澶辫触");
                     }
 
                     //淇敼璁㈠崟涓昏〃鐘舵��,娌℃湁浣滀笟鏁伴噺鏃舵墠鍙互淇敼
                     boolean flag = true;
-                    List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", wrkDetl.getOrderNo()));
-                    for (OrderDetl orderDetl : orderDetls) {
-                        if (orderDetl.getWorkQty() > 0) {
+                    List<OrderDetlPakout> orderDetlPakouts = orderDetlPakoutService.selectList(new EntityWrapper<OrderDetlPakout>().eq("order_no", wrkDetl.getOrderNo()));
+                    for (OrderDetlPakout orderDetlPakout : orderDetlPakouts) {
+                        if (orderDetlPakout.getWorkQty() > 0) {
                             flag = false;
                         }
                     }
                     if (flag) {
-                        Order order = orderService.selectOne(new EntityWrapper<Order>().eq("order_no", wrkDetl.getOrderNo()));
+                        OrderPakout order = orderPakoutService.selectOne(new EntityWrapper<OrderPakout>().eq("order_no", wrkDetl.getOrderNo()));
                         if (!Cools.isEmpty(order) && order.getSettle() == 2) {
                             order.setSettle(1L);
                             order.setUpdateBy(userId);
                             order.setUpdateTime(now);
                         }
-                        if (!orderService.update(order, new EntityWrapper<Order>().eq("order_no", wrkDetl.getOrderNo()))) {
+                        if (!orderPakoutService.update(order, new EntityWrapper<OrderPakout>().eq("order_no", wrkDetl.getOrderNo()))) {
                             throw new CoolException("淇敼璁㈠崟鐘舵�佸け璐�");
                         }
                     }
@@ -1799,10 +1775,10 @@
 //                    moveLocForDeepLoc(locMast1);
 //                }
 //            }
-            if ((locMast.getBay1() >= 3 && locMast.getBay1() <= 6) ) {
+            if ((locMast.getBay1() >= 3 && locMast.getBay1() <= 6)) {
                 locMasts = locMastService.selectList(new EntityWrapper<LocMast>()
                         .eq("row1", locMast.getBay1())
-                        .in("bay1", 3,4,5,6)
+                        .in("bay1", 3, 4, 5, 6)
                         .eq("crn_no", 7)
                         .eq("loc_type1", locMast.getLocType1())
                         .orderBy("bay1", true));

--
Gitblit v1.9.1