From 63328dd80adc6331db581dda6418308e6fd4da12 Mon Sep 17 00:00:00 2001
From: maven <2163098428@qq.com>
Date: 星期二, 13 一月 2026 16:50:21 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_New' into dev_New

---
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |   52 ++++++++++++++--------------------------------------
 1 files changed, 14 insertions(+), 38 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 8e6aad1..3d1c846 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -23,9 +23,11 @@
 import com.ruoyi.quality.mapper.QualityInspectMapper;
 import com.ruoyi.quality.mapper.QualityInspectParamMapper;
 import com.ruoyi.quality.mapper.QualityTestStandardMapper;
+import com.ruoyi.quality.mapper.QualityTestStandardParamMapper;
 import com.ruoyi.quality.pojo.QualityInspect;
 import com.ruoyi.quality.pojo.QualityInspectParam;
 import com.ruoyi.quality.pojo.QualityTestStandard;
+import com.ruoyi.quality.pojo.QualityTestStandardParam;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -63,6 +65,7 @@
     private ProductMapper productMapper;
 
     private QualityTestStandardMapper qualityTestStandardMapper;
+    private QualityTestStandardParamMapper qualityTestStandardParamMapper;
 
     private QualityInspectParamMapper qualityInspectParamMapper;
 
@@ -89,34 +92,7 @@
 
         SysUser user = SecurityUtils.getLoginUser().getUser();
 
-        if (dto.isReportWork()) {
-            // 鏇存柊閫昏緫 - 鍙洿鏂版暟閲�
-            QueryWrapper<ProductionProductOutput> outputWrapper = new QueryWrapper<>();
-            outputWrapper.eq("product_main_id", dto.getProductMainId());
 
-            ProductionProductOutput output = productionProductOutputMapper.selectOne(outputWrapper);
-            if (output == null) {
-                throw new RuntimeException("浜у嚭璁板綍涓嶅瓨鍦�");
-            }
-
-            // 鏌ヨ鐢熶骇鏍哥畻璁板綍
-            QueryWrapper<SalesLedgerProductionAccounting> accountingWrapper = new QueryWrapper<>();
-            accountingWrapper.eq("sales_ledger_work_id", dto.getProductMainId());
-            SalesLedgerProductionAccounting accounting = salesLedgerProductionAccountingMapper.selectOne(accountingWrapper);
-            if (accounting == null) {
-                throw new RuntimeException("鐢熶骇鏍哥畻璁板綍涓嶅瓨鍦�");
-            }
-
-            // 鍙洿鏂版暟閲�
-            if (dto.getQuantity() != null) {
-                output.setQuantity(dto.getQuantity());
-                productionProductOutputMapper.updateById(output);
-                // 鏇存柊鐢熶骇鏍哥畻璁板綍
-                accounting.setFinishedNum(dto.getQuantity());
-                salesLedgerProductionAccountingMapper.updateById(accounting);
-            }
-            return true;
-        }
 
         // 鏂板閫昏緫
         ProductionProductMain productionProductMain = new ProductionProductMain();
@@ -195,16 +171,16 @@
             qualityInspect.setProductMainId(productionProductMain.getId());
             qualityInspectMapper.insert(qualityInspect);
 
-            qualityTestStandardMapper.selectList(
-                    new LambdaQueryWrapper<QualityTestStandard>()
-                            .eq(QualityTestStandard::getProductId, product.getId())
-            ).forEach(standard -> {
-                QualityInspectParam param = new QualityInspectParam();
-                BeanUtils.copyProperties(standard, param);
-                param.setId(null);
-                param.setInspectId(qualityInspect.getId());
-                qualityInspectParamMapper.insert(param);
-            });
+            List<QualityTestStandardParam> qualityTestStandardParams = qualityTestStandardParamMapper.selectListByProductId(product.getId());
+            if (qualityTestStandardParams.size()>0) {
+                qualityTestStandardParams.forEach(standard -> {
+                    QualityInspectParam param = new QualityInspectParam();
+                    BeanUtils.copyProperties(standard, param);
+                    param.setId(null);
+                    param.setInspectId(qualityInspect.getId());
+                    qualityInspectParamMapper.insert(param);
+                });
+            }
         }
         // 娣诲姞鎶曞叆
         if (productModel != null) {
@@ -212,7 +188,7 @@
             for (ProductStructureDto productStructureDto : productStructureDtos) {
                 ProductionProductInput productionProductInput = new ProductionProductInput();
                 productionProductInput.setProductModelId(productStructureDto.getProductModelId());
-                productionProductInput.setQuantity(productStructureDto.getUnitQuantity());
+                productionProductInput.setQuantity(productStructureDto.getUnitQuantity().multiply(dto.getQuantity()));
                 productionProductInput.setProductMainId(productionProductMain.getId());
                 productionProductInputMapper.insert(productionProductInput);
             }

--
Gitblit v1.9.3