From b686699a24f80abc6745f5f66fee96218f817c7f Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期六, 10 一月 2026 16:41:51 +0800
Subject: [PATCH] feat(quality): 完善质检流程并修复产品ID映射错误

---
 src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java |  113 ++++++++++++++++++++++++++++++++++----------------------
 1 files changed, 69 insertions(+), 44 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 b2633a8..27111db 100644
--- a/src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java
+++ b/src/main/java/com/ruoyi/quality/service/impl/QualityInspectServiceImpl.java
@@ -11,7 +11,12 @@
 import com.deepoove.poi.config.Configure;
 import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.utils.HackLoopTableRenderPolicy;
+import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.poi.ExcelUtil;
+import com.ruoyi.framework.security.LoginUser;
+import com.ruoyi.procurementrecord.dto.Details;
+import com.ruoyi.procurementrecord.dto.ProcurementAddDto;
+import com.ruoyi.procurementrecord.service.ProcurementRecordService;
 import com.ruoyi.quality.dto.QualityInspectDto;
 import com.ruoyi.quality.mapper.QualityInspectMapper;
 import com.ruoyi.quality.mapper.QualityInspectParamMapper;
@@ -23,6 +28,8 @@
 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;
@@ -37,6 +44,7 @@
 import java.io.InputStream;
 import java.io.OutputStream;
 import java.net.URLEncoder;
+import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
 import java.util.stream.Collectors;
@@ -54,6 +62,10 @@
 
     private QualityUnqualifiedMapper qualityUnqualifiedMapper;
 
+    private SalesLedgerProductMapper salesLedgerProductMapper;
+
+    private ProcurementRecordService procurementRecordService;
+
     @Override
     public int add(QualityInspectDto qualityInspectDto) {
         QualityInspect qualityInspect = new QualityInspect();
@@ -64,22 +76,6 @@
             qualityInspectParam.setInspectId(qualityInspect.getId());
         }
         qualityInspectParamService.saveBatch(qualityInspectDto.getQualityInspectParams());
-//        String[] ignoreProperties = {"id"};//鎺掗櫎id灞炴��
-//        //鏍规嵁浜у搧id鏌ヨ鎸囨爣缁存姢瀵瑰簲鏂板妫�楠屽弬鏁�
-//        List<QualityTestStandard> qualityTestStandards = qualityTestStandardMapper.selectList(Wrappers.<QualityTestStandard>lambdaQuery()
-//                .eq(QualityTestStandard::getProductId, qualityInspect.getProductId()));
-//        if (qualityTestStandards.size()>0){
-//
-//            List<QualityInspectParam> qualityInspectParams = qualityTestStandards.stream().map(qualityTestStandard -> {
-//                QualityInspectParam qualityInspectParam = new QualityInspectParam();
-//                BeanUtils.copyProperties(qualityTestStandard, qualityInspectParam,ignoreProperties);
-//                qualityInspectParam.setInspectId(qualityInspect.getId());
-//                return qualityInspectParam;
-//            }).collect(Collectors.toList());
-//            qualityInspectParamService.saveBatch(qualityInspectParams);
-//        }else{
-//            throw new BaseException("璇ヤ骇鍝佹病鏈夌淮鎶ゆ楠屾寚鏍�,璇锋鏌�!!!!!!!!");
-//        }
         return 0;
     }
 
@@ -95,17 +91,61 @@
 
     //鎻愪氦
     @Override
