From 097433ca16e6f8aa7ec736298693dd5c7613e811 Mon Sep 17 00:00:00 2001
From: pjb <pjb123456>
Date: 星期日, 13 七月 2025 10:19:12 +0800
Subject: [PATCH] 堆垛机分配库位加入可入条件限制

---
 src/main/java/com/zy/asrs/controller/LocMastController.java |   76 +++++++++++++++++++++++++++++++++++---
 1 files changed, 70 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/LocMastController.java b/src/main/java/com/zy/asrs/controller/LocMastController.java
index 757a36f..4037e82 100644
--- a/src/main/java/com/zy/asrs/controller/LocMastController.java
+++ b/src/main/java/com/zy/asrs/controller/LocMastController.java
@@ -17,6 +17,7 @@
 import com.zy.asrs.service.*;
 import com.zy.common.entity.Parameter;
 import com.zy.common.model.Shelves;
+import com.zy.common.service.CommonService;
 import com.zy.common.web.BaseController;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
@@ -42,6 +43,15 @@
 
     @Resource
     private LocDetlMapper locDetlMapper;
+
+    @Resource
+    private CommonService commonService;
+
+    @Resource
+    private WrkMastLogService wrkMastLogService;
+
+    @Resource
+    private WrkDetlLogService wrkDetlLogService;
 
     @RequestMapping(value = "/locMast/init/pwd")
     public R locMastInitPwd(@RequestParam(required = false) String pwd) {
@@ -73,6 +83,21 @@
         excludeTrash(param);
         EntityWrapper<LocMast> wrapper = new EntityWrapper<>();
         convert(param, wrapper);
+        if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));}
+        return R.ok(locMastService.selectPage(new Page<>(curr, limit), wrapper));
+    }
+
+    @RequestMapping(value = "/locMast/emptyList/auth")
+    @ManagerAuth
+    public R emptyList(@RequestParam(defaultValue = "1")Integer curr,
+                  @RequestParam(defaultValue = "10")Integer limit,
+                  @RequestParam(required = false)String orderByField,
+                  @RequestParam(required = false)String orderByType,
+                  @RequestParam Map<String, Object> param){
+        excludeTrash(param);
+        EntityWrapper<LocMast> wrapper = new EntityWrapper<>();
+        convert(param, wrapper);
+        wrapper.in("loc_sts","Z","M");
         if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));}
         return R.ok(locMastService.selectPage(new Page<>(curr, limit), wrapper));
     }
@@ -118,12 +143,12 @@
             return R.error();
         }
 
-        WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>()
-                .eq("source_loc_no", locMast.getLocNo())
-                .or().eq("loc_no", locMast.getLocNo()));
-        if(!Cools.isEmpty(wrkMast)){
-            return  R.error("璇ュ簱浣嶆鍦ㄤ綔涓氾紝璇峰厛澶勭悊宸ヤ綔妗�");
-        }
+//        WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>()
+//                .eq("source_loc_no", locMast.getLocNo())
+//                .or().eq("loc_no", locMast.getLocNo()));
+//        if(!Cools.isEmpty(wrkMast)){
+//            return  R.error("璇ュ簱浣嶆鍦ㄤ綔涓氾紝璇峰厛澶勭悊宸ヤ綔妗�");
+//        }
 
         LocMast oldLocMast = locMastService.selectById(locMast.getLocNo());
         if (locMast.getLocSts().equals("F") && (oldLocMast.getLocSts().equals("D") || oldLocMast.getLocSts().equals("O"))) {
@@ -134,6 +159,31 @@
         if (oldLocMast.getLocSts().equals("R") || oldLocMast.getLocSts().equals("F") || oldLocMast.getLocSts().equals("S")) {
             if (locMast.getLocSts().equals("O") || locMast.getLocSts().equals("D")) {
                 List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()));
+                // 娣诲姞鍘嗗彶宸ヤ綔涓绘。
+                WrkMastLog wrkMastLog = new WrkMastLog();
+                wrkMastLog.setWrkNo(commonService.getWorkNo(3));
+                wrkMastLog.setIoTime(now);
+                wrkMastLog.setWrkSts(5);
+                wrkMastLog.setIoType(19);
+                wrkMastLog.setIoPri(13D); // 浼樺厛绾�
+                wrkMastLog.setCrnNo(locMast.getCrnNo());
+                wrkMastLog.setSourceLocNo(locMast.getLocNo());
+                wrkMastLog.setLocNo(locMast.getLocNo());
+                wrkMastLog.setBarcode(locMast.getBarcode()); // 鎵樼洏鐮�
+                wrkMastLog.setFullPlt("Y"); // 婊℃澘锛歒
+                wrkMastLog.setPicking("N"); // 鎷f枡
+                wrkMastLog.setExitMk("N"); // 閫�鍑�
+                wrkMastLog.setEmptyMk("N"); // 绌烘澘
+                wrkMastLog.setLinkMis("Y");
+                // 鎿嶄綔浜哄憳鏁版嵁
+                wrkMastLog.setAppeTime(now);
+                wrkMastLog.setModiTime(now);
+                wrkMastLog.setAppeUser(getUserId());
+                wrkMastLog.setModiUser(getUserId());
+                boolean res = wrkMastLogService.insert(wrkMastLog);
+                if (!res) {
+                    throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�");
+                }
                 for (LocDetl locDetl : locDetls) {
                     // 淇濆瓨璋冩暣璁板綍
                     AdjDetl adjDetl = new AdjDetl();
@@ -149,6 +199,20 @@
                     if (!adjDetlService.insert(adjDetl)) {
                         throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
                     }
+
+                    // 娣诲姞鍘嗗彶宸ヤ綔鏄庣粏
+                    WrkDetlLog wrkDetl = new WrkDetlLog();
+                    wrkDetl.sync(locDetl);
+                    wrkDetl.setWrkNo(wrkMastLog.getWrkNo());
+                    wrkDetl.setIoTime(wrkMastLog.getIoTime());
+                    wrkDetl.setAnfme(0.0);
+                    wrkDetl.setAppeTime(now);
+                    wrkDetl.setModiTime(now);
+                    wrkMastLog.setAppeUser(getUserId());
+                    wrkMastLog.setModiUser(getUserId());
+                    if (!wrkDetlLogService.insert(wrkDetl)) {
+                        throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触");
+                    }
                 }
                 if (!locDetlService.delete(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()))) {
                     throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");

--
Gitblit v1.9.1