|  |  |  | 
|---|
|  |  |  | package com.ruoyi.system.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | import com.ruoyi.system.service.TBillService; | 
|---|
|  |  |  | import com.ruoyi.system.service.TInvoiceService; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
|---|
|  |  |  | 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> | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Service | 
|---|
|  |  |  | public class TInvoiceServiceImpl extends ServiceImpl<TInvoiceMapper, TInvoice> implements TInvoiceService { | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | TInvoiceToBillServiceImpl tInvoiceToBillService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | TBillService tBillService; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | TencentMailUtil mailUtil; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<TInvoice> pageList(TInvoiceQuery query) { | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(null != query.getStatus(),TInvoice::getStatus,query.getStatus()) | 
|---|
|  |  |  | .ge(StringUtils.isNotEmpty(query.getInvoiceStartTime()),TInvoice::getInvoiceTime,query.getInvoiceStartTime()) | 
|---|
|  |  |  | .le(StringUtils.isNotEmpty(query.getInvoiceEndTime()),TInvoice::getInvoiceTime,query.getInvoiceEndTime()) | 
|---|
|  |  |  | .eq(StringUtils.isNotEmpty(query.getBusinessDeptId())&& ! "0".equals(query.getBusinessDeptId()),TInvoice::getBusinessDeptId,query.getBusinessDeptId()) | 
|---|
|  |  |  | .orderByDesc(TInvoice::getCreateTime); | 
|---|
|  |  |  | return this.baseMapper.selectList(queryWrapper); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Boolean uploadVoucher(TInvoiceQuery query, List<Map<String, String>> map) { | 
|---|
|  |  |  | // 检查是否存在对应的发票记录 | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | // 异步发送邮件 | 
|---|
|  |  |  | CompletableFuture.runAsync(() -> { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | mailUtil.sendInvoice(preexist.getEmail(), map); | 
|---|
|  |  |  | } catch (ServiceException e) { | 
|---|
|  |  |  | log.error("邮件发送失败", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 更新数据库 | 
|---|
|  |  |  | return updateById(tInvoice); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|