From cf2e4086d44e51bcd7407133d460dda498b45eff Mon Sep 17 00:00:00 2001
From: whycq <you@example.com>
Date: 星期三, 28 六月 2023 21:55:29 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/utils/Utils.java |  121 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 121 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java
index 7afa71a..9625946 100644
--- a/src/main/java/com/zy/asrs/utils/Utils.java
+++ b/src/main/java/com/zy/asrs/utils/Utils.java
@@ -1,5 +1,6 @@
 package com.zy.asrs.utils;
 
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Arith;
 import com.core.common.Cools;
 import com.core.common.SpringUtils;
@@ -613,4 +614,124 @@
         return false;
     }
 
+    /**
+     * 妫�娴嬪綋鍓嶅簱浣嶅唴渚у叾浠栧簱浣嶆槸鍚︿负D銆丗銆乆銆丱
+     * 杩斿洖true琛ㄧず鍐呬晶搴撲綅涓嶆槸DFXO锛岃繑鍥瀎alse琛ㄧず鍐呬晶搴撲綅鏄疍FXO
+     */
+    public static boolean checkInsideLocIsDFXO(String locNo) {
+        LocMastService locMastService = SpringUtils.getBean(LocMastService.class);
+        List<String> insideLoc = Utils.getGroupInsideLoc(locNo);
+        if (insideLoc.size() > 0) {
+            List<LocMast> insideLocMast = locMastService.selectByLocNos(insideLoc);
+            for (LocMast mast : insideLocMast) {
+                if (!mast.getLocSts().equals("D")
+                        && !mast.getLocSts().equals("F")
+                        && !mast.getLocSts().equals("X")
+                && !mast.getLocSts().equals("O")) {
+                    //D銆丗銆乆(涓嶈兘閫夊畾杩欎釜澶栦晶搴撲綅)
+                    return true;
+                }
+            }
+        }
+        Integer row = selectInSide(Utils.getRow(locNo));
+        if (row==0){
+            return true;
+        }
+        LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", row).eq("bay1", Utils.getBay(locNo)).eq("lev1", Utils.getLev(locNo)));
+        if (Cools.isEmpty(locMast)) {
+            if (row==7 && Utils.getBay(locNo)<4){
+                locMast =  locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", 6).eq("bay1", Utils.getBay(locNo)).eq("lev1", Utils.getLev(locNo)));
+                if (Cools.isEmpty(locMast)) {
+                    return false;
+                }
+            }else {
+                return false;
+            }
+        }
+        if (!locMast.getLocSts().equals("F") && !locMast.getLocSts().equals("D") ){
+            if (locMast.getLocSts().equals("X")){
+                row = selectInSide2(row);
+                if (row==0){
+                    return true;
+                }
+                LocMast locMast1 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", row).eq("bay1", Utils.getBay(locNo)).eq("lev1", Utils.getLev(locNo)));
+                if (!locMast1.getLocSts().equals("F") && !locMast1.getLocSts().equals("D") ){
+                    return true;
+                }
+            } else {
+                return true;
+            }
+        }
+
+        return false;
+    }
+
+    public static Integer selectInSide(Integer row){
+        switch (row){
+            case 1:
+            case 2:
+            case 3:
+                row = 1;
+                break;
+            case 4:
+            case 5:
+            case 6:
+            case 7:
+                row = 7;
+                break;
+            case 8:
+            case 9:
+            case 10:
+            case 11:
+                row = 8;
+                break;
+            case 12:
+            case 13:
+            case 14:
+                row = 14;
+                break;
+            case 15:
+            case 16:
+            case 17:
+            case 18:
+                row = 15;
+                break;
+            case 19:
+            case 20:
+            case 21:
+                row = 21;
+                break;
+            default:
+                row = 0;
+                break;
+        }
+        return row;
+    }
+    public static Integer selectInSide2(Integer row){
+        switch (row){
+            case 1:
+                row = 2;
+                break;
+            case 7:
+                row = 6;
+                break;
+            case 8:
+                row = 9;
+                break;
+            case 14:
+                row = 13;
+                break;
+            case 15:
+                row = 16;
+                break;
+            case 21:
+                row = 20;
+                break;
+            default:
+                row = 0;
+                break;
+        }
+        return row;
+    }
+
 }

--
Gitblit v1.9.1