From d44598d72c02bc05227b64749ea017c1eb69c6a5 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期六, 06 三月 2021 14:46:46 +0800 Subject: [PATCH] # --- src/main/java/zy/cloud/wms/manager/service/impl/LocDetlServiceImpl.java | 86 +++++++++++++++++++++++++++++++++++++++++- 1 files changed, 83 insertions(+), 3 deletions(-) diff --git a/src/main/java/zy/cloud/wms/manager/service/impl/LocDetlServiceImpl.java b/src/main/java/zy/cloud/wms/manager/service/impl/LocDetlServiceImpl.java index c74583b..0578a6e 100644 --- a/src/main/java/zy/cloud/wms/manager/service/impl/LocDetlServiceImpl.java +++ b/src/main/java/zy/cloud/wms/manager/service/impl/LocDetlServiceImpl.java @@ -1,12 +1,92 @@ package zy.cloud.wms.manager.service.impl; -import zy.cloud.wms.manager.mapper.LocDetlMapper; -import zy.cloud.wms.manager.entity.LocDetl; -import zy.cloud.wms.manager.service.LocDetlService; +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 org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import zy.cloud.wms.common.config.CodeCoolException; +import zy.cloud.wms.manager.entity.CustOrder; +import zy.cloud.wms.manager.entity.LocDetl; +import zy.cloud.wms.manager.entity.Mat; +import zy.cloud.wms.manager.mapper.LocDetlMapper; +import zy.cloud.wms.manager.service.CustOrderService; +import zy.cloud.wms.manager.service.LocDetlService; +import zy.cloud.wms.manager.service.MatService; + +import java.util.ArrayList; +import java.util.List; +import java.util.stream.Collectors; @Service("locDetlService") public class LocDetlServiceImpl extends ServiceImpl<LocDetlMapper, LocDetl> implements LocDetlService { + @Autowired + private CustOrderService custOrderService; + @Autowired + private MatService matService; + + @Override + public Page<LocDetl> getPage(Page page, String nodeId, Object locNo, Object matnr, Object maktx) { + return page.setRecords(baseMapper.listByPage(page, nodeId, locNo, matnr, maktx)); + } + + @Override + public LocDetl getLocDetl(Long nodeId, String matnr) { + return this.baseMapper.selectByLocNoAndMatnr(nodeId, matnr); + } + + @Override + public List<LocDetl> findOfSort(String matnr) { + List<LocDetl> result = new ArrayList<>(); + List<LocDetl> locDetls = this.baseMapper.selectByPrior(matnr, null); + if (!Cools.isEmpty(locDetls)) { + result.addAll(locDetls); + } + List<Long> nodeIds = locDetls.stream().map(LocDetl::getNodeId).distinct().collect(Collectors.toList()); + List<LocDetl> locDetls1 = this.selectList(new EntityWrapper<LocDetl>().eq("matnr", matnr).eq("status", 1).orderBy("create_time")); + for (LocDetl locDetl : locDetls1) { + if (!nodeIds.contains(locDetl.getNodeId())) { + result.add(locDetl); + } + } + return result; + } + + @Override + public void checkLocDetlCount(String number) { + List<CustOrder> custOrders = custOrderService.selectList(new EntityWrapper<CustOrder>().eq("number", number).eq("status", 1)); + StringBuilder errorMsg = new StringBuilder(); + boolean error = false; + for (CustOrder custOrder : custOrders) { + Double count = this.baseMapper.selectCountByMatnr(custOrder.getUserCode()); + if (count == null) { + count = 0.0D; + } + if (count < custOrder.getQty()) { + if (!error) { + error = true; + } + Mat mat = matService.selectByMatnr(custOrder.getUserCode()); + errorMsg.append(mat == null ? custOrder.getUserCode() : mat.getMaktx()).append("搴撳瓨涓嶈冻锛岀己璐ф暟閲忥細").append(custOrder.getQty() - count).append("</br>"); + } + } + if (error) { + throw new CodeCoolException("20001-" + errorMsg.toString()); + } + } + + @Override + public Boolean reduceStock(Long nodeId, String matnr, Double anfme) { + return this.baseMapper.reduceStock(nodeId, matnr, anfme)>0; + } + + @Override + public Boolean removeStock(Long nodeId, String matnr) { + return this.baseMapper.removeStock(nodeId, matnr)>0; + } + + + } -- Gitblit v1.9.1