|  |  |  | 
|---|
|  |  |  | package com.ruoyi.system.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.Query; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
|---|
|  |  |  | import com.ruoyi.common.basic.PageInfo; | 
|---|
|  |  |  | import com.ruoyi.common.utils.SecurityUtils; | 
|---|
|  |  |  | import com.ruoyi.common.utils.StringUtils; | 
|---|
|  |  |  | import com.ruoyi.system.importExcel.TBankFlowImportExcel; | 
|---|
|  |  |  | import com.ruoyi.system.mapper.TBankFlowMapper; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.math.RoundingMode; | 
|---|
|  |  |  | import java.time.LocalDate; | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.time.format.DateTimeParseException; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<TBankFlow> pageList(TBankFlowQuery query) { | 
|---|
|  |  |  | PageInfo<TBankFlow> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); | 
|---|
|  |  |  | List<TBankFlow> list = makeQuery(query); | 
|---|
|  |  |  | pageInfo.setRecords(list); | 
|---|
|  |  |  | pageInfo.setTotal(list.size()); | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<TBankFlow> makeQuery(TBankFlowQuery query) { | 
|---|
|  |  |  | LambdaQueryWrapper<TBankFlow> 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.selectList(queryWrapper); | 
|---|
|  |  |  | .eq(StringUtils.isNotEmpty(query.getBusinessDeptId())&& !"0".equals(query.getBusinessDeptId()),TBankFlow::getBusinessDeptId,query.getBusinessDeptId()) | 
|---|
|  |  |  | .orderByDesc(TBankFlow::getCreateTime); | 
|---|
|  |  |  | return this.baseMapper.selectPage(pageInfo, queryWrapper); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public TBankFlowStatisticsVo getPaymentStats(TBankFlowQuery query) { | 
|---|
|  |  |  | return this.baseMapper.getPaymentStats(query); | 
|---|
|  |  |  | return this.baseMapper.getPaymentStats(query,SecurityUtils.getBusinessDeptId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<TBankFlow> searchByBankSerialNumber(String bankSerialNumber) { | 
|---|
|  |  |  | String businessDeptId = SecurityUtils.getBusinessDeptId(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LambdaQueryWrapper<TBankFlow> queryWrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | queryWrapper.like(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber) | 
|---|
|  |  |  | .eq(StringUtils.isNotEmpty(bankSerialNumber) && !"0".equals(bankSerialNumber),TBankFlow::getBusinessDeptId,businessDeptId) | 
|---|
|  |  |  | .orderByDesc(TBankFlow::getPayTime); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PageInfo<TBankFlow> pageInfo = new PageInfo<>(1, 20); | 
|---|
|  |  |  | pageInfo = this.baseMapper.selectPage(pageInfo, queryWrapper); | 
|---|
|  |  |  | return pageInfo.getRecords(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void saveImportBatch(List<TBankFlowImportExcel> list, List<TBankFlowImportExcel> failList) { | 
|---|
|  |  |  | String businessDeptId = SecurityUtils.getBusinessDeptId(); | 
|---|
|  |  |  | for (TBankFlowImportExcel row : list) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | TBankFlow preexist = findUniq(row.getBankSerialNumber()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TBankFlow flow = new TBankFlow(); | 
|---|
|  |  |  | BeanUtils.copyProperties(row,flow); | 
|---|
|  |  |  | flow.setBusinessDeptId(businessDeptId); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | LocalDateTime parse = LocalDateTime.parse(row.getPayTime(), DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); | 
|---|
|  |  |  | flow.setPayTime(parse); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TFlowManagementQuery query = new TFlowManagementQuery(); | 
|---|
|  |  |  | query.setBankSerialNumber(row.getBankSerialNumber()); | 
|---|
|  |  |  | List<TFlowManagement> list1 = flowManagementService.makeQuery(query); | 
|---|
|  |  |  | List<TFlowManagement> list1 = flowManagementService.findByBankSerialNumber(row.getBankSerialNumber()); | 
|---|
|  |  |  | for (TFlowManagement tFlowManagement : list1) { | 
|---|
|  |  |  | // 如果相同流水号金额相同 :抵扣金额为流水金额,剩余金额为0,状态为正常 | 
|---|
|  |  |  | if (row.getFlowMoney().compareTo(tFlowManagement.getFlowMoney()) == 0){ | 
|---|