From 9d13343087fad70aebae38f04d533dd3832ef40c Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 10 三月 2021 13:20:42 +0800
Subject: [PATCH] #

---
 src/main/java/zy/cloud/wms/manager/service/impl/LocDetlServiceImpl.java |   88 ++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 85 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..a5141f7 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,94 @@
 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<LocDetl> page) {
+        page.setRecords(baseMapper.listByPage(page.getCondition()));
+        page.setTotal(baseMapper.listByPageCount(page.getCondition()));
+        return page;
+    }
+
+    @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