wujianwei
2026-01-06 67ed08fdbc54408e2e6f29bc72b2f548a8d91290
service/src/main/java/com/ruoyi/cwgl/service/impl/InvoiceManageServiceImpl.java
@@ -1,11 +1,14 @@
package com.ruoyi.cwgl.service.impl;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.utils.DateUtils;
import javax.annotation.Resource;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.cwgl.domain.InvoiceDetail;
import org.springframework.transaction.annotation.Transactional;
@@ -21,7 +24,9 @@
import com.ruoyi.cwgl.mapper.InvoiceManageMapper;
import com.ruoyi.cwgl.domain.InvoiceManage;
import com.ruoyi.cwgl.domain.InvoiceManageLog;
import com.ruoyi.cwgl.service.IInvoiceManageService;
import com.ruoyi.cwgl.service.IInvoiceManageLogService;
import com.ruoyi.common.core.text.Convert;
/**
@@ -37,6 +42,9 @@
    protected final Logger logger = LoggerFactory.getLogger(getClass());
    @Resource
    private InvoiceManageMapper invoiceManageMapper;
    @Resource
    private IInvoiceManageLogService invoiceManageLogService;
    /**
@@ -103,13 +111,18 @@
     * @param invoiceManage 发票管理
     * @return 结果
     */
    @Transactional
    @Override
    public int insertInvoiceManage(InvoiceManage invoiceManage)
    {
        invoiceManage.setCreateTime(DateUtils.getNowDate());
        int rows = invoiceManageMapper.insertInvoiceManage(invoiceManage);
        insertInvoiceDetail(invoiceManage);
        // 记录新增发票管理日志
        if (rows > 0) {
            recordInvoiceManageLog(invoiceManage, "新增发票管理");
        }
        return rows;
    }
@@ -123,6 +136,14 @@
    public int insertInvoiceManageBatch(List<InvoiceManage> invoiceManages)
    {
        int rows = invoiceManageMapper.insertInvoiceManageBatch(invoiceManages);
        // 记录批量新增发票管理日志
        if (rows > 0 && invoiceManages != null && !invoiceManages.isEmpty()) {
            for (InvoiceManage invoiceManage : invoiceManages) {
                recordInvoiceManageLog(invoiceManage, "批量新增发票管理");
            }
        }
        return rows;
    }
@@ -139,7 +160,14 @@
        invoiceManage.setUpdateTime(DateUtils.getNowDate());
        invoiceManageMapper.deleteInvoiceDetailByInvoiceManageId(invoiceManage.getId());
        insertInvoiceDetail(invoiceManage);
        return invoiceManageMapper.updateInvoiceManage(invoiceManage);
        int rows = invoiceManageMapper.updateInvoiceManage(invoiceManage);
        // 记录修改发票管理日志
        if (rows > 0) {
            recordInvoiceManageLog(invoiceManage, "修改发票管理");
        }
        return rows;
    }
    /**
@@ -150,7 +178,16 @@
     */
    @Override
    public int updateInvoiceManageBatch(List<InvoiceManage> invoiceManages){
        return invoiceManageMapper.updateInvoiceManageBatch(invoiceManages);
        int rows = invoiceManageMapper.updateInvoiceManageBatch(invoiceManages);
        // 记录批量修改发票管理日志
        if (rows > 0 && invoiceManages != null && !invoiceManages.isEmpty()) {
            for (InvoiceManage invoiceManage : invoiceManages) {
                recordInvoiceManageLog(invoiceManage, "批量修改发票管理");
            }
        }
        return rows;
    }
    /**
@@ -210,6 +247,7 @@
            for (InvoiceDetail invoiceDetail : invoiceDetailList)
            {
                invoiceDetail.setInvoiceManageId(id);
                invoiceDetail.setCreateTime(new Date());
                list.add(invoiceDetail);
            }
            if (list.size() > 0)
@@ -218,4 +256,99 @@
            }
        }
    }
    /**
     * 记录发票管理操作日志
     *
     * @param invoiceManage 发票管理对象
     * @param operationType 操作类型
     */
    private void recordInvoiceManageLog(InvoiceManage invoiceManage, String operationType)
    {
        try {
            InvoiceManageLog log = new InvoiceManageLog();
            log.setInvoiceManageId(invoiceManage.getId());
            log.setOperator(SecurityUtils.getUsername());
            log.setOperationTime(DateUtils.getNowDate());
            // 构建操作描述,包含开票金额、关联账单编号和对应开票金额
            StringBuilder descBuilder = new StringBuilder();
            descBuilder.append(operationType).append(": ");
            if (invoiceManage.getInvoiceAmount() != null) {
                descBuilder.append("开票金额=").append(invoiceManage.getInvoiceAmount()).append("; ");
            }
            // 获取关联账单信息
            if (invoiceManage.getInvoiceDetailList() != null && !invoiceManage.getInvoiceDetailList().isEmpty()) {
                descBuilder.append("关联账单信息: ");
                for (InvoiceDetail detail : invoiceManage.getInvoiceDetailList()) {
                    if (detail.getReceivableBillNo() != null) {
                        descBuilder.append("账单编号=").append(detail.getReceivableBillNo());
                    }
                    if (detail.getCurrentBilledAmount() != null) {
                        descBuilder.append(", 本次开票金额=").append(detail.getCurrentBilledAmount());
                    }
                    descBuilder.append("; ");
                }
            }
            log.setOperationDesc(descBuilder.toString());
            log.setCreateTime(DateUtils.getNowDate());
            invoiceManageLogService.insertInvoiceManageLog(log);
        } catch (Exception e) {
            logger.error("记录发票管理操作日志失败: {}", e.getMessage());
        }
    }
    @Override
    public AjaxResult applyInvoice(Integer id) {
        return AjaxResult.success("申请开票成功");
    }
    /**
     * 记录申请开票日志
     *
     * @param invoiceManage 发票管理对象
     */
    private void recordApplyInvoiceLog(InvoiceManage invoiceManage)
    {
        try {
            InvoiceManageLog log = new InvoiceManageLog();
            log.setInvoiceManageId(invoiceManage.getId());
            log.setOperator(SecurityUtils.getUsername());
            log.setOperationTime(new java.util.Date());
            // 构建操作描述,包含开票金额、关联账单编号和对应开票金额
            StringBuilder descBuilder = new StringBuilder();
            descBuilder.append("申请开票: ");
            if (invoiceManage.getInvoiceAmount() != null) {
                descBuilder.append("开票金额=").append(invoiceManage.getInvoiceAmount()).append("; ");
            }
            // 获取关联账单信息
            if (invoiceManage.getInvoiceDetailList() != null && !invoiceManage.getInvoiceDetailList().isEmpty()) {
                descBuilder.append("关联账单信息: ");
                for (com.ruoyi.cwgl.domain.InvoiceDetail detail : invoiceManage.getInvoiceDetailList()) {
                    if (detail.getReceivableBillNo() != null) {
                        descBuilder.append("账单编号=").append(detail.getReceivableBillNo());
                    }
                    if (detail.getCurrentBilledAmount() != null) {
                        descBuilder.append(", 本次开票金额=").append(detail.getCurrentBilledAmount());
                    }
                    descBuilder.append("; ");
                }
            }
            log.setOperationDesc(descBuilder.toString());
            log.setCreateTime(new java.util.Date());
            invoiceManageLogService.insertInvoiceManageLog(log);
        } catch (Exception e) {
            logger.error("记录申请开票日志失败: {}", e.getMessage());
        }
    }
}