From cb98548ecc0fa2d4388eb67528b98be39670bc0c Mon Sep 17 00:00:00 2001
From: zyx <zyx123456>
Date: 星期四, 20 七月 2023 10:05:02 +0800
Subject: [PATCH] agv 有单入库功能

---
 src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java |  214 +++++++++++++++++++++++++++++++----------------------
 1 files changed, 125 insertions(+), 89 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
index 60f20e7..bf873fb 100644
--- a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
@@ -39,6 +39,9 @@
     private AgvBasDevpService agvBasDevpService;
 
 
+    /*
+    缁勬墭 + 缁戝畾鏆傚瓨浣�
+     */
     @Override
     @Transactional
     public String comb(CombParam param, Long userId) {
@@ -46,98 +49,18 @@
             throw new CoolException(BaseRes.PARAM);
         }
 
+        //妫�鏌ユ槸鍚﹀凡瀛樺湪鐩稿悓鐨勬墭鐩樻潯鐮侊紝瀛樺湪鍒欐姏鍑哄紓甯�
         if (agvWaitPakinService.selectCount(new EntityWrapper<AgvWaitPakin>().
                 eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) {
             throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱");
         }
 
-        Date now = new Date();
-        //鏃犲崟缁勬墭
         if (Cools.isEmpty(param.getOrderNo())) {
-            List<DetlDto> detlDtos = new ArrayList<>();
-            param.getCombMats().forEach(elem -> {
-                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme());
-                if (DetlDto.has(detlDtos, detlDto)) {
-                    DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch());
-                    assert one != null;
-                    one.setAnfme(one.getAnfme() + detlDto.getAnfme());
-                } else {
-                    detlDtos.add(detlDto);
-                }
-            });
-
-            detlDtos.forEach(detlDto -> {
-                Mat mat = matService.selectByMatnr(detlDto.getMatnr());
-                if (Cools.isEmpty(mat)) {
-                    throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
-                }
-                AgvWaitPakin waitPakin = new AgvWaitPakin();
-                waitPakin.setBatch(detlDto.getBatch());//鎵瑰彿
-
-                waitPakin.sync(mat);
-                waitPakin.setZpallet(param.getBarcode());   // 鎵樼洏鐮�
-                waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
-                waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
-                waitPakin.setStatus("Y");    // 鐘舵��
-                waitPakin.setAppeUser(userId);
-                waitPakin.setAppeTime(now);
-                waitPakin.setModiUser(userId);
-                waitPakin.setModiTime(now);
-                if (!agvWaitPakinService.insert(waitPakin)) {
-                    throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
-                }
-            });
+            //鏃犲崟缁勬墭
+            NoOrderComb(param,userId);
         }else {
-            //鍏宠仈缁勬墭
-            Order order = orderService.selectByNo(param.getOrderNo());
-            if (order.getSettle() > 2) {
-                throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�");
-            }
-            // 鐢熸垚鍏ュ簱閫氱煡妗�
-            List<DetlDto> detlDtos = new ArrayList<>();
-            param.getCombMats().forEach(elem -> {
-
-                // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙
-                OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), elem.getMatnr(), elem.getBatch());
-                if (elem.getAnfme() > orderDetl.getEnableQty()) {
-                    throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�");
-                }
-                // 淇敼璁㈠崟鏄庣粏鏁伴噺
-                if (!orderDetlService.increase(order.getId(), elem.getMatnr(), elem.getBatch(), elem.getAnfme())) {
-                    throw new CoolException("淇敼鍗曟嵁鏄庣粏鏁伴噺澶辫触");
-                }
-
-                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme());
-                if (DetlDto.has(detlDtos, detlDto)) {
-                    DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch());
-                    assert one != null;
-                    one.setAnfme(one.getAnfme() + detlDto.getAnfme());
-                } else {
-                    detlDtos.add(detlDto);
-                }
-            });
-            for (DetlDto detlDto : detlDtos) {
-                Mat mat = matService.selectByMatnr(detlDto.getMatnr());
-                if (Cools.isEmpty(mat)) {
-                    throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
-                }
-                AgvWaitPakin waitPakin = new AgvWaitPakin();
-                waitPakin.sync(mat);
-                waitPakin.setOrderNo(order.getOrderNo());   // 鍗曟嵁缂栧彿
-                waitPakin.setBatch(detlDto.getBatch());     // 搴忓垪鐮�
-                waitPakin.setZpallet(param.getBarcode());   // 鎵樼洏鐮�
-                waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
-                waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
-                waitPakin.setStatus("Y");    // 鐘舵��
-                waitPakin.setAppeUser(userId);
-                waitPakin.setAppeTime(now);
-                waitPakin.setModiUser(userId);
-                waitPakin.setModiTime(now);
-                if (!agvWaitPakinService.insert(waitPakin)) {
-                    throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
-                }
-            }
-            orderService.updateSettle(order.getId(), 2L, userId);
+            //鏈夊崟缁勬墭
+            OrderComb(param,userId);
         }
 
         if(StringUtils.isEmpty(param.getLocno())){
@@ -148,6 +71,114 @@
         }
 
     }
