From d7ca504a668322be5137d3dc8e72072c4efbd9c9 Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期三, 22 四月 2026 15:33:31 +0800
Subject: [PATCH] refactor(sales): 重构销售分类账服务以集成生产质量相关模块

---
 src/main/java/com/ruoyi/sales/service/impl/InvoiceLedgerServiceImpl.java |   35 ++++++++++++++++-------------------
 1 files changed, 16 insertions(+), 19 deletions(-)

diff --git a/src/main/java/com/ruoyi/sales/service/impl/InvoiceLedgerServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/InvoiceLedgerServiceImpl.java
index 614fc20..d18a51a 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/InvoiceLedgerServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/InvoiceLedgerServiceImpl.java
@@ -14,48 +14,37 @@
 import com.ruoyi.sales.mapper.*;
 import com.ruoyi.sales.pojo.*;
 import com.ruoyi.sales.service.InvoiceLedgerService;
+import jakarta.servlet.http.HttpServletResponse;
+import lombok.RequiredArgsConstructor;
 import org.apache.commons.collections4.CollectionUtils;
 import org.springframework.beans.BeanUtils;
-import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.ObjectUtils;
 import org.springframework.web.multipart.MultipartFile;
 
-import javax.servlet.http.HttpServletResponse;
 import java.io.File;
 import java.math.BigDecimal;
 import java.time.LocalDate;
 import java.time.YearMonth;
-import java.util.Comparator;
 import java.util.List;
 import java.util.Objects;
 import java.util.UUID;
 import java.util.stream.Collectors;
 
 @Service
+@RequiredArgsConstructor
 public class InvoiceLedgerServiceImpl extends ServiceImpl<InvoiceLedgerMapper, InvoiceLedger> implements InvoiceLedgerService {
 
     @Value("${ruoyi.profile}")
     private String uploadFile;
 
-    @Autowired
-    private InvoiceLedgerMapper invoiceLedgerMapper;
-
-    @Autowired
-    private InvoiceLedgerFileMapper invoiceLedgerFileMapper;
-
-    @Autowired
-    private InvoiceRegistrationProductMapper invoiceRegistrationProductMapper;
-
-    @Autowired
-    private ReceiptPaymentMapper receiptPaymentMapper;
-
-    @Autowired
-    private SalesLedgerProductMapper salesLedgerProductMapper;
-    @Autowired
-    private CommonFileMapper commonFileMapper;
+    private final InvoiceLedgerMapper invoiceLedgerMapper;
+    private final InvoiceLedgerFileMapper invoiceLedgerFileMapper;
+    private final InvoiceRegistrationProductMapper invoiceRegistrationProductMapper;
+    private final ReceiptPaymentMapper receiptPaymentMapper;
+    private final SalesLedgerProductMapper salesLedgerProductMapper;
 
     /**
      * 寮�绁ㄥ彴璐︽柊澧�
@@ -326,6 +315,14 @@
         if(ObjectUtils.isEmpty(invoiceRegistrationProductDto)){
             throw new RuntimeException("浜у搧寮�绁ㄥ彴璐︽煡鎵惧け璐�");
         }
+        List<InvoiceRegistrationProduct> invoiceRegistrationProducts = invoiceRegistrationProductMapper.selectList(new LambdaQueryWrapper<InvoiceRegistrationProduct>()
+                .eq(InvoiceRegistrationProduct::getSalesLedgerProductId, invoiceRegistrationProductDto.getSalesLedgerProductId()));
+        if(CollectionUtils.isNotEmpty(invoiceRegistrationProducts)){
+            invoiceRegistrationProductDto.setNoInvoiceNum(invoiceRegistrationProductDto.getQuantity()
+                    .subtract(invoiceRegistrationProducts.stream().map(InvoiceRegistrationProduct::getInvoiceNum).reduce(BigDecimal.ZERO, BigDecimal::add)));
+            invoiceRegistrationProductDto.setNoInvoiceAmount(invoiceRegistrationProductDto.getTaxInclusiveTotalPrice()
+                    .subtract(invoiceRegistrationProducts.stream().map(InvoiceRegistrationProduct::getInvoiceAmount).reduce(BigDecimal.ZERO, BigDecimal::add)));
+        }
         // 鏌ヨ闄勪欢
         QueryWrapper<InvoiceLedgerFile> queryWrapper = new QueryWrapper<>();
         queryWrapper.eq("invoice_ledger_id", invoiceRegistrationProductDto.getInvoiceLedgerId());

--
Gitblit v1.9.3