From aa221b6b6c3939130c78e4219207d14ce877ff30 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期三, 06 八月 2025 15:57:34 +0800
Subject: [PATCH] 1

---
 src/main/java/com/zy/asrs/task/handler/AutoMoveHandler.java |   81 +++++++++++++++++++++++++++++-----------
 1 files changed, 59 insertions(+), 22 deletions(-)

diff --git a/src/main/java/com/zy/asrs/task/handler/AutoMoveHandler.java b/src/main/java/com/zy/asrs/task/handler/AutoMoveHandler.java
index 0b4fb38..1a5e60b 100644
--- a/src/main/java/com/zy/asrs/task/handler/AutoMoveHandler.java
+++ b/src/main/java/com/zy/asrs/task/handler/AutoMoveHandler.java
@@ -1,6 +1,7 @@
 package com.zy.asrs.task.handler;
 
 
+import com.baomidou.mybatisplus.enums.SqlLike;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.exception.CoolException;
@@ -49,18 +50,21 @@
 //        return SUCCESS;
 //    }
 
+    @Transactional
     public ReturnT<String> start2(AgvWrkMast agvWrkMast) {
         // locType 1. 鑷姩锛� 2. 鎵嬪姩
         doAutoMove2(agvWrkMast);
         return SUCCESS;
     }
 
+    @Transactional
     public ReturnT<String> start3(AgvWrkMast agvWrkMast) {
         // locType 1. 鑷姩锛� 2. 鎵嬪姩
         doHandMove2(agvWrkMast);
         return SUCCESS;
     }
 
+    @Transactional
     public ReturnT<String> start4(AgvWrkMast agvWrkMast) {
         // locType 1. 鑷姩锛� 2. 鎵嬪姩
         doAutoMove3(agvWrkMast);
@@ -155,7 +159,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvLocMast.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvLocMast.getBarcode().substring(0, 2)));
+
         // 鐩爣妤煎眰
         mast.setPauseMk(agvLocMast.getLocType3().toString());
 
@@ -191,7 +196,8 @@
         return SUCCESS;
     }
 
-    private ReturnT<String> doAutoMove2(AgvWrkMast agvWrkMast) {
+    @Transactional
+    public ReturnT<String> doAutoMove2(AgvWrkMast agvWrkMast) {
         Date now = new Date();
         String barcode = agvWrkMast.getBarcode();
         AgvLocMast locMast;
@@ -227,7 +233,8 @@
         return SUCCESS;
     }
 
-    private ReturnT<String> doAutoMove3(AgvWrkMast agvWrkMast) {
+    @Transactional
+    public ReturnT<String> doAutoMove3(AgvWrkMast agvWrkMast) {
         Date now = new Date();
         //妫�绱㈠簱浣嶏紝閫夋嫨鍚堥�傜殑搴撲綅
         AgvLocMast locMast = agvCommonService.getLocNo(3, agvWrkMast.getCrnNo(), false, false);
@@ -247,7 +254,8 @@
         return SUCCESS;
     }
 
-    private ReturnT<String> doHandMove2(AgvWrkMast agvWrkMast) {
+    @Transactional
+    public ReturnT<String> doHandMove2(AgvWrkMast agvWrkMast) {
         Date now = new Date();
         String lev1 = agvWrkMast.getSourceLocNo().substring(agvWrkMast.getSourceLocNo().length() - 4).substring(0, 2);
         AgvBasDevp devpNo = new AgvBasDevp();
@@ -258,7 +266,7 @@
         }
 
         if (Cools.isEmpty(devpNo)) {
-            log.info("鏆傛棤绌洪棽鎺ラ┏浣�");
+            //log.info("鏆傛棤绌洪棽鎺ラ┏浣�");
             return FAIL;
             //throw new CoolException("鏆傛棤绌洪棽鎺ラ┏浣�");
         }
@@ -275,7 +283,7 @@
     /*
     鏇存柊鐩爣搴撲綅淇℃伅
      */
-    private void updateAgvLocMast(AgvLocMast locMast, String locSts) {
+    public void updateAgvLocMast(AgvLocMast locMast, String locSts) {
         locMast.setLocSts(locSts);
         agvLocMastService.updateById(locMast);
     }
@@ -283,14 +291,14 @@
     /*
     鏇存柊婧愮珯鐐逛俊鎭�
      */
-    private void updateAgvBasDevp(AgvBasDevp agvBasDevp, String locSts) {
+    public void updateAgvBasDevp(AgvBasDevp agvBasDevp, String locSts) {
         if (!Cools.isEmpty(agvBasDevp)) {
             agvBasDevp.setLocSts(locSts);
             agvBasDevpService.updateById(agvBasDevp);
         }
     }
 
-    private void updateAgvBasDevp(AgvBasDevp agvBasDevp, String locSts, Short continerType, String containerCode) {
+    public void updateAgvBasDevp(AgvBasDevp agvBasDevp, String locSts, Short continerType, String containerCode) {
         if (!Cools.isEmpty(agvBasDevp)) {
             agvBasDevp.setLocSts(locSts);
             agvBasDevp.setBarcode(containerCode);
@@ -323,7 +331,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvLocMast.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvLocMast.getBarcode().substring(0, 2)));
+
 
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);
@@ -340,6 +349,7 @@
         return SUCCESS;
     }
 
+    @Transactional
     public ReturnT<String> autoEmptyBack3(AgvWrkMast agvWrkMast) {
         Date now = new Date();
         AgvBasDevp agvBasDevp = agvBasDevpService.selectByDevNo(agvWrkMast.getSourceLocNo());
@@ -405,6 +415,8 @@
 //        return SUCCESS;
 //    }
 
+
+    @Transactional
     public ReturnT<String> autoEmptyBack4(AgvLocMast agvLocMast) {
         Date now = new Date();
         //鏌ヨ宸ヤ綔妗�
@@ -424,7 +436,7 @@
         } else if (agvLocMast.getFloor() == 1 && agvLocMast.getLev1() == 2) {
             floor = "02F1";
         }
-        List<AgvWrkMast> agvWrkMasts = agvWrkMastService.selectList(new EntityWrapper<AgvWrkMast>().eq("io_type", 109).like("source_loc_no", floor).or().eq("io_type", 113));
+        List<AgvWrkMast> agvWrkMasts = agvWrkMastService.selectList(new EntityWrapper<AgvWrkMast>().eq("io_type", 109).like("barcode", "30", SqlLike.RIGHT).like("source_loc_no", floor).or().eq("io_type", 113));
         if (agvWrkMasts.size() >= 5) {
             //log.error("鏆傚仠鍥炴祦");
             return FAIL;
@@ -437,6 +449,20 @@
             wrkSts = 21L;
             ioType = 109;
         } else {
+            try {
+                List<AgvLocMast> agvLocMasts = agvLocMastService.selectList(new EntityWrapper<AgvLocMast>().eq("loc_sts", "O").eq("loc_type1", 3).eq("lev1", 1).eq("floor", 1));
+                int num = 20;
+                Config config = configService.selectOne(new EntityWrapper<Config>().eq("code", "LOC_3_NUM_RETURN"));
+                if (config != null && !Cools.isEmpty(config.getValue())) {
+                    num = Integer.parseInt(config.getValue());
+                }
+                if (agvLocMasts == null || agvLocMasts.size() < num) {
+                    log.error("<搴撲綅涓嶈冻>" + num + "<搴撲綅涓嶈冻>");
+                    return FAIL;
+                }
+            } catch (Exception e) {
+
+            }
             //妫�绱㈠簱浣嶏紝閫夋嫨鍚堥�傜殑搴撲綅
             locMast = agvCommonService.getLocNo(3, 1, true, true);
             locNo = locMast.getLocNo();
@@ -460,7 +486,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvLocMast.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvLocMast.getBarcode().substring(0, 2)));
+
 
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);
@@ -483,7 +510,7 @@
         return SUCCESS;
     }
 
-
+    @Transactional
     public ReturnT<String> autoEmptyBackSiqi(AgvLocMast agvLocMast) {
         Date now = new Date();
         //鏌ヨ宸ヤ綔妗�
@@ -501,9 +528,9 @@
         } else if (agvLocMast.getFloor() == 2) {
             floor = "F2";
         }
-        List<AgvWrkMast> agvWrkMasts = agvWrkMastService.selectList(new EntityWrapper<AgvWrkMast>().eq("io_type", 109).like("source_loc_no", floor).or().eq("io_type", 113));
+        List<AgvWrkMast> agvWrkMasts = agvWrkMastService.selectList(new EntityWrapper<AgvWrkMast>().eq("io_type", 109).like("barcode", "31", SqlLike.RIGHT).like("source_loc_no", floor).or().eq("io_type", 113));
         Config config = configService.selectOne(new EntityWrapper<Config>().eq("code", "RETURN_6_MAX"));
-        if (config == null && !Cools.isEmpty(config.getValue())) {
+        if (config != null && !Cools.isEmpty(config.getValue())) {
             if (agvWrkMasts.size() >= Integer.parseInt(config.getValue())) {
                 return FAIL;
             }
@@ -544,13 +571,14 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvLocMast.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvLocMast.getBarcode().substring(0, 2)));
+
 
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);
         mast.setModiUser(9527L);
         mast.setModiTime(now);
-        mast.setLogErrMemo("autoEmptyBack4");
+        mast.setLogErrMemo("autoEmptyBackSiqi");
         if (!agvWrkMastService.insertByIncrease(mast)) {
             throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
         }
@@ -568,6 +596,7 @@
     }
 
 
+    @Transactional
     public ReturnT<String> autoEmptyBack5(AgvBasDevp agvBasDevp) {
         //鏌ヨ宸ヤ綔妗�
         AgvWrkMast agvWrkMast = agvWrkMastService.selectByContainerCode(agvBasDevp.getBarcode());
@@ -585,7 +614,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvBasDevp.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvBasDevp.getBarcode().substring(0, 2)));
+
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);
         mast.setModiUser(9527L);
@@ -619,6 +649,8 @@
         return SUCCESS;
     }
 
+
+    @Transactional
     public ReturnT<String> autoEmptyBack6(AgvBasDevp agvBasDevp) {
         //鏌ヨ宸ヤ綔妗�
         AgvWrkMast agvWrkMast = agvWrkMastService.selectByContainerCode(agvBasDevp.getBarcode());
@@ -642,7 +674,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvBasDevp.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvBasDevp.getBarcode().substring(0, 2)));
+
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);
         mast.setModiUser(9527L);
@@ -658,6 +691,7 @@
         return SUCCESS;
     }
 
+    @Transactional
     public ReturnT<String> autoTransfers(AgvLocMast agvLocMast, Integer maxTansk) {
         Date now = new Date();
         List<AgvLocDetl> locDetls = agvLocDetlService.selectList(new EntityWrapper<AgvLocDetl>().eq("loc_no", agvLocMast.getLocNo()));
@@ -697,7 +731,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvLocMast.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvLocMast.getBarcode().substring(0, 2)));
+
 
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);
@@ -739,6 +774,7 @@
      * @param maxTansk
      * @return
      */
+    @Transactional
     public ReturnT<String> autoTransfersV2(AgvLocMast agvLocMast, Integer maxTansk) {
         Date now = new Date();
         List<AgvLocDetl> locDetls = agvLocDetlService.selectList(new EntityWrapper<AgvLocDetl>().eq("loc_no", agvLocMast.getLocNo()));
@@ -755,9 +791,9 @@
         AgvLocMast LocMast;
         if (agvLocMast.getLev1() == 1) {
             //妫�绱㈠簱浣嶏紝閫夋嫨鍚堥�傜殑搴撲綅
-            LocMast = agvCommonService.getLocByLocRule(3, 1, 2);
+            LocMast = agvCommonService.getLocByLocRule2(3, 1, 2);
         } else {
-            LocMast = agvCommonService.getLocByLocRule(3, 1, 1);
+            LocMast = agvCommonService.getLocByLocRule2(3, 1, 1);
         }
         List<AgvWrkMast> agvWrkMasts = agvWrkMastService.selectList(new EntityWrapper<AgvWrkMast>().eq("io_type", 12));
         if (agvWrkMasts.size() >= maxTansk) {
@@ -779,7 +815,8 @@
         //璐ф灦缂栫爜
         mast.setBarcode(agvLocMast.getBarcode());
         //璐ф灦绫诲瀷
-        mast.setWhsType(30);
+        mast.setWhsType(Integer.parseInt(agvLocMast.getBarcode().substring(0, 2)));
+
 
         mast.setAppeUser(9527L);
         mast.setAppeTime(now);

--
Gitblit v1.9.1