From 4635770544e2d57416ad88a8983ee293919f5fec Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期一, 25 五月 2026 09:25:36 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_New_pro' into dev_New_pro

---
 src/main/java/com/ruoyi/approve/service/impl/ApproveNodeServiceImpl.java |  151 +++-----------------------------------------------
 1 files changed, 9 insertions(+), 142 deletions(-)

diff --git a/src/main/java/com/ruoyi/approve/service/impl/ApproveNodeServiceImpl.java b/src/main/java/com/ruoyi/approve/service/impl/ApproveNodeServiceImpl.java
index 7cbf63e..964be23 100644
--- a/src/main/java/com/ruoyi/approve/service/impl/ApproveNodeServiceImpl.java
+++ b/src/main/java/com/ruoyi/approve/service/impl/ApproveNodeServiceImpl.java
@@ -1,9 +1,7 @@
 package com.ruoyi.approve.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
-import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
-import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.approve.mapper.ApproveNodeMapper;
@@ -11,34 +9,16 @@
 import com.ruoyi.approve.pojo.ApproveNode;
 import com.ruoyi.approve.pojo.ApproveProcess;
 import com.ruoyi.approve.service.IApproveNodeService;
+import com.ruoyi.basic.enums.ApplicationTypeEnum;
+import com.ruoyi.basic.enums.RecordTypeEnum;
+import com.ruoyi.basic.utils.FileUtil;
 import com.ruoyi.common.enums.FileNameType;
-import com.ruoyi.common.enums.StockInQualifiedRecordTypeEnum;
 import com.ruoyi.common.utils.SecurityUtils;
-import com.ruoyi.device.mapper.DeviceRepairMapper;
-import com.ruoyi.device.pojo.DeviceRepair;
-import com.ruoyi.other.service.impl.TempFileServiceImpl;
-import com.ruoyi.procurementrecord.utils.StockUtils;
 import com.ruoyi.project.system.domain.SysUser;
 import com.ruoyi.project.system.mapper.SysUserMapper;
 import com.ruoyi.project.system.service.ISysNoticeService;
-import com.ruoyi.purchase.mapper.PurchaseLedgerMapper;
-import com.ruoyi.purchase.pojo.PurchaseLedger;
-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 com.ruoyi.sales.mapper.CommonFileMapper;
-import com.ruoyi.sales.mapper.SalesLedgerProductMapper;
-import com.ruoyi.sales.mapper.SalesQuotationMapper;
-import com.ruoyi.sales.mapper.ShippingInfoMapper;
 import com.ruoyi.sales.pojo.CommonFile;
-import com.ruoyi.sales.pojo.SalesLedgerProduct;
-import com.ruoyi.sales.pojo.SalesQuotation;
-import com.ruoyi.sales.pojo.ShippingInfo;
 import com.ruoyi.sales.service.impl.CommonFileServiceImpl;
 import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
@@ -58,20 +38,11 @@
     private final ApproveNodeMapper approveNodeMapper;
     private final ApproveProcessMapper approveProcessMapper;
     private final SysUserMapper sysUserMapper;
-    private final TempFileServiceImpl tempFileService;
     private final ISysNoticeService sysNoticeService;
     private final CommonFileMapper fileMapper;
-    private final DeviceRepairMapper deviceRepairMapper;
-    private final PurchaseLedgerMapper purchaseLedgerMapper;
-    private final SalesQuotationMapper salesQuotationMapper;
-    private final ShippingInfoMapper shippingInfoMapper;
     private final CommonFileServiceImpl commonFileService;
-    private final StockUtils stockUtils;
-    private final SalesLedgerProductMapper salesLedgerProductMapper;
-    private final QualityInspectMapper qualityInspectMapper;
-    private final QualityTestStandardMapper qualityTestStandardMapper;
-    private final QualityTestStandardParamMapper qualityTestStandardParamMapper;
-    private final QualityInspectParamMapper qualityInspectParamMapper;
+    private final ApproveBusinessStatusService approveBusinessStatusService;
+    private final FileUtil fileUtil;
 
 
     public ApproveProcess getApproveById(String id) {
@@ -166,86 +137,8 @@
         }
         approveProcessMapper.updateById(approveProcess);
 
-        DeviceRepair deviceRepair = deviceRepairMapper.selectById(approveProcess.getDeviceRepairId());
-        if (ObjectUtils.isNotNull(deviceRepair)) {
-            if (approveProcess.getApproveStatus().equals(2)) {
-                // 鍚屾剰
-                deviceRepair.setStatus(1);
-            } else if (approveProcess.getApproveStatus().equals(3)) {
-                // 鎷掔粷
-                deviceRepair.setStatus(2);
-            }
-            deviceRepairMapper.updateById(deviceRepair);
-        }
-
-        //閲囪喘瀹℃牳
-        if (approveProcess.getApproveType().equals(5)) {
-            PurchaseLedger purchaseLedger = purchaseLedgerMapper.selectOne(new LambdaQueryWrapper<PurchaseLedger>()
-                    .eq(PurchaseLedger::getPurchaseContractNumber, approveProcess.getApproveReason())
-                    .last("limit 1"));
-            if (purchaseLedger != null) {
-                if (status.equals(2)) {
-                    // 鍚屾剰
-                    purchaseLedger.setApprovalStatus(3);
-                    List<SalesLedgerProduct> salesLedgerProducts = salesLedgerProductMapper.selectList(new QueryWrapper<SalesLedgerProduct>()
-                            .lambda().eq(SalesLedgerProduct::getSalesLedgerId, purchaseLedger.getId()).eq(SalesLedgerProduct::getType, 2));
-                    for (SalesLedgerProduct salesLedgerProduct : salesLedgerProducts) {
-                        // 璐ㄦ
-                        if (salesLedgerProduct.getIsChecked()) {
-                            addQualityInspect(purchaseLedger, salesLedgerProduct);
-                        } else {
-                            //鐩存帴鍏ュ簱
-                            stockUtils.addStock(salesLedgerProduct.getProductModelId(), salesLedgerProduct.getQuantity(), StockInQualifiedRecordTypeEnum.PURCHASE_STOCK_IN.getCode(), purchaseLedger.getId());
-                        }
-                    }
-                } else if (status.equals(3)) {
-                    // 鎷掔粷
-                    purchaseLedger.setApprovalStatus(4);
-                } else if (status.equals(1)) {
-                    // 瀹℃牳涓�
-                    purchaseLedger.setApprovalStatus(2);
-                }
-                purchaseLedgerMapper.updateById(purchaseLedger);
-            }
-        }
-        // 閿�鍞姤浠风姸鎬佷慨鏀�
-        if (approveProcess.getApproveType().equals(6)) {
-            SalesQuotation salesQuote = salesQuotationMapper.selectOne(new LambdaQueryWrapper<SalesQuotation>()
-                    .eq(SalesQuotation::getQuotationNo, approveProcess.getApproveReason())
-                    .last("limit 1"));
-            // 鍚屾剰
-            if (status.equals(2) && salesQuote != null) {
-                salesQuote.setStatus("閫氳繃");
-            } else if (status.equals(3) && salesQuote != null) {
-                salesQuote.setStatus("鎷掔粷");
-            } else if (status.equals(1) && salesQuote != null) {
-                salesQuote.setStatus("瀹℃牳涓�");
-            }
-            salesQuotationMapper.updateById(salesQuote);
-        }
-        // 鍑哄簱瀹℃壒淇敼
-        if (approveProcess.getApproveType().equals(7)) {
-            String[] split = approveProcess.getApproveReason().split(":");
-            ShippingInfo shippingInfo = shippingInfoMapper.selectOne(new LambdaQueryWrapper<ShippingInfo>()
-                    .eq(ShippingInfo::getShippingNo, split[1])
-                    .orderByDesc(ShippingInfo::getCreateTime)
-                    .last("limit 1"));
-            if (shippingInfo != null) {
-                if (status.equals(2)) {
-                    shippingInfo.setStatus("瀹℃牳閫氳繃");
-                } else if (status.equals(3)) {
-                    shippingInfo.setStatus("瀹℃牳鎷掔粷");
-                } else if (status.equals(1)) {
-                    shippingInfo.setStatus("瀹℃牳涓�");
-                }
-                shippingInfoMapper.updateById(shippingInfo);
-            }
-
-        }
-        // 缁戝畾闄勪欢
-        if (!CollectionUtils.isEmpty(approveNode.getTempFileIds()) && approveNode.getApproveNodeStatus() == 1) {
-            tempFileService.migrateTempFilesToFormal(approveNode.getId(), approveNode.getTempFileIds(), FileNameType.ApproveNode.getValue());
-        }
+        approveBusinessStatusService.syncBusinessStatus(approveProcess.getApproveType(), approveProcess.getApproveReason(), status);
+        fileUtil.saveStorageAttachment(ApplicationTypeEnum.FILE, RecordTypeEnum.APPROVE_NODE, approveNode.getId(), approveNode.getStorageBlobDTOS());
     }
 
     @Override
@@ -316,36 +209,10 @@
                 return "鍙戣揣瀹℃壒";
             case 8:
                 return "鍗遍櫓浣滀笟瀹℃壒";
+            case 9:
+                return "鍔炲叕鐢ㄥ搧瀹℃壒";
         }
         return null;
-    }
-
-    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.getProductId());
-        qualityInspect.setProductName(saleProduct.getProductCategory());
-        qualityInspect.setModel(saleProduct.getSpecificationModel());
-        qualityInspect.setProductModelId(saleProduct.getProductModelId());
-        qualityInspect.setUnit(saleProduct.getUnit());
-        qualityInspect.setQuantity(saleProduct.getQuantity());
-        qualityInspectMapper.insert(qualityInspect);
-        List<QualityTestStandard> qualityTestStandard = qualityTestStandardMapper.getQualityTestStandardByProductId(saleProduct.getProductId(), 0,null);
-        if (qualityTestStandard.size()>0){
-            qualityInspect.setTestStandardId(qualityTestStandard.get(0).getId());
-            qualityInspectMapper.updateById(qualityInspect);
-            qualityTestStandardParamMapper.selectList(Wrappers.<QualityTestStandardParam>lambdaQuery()
-                            .eq(QualityTestStandardParam::getTestStandardId,qualityTestStandard.get(0).getId()))
-                    .forEach(qualityTestStandardParam -> {
-                        QualityInspectParam param = new QualityInspectParam();
-                        com.ruoyi.common.utils.bean.BeanUtils.copyProperties(qualityTestStandardParam, param);
-                        param.setId(null);
-                        param.setInspectId(qualityInspect.getId());
-                        qualityInspectParamMapper.insert(param);
-                    });
-        }
     }
 
 }

--
Gitblit v1.9.3