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.utils.StringUtils; import com.ruoyi.system.importExcel.TBankFlowImportExcel; import com.ruoyi.system.mapper.TBankFlowMapper; import com.ruoyi.system.model.TBankFlow; import com.ruoyi.system.model.TBill; import com.ruoyi.system.model.TFlowManagement; import com.ruoyi.system.query.TBankFlowQuery; import com.ruoyi.system.query.TFlowManagementQuery; import com.ruoyi.system.service.TBankFlowService; import com.ruoyi.system.service.TFlowManagementService; import com.ruoyi.system.vo.TBankFlowStatisticsVo; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.math.BigDecimal; import java.math.RoundingMode; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.time.format.DateTimeParseException; import java.util.List; /** *

* 流水管理 服务实现类 *

* * @author xiaochen * @since 2025-02-07 */ @Service public class TBankFlowServiceImpl extends ServiceImpl implements TBankFlowService { @Autowired TFlowManagementService flowManagementService; @Override public PageInfo pageList(TBankFlowQuery query) { PageInfo pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper.eq(StringUtils.isNotEmpty(query.getBankSerialNumber()),TBankFlow::getBankSerialNumber,query.getBankSerialNumber()) .like(StringUtils.isNotEmpty(query.getPayer()),TBankFlow::getPayer,query.getPayer()) .ge(StringUtils.isNotEmpty(query.getPayStartTime()),TBankFlow::getPayTime,query.getPayStartTime()) .lt(StringUtils.isNotEmpty(query.getPayEndTime()),TBankFlow::getPayTime,query.getPayEndTime()) .eq(null != query.getFlowStatus(),TBankFlow::getFlowStatus,query.getFlowStatus()) .orderByDesc(TBankFlow::getCreateTime); return this.baseMapper.selectPage(pageInfo, queryWrapper); } @Override public TBankFlowStatisticsVo getPaymentStats(TBankFlowQuery query) { return this.baseMapper.getPaymentStats(query); } /** * 根据银行流水号模糊查询 * @param bankSerialNumber * @return */ @Override public List searchByBankSerialNumber(String bankSerialNumber) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper.like(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber) .orderByDesc(TBankFlow::getPayTime); PageInfo pageInfo = new PageInfo<>(1, 20); pageInfo = this.baseMapper.selectPage(pageInfo, queryWrapper); return pageInfo.getRecords(); } @Override public void saveImportBatch(List list, List failList) { for (TBankFlowImportExcel row : list) { try { TBankFlow preexist = findUniq(row.getBankSerialNumber()); if (preexist != null){ row.setResult("流水号已存在"+row.getBankSerialNumber()); failList.add(row); continue; } TBankFlow flow = new TBankFlow(); BeanUtils.copyProperties(row,flow); try { LocalDateTime parse = LocalDateTime.parse(row.getPayTime(), DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); flow.setPayTime(parse); }catch (DateTimeParseException e){ row.setResult("支付时间格式不正确"+row.getPayTime()); failList.add(row); continue; } TFlowManagementQuery query = new TFlowManagementQuery(); query.setBankSerialNumber(row.getBankSerialNumber()); List list1 = flowManagementService.findByBankSerialNumber(row.getBankSerialNumber()); for (TFlowManagement tFlowManagement : list1) { // 如果相同流水号金额相同 :抵扣金额为流水金额,剩余金额为0,状态为正常 if (row.getFlowMoney().compareTo(tFlowManagement.getFlowMoney()) == 0){ flow.setDeductionMoney(tFlowManagement.getFlowMoney()); flow.setRemainingMoney(BigDecimal.ZERO); flow.setFlowStatus(1); this.baseMapper.insert(flow); break; }else { // 流水号相同,金额不同:已抵扣金额为系统流水金额,剩余金额 = 银行流水金额-系统流水金额,状态为异常 flow.setDeductionMoney(tFlowManagement.getFlowMoney()); flow.setRemainingMoney(row.getFlowMoney().divide(tFlowManagement.getFlowMoney(),2, RoundingMode.HALF_DOWN)); flow.setFlowStatus(2); this.baseMapper.insert(flow); break; } } // 系统流水查找不到:抵扣金额为0,剩余金额为流水金额,状态为异常 flow.setDeductionMoney(BigDecimal.ZERO); flow.setRemainingMoney(row.getFlowMoney()); flow.setFlowStatus(2); this.baseMapper.insert(flow); }catch (Exception e){ log.error("导入银行流水信息异常",e); row.setResult("导入异常:"+e.getMessage()); failList.add(row); } } } /** * 根据流水号查找唯一流水 * @param bankSerialNumber * @return */ @Override public TBankFlow findUniq(String bankSerialNumber) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper.eq(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber); return this.baseMapper.selectOne(queryWrapper); } }