From 80166fd68f21bce3a243e499e4a757c013397f89 Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期五, 16 一月 2026 10:58:10 +0800
Subject: [PATCH] 添加新增采购的时候是否推送质检

---
 src/main/resources/mapper/production/ProductWorkOrderMapper.xml                       |    4 -
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |    2 -
 src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java          |   55 +++++++++++++++------------
 src/main/java/com/ruoyi/sales/pojo/SalesLedgerProduct.java                            |    3 +
 4 files changed, 35 insertions(+), 29 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 9722fb3..c4d2ba5 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -148,8 +148,6 @@
         //鏇存柊宸ュ崟
         if (insert > 0) {
             Map<String, Object> params = new HashMap<>();
-            params.put("quantity", dto.getQuantity());
-            params.put("productMainId", productionProductMain.getId());
             params.put("workOrderId", dto.getWorkOrderId());
             params.put("deductQuantity", dto.getQuantity());
 
diff --git a/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java b/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java
index db90551..7fa971c 100644
--- a/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java
+++ b/src/main/java/com/ruoyi/purchase/service/impl/PurchaseLedgerServiceImpl.java
@@ -232,31 +232,11 @@
         }
         //鏂板鍘熸潗鏂欐楠�
         for (SalesLedgerProduct saleProduct : productList) {
-            QualityInspect qualityInspect = new QualityInspect();
-            qualityInspect.setInspectType(0);
-            qualityInspect.setSupplier(purchaseLedger.getSupplierName());
-            qualityInspect.setPurchaseLedgerId(purchaseLedger.getId());
-            qualityInspect.setProductId(saleProduct.getId());
-            qualityInspect.setProductName(saleProduct.getProductCategory());
-            qualityInspect.setModel(saleProduct.getSpecificationModel());
-            qualityInspect.setProductModelId(saleProduct.getProductModelId());
-            qualityInspect.setUnit(saleProduct.getUnit());
-            qualityInspect.setQuantity(saleProduct.getQuantity());
-            qualityInspectMapper.insert(qualityInspect);
-            QualityTestStandard qualityTestStandard = new QualityTestStandard();
-            qualityTestStandard.setProductId(saleProduct.getProductId());
-            List<QualityTestStandard> qualityTestStandards = qualityTestStandardMapper.qualityTestStandardList(qualityTestStandard);
-            for (QualityTestStandard qualityTestStandardDB : qualityTestStandards) {
-                QualityInspectParam qualityInspectParam = new QualityInspectParam();
-                qualityInspectParam.setInspectId(qualityInspect.getId());
-                qualityInspectParam.setParameterItem(qualityTestStandardDB.getParameterItem());
-                qualityInspectParam.setUnit(qualityTestStandardDB.getUnit());
-                qualityInspectParam.setStandardValue(qualityTestStandardDB.getStandardValue());
-                qualityInspectParam.setControlValue(qualityTestStandardDB.getControlValue());
-                qualityInspectParamMapper.insert(qualityInspectParam);
+            //鏄惁鎺ㄩ�佽川妫�锛屽鏋渢rue灏辨坊鍔�
+            if (saleProduct.getIsChecked()) {
+                addQualityInspect(purchaseLedger, saleProduct);
             }
         }
-
         // 5. 杩佺Щ涓存椂鏂囦欢鍒版寮忕洰褰�
         if (purchaseLedgerDto.getTempFileIds() != null && !purchaseLedgerDto.getTempFileIds().isEmpty()) {
             migrateTempFilesToFormal(purchaseLedger.getId(), purchaseLedgerDto.getTempFileIds());
@@ -264,6 +244,33 @@
 
         return 1;
     }
+
+    private void addQualityInspect(PurchaseLedger purchaseLedger, SalesLedgerProduct saleProduct) {
+        QualityInspect qualityInspect = new QualityInspect();
+        qualityInspect.setInspectType(0);
+        qualityInspect.setSupplier(purchaseLedger.getSupplierName());
+        qualityInspect.setPurchaseLedgerId(purchaseLedger.getId());
+        qualityInspect.setProductId(saleProduct.getId());
+        qualityInspect.setProductName(saleProduct.getProductCategory());
+        qualityInspect.setModel(saleProduct.getSpecificationModel());
+        qualityInspect.setProductModelId(saleProduct.getProductModelId());
+        qualityInspect.setUnit(saleProduct.getUnit());
+        qualityInspect.setQuantity(saleProduct.getQuantity());
+        qualityInspectMapper.insert(qualityInspect);
+        QualityTestStandard qualityTestStandard = new QualityTestStandard();
+        qualityTestStandard.setProductId(saleProduct.getProductId());
+        List<QualityTestStandard> qualityTestStandards = qualityTestStandardMapper.qualityTestStandardList(qualityTestStandard);
+        for (QualityTestStandard qualityTestStandardDB : qualityTestStandards) {
+            QualityInspectParam qualityInspectParam = new QualityInspectParam();
+            qualityInspectParam.setInspectId(qualityInspect.getId());
+            qualityInspectParam.setParameterItem(qualityTestStandardDB.getParameterItem());
+            qualityInspectParam.setUnit(qualityTestStandardDB.getUnit());
+            qualityInspectParam.setStandardValue(qualityTestStandardDB.getStandardValue());
+            qualityInspectParam.setControlValue(qualityTestStandardDB.getControlValue());
+            qualityInspectParamMapper.insert(qualityInspectParam);
+        }
+    }
+
 
     private void handleSalesLedgerProducts(Long salesLedgerId, List<SalesLedgerProduct> products, Integer type) {
         if (products == null || products.isEmpty()) {
@@ -452,7 +459,7 @@
         materialInspectLambdaQueryWrapper.in(QualityInspect::getPurchaseLedgerId, ids);
         List<QualityInspect> qualityInspects = qualityInspectMapper.selectList(materialInspectLambdaQueryWrapper);
         qualityInspects.stream().forEach(qualityInspect -> {
-            if (qualityInspect.getInspectState().equals(1)) {
+            if (ObjectUtils.isNotEmpty(qualityInspect.getInspectState())&&qualityInspect.getInspectState().equals(1)) {
                 throw new BaseException("宸叉彁浜ょ殑妫�楠屽崟涓嶈兘鍒犻櫎");
             }
         });
diff --git a/src/main/java/com/ruoyi/sales/pojo/SalesLedgerProduct.java b/src/main/java/com/ruoyi/sales/pojo/SalesLedgerProduct.java
index 7af592b..03a034d 100644
--- a/src/main/java/com/ruoyi/sales/pojo/SalesLedgerProduct.java
+++ b/src/main/java/com/ruoyi/sales/pojo/SalesLedgerProduct.java
@@ -209,4 +209,7 @@
 //    @TableField(exist = false)
     @ApiModelProperty(value = "瀹℃壒鐘舵�侊細0鏈敓浜�,1宸茬敓浜�,2寰呭鏍�(瀹℃牳涓�),3瀹℃牳瀹屾垚,4瀹℃牳澶辫触")
     private Integer approveStatus;
+    
+    @ApiModelProperty(value = "鏄惁璐ㄦ")
+    private Boolean isChecked;
 }
diff --git a/src/main/resources/mapper/production/ProductWorkOrderMapper.xml b/src/main/resources/mapper/production/ProductWorkOrderMapper.xml
index ac0348a..0489bbc 100644
--- a/src/main/resources/mapper/production/ProductWorkOrderMapper.xml
+++ b/src/main/resources/mapper/production/ProductWorkOrderMapper.xml
@@ -49,9 +49,7 @@
         UPDATE product_work_order
         SET
             report_work = #{reportWork},
-            quantity = #{quantity},
-            plan_quantity = plan_quantity - #{deductQuantity},
-            product_main_id = #{productMainId}
+            plan_quantity = plan_quantity - #{deductQuantity}
         WHERE id = #{workOrderId}
     </update>
 

--
Gitblit v1.9.3