From 914a092bc4c21d69641f94b68fecf61b25ddaca1 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期三, 06 九月 2023 13:11:38 +0800 Subject: [PATCH] #拣货单完成、上架规则 --- src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java | 182 +++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 181 insertions(+), 1 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 7bda2b3..1c8bf2b 100644 --- a/src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/NodeServiceImpl.java @@ -1,17 +1,48 @@ package com.zy.asrs.service.impl; import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.baomidou.mybatisplus.plugins.Page; import com.baomidou.mybatisplus.service.impl.ServiceImpl; +import com.core.common.Cools; +import com.core.common.R; +import com.core.common.SnowflakeIdWorker; import com.core.exception.CoolException; +import com.zy.asrs.entity.ManLocDetl; +import com.zy.asrs.entity.Mat; import com.zy.asrs.entity.Node; +import com.zy.asrs.entity.OrderDetl; +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.NodeService; +import com.zy.asrs.service.*; +import com.zy.asrs.utils.SaasUtils; +import com.zy.asrs.utils.VersionUtils; +import com.zy.system.entity.User; +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; +import java.util.Map; @Service("nodeService") public class NodeServiceImpl extends ServiceImpl<NodeMapper, Node> implements NodeService { + @Autowired + private NodeService nodeService; + @Autowired + private MatService matService; + @Autowired + private SnowflakeIdWorker snowflakeIdWorker; + @Autowired + private ManLocDetlService manLocDetlService; + @Autowired + private OrderDetlService orderDetlService; + @Autowired + private OrderService orderService; @Override public Node getTop() { Node top = this.selectOne(new EntityWrapper<Node>().eq("type", 0).eq("level", 0)); @@ -52,4 +83,153 @@ 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)); } + + @Override + public R stockPakin(PakinParam param, Long userId, Long hostId, User user) { + Node node = nodeService.selectByUuid(param.getNodeId(), hostId); + if (node == null) { + node = nodeService.selectById(param.getNodeId()); + } + if (node == null) { + return R.error("璐т綅涓嶅瓨鍦�"); + } + if (Cools.isEmpty(param.getMats())) { + return R.error("鍏ュ簱鐗╂枡涓嶈兘涓虹┖"); + } + Date now = new Date(); + for (MatnrDto dto : param.getMats()) { + + Mat mat = matService.selectByMatnr(dto.getMatnr()); + if (mat == null) { + throw new CoolException("鐗╂枡鏁版嵁閿欒锛岃鑱旂郴绠$悊鍛�"); + } + 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(node.getUuid()); + 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); + manLocDetl.setStatus(1); + manLocDetl.setPayment(1); + SaasUtils.insertLog(0,manLocDetl.getLocNo(),manLocDetl.getMatnr(), manLocDetl.getAnfme(),user.getUsername()); + 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.error("搴撲綅瀛樺湪鐗╂枡锛岃鍕块噸澶嶅叆搴�"); + } + if (!Cools.isEmpty(dto.getOrderNo())) { + OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>() + .eq("order_no", dto.getOrderNo()) + .eq("matnr", dto.getMatnr())); + orderDetl.setQty(orderDetl.getQty() + dto.getCount()); + orderDetlService.updateById(orderDetl); + orderService.checkSettleUpdate(orderDetl.getOrderId()); + } + } + return R.ok("鍏ュ簱鎴愬姛"); + } + + @Transactional + @Override + public R initPakout(List<InitPakoutParam> params, Long userId, Long hostId,User user) { + if (!Cools.isEmpty(params)) { + Date now = new Date(); + for (InitPakoutParam param : params) { + ManLocDetl manLocDetl = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>() + .eq("node_id", param.getNodeId()) + .eq("matnr", param.getMatnr())); + Node node = nodeService.selectOne(new EntityWrapper<Node>() + .eq("id", param.getNodeId())); + if (node == null) { + return R.error("鎵句笉鍒拌搴撲綅,璇疯仈绯荤鐞嗗憳:" + param.getNodeId() ); + } + if (manLocDetl == null) { + return R.error("鐗╂枡:"+ param.getMatnr() + " 鍦ㄥ簱浣嶄腑涓嶅瓨鍦�"); + } + if (manLocDetl.getAnfme() - param.getCount() < 0) { + return R.error("鐗╂枡:"+ param.getMatnr() + " 鍦ㄥ簱浣嶄腑鏁伴噺涓嶈冻"); + } else if (manLocDetl.getAnfme() - param.getCount() == 0) { + SaasUtils.insertLog(1,manLocDetl.getLocNo(), manLocDetl.getMatnr(),param.getCount(),user.getUsername()); + manLocDetlService.delete(new EntityWrapper<ManLocDetl>() + .eq("loc_no",node.getUuid()) + .eq("matnr",param.getMatnr())); + } 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(),param.getCount(),user.getUsername()); + } + } + } + return R.ok("鍑哄簱鎴愬姛"); + } + + @Transactional + @Override + public void locMove(String sourceLocNo, String targetLocNo, Long userId,User user) { + List<ManLocDetl> sourceManDetl = manLocDetlService.selectList(new EntityWrapper<ManLocDetl>() + .eq("loc_no", sourceLocNo)); + for (ManLocDetl source : sourceManDetl) { + Node targetNode = nodeService.selectOne(new EntityWrapper<Node>() + .eq("uuid", targetLocNo)); + Node sourceNode = nodeService.selectOne(new EntityWrapper<Node>() + .eq("uuid", sourceLocNo)); + if (targetNode == null || targetNode.equals("")) { + throw new RuntimeException("鏃犳硶鏌ヨ鍒扮Щ搴撶殑鐩爣搴撲綅"); + } + ManLocDetl check = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>() + .eq("loc_no", targetNode.getUuid()) + .eq("matnr", source.getMatnr())); + if (check == null) { + manLocDetlService.delete(new EntityWrapper<ManLocDetl>().eq("loc_no", source.getLocNo()) + .eq("matnr", source.getMatnr())); + source.setLocNo(targetNode.getUuid()); + source.setNodeId(targetNode.getId()); + + SaasUtils.insertLog(2,source.getLocNo(), source.getMatnr(), source.getAnfme(),user.getUsername()); + 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())); + throw new RuntimeException("鐩爣搴撲綅鏈夌墿"); + } + + } + } + + @Override + public Page<Node> getPage(Page<Node> page) { + Map<String, Object> condition = page.getCondition(); + List<Node> manLocDetls = baseMapper.listByPage(condition); + page.setRecords(manLocDetls); + page.setTotal(baseMapper.listByPageCount(page.getCondition())); + return page; + } + + @Override + public List<String> getRemmendLoc(String matnr) { + return this.baseMapper.getRommendLoc(matnr); + } } -- Gitblit v1.9.1