From b29a1cb6fbca3cf8cf1d307c4c519ae2047c9b18 Mon Sep 17 00:00:00 2001
From: zhangherong <571457620@qq.com>
Date: 星期四, 04 九月 2025 15:43:13 +0800
Subject: [PATCH] art: 物料台账-相关接口修改

---
 src/main/java/org/jeecg/modules/lsw/service/impl/LswMaterialServiceImpl.java |   77 ++++++++++++++++++++------------------
 1 files changed, 41 insertions(+), 36 deletions(-)

diff --git a/src/main/java/org/jeecg/modules/lsw/service/impl/LswMaterialServiceImpl.java b/src/main/java/org/jeecg/modules/lsw/service/impl/LswMaterialServiceImpl.java
index 2808281..f9f93f1 100644
--- a/src/main/java/org/jeecg/modules/lsw/service/impl/LswMaterialServiceImpl.java
+++ b/src/main/java/org/jeecg/modules/lsw/service/impl/LswMaterialServiceImpl.java
@@ -2,23 +2,17 @@
 
 import cn.hutool.core.collection.CollectionUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
-import com.baomidou.mybatisplus.core.metadata.IPage;
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import org.apache.commons.lang.StringUtils;
 import org.jeecg.common.constant.CommonConstant;
 import org.jeecg.common.exception.JeecgBootException;
 import org.jeecg.modules.lsw.entity.LswMaterial;
-import org.jeecg.modules.lsw.entity.LswMaterialInventory;
-import org.jeecg.modules.lsw.mapper.LswMaterialInventoryMapper;
 import org.jeecg.modules.lsw.mapper.LswMaterialMapper;
 import org.jeecg.modules.lsw.service.ILswMaterialService;
-import org.springframework.beans.factory.annotation.Autowired;
+import org.jeecg.modules.mes.entity.MesProductionOrder;
+import org.jeecg.modules.sap.dto.OrderBomDTO;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
-import javax.servlet.http.HttpServletRequest;
-import java.io.Serializable;
 import java.util.Collection;
 import java.util.HashMap;
 import java.util.List;
@@ -33,38 +27,11 @@
 @Service
 public class LswMaterialServiceImpl extends ServiceImpl<LswMaterialMapper, LswMaterial> implements ILswMaterialService {
 
-    @Autowired
-    private LswMaterialMapper lswMaterialMapper;
-    @Autowired
-    private LswMaterialInventoryMapper lswMaterialInventoryMapper;
-
-    @Override
-    public IPage<Map<String, Object>> getLswMaterialListData(Integer pageNo, Integer pageSize, HttpServletRequest req) {
-        IPage<Map> pageData = new Page<Map>(pageNo, pageSize);
-        Map<String, String> paramMap = new HashMap<String, String>();
-        Map<String, String[]> parameterMap = req.getParameterMap();
-        if (null != parameterMap) {
-            if (parameterMap.containsKey("materialNumber") && StringUtils.isNotBlank(parameterMap.get("materialNumber")[0])) {
-                paramMap.put("materialNumber", parameterMap.get("materialNumber")[0]);
-            }
-            if (parameterMap.containsKey("materialName") && StringUtils.isNotBlank(parameterMap.get("materialName")[0])) {
-                paramMap.put("materialName", parameterMap.get("materialName")[0].trim());
-            }
-            if (parameterMap.containsKey("materialModel") && StringUtils.isNotBlank(parameterMap.get("materialModel")[0])) {
-                paramMap.put("materialModel", parameterMap.get("materialModel")[0].trim());
-            }
-            if (parameterMap.containsKey("materialCategory") && StringUtils.isNotBlank(parameterMap.get("materialCategory")[0])) {
-                paramMap.put("materialCategory", parameterMap.get("materialCategory")[0].trim());
-            }
-        }
-        return super.getBaseMapper().getLswMaterialListData(pageData, paramMap);
-    }
-
     @Override
     @Transactional(rollbackFor = Exception.class)
     public boolean editMaterial(LswMaterial lswMaterial) {
         LswMaterial entity = this.getBaseMapper().selectById(lswMaterial.getId());
-        if(entity == null) {
+        if (entity == null) {
             throw new JeecgBootException("瑕佺紪杈戠殑鏁版嵁涓嶅瓨鍦紒");
         }
         entity.setMaterialCategory(lswMaterial.getMaterialCategory());
@@ -84,4 +51,42 @@
         return list.get(0);
     }
 
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean saveOrUpdateMaterial(Map<String, MesProductionOrder> orderMap, List<OrderBomDTO> orderBomDTOList) {
+        Map<String, LswMaterial> addMap = new HashMap<>();
+        for (Map.Entry<String, MesProductionOrder> entry : orderMap.entrySet()) {
+            MesProductionOrder order = entry.getValue();
+            LswMaterial material = queryByMaterialNumber(order.getMaterialNumber());
+            if (material == null) {
+                //鏂板鐗╂枡
+                material = new LswMaterial();
+                material.setMaterialStatus(CommonConstant.STATUS_1);
+                material.setMaterialNumber(order.getMaterialNumber());
+                material.setMaterialName(order.getMaterialName());
+                material.setMaterialUnit(order.getProductionUnit());
+                material.setDelFlag(CommonConstant.DEL_FLAG_0);
+                addMap.put(material.getMaterialNumber(), material);
+            }
+        }
+        for (OrderBomDTO bomDTO : orderBomDTOList) {
+            LswMaterial material = queryByMaterialNumber(bomDTO.getMATNR());
+            if (material == null) {
+                //鏂板鐗╂枡
+                material = new LswMaterial();
+                material.setMaterialStatus(CommonConstant.STATUS_1);
+                material.setMaterialNumber(bomDTO.getMATNR());
+                material.setMaterialName(bomDTO.getMAKTX());
+                material.setMaterialUnit(bomDTO.getMEINS());
+                material.setDelFlag(CommonConstant.DEL_FLAG_0);
+                addMap.put(material.getMaterialNumber(), material);
+            }
+        }
+        if (CollectionUtil.isNotEmpty(addMap)) {
+            Collection<LswMaterial> addList = addMap.values();
+            super.saveBatch(addList);
+        }
+        return true;
+    }
+
 }

--
Gitblit v1.9.3