From 1fd5eac12e532a9906e0c1d57676c692c68d1f32 Mon Sep 17 00:00:00 2001
From: chenrui <1187576398@qq.com>
Date: 星期二, 20 五月 2025 17:46:08 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/main/java/com/ruoyi/sales/service/impl/InvoiceRegistrationServiceImpl.java |   55 ++++++++++++++++++++++++++++++-------------------------
 1 files changed, 30 insertions(+), 25 deletions(-)

diff --git a/src/main/java/com/ruoyi/sales/service/impl/InvoiceRegistrationServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/InvoiceRegistrationServiceImpl.java
index 3130872..7f8bd60 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/InvoiceRegistrationServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/InvoiceRegistrationServiceImpl.java
@@ -5,15 +5,17 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import com.ruoyi.basic.excel.SupplierManageExcelDto;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.sales.dto.InvoiceRegistrationDto;
 import com.ruoyi.sales.dto.InvoiceRegistrationProductDto;
+import com.ruoyi.sales.dto.SalesLedgerDto;
 import com.ruoyi.sales.excel.InvoiceRegisAndProductExcelDto;
 import com.ruoyi.sales.mapper.InvoiceRegistrationMapper;
 import com.ruoyi.sales.mapper.InvoiceRegistrationProductMapper;
+import com.ruoyi.sales.mapper.SalesLedgerProductMapper;
 import com.ruoyi.sales.pojo.InvoiceRegistration;
 import com.ruoyi.sales.pojo.InvoiceRegistrationProduct;
+import com.ruoyi.sales.pojo.SalesLedgerProduct;
 import com.ruoyi.sales.service.InvoiceRegistrationService;
 import org.apache.commons.collections4.CollectionUtils;
 import org.springframework.beans.BeanUtils;
@@ -35,38 +37,41 @@
     @Autowired
     private InvoiceRegistrationProductMapper invoiceRegistrationProductMapper;
 
+    @Autowired
+    private SalesLedgerProductMapper salesLedgerProductMapper;
 
     /**
-     * 寮�绁ㄧ櫥璁版柊澧�
-     * @param invoiceRegistrationDto
+     * 寮�绁ㄧ櫥璁拌褰曟柊澧�
+     * @param salesLedgerDto
      * @return
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public void invoiceRegistrationSaveOrUpdate(InvoiceRegistrationDto invoiceRegistrationDto) {
+    public void invoiceRegistrationSave(SalesLedgerDto salesLedgerDto) {
         InvoiceRegistration invoiceRegistration = new InvoiceRegistration();
-        BeanUtils.copyProperties(invoiceRegistrationDto, invoiceRegistration);
-        List<InvoiceRegistrationProductDto> productDtoList = invoiceRegistrationDto.getProductDtoList();
-        // 鏂板寮�绁ㄧ櫥璁�
-        if(invoiceRegistrationDto.getId() == null){
-            invoiceRegistrationMapper.insert(invoiceRegistration);
-            // 鏂板寮�绁ㄤ骇鍝佺櫥璁�
-            if(CollectionUtils.isNotEmpty(productDtoList)){
-                for (InvoiceRegistrationProductDto invoiceRegistrationProductDto : productDtoList) {
-                    InvoiceRegistrationProduct invoiceRegistrationProduct = new InvoiceRegistrationProduct();
-                    BeanUtils.copyProperties(invoiceRegistrationProductDto, invoiceRegistrationProduct);
-                    invoiceRegistrationProduct.setInvoiceRegistrationId(invoiceRegistration.getId());
-                    invoiceRegistrationProductMapper.insert(invoiceRegistrationProduct);
+        BeanUtils.copyProperties(salesLedgerDto, invoiceRegistration);
+        invoiceRegistration.setId(null);
+        invoiceRegistration.setCustomerId(salesLedgerDto.getCustomerId().intValue());
+        invoiceRegistration.setSalesLedgerId(salesLedgerDto.getId().intValue());
+        invoiceRegistrationMapper.insert(invoiceRegistration);
+        List<SalesLedgerProduct> productData = salesLedgerDto.getProductData();
+        if(CollectionUtils.isNotEmpty(productData)){
+            for (SalesLedgerProduct productDatum : productData) {
+                // 濡傛灉寮�绁ㄦ暟涓�0 璺宠繃
+                Integer currentInvoiceNum = productDatum.getCurrentInvoiceNum();
+                if(null == currentInvoiceNum || currentInvoiceNum == 0){
+                    continue;
                 }
-            }
-        // 寮�绁ㄧ櫥璁颁慨鏀�
-        }else {
-            if(CollectionUtils.isNotEmpty(productDtoList)){
-                for (InvoiceRegistrationProductDto invoiceRegistrationProductDto : productDtoList) {
-                    InvoiceRegistrationProduct invoiceRegistrationProduct = new InvoiceRegistrationProduct();
-                    BeanUtils.copyProperties(invoiceRegistrationProductDto, invoiceRegistrationProduct);
-                    invoiceRegistrationProductMapper.updateById(invoiceRegistrationProduct);
-                }
+                InvoiceRegistrationProduct invoiceRegistrationProduct = new InvoiceRegistrationProduct();
+                BeanUtils.copyProperties(productDatum, invoiceRegistrationProduct);
+                invoiceRegistrationProduct.setId(null);
+                invoiceRegistrationProduct.setSalesLedgerId(salesLedgerDto.getId().intValue());
+                invoiceRegistrationProduct.setInvoiceRegistrationId(invoiceRegistration.getId());
+                invoiceRegistrationProduct.setInvoiceAmount(productDatum.getCurrentInvoiceAmount());
+                invoiceRegistrationProduct.setInvoiceNum(productDatum.getCurrentInvoiceNum());
+                invoiceRegistrationProduct.setSalesLedgerProductId(productDatum.getId().intValue());
+                invoiceRegistrationProductMapper.insert(invoiceRegistrationProduct);
+                salesLedgerProductMapper.updateById(productDatum);
             }
         }
     }

--
Gitblit v1.9.3