From b4fc2f5e7ce5f0e984f406c4bca23dd5044fdcec Mon Sep 17 00:00:00 2001
From: ZY <zc857179121@qq.com>
Date: 星期二, 01 四月 2025 13:35:38 +0800
Subject: [PATCH] 组托限制相同物料

---
 src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java |   82 ++++++++++++++++++++++------------------
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java      |   15 +++++--
 2 files changed, 56 insertions(+), 41 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 982fcbf..41918fd 100644
--- a/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/AgvMobileServiceImpl.java
@@ -15,9 +15,7 @@
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.StringUtils;
 
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
 import java.util.stream.Collectors;
 
 /**
@@ -60,27 +58,37 @@
         }
 
         //妫�鏌ュ簱瀛樻槸鍚︽湁鐩稿悓鏂欑锛屽瓨鍦ㄥ垯鎶涘嚭寮傚父
-        if(!Cools.isEmpty(agvLocDetlService.selectOne(new EntityWrapper<AgvLocDetl>().eq("supp_code",param.getBarcode())))){
+        if (!Cools.isEmpty(agvLocDetlService.selectOne(new EntityWrapper<AgvLocDetl>().eq("supp_code", param.getBarcode())))) {
             throw new CoolException(param.getBarcode() + "鏂欑鐮佸凡瀛樺湪AGV搴撳瓨鏄庣粏涓�");
         }
 
         //鏌ョ湅宸ヤ綔妗f槸鍚︽湁鐩稿悓鏂欑锛屽瓨鍦ㄥ垯鎶涘嚭寮傚父
-        if(!Cools.isEmpty(agvWrkMastService.selectByContainerCode(param.getBarcode()))){
+        if (!Cools.isEmpty(agvWrkMastService.selectByContainerCode(param.getBarcode()))) {
             throw new CoolException(param.getBarcode() + "鏂欑鐮佸凡瀛樺湪AGV宸ヤ綔妗d腑");
+        }
+        List<CombParam.CombMat> combMats = param.getCombMats();
+        Map<String, String> map = new HashMap<>();
+        for (CombParam.CombMat combMat : combMats) {
+            String batch = Cools.isEmpty(combMat.getBatch()) ? "" : combMat.getBatch();
+            if (!Cools.isEmpty(map.get(combMat.getMatnr() + batch))) {
+                throw new CoolException(param.getBarcode() + "缁勬墭鐨勭墿鏂欐槑缁嗛噸澶�,璇锋鏌ユ槸鍚﹂噸澶嶆壂鐮�");
+            } else {
+                map.put(combMat.getMatnr() + batch, combMat.getMatnr());
+            }
         }
 
         if (Cools.isEmpty(param.getOrderNo())) {
             //鏃犲崟缁勬墭
-            NoOrderComb(param,userId);
-        }else {
+            NoOrderComb(param, userId);
+        } else {
             //鏈夊崟缁勬墭
-            OrderComb(param,userId);
+            OrderComb(param, userId);
         }
 
-        if(StringUtils.isEmpty(param.getLocno())){
+        if (StringUtils.isEmpty(param.getLocno())) {
             return "缁勬墭鎴愬姛";
-        }else {
-            combBinding(param.getBarcode(),param.getLocno());
+        } else {
+            combBinding(param.getBarcode(), param.getLocno());
             return "缁勬墭鎴愬姛锛岀粦瀹氱珯鐐规垚鍔�";
         }
 
@@ -89,23 +97,23 @@
     /*
     AGV鏃犲崟缁勬墭
      */
-    private void NoOrderComb(CombParam param, Long userId){
-        List<DetlDto> detlDtos = mappingDetlDtoByCombMat(param,null);
+    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);
+            syncWaitPakin(detlDto, "", param.getBarcode(), userId, now);
         });
     }
 
     /*
     AGV鏈夊崟缁勬墭
      */
