From eeebc22772cbf7dc03ed4bc6f734e6de9f5c3e75 Mon Sep 17 00:00:00 2001 From: zhangherong <571457620@qq.com> Date: 星期三, 06 八月 2025 10:55:56 +0800 Subject: [PATCH] art: 订单BOM、物料工序 后端代码修改、优化 --- src/main/java/org/jeecg/modules/pms/service/impl/PmsProcessBillMaterialsServiceImpl.java | 94 ++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 76 insertions(+), 18 deletions(-) diff --git a/src/main/java/org/jeecg/modules/pms/service/impl/PmsProcessBillMaterialsServiceImpl.java b/src/main/java/org/jeecg/modules/pms/service/impl/PmsProcessBillMaterialsServiceImpl.java index eda1def..ec90412 100644 --- a/src/main/java/org/jeecg/modules/pms/service/impl/PmsProcessBillMaterialsServiceImpl.java +++ b/src/main/java/org/jeecg/modules/pms/service/impl/PmsProcessBillMaterialsServiceImpl.java @@ -1,43 +1,101 @@ package org.jeecg.modules.pms.service.impl; +import cn.hutool.core.collection.CollectionUtil; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; 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.apache.commons.lang3.StringUtils; +import org.jeecg.modules.mes.entity.MesProductionOrder; import org.jeecg.modules.pms.entity.PmsProcessBillMaterials; import org.jeecg.modules.pms.mapper.PmsProcessBillMaterialsMapper; +import org.jeecg.modules.pms.service.IPmsProcessBillMaterialsDetailService; import org.jeecg.modules.pms.service.IPmsProcessBillMaterialsService; +import org.jeecg.modules.sap.dto.OrderBomDTO; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; -import javax.servlet.http.HttpServletRequest; -import java.util.HashMap; +import java.util.List; import java.util.Map; +import java.util.stream.Collectors; /** * @Description: 璁㈠崟BOM * @Author: jeecg-boot - * @Date: 2025-07-01 + * @Date: 2025-07-01 * @Version: V1.0 */ @Service public class PmsProcessBillMaterialsServiceImpl extends ServiceImpl<PmsProcessBillMaterialsMapper, PmsProcessBillMaterials> implements IPmsProcessBillMaterialsService { + @Autowired + private IPmsProcessBillMaterialsDetailService processBillMaterialsDetailService; @Override - public IPage<Map<String, Object>> getpmsProcessBillMaterialsListData(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("batchNumber") && StringUtils.isNotBlank(parameterMap.get("batchNumber")[0])) { - paramMap.put("batchNumber", parameterMap.get("batchNumber")[0].trim()); + @Transactional(rollbackFor = Exception.class) + public boolean saveOrUpdateOrderBom(Map<String, MesProductionOrder> orderMap, List<OrderBomDTO> orderBomDTOList) { + for (Map.Entry<String, MesProductionOrder> entry : orderMap.entrySet()) { + MesProductionOrder order = entry.getValue(); + PmsProcessBillMaterials materials = getByOrderId(order.getId()); + if (materials != null) { + //鏇存柊鐗╂枡鏁版嵁 + materials.setOrderId(order.getId()); + materials.setMaterialNumber(order.getMaterialNumber()); + materials.setMaterialName(order.getMaterialName()); + materials.setProductionUnit(order.getProductionUnit()); + materials.setProductionQuantity(order.getOrderQuantity()); + this.getBaseMapper().updateById(materials); + //鏇存柊鐗╂枡鏄庣粏鏁版嵁 + processBillMaterialsDetailService.removeByMaterialsId(materials.getId()); + //杩囨护鍑烘璁㈠崟鐨勭墿鏂欎俊鎭� + List<OrderBomDTO> collect = orderBomDTOList.stream().filter(orderBomDTO -> entry.getKey().equals(orderBomDTO.getAUFNR())).collect(Collectors.toList()); + processBillMaterialsDetailService.saveBatchDetail(materials.getId(), collect); + } else { + materials = new PmsProcessBillMaterials(); + materials.setOrderId(order.getId()); + materials.setMaterialNumber(order.getMaterialNumber()); + materials.setMaterialName(order.getMaterialName()); + materials.setProductionUnit(order.getProductionUnit()); + materials.setProductionQuantity(order.getOrderQuantity()); + this.getBaseMapper().insert(materials); + //杩囨护鍑烘璁㈠崟鐨勭墿鏂欎俊鎭� + List<OrderBomDTO> collect = orderBomDTOList.stream().filter(orderBomDTO -> entry.getKey().equals(orderBomDTO.getAUFNR())).collect(Collectors.toList()); + processBillMaterialsDetailService.saveBatchDetail(materials.getId(), collect); } } - return super.getBaseMapper().getpmsProcessBillMaterialsListData(pageData, paramMap); + return true; + } + + @Override + public PmsProcessBillMaterials getByOrderId(String orderId) { + LambdaQueryWrapper<PmsProcessBillMaterials> queryWrapper = new LambdaQueryWrapper<>(); + queryWrapper.eq(PmsProcessBillMaterials::getOrderId, orderId); + List<PmsProcessBillMaterials> list = super.list(queryWrapper); + if (CollectionUtil.isNotEmpty(list)) { + return list.get(0); + } + return null; + } + + @Override + public IPage<PmsProcessBillMaterials> queryPageList(Page<PmsProcessBillMaterials> page, PmsProcessBillMaterials query) { + QueryWrapper<PmsProcessBillMaterials> queryWrapper = new QueryWrapper<>(); + queryWrapper.orderByDesc("pbm.create_time"); + if (query != null) { + //鐗╂枡缂栫爜 妯$硦鏌ヨ + if (StringUtils.isNotBlank(query.getMaterialNumber())) { + queryWrapper.like("pbm.material_number", query.getMaterialNumber()); + } + //鐗╂枡鍚嶇О 妯$硦鏌ヨ + if (StringUtils.isNotBlank(query.getMaterialName())) { + queryWrapper.like("pbm.material_name", query.getMaterialName()); + } + //璁㈠崟鍙� 妯$硦鏌ヨ + if (StringUtils.isNotBlank(query.getOrderCode())) { + queryWrapper.like("po.order_code", query.getOrderCode()); + } + } + return this.getBaseMapper().queryPageList(page, queryWrapper); } } -- Gitblit v1.9.3