From 1ea41a22eadfb3eef3d434bef7d2efff3bae331c Mon Sep 17 00:00:00 2001
From: ytfl <ytfl@qq.com>
Date: 星期日, 15 六月 2025 17:18:27 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/nc/task/handler/PlanOrderHandler.java |  152 ++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 109 insertions(+), 43 deletions(-)

diff --git a/src/main/java/com/zy/nc/task/handler/PlanOrderHandler.java b/src/main/java/com/zy/nc/task/handler/PlanOrderHandler.java
index fa91563..2dd3437 100644
--- a/src/main/java/com/zy/nc/task/handler/PlanOrderHandler.java
+++ b/src/main/java/com/zy/nc/task/handler/PlanOrderHandler.java
@@ -1,7 +1,6 @@
 package com.zy.nc.task.handler;
 
 import com.alibaba.fastjson.JSONObject;
-import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.exception.CoolException;
 import com.zy.asrs.entity.InventoryCheckOrder;
@@ -21,10 +20,12 @@
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.interceptor.TransactionAspectSupport;
 
 import java.util.ArrayList;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.List;
 
 @Service
@@ -63,17 +64,77 @@
      *
      * @return
      */
+    @Transactional
     public ReturnT<String> start1(List<NccSaleXsfhmxWms> wmsFlag) {
         try {
-            OpenOrderPakoutParam param = new OpenOrderPakoutParam();
-            param.setOrderType("閿�鍞彂璐�");
+            HashMap<String, List<NccSaleXsfhmxWms>> map = new HashMap<>();
+            List<NccSaleXsfhmxWms> fenzu;
+            for (NccSaleXsfhmxWms wms : wmsFlag) {
+                if (map.get(wms.getFhckbm()) == null) {
+                    fenzu = new ArrayList<>();
+                    fenzu.add(wms);
+                    map.put(wms.getFhckbm(), fenzu);
+                } else {
+                    fenzu = map.get(wms.getFhckbm());
+                    fenzu.add(wms);
+                    map.put(wms.getFhckbm(), fenzu);
+                }
+            }
+            int size = 1;
+            for (String key : map.keySet()) {
+                OpenOrderPakoutParam param = new OpenOrderPakoutParam();
+                DetlDto detlDto;
+                List<DetlDto> orderDetails = new ArrayList<>();
+                long i = 1;
+                for (NccSaleXsfhmxWms nccSaleXsfhmxWms : map.get(key)) {
+                    param.setOrderType("閿�鍞彂璐�");
+                    detlDto = new DetlDto();
+                    detlDto.setMatnr(nccSaleXsfhmxWms.getWlbm());
+                    detlDto.setAnfme(nccSaleXsfhmxWms.getNnum().doubleValue());
+                    detlDto.setBatch(nccSaleXsfhmxWms.getVbatchcode());
+                    detlDto.setWeight(nccSaleXsfhmxWms.getNastnum().doubleValue());
+                    detlDto.setStandby1(nccSaleXsfhmxWms.getFhckbm());
+                    detlDto.setLineNumber(i);
+                    detlDto.setRemark(JSONObject.toJSONString(nccSaleXsfhmxWms));
+                    orderDetails.add(detlDto);
+                    log.info("NccSaleXsfhmxWms鏁版嵁:{}", JSONObject.toJSON(nccSaleXsfhmxWms));
+                    i++;
+                    nccSaleXsfhmxWms.setWmsFlag(1);
+                    param.setOrderNo(nccSaleXsfhmxWms.getVbillcode() + "-" + size);
+                    param.setCstmrName(nccSaleXsfhmxWms.getKhmc());
+                }
+                param.setOrderDetails(orderDetails);
+                openService.pakoutOrderCreate(param);
+                nccSaleXsfhmxWmsService.updateBatchById(map.get(key));
+                size++;
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
+            return FAIL.setMsg(e.getMessage());
+        }
+        return SUCCESS;
+    }
+
+    /**
+     * 鍙戣揣
+     *
+     * @return
+     */
+    @Transactional
+    public ReturnT<String> start1In(List<NccSaleXsfhmxWms> wmsFlag) {
+        try {
+            OpenOrderPakinParam param = new OpenOrderPakinParam();
             DetlDto detlDto;
             List<DetlDto> orderDetails = new ArrayList<>();
             long i = 1;
             for (NccSaleXsfhmxWms nccSaleXsfhmxWms : wmsFlag) {
+                param.setOrderType("閿�鍞��璐�");
                 detlDto = new DetlDto();
                 detlDto.setMatnr(nccSaleXsfhmxWms.getWlbm());
-                detlDto.setAnfme(nccSaleXsfhmxWms.getNastnum().doubleValue());
+                detlDto.setAnfme(nccSaleXsfhmxWms.getNnum().doubleValue());
+                detlDto.setWeight(nccSaleXsfhmxWms.getNastnum().doubleValue());
+                detlDto.setStandby1(nccSaleXsfhmxWms.getFhckbm());
                 detlDto.setLineNumber(i);
                 detlDto.setRemark(JSONObject.toJSONString(nccSaleXsfhmxWms));
                 orderDetails.add(detlDto);
@@ -83,11 +144,11 @@
                 param.setOrderNo(nccSaleXsfhmxWms.getVbillcode());
             }
             param.setOrderDetails(orderDetails);
-            openService.pakoutOrderCreate(param);
+            openService.pakinOrderCreate(param);
             nccSaleXsfhmxWmsService.updateBatchById(wmsFlag);
         } catch (Exception e) {
             e.printStackTrace();
-            TransactionAspectSupport. currentTransactionStatus().setRollbackOnly();
+            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
             return FAIL.setMsg(e.getMessage());
         }
         return SUCCESS;
@@ -98,6 +159,7 @@
      *
      * @return
      */
+    @Transactional
     public ReturnT<String> start2In(List<NccScZkmxbWms> wmsFlag) {
         try {
             OpenOrderPakinParam param = new OpenOrderPakinParam();
@@ -110,6 +172,7 @@
                 detlDto = new DetlDto();
                 detlDto.setMatnr(nccScZkmxbWms.getWlbm());
                 detlDto.setAnfme(nccScZkmxbWms.getYingzzsl().doubleValue());
+                detlDto.setWeight(nccScZkmxbWms.getYingzsl().doubleValue());
                 detlDto.setBatch(nccScZkmxbWms.getVbatchcode());
                 detlDto.setLineNumber(i);
                 detlDto.setRemark(JSONObject.toJSONString(nccScZkmxbWms));
@@ -135,6 +198,7 @@
      *
      * @return
      */
+    @Transactional
     public ReturnT<String> start2Out(List<NccScZkmxbWms> wmsFlag) {
         try {
             OpenOrderPakoutParam param = new OpenOrderPakoutParam();
@@ -147,6 +211,7 @@
                 detlDto = new DetlDto();
                 detlDto.setMatnr(nccScZkmxbWms.getWlbm());
                 detlDto.setAnfme(nccScZkmxbWms.getYingzzsl().doubleValue());
+                detlDto.setWeight(nccScZkmxbWms.getYingzsl().doubleValue());
                 detlDto.setBatch(nccScZkmxbWms.getVbatchcode());
                 detlDto.setLineNumber(i);
                 detlDto.setRemark(JSONObject.toJSONString(nccScZkmxbWms));
@@ -171,6 +236,7 @@
      *
      * @return
      */
+    @Transactional
     public ReturnT<String> start3(List<NccCgCgdhdWms> wmsFlag) {
         try {
             OpenOrderPakinParam param = new OpenOrderPakinParam();
@@ -183,6 +249,7 @@
                 detlDto = new DetlDto();
                 detlDto.setMatnr(nccCgCgdhdWms.getWlbm());
                 detlDto.setAnfme(nccCgCgdhdWms.getYdzsl().doubleValue());
+                detlDto.setAnfme(nccCgCgdhdWms.getYdsl().doubleValue());
                 detlDto.setBatch(nccCgCgdhdWms.getVbatchcode());
                 detlDto.setLineNumber(i);
                 detlDto.setRemark(JSONObject.toJSONString(nccCgCgdhdWms));
@@ -209,43 +276,40 @@
      *
      * @return
      */
-    public ReturnT<String> start4(List<NccCkPddWms> wmsFlag) {
-        try {
-            InventoryCheckOrder param = new InventoryCheckOrder();
-            InventoryCheckOrderDetl checkOrderDetl = null;
-            for (NccCkPddWms nccScZkmxbWms : wmsFlag) {
-                log.info("NccCkPddWms鏁版嵁:{}", JSONObject.toJSON(nccScZkmxbWms));
-                Mat mat = matService.selectByMatnr(nccScZkmxbWms.getWlbm());
-                if (Cools.isEmpty(mat)) {
-                    throw new CoolException(nccScZkmxbWms.getWlbm() + "缂栧彿鍟嗗搧妫�绱㈠け璐ワ紝璇峰厛娣诲姞鍟嗗搧");
-                }
-                List<InventoryCheckOrderDetl> checkOrderDetls = inventoryCheckOrderDetlService.selectList(new EntityWrapper<InventoryCheckOrderDetl>().eq("order_no", nccScZkmxbWms.getVbillcode()).eq("matnr", mat.getMatnr()).eq("batch", nccScZkmxbWms.getVbatchcode()));
-                if (checkOrderDetls != null && !checkOrderDetls.isEmpty()) {
-                    //throw new CoolException(nccScZkmxbWms.getWlbm() + "鐩樼偣鍗曠殑鏄庣粏閲嶅浜�");
-                }
-                checkOrderDetl = new InventoryCheckOrderDetl();
-                checkOrderDetl.setMatnr(nccScZkmxbWms.getWlbm());
-                checkOrderDetl.setMaktx(mat.getMaktx());
-                checkOrderDetl.setOrderNo(nccScZkmxbWms.getVbillcode());
-                checkOrderDetl.setAnfme(nccScZkmxbWms.getZmzsl().doubleValue());
-                checkOrderDetl.setBatch(nccScZkmxbWms.getVbatchcode());
-                inventoryCheckOrderDetlService.insert(checkOrderDetl);
-                nccScZkmxbWms.setWmsFlag(1);
-                param.setOrderNo(nccScZkmxbWms.getVbillcode());
-                param.setCreateBy(nccScZkmxbWms.getPdrmc());
-
-            }
-            param.setCreateTime(new Date());
-            param.setStatus("1");
-            inventoryCheckOrderService.insert(param);
-            nccCkPddWmsService.updateBatchById(wmsFlag);
-        } catch (Exception e) {
-            e.printStackTrace();
-            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
-            return FAIL.setMsg(e.getMessage());
-        }
-        return SUCCESS;
-    }
+//    @Transactional
+//    public ReturnT<String> start4(List<NccCkPddWms> wmsFlag) {
+//        try {
+//            InventoryCheckOrder param = new InventoryCheckOrder();
+//            InventoryCheckOrderDetl checkOrderDetl = null;
+//            for (NccCkPddWms nccScZkmxbWms : wmsFlag) {
+//                log.info("NccCkPddWms鏁版嵁:{}", JSONObject.toJSON(nccScZkmxbWms));
+//                Mat mat = matService.selectByMatnr(nccScZkmxbWms.getWlbm());
+//                if (Cools.isEmpty(mat)) {
+//                    throw new CoolException(nccScZkmxbWms.getWlbm() + "缂栧彿鍟嗗搧妫�绱㈠け璐ワ紝璇峰厛娣诲姞鍟嗗搧");
+//                }
+//                checkOrderDetl = new InventoryCheckOrderDetl();
+//                checkOrderDetl.setMatnr(nccScZkmxbWms.getWlbm());
+//                checkOrderDetl.setMaktx(mat.getMaktx());
+//                checkOrderDetl.setOrderNo(nccScZkmxbWms.getVbillcode());
+//                checkOrderDetl.setAnfme(nccScZkmxbWms.getZmzsl().doubleValue());
+//                checkOrderDetl.setBatch(nccScZkmxbWms.getVbatchcode());
+//                inventoryCheckOrderDetlService.insert(checkOrderDetl);
+//                nccScZkmxbWms.setWmsFlag(1);
+//                param.setOrderNo(nccScZkmxbWms.getVbillcode());
+//                param.setCreateBy(nccScZkmxbWms.getPdrmc());
+//
+//            }
+//            param.setCreateTime(new Date());
+//            param.setStatus("1");
+//            inventoryCheckOrderService.insert(param);
+//            nccCkPddWmsService.updateBatchById(wmsFlag);
+//        } catch (Exception e) {
+//            e.printStackTrace();
+//            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
+//            return FAIL.setMsg(e.getMessage());
+//        }
+//        return SUCCESS;
+//    }
 
 
     /**
@@ -253,6 +317,7 @@
      *
      * @return
      */
+    @Transactional
     public ReturnT<String> start5(List<NccSaleDbddWms> wmsFlag) {
         try {
             OpenOrderPakoutParam param = new OpenOrderPakoutParam();
@@ -265,6 +330,7 @@
                 detlDto = new DetlDto();
                 detlDto.setMatnr(nccCgCgdhdWms.getWlbm());
                 detlDto.setAnfme(nccCgCgdhdWms.getZsl().doubleValue());
+                detlDto.setWeight(nccCgCgdhdWms.getFsl().doubleValue());
                 detlDto.setBatch(nccCgCgdhdWms.getVbatchcode());
                 detlDto.setLineNumber(i);
                 detlDto.setRemark(JSONObject.toJSONString(nccCgCgdhdWms));

--
Gitblit v1.9.1