-    private void OrderComb(CombParam param, Long userId){
+    private void OrderComb(CombParam param, Long userId) {
         //鍏宠仈缁勬墭
         Order order = orderService.selectByNo(param.getOrderNo());
-        if(Cools.isEmpty(order)){
+        if (Cools.isEmpty(order)) {
             throw new CoolException("鍗曟嵁缂栧彿涓嶅瓨鍦�");
         }
         //璁㈠崟鐘舵��2浠ヤ笂涓哄畬鎴愭垨鑰呭彇娑堢殑璁㈠崟
@@ -113,12 +121,12 @@
             throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�");
         }
         // 鐢ㄤ簬鐢熸垚鍏ュ簱閫氱煡妗f墍闇�鍙傛暟
-        List<DetlDto> detlDtos = mappingDetlDtoByCombMat(param,order);
+        List<DetlDto> detlDtos = mappingDetlDtoByCombMat(param, order);
         //鐢ㄤ簬缁熶竴涓�涓墭鐩樹笅鐨勫叆搴撻�氱煡妗g殑鐢熸垚鏃堕棿
         Date now = new Date();
         for (DetlDto detlDto : detlDtos) {
             //鍚屾鐢熸垚鍏ュ簱閫氱煡妗�
-            syncWaitPakin(detlDto,order.getOrderNo(),param.getBarcode(),userId,now);
+            syncWaitPakin(detlDto, order.getOrderNo(), param.getBarcode(), userId, now);
         }
         //淇敼鍗曟嵁鐘舵�佷负2.浣滀笟涓�
         orderService.updateSettle(order.getId(), 2L, userId);
@@ -127,19 +135,19 @@
     /*
     鏍规嵁PDA鎵爜鎵�浼犵殑鐗╂枡淇℃伅鍙傛暟鏄犲皠涓篋etlDto
      */
-    private List<DetlDto> mappingDetlDtoByCombMat(CombParam param, Order order){
+    private List<DetlDto> mappingDetlDtoByCombMat(CombParam param, Order order) {
         List<DetlDto> detlDtos = new ArrayList<>();
         param.getCombMats().forEach(combMat -> {
 
-            if(!Cools.isEmpty(order)){
+            if (!Cools.isEmpty(order)) {
                 //妫�鏌ュ叆搴撴暟閲�
-                checkOrderQty(order,combMat);
+                checkOrderQty(order, combMat);
             }
 
-            DetlDto detlDto = new DetlDto(combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme(), combMat.getCsocode(), combMat.getIsoseq(),combMat.getContainerCode());
+            DetlDto detlDto = new DetlDto(combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme(), combMat.getCsocode(), combMat.getIsoseq(), combMat.getContainerCode());
             //鍚屼竴鎵樼洏涓嬬浉鍚岀墿鏂欎俊鎭拰鎵瑰彿杞负涓�涓叆搴撻�氱煡妗�
             if (DetlDto.has(detlDtos, detlDto)) {
-                DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch(), detlDto.getCsocode(), detlDto.getIsoseq(),null);
+                DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch(), detlDto.getCsocode(), detlDto.getIsoseq(), null);
                 assert one != null;
                 one.setAnfme(one.getAnfme() + detlDto.getAnfme());
             } else {
@@ -153,17 +161,17 @@
     /*
     妫�鏌ュ叆搴撴暟閲忔槸鍚﹀皬浜庣瓑浜庡崟鎹暟閲忥紝鍚堢悊鍒欎慨鏀筄rderDetl浣滀笟鏁伴噺淇℃伅锛屽惁鍒欐姏鍑哄紓甯�
      */
-    private void checkOrderQty(Order order, CombParam.CombMat combMat){
+    private void checkOrderQty(Order order, CombParam.CombMat combMat) {
         // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙锛屽鏋滀綔涓氭暟閲忓ぇ浜庡崟鎹暟閲忓垯鎶涘嚭寮傚父
-        OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getCsocode(),combMat.getIsoseq());
-        if(Cools.isEmpty(orderDetl)){
+        OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getCsocode(), combMat.getIsoseq());
+        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(), combMat.getCsocode(),combMat.getIsoseq())) {
+        if (!orderDetlService.increase(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme(), combMat.getCsocode(), combMat.getIsoseq())) {
             throw new CoolException("淇敼鍗曟嵁鏄庣粏鏁伴噺澶辫触");
         }
     }
@@ -171,7 +179,7 @@
     /*
     鍚屾鐢熸垚AGV鍏ュ簱閫氱煡妗f暟鎹�
      */
-    private void syncWaitPakin(DetlDto detlDto, String orderNo, String zpallet, Long userId, Date now ){
+    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涓嶅瓨鍦�");
@@ -217,36 +225,36 @@
     @Override
     public void combBinding(String barcode, String stationCode) {
 
-        if(Cools.isEmpty(agvWaitPakinService.selectByContainerCode(barcode))){
+        if (Cools.isEmpty(agvWaitPakinService.selectByContainerCode(barcode))) {
             throw new CoolException("璇ユ枡绠辨湭缁勬墭锛屾棤娉曠粦瀹氱珯鐐�");
         }
 
         AgvBasDevp agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>().eq("barcode", barcode));
 
-        if(!Cools.isEmpty(agvBasDevp)){
-            throw new CoolException(barcode + "宸茬粡缁戝畾鍦�"+ agvBasDevp.getDevNo() +"绔欑偣");
+        if (!Cools.isEmpty(agvBasDevp)) {
+            throw new CoolException(barcode + "宸茬粡缁戝畾鍦�" + agvBasDevp.getDevNo() + "绔欑偣");
         }
 
-        agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>().eq("dev_no",stationCode));
-        if(agvBasDevp == null){
+        agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>().eq("dev_no", stationCode));
+        if (agvBasDevp == null) {
             throw new CoolException(stationCode + "绔欑偣淇℃伅閿欒");
         }
-        if(!"O".equals(agvBasDevp.getLocSts())){
+        if (!"O".equals(agvBasDevp.getLocSts())) {
             throw new CoolException(stationCode + "璇ョ珯鐐硅揣浣嶇姸鎬侀潪绌�");
         }
         AgvWrkMast agvWrkMast = agvWrkMastService.selectOne(new EntityWrapper<AgvWrkMast>().eq("loc_no", agvBasDevp.getDevNo()));
-        if(!Cools.isEmpty(agvWrkMast)){
+        if (!Cools.isEmpty(agvWrkMast)) {
             throw new CoolException(stationCode + "璇ョ珯鐐瑰凡琚伐浣滃彿涓�" + agvWrkMast.getWrkNo() + "鍗犵敤锛屾棤娉曠粦瀹�");
         }
 
         agvBasDevp.setBarcode(barcode);
         agvBasDevp.setLocSts("F");
-        agvBasDevpService.update(agvBasDevp,(new EntityWrapper<AgvBasDevp>().eq("dev_no",stationCode)));
+        agvBasDevpService.update(agvBasDevp, (new EntityWrapper<AgvBasDevp>().eq("dev_no", stationCode)));
     }
 
     public List<AgvBasDevp> getAgvBasDevpByFloor(int floor) {
         EntityWrapper<AgvBasDevp> wrapper = new EntityWrapper<>();
-        wrapper.eq("floor",floor).eq("cache_shelves","Y").eq("loc_sts","F");
+        wrapper.eq("floor", floor).eq("cache_shelves", "Y").eq("loc_sts", "F");
         List<AgvBasDevp> agvBasDevpList = agvBasDevpService.selectList(wrapper);
         return agvBasDevpList.stream().filter(agvBasDevp -> {
             return !Cools.isEmpty(agvWaitPakinService.selectByContainerCode(agvBasDevp.getBarcode()));
diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
index 536b54f..bbf8a2e 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -22,10 +22,7 @@
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.StringUtils;
 
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * Created by vincent on 2022/4/9
@@ -525,6 +522,16 @@
             callApiLogSaveMES(param, null, param.getBarcode() + "锛氬伐浣滄槑缁嗘。宸插瓨鍦ㄦ鏁版嵁", false);
             throw new CoolException("宸ヤ綔鏄庣粏妗e凡瀛樺湪姝ゆ暟鎹�===>>" + param.getBarcode());
         }
+        List<CombParam.CombMat> combMats = param.getCombMats();
+        Map<String, String> map = new HashMap<>();
+        for (CombParam.CombMat combMat : combMats) {
+            String batch = Cools.isEmpty(combMat.getBatch()) ? "" : combMat.getBatch();
+            if (!Cools.isEmpty(map.get(combMat.getMatnr() + batch))) {
+                throw new CoolException(param.getBarcode() + "缁勬墭鐨勭墿鏂欐槑缁嗛噸澶�,璇锋鏌ユ槸鍚﹂噸澶嶆壂鐮�");
+            } else {
+                map.put(combMat.getMatnr() + batch, combMat.getMatnr());
+            }
+        }
 
         Date now = new Date();
         try{

--
Gitblit v1.9.1