From 5706757a0bcec3318c8c460d34c1827788065d7c Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期三, 12 三月 2025 13:53:47 +0800 Subject: [PATCH] Merge branch 'xizang-changyun' of https://gitee.com/xiaochen991015/xizang --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TInvoiceServiceImpl.java | 99 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 98 insertions(+), 1 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TInvoiceServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TInvoiceServiceImpl.java index 36dbad6..c0be87b 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TInvoiceServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TInvoiceServiceImpl.java @@ -3,7 +3,9 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.common.basic.PageInfo; +import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.utils.StringUtils; +import com.ruoyi.common.utils.TencentMailUtil; import com.ruoyi.system.mapper.TInvoiceMapper; import com.ruoyi.system.model.TInvoice; import com.ruoyi.system.query.TInvoiceQuery; @@ -12,7 +14,10 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; -import java.util.List; +import javax.annotation.Resource; +import java.util.*; +import java.util.concurrent.CompletableFuture; +import java.util.stream.Collectors; /** * <p> @@ -28,6 +33,8 @@ TInvoiceToBillServiceImpl tInvoiceToBillService; @Autowired TBillService tBillService; + @Resource + TencentMailUtil mailUtil; @Override public PageInfo<TInvoice> pageList(TInvoiceQuery query) { @@ -49,4 +56,94 @@ .orderByDesc(TInvoice::getCreateTime); return this.baseMapper.selectList(queryWrapper); } + + @Override + public Boolean uploadVoucher(TInvoiceQuery query) { + // 检查是否存在对应的发票记录 + TInvoice preexist = getById(query.getId()); + if (preexist == null) { + log.error("未找到对应的发票记录,ID: {}"+query.getId()); + return false; + } + + // 更新发票信息 + TInvoice tInvoice = new TInvoice(); + tInvoice.setId(query.getId()); + tInvoice.setInvoiceVoucher(query.getInvoiceVoucher()); + tInvoice.setInvoiceVoucherName(query.getInvoiceVoucherName()); + tInvoice.setInvoiceTime(query.getInvoiceTime()); + tInvoice.setStatus(2); + + // 处理附件信息 + List<Map<String, String>> attachments = buildAttachments(query.getInvoiceVoucher(), query.getInvoiceVoucherName()); + if (attachments.isEmpty()) { + log.warn("未找到有效的附件信息"); + return updateById(tInvoice); + } + + // 异步发送邮件 + CompletableFuture.runAsync(() -> { + try { + mailUtil.sendInvoice(preexist.getEmail(), attachments); + } catch (ServiceException e) { + log.error("邮件发送失败", e); + } + }); + + // 更新数据库 + return updateById(tInvoice); + } + + private List<Map<String, String>> buildAttachments(String invoiceVoucher, String invoiceVoucherName) { + if (invoiceVoucher == null || invoiceVoucherName == null) { + return Collections.emptyList(); + } + + String[] voucherUrls = invoiceVoucher.split(","); + String[] voucherNames = invoiceVoucherName.split(","); + + // 确保两个数组长度一致 + int length = Math.min(voucherUrls.length, voucherNames.length); + if (length == 0) { + return Collections.emptyList(); + } + + // 构建附件列表 + List<Map<String, String>> attachments = new ArrayList<>(length); + for (int i = 0; i < length; i++) { + Map<String, String> attachment = new HashMap<>(2); // 初始容量为2,避免扩容 + attachment.put("url", voucherUrls[i]); + attachment.put("fileName", voucherNames[i]); + attachments.add(attachment); + } + + return attachments; + } + + // @Override + // public Boolean uploadVoucher(TInvoiceQuery query) { + // TInvoice preexist = getById(query.getId()); + // if (preexist == null){ + // return false; + // } + // TInvoice tInvoice = new TInvoice(); + // tInvoice.setId(query.getId()); + // tInvoice.setInvoiceVoucher(query.getInvoiceVoucher()); + // tInvoice.setInvoiceVoucherName(query.getInvoiceVoucherName()); + // tInvoice.setInvoiceTime(query.getInvoiceTime()); + // tInvoice.setStatus(2); + // List<Map<String, String>> mapArrayList = new ArrayList<>(); + // String invoiceVoucher = query.getInvoiceVoucher(); + // String invoiceVoucherName = query.getInvoiceVoucherName(); + // + // List<String> list = Arrays.stream(invoiceVoucher.split(",")).collect(Collectors.toList()); + // for (int i = 0; i < list.size()-1; i++) { + // Map<String, String> map = new HashMap<>(); + // map.put("url", list.get(i)); + // map.put("fileName",invoiceVoucherName.split(",")[i]); + // mapArrayList.add(map); + // } + // mailUtil.sendInvoice(preexist.getEmail(),mapArrayList); + // return updateById(tInvoice); + // } } -- Gitblit v1.7.1