From 04dce61c02c10832665cdaf1aabf5b7e9b31da47 Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期三, 21 一月 2026 16:17:19 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_New' into dev_New

---
 src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java |   71 ++++++++++++++++++++++++++---------
 1 files changed, 52 insertions(+), 19 deletions(-)

diff --git a/src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java b/src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java
index 27111db..1ae24e9 100644
--- a/src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java
+++ b/src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java
@@ -3,7 +3,6 @@
 
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
-import com.baomidou.mybatisplus.core.toolkit.StringUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -16,25 +15,19 @@
 import com.ruoyi.framework.security.LoginUser;
 import com.ruoyi.procurementrecord.dto.Details;
 import com.ruoyi.procurementrecord.dto.ProcurementAddDto;
+import com.ruoyi.procurementrecord.pojo.ProcurementRecordStorage;
 import com.ruoyi.procurementrecord.service.ProcurementRecordService;
 import com.ruoyi.quality.dto.QualityInspectDto;
 import com.ruoyi.quality.mapper.QualityInspectMapper;
-import com.ruoyi.quality.mapper.QualityInspectParamMapper;
 import com.ruoyi.quality.mapper.QualityTestStandardMapper;
 import com.ruoyi.quality.mapper.QualityUnqualifiedMapper;
 import com.ruoyi.quality.pojo.QualityInspect;
 import com.ruoyi.quality.pojo.QualityInspectParam;
-import com.ruoyi.quality.pojo.QualityTestStandard;
 import com.ruoyi.quality.pojo.QualityUnqualified;
 import com.ruoyi.quality.service.IQualityInspectParamService;
 import com.ruoyi.quality.service.IQualityInspectService;
 import com.ruoyi.sales.mapper.SalesLedgerProductMapper;
 import com.ruoyi.sales.pojo.SalesLedgerProduct;
-import com.ruoyi.staff.mapper.StaffJoinLeaveRecordMapper;
-import com.ruoyi.staff.mapper.StaffOnJobMapper;
-import com.ruoyi.staff.pojo.StaffJoinLeaveRecord;
-import com.ruoyi.staff.pojo.StaffOnJob;
-import com.ruoyi.staff.service.IStaffOnJobService;
 import lombok.AllArgsConstructor;
 import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
@@ -43,7 +36,9 @@
 import javax.servlet.http.HttpServletResponse;
 import java.io.InputStream;
 import java.io.OutputStream;
+import java.math.BigDecimal;
 import java.net.URLEncoder;
+import java.time.LocalDateTime;
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
@@ -101,6 +96,7 @@
             List<QualityInspectParam> inspectParams = qualityInspectParamService.list(Wrappers.<QualityInspectParam>lambdaQuery().eq(QualityInspectParam::getInspectId, inspect.getId()));
             String text = inspectParams.stream().map(QualityInspectParam::getParameterItem).collect(Collectors.joining(","));
             qualityUnqualified.setDefectivePhenomena(text+"杩欎簺鎸囨爣涓瓨鍦ㄤ笉鍚堟牸");//涓嶅悎鏍肩幇璞�
+            qualityUnqualified.setInspectId(qualityInspect.getId());
             qualityUnqualifiedMapper.insert(qualityUnqualified);
         }
 
