From acfe8943be0bb1440e0e6ba27ad9e694859e835e Mon Sep 17 00:00:00 2001
From: wujianwei <wjw@11.com>
Date: 星期一, 12 一月 2026 14:45:20 +0800
Subject: [PATCH] 修改发票新增

---
 service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java |   40 +++++++++++++++++++++++++++++++---------
 1 files changed, 31 insertions(+), 9 deletions(-)

diff --git a/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java b/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
index c294182..af606db 100644
--- a/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
+++ b/service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
@@ -1,8 +1,6 @@
 package com.ruoyi.cwgl.service.impl;
 
-import java.math.BigDecimal;
 import java.util.*;
-import java.util.stream.Collectors;
 
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.http.HttpUtil;
@@ -33,6 +31,7 @@
 import com.ruoyi.common.core.service.BaseService;
 
 import com.ruoyi.cwgl.mapper.InvoiceManageMapper;
+import com.ruoyi.cwgl.mapper.InvoiceBillDetailMapper;
 import com.ruoyi.cwgl.service.IInvoiceManageService;
 import com.ruoyi.cwgl.service.IInvoiceManageLogService;
 import com.ruoyi.common.core.text.Convert;
@@ -51,6 +50,9 @@
     private InvoiceManageMapper invoiceManageMapper;
 
     @Resource
+    private InvoiceBillDetailMapper invoiceBillDetailMapper;
+
+    @Resource
     private IInvoiceManageLogService invoiceManageLogService;
 
     @Autowired
@@ -67,7 +69,8 @@
     private String invoicingAddress;
     @Value("${custom.gdpaasApi.returnAddress}")
     private String returnAddress;
-
+    @Autowired
+    private IInvoiceBusinessService invoiceBusinessService;
     /**
      * 鏌ヨ鍙戠エ绠$悊
      *
@@ -263,6 +266,20 @@
                 invoiceManageMapper.batchInvoiceDetail(list);
             }
         }
+        
+        // 鏂板鍙戠エ涓氬姟鍟嗗搧鏄庣粏淇℃伅
+        List<InvoiceBillDetail> invoiceBillDetails = invoiceManage.getInvoiceBillDetails();
+        if (StringUtils.isNotNull(invoiceBillDetails)) {
+            List<InvoiceBillDetail> billDetailList = new ArrayList<InvoiceBillDetail>();
+            for (InvoiceBillDetail invoiceBillDetail : invoiceBillDetails) {
+                invoiceBillDetail.setInvoiceManageId(id);
+                invoiceBillDetail.setCreateTime(new Date());
+                billDetailList.add(invoiceBillDetail);
+            }
+            if (billDetailList.size() > 0) {
+                invoiceBillDetailMapper.insertInvoiceBillDetailBatch(billDetailList);
+            }
+        }
     }
 
     /**
@@ -310,7 +327,7 @@
     }
 
     @Override
-    public AjaxResult applyInvoice(Integer id, List<InvoiceBillDetail> invoiceBillDetails) {
+    public AjaxResult applyInvoice(Integer id) {
         InvoiceManage invoiceManage = selectInvoiceManageById(id);
         if (invoiceManage == null) {
             throw new ServiceException("鍙戠エ璁板綍涓嶅瓨鍦�");
@@ -319,9 +336,9 @@
             throw new ServiceException("璇峰嬁閲嶅寮�绁�");
 
         }
-        List<InvoiceDetail> invoiceDetailList = invoiceManage.getInvoiceDetailList();
-        if (CollectionUtil.isEmpty(invoiceDetailList)) {
-            throw new ServiceException("鏀惰垂鏄庣粏鏃犳暟鎹�");
+        List<InvoiceBillDetail> invoiceBillDetails = invoiceManage.getInvoiceBillDetails();
+        if (CollectionUtil.isEmpty(invoiceBillDetails)) {
+            throw new ServiceException("鍟嗗搧鏄庣粏鏃犳暟鎹棤娉曞紑鍙戠エ");
 
         }
 
@@ -361,7 +378,7 @@
         for (InvoiceBillDetail billingDetail : invoiceBillDetails) {
             InvoiceDetailApi invoiceDetail = new InvoiceDetailApi();
 
-
+            invoiceDetail.setGoodsCode(invoiceDetail.getGoodsCode());
             invoiceDetail.setGoodsName(invoiceDetail.getGoodsName());
 
             invoiceDetail.setWithTaxFlag(billingDetail.getWithTaxFlag().toString());
@@ -384,7 +401,7 @@
         }
         JSONObject jsonObject = JSONObject.parseObject(json);
         String code = jsonObject.getString("code");
-
+        logger.info("寮�绁ㄨ繑鍥瀧}",jsonObject);
         String invoiceSerialNum = null;
         InvoiceBusiness record = new InvoiceBusiness();
         record.setReqData(JSONObject.toJSONString(invoicingVo));
@@ -398,8 +415,11 @@
             logger.info("寮�绁ㄦ垚鍔熷彂绁ㄥ簭鍒楀彿涓簕}", invoiceSerialNum);
             record.setInvoiceSerialNum(invoiceSerialNum);
             record.setInvoiceManageId(invoiceManage.getId());
+            invoiceBusinessService.insertInvoiceBusiness(record);
             return AjaxResult.success();
         }
+
+
         return AjaxResult.error("寮�绁ㄥけ璐�");
     }
 
@@ -474,3 +494,5 @@
     }
 }
 
+
+

--
Gitblit v1.8.0