From 7343e9005cbe2b5a914d99154c01acacbeb7aa16 Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期六, 07 十月 2023 12:53:27 +0800 Subject: [PATCH] #新增许可证 --- src/main/java/com/zy/common/service/CommonService.java | 194 +++++++++++++++++++++--------------------------- 1 files changed, 86 insertions(+), 108 deletions(-) diff --git a/src/main/java/com/zy/common/service/CommonService.java b/src/main/java/com/zy/common/service/CommonService.java index af0d55d..0f568d3 100644 --- a/src/main/java/com/zy/common/service/CommonService.java +++ b/src/main/java/com/zy/common/service/CommonService.java @@ -129,15 +129,15 @@ // 鐩爣搴撲綅 LocMast locMast = null; - //娣疯浇鎵惧簱浣� - locMast = getLocNoStep1(matNos, locTypeDto); + // 闈犺繎鎽嗘斁瑙勫垯 --- 绌烘墭 + locMast = getLocNoStep4(staDescId, locTypeDto); if (locMast != null) { //鎵惧埌搴撲綅锛岃繑鍥瀌to return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto } //搴撲綅瑙勫垯 - locMast = getLocNoStep2(matNos, locTypeDto); + locMast = getLocNoStepRule(matNos, locTypeDto); if (locMast != null) { //鎵惧埌搴撲綅锛岃繑鍥瀌to return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto @@ -150,18 +150,15 @@ return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto } - // 闈犺繎鎽嗘斁瑙勫垯 --- 绌烘墭 - locMast = getLocNoStep4(staDescId, locTypeDto); + //鎼滅储鍗曞搧 + locMast = getLocNoStepSingle(matNos, locTypeDto); if (locMast != null) { //鎵惧埌搴撲綅锛岃繑鍥瀌to return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto } - // 鏍规嵁鐗╂枡棰戠巼鏌ヨ搴撲綅 - - // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋� - // 寮�濮嬫煡鎵惧簱浣� ==============================>> - locMast = getLocNoStep5(locTypeDto, times); + //鎼滅储娣锋斁 + locMast = getLocNoStepMixed(matNos, locTypeDto, times); if (locMast != null) { //鎵惧埌搴撲綅锛岃繑鍥瀌to return getLocNoStep6(staDescId, sourceStaNo, locMast);//杩斿洖dto @@ -172,95 +169,38 @@ } /** - * 娣疯浇鎵惧簱浣� - */ - private LocMast getLocNoStep1(List<String> matNos, LocTypeDto locTypeDto) { - //鍒ゆ柇褰撳墠璐х墿鏄惁涓烘贩杞借揣鐗� - String firstMatNos = matNos.get(0); - boolean mixed = false;//榛樿涓嶆槸娣疯浇璐х墿 - for (String matNo : matNos) { - if (!firstMatNos.equals(matNo)) { - mixed = true;//娣疯浇璐х墿 - break; - } - } - - if (!mixed) { - return null;//涓嶆槸娣疯浇璐х墿锛岀洿鎺ヨ烦鍑哄綋鍓嶄换鍔� - } - - // 鎵炬贩杞藉簱浣嶈鍒� - List<LocRule> locRules = locRuleService.findMixed(); - 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()); - if (null != locMast0) { - // 娴呭簱浣嶇鍚堝昂瀵告娴� - if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { - // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣� - if (locMastService.checkEmptyCount(locMast0, 10)) { - return locMast0;//鎵惧埌绌轰綑鐨勬贩杞藉簱浣� - } - } - } - } - - } - - if (locRules.get(0).getKeepGo() == 0) { - //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣� - //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父 - throw new CoolException("娣疯浇鍖哄煙娌℃湁绌哄簱浣�"); - } - - return null; - } - - /** * 搴撲綅瑙勫垯 */ - private LocMast getLocNoStep2(List<String> matNos, LocTypeDto locTypeDto) { + private LocMast getLocNoStepRule(List<String> matNos, LocTypeDto locTypeDto) { LocMast locMast = null; - // 搴撳尯閿佸畾 - 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; + //搴撲綅瑙勫垯鍙兘鍦ㄥ崟鍝佽揣鐗╀腑鐢熸晥 + if (matNos.size() == 1) { + // 搴撳尯閿佸畾 + List<LocRule> locRules = locRuleService.find(Cools.isEmpty(matNos) ? null : matNos.get(0)); + if (locRules == null || locRules.isEmpty()) { + return null;//娌℃湁搴撲綅瑙勫垯锛岃烦鍑哄綋鍓嶄换鍔� } - 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; - } + 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 locMast0 : locMasts) { + //棰勭暀绌哄簱浣� + if (locMastService.checkEmptyCount(locMast0, 10)) { + return locMast0; } } } - } - if (locRules.get(0).getKeepGo() == 0) { - //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣� - //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父 - throw new CoolException("瑙勫垯鍖哄煙娌℃湁绌哄簱浣�"); + if (locRules.get(0).getKeepGo() == 0) { + //鎵句笉鍒扮┖搴撲綅锛屼笖绂佹缁х画瀵绘壘鍏朵粬闈炴贩杞藉尯鍩熷簱浣� + //鎵句笉鍒板簱浣嶏紝鎶涘嚭寮傚父 + throw new CoolException("瑙勫垯鍖哄煙娌℃湁绌哄簱浣�"); + } } return locMast; @@ -276,7 +216,7 @@ LocMast locMast0 = locMastService.findNearloc(wrkMast.getLocNo()); if (null != locMast0) { // 娴呭簱浣嶇鍚堝昂瀵告娴� - if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { + if (VersionUtils.checkLocType(locMast0, locTypeDto)) { locMast = locMast0; } } @@ -288,7 +228,7 @@ LocMast locMast0 = locMastService.findNearloc(locNo); if (null != locMast0) { // 娴呭簱浣嶇鍚堝昂瀵告娴� - if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { + if (VersionUtils.checkLocType(locMast0, locTypeDto)) { locMast = locMast0; break; } @@ -311,7 +251,7 @@ LocMast locMast0 = locMastService.findNearloc(wrkMast.getLocNo()); if (null != locMast0) { // 娴呭簱浣嶇鍚堝昂瀵告娴� - if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { + if (VersionUtils.checkLocType(locMast0, locTypeDto)) { locMast = locMast0; break; } @@ -319,13 +259,13 @@ } if (Cools.isEmpty(locMast)){ List<LocMast> locMasts = locMastService.selectList(new EntityWrapper<LocMast>() - .eq("loc_sts", "D")); + .eq("loc_sts", "O")); if (locMasts.size() > 0) { for (LocMast loc : locMasts) { LocMast locMast0 = locMastService.findNearloc(loc.getLocNo()); if (null != locMast0) { // 娴呭簱浣嶇鍚堝昂瀵告娴� - if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) { + if (VersionUtils.checkLocType(locMast0, locTypeDto)) { locMast = locMast0; break; } @@ -338,26 +278,64 @@ return locMast; } - // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋� - private LocMast getLocNoStep5(LocTypeDto locTypeDto, int times) { + // 鎼滅储娣锋斁 + private LocMast getLocNoStepMixed(List<String> matNos, LocTypeDto locTypeDto, int times) { LocMast locMast = null; - // 1.褰撴绱㈠簱鎺掍负娴呭簱浣嶆帓鏃讹紝浼樺厛瀵绘壘褰撳墠搴撴帓鐨勬繁搴撲綅鎺� - List<LocMast> peakLocs = locMastService.selectAllPeakLoc(); - for (LocMast peakLoc : peakLocs) { - List<String> groupInsideLoc = Utils.getGroupInsideLoc(peakLoc.getLocNo()); - if (!Cools.isEmpty(groupInsideLoc)) { - if (!locMastService.checkAllLocEmpty(groupInsideLoc)) continue; - locMast = peakLoc; - break; - } else { - locMast = peakLoc; - break; + + if (matNos.size() > 1) { + List<LocMast> locMasts = locMastService.selectAreaEmpty(locTypeDto.getLocType1(), 1);//鎼滅储娣锋斁搴撲綅 + //娣锋斁鍖哄煙鐩存帴鍙栫涓�涓嵆鍙� + for (LocMast mast : locMasts) { + //棰勭暀绌哄簱浣� + if (locMastService.checkEmptyCount(mast, 10)) { + locMast = mast; + break; + } } } // 2.搴撲綅褰撳墠鎵�灞炲昂瀵告棤绌哄簱浣嶆椂锛岃皟鏁村昂瀵稿弬鏁帮紝鍚戜笂鍏煎妫�绱㈠簱浣� if (Cools.isEmpty(locMast)) { log.error("绯荤粺娌℃湁绌哄簱浣嶏紒锛侊紒 灏哄瑙勬牸锛� {}锛� 杞娆℃暟锛歿}", JSON.toJSONString(locTypeDto), times); + } + + return locMast; + } + + // 鎼滅储鍗曞搧 + private LocMast getLocNoStepSingle(List<String> matNos, LocTypeDto locTypeDto) { + LocMast locMast = null; + // 1.鍏堟悳绱㈠崟鍝� + if (matNos.size() == 1) { + //鍗曞搧 + List<LocMast> locMasts = locMastService.selectAreaEmpty(locTypeDto.getLocType1(), 2);//鎼滅储鍗曞搧搴撲綅 + for (LocMast mast : locMasts) { + List<String> groupLoc = Utils.getGroupLoc(mast.getLocNo()); + if (!locMastService.checkAllLocEmpty(groupLoc)) { + continue; + } + + LocMast tmp = null; + for (String loc : groupLoc) { + LocMast locMast1 = locMastService.selectByLoc(loc); + if (locMast1 == null) { + continue; + } + + if (!locMast1.getLocSts().equals("O")) { + continue; + } + + tmp = locMast1; + break; + } + + //棰勭暀绌哄簱浣� + if (tmp != null && locMastService.checkEmptyCount(mast, 10)) { + locMast = tmp; + break; + } + } } return locMast; @@ -371,7 +349,7 @@ Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() .eq("type_no", staDescId) .eq("stn_no", sourceStaNo) - .eq("crn_no",Utils.getLev(locNo));//鍊熺敤鍫嗗灈鏈哄彿瀛楁鍏呭綋妤煎眰鍙� + .eq("crn_no",Utils.stnNoToLiftNo(sourceStaNo));//鍊熺敤鍫嗗灈鏈哄彿瀛楁鍏呭綋鎻愬崌鏈哄彿 StaDesc staDesc = staDescService.selectOne(wrapper); if (Cools.isEmpty(staDesc)) { log.error("鍏ュ簱璺緞涓嶅瓨鍦�, staDescId={}, sourceStaNo={}", staDescId, sourceStaNo); -- Gitblit v1.9.1