From e947c5ed8575d84ee831dcb47ef5c26d9c21e1f3 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期一, 24 十月 2022 11:01:57 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/common/service/CommonService.java |  100 ++++++++++++++++++++++++++++++++++---------------
 1 files changed, 69 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 3281c7f..2f4a91a 100644
--- a/src/main/java/com/zy/common/service/CommonService.java
+++ b/src/main/java/com/zy/common/service/CommonService.java
@@ -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,26 @@
 
         // 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;
+                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 {
+
+            }
         }
 
         // 2.搴撲綅褰撳墠鎵�灞炲昂瀵告棤绌哄簱浣嶆椂锛岃皟鏁村昂瀵稿弬鏁帮紝鍚戜笂鍏煎妫�绱㈠簱浣�

--
Gitblit v1.9.1