From b64f451f37fafdaac2262972d3711d2370b72480 Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期三, 19 七月 2023 16:20:23 +0800
Subject: [PATCH] #接口对接工具类实装

---
 src/main/java/com/zy/common/service/CommonService.java |  129 ++++++++++++------------------------------
 1 files changed, 37 insertions(+), 92 deletions(-)

diff --git a/src/main/java/com/zy/common/service/CommonService.java b/src/main/java/com/zy/common/service/CommonService.java
index 7c14d77..c8ff3bc 100644
--- a/src/main/java/com/zy/common/service/CommonService.java
+++ b/src/main/java/com/zy/common/service/CommonService.java
@@ -97,27 +97,8 @@
      */
     @Transactional
     public StartupDto getLocNo(Integer whsType, Integer staDescId, Integer sourceStaNo, List<String> matNos, LocTypeDto locTypeDto, int times) {
-//        whsType = getWhsType(sourceStaNo, times);
-        switch (sourceStaNo){
-            case 101:
-            case 109:
-            case 117:
-                whsType=1;
-                break;
-            case 201:
-                whsType=2;
-                break;
-            case 207:
-                whsType=3;
-                break;
-            case 213:
-                whsType=4;
-                break;
-        }
-
+        whsType = 1;
         StartupDto startupDto = new StartupDto();
-
-
 
         RowLastno rowLastno = rowLastnoService.selectById(whsType);
         if (Cools.isEmpty(rowLastno)) {
@@ -130,8 +111,7 @@
         int eRow = rowLastno.geteRow();
         int crn_qty = rowLastno.getCrnQty();
         int rowCount = eRow - sRow + 1;
-        // 鐩爣鍫嗗灈鏈哄彿
-        int crnNo = 0;
+
         // 鐩爣搴撲綅
         LocMast locMast = null;
 
@@ -149,7 +129,6 @@
                     if (VersionUtils.locMoveCheckLocType(shallowLoc, locTypeDto)) {
                         if (basCrnpService.checkSiteError(shallowLoc.getCrnNo(), true)) {
                             locMast = shallowLoc;
-                            crnNo = locMast.getCrnNo();
                             break;
                         }
                     }
@@ -171,7 +150,6 @@
                     if (shallowLoc != null && shallowLoc.getLocSts().equals("O")) {
                         if (basCrnpService.checkSiteError(shallowLoc.getCrnNo(), true)) {
                             locMast = shallowLoc;
-                            crnNo = locMast.getCrnNo();
                             break;
                         }
                     }
@@ -180,44 +158,8 @@
         }
 
         // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋�
-        if (null == locMast) {
-            Shelves shelves = new Shelves(rowCount, crn_qty);
-            int divides = (int) Arith.divides(1, curRow - 1, 4);
-            curRow = (int) Arith.remainder(curRow, 4);
-            if (curRow == 0) {
-                curRow = 4;
-            }
-            for (int i = 0; i < shelves.group; i ++) {
-                curRow = shelves.start(curRow);
-                if (curRow < 0) {
-                    throw new CoolException("妫�绱㈠簱浣嶅け璐ワ紝璇疯仈绯荤鐞嗗憳");
-                }
-                Integer crnNo1 = shelves.get(curRow);
-                crnNo1 = crnNo1 + divides*1;
-                if (basCrnpService.checkSiteError(crnNo1, true)) {
-                    crnNo = crnNo1;
-                    curRow = curRow + divides*4;
-                    break;
-                }
-            }
-        }
-
-        if (crnNo == 0) {
-            throw new CoolException("娌℃湁鍙敤鐨勫爢鍨涙満");
-        }
-        // 鑾峰彇鐩爣绔�
-        Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>()
-                .eq("type_no", staDescId)
-                .eq("stn_no", sourceStaNo)
-                .eq("crn_no", crnNo);
-        StaDesc staDesc = staDescService.selectOne(wrapper);
-        if (Cools.isEmpty(staDesc)) {
-            log.error("type_no={},stn_no={},crn_no={}", staDescId, sourceStaNo, crnNo);
-            throw new CoolException("鍏ュ簱璺緞涓嶅瓨鍦�");
-        }
-        BasDevp staNo = basDevpService.selectById(staDesc.getCrnStn());
-        if (!staNo.getAutoing().equals("Y")) {
-            throw new CoolException("鐩爣绔�"+staDesc.getCrnStn()+"涓嶅彲鐢�");
+        if (null == locMast){
+            curRow = getCurRow(curRow);
         }
 
         // 鏇存柊搴撲綅鎺掑彿
@@ -259,9 +201,33 @@
                 }
             }
         }
+        Integer crnNo = 0;
+        BasDevp staNo =null;
+        boolean sign=false;
+        if (!Cools.isEmpty(locMast)){
+            try{
+                crnNo = locMast.getCrnNo();
+                // 鑾峰彇鐩爣绔�
+                Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>()
+                        .eq("type_no", staDescId)
+                        .eq("stn_no", sourceStaNo)
+                        .eq("crn_no", crnNo);
+                StaDesc staDesc = staDescService.selectOne(wrapper);
+                if (Cools.isEmpty(staDesc)) {
+                    log.error("type_no={},stn_no={},crn_no={}", staDescId, sourceStaNo, crnNo);
+                    throw new CoolException("鍏ュ簱璺緞涓嶅瓨鍦�");
+                }
+                staNo = basDevpService.selectById(staDesc.getCrnStn());
+                if (!staNo.getAutoing().equals("Y")) {
+                    throw new CoolException("鐩爣绔�"+staDesc.getCrnStn()+"涓嶅彲鐢�");
+                }
+            }catch (Exception e){
+                sign=true;
+            }
+        }
 
         // 2.搴撲綅褰撳墠鎵�灞炲昂瀵告棤绌哄簱浣嶆椂锛岃皟鏁村昂瀵稿弬鏁帮紝鍚戜笂鍏煎妫�绱㈠簱浣�
-        if (Cools.isEmpty(locMast)) {
+        if (Cools.isEmpty(locMast) || sign) {
             // 褰撳墠宸烽亾鏃犵┖搴撲綅鏃讹紝閫掑綊璋冩暣鑷充笅涓�宸烽亾锛屾绱㈠叏閮ㄥ贩閬撴棤鏋滃悗锛岃烦鍑洪�掑綊
             if (times < rowCount) {
                 times = times + 1;
@@ -307,35 +273,14 @@
     /**
      * 鏍规嵁鍏ュ簱绔欒幏鍙栧簱浣嶆帓鍙峰垎閰�
      */
-    private Integer getWhsType(Integer sourceStaNo, int times) {
-        if (times >= 16) {
-            return 4;
+    private Integer getCurRow(Integer curRow) {
+        if (Utils.isDeepLocLeft(slaveProperties,curRow)){
+            curRow=curRow+3;
+        }else if (Utils.isDeepLocLeft(slaveProperties,curRow-1)){
+            curRow=curRow+1;
+        }else {
+            curRow=curRow-2;
         }
-        switch (sourceStaNo) {
-            case 173:
-            case 176:
-            case 180:
-            case 185:
-                return 1;
-            case 189:
-            case 194:
-            case 198:
-            case 202:
-                return 2;
-            case 206:
-//            case 211:
-//            case 215:
-//            case 219:
-//            case 223:
-            case 227:
-                return 3;
-            case 305:
-            case 303:
-            case 301:
-                return 4;
-            default:
-                throw new CoolException("鏍规嵁鍏ュ簱绔欒幏鍙栧簱浣嶆帓鍙峰垎閰嶅け璐ワ紝鍏ュ簱绔欙細" + sourceStaNo);
-        }
+        return curRow;
     }
-
 }

--
Gitblit v1.9.1