From 52d98d59dfa75bd18187e99e1e550701a1b27191 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 23 四月 2026 17:03:21 +0800
Subject: [PATCH] Merge branch 'dev_衡阳_鹏创电子' of http://114.132.189.42:9002/r/product-inventory-management-after into dev_衡阳_鹏创电子

---
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |   66 +++++++++++++++++++++++----------
 1 files changed, 46 insertions(+), 20 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
index 84b382b..d22f0f4 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -18,6 +18,7 @@
 import com.ruoyi.common.exception.ServiceException;
 import com.ruoyi.common.utils.bean.BeanUtils;
 import com.ruoyi.procurementrecord.utils.StockUtils;
+import com.ruoyi.production.dto.ProductStructureDto;
 import com.ruoyi.production.dto.ProductionProductMainDto;
 import com.ruoyi.production.mapper.*;
 import com.ruoyi.production.pojo.*;
@@ -33,12 +34,12 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.time.LocalDate;
 import java.time.LocalDateTime;
 import java.time.format.DateTimeFormatter;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.function.Function;
 import java.util.stream.Collectors;
 
 @Service
@@ -175,23 +176,48 @@
         productionProductMain.setStatus(0);
         productionProductMainMapper.insert(productionProductMain);
         /*鏂板鎶ュ伐鎶曞叆琛�*/
-//        List<ProductStructureDto> productStructureDtos = productStructureMapper.listBybomAndProcess(productProcessRoute.getBomId(), productProcess.getId());
-//        if (productStructureDtos.isEmpty()) {
-//            //濡傛灉璇ュ伐搴忔病鏈変骇鍝佺粨鏋勭殑鎶曞叆鍝�,閭h繖涓姇鍏ュ搧鍜屼骇鍑哄搧鏄悓涓�涓�
-//            ProductStructureDto productStructureDto = new ProductStructureDto();
-//            productStructureDto.setProductModelId(productProcessRouteItem.getProductModelId());
-//            productStructureDto.setUnitQuantity(BigDecimal.ONE);
-//            productStructureDtos.add(productStructureDto);
-//        }
-//        for (ProductStructureDto productStructureDto : productStructureDtos) {
-//            System.out.println(productStructureDto.getProductModelId());
-//            ProductionProductInput productionProductInput = new ProductionProductInput();
-//            productionProductInput.setProductModelId(productStructureDto.getProductModelId());
+        List<ProductStructureDto> productStructureDtos = productStructureMapper.listBybomAndProcess(productProcessRoute.getBomId(), productProcess.getId());
+        if (productStructureDtos.isEmpty()) {
+            //濡傛灉璇ュ伐搴忔病鏈変骇鍝佺粨鏋勭殑鎶曞叆鍝�,閭h繖涓姇鍏ュ搧鍜屼骇鍑哄搧鏄悓涓�涓�
+            ProductStructureDto productStructureDto = new ProductStructureDto();
+            productStructureDto.setProductModelId(productProcessRouteItem.getProductModelId());
+            productStructureDto.setUnitQuantity(BigDecimal.ONE);
+            productStructureDtos.add(productStructureDto);
+        }
+        Set<Long> parentIds = productStructureDtos.stream()
+                .map(ProductStructureDto::getParentId)
+                .filter(Objects::nonNull)
+                .collect(Collectors.toSet());
+        Map<Long, ProductStructureDto> parentMap =
+                productStructureMapper.selectByIds(parentIds)
+                        .stream()
+                        .collect(Collectors.toMap(
+                                ProductStructureDto::getId,
+                                Function.identity()
+                        ));
+        for (ProductStructureDto productStructureDto : productStructureDtos) {
+            ProductionProductInput productionProductInput = new ProductionProductInput();
+            productionProductInput.setProductModelId(productStructureDto.getProductModelId());
 //            productionProductInput.setQuantity(productStructureDto.getUnitQuantity().multiply(dto.getQuantity()));
-//            productionProductInput.setProductMainId(productionProductMain.getId());
-//            productionProductInputMapper.insert(productionProductInput);
-//            stockUtils.substractStock(productStructureDto.getProductModelId(), productionProductInput.getQuantity(), StockOutQualifiedRecordTypeEnum.PRODUCTION_REPORT_STOCK_OUT.getCode(), productionProductMain.getId(),dto.getBatchNo());
-//        }
+            BigDecimal childQty = productStructureDto.getUnitQuantity();
+            BigDecimal parentQty = BigDecimal.ONE;
+            if (productStructureDto.getParentId() != null) {
+                ProductStructureDto parent = parentMap.get(productStructureDto.getParentId());
+                if (parent != null) {
+                    parentQty = parent.getUnitQuantity();
+                }
+            }
+
+            // 鏍稿績璁$畻
+            BigDecimal needQty = childQty.divide(parentQty, 6, RoundingMode.HALF_UP).multiply(dto.getQuantity());
+
+
+            productionProductInput.setQuantity(needQty);
+
+            productionProductInput.setProductMainId(productionProductMain.getId());
+            productionProductInputMapper.insert(productionProductInput);
+            stockUtils.substractStock(productStructureDto.getProductModelId(), productionProductInput.getQuantity(), StockOutQualifiedRecordTypeEnum.PRODUCTION_REPORT_STOCK_OUT.getCode(), productionProductMain.getId(), null);
+        }
         /*鏂板鎶ュ伐浜у嚭琛�*/
         ProductionProductOutput productionProductOutput = new ProductionProductOutput();
         productionProductOutput.setProductMainId(productionProductMain.getId());
@@ -448,4 +474,4 @@
         
         return productionProductMainDtos;
     }
-}
\ No newline at end of file
+}

--
Gitblit v1.9.3