From b3fcc1eda7f6305e9ae128b6ca51cf6d9f3f90c1 Mon Sep 17 00:00:00 2001
From: Junjie <DELL@qq.com>
Date: 星期四, 25 十二月 2025 09:58:49 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/common/web/param/TransferLocParam.java |   12 ++++
 src/main/java/com/zy/asrs/utils/Utils.java                  |   18 ++++++
 src/main/java/com/zy/common/web/WcsController.java          |  137 +++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 165 insertions(+), 2 deletions(-)

diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java
index ac837db..c965065 100644
--- a/src/main/java/com/zy/asrs/utils/Utils.java
+++ b/src/main/java/com/zy/asrs/utils/Utils.java
@@ -624,4 +624,22 @@
         return result;
     }
 
+    /**
+     * 閫氳繃搴撲綅鍙疯幏鍙栨墍鍦ㄥ贩閬�
+     */
+    public static int getLaneByLocNo(String locNo) {
+        int row = Utils.getRow(locNo);
+        switch (row) {
+            case 1:
+            case 2:
+            case 3:
+                return 1;
+            case 4:
+            case 5:
+            case 6:
+                return 2;
+        }
+        return 0;
+    }
+
 }
diff --git a/src/main/java/com/zy/common/web/WcsController.java b/src/main/java/com/zy/common/web/WcsController.java
index 8ab6a1b..a921aaa 100644
--- a/src/main/java/com/zy/common/web/WcsController.java
+++ b/src/main/java/com/zy/common/web/WcsController.java
@@ -1,7 +1,6 @@
 package com.zy.common.web;
 
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
-import com.baomidou.mybatisplus.mapper.Wrapper;
 import com.core.common.Cools;
 import com.core.common.R;
 import com.core.exception.CoolException;
@@ -9,15 +8,17 @@
 import com.zy.asrs.entity.param.EmptyPlateOutParam;
 import com.zy.asrs.entity.result.FindLocNoAttributeVo;
 import com.zy.asrs.service.*;
+import com.zy.asrs.utils.Utils;
 import com.zy.common.CodeRes;
 import com.zy.common.model.LocTypeDto;
 import com.zy.common.model.StartupDto;
+import com.zy.common.properties.SlaveProperties;
 import com.zy.common.service.CommonService;
 import com.zy.common.web.param.SearchLocParam;
+import com.zy.common.web.param.TransferLocParam;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.transaction.annotation.Transactional;
-import org.springframework.transaction.interceptor.TransactionAspectSupport;
 import org.springframework.web.bind.annotation.*;
 
 import java.util.ArrayList;
@@ -54,6 +55,8 @@
     private WrkMastLogService wrkMastLogService;
     @Autowired
     private WrkDetlLogService wrkDetlLogService;
+    @Autowired
+    private SlaveProperties slaveProperties;
 
     @PostMapping("/pakin/loc/v1")
     @ResponseBody
@@ -138,6 +141,27 @@
         StartupDto dto = startupPickPutStore(param);
         log.info("WCS鎷f枡鐩樼偣鍏ュ簱鎺ュ彛,鎵樼洏鐮�:{}", param.getBarcode());
         return R.ok().add(dto);
+    }
+
+    @PostMapping("/transfer/loc/v1")
+    @ResponseBody
+    public synchronized R transferLocV1(@RequestBody TransferLocParam param) {
+        log.info("鏀跺埌WCS鐢宠绉诲簱鎺ュ彛璇锋眰====>>鍏ュ弬:{}", param);
+        if (Cools.isEmpty(param.getLocNo())) {
+            return R.error("搴撲綅鍙蜂笉瀛樺湪");
+        }
+
+        if (Cools.isEmpty(param.getLane())) {
+            return R.error("宸烽亾鍙蜂笉瀛樺湪");
+        }
+
+        try {
+            transferLoc(param.getLocNo(), param.getLane());
+            return R.ok();
+        } catch (Exception e) {
+            e.printStackTrace();
+            return R.error(e.getMessage());
+        }
     }
 
     @PostMapping("/auto/emptyIn/v1")
@@ -464,4 +488,113 @@
         return dto;
     }
 
+    @Transactional
+    public synchronized void transferLoc(String sourceLocNo, Integer lane) {
+        LocMast sourceLocMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", sourceLocNo));
+        if (sourceLocMast == null) {
+            throw new CoolException(sourceLocNo + "婧愬簱浣嶄笉瀛樺湪");
+        }
+
+        if (!(sourceLocMast.getLocSts().equals("F") || sourceLocMast.getLocSts().equals("D"))) {
+            throw new CoolException(sourceLocNo + "婧愬簱浣嶇姸鎬佷笉澶勪簬鍦ㄥ簱");
+        }
+
+        List<Integer> rows = locMastService.selectRowByCrnNo(sourceLocMast.getCrnNo());
+        LocMast transferLoc = null;
+        for (Integer row : rows) {
+            List<LocMast> locMasts = locMastService.selectList(new EntityWrapper<LocMast>()
+                    .eq("row1", row)
+                    .eq("loc_type1", sourceLocMast.getLocType1())
+                    .eq("loc_sts", "O")
+            );
+            for (LocMast locMast : locMasts) {
+                if (sourceLocMast.getCrnNo() == 1) {
+                    if (Utils.getLaneByLocNo(locMast.getLocNo()) != lane) {
+                        continue;
+                    }
+                }
+
+                if (Utils.isDeepLoc(slaveProperties, locMast.getLocNo())) {
+                    String shallowLocNo = Utils.getShallowLoc(slaveProperties, locMast.getLocNo());
+                    LocMast shallowLoc1 = locMastService.selectById(shallowLocNo);
+                    if (!shallowLoc1.getLocSts().equals("O")) {
+                        continue;
+                    }
+                }
+
+                transferLoc = locMast;
+                break;
+            }
+
+            if (null != transferLoc) {
+                break;
+            }
+        }
+
+        if (transferLoc == null) {
+            throw new CoolException(sourceLocNo + "搴撲綅绉昏浆澶辫触锛屾湭鎵惧埌绌哄簱浣�");
+        }
+
+        // 鑾峰彇宸ヤ綔鍙�
+        int workNo = commonService.getWorkNo(0);
+        // 淇濆瓨宸ヤ綔妗�
+        WrkMast wrkMast = new WrkMast();
+        wrkMast.setWrkNo(workNo);
+        wrkMast.setIoTime(new Date());
+        wrkMast.setWrkSts(11L); // 宸ヤ綔鐘舵�侊細11.鐢熸垚鍑哄簱ID
+        wrkMast.setIoType(11); // 鍏ュ嚭搴撶姸鎬侊細 11.搴撴牸绉昏浇
+        wrkMast.setIoPri(13D);
+        wrkMast.setCrnNo(transferLoc.getCrnNo());
+        wrkMast.setSourceLocNo(sourceLocMast.getLocNo()); // 婧愬簱浣�
+        wrkMast.setLocNo(transferLoc.getLocNo()); // 鐩爣搴撲綅
+        wrkMast.setFullPlt(sourceLocMast.getLocSts().equals("D") ? "N" : "Y"); // 婊℃澘
+        wrkMast.setPicking("N"); // 鎷f枡
+        wrkMast.setExitMk("N"); // 閫�鍑�
+        wrkMast.setEmptyMk(sourceLocMast.getLocSts().equals("D") ? "Y" : "N"); // 绌烘澘
+        wrkMast.setBarcode(sourceLocMast.getBarcode()); // 鎵樼洏鐮�
+        wrkMast.setLinkMis("N");
+        wrkMast.setAppeTime(new Date());
+        wrkMast.setModiTime(new Date());
+        boolean res = wrkMastService.insert(wrkMast);
+        if (!res) {
+            throw new CoolException(sourceLocNo + "搴撲綅绉昏浆澶辫触锛岀敓鎴愬簱浣嶇Щ杞伐浣滄。澶辫触");
+        }
+
+        // 宸ヤ綔妗f槑缁嗕繚瀛�
+        if (sourceLocMast.getLocSts().equals("F")) {
+            List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", sourceLocMast.getLocNo()));
+
+            for (LocDetl locDetl : locDetls) {
+                WrkDetl wrkDetl = new WrkDetl();
+                wrkDetl.sync(locDetl);
+                wrkDetl.setWrkNo(workNo);
+                wrkDetl.setIoTime(new Date());
+                wrkDetl.setAnfme(locDetl.getAnfme());
+                wrkDetl.setAppeTime(new Date());
+                wrkDetl.setModiTime(new Date());
+                if (!wrkDetlService.insert(wrkDetl)) {
+                    throw new CoolException(sourceLocNo + "搴撲綅绉昏浆澶辫触锛岀敓鎴愬簱浣嶇Щ杞伐浣滄槑缁嗘。澶辫触");
+                }
+            }
+        }
+
+        // 淇敼婧愬簱浣嶇姸鎬�
+        if (sourceLocMast.getLocSts().equals("D") || sourceLocMast.getLocSts().equals("F")) {
+            sourceLocMast.setLocSts("R"); // R.鍑哄簱棰勭害
+            sourceLocMast.setModiTime(new Date());
+            if (!locMastService.updateById(sourceLocMast)) {
+                throw new CoolException(sourceLocNo + "搴撲綅绉昏浆澶辫触锛屾洿鏂版簮搴撲綅鐘舵�佸け璐�");
+            }
+        }
+
+        // 淇敼鐩爣搴撲綅鐘舵��
+        if (transferLoc.getLocSts().equals("O")) {
+            transferLoc.setLocSts("S"); // S.鍏ュ簱棰勭害
+            transferLoc.setModiTime(new Date());
+            if (!locMastService.updateById(transferLoc)) {
+                throw new CoolException(sourceLocNo + "搴撲綅绉昏浆澶辫触锛屾洿鏂扮洰鏍囧簱浣嶇姸鎬佸け璐�");
+            }
+        }
+    }
+
 }
diff --git a/src/main/java/com/zy/common/web/param/TransferLocParam.java b/src/main/java/com/zy/common/web/param/TransferLocParam.java
new file mode 100644
index 0000000..782b234
--- /dev/null
+++ b/src/main/java/com/zy/common/web/param/TransferLocParam.java
@@ -0,0 +1,12 @@
+package com.zy.common.web.param;
+
+import lombok.Data;
+
+@Data
+public class TransferLocParam {
+
+    private String locNo;
+
+    private Integer lane;
+
+}

--
Gitblit v1.9.1