From 57936e11434f6614f818a0a0a495918dc1af6dd6 Mon Sep 17 00:00:00 2001 From: pang.jiabao <pang_jiabao@163.com> Date: 星期一, 02 十二月 2024 08:07:01 +0800 Subject: [PATCH] 单据出库完成 --- src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java | 100 ++++++++++++++++++++++++++++++++++---------------- 1 files changed, 68 insertions(+), 32 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java index e4049ed..0a4695f 100644 --- a/src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java @@ -12,18 +12,15 @@ import com.zy.asrs.entity.param.InitPakoutParam; import com.zy.asrs.entity.param.MatnrDto; import com.zy.asrs.entity.param.PakinParam; -import com.zy.asrs.entity.result.Pakin; import com.zy.asrs.mapper.NodeMapper; import com.zy.asrs.service.ManLocDetlService; import com.zy.asrs.service.MatService; import com.zy.asrs.service.NodeService; import com.zy.asrs.utils.SaasUtils; -import com.zy.asrs.utils.VersionUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import java.beans.Transient; import java.util.Date; import java.util.List; @@ -70,12 +67,12 @@ @Override public Node selectByUuid(String uuid, Long hostId, Integer type) { - return selectOne(new EntityWrapper<Node>().eq("host_id", hostId).eq("uuid", uuid).eq("type", type)); + return selectOne(new EntityWrapper<Node>().isNull("host_id").eq("uuid", uuid).eq("type", type)); } @Override public Node selectByUuid(String uuid, Long hostId, Integer type, Long parentId) { - return selectOne(new EntityWrapper<Node>().eq("host_id", hostId).eq("uuid", uuid).eq("type", type).eq("parent_id", parentId)); + return selectOne(new EntityWrapper<Node>().isNull("host_id").eq("uuid", uuid).eq("type", type).eq("parent_id", parentId)); } @Override @@ -92,26 +89,38 @@ } Date now = new Date(); for (MatnrDto dto : param.getMats()) { + Mat mat = matService.selectByMatnr(dto.getMatnr()); if (mat == null) { throw new CoolException("鐗╂枡鏁版嵁閿欒锛岃鑱旂郴绠$悊鍛�"); } - ManLocDetl manLocDetl = new ManLocDetl(); - manLocDetl.setLocNo(node.getUuid()); - manLocDetl.setNodeId(node.getId()); - manLocDetl.setZpallet(mat.getBarcode()); - manLocDetl.setAnfme(dto.getCount()); - manLocDetl.setMatnr(mat.getMatnr()); - manLocDetl.setMaktx(mat.getMaktx()); - manLocDetl.setName(mat.getName()); - manLocDetl.setSpecs(mat.getSpecs()); - manLocDetl.setModel(mat.getModel()); - manLocDetl.setBatch(mat.getBeBatch() + ""); - manLocDetl.setCreateTime(now); - manLocDetl.setModiTime(now); - manLocDetl.setCreateBy(userId); - SaasUtils.insertLog(0,manLocDetl.getLocNo(),manLocDetl.getMatnr(), manLocDetl.getAnfme()); - manLocDetlService.insert(manLocDetl); + ManLocDetl check = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>() + .eq("loc_no", node.getUuid()) + .eq("matnr", dto.getMatnr())); + if (check == null) { + ManLocDetl manLocDetl = new ManLocDetl(); + manLocDetl.setLocNo(node.getUuid()); + manLocDetl.setNodeId(node.getId()); + manLocDetl.setZpallet(mat.getBarcode()); + manLocDetl.setAnfme(dto.getCount()); + manLocDetl.setMatnr(mat.getMatnr()); + manLocDetl.setMaktx(mat.getMaktx()); + manLocDetl.setName(mat.getName()); + manLocDetl.setBatch(null); + manLocDetl.setSpecs(mat.getSpecs()); + manLocDetl.setModel(mat.getModel()); + manLocDetl.setCreateTime(now); + manLocDetl.setModiTime(now); + manLocDetl.setCreateBy(userId); + SaasUtils.insertLog(0,manLocDetl.getLocNo(),manLocDetl.getMatnr(), manLocDetl.getAnfme(),userId, manLocDetl.getBatch()); + manLocDetlService.insert(manLocDetl); + }else { + check.setAnfme(dto.getCount() + check.getAnfme()); + manLocDetlService.update(check,new EntityWrapper<ManLocDetl>() + .eq("loc_no", node.getUuid()) + .eq("matnr", dto.getMatnr())); + } + } return R.ok("鍏ュ簱鎴愬姛"); @@ -136,13 +145,23 @@ } if (manLocDetl.getAnfme() - param.getCount() < 0) { return R.error("鐗╂枡:"+ param.getMatnr() + " 鍦ㄥ簱浣嶄腑鏁伴噺涓嶈冻"); - }else { + } else if (manLocDetl.getAnfme() - param.getCount() == 0) { + SaasUtils.insertLog(1,manLocDetl.getLocNo(), manLocDetl.getMatnr(),param.getCount(),userId,manLocDetl.getBatch()); + manLocDetlService.delete(new EntityWrapper<ManLocDetl>() + .eq("loc_no",node.getUuid()) + .eq("matnr",param.getMatnr())); + // 娓呯┖搴撲綅鏉$爜 + node.setBarcode(""); + node.setUpdateBy(userId); + node.setUpdateTime(now); + nodeService.updateById(node); + } else { manLocDetl.setAnfme(manLocDetl.getAnfme() - param.getCount()); manLocDetlService.update(manLocDetl,new EntityWrapper<ManLocDetl>() .eq("loc_no",node.getUuid()) .eq("matnr",param.getMatnr())); - SaasUtils.insertLog(1,manLocDetl.getLocNo(), manLocDetl.getMatnr(),manLocDetl.getAnfme()); + SaasUtils.insertLog(1,manLocDetl.getLocNo(), manLocDetl.getMatnr(),param.getCount(),userId,manLocDetl.getBatch()); } } } @@ -152,19 +171,36 @@ @Transactional @Override public void locMove(String sourceLocNo, String targetLocNo, Long userId) { - List<ManLocDetl> targets = manLocDetlService.selectList(new EntityWrapper<ManLocDetl>() + List<ManLocDetl> sourceManDetl = manLocDetlService.selectList(new EntityWrapper<ManLocDetl>() .like("loc_no", sourceLocNo)); - for (ManLocDetl target : targets) { - Node uuid = nodeService.selectOne(new EntityWrapper<Node>() + for (ManLocDetl source : sourceManDetl) { + Node targetNode = nodeService.selectOne(new EntityWrapper<Node>() .eq("uuid", targetLocNo)); - if (uuid == null || uuid.equals("")) { + Node sourceNode = nodeService.selectOne(new EntityWrapper<Node>() + .eq("uuid", sourceLocNo)); + if (targetNode == null || targetNode.equals("")) { throw new RuntimeException("鏃犳硶鏌ヨ鍒扮Щ搴撶殑鐩爣搴撲綅"); } - manLocDetlService.deleteById(target); - target.setLocNo(uuid.getUuid()); - target.setNodeId(uuid.getId()); - SaasUtils.insertLog(2,target.getLocNo(), target.getMatnr(), target.getAnfme()); - manLocDetlService.insert(target); + ManLocDetl check = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>() + .eq("loc_no", targetNode.getUuid()) + .eq("matnr", source.getMatnr())); + if (check == null) { + manLocDetlService.deleteById(source); + source.setLocNo(targetNode.getUuid()); + source.setNodeId(targetNode.getId()); + + SaasUtils.insertLog(2,source.getLocNo(), source.getMatnr(), source.getAnfme(),userId,source.getBatch()); + manLocDetlService.insert(source); + }else { + check.setAnfme(check.getAnfme() + source.getAnfme()); + manLocDetlService.update(check,new EntityWrapper<ManLocDetl>() + .eq("loc_no", targetNode.getUuid()) + .eq("matnr", check.getMatnr())); + manLocDetlService.delete(new EntityWrapper<ManLocDetl>() + .eq("loc_no", sourceNode.getUuid()) + .eq("matnr", source.getMatnr())); + } + } } } -- Gitblit v1.9.1