From f2830fa9a99dd5bb0bca1f540c5124004cd4516d Mon Sep 17 00:00:00 2001
From: zyx <zyx123456>
Date: 星期二, 20 二月 2024 15:15:05 +0800
Subject: [PATCH] bug修复 四项库作业数量重复

---
 src/main/java/com/zy/common/service/AgvCommonService.java |   71 ++++++++++++++++++++++++++---------
 1 files changed, 53 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/zy/common/service/AgvCommonService.java b/src/main/java/com/zy/common/service/AgvCommonService.java
index 1f21122..8684a32 100644
--- a/src/main/java/com/zy/common/service/AgvCommonService.java
+++ b/src/main/java/com/zy/common/service/AgvCommonService.java
@@ -29,6 +29,8 @@
     private AgvLocMastService agvLocMastService;
     @Autowired
     private MatService matService;
+    @Autowired
+    private LocRuleService locRuleService;
 
     public int getWorkNo(Integer wrkMk) {
         AgvWrkLastno wrkLastno = agvWrkLastnoService.selectById(wrkMk);
@@ -72,13 +74,21 @@
     public AgvLocMast getLocNo(List<AgvWaitPakin> agvWaitPakinList, int floor) {
         // 鐩爣搴撲綅
         AgvLocMast locMast = null;
+        if(Cools.isEmpty(agvWaitPakinList)){
+            return getLocNoRule(floor);
+        }
 
         //搴撲綅瑙勫垯
-        if(!Cools.isEmpty(agvWaitPakinList)){
-            locMast = getLocByLocRule(agvWaitPakinList.get(0),floor);
-            if(!Cools.isEmpty(locMast)){
-                return locMast;
-            }
+        locMast = getLocByLocRule(agvWaitPakinList.get(0),floor);
+        if(!Cools.isEmpty(locMast)){
+            return locMast;
+        }
+
+
+        //搴撲綅缂栫爜瑙勫垯
+        locMast = getLocByLocCodeRule(agvWaitPakinList.get(0),floor);
+        if(!Cools.isEmpty(locMast)){
+            return locMast;
         }
 
         // 闈犺繎鎽嗘斁瑙勫垯 --- 鐩稿悓璁㈠崟鍙�, 鍚屽ぉ鍚岃鏍肩墿鏂�
@@ -90,21 +100,15 @@
 
         //鏍规嵁鐗╂枡棰戠巼鎼滅储搴撲綅锛岄鐜囬珮鍒欐悳绱㈢缂撳瓨璐ф灦鏈�杩戝簱浣嶏紝棰戠巼浣庡垯鎼滅储鏈�杩滃簱浣�
         Mat mat = matService.selectByMatnr(agvWaitPakinList.get(0).getMatnr());
-        if(true){
-
-        }else {
-
+        if(Cools.isEmpty(mat.getBeBatch())){
+            mat.setBeBatch(0);
+        }
+        locMast = getLocByFre(mat.getBeBatch(), floor);
+        if (locMast != null) {
+            return locMast;
         }
 
-//
-//        // 闈犺繎鎽嗘斁瑙勫垯 --- 绌烘墭
-//        locMast = getLocNoStep4(staDescId, locTypeDto);
-//        if (locMast != null) {
-//            //鎵惧埌搴撲綅锛岃繑鍥瀌to
-//            return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto
-//        }
-//
-//        // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋�
+
         // 寮�濮嬫煡鎵惧簱浣� ==============================>>
         locMast = getLocNoRule(floor);
         if (locMast != null) {
@@ -150,6 +154,37 @@
     }
 
     /*
+    搴撲綅瑙勫垯鏌ユ壘
+     */
+    private AgvLocMast getLocByLocCodeRule(AgvWaitPakin agvWaitPakin, int floor) {
+        if(Cools.isEmpty(agvWaitPakin.getBrand())){
+            return null;
+        }
+
+        //搴撳尯
+        String other = "agv-" + floor;
+        List<LocRule> locRules = locRuleService.findCode(agvWaitPakin.getMatnr(), other);
+        if(Cools.isEmpty(locRules)){
+            return null;
+        }
+
+        for (LocRule agvLocRule : locRules) {
+            EntityWrapper<AgvLocMast> wrapper = new EntityWrapper<>();
+            wrapper.between("row1",agvLocRule.getRowBeg(),agvLocRule.getRowEnd())
+                    .between("bay1",agvLocRule.getBayBeg(),agvLocRule.getBayEnd())
+                    .between("lev1",agvLocRule.getLevBeg(),agvLocRule.getLevEnd())
+                    .eq("floor",floor)
+                    .eq("loc_sts","O");
+            AgvLocMast agvLocMast = agvLocMastService.selectOne(wrapper);
+            if(!Cools.isEmpty(agvLocMast)){
+                return agvLocMast;
+            }
+        }
+
+        return null;
+    }
+
+    /*
     闈犺繎鎽嗘斁瑙勫垯
      */
     private AgvLocMast getLocByProximityRule(){

--
Gitblit v1.9.1