-    public int submit(Integer id) {
-        QualityInspect qualityInspect = qualityInspectMapper.selectById(id);
+    public int submit(QualityInspect inspect) {
+        QualityInspect qualityInspect = qualityInspectMapper.selectById(inspect.getId());
         /*鍒ゆ柇涓嶅悎鏍�*/
         if (ObjectUtils.isNotNull(qualityInspect.getCheckResult()) && qualityInspect.getCheckResult().equals("涓嶅悎鏍�")){
             QualityUnqualified qualityUnqualified = new QualityUnqualified();
             BeanUtils.copyProperties(qualityInspect,qualityUnqualified);
             qualityUnqualified.setInspectState(0);//寰呭鐞�
-            List<QualityInspectParam> inspectParams = qualityInspectParamService.list(Wrappers.<QualityInspectParam>lambdaQuery().eq(QualityInspectParam::getInspectId, id));
+            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+"杩欎簺鎸囨爣涓瓨鍦ㄤ笉鍚堟牸");//涓嶅悎鏍肩幇璞�
             qualityUnqualifiedMapper.insert(qualityUnqualified);
+        }
+
+        LoginUser loginUser = SecurityUtils.getLoginUser();
+        if (qualityInspect.getInspectType() == 0) {
+            if ("鍚堟牸".equals(qualityInspect.getCheckResult())) {
+                ProcurementAddDto procurementRecordOutAdd = new ProcurementAddDto();
+                procurementRecordOutAdd.setType(1);
+                procurementRecordOutAdd.setTypeName("閲囪喘鍏ュ簱");
+                procurementRecordOutAdd.setNickName(loginUser.getNickName());
+                procurementRecordOutAdd.setPurchaseLedgerId(Math.toIntExact(qualityInspect.getPurchaseLedgerId()));
+                if (qualityInspect.getPurchaseLedgerId() == null) {
+                    throw new BaseException("璇烽�夋嫨閲囪喘鍗�");
+                }
+                SalesLedgerProduct salesLedgerProduct = salesLedgerProductMapper.selectById(qualityInspect.getProductId());
+
+                ArrayList<Details> detailss = new ArrayList<>();
+                Details details = new Details();
+                details.setId(Math.toIntExact(qualityInspect.getProductId()));
+                details.setInboundQuantity(qualityInspect.getQuantity());
+                details.setWarnNum(salesLedgerProduct.getWarnNum());
+                details.setUnitPrice(salesLedgerProduct.getTaxInclusiveUnitPrice());
+                details.setTotalPrice(salesLedgerProduct.getTaxInclusiveTotalPrice());
+                detailss.add( details);
+                procurementRecordOutAdd.setDetails(detailss);
+                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.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);
+            procurementRecordOutAdd.setDetails(details);
+            procurementRecordService.add(procurementRecordOutAdd);
         }
         qualityInspect.setInspectState(1);//宸叉彁浜�
         return qualityInspectMapper.updateById(qualityInspect);
@@ -113,8 +153,8 @@
 
     /*鐢熸垚妫�楠屾姤鍛�*/
     @Override
-    public void down(HttpServletResponse response, Integer id) {
-        QualityInspect inspect = qualityInspectMapper.selectById(id);
+    public void down(HttpServletResponse response, QualityInspect qualityInspect) {
+        QualityInspect inspect = qualityInspectMapper.selectById(qualityInspect.getId());
         String inspectType="";
         switch (inspect.getInspectType()){
             case 0:
@@ -127,7 +167,7 @@
                 inspectType="鍑哄巶妫�楠�";
                 break;
         }
-        List<QualityInspectParam> paramList = qualityInspectParamService.list(Wrappers.<QualityInspectParam>lambdaQuery().eq(QualityInspectParam::getInspectId, id));
+        List<QualityInspectParam> paramList = qualityInspectParamService.list(Wrappers.<QualityInspectParam>lambdaQuery().eq(QualityInspectParam::getInspectId, inspect.getId()));
         int index = 1;
         for (QualityInspectParam detail : paramList) {
             detail.setIndex(index);
@@ -149,6 +189,7 @@
             response.setContentType("application/msword");
             String fileName = URLEncoder.encode(
                     "妫�楠屾姤鍛�", "UTF-8");
+            response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
             response.setHeader("Content-disposition",
                     "attachment;filename=" + fileName + ".docx");
             OutputStream os = response.getOutputStream();
@@ -164,32 +205,16 @@
 
     @Override
     public int updateQualityInspect(QualityInspectDto qualityInspectDto) {
-        if (qualityInspectDto.getQualityInspectParams().size()>0) {
-            qualityInspectParamService.updateBatchById(qualityInspectDto.getQualityInspectParams());
+        if (ObjectUtils.isNotNull(qualityInspectDto.getQualityInspectParams())) {
+            qualityInspectParamService.remove(Wrappers.<QualityInspectParam>lambdaQuery().eq(QualityInspectParam::getInspectId,qualityInspectDto.getId()));
+            for (QualityInspectParam qualityInspectParam : qualityInspectDto.getQualityInspectParams()) {
+                qualityInspectParam.setInspectId(qualityInspectDto.getId());
+            }
+            qualityInspectParamService.saveBatch(qualityInspectDto.getQualityInspectParams());
         }
         QualityInspect qualityInspect = new QualityInspect();
         BeanUtils.copyProperties(qualityInspectDto,qualityInspect);
         return qualityInspectMapper.updateById(qualityInspect);
-
-//        String[] ignoreProperties = {"id"};//鎺掗櫎id灞炴��
-//        //鍏堝垹闄ゆ墍鏈夋楠屽弬鏁板啀鏂板
-//        qualityInspectParamService.remove(Wrappers.<QualityInspectParam>lambdaQuery()
-//                .eq(QualityInspectParam::getInspectId,qualityInspect.getId()));
-//        //鏍规嵁浜у搧id鏌ヨ鎸囨爣缁存姢瀵瑰簲鏂板妫�楠屽弬鏁�
-//        List<QualityTestStandard> qualityTestStandards = qualityTestStandardMapper.selectList(Wrappers.<QualityTestStandard>lambdaQuery()
-//                .eq(QualityTestStandard::getProductId, qualityInspect.getProductId()));
-//        if (qualityTestStandards.size()>0){
-//            List<QualityInspectParam> qualityInspectParams = qualityTestStandards.stream().map(qualityTestStandard -> {
-//                QualityInspectParam qualityInspectParam = new QualityInspectParam();
-//                BeanUtils.copyProperties(qualityTestStandard, qualityInspectParam,ignoreProperties);
-//                qualityInspectParam.setInspectId(qualityInspect.getId());
-//                return qualityInspectParam;
-//            }).collect(Collectors.toList());
-//            qualityInspectParamService.saveBatch(qualityInspectParams);
-//        }else{
-//            throw new BaseException("璇ヤ骇鍝佹病鏈夌淮鎶ゆ楠屾寚鏍�,璇锋鏌�!!!!!!!!");
-//        }
-//        return  qualityInspectMapper.updateById(qualityInspect);
     }
 
     @Override

--
Gitblit v1.9.3