+
+    /*
+    AGV鏃犲崟缁勬墭
+     */
+    private void NoOrderComb(CombParam param, Long userId){
+        List<DetlDto> detlDtos = mappingDetlDtoByCombMat(param,null);
+
+        //鐢ㄤ簬缁熶竴涓�涓墭鐩樹笅鐨勫叆搴撻�氱煡妗g殑鐢熸垚鏃堕棿
+        Date now = new Date();
+        detlDtos.forEach(detlDto -> {
+            syncWaitPakin(detlDto,"",param.getBarcode(),userId,now);
+        });
+    }
+
+    /*
+    AGV鏈夊崟缁勬墭
+     */
+    private void OrderComb(CombParam param, Long userId){
+        //鍏宠仈缁勬墭
+        Order order = orderService.selectByNo(param.getOrderNo());
+        if(Cools.isEmpty(order)){
+            throw new CoolException("鍗曟嵁缂栧彿涓嶅瓨鍦�");
+        }
+        //璁㈠崟鐘舵��2浠ヤ笂涓哄畬鎴愭垨鑰呭彇娑堢殑璁㈠崟
+        if (order.getSettle() > 2) {
+            throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�");
+        }
+        // 鐢ㄤ簬鐢熸垚鍏ュ簱閫氱煡妗f墍闇�鍙傛暟
+        List<DetlDto> detlDtos = mappingDetlDtoByCombMat(param,order);
+        //鐢ㄤ簬缁熶竴涓�涓墭鐩樹笅鐨勫叆搴撻�氱煡妗g殑鐢熸垚鏃堕棿
+        Date now = new Date();
+        for (DetlDto detlDto : detlDtos) {
+            //鍚屾鐢熸垚鍏ュ簱閫氱煡妗�
+            syncWaitPakin(detlDto,order.getOrderNo(),param.getBarcode(),userId,now);
+        }
+        //淇敼鍗曟嵁鐘舵�佷负2.浣滀笟涓�
+        orderService.updateSettle(order.getId(), 2L, userId);
+    }
+
+    /*
+    鏍规嵁PDA鎵爜鎵�浼犵殑鐗╂枡淇℃伅鍙傛暟鏄犲皠涓篋etlDto
+     */
+    private List<DetlDto> mappingDetlDtoByCombMat(CombParam param, Order order){
+        List<DetlDto> detlDtos = new ArrayList<>();
+        param.getCombMats().forEach(combMat -> {
+
+            if(!Cools.isEmpty(order)){
+                //妫�鏌ュ叆搴撴暟閲�
+                checkOrderQty(order,combMat);
+            }
+
+            DetlDto detlDto = new DetlDto(combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme());
+            //鍚屼竴鎵樼洏涓嬬浉鍚岀墿鏂欎俊鎭拰鎵瑰彿杞负涓�涓叆搴撻�氱煡妗�
+            if (DetlDto.has(detlDtos, detlDto)) {
+                DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch());
+                assert one != null;
+                one.setAnfme(one.getAnfme() + detlDto.getAnfme());
+            } else {
+                detlDtos.add(detlDto);
+            }
+        });
+
+        return detlDtos;
+    }
+
+    /*
+    妫�鏌ュ叆搴撴暟閲忔槸鍚﹀皬浜庣瓑浜庡崟鎹暟閲忥紝鍚堢悊鍒欎慨鏀筄rderDetl浣滀笟鏁伴噺淇℃伅锛屽惁鍒欐姏鍑哄紓甯�
+     */
+    private void checkOrderQty(Order order, CombParam.CombMat combMat){
+        // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙锛屽鏋滀綔涓氭暟閲忓ぇ浜庡崟鎹暟閲忓垯鎶涘嚭寮傚父
+        OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), combMat.getMatnr(), combMat.getBatch());
+        if(Cools.isEmpty(orderDetl)){
+            throw new CoolException("鏈尮閰嶅埌璇ュ崟鎹笅鐨勭墿鏂�");
+        }
+        if (combMat.getAnfme() > orderDetl.getEnableQty()) {
+            throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�");
+        }
+        // 淇敼璁㈠崟鏄庣粏鏁伴噺
+        if (!orderDetlService.increase(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme())) {
+            throw new CoolException("淇敼鍗曟嵁鏄庣粏鏁伴噺澶辫触");
+        }
+    }
+
+    /*
+    鍚屾鐢熸垚AGV鍏ュ簱閫氱煡妗f暟鎹�
+     */
+    private void syncWaitPakin(DetlDto detlDto, String orderNo, String zpallet, Long userId, Date now ){
+        Mat mat = matService.selectByMatnr(detlDto.getMatnr());
+        if (Cools.isEmpty(mat)) {
+            throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
+        }
+        AgvWaitPakin waitPakin = new AgvWaitPakin();
+        waitPakin.sync(mat);
+        waitPakin.setOrderNo(orderNo);   // 鍗曟嵁缂栧彿
+        waitPakin.setBatch(detlDto.getBatch());     // 搴忓垪鐮�
+        waitPakin.setZpallet(zpallet);   // 鎵樼洏鐮�
+        waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
+        waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
+        waitPakin.setStatus("Y");    // 鐘舵��
+        waitPakin.setAppeUser(userId);
+        waitPakin.setAppeTime(now);
+        waitPakin.setModiUser(userId);
+        waitPakin.setModiTime(now);
+        if (!agvWaitPakinService.insert(waitPakin)) {
+            throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
+        }
+    }
+
 
     @Override
     @Transactional
@@ -163,9 +194,14 @@
 
     @Override
     public void combBinding(String barcode, String stationCode) {
-        EntityWrapper<AgvBasDevp> wrapper = new EntityWrapper<>();
-        wrapper.eq("dev_no",stationCode);
-        AgvBasDevp agvBasDevp = agvBasDevpService.selectOne(wrapper);
+
+        AgvBasDevp agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>().eq("barcode", barcode));
+
+        if(!Cools.isEmpty(agvBasDevp)){
+            throw new CoolException(barcode + "宸茬粡缁戝畾鍦�"+ agvBasDevp.getDevNo() +"绔欑偣");
+        }
+
+        agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>().eq("dev_no",stationCode));
         if(agvBasDevp == null){
             throw new CoolException(stationCode + "绔欑偣淇℃伅閿欒");
         }
@@ -175,7 +211,7 @@
 
         agvBasDevp.setBarcode(barcode);
         agvBasDevp.setLocSts("F");
-        agvBasDevpService.update(agvBasDevp,wrapper);
+        agvBasDevpService.update(agvBasDevp,(new EntityWrapper<AgvBasDevp>().eq("dev_no",stationCode)));
     }
 
     public List<AgvBasDevp> getAgvBasDevpByFloor(int floor) {

--
Gitblit v1.9.1