From d382ffad92c48f6a96bb7d5e1fd733b90c9ca137 Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期六, 03 六月 2023 09:50:38 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java |   79 +++++++++++++++++++++++++++++++++++++--
 1 files changed, 74 insertions(+), 5 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 45a92f5..e104b23 100644
--- a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java
@@ -74,6 +74,8 @@
     @Autowired
     private WcsController wcsController;
     @Autowired
+    private WaitPakinService waitPakinService;
+    @Autowired
     private RowLastnoService rowLastnoService;
     @Autowired
     private SlaveProperties slaveProperties;
@@ -159,13 +161,55 @@
     @Override
     @Transactional
     public void startupFullTakeStore(StockOutParam param, Long userId) {
-        ArrayList<String> locNos = new ArrayList<>();
-        for (StockOutParam.LocDetl locDetl:param.getLocDetls()){
-            if (!locNos.contains(locDetl.getLocNo())){
-                locNos.add(locDetl.getLocNo());
+        List<StockOutParam.LocDetl> locDetls = new ArrayList<>();
+
+        //鍑哄簱鏃讹紝濡傛灉褰撳墠搴撲綅缁勬湁鐩稿悓鐨勭墿鏂欙紝鍒欏厛鍑哄渚х墿鏂�
+        for (StockOutParam.LocDetl locDetl : param.getLocDetls()) {
+            List<String> outerSingleLoc = Utils.getGroupOuterSingleLoc(locDetl.getLocNo());
+            outerSingleLoc.add(locDetl.getLocNo());
+            boolean flag = false;
+            Double useCount = 0D;
+            for (String locNo : outerSingleLoc) {
+                for (LocDetl locDetl0 : locDetlService.selectByLocNo(locNo)) {
+                    if (!locDetl0.getMatnr().equals(locDetl.getMatnr())) {
+                        //涓嶆槸鐩稿悓鐗╂枡
+                        continue;
+                    }
+                    double lastCount = locDetl.getCount() - useCount;//鍓╀綑鎵�闇�鏁伴噺
+                    double realCount = 0;//瀹為檯鎻愪緵鏁伴噺
+                    if (locDetl0.getAnfme() >= lastCount) {//瀹為檯鏁伴噺澶т簬鎵�闇�鏁伴噺锛屾寜鎵�闇�鏁伴噺鎻愪緵
+                        realCount = lastCount;
+                    } else {
+                        //瀹為檯灏忎簬鎵�闇�鏁伴噺锛屾寜瀹為檯鏁伴噺鎻愪緵
+                        realCount = locDetl0.getAnfme();
+                    }
+                    useCount += realCount;//宸蹭娇鐢ㄧ殑鏁伴噺
+
+                    locDetls.add(new StockOutParam.LocDetl(locDetl0.getLocNo(), locDetl.getMatnr(), locDetl.getBatch(), realCount));
+                    flag = true;
+                    if (useCount >= locDetl.getCount()) {
+                        //鎵惧埌鐨勫簱瀛� >= 鎵�闇�搴撳瓨锛屾弧瓒虫潯浠�
+                        break;
+                    }
+                }
             }
+
+            if (!flag) {
+                locDetls.add(locDetl);
+            }
+
         }
-        List<StockOutParam.LocDetl> locDetls = param.getLocDetls();
+
+//        ArrayList<String> locNos = new ArrayList<>();
+//        for (StockOutParam.LocDetl locDetl:param.getLocDetls()){
+//            if (!locNos.contains(locDetl.getLocNo())){
+//                locNos.add(locDetl.getLocNo());
+//            }
+//        }
+//        List<StockOutParam.LocDetl> locDetls = param.getLocDetls();
+
+
+
 //        ArrayList<String> locNos = new ArrayList<>();
 //        List<StockOutParam.LocDetl> locDetls = new ArrayList<>();
 //        ArrayList<String> matnrs = new ArrayList<>();//鐩殑鍋氭暟鎹幓閲�
@@ -480,8 +524,32 @@
                         wrkDetl.setModiUser(userId);
                         wrkDetl.setSpecs(locDetl.getSpecs());
                         wrkDetl.setMatType(locDetl.getMatType());
+                        wrkDetl.setZpallet(locMast.getBarcode());
                         if (!wrkDetlService.insert(wrkDetl)) {
                             throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
+                        }
+
+                        Mat mat = matService.selectByMatnr(locDetl.getMatnr());
+                        if (Cools.isEmpty(mat)) {
+                            throw new CoolException(locDetl.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
+                        }
+                        WaitPakin waitPakin = new WaitPakin();
+                        waitPakin.sync(mat);
+                        waitPakin.setBatch("");
+                        waitPakin.setZpallet(locMast.getBarcode());   // 鎵樼洏鐮�
+                        waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
+                        waitPakin.setAnfme(locDetl.getAnfme());  // 鏁伴噺
+                        waitPakin.setStatus("Y");    // 鐘舵��
+                        waitPakin.setAppeUser(userId);
+                        waitPakin.setAppeTime(now);
+                        waitPakin.setModiUser(userId);
+                        waitPakin.setModiTime(now);
+                        waitPakin.setMemo(locDetl.getMemo());
+                        waitPakin.setFrozen(0); // 鏄惁鍐荤粨
+                        waitPakin.setManu(locDetl.getManu());
+                        waitPakin.setMatType(mat.getMatType());//鐗╂枡绫诲瀷
+                        if (!waitPakinService.insert(waitPakin)) {
+                            throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
                         }
                     }
                     // 淇敼搴撲綅鐘舵��:   F.鍦ㄥ簱 ====>>> R.鍑哄簱棰勭害
@@ -573,6 +641,7 @@
                 wrkDetl.setModiUser(userId);
                 wrkDetl.setSpecs(detlDto.getLocDetl().getSpecs());
                 wrkDetl.setMatType(detlDto.getLocDetl().getMatType());
+                wrkDetl.setZpallet(locMast.getBarcode());
                 if (!wrkDetlService.insert(wrkDetl)) {
                     throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�");
                 }

--
Gitblit v1.9.1