From 6559c51b0ddc00a14a7589bc57bbfec4a01a0b2f Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期四, 08 十二月 2022 11:16:15 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/common/service/CommonService.java |  142 ++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 109 insertions(+), 33 deletions(-)

diff --git a/src/main/java/com/zy/common/service/CommonService.java b/src/main/java/com/zy/common/service/CommonService.java
index 3281c7f..1e48dab 100644
--- a/src/main/java/com/zy/common/service/CommonService.java
+++ b/src/main/java/com/zy/common/service/CommonService.java
@@ -114,11 +114,11 @@
         int end = 30;
         int dualCrnNo;
         switch (sourceStaNo) {
-            case 107:
+            case 203:
                 whsType = 1;
                 dualCrnNo = 2;
                 break;
-            case 118:
+            case 102:
                 whsType = 2;
                 start = 31;
                 end = 32;
@@ -167,7 +167,24 @@
                         }
                     }
                 } else {
-
+                    if (Utils.isShallowLoc(slaveProperties, locNo)) {
+                        continue;
+                    }
+                    String shallowLocNo = Utils.getShallowLoc(slaveProperties, locNo);
+                    // 妫�娴嬬洰鏍囧簱浣嶆槸鍚︿负绌哄簱浣�
+                    LocMast shallowLoc = locMastService.selectById(shallowLocNo);
+                    if (shallowLoc != null && shallowLoc.getLocSts().equals("O")) {
+                        if (VersionUtils.locMoveCheckLocType(shallowLoc, locTypeDto)) {
+                            // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
+                            if (locMastService.checkEmptyCount(shallowLoc)) {
+                                if (basCrnpService.checkSiteError(shallowLoc.getCrnNo(), true)) {
+                                    locMast = shallowLoc;
+                                    crnNo = locMast.getCrnNo();
+                                    break;
+                                }
+                            }
+                        }
+                    }
                 }
             }
         }
@@ -178,21 +195,36 @@
                     .eq("loc_sts", "D").ge("row1", start).le("row1", end));
             if (locMasts.size() > 0) {
                 for (LocMast loc : locMasts) {
-                    LocMast locMast0 = locMastService.findOutMost(loc.getLocNo());
-                    if (null != locMast0) {
-                        // 娴呭簱浣嶇鍚堝昂瀵告娴�
-                        if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) {
-                            int locCrnNo;
-                            if (whsType == 1) {
-                                locCrnNo = 2;
-                            } else {
-                                locCrnNo = 3;
+                    if (whsType == 1) {
+                        LocMast locMast0 = locMastService.findOutMost(loc.getLocNo());
+                        if (null != locMast0) {
+                            // 娴呭簱浣嶇鍚堝昂瀵告娴�
+                            if (VersionUtils.locMoveCheckLocType(locMast0, locTypeDto)) {
+                                // 娴呭簱浣嶅搴斿爢鍨涙満蹇呴』鍙敤涓旀棤寮傚父
+                                if (basCrnpService.checkSiteError(dualCrnNo, true)) {
+                                    crnNo = dualCrnNo;
+                                    locMast = locMast0;
+                                    break;
+                                }
                             }
-                            // 娴呭簱浣嶅搴斿爢鍨涙満蹇呴』鍙敤涓旀棤寮傚父
-                            if (basCrnpService.checkSiteError(locCrnNo, true)) {
-                                crnNo = locCrnNo;
-                                locMast = locMast0;
-                                break;
+                        }
+                    } else {
+                        if (Utils.isShallowLoc(slaveProperties, loc.getLocNo())) {
+                            continue;
+                        }
+                        String shallowLocNo = Utils.getShallowLoc(slaveProperties, loc.getLocNo());
+                        // 妫�娴嬬洰鏍囧簱浣嶆槸鍚︿负绌哄簱浣�
+                        LocMast shallowLoc = locMastService.selectById(shallowLocNo);
+                        if (shallowLoc != null && shallowLoc.getLocSts().equals("O")) {
+                            if (VersionUtils.locMoveCheckLocType(shallowLoc, locTypeDto)) {
+                                // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
+                                if (locMastService.checkEmptyCount(shallowLoc)) {
+                                    if (basCrnpService.checkSiteError(shallowLoc.getCrnNo(), true)) {
+                                        locMast = shallowLoc;
+                                        crnNo = locMast.getCrnNo();
+                                        break;
+                                    }
+                                }
                             }
                         }
                     }
@@ -201,14 +233,16 @@
         }
 
         // 濡傛灉娌℃湁鐩歌繎鐗╂枡锛屽垯鎸夎鍒欒疆璇㈣揣鏋�
-        if (null == locMast && whsType == 1) {
-            if (curRow == 2) {
-                curRow = 30;
-            } else if (curRow == 30) {
-                curRow = 2;
+        if (null == locMast) {
+            if (whsType == 1) {
+                if (curRow == 2) {
+                    curRow = 30;
+                } else if (curRow == 30) {
+                    curRow = 2;
+                }
             }
             if (basCrnpService.checkSiteError(dualCrnNo, true)) {
-               crnNo = dualCrnNo;
+                crnNo = dualCrnNo;
             }
         }
 
@@ -240,22 +274,64 @@
 
         // 1.褰撴绱㈠簱鎺掍负娴呭簱浣嶆帓鏃讹紝浼樺厛瀵绘壘褰撳墠搴撴帓鐨勬繁搴撲綅鎺�
         if (locMast == null) {
-            List<Integer> rows = Utils.getGroupLoc(curRow);
+            if (whsType == 1) {
+                List<Integer> rows = Utils.getGroupLoc(curRow);
 
-            List<LocMast> locMasts = locMastService.queryFreeLocMast(rows, rows.size(), locTypeDto.getLocType1());
-            if (!Cools.isEmpty(locMasts)) {
-                Integer innermostRow = Utils.getOutLayerRow(locMasts.get(0).getLocNo(), false);
-                for (LocMast one : locMasts) {
-                    if (one.getRow1().equals(innermostRow)) {
-                        locMast = one;
-                        break;
+//                Iterator<Integer> iterator = rows.iterator();
+//                while (iterator.hasNext()) {
+//                    Integer next = iterator.next();
+//                    if (next.equals(17) || next.equals(18)) {
+//                        iterator.remove();
+//                    }
+//                }
+
+                List<LocMast> locMasts = locMastService.queryFreeLocMast(rows, rows.size(), locTypeDto.getLocType1());
+                if (!Cools.isEmpty(locMasts)) {
+                    Integer innermostRow = Utils.getOutLayerRow(locMasts.get(0).getLocNo(), false);
+                    for (LocMast one : locMasts) {
+                        if (one.getRow1().equals(innermostRow)) {
+                            locMast = one;
+                            break;
+                        }
                     }
                 }
-            }
-            // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣� todo:luxiaotao
+                // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣� todo:luxiaotao
 //            if (!locMastService.checkEmptyCount(locMast)) {
 //                locMast = null;
 //            }
+            } else {
+                if (Utils.isShallowLoc(slaveProperties, curRow)) {
+                    Integer deepRow = Utils.getDeepRow(slaveProperties, curRow);
+                    locMast = locMastService.queryFreeLocMast0(deepRow, locTypeDto.getLocType1());
+                    // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
+                    if (locMast !=null && !locMastService.checkEmptyCount(locMast)) {
+                        locMast = null;
+                    }
+                }
+
+                if (Cools.isEmpty(locMast)) {
+                    locMast = locMastService.queryFreeLocMast0(curRow, locTypeDto.getLocType1());
+                    // 鍥犲簱浣嶇Щ杞�侀渶棰勭暀绌哄簱浣�
+                    if (!locMastService.checkEmptyCount(locMast)) {
+                        locMast = null;
+                    }
+
+                    // 鐩爣搴撲綅 ===>> 娴呭簱浣嶏紝 鍒欐牎楠屽叾娣卞簱浣嶆槸鍚︿负 F D X
+                    if (null != locMast && Utils.isShallowLoc(slaveProperties, locMast.getLocNo())) {
+                        LocMast deepLoc = locMastService.selectById(Utils.getDeepLoc(slaveProperties, locMast.getLocNo()));
+                        if (!deepLoc.getLocSts().equals("F") && !deepLoc.getLocSts().equals("D") && !deepLoc.getLocSts().equals("X")) {
+                            locMast = null;
+                        }
+                    }
+                    // 鐩爣搴撲綅 ===>> 娣卞簱浣嶏紝 鍒欐牎楠屽叾娴呭簱浣嶆槸鍚︿负 O
+                    if (null != locMast && Utils.isDeepLoc(slaveProperties, locMast.getLocNo())) {
+                        LocMast shallowLoc = locMastService.selectById(Utils.getShallowLoc(slaveProperties, locMast.getLocNo()));
+                        if (!shallowLoc.getLocSts().equals("O")) {
+                            locMast = null;
+                        }
+                    }
+                }
+            }
         }
 
         // 2.搴撲綅褰撳墠鎵�灞炲昂瀵告棤绌哄簱浣嶆椂锛岃皟鏁村昂瀵稿弬鏁帮紝鍚戜笂鍏煎妫�绱㈠簱浣�

--
Gitblit v1.9.1