From 4fadacc0638d051189ffaebb25d0747380d6b02c Mon Sep 17 00:00:00 2001
From: yuan <123@>
Date: 星期四, 23 四月 2026 16:50:18 +0800
Subject: [PATCH] fix(production): 修改生产数量计算逻辑

---
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |   34 ++++++++++++++++++++++++++++++----
 1 files changed, 30 insertions(+), 4 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 b2ab1ce..d22f0f4 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -34,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
@@ -184,10 +184,36 @@
             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.setQuantity(productStructureDto.getUnitQuantity().multiply(dto.getQuantity()));
+            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);

--
Gitblit v1.9.3