From 2facff7a8993d2ff6412ef70e477d3d4996892a6 Mon Sep 17 00:00:00 2001
From: mrzhssss <pro6@qq.com>
Date: 星期三, 16 三月 2022 16:56:29 +0800
Subject: [PATCH] #

---
 src/main/java/zy/cloud/wms/manager/controller/ReceiveDetlController.java |   72 ++++++++++++++++++++++++++++++++----
 1 files changed, 64 insertions(+), 8 deletions(-)

diff --git a/src/main/java/zy/cloud/wms/manager/controller/ReceiveDetlController.java b/src/main/java/zy/cloud/wms/manager/controller/ReceiveDetlController.java
index 0dc4932..10bc7c4 100644
--- a/src/main/java/zy/cloud/wms/manager/controller/ReceiveDetlController.java
+++ b/src/main/java/zy/cloud/wms/manager/controller/ReceiveDetlController.java
@@ -6,14 +6,10 @@
 import com.baomidou.mybatisplus.mapper.Wrapper;
 import com.baomidou.mybatisplus.plugins.Page;
 import com.core.common.DateUtils;
-import zy.cloud.wms.manager.entity.LocDetl;
-import zy.cloud.wms.manager.entity.Node;
-import zy.cloud.wms.manager.entity.ReceiveDetl;
-import zy.cloud.wms.manager.entity.ReceiveLog;
+import org.springframework.transaction.annotation.Transactional;
+import zy.cloud.wms.manager.entity.*;
 import zy.cloud.wms.manager.entity.dto.PutShelfDTO;
-import zy.cloud.wms.manager.service.LocDetlService;
-import zy.cloud.wms.manager.service.NodeService;
-import zy.cloud.wms.manager.service.ReceiveDetlService;
+import zy.cloud.wms.manager.service.*;
 import com.core.annotations.ManagerAuth;
 import com.core.common.BaseRes;
 import com.core.common.Cools;
@@ -21,7 +17,6 @@
 import zy.cloud.wms.common.web.BaseController;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
-import zy.cloud.wms.manager.service.ReceiveLogService;
 
 import java.util.*;
 
@@ -36,6 +31,8 @@
     private NodeService nodeService;
     @Autowired
     private ReceiveLogService receiveLogService;
+    @Autowired
+    private ReceiveService receiveService;
 
     @RequestMapping(value = "/receiveDetl/{id}/auth")
     @ManagerAuth
@@ -209,8 +206,67 @@
         receiveLog.setBatch(putShelfDTO.getBatch());
         receiveLog.setCreateBy(getUserId());
         receiveLog.setUpdateBy(getUserId());
+        receiveLog.setIoType(1);
         receiveLogService.insert(receiveLog);
         return R.ok("娣诲姞鎴愬姛");
     }
 
+    /**
+     * 鎾ら攢涓婃灦鎿嶄綔
+     */
+    @RequestMapping("/receiveDetl/renew/auth")
+    @ManagerAuth
+    @Transactional
+    public R renew(@RequestBody ReceiveDetl receiveDetl){
+        /**
+         * 鎺х
+         */
+        if (receiveDetl.getInQty() <= 0){
+            return R.error("娌℃湁涓婃灦璁板綍,鏃犳硶鎾ゅ洖");
+        }
+        Receive receive = receiveService.selectOne(new EntityWrapper<Receive>()
+                .eq("id", receiveDetl.getOrderId()));
+        if (Cools.isEmpty(receive)) {
+            return R.error("鎵句笉鍒拌鍗曟嵁,璇疯仈绯荤鐞嗗憳");
+        }
+        if (receive.getSettle() == 4){
+            return R.error("璇ュ崟鎹凡缁忓畬缁�");
+        }
+
+        /**
+         * 淇敼搴撳瓨鏁伴噺,鍚屾椂鎾ゅ洖涓婃灦瀹屾垚鍚�,灏嗘搷浣滆褰曞弽鍐欏洖涓婃灦缁熻琛� man_receive_log
+         */
+        List<ReceiveLog> receiveLogs = receiveLogService.selectList(new EntityWrapper<ReceiveLog>()
+                .eq("order_no", receiveDetl.getOrderNo())
+                .eq("matnr", receiveDetl.getMatnr())
+                .eq("batch", receiveDetl.getBatch())
+                .eq("io_type", 1));
+        if (!Cools.isEmpty(receiveLogs)) {
+            return R.error("鎵句笉鍒板叆搴撹褰�");
+        }
+        for (ReceiveLog receiveLog : receiveLogs) {
+            locDetlService.delete(new EntityWrapper<LocDetl>()
+                    .eq("loc_no",receiveLog.getNodeName())
+                    .eq("matnr",receiveLog.getMatnr())
+                    .eq("batch",receiveLog.getBatch()));
+            receiveLog.setIoType(101);
+            receiveLog.setCreateBy(getUserId());
+            receiveLog.setUpdateBy(getUserId());
+            receiveLogService.insert(receiveLog);
+        }
+
+        /**
+         * 鍙嶅啓鍥炲叆搴撴。
+         */
+        receiveDetl.setInQty(0);
+        receiveDetl.setUpdateTime(new Date());
+        receiveDetl.setUpdateBy(getUserId());
+        receiveDetlService.update(receiveDetl,new EntityWrapper<ReceiveDetl>()
+                .eq("id",receiveDetl.getId()));
+
+
+
+        return R.ok("鎾ゅ洖鎴愬姛");
+    }
+
 }

--
Gitblit v1.9.1