From 3c1e34e86e18224acf34883039f7c31cab5a3d4d Mon Sep 17 00:00:00 2001
From: zyx <zyx123456>
Date: 星期二, 19 九月 2023 16:28:44 +0800
Subject: [PATCH] 平库增加

---
 src/main/java/com/zy/common/service/CommonService.java |   80 ++++++++++++++++++++++++---------------
 1 files changed, 49 insertions(+), 31 deletions(-)

diff --git a/src/main/java/com/zy/common/service/CommonService.java b/src/main/java/com/zy/common/service/CommonService.java
index d62cd45..ed76694 100644
--- a/src/main/java/com/zy/common/service/CommonService.java
+++ b/src/main/java/com/zy/common/service/CommonService.java
@@ -144,6 +144,8 @@
             //鎵惧埌搴撲綅锛岃繑鍥瀌to
             return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto
         }
+        // 鏍规嵁鐗╂枡棰戠巼鏌ヨ搴撲綅
+
 
         // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋�
         // 寮�濮嬫煡鎵惧簱浣� ==============================>>
@@ -161,8 +163,6 @@
      * 娣疯浇鎵惧簱浣�
      */
     private LocMast getLocNoStep1(List<String> matNos, LocTypeDto locTypeDto) {
-        LocMast locMast = null;
-
         //鍒ゆ柇褰撳墠璐х墿鏄惁涓烘贩杞借揣鐗�
         String firstMatNos = matNos.get(0);
         boolean mixed = false;//榛樿涓嶆槸娣疯浇璐х墿
@@ -174,41 +174,44 @@
         }
 
         if (!mixed) {
-            return locMast;//涓嶆槸娣疯浇璐х墿锛岀洿鎺ヨ烦鍑哄綋鍓嶄换鍔�
+            return null;//涓嶆槸娣疯浇璐х墿锛岀洿鎺ヨ烦鍑哄綋鍓嶄换鍔�
         }
 
         // 鎵炬贩杞藉簱浣嶈鍒�
-        LocRule locRule = locRuleService.findMixed();
-        if (locRule == null) {
-            return locMast;//娌℃湁娣疯浇瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔�
+        List<LocRule> locRules = locRuleService.findMixed();
+        if (locRules == null || locRules.size() == 0) {
+            return null;//娌℃湁娣疯浇瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔�
         }
 
-        //灏嗗簱浣嶈鍒欑粍杞崲涓哄簱浣嶇粍
-        List<LocMast> locMasts = locRuleService.locRuleToLocNos(locRule);
-        if (locMasts == null || locMasts.size() == 0) {
-            if (locRule.getKeepGo() == 0) {
-                //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣�
-                //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父
-                throw new CoolException("娣疯浇鍖哄煙娌℃湁绌哄簱浣�");
+        for (LocRule locRule : locRules) {
+            if (locRule == null) {
+                continue;
             }
-            return locMast;//娌℃湁娣疯浇瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔�
-        }
 
-        for (LocMast one : locMasts) {
-            LocMast locMast0 = locMastService.findOutMost(one.getLocNo());
-            if (null != locMast0) {
-                // 娴呭簱浣嶇鍚堝昂瀵告娴�
-                if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) {
-                    // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
-                    if (locMastService.checkEmptyCount(locMast0, 10)) {
-                        locMast = locMast0;
-                        break;
+            List<LocMast> locMasts = locMastService.queryFreeLocMast2(locTypeDto.getLocType1(), locRule.getRowBeg(), locRule.getRowEnd(), locRule.getBayBeg(), locRule.getBayEnd(), locRule.getLevBeg(), locRule.getLevEnd());
+
+            for (LocMast one : locMasts) {
+                LocMast locMast0 = locMastService.findOutMost(one.getLocNo());
+                if (null != locMast0) {
+                    // 娴呭簱浣嶇鍚堝昂瀵告娴�
+                    if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) {
+                        // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
+                        if (locMastService.checkEmptyCount(locMast0, 10)) {
+                            return locMast0;//鎵惧埌绌轰綑鐨勬贩杞藉簱浣�
+                        }
                     }
                 }
             }
+
         }
 
-        return locMast;
+        if (locRules.get(0).getKeepGo() == 0) {
+            //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣�
+            //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父
+            throw new CoolException("娣疯浇鍖哄煙娌℃湁绌哄簱浣�");
+        }
+
+        return null;
     }
 
     /**
@@ -217,8 +220,16 @@
     private LocMast getLocNoStep2(List<String> matNos, LocTypeDto locTypeDto) {
         LocMast locMast = null;
         // 搴撳尯閿佸畾
-        LocRule locRule = locRuleService.find(Cools.isEmpty(matNos) ? null : matNos.get(0));
-        if (!Cools.isEmpty(locRule)) {
+        List<LocRule> locRules = locRuleService.find(Cools.isEmpty(matNos) ? null : matNos.get(0));
+        if (locRules == null || locRules.size() == 0) {
+            return null;//娌℃湁搴撲綅瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔�
+        }
+
+        for (LocRule locRule : locRules) {
+            if (locRule == null) {
+                continue;
+            }
+
             List<LocMast> locMasts = locMastService.queryFreeLocMast2(locTypeDto.getLocType1(), locRule.getRowBeg(), locRule.getRowEnd(), locRule.getBayBeg(), locRule.getBayEnd(), locRule.getLevBeg(), locRule.getLevEnd());
             for (LocMast one : locMasts) {
                 LocMast locMast0 = locMastService.findOutMost(one.getLocNo());
@@ -227,13 +238,19 @@
                     if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) {
                         // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
                         if (locMastService.checkEmptyCount(locMast0, 10)) {
-                            locMast = locMast0;
-                            break;
+                            return locMast0;
                         }
                     }
                 }
             }
         }
+
+        if (locRules.get(0).getKeepGo() == 0) {
+            //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣�
+            //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父
+            throw new CoolException("瑙勫垯鍖哄煙娌℃湁绌哄簱浣�");
+        }
+
         return locMast;
     }
 
@@ -337,11 +354,12 @@
     //杩斿洖dto
     private StartupDto getLocNoStep6(Integer staDescId, Integer sourceStaNo, LocMast locMast) {
         StartupDto startupDto = new StartupDto();
-
+        String locNo = locMast.getLocNo();
         // 鑾峰彇鐩爣绔�
         Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>()
                 .eq("type_no", staDescId)
-                .eq("stn_no", sourceStaNo);
+                .eq("stn_no", sourceStaNo)
+                .eq("crn_no",Utils.getLev(locNo));//鍊熺敤鍫嗗灈鏈哄彿瀛楁鍏呭綋妤煎眰鍙�
         StaDesc staDesc = staDescService.selectOne(wrapper);
         if (Cools.isEmpty(staDesc)) {
             log.error("鍏ュ簱璺緞涓嶅瓨鍦�, staDescId={}, sourceStaNo={}", staDescId, sourceStaNo);

--
Gitblit v1.9.1