@@ -109,7 +105,7 @@
             if ("鍚堟牸".equals(qualityInspect.getCheckResult())) {
                 ProcurementAddDto procurementRecordOutAdd = new ProcurementAddDto();
                 procurementRecordOutAdd.setType(1);
-                procurementRecordOutAdd.setTypeName("閲囪喘鍏ュ簱");
+                procurementRecordOutAdd.setTypeName("閲囪喘鍘熸潗鏂欐楠屽悎鏍煎叆搴�");
                 procurementRecordOutAdd.setNickName(loginUser.getNickName());
                 procurementRecordOutAdd.setPurchaseLedgerId(Math.toIntExact(qualityInspect.getPurchaseLedgerId()));
                 if (qualityInspect.getPurchaseLedgerId() == null) {
@@ -119,33 +115,70 @@
 
                 ArrayList<Details> detailss = new ArrayList<>();
                 Details details = new Details();
-                details.setId(Math.toIntExact(qualityInspect.getProductId()));
+                details.setId(Math.toIntExact(salesLedgerProduct.getId()));
                 details.setInboundQuantity(qualityInspect.getQuantity());
                 details.setWarnNum(salesLedgerProduct.getWarnNum());
                 details.setUnitPrice(salesLedgerProduct.getTaxInclusiveUnitPrice());
                 details.setTotalPrice(salesLedgerProduct.getTaxInclusiveTotalPrice());
+                details.setProductModelId(qualityInspect.getProductModelId());
                 detailss.add( details);
                 procurementRecordOutAdd.setDetails(detailss);
+                procurementRecordOutAdd.setQualityInspectId(qualityInspect.getId());
                 procurementRecordService.add(procurementRecordOutAdd);
             }
         }else if (qualityInspect.getInspectType() == 1) {
-
-        }else if (qualityInspect.getInspectType() == 2) {
             //鏌ヨUnitPrice/TotalPrice
-            SalesLedgerProduct salesLedgerProduct = salesLedgerProductMapper.selectSalesLedgerProductByMainId(qualityInspect.getProductMainId());
             ProcurementAddDto procurementRecordOutAdd = new ProcurementAddDto();
             procurementRecordOutAdd.setType(2);
-            procurementRecordOutAdd.setTypeName("鐢熶骇鍏ュ簱");
+            procurementRecordOutAdd.setTypeName("鐢熶骇杩囩▼妫�楠屽悎鏍煎叆搴�");
             procurementRecordOutAdd.setNickName(loginUser.getNickName());
             List<Details> details = new ArrayList<>();
             Details details1 = new Details();
             details1.setInboundQuantity(qualityInspect.getQuantity());
-            details1.setId(Math.toIntExact(salesLedgerProduct.getId()));
-            details1.setUnitPrice(salesLedgerProduct.getTaxInclusiveUnitPrice());
-            details1.setTotalPrice(salesLedgerProduct.getTaxInclusiveTotalPrice());
-            details.add(details1);
+            details1.setProductModelId(qualityInspect.getProductModelId());
             procurementRecordOutAdd.setDetails(details);
-            procurementRecordService.add(procurementRecordOutAdd);
+
+            ProcurementRecordStorage.ProcurementRecordStorageBuilder procurementRecordBuilder = ProcurementRecordStorage.builder()
+                    .salesLedgerProductId(0)
+                    .inboundBatches( "鐢熶骇鍗婃垚鍝佸叆搴�")
+                    .inboundNum(details1.getInboundQuantity())
+                    .type(2)
+                    .warnNum(new BigDecimal(0))
+                    .unitPrice(new BigDecimal(0))
+                    .totalPrice(new BigDecimal(0))
+                    .createTime(LocalDateTime.now())
+                    .createUser(loginUser.getUserId())
+                    .updateTime(LocalDateTime.now())
+                    .updateUser(loginUser.getUserId())
+                    .createBy(procurementRecordOutAdd.getNickName())
+                    .productModelId(details1.getProductModelId())
+                    .qualityInspectId(qualityInspect.getId());
+            procurementRecordService.save(procurementRecordBuilder.build());
+
+
+
+        }else if (qualityInspect.getInspectType() == 2) {
+            //鏌ヨUnitPrice/TotalPrice
+            if (ObjectUtils.isNull(qualityInspect.getProductMainId())){
+                //濡傛灉鏄墜鍔ㄦ柊澧炵殑鍑哄巶妫�
+            }else {
+                SalesLedgerProduct salesLedgerProduct = salesLedgerProductMapper.selectSalesLedgerProductByMainId(qualityInspect.getProductMainId());
+                ProcurementAddDto procurementRecordOutAdd = new ProcurementAddDto();
+                procurementRecordOutAdd.setType(2);
+                procurementRecordOutAdd.setTypeName("鐢熶骇鍑哄巶妫�楠屽悎鏍煎叆搴�");
+                procurementRecordOutAdd.setNickName(loginUser.getNickName());
+                List<Details> details = new ArrayList<>();
+                Details details1 = new Details();
+                details1.setInboundQuantity(qualityInspect.getQuantity());
+                details1.setId(Math.toIntExact(salesLedgerProduct.getId()));
+                details1.setUnitPrice(salesLedgerProduct.getTaxInclusiveUnitPrice());
+                details1.setTotalPrice(salesLedgerProduct.getTaxInclusiveTotalPrice());
+                details1.setProductModelId(salesLedgerProduct.getProductModelId());
+                details.add(details1);
+                procurementRecordOutAdd.setDetails(details);
+                procurementRecordOutAdd.setQualityInspectId(qualityInspect.getId());
+                procurementRecordService.add(procurementRecordOutAdd);
+            }
         }
         qualityInspect.setInspectState(1);//宸叉彁浜�
         return qualityInspectMapper.updateById(qualityInspect);

--
Gitblit v1.9.3