From 0e7e7b7935a47f17622500b76c24ac185e491486 Mon Sep 17 00:00:00 2001
From: zc <zc@123>
Date: 星期四, 24 四月 2025 10:48:38 +0800
Subject: [PATCH] 初步完成调试

---
 src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java |   98 ++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 85 insertions(+), 13 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 3f4ac35..237d191 100644
--- a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
@@ -181,6 +181,9 @@
         if (!locDetlDtos.isEmpty()) {
             LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", locDetlDtos.get(0).getLocDetl().getLocNo()));
             if (locMast.getLocSts().equals("F") || locMast.getLocSts().equals("D")) {
+                if (staNo.getDevNo() == 1135 && locMast.getLocType1() == 2) {
+                    throw new CoolException("鎵�閫夊簱浣嶄笉鏄綆搴撲綅鏃犳硶璋冩嫧锛屽簱浣嶅彿锛歿}" + locMast.getLocNo());
+                }
                 // 鍚姩鍑哄簱寮�濮� 101.鍑哄簱
                 stockOut(staNo, locDetlDtos, null, userId);
             } else {
@@ -228,6 +231,11 @@
             LocMast locMast = locMastService.selectById(dto.getLocNo());
 
             Integer outSta = staNo.getDevNo();
+            if (outSta == 1135 || outSta == 1031) {
+                if (101 != ioType) {
+                    throw new CoolException("璇ョ珯鐐瑰繀椤诲叏鏉垮嚭搴擄紝鍑哄簱搴撲綅鍙凤細" + dto.getLocNo());
+                }
+            }
 //            //2鍙峰爢鍨涙満鍏ㄦ澘鍑哄簱绔欐寚瀹氫负204绔欙紝鎷f枡绔欐寚瀹氫负202
 //            if(locMast.getCrnNo()==2){
 //                outSta = ioType == 101 ? 204 : 202;
@@ -1863,7 +1871,6 @@
 
     @Transactional
     public void toSxk(WrkMast wrkMastold, List<WrkDetl> wrkDetls, Short locType) {
-
         LocTypeDto locTypeDto = new LocTypeDto();
         locTypeDto.setLocType1(locType);
         StartupDto dto = commonService.getLocNo(1, 1031, null, null, null, locTypeDto, false);
@@ -1877,9 +1884,11 @@
         WrkMast wrkMast = new WrkMast();
         wrkMast.setWrkNo(workNo);
         wrkMast.setIoTime(new Date());
-        wrkMast.setWrkSts(1L); // 宸ヤ綔鐘舵�侊細1.鐢熸垚鍏ュ簱ID
-        wrkMast.setIoType(1); // 鍏ュ嚭搴撶姸鎬侊細 1.搴撴牸绉昏浇
+        wrkMast.setWrkSts(2L); // 宸ヤ綔鐘舵�侊細1.鐢熸垚鍏ュ簱ID
+        wrkMast.setIoType(wrkMastold.getIoType() - 100); // 鍏ュ嚭搴撶姸鎬侊細 1.搴撴牸绉昏浇
         wrkMast.setIoPri(12D);
+        wrkMast.setStaNo(1032);
+        wrkMast.setSourceStaNo(1031);
         wrkMast.setCrnNo(7);
         wrkMast.setLocNo(dto.getLocNo()); // 鐩爣搴撲綅
         wrkMast.setFullPlt("Y"); // 婊℃澘
@@ -1895,16 +1904,18 @@
             throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
         }
         // 宸ヤ綔妗f槑缁嗕繚瀛�
-        for (WrkDetl wrk : wrkDetls) {
-            WrkDetl wrkDetl = new WrkDetl();
-            Synchro.Copy(wrk, wrkDetl);
-            wrkDetl.setWrkNo(workNo);
-            wrkDetl.setIoTime(new Date());
-            wrkDetl.setAnfme(wrk.getAnfme());
-            wrkDetl.setAppeTime(new Date());
-            wrkDetl.setModiTime(new Date());
-            if (!wrkDetlService.insert(wrkDetl)) {
-                throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+        if (wrkDetls != null) {
+            for (WrkDetl wrk : wrkDetls) {
+                WrkDetl wrkDetl = new WrkDetl();
+                Synchro.Copy(wrk, wrkDetl);
+                wrkDetl.setWrkNo(workNo);
+                wrkDetl.setIoTime(new Date());
+                wrkDetl.setAnfme(wrk.getAnfme());
+                wrkDetl.setAppeTime(new Date());
+                wrkDetl.setModiTime(new Date());
+                if (!wrkDetlService.insert(wrkDetl)) {
+                    throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+                }
             }
         }
         // 淇敼鐩爣搴撲綅鐘舵��
@@ -1920,5 +1931,66 @@
 
     }
 
+    @Transactional
+    public void toCrn(WrkMast wrkMastold, List<WrkDetl> wrkDetls, Short locType) {
+        LocTypeDto locTypeDto = new LocTypeDto();
+        locTypeDto.setLocType1(locType);
+        StartupDto dto = commonService.getLocNo(1, 1135, null, null, null, locTypeDto, false);
+        if (Cools.isEmpty(dto)) {
+            throw new CoolException("鍘诲爢鍨涙満鏈壘鍒板簱浣�");
+        }
+        LocMast loc = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", dto.getLocNo()));
+        // 鑾峰彇宸ヤ綔鍙�
+        int workNo = commonService.getWorkNo(0);
+        // 淇濆瓨宸ヤ綔妗�
+        WrkMast wrkMast = new WrkMast();
+        wrkMast.setWrkNo(workNo);
+        wrkMast.setIoTime(new Date());
+        wrkMast.setWrkSts(1L); // 宸ヤ綔鐘舵�侊細1.鐢熸垚鍏ュ簱ID
+        wrkMast.setIoType(wrkMastold.getIoType() - 100);  // 鍏ュ嚭搴撶姸鎬侊細 1.鍏ュ簱
+        wrkMast.setIoPri(12D);
+        wrkMast.setCrnNo(1);
+        wrkMast.setStaNo(1131);
+        wrkMast.setSourceStaNo(1135);
+        wrkMast.setLocNo(dto.getLocNo()); // 鐩爣搴撲綅
+        wrkMast.setFullPlt(wrkDetls == null ? "N" : "Y"); // 婊℃澘
+        wrkMast.setPicking("N"); // 鎷f枡
+        wrkMast.setExitMk("N"); // 閫�鍑�
+        wrkMast.setEmptyMk(wrkDetls != null ? "N" : "Y"); // 绌烘澘
+        wrkMast.setBarcode(wrkMastold.getBarcode()); // 鎵樼洏鐮�
+        wrkMast.setLinkMis("N");
+        wrkMast.setAppeTime(new Date());
+        wrkMast.setModiTime(new Date());
+        boolean res = wrkMastService.insert(wrkMast);
+        if (!res) {
+            throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+        }
+        // 宸ヤ綔妗f槑缁嗕繚瀛�
+        if (wrkDetls != null) {
+            for (WrkDetl wrk : wrkDetls) {
+                WrkDetl wrkDetl = new WrkDetl();
+                Synchro.Copy(wrk, wrkDetl);
+                wrkDetl.setWrkNo(workNo);
+                wrkDetl.setIoTime(new Date());
+                wrkDetl.setAnfme(wrk.getAnfme());
+                wrkDetl.setAppeTime(new Date());
+                wrkDetl.setModiTime(new Date());
+                if (!wrkDetlService.insert(wrkDetl)) {
+                    throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+                }
+            }
+        }
+        // 淇敼鐩爣搴撲綅鐘舵��
+        if (loc.getLocSts().equals("O")) {
+            loc.setLocSts("S"); // S.鍏ュ簱棰勭害
+            loc.setModiTime(new Date());
+            if (!locMastService.updateById(loc)) {
+                throw new CoolException("鏇存柊鐩爣搴撲綅鐘舵�佸け璐�");
+            }
+        } else {
+            throw new CoolException("绉昏浆澶辫触");
+        }
+
+    }
 
 }

--
Gitblit v1.9.1