From b25fc15afed603c0c874e77d37bf93f08d5398c9 Mon Sep 17 00:00:00 2001
From: zhangc <zc@123>
Date: 星期四, 13 二月 2025 12:18:34 +0800
Subject: [PATCH] 兼容四期

---
 src/main/java/com/zy/asrs/controller/AgvLocMastController.java |   58 +++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 49 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/AgvLocMastController.java b/src/main/java/com/zy/asrs/controller/AgvLocMastController.java
index 9070c6a..505e6a4 100644
--- a/src/main/java/com/zy/asrs/controller/AgvLocMastController.java
+++ b/src/main/java/com/zy/asrs/controller/AgvLocMastController.java
@@ -48,7 +48,7 @@
                   @RequestParam Map<String, Object> param){
         excludeTrash(param);
         EntityWrapper<AgvLocMast> wrapper = new EntityWrapper<>();
-        convert(param, wrapper);
+        convert1(param, wrapper);
         if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));}
         return R.ok(agvLockMastService.selectPage(new Page<>(curr, limit), wrapper.eq("status",0)));
     }
@@ -69,7 +69,7 @@
     @Transactional
     public R update(AgvLocMast locMast){
         if (Cools.isEmpty(locMast) || null==locMast.getLocNo()){
-            return R.error();
+            return R.error("鍙傛暟缂哄け");
         }
         AgvWrkMast wrkMast = agvWrkMastService.selectOne(new EntityWrapper<AgvWrkMast>()
                 .eq("source_loc_no", locMast.getLocNo())
@@ -80,6 +80,29 @@
         AgvLocMast oldLocMast = agvLockMastService.selectById(locMast.getLocNo());
         if (locMast.getLocSts().equals("F") && (oldLocMast.getLocSts().equals("D") || oldLocMast.getLocSts().equals("O"))) {
             return R.error("褰撳墠鎿嶄綔宸茶闃绘锛岃鑱旂郴绠$悊鍛�");
+        }
+        int br = 0;
+        if (locMast.getLocSts() == "O" || locMast.getLocSts() == "X"){
+            switch (locMast.getBarcode().substring(0,2)) {
+                case "10":
+                    br = 1;
+                    break;
+                case "20":
+                    br = 2;
+                    break;
+                case "21":
+                    br = 4;
+                    break;
+                case "30":
+                    br = 3;
+                    break;
+                case "40":
+                    br = 5;
+                    break;
+            }
+            if (oldLocMast.getLocType1() != br) {
+                return  R.error("璐ф灦鍜屽簱浣嶇被鍨嬩笉鍖归厤锛�");
+            }
         }
         Date now = new Date();
         // 鏈夌墿鏂欐椂淇敼涓虹┖搴撲綅鎴栬�呯┖鏉垮簱浣嶏紝鍒欏垹闄ゅ簱瀛樻槑缁�
@@ -99,18 +122,21 @@
                     adjDetl.setAppeTime(now);
                     adjDetl.setAppeUser(getUserId());
                     if (!adjDetlService.insert(adjDetl)) {
-                        throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
+                        throw new CoolException("搴撲綅淇敼澶辫触");
                     }
                 }
                 if (!agvLocDetlService.delete(new EntityWrapper<AgvLocDetl>().eq("loc_no", locMast.getLocNo()))) {
-                    throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
+                    throw new CoolException("搴撲綅鏄庣粏鍒犻櫎澶辫触");
+                }
+                if (locMast.getLocSts().equals("O")) {
+                    locMast.setBarcode("");
                 }
             }
         }
         locMast.setModiUser(getUserId());
         locMast.setModiTime(now);
         if(!agvLockMastService.updateById(locMast)) {
-            throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
+            throw new CoolException("涓诲簱浣嶄慨鏀瑰け璐�");
         }
         return R.ok();
     }
@@ -120,7 +146,7 @@
     public R delete(@RequestParam String param){
         List<AgvLocMast> list = JSONArray.parseArray(param, AgvLocMast.class);
         if (Cools.isEmpty(list)){
-            return R.error();
+            return R.error("鍙傛暟缂哄け");
         }
         for (AgvLocMast entity : list){
             agvLockMastService.delete(new EntityWrapper<>(entity));
@@ -153,11 +179,13 @@
     @ManagerAuth(memo = "鍒濆鍖栧簱浣�")
     public R init(LocMastInitParam param) {
         //娓呯┖鍘熸湁搴撲綅
-        agvLockMastService.clearLoc();
+//        agvLockMastService.clearLoc();
+        //鍒濆鍖栦竴妤煎簱浣�
+        agvLockMastService.initLocFloor1();
         //鍒濆鍖栦簩妤煎簱浣�
-        agvLockMastService.initLocFloor2();
+//        agvLockMastService.initLocFloor2();
         //鍒濆鍖栦笁妤肩珯鐐�
-        //agvLockMastService.initLocFloor3();
+//        agvLockMastService.initLocFloor3();
 
         return R.ok();
     }
@@ -180,4 +208,16 @@
             }
         }
     }
+    private <T> void convert1(Map<String, Object> map, EntityWrapper<T> wrapper){
+        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 {
+                wrapper.eq(entry.getKey(), val);
+            }
+        }
+    }
 }

--
Gitblit v1.9.1