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