From fc3347a225114a8dbd37b451981109c8170b9dd4 Mon Sep 17 00:00:00 2001
From: ZY <zc857179121@qq.com>
Date: 星期一, 19 八月 2024 08:29:14 +0800
Subject: [PATCH] 1

---
 src/main/java/com/zy/asrs/controller/LocMastController.java |   28 +++++++++++++++++++++++-----
 1 files changed, 23 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/LocMastController.java b/src/main/java/com/zy/asrs/controller/LocMastController.java
index e343c2b..2d82d5e 100644
--- a/src/main/java/com/zy/asrs/controller/LocMastController.java
+++ b/src/main/java/com/zy/asrs/controller/LocMastController.java
@@ -15,10 +15,12 @@
 import com.zy.asrs.entity.param.LocMastInitParam;
 import com.zy.asrs.service.LocDetlService;
 import com.zy.asrs.service.LocMastService;
+import com.zy.asrs.utils.Utils;
 import com.zy.common.entity.Parameter;
 import com.zy.common.model.Shelves;
 import com.zy.common.web.BaseController;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.bind.annotation.*;
 
 import java.util.*;
@@ -66,15 +68,24 @@
     }
 
     private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){
+        boolean sign = false;
         for (Map.Entry<String, Object> entry : map.entrySet()){
             String val = String.valueOf(entry.getValue());
             if (val.contains(RANGE_TIME_LINK)){
                 String[] dates = val.split(RANGE_TIME_LINK);
                 wrapper.ge(entry.getKey(), DateUtils.convert(dates[0]));
                 wrapper.le(entry.getKey(), DateUtils.convert(dates[1]));
-            } else {
+            } else if (entry.getKey().equals("loc_no")){
                 wrapper.like(entry.getKey(), val);
+            } else {
+                if (entry.getKey().equals("loc_type1")){
+                    sign=true;
+                }
+                wrapper.eq(entry.getKey(), val);
             }
+        }
+        if (sign){
+            wrapper.and().ne("loc_sts","Y");
         }
     }
 
@@ -173,10 +184,16 @@
                     String locNo = String.format("%02d", r) + String.format("%03d", b) + String.format("%02d", l);
                     // 鑾峰彇鍫嗗灈鏈哄彿
                     int crnNo = 0;
-                    Shelves shelves = new Shelves(param.getEndRow() - param.getStartRow() + 1, param.getCrnAmount());
+                    Shelves shelves = new Shelves(param.getEndRow() - param.getStartRow() + 1, param.getCrnAmount(),param.getStartRow());
                     for (List<Integer> node : shelves.nodes){
+
                         if (node.contains(r)) {
-                            crnNo = shelves.nodes.indexOf(node) + 1;
+                            if (!Cools.isEmpty(param.getStaCrn()) && param.getStaCrn() > 0){
+                                crnNo = shelves.nodes.indexOf(node) + param.getStaCrn();
+                            }else {
+                                crnNo = shelves.nodes.indexOf(node) + 1;
+                            }
+
                             break;
                         }
                     }
@@ -199,8 +216,9 @@
                 }
             }
         }
-        locMastService.delete(new EntityWrapper<>());
-        locDetlService.delete(new EntityWrapper<>());
+        if (!Cools.isEmpty(param.getEnable()) && param.getEnable() == 1){
+             locMastService.delete(new EntityWrapper<>());
+        }
         locMastService.insertBatch(list);
         return R.ok("鍒濆鍖栨垚鍔�");
     }

--
Gitblit v1.9.1