12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055 |
- package com.winhc.repal.service.impl;
- import cn.hutool.core.collection.CollUtil;
- import cn.hutool.core.util.NumberUtil;
- import cn.hutool.core.util.ObjectUtil;
- import cn.hutool.core.util.StrUtil;
- import com.alibaba.fastjson.JSON;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.toolkit.Wrappers;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.winhc.common.base.ApiDataResult;
- import com.winhc.common.enums.CodeMsg;
- import com.winhc.common.exception.CommonException;
- import com.winhc.common.model.base.VOPage;
- import com.winhc.repal.cloud.DataMiddlewareService;
- import com.winhc.repal.cloud.InCaseService;
- import com.winhc.repal.cloud.dto.GetCompanyRiskNumDTO;
- import com.winhc.repal.cloud.dto.GetCreditPunishmentLabelDTO;
- import com.winhc.repal.cloud.dto.GetFinanceDynamicNumDTO;
- import com.winhc.repal.cloud.dto.QueryV8DynamicDTO;
- import com.winhc.repal.cloud.vo.*;
- import com.winhc.repal.entity.*;
- import com.winhc.repal.enums.*;
- import com.winhc.repal.model.bo.*;
- import com.winhc.repal.model.dto.*;
- import com.winhc.repal.model.vo.*;
- import com.winhc.repal.repository.RepalBillMapper;
- import com.winhc.repal.repository.RepalChangeRecordMapper;
- import com.winhc.repal.repository.RepalResponsiblePersonMapper;
- import com.winhc.repal.service.*;
- import com.winhc.repal.util.DiagnosisUtil;
- import com.winhc.repal.util.RepalBillStatusUtil;
- import com.winhc.repal.util.UserContextUtil;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.beans.BeanUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import java.math.BigDecimal;
- import java.math.RoundingMode;
- import java.time.DayOfWeek;
- import java.time.LocalDate;
- import java.time.LocalDateTime;
- import java.time.LocalTime;
- import java.time.format.DateTimeFormatter;
- import java.time.temporal.TemporalAdjusters;
- import java.util.*;
- import java.util.function.Function;
- import java.util.stream.Collectors;
- /**
- * @description RepalBill 接口实现类
- * @author Generator
- * @date 2022-04-08
- */
- @Service
- public class RepalBillServiceImpl extends ServiceImpl<RepalBillMapper, RepalBill> implements RepalBillService {
- public static final Logger LOGGER = LoggerFactory.getLogger(RepalBillServiceImpl.class);
- @Autowired
- private RepalBillMapper repalBillMapper;
- @Autowired
- private RepalResponsiblePersonService repalResponsiblePersonService;
- @Autowired
- private RepalGroupMemberService repalGroupMemberService;
- @Autowired
- private RepalCustomerService repalCustomerService;
- @Autowired
- private DataMiddlewareService dataMiddlewareService;
- @Autowired
- private InCaseService inCaseService;
- @Autowired
- private RepalBillDiagnosisService repalBillDiagnosisService;
- @Autowired
- private RepalChangeRecordService repalChangeRecordService;
- @Autowired
- private RepalBookService repalBookService;
- @Autowired
- private RepalRolePermissionService repalRolePermissionService;
- @Autowired
- private RepalRemindHistoryService repalRemindHistoryService;
- @Autowired
- private RepalRemindReadInfoService repalRemindReadInfoService;
- @Autowired
- private RepalBillOperLogService repalBillOperLogService;
- @Autowired
- private UserExtService userExtService;
- @Autowired
- private RepalResponsiblePersonMapper repalResponsiblePersonMapper;
- @Autowired
- private RepalDynamicService repalDynamicService;
- @Autowired
- private RepalVipService repalVipService;
- @Autowired
- private RepalCustChargeRelService repalCustChargeRelService;
- @Autowired
- private CompanyService companyService;
- @Override
- public RepalBillInfoVO getRepalBillPage(GetRepalBillPageDTO dto) {
- long userId = UserContextUtil.getUser().getUserId();
- Long groupId = repalGroupMemberService.getUserGroupId(userId);
- VOPage<RepalBillPageVO> voPage = new VOPage<>();
- voPage.setPageSize(dto.getPageSize());
- voPage.setPageNum(dto.getPageNum());
- RepalBillInfoVO infoVO = new RepalBillInfoVO();
- boolean allFlag = repalRolePermissionService.checkUserPermission(userId,
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(dto.getRepalBillType()) ? PermissionEnum.QUERY_ALL_RECEIVABLE.getCode() : PermissionEnum.QUERY_ALL_RECEIPT.getCode());
- // 分页数据
- Page<RepalBill> repalBillPage = new Page<>(dto.getPageNum(),dto.getPageSize());
- BillPageBO billPageBO = new BillPageBO();
- BeanUtils.copyProperties(dto, billPageBO);
- billPageBO.setUserId(userId);
- billPageBO.setAllFlag(allFlag);
- billPageBO.setRepalGroupId(groupId);
- // 对应1-4到期时间
- if (Objects.nonNull(dto.getOverdueType())) {
- switch (dto.getOverdueType()) {
- case 1:
- billPageBO.setStartDate(LocalDate.now());
- billPageBO.setEndDate(billPageBO.getStartDate());
- break;
- case 2:
- billPageBO.setStartDate(LocalDate.now().with(DayOfWeek.MONDAY));
- billPageBO.setEndDate(LocalDate.now().with(DayOfWeek.SUNDAY));
- break;
- case 3:
- billPageBO.setStartDate(LocalDate.now().with(TemporalAdjusters.firstDayOfMonth()));
- billPageBO.setEndDate(LocalDate.now().with(TemporalAdjusters.lastDayOfMonth()));
- break;
- case 4:
- billPageBO.setStartDate(LocalDate.now().with(TemporalAdjusters.firstDayOfYear()));
- billPageBO.setEndDate(LocalDate.now().with(TemporalAdjusters.lastDayOfYear()));
- break;
- default:
- break;
- }
- }
- LOGGER.info("allFlag:[{}]", allFlag);
- TotalMoneyBO totalMoneyBO;
- TotalMoneyBO overdueBO;
- TotalMoneyBO totalBO;
- BillPageBO totalQueryBO = new BillPageBO();
- BillPageBO totalOverdueQueryBO = new BillPageBO();
- BillPageBO totalSumBO = new BillPageBO();
- BeanUtils.copyProperties(billPageBO, totalQueryBO);
- BeanUtils.copyProperties(billPageBO, totalOverdueQueryBO);
- BeanUtils.copyProperties(billPageBO, totalSumBO);
- totalQueryBO.setOverdueStatus(RepalBillStatusEnum.PROGRESSING.getCode());
- totalOverdueQueryBO.setOverdueStatus(RepalBillStatusEnum.OVERDUE.getCode());
- totalSumBO.setOverdueStatus(null);
- if (allFlag) {
- totalQueryBO.setUserId(null);
- totalOverdueQueryBO.setUserId(null);
- totalSumBO.setUserId(null);
- totalMoneyBO = repalBillMapper.getTotalMoneyByGroup(totalQueryBO);
- overdueBO = repalBillMapper.getTotalMoneyByGroup(totalOverdueQueryBO);
- totalBO = repalBillMapper.getTotalMoneyByGroup(totalSumBO);
- } else {
- // 只查询自己负责的
- totalMoneyBO = repalBillMapper.getTotalMoneyByGroup(totalQueryBO);
- overdueBO = repalBillMapper.getTotalMoneyByGroup(totalOverdueQueryBO);
- totalBO = repalBillMapper.getTotalMoneyByGroup(totalSumBO);
- }
- infoVO.setTotalBillMoneyStr(totalMoneyBO.getTotalMoney().stripTrailingZeros().toPlainString());
- infoVO.setTotalBillCount(totalMoneyBO.getTotalCount());
- infoVO.setTotalOverdueCount(overdueBO.getTotalCount());
- infoVO.setTotalOverdueStr(overdueBO.getTotalMoney().stripTrailingZeros().toPlainString());
- infoVO.setTotalCount(totalBO.getTotalCount());
- infoVO.setTotalStr(totalBO.getTotalMoney().stripTrailingZeros().toPlainString());
- repalBillPage = repalBillMapper.getRepalBillPage(repalBillPage, billPageBO);
- voPage.setTotalPage(Math.toIntExact(repalBillPage.getPages()));
- voPage.setTotalNum(repalBillPage.getTotal());
- voPage.setDataList(new ArrayList<>());
- infoVO.setPage(voPage);
- if (CollUtil.isEmpty(repalBillPage.getRecords())) {
- return infoVO;
- }
- // 未读消息
- List<Long> billIdList = repalBillPage.getRecords().stream().map(RepalBill::getId).collect(Collectors.toList());
- Map<Long, RepalBillRemindUnReadVO> unreadMap = new HashMap<>();
- repalBillPage.getRecords().parallelStream().forEach(repalBill -> {
- RepalRemindReadInfo repalRemindReadInfo = repalRemindReadInfoService.getReadInfoByUserId(userId,repalBill.getId(),repalBill.getRepalBookId());
- RepalBillRemindUnReadVO readVO = repalRemindHistoryService.getBillRemindUnReadVO(repalRemindReadInfo.getRiskRemindId(),
- repalRemindReadInfo.getRankRemindId(),repalRemindReadInfo.getOverdueRemindId(),
- repalRemindReadInfo.getFinanceRemindId(),repalBill.getRepalBookId(),repalBill.getId(),
- Objects.isNull(billPageBO.getStartDate()) ? null : LocalDateTime.of(billPageBO.getStartDate(), LocalTime.MIN),
- Objects.isNull(billPageBO.getEndDate()) ? null : LocalDateTime.of(billPageBO.getEndDate(), LocalTime.MAX));
- unreadMap.put(repalBill.getId(), readVO);
- });
- Map<Long, List<String>> nameMap = repalResponsiblePersonService.getResponsiblePersonNameList(billIdList);
- List<RepalCustomer> customerList = repalCustomerService.list(Wrappers.lambdaQuery(RepalCustomer.class).in(RepalCustomer::getCustId,
- repalBillPage.getRecords().stream().map(RepalBill::getCustomerId).distinct().collect(Collectors.toList())));
- Map<Long, Integer> custMap = customerList.stream().collect(Collectors.toMap(RepalCustomer::getCustId, RepalCustomer::getCustProperty));
- voPage.setDataList(repalBillPage.getRecords().stream().map(repalBill -> {
- RepalBillPageVO vo = new RepalBillPageVO();
- BeanUtils.copyProperties(repalBill, vo);
- vo.setRepalBillId(repalBill.getId());
- if (nameMap.containsKey(repalBill.getId())) {
- vo.setResponsiblePersonNames(String.join("、", nameMap.get(repalBill.getId())));
- }
- vo.setRepalOverdueStatus(repalBill.getRepalBillStatus() > 1 ? repalBill.getRepalBillStatus() + 1 : repalBill.getRepalBillStatus());
- if (RepalBillStatusEnum.PROGRESSING.getCode().equals(vo.getRepalOverdueStatus()) && LocalDate.now().plusDays(3).equals(vo.getEndDate())) {
- vo.setRepalOverdueStatus(2);
- }
- vo.setCustName(repalBill.getCustomerName());
- vo.setCustProperty(custMap.get(repalBill.getCustomerId()));
- vo.setTotalMoneyStr(repalBill.getTotalMoney().stripTrailingZeros().toPlainString());
- vo.setReceivableMoneyStr(repalBill.getReceivable().stripTrailingZeros().toPlainString());
- // 评分趋势
- vo.setDiagnosisScoreTrend(DiagnosisUtil.getDiagnosisScoreTrend(repalBill.getPreDiagnosisScore(), repalBill.getDiagnosisScore(), repalBill.getPreDiagnosisGrade(), repalBill.getDiagnosisGrade()));
- if (Objects.nonNull(repalBill.getDiagnosisScore())) {
- vo.setDiagnosisScore(repalBill.getDiagnosisScore().stripTrailingZeros().toPlainString());
- }
- RepalBillRemindUnReadVO unReadVO = unreadMap.get(vo.getRepalBillId());
- if (Objects.nonNull(unReadVO)) {
- vo.setDynamicCountList(new ArrayList<Integer>(){{
- add(unReadVO.getUnreadRiskCount());
- add(unReadVO.getUnreadFinanceCount());
- add(unReadVO.getUnreadRankCount());
- add(unReadVO.getUnreadOverdueCount());
- }});
- }
- return vo;
- }).collect(Collectors.toList()));
- return infoVO;
- }
- @Override
- public VOPage<RepalBillPageVO> searchBill(SearchBillDTO dto) {
- long userId = UserContextUtil.getUser().getUserId();
- Long groupId = repalGroupMemberService.getUserGroupId(userId);
- VOPage<RepalBillPageVO> voPage = new VOPage<>();
- voPage.setPageSize(dto.getPageSize());
- voPage.setPageNum(dto.getPageNum());
- // 分页数据
- Page<RepalBill> repalBillPage = new Page<>(dto.getPageNum(),dto.getPageSize());
- SearchBillPageBO searchBillPageBO = new SearchBillPageBO();
- searchBillPageBO.setReceivableFlag(repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIVABLE.getCode()));
- searchBillPageBO.setReceiptFlag(repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIPT.getCode()));
- searchBillPageBO.setRepalBillType(dto.getRepalBillType());
- // if (Objects.isNull(dto.getRepalBillType())) {
- // searchBillPageBO.setReceivableFlag(repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIVABLE.getCode()));
- // searchBillPageBO.setReceiptFlag(repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIPT.getCode()));
- // } else {
- // searchBillPageBO.setRepalBillType(dto.getRepalBillType());
- // if (RepalBillTypeEnum.RECEIVABLE.getCode().equals(dto.getRepalBillType())) {
- // searchBillPageBO.setReceivableFlag(repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIVABLE.getCode()));
- // searchBillPageBO.setReceiptFlag(false);
- // } else {
- // searchBillPageBO.setReceivableFlag(false);
- // searchBillPageBO.setReceiptFlag(repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIPT.getCode()));
- // }
- // }
- searchBillPageBO.setKeyword(dto.getKeyword());
- searchBillPageBO.setUserId(userId);
- searchBillPageBO.setRepalGroupId(groupId);
- searchBillPageBO.setRepalBookId(dto.getRepalBookId());
- searchBillPageBO.setAllFlag(searchBillPageBO.getReceivableFlag() && searchBillPageBO.getReceiptFlag());
- repalBillPage = repalBillMapper.searchPage(repalBillPage, searchBillPageBO);
- voPage.setTotalPage(Math.toIntExact(repalBillPage.getPages()));
- voPage.setTotalNum(repalBillPage.getTotal());
- voPage.setDataList(new ArrayList<>());
- if (CollUtil.isEmpty(repalBillPage.getRecords())) {
- return voPage;
- }
- // 未读消息
- List<Long> billIdList = repalBillPage.getRecords().stream().map(RepalBill::getId).collect(Collectors.toList());
- Map<Long, RepalBillRemindUnReadVO> unreadMap = new HashMap<>();
- repalBillPage.getRecords().parallelStream().forEach(repalBill -> {
- RepalRemindReadInfo repalRemindReadInfo = repalRemindReadInfoService.getReadInfoByUserId(userId,repalBill.getId(),repalBill.getRepalBookId());
- RepalBillRemindUnReadVO readVO = repalRemindHistoryService.getBillRemindUnReadVO(repalRemindReadInfo.getRiskRemindId(),
- repalRemindReadInfo.getRankRemindId(),repalRemindReadInfo.getOverdueRemindId(),
- repalRemindReadInfo.getFinanceRemindId(),repalBill.getRepalBookId(),repalBill.getId(),
- null, null);
- unreadMap.put(repalBill.getId(), readVO);
- });
- Map<Long, List<String>> nameMap = repalResponsiblePersonService.getResponsiblePersonNameList(billIdList);
- List<RepalCustomer> customerList = repalCustomerService.list(Wrappers.lambdaQuery(RepalCustomer.class).in(RepalCustomer::getCustId,
- repalBillPage.getRecords().stream().map(RepalBill::getCustomerId).distinct().collect(Collectors.toList())));
- Map<Long, Integer> custMap = customerList.stream().collect(Collectors.toMap(RepalCustomer::getCustId, RepalCustomer::getCustProperty));
- voPage.setDataList(repalBillPage.getRecords().stream().map(repalBill -> {
- RepalBillPageVO vo = new RepalBillPageVO();
- BeanUtils.copyProperties(repalBill, vo);
- vo.setRepalBillId(repalBill.getId());
- if (nameMap.containsKey(repalBill.getId())) {
- vo.setResponsiblePersonNames(String.join("、", nameMap.get(repalBill.getId())));
- }
- vo.setRepalOverdueStatus(repalBill.getRepalBillStatus() > 1 ? repalBill.getRepalBillStatus() + 1 : repalBill.getRepalBillStatus());
- vo.setCustName(repalBill.getCustomerName());
- vo.setCustProperty(custMap.get(repalBill.getCustomerId()));
- vo.setTotalMoneyStr(repalBill.getTotalMoney().stripTrailingZeros().toPlainString());
- vo.setReceivableMoneyStr(repalBill.getReceivable().stripTrailingZeros().toPlainString());
- // 评分趋势
- vo.setDiagnosisScoreTrend(DiagnosisUtil.getDiagnosisScoreTrend(repalBill.getPreDiagnosisScore(), repalBill.getDiagnosisScore(), repalBill.getPreDiagnosisGrade(), repalBill.getDiagnosisGrade()));
- if (Objects.nonNull(repalBill.getDiagnosisScore())) {
- vo.setDiagnosisScore(repalBill.getDiagnosisScore().stripTrailingZeros().toPlainString());
- }
- RepalBillRemindUnReadVO unReadVO = unreadMap.get(vo.getRepalBillId());
- if (Objects.nonNull(unReadVO)) {
- vo.setDynamicCountList(new ArrayList<Integer>(){{
- add(unReadVO.getUnreadRiskCount());
- add(unReadVO.getUnreadFinanceCount());
- add(unReadVO.getUnreadRankCount());
- add(unReadVO.getUnreadOverdueCount());
- }});
- }
- return vo;
- }).collect(Collectors.toList()));
- return voPage;
- }
- @Override
- public RepalBillDetailVO getRepalBillDetail(Long repalBillId) {
- RepalBill repalBill = this.getById(repalBillId);
- // 负责人或高级权限才能查看
- boolean queryAllFlag = repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.QUERY_ALL_RECEIVABLE.getCode() : PermissionEnum.QUERY_ALL_RECEIPT.getCode());
- if (!queryAllFlag &&!repalResponsiblePersonService.getResponsiblePersonId(repalBillId).contains(UserContextUtil.getUser().getUserId())) {
- throw new CommonException(CodeMsg.FAILED, "没有查看权限");
- }
- RepalBillDetailVO vo = new RepalBillDetailVO();
- BeanUtils.copyProperties(repalBill, vo);
- vo.setRepalBillId(repalBill.getId());
- RepalCustomer repalCustomer = repalCustomerService.getById(repalBill.getCustomerId());
- vo.setCompanyId(repalCustomer.getCompanyId());
- vo.setCustomerId(repalCustomer.getCustId());
- vo.setCustProperty(repalCustomer.getCustProperty());
- List<String> nameList = repalResponsiblePersonService.getResponsiblePersonName(vo.getRepalBillId());
- if (CollUtil.isNotEmpty(nameList)) {
- vo.setResponsiblePersonNames(CollUtil.isEmpty(nameList) ? "" : String.join("、", nameList));
- }
- List<ResponsiblePersonNameVO> personList = repalResponsiblePersonService.getPersonNameList(vo.getRepalBillId());
- if (CollUtil.isNotEmpty(personList)) {
- vo.setResponsiblePersonNames(personList.stream().map(ResponsiblePersonNameVO::getUserName).collect(Collectors.joining("、")));
- vo.setResponsiblePersonList(personList);
- }
- vo.setTotalMoneyStr(repalBill.getTotalMoney().stripTrailingZeros().toPlainString());
- vo.setReceiptStr(repalBill.getReceipt().stripTrailingZeros().toPlainString());
- vo.setReceivableStr(repalBill.getReceivable().stripTrailingZeros().toPlainString());
- // 评分趋势
- vo.setDiagnosisScoreTrend(DiagnosisUtil.getDiagnosisScoreTrend(repalBill.getPreDiagnosisScore(), repalBill.getDiagnosisScore(), repalBill.getPreDiagnosisGrade(), repalBill.getDiagnosisGrade()));
- if (Objects.nonNull(repalBill.getDiagnosisScore())) {
- vo.setDiagnosisGradeDesc(DiagnosisUtil.getGradeConclusion(repalBill.getDiagnosisScore()));
- vo.setDiagnosisScore(repalBill.getDiagnosisScore().stripTrailingZeros().toPlainString());
- }
- // companyId
- if (StrUtil.isNotBlank(vo.getCompanyId())) {
- // 财产数量
- ApiDataResult<List<FinanceDynamicNumVO>> financeResult = dataMiddlewareService.getFinanceDynamicNumV8List(new GetFinanceDynamicNumDTO().setCompanyIdList(Collections.singletonList(vo.getCompanyId())));
- if (Objects.nonNull(financeResult) && CollUtil.isNotEmpty(financeResult.getData())) {
- vo.setAssetsNum(financeResult.getData().get(0).getFinanceDynamicNum());
- }
- // 风险数量
- ApiDataResult<List<CompanyRiskNumVO>> riskResult = dataMiddlewareService.getCompanyRiskNumList(new GetCompanyRiskNumDTO(Collections.singletonList(vo.getCompanyId())));
- if (Objects.nonNull(riskResult) && CollUtil.isNotEmpty(riskResult.getData())) {
- vo.setRiskNum(riskResult.getData().get(0).getRiskNum());
- }
- // 失信限高标签
- ApiDataResult<List<CreditPunishmentLabelListVO>> labelResult = dataMiddlewareService.getCreditPunishmentLabelList(new GetCreditPunishmentLabelDTO(Collections.singletonList(vo.getCompanyId())));
- if (Objects.nonNull(labelResult) && CollUtil.isNotEmpty(labelResult.getData())) {
- vo.setLabelList(labelResult.getData().get(0).getLabelList());
- }
- }
- if (Objects.nonNull(repalBill.getDiagnosisId())) {
- RepalBillDiagnosis repalBillDiagnosis = repalBillDiagnosisService.getById(repalBill.getDiagnosisId());
- if (Objects.nonNull(repalBillDiagnosis)) {
- try {
- ApiDataResult<DiagnosisRecordVO> apiDataResult = inCaseService.getRecordVO(repalBillDiagnosis.getBizId());
- if (Objects.nonNull(apiDataResult)) {
- vo.setAnalysisList(DiagnosisUtil.convertItemToList(apiDataResult.getData().getResultItem()));
- }
- } catch (Exception e) {
- LOGGER.error("查询评估信息错误", e);
- }
- }
- }
- // 合同
- if (StrUtil.isNotBlank(repalBill.getContractUrl())) {
- List<String> urlList = Arrays.stream(repalBill.getContractUrl().split(";")).collect(Collectors.toList());
- vo.setContractList(urlList.stream().map(s -> {
- RepalBillDetailVO.BillContract billContract = new RepalBillDetailVO.BillContract();
- billContract.setContractUrl(s);
- billContract.setContractName(s.substring(s.lastIndexOf("/") + 1));
- return billContract;
- }).collect(Collectors.toList()));
- }
- if (RepalBillStatusEnum.OVERDUE.getCode().equals(repalBill.getRepalBillStatus())) {
- if (Objects.nonNull(repalBill.getEndDate())) {
- if (LocalDate.now().isAfter(repalBill.getEndDate()) || LocalDate.now().compareTo(repalBill.getEndDate()) == 0) {
- // 避免天数出现负数
- vo.setOverdueDay(Math.toIntExact(LocalDate.now().toEpochDay() - repalBill.getEndDate().toEpochDay()) + 1);
- }
- }
- }
- List<RepalChangeRecord> repalChangeRecordList = repalChangeRecordService.list(Wrappers.lambdaQuery(RepalChangeRecord.class)
- .eq(RepalChangeRecord::getRepalBillId, vo.getRepalBillId())
- .eq(RepalChangeRecord::getDeleted, DeletedStatusEnum.NORMAL.getCode()));
- if (CollUtil.isNotEmpty(repalChangeRecordList)) {
- vo.setChangeList(repalChangeRecordList.stream().map(t -> {
- RepalBillDetailVO.BillMoneyChange billMoneyChange = new RepalBillDetailVO.BillMoneyChange();
- billMoneyChange.setChangeTime(t.getTimeCreated());
- billMoneyChange.setName(t.getOperUserName());
- billMoneyChange.setChangeAmt(t.getTransMoney().setScale(2).toString());
- return billMoneyChange;
- }).collect(Collectors.toList()));
- } else {
- vo.setChangeList(new ArrayList<>());
- }
- return vo;
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean deleteRepalBillById(DeleteRepalBillDTO dto) {
- RepalBill repalBill = this.getById(dto.getRepalBillId());
- if (!repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getCode() : PermissionEnum.UPDATE_RECEIPT.getCode())) {
- throw new CommonException(CodeMsg.FAILED, "无对应权限");
- }
- this.update(Wrappers.lambdaUpdate(RepalBill.class).eq(RepalBill::getId, dto.getRepalBillId())
- .set(RepalBill::getDeleted, DeletedStatusEnum.DELETE.getCode()));
- // 删除关联人
- repalResponsiblePersonService.deletePersonByBillId(dto.getRepalBillId());
- return true;
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean settleRepalBillById(SettleRepalBillDTO dto) {
- long userId = UserContextUtil.getUser().getUserId();
- RepalBill repalBill = this.getById(dto.getRepalBillId());
- if (!repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getCode() : PermissionEnum.UPDATE_RECEIPT.getCode())) {
- throw new CommonException(CodeMsg.FAILED, "无对应权限");
- }
- // 结清tag
- boolean success = false;
- // 金额溢出
- if (dto.getMoney().compareTo(repalBill.getReceivable()) >= 0) {
- dto.setMoney(repalBill.getReceivable());
- success = true;
- }
- RepalGroupMember member = repalGroupMemberService.getOne(Wrappers.lambdaQuery(RepalGroupMember.class)
- .eq(RepalGroupMember::getRepalGroupId, repalGroupMemberService.getUserGroupId(userId))
- .eq(RepalGroupMember::getUserId, userId)
- .eq(RepalGroupMember::getDeleted, DeletedStatusEnum.NORMAL.getCode()));
- if (Objects.isNull(member)) {
- throw new CommonException(CodeMsg.FAILED, "成员信息错误");
- }
- RepalChangeRecord changeRecord = new RepalChangeRecord();
- changeRecord.setRepalBookId(repalBill.getRepalBookId());
- changeRecord.setRepalBillId(repalBill.getId());
- changeRecord.setAfterMoney(repalBill.getReceivable().subtract(dto.getMoney()));
- changeRecord.setPreMoney(repalBill.getReceivable());
- changeRecord.setTransMoney(dto.getMoney());
- changeRecord.setOperUserId(userId);
- changeRecord.setRecordDate(dto.getRecordDate());
- changeRecord.setOperUserName(member.getMemberUserName());
- repalChangeRecordService.save(changeRecord);
- // 重新计算金额
- repalBill.setReceivable(success ? BigDecimal.ZERO : repalBill.getReceivable().subtract(dto.getMoney()));
- repalBill.setReceipt(success ? repalBill.getTotalMoney() : repalBill.getReceipt().add(dto.getMoney()));
- this.update(Wrappers.lambdaUpdate(RepalBill.class)
- .eq(RepalBill::getId, repalBill.getId())
- .set(success, RepalBill::getRepalBillStatus, RepalBillStatusEnum.SUCCESS.getCode())
- .set(RepalBill::getReceivable, repalBill.getReceivable())
- .set(RepalBill::getReceipt, repalBill.getReceipt())
- .set(success, RepalBill::getSettleTime, LocalDateTime.now()));
- return true;
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean addRepalBill(AddRepalBillDTO dto) {
- RepalCustomer customer = repalCustomerService.getById(dto.getCustomerId());
- if (Objects.isNull(customer)) {
- throw new CommonException(CodeMsg.FAILED, "客户信息错误");
- }
- long groupId = repalGroupMemberService.getUserGroupId(UserContextUtil.getUser().getUserId());
- // 评级flag
- boolean diagnosisFlag = (CustPropertyEnum.COMPANY.getCode().equals(customer.getCustProperty()) || CustPropertyEnum.GOV.getCode().equals(customer.getCustProperty()))
- && RepalBillTypeEnum.RECEIVABLE.getCode().equals(dto.getRepalBillType());
- if (diagnosisFlag && StrUtil.isBlank(customer.getCompanyId())) {
- throw new CommonException(CodeMsg.FAILED, "公司信息错误");
- }
- if (!repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(dto.getRepalBillType()) ? PermissionEnum.ADD_RECEIVABLE.getCode() : PermissionEnum.ADD_RECEIPT.getCode())) {
- throw new CommonException(CodeMsg.FAILED, "无对应权限");
- }
- if (Objects.isNull(dto.getRepalBookId())) {
- // 新建账本
- RepalBook repalBook = new RepalBook();
- repalBook.setRepalGroupId(groupId);
- repalBook.setRepalBookName("默认账本");
- repalBook.setUserId(UserContextUtil.getUser().getUserId());
- repalBookService.save(repalBook);
- dto.setRepalBookId(repalBook.getId());
- }
- RepalBill repalBill = new RepalBill();
- BeanUtils.copyProperties(dto, repalBill);
- repalBill.setCustomerName(customer.getCustName());
- repalBill.setUserId(UserContextUtil.getUser().getUserId());
- repalBill.setRepalBillStatus(RepalBillStatusUtil.getRepalBillStatus(dto.getEndDate()));
- repalBill.setRepalGroupId(groupId);
- repalBill.setReceivable(dto.getTotalMoney());
- if (CollUtil.isNotEmpty(dto.getContractUrlList())) {
- repalBill.setContractUrl(String.join(";", dto.getContractUrlList()));
- }
- if (!diagnosisFlag) {
- repalBill.setRefreshStatus(RefreshStatusEnum.REFRESH_SUCCESS.getCode());
- }
- this.save(repalBill);
- if (diagnosisFlag) {
- // 非个人 & 应收,才会评级
- repalBillDiagnosisService.addRepalBillDiagnosis(repalBill.getUserId(), repalBill.getId(), dto.getTotalMoney(), Collections.singletonList(customer.getCustName()));
- }
- // 负责人
- if (CollUtil.isNotEmpty(dto.getResponsiblePersonIdList())) {
- repalResponsiblePersonService.saveBatch(dto.getResponsiblePersonIdList().stream().map(t -> {
- RepalResponsiblePerson person = new RepalResponsiblePerson();
- person.setRepalGroupId(groupId);
- person.setRepalBookId(dto.getRepalBookId());
- person.setRepalBillId(repalBill.getId());
- person.setUserId(t);
- return person;
- }).collect(Collectors.toList()));
- }
- return true;
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean breakRepalBill(BreakRepalBillDTO dto) {
- RepalBill repalBill = this.getById(dto.getRepalBillId());
- if (Objects.isNull(repalBill)) {
- throw new CommonException(CodeMsg.FAILED, "账款错误");
- }
- if (!repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getCode() : PermissionEnum.UPDATE_RECEIPT.getCode())) {
- throw new CommonException(CodeMsg.FAILED, "无对应权限");
- }
- this.update(Wrappers.lambdaUpdate(RepalBill.class)
- .eq(RepalBill::getId, dto.getRepalBillId())
- .set(RepalBill::getRepalBillStatus, RepalBillStatusEnum.END.getCode())
- .set(StrUtil.isNotBlank(dto.getBreakReason()), RepalBill::getBreakReason, dto.getBreakReason()));
- return true;
- }
- @Override
- public Boolean unBreakRepalBill(BreakRepalBillDTO dto) {
- RepalBill repalBill = this.getById(dto.getRepalBillId());
- if (Objects.isNull(repalBill)) {
- throw new CommonException(CodeMsg.FAILED, "账款错误");
- }
- if (!repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getCode() : PermissionEnum.UPDATE_RECEIPT.getCode())) {
- throw new CommonException(CodeMsg.FAILED, "无对应权限");
- }
- // 逾期标志
- boolean overdue = LocalDate.now().isAfter(repalBill.getEndDate());
- this.update(Wrappers.lambdaUpdate(RepalBill.class)
- .eq(RepalBill::getId, dto.getRepalBillId())
- .set(RepalBill::getRepalBillStatus, overdue ? RepalBillStatusEnum.OVERDUE.getCode() : RepalBillStatusEnum.PROGRESSING.getCode())
- .set(StrUtil.isNotBlank(dto.getBreakReason()), RepalBill::getBreakReason, dto.getBreakReason()));
- return true;
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean updateRepalBill(UpdateRepalBillDTO dto) {
- RepalBill repalBill = this.getById(dto.getRepalBillId());
- if (!repalRolePermissionService.checkUserPermission(UserContextUtil.getUser().getUserId(),
- RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getCode() : PermissionEnum.UPDATE_RECEIPT.getCode())) {
- throw new CommonException(CodeMsg.FAILED, "无对应权限");
- }
- // 责任人
- List<Long> currentIdList = repalResponsiblePersonService.getResponsiblePersonId(repalBill.getId());
- List<Long> difference = new ArrayList<>(CollUtil.disjunction(dto.getResponsiblePersonIdList(), currentIdList));
- if (CollUtil.isNotEmpty(difference)) {
- for (Long aLong : difference) {
- if (currentIdList.contains(aLong)) {
- // 移除
- repalResponsiblePersonService.update(Wrappers.lambdaUpdate(RepalResponsiblePerson.class)
- .eq(RepalResponsiblePerson::getRepalBillId, repalBill.getId())
- .eq(RepalResponsiblePerson::getUserId, aLong)
- .set(RepalResponsiblePerson::getDeleted, DeletedStatusEnum.DELETE.getCode()));
- }
- if (dto.getResponsiblePersonIdList().contains(aLong)) {
- // 新增
- RepalResponsiblePerson person = new RepalResponsiblePerson();
- person.setRepalBillId(repalBill.getId());
- person.setRepalBookId(repalBill.getRepalBookId());
- person.setRepalGroupId(repalBill.getRepalGroupId());
- person.setUserId(aLong);
- repalResponsiblePersonService.save(person);
- }
- }
- }
- if (LocalDate.now().isAfter(dto.getEndDate())) {
- // 逾期
- repalBill.setRepalBillStatus(RepalBillStatusEnum.OVERDUE.getCode());
- }
- // 改金额三种状态
- if (dto.getReceivable().compareTo(BigDecimal.ZERO) == 0) {
- repalBill.setTotalMoney(repalBill.getReceipt());
- repalBill.setRepalBillStatus(RepalBillStatusEnum.SUCCESS.getCode());
- }
- if (dto.getReceivable().compareTo(repalBill.getReceivable()) > 0) {
- repalBill.setTotalMoney(repalBill.getTotalMoney().add(dto.getReceivable().subtract(repalBill.getReceivable())));
- }
- if (dto.getReceivable().compareTo(repalBill.getReceivable()) < 0) {
- repalBill.setTotalMoney(repalBill.getTotalMoney().subtract(repalBill.getReceivable().subtract(dto.getReceivable())));
- }
- repalBill.setReceivable(dto.getReceivable());
- this.update(Wrappers.lambdaUpdate(RepalBill.class)
- .eq(RepalBill::getId, repalBill.getId())
- .set(RepalBill::getEndDate, dto.getEndDate())
- .set(RepalBill::getRepalBillStatus, repalBill.getRepalBillStatus())
- .set(RepalBill::getRepalBillStage, dto.getRepalBillStage())
- .set(RepalBill::getBillRemark, dto.getBillRemark())
- .set(RepalBill::getTotalMoney, repalBill.getTotalMoney())
- .set(RepalBill::getReceivable, repalBill.getReceivable())
- .set(RepalBill::getReceipt, repalBill.getReceipt())
- .set(RepalBill::getContractName, dto.getContractName())
- .set(RepalBill::getContractEndDate, dto.getContractEndDate())
- .set(RepalBill::getContractUrl, String.join( ";", dto.getContractUrlList()))
- );
- RepalBillOperLog repalBillOperLog = new RepalBillOperLog();
- repalBillOperLog.setUserId(UserContextUtil.getUser().getUserId());
- repalBillOperLog.setActionCode(RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getCode() : PermissionEnum.UPDATE_RECEIPT.getCode());
- repalBillOperLog.setActionCode(RepalBillTypeEnum.RECEIVABLE.getCode().equals(repalBill.getRepalBillType()) ? PermissionEnum.UPDATE_RECEIVABLE.getMsg() : PermissionEnum.UPDATE_RECEIPT.getMsg());
- repalBillOperLog.setBizType("update");
- repalBillOperLog.setBizId(String.valueOf(repalBill.getId()));
- repalBillOperLog.setActionContent(JSON.toJSONString(dto));
- repalBillOperLogService.save(repalBillOperLog);
- return true;
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean deleteRepalBillByBookId(Long repalBookId) {
- this.update(Wrappers.lambdaUpdate(RepalBill.class)
- .eq(RepalBill::getRepalBookId, repalBookId)
- .set(RepalBill::getDeleted, DeletedStatusEnum.DELETE.getCode()));
- // 责任人也删除
- repalResponsiblePersonService.deletePersonByBookId(repalBookId);
- return true;
- }
- @Override
- public boolean checkAllBillRefreshStatus(Long repalBookId, Long repalBillId) {
- LambdaQueryWrapper<RepalBill> qw = Wrappers.lambdaQuery(RepalBill.class);
- qw.eq(RepalBill::getRepalBookId,repalBookId);
- qw.ne(RepalBill::getId,repalBillId);
- List<RepalBill> results = list(qw);
- for(RepalBill accountBill:results){
- if(!RefreshStatusEnum.REFRESH_SUCCESS.getCode().equals(accountBill.getRefreshStatus())){
- return false;
- }
- }
- return true;
- }
- @Override
- public VOPage<RepalBillPageVO> getCustRepalBillPage(Integer pageNum, Integer pageSize, Long custId) {
- VOPage<RepalBillPageVO> voPage = new VOPage<>();
- voPage.setPageSize(pageSize);
- voPage.setPageNum(pageNum);
- // 分页数据
- Page<RepalBill> repalBillPage = new Page<>(pageNum,pageSize);
- repalBillPage = repalBillMapper.getCustRepalBillPage(repalBillPage,custId);
- voPage.setTotalPage(Math.toIntExact(repalBillPage.getPages()));
- voPage.setTotalNum(repalBillPage.getTotal());
- voPage.setDataList(new ArrayList<>());
- if (CollUtil.isEmpty(repalBillPage.getRecords())) {
- return voPage;
- }
- // 未读消息
- List<Long> billIdList = repalBillPage.getRecords().stream().map(RepalBill::getId).collect(Collectors.toList());
- long userId = UserContextUtil.getUser().getUserId();
- Map<Long, RepalBillRemindUnReadVO> unreadMap = new HashMap<>();
- repalBillPage.getRecords().parallelStream().forEach(repalBill -> {
- RepalRemindReadInfo repalRemindReadInfo = repalRemindReadInfoService.getReadInfoByUserId(userId,repalBill.getId(),repalBill.getRepalBookId());
- RepalBillRemindUnReadVO readVO = repalRemindHistoryService.getBillRemindUnReadVO(repalRemindReadInfo.getRiskRemindId(),
- repalRemindReadInfo.getRankRemindId(),repalRemindReadInfo.getOverdueRemindId()
- ,repalRemindReadInfo.getFinanceRemindId(),repalBill.getRepalBookId(),repalBill.getId(),
- null, null);
- unreadMap.put(repalBill.getId(), readVO);
- });
- Map<Long, List<String>> nameMap = repalResponsiblePersonService.getResponsiblePersonNameList(billIdList);
- List<RepalCustomer> customerList = repalCustomerService.list(Wrappers.lambdaQuery(RepalCustomer.class).in(RepalCustomer::getCustId,
- repalBillPage.getRecords().stream().map(RepalBill::getCustomerId).distinct().collect(Collectors.toList())));
- Map<Long, Integer> custMap = customerList.stream().collect(Collectors.toMap(RepalCustomer::getCustId, RepalCustomer::getCustProperty));
- voPage.setDataList(repalBillPage.getRecords().stream().map(t -> {
- RepalBillPageVO vo = new RepalBillPageVO();
- BeanUtils.copyProperties(t, vo);
- vo.setRepalBillId(t.getId());
- if(nameMap.containsKey(t.getId())) {
- vo.setResponsiblePersonNames(String.join("、", nameMap.get(t.getId())));
- }
- vo.setRepalOverdueStatus(t.getRepalBillStatus() > 1 ? t.getRepalBillStatus() + 1 : t.getRepalBillStatus());
- if (RepalBillStatusEnum.PROGRESSING.getCode().equals(vo.getRepalOverdueStatus()) && LocalDate.now().plusDays(3).equals(vo.getEndDate())) {
- vo.setRepalOverdueStatus(2);
- }
- vo.setCustName(t.getCustomerName());
- vo.setCustProperty(custMap.get(t.getCustomerId()));
- vo.setTotalMoneyStr(t.getTotalMoney().stripTrailingZeros().toPlainString());
- vo.setReceivableMoneyStr(t.getReceivable().stripTrailingZeros().toPlainString());
- // 评分趋势
- vo.setDiagnosisScoreTrend(DiagnosisUtil.getDiagnosisScoreTrend(t.getPreDiagnosisScore(), t.getDiagnosisScore(), t.getPreDiagnosisGrade(), t.getDiagnosisGrade()));
- if (Objects.nonNull(t.getDiagnosisScore())) {
- vo.setDiagnosisScore(t.getDiagnosisScore().stripTrailingZeros().toPlainString());
- }
- RepalBillRemindUnReadVO unReadVO = unreadMap.get(vo.getRepalBillId());
- if (Objects.nonNull(unReadVO)) {
- vo.setDynamicCountList(new ArrayList<Integer>(){{
- add(unReadVO.getUnreadRiskCount());
- add(unReadVO.getUnreadFinanceCount());
- add(unReadVO.getUnreadRankCount());
- add(unReadVO.getUnreadOverdueCount());
- }});
- }
- return vo;
- }).collect(Collectors.toList()));
- return voPage;
- }
- @Override
- public RepalManageBillInfoVO queryManageInfo() {
- //权限
- UserContextBO userContextBO = UserContextUtil.getUser();
- boolean allFlag = repalRolePermissionService.checkUserPermission(userContextBO.getUserId(),PermissionEnum.QUERY_ALL_URGE.getCode());
- //查询组织编号
- RepalGroupMember repalGroupMember = repalGroupMemberService.getOne(Wrappers.lambdaQuery(RepalGroupMember.class).eq(RepalGroupMember::getUserId,userContextBO.getUserId()).eq(RepalGroupMember::getDeleted,Dict.DeletedStatusEnunm.否.getCode()),false);
- if(ObjectUtil.isNull(repalGroupMember)){
- throw new CommonException(CodeMsg.FAILED,"您还未加入该组织,请联系超级管理员");
- }
- LocalDate startTime = LocalDate.now().plusDays(7);
- ManageBillInfoBO manageBillInfo = repalBillMapper.getManageBillInfo(allFlag,userContextBO.getUserId(),repalGroupMember.getRepalGroupId(),startTime);
- RepalManageBillInfoVO repalManageBillInfoVO = new RepalManageBillInfoVO();
- if(ObjectUtil.isNull(manageBillInfo.getTotalMoney()) || NumberUtil.equals(BigDecimal.ZERO,manageBillInfo.getTotalMoney())){
- repalManageBillInfoVO.setOverdueScaleStr("0");
- repalManageBillInfoVO.setTotalOverdueCount(0);
- repalManageBillInfoVO.setTotalOverdueStr("0");
- repalManageBillInfoVO.setTotalOverdueWeekCount(0);
- repalManageBillInfoVO.setTotalOverdueWeekStr("0");
- }else {
- repalManageBillInfoVO.setTotalOverdueCount(manageBillInfo.getTotalOverdueCount());
- repalManageBillInfoVO.setTotalOverdueStr(manageBillInfo.getTotalOverdue().toPlainString());
- repalManageBillInfoVO.setTotalOverdueWeekCount(manageBillInfo.getTotalOverdueWeekCount());
- repalManageBillInfoVO.setTotalOverdueWeekStr(manageBillInfo.getTotalOverdueWeek().toPlainString());
- repalManageBillInfoVO.setOverdueScaleStr(manageBillInfo.getTotalOverdue().divide(manageBillInfo.getTotalMoney(),2, RoundingMode.HALF_UP).toPlainString());
- }
- return repalManageBillInfoVO;
- }
- @Override
- public VOPage<RepalManageBillPageVO> queryManageBillPage(Integer pageNum, Integer pageSize) {
- //权限
- UserContextBO userContextBO = UserContextUtil.getUser();
- boolean allFlag = repalRolePermissionService.checkUserPermission(userContextBO.getUserId(),PermissionEnum.QUERY_ALL_URGE.getCode());
- //查询组织编号
- RepalGroupMember repalGroupMember = repalGroupMemberService.getOne(Wrappers.lambdaQuery(RepalGroupMember.class).eq(RepalGroupMember::getUserId,userContextBO.getUserId()).eq(RepalGroupMember::getDeleted,Dict.DeletedStatusEnunm.否.getCode()),false);
- if(ObjectUtil.isNull(repalGroupMember)){
- throw new CommonException(CodeMsg.FAILED,"您还未加入该组织,请联系超级管理员");
- }
- LocalDate startTime = LocalDate.now().plusDays(7);
- VOPage<RepalManageBillPageVO> voPage = new VOPage<>();
- voPage.setPageSize(pageSize);
- voPage.setPageNum(pageNum);
- // 分页数据
- Page<RepalManageBillPageBO> repalBillPage = new Page<>(pageNum,pageSize);
- repalBillPage = repalBillMapper.getManageBillPage(repalBillPage,allFlag,userContextBO.getUserId(),repalGroupMember.getRepalGroupId(),startTime);
- voPage.setTotalPage(Math.toIntExact(repalBillPage.getPages()));
- voPage.setTotalNum(repalBillPage.getTotal());
- voPage.setDataList(new ArrayList<>());
- if (CollUtil.isEmpty(repalBillPage.getRecords())) {
- return voPage;
- }
- List<RepalManageBillPageVO> vos = new ArrayList<>();
- voPage.setDataList(vos);
- Map<Long,List<ResponsiblePersonNameVO>> personMap= repalResponsiblePersonMapper.getResponsiblePersonNameList(repalBillPage.getRecords().stream().map(RepalManageBillPageBO::getRepalBillId).collect(Collectors.toList())).stream().collect(Collectors.groupingBy(ResponsiblePersonNameVO::getRepalBillId));
- for(RepalManageBillPageBO manageBillPageBO:repalBillPage.getRecords()){
- RepalManageBillPageVO vo = new RepalManageBillPageVO();
- vos.add(vo);
- BeanUtils.copyProperties(manageBillPageBO,vo);
- vo.setOverdueDay(Math.abs(manageBillPageBO.getEndDate().toEpochDay() - LocalDate.now().toEpochDay())+1);
- vo.setTotalMoneyStr(manageBillPageBO.getTotalMoney().stripTrailingZeros().toPlainString());
- vo.setReceivableStr(manageBillPageBO.getReceivable().stripTrailingZeros().toPlainString());
- //负责人
- if(personMap.containsKey(manageBillPageBO.getRepalBillId())){
- List<ResponsiblePersonNameVO> personNames = personMap.get(manageBillPageBO.getRepalBillId());
- vo.setResponsiblePersonName(personNames.stream().map(ResponsiblePersonNameVO::getUserName).collect(Collectors.toList()));
- }
- //催款动态条数
- int dynamicCount = repalDynamicService.count(Wrappers.lambdaQuery(RepalDynamic.class).eq(RepalDynamic::getRepalBillId,manageBillPageBO.getRepalBillId()));
- vo.setRepalDynamicCount(dynamicCount);
- }
- return voPage;
- }
- @Override
- public RepalManageBillDetailVO querManageBillDetail(Long repalBillId) {
- //不校验权限,默认看到列表的时候已经通过
- RepalBill repalBill = this.getById(repalBillId);
- RepalManageBillDetailVO vo = new RepalManageBillDetailVO();
- BeanUtils.copyProperties(repalBill, vo);
- vo.setCustId(repalBill.getCustomerId());
- vo.setRepalBillId(repalBill.getId());
- RepalBook repalBook = repalBookService.getById(repalBill.getRepalBookId());
- if(ObjectUtil.isNotNull(repalBook)){
- vo.setRepalBookName(repalBook.getRepalBookName());
- }
- RepalCustomer repalCustomer = repalCustomerService.getById(repalBill.getCustomerId());
- vo.setCompanyId(repalCustomer.getCompanyId());
- vo.setCustProperty(repalCustomer.getCustProperty());
- List<String> nameList = repalResponsiblePersonService.getResponsiblePersonName(vo.getRepalBillId());
- vo.setResponsiblePersonName(nameList);
- vo.setTotalMoneyStr(repalBill.getTotalMoney().stripTrailingZeros().toPlainString());
- vo.setReceiptStr(repalBill.getReceipt().stripTrailingZeros().toPlainString());
- vo.setReceivableStr(repalBill.getReceivable().stripTrailingZeros().toPlainString());
- vo.setOverdueDay(Math.abs(LocalDate.now().toEpochDay()-repalBill.getEndDate().toEpochDay())+1);
- // 评分趋势
- vo.setDiagnosisScoreTrend(DiagnosisUtil.getDiagnosisScoreTrend(repalBill.getPreDiagnosisScore(), repalBill.getDiagnosisScore(), repalBill.getPreDiagnosisGrade(), repalBill.getDiagnosisGrade()));
- if (Objects.nonNull(repalBill.getDiagnosisScore())) {
- vo.setDiagnosisGradeDesc(DiagnosisUtil.getGradeConclusion(repalBill.getDiagnosisScore()));
- vo.setDiagnosisScore(repalBill.getDiagnosisScore().stripTrailingZeros().toPlainString());
- }
- // companyId
- if (StrUtil.isNotBlank(vo.getCompanyId())) {
- // 财产数量
- ApiDataResult<List<FinanceDynamicNumVO>> financeResult = dataMiddlewareService.getFinanceDynamicNumV8List(new GetFinanceDynamicNumDTO().setCompanyIdList(Collections.singletonList(vo.getCompanyId())));
- if (Objects.nonNull(financeResult) && CollUtil.isNotEmpty(financeResult.getData())) {
- vo.setAssetsNum(financeResult.getData().get(0).getFinanceDynamicNum());
- }
- // 风险数量
- ApiDataResult<List<CompanyRiskNumVO>> riskResult = dataMiddlewareService.getCompanyRiskNumList(new GetCompanyRiskNumDTO(Collections.singletonList(vo.getCompanyId())));
- if (Objects.nonNull(riskResult) && CollUtil.isNotEmpty(riskResult.getData())) {
- vo.setRiskNum(riskResult.getData().get(0).getRiskNum());
- }
- // 失信限高标签
- ApiDataResult<List<CreditPunishmentLabelListVO>> labelResult = dataMiddlewareService.getCreditPunishmentLabelList(new GetCreditPunishmentLabelDTO(Collections.singletonList(vo.getCompanyId())));
- if (Objects.nonNull(labelResult) && CollUtil.isNotEmpty(labelResult.getData())) {
- vo.setLabelList(labelResult.getData().get(0).getLabelList());
- }
- }
- //查询套餐剩余qingk
- RepalVip repalVip = repalVipService.getOne(Wrappers.lambdaQuery(RepalVip.class).eq(RepalVip::getRepalGroupId,repalCustomer.getRepalGroupId()),false);
- RepalVipVO repalVipVO = new RepalVipVO();
- if(ObjectUtil.isNotNull(repalVip)){
- BeanUtils.copyProperties(repalVip,repalVipVO);
- }
- vo.setRepalVip(repalVipVO);
- //查询催款动态列表
- List<RepalDynamic> dynamics = repalDynamicService.list(Wrappers.lambdaQuery(RepalDynamic.class).eq(RepalDynamic::getRepalBillId,repalBillId).orderByDesc(RepalDynamic::getId));
- if(CollUtil.isNotEmpty(dynamics)){
- List<RepalDynamicVO> repalDynamicVOs = new ArrayList<>(dynamics.size());
- vo.setRepalDynamics(repalDynamicVOs);
- Map<Long,RepalGroupMember> memberMap = repalGroupMemberService.list(Wrappers.lambdaQuery(RepalGroupMember.class).in(RepalGroupMember::getUserId,dynamics.stream().map(RepalDynamic::getMemberId).distinct().collect(Collectors.toList()))).stream().collect(Collectors.toMap(RepalGroupMember::getUserId,Function.identity()));
- for(RepalDynamic dynamic:dynamics){
- RepalDynamicVO repalDynamicVO = new RepalDynamicVO();
- repalDynamicVOs.add(repalDynamicVO);
- BeanUtils.copyProperties(dynamic,repalDynamicVO);
- if(memberMap.containsKey(dynamic.getMemberId())){
- RepalGroupMember repalGroupMember = memberMap.get(dynamic.getMemberId());
- repalDynamicVO.setMemberUserName(repalGroupMember.getMemberUserName());
- }
- }
- }
- return vo;
- }
- @Override
- public List<Long> getBillIdListByBookId(Long repalBookId, Long userId) {
- return repalBillMapper.getBillIdListByBookId(repalBookId, userId);
- }
- @Override
- public List<String> getBillGradeByBookId(Long repalBookId, Long userId, LocalDateTime start, LocalDateTime end) {
- return repalBillMapper.getBillGradeByBookId(repalBookId, userId, start, end);
- }
- @Override
- public HomeReceivableBO getBillTotal(Integer repalBillStatus, Long userId, Long repalBookId, Integer repalBillType, LocalDateTime start, LocalDateTime end) {
- return repalBillMapper.getBillTotal(repalBillStatus, userId, repalBookId, repalBillType, start, end);
- }
- @Override
- @Transactional(rollbackFor = Exception.class)
- public Boolean transferBill(TransferBillDTO dto) {
- // 账款创建人
- this.update(Wrappers.lambdaUpdate(RepalBill.class)
- .eq(RepalBill::getUserId, dto.getUserId())
- .set(RepalBill::getUserId, dto.getTransferUserId()));
- // 账款负责人
- repalResponsiblePersonService.update(Wrappers.lambdaUpdate(RepalResponsiblePerson.class)
- .eq(RepalResponsiblePerson::getUserId, dto.getUserId())
- .set(RepalResponsiblePerson::getUserId, dto.getTransferUserId()));
- // 客户负责人
- repalCustChargeRelService.update(Wrappers.lambdaUpdate(RepalCustChargeRel.class)
- .eq(RepalCustChargeRel::getMemberUserId, dto.getUserId())
- .set(RepalCustChargeRel::getMemberUserId, dto.getTransferUserId()));
- return true;
- }
- @Autowired
- private RepalChangeRecordMapper repalChangeRecordMapper;
- @Override
- public VOPage<ReturnedBillVO> getReturnedBillPage(ReturnedBillDTO dto) {
- VOPage<ReturnedBillVO> voPage = new VOPage<>();
- voPage.setPageNum(dto.getPageNum());
- voPage.setPageSize(dto.getPageSize());
- Page<ReturnedBillVO> recordPage = new Page<>(dto.getPageNum(), dto.getPageSize());
- //
- long userId = UserContextUtil.getUser().getUserId();
- boolean allFlag = repalRolePermissionService.checkUserPermission(userId, PermissionEnum.QUERY_ALL_RECEIVABLE.getCode());
- dto.setUserId(allFlag ? null : userId);
- dto.setRepalGroupId(repalGroupMemberService.getUserGroupId(userId));
- recordPage = repalChangeRecordMapper.getReturnedBill(recordPage, dto);
- voPage.setTotalPage(Math.toIntExact(recordPage.getPages()));
- voPage.setTotalNum(recordPage.getTotal());
- if (CollUtil.isEmpty(recordPage.getRecords())) {
- return voPage;
- }
- for (ReturnedBillVO record : recordPage.getRecords()) {
- record.setMoneyStr(record.getMoney().setScale(2).toString());
- }
- voPage.setDataList(recordPage.getRecords());
- return voPage;
- }
- @Override
- public ReturnedBillDetailVO getReturnedBillDetail(Long repalChangeRecordId) {
- ReturnedBillDetailVO vo = new ReturnedBillDetailVO();
- RepalChangeRecord record = repalChangeRecordService.getById(repalChangeRecordId);
- if (Objects.isNull(record)) {
- throw new CommonException(CodeMsg.FAILED, "查询失败");
- }
- BeanUtils.copyProperties(record, vo);
- vo.setRepalChangeRecordId(repalChangeRecordId);
- RepalBill bill = this.getById(record.getRepalBillId());
- RepalCustomer cust = repalCustomerService.getById(bill.getCustomerId());
- List<String> nameList = repalResponsiblePersonService.getResponsiblePersonName(bill.getId());
- if (CollUtil.isNotEmpty(nameList)) {
- vo.setResponsiblePersonNames(CollUtil.isEmpty(nameList) ? "" : String.join("、", nameList));
- }
- vo.setEndDate(bill.getEndDate());
- vo.setTotalMoneyStr(bill.getTotalMoney().setScale(2).toString());
- vo.setReceivableStr(bill.getReceivable().setScale(2).toString());
- vo.setCustProperty(cust.getCustProperty());
- vo.setCustName(cust.getCustName());
- vo.setUserName(record.getOperUserName());
- vo.setRepalBillStatus(bill.getRepalBillStatus());
- vo.setMoneyStr(record.getTransMoney().setScale(2).toString());
- // 评分趋势
- vo.setDiagnosisGrade(bill.getDiagnosisGrade());
- vo.setDiagnosisScoreTrend(DiagnosisUtil.getDiagnosisScoreTrend(bill.getPreDiagnosisScore(), bill.getDiagnosisScore(), bill.getPreDiagnosisGrade(), bill.getDiagnosisGrade()));
- if (Objects.nonNull(bill.getDiagnosisScore())) {
- vo.setDiagnosisScore(bill.getDiagnosisScore().stripTrailingZeros().toPlainString());
- }
- RepalRemindReadInfo repalRemindReadInfo = repalRemindReadInfoService.getReadInfoByUserId(UserContextUtil.getUser().getUserId(), bill.getId(),bill.getRepalBookId());
- RepalBillRemindUnReadVO readVO = repalRemindHistoryService.getBillRemindUnReadVO(repalRemindReadInfo.getRiskRemindId(),
- repalRemindReadInfo.getRankRemindId(),repalRemindReadInfo.getOverdueRemindId(),
- repalRemindReadInfo.getFinanceRemindId(),bill.getRepalBookId(),bill.getId(),
- null, null);
- vo.setDynamicCountList(new ArrayList<Integer>(){{
- add(readVO.getUnreadRiskCount());
- add(readVO.getUnreadFinanceCount());
- add(readVO.getUnreadRankCount());
- add(readVO.getUnreadOverdueCount());
- }});
- return vo;
- }
- @Override
- public DiagnosisSectionVO getDiagnosisDynamic(Long repalBillId) {
- RepalBill repalBill = this.getById(repalBillId);
- if (Objects.isNull(repalBill)) {
- throw new CommonException(CodeMsg.FAILED, "账款id错误");
- }
- if (ObjectUtil.isAllEmpty(repalBill.getPreDiagnosisScore(), repalBill.getDiagnosisScore())) {
- LOGGER.error("没有账款评级");
- return null;
- }
- DiagnosisSectionVO vo = new DiagnosisSectionVO();
- BeanUtils.copyProperties(repalBill, vo);
- vo.setDiagnosisRecordId(repalBill.getDiagnosisId());
- vo.setDiagnosisGrade(repalBill.getDiagnosisGrade());
- vo.setDiagnosisScoreStr(Objects.nonNull(repalBill.getDiagnosisScore()) ? repalBill.getDiagnosisScore().stripTrailingZeros().toPlainString() : "");
- vo.setPreDiagnosisGrade(repalBill.getPreDiagnosisGrade());
- vo.setPreDiagnosisScoreStr(Objects.nonNull(repalBill.getPreDiagnosisScore()) ? repalBill.getPreDiagnosisScore().stripTrailingZeros().toPlainString() : "");
- RepalBillDiagnosis diagnosis = repalBillDiagnosisService.getById(repalBill.getDiagnosisId());
- if (Objects.nonNull(diagnosis)) {
- vo.setDiagnosisRecordId(diagnosis.getBizId());
- }
- QueryV8DynamicDTO dynamicDto = new QueryV8DynamicDTO();
- dynamicDto.setEntityNames(Collections.singletonList(repalBill.getCustomerName()));
- LocalDateTime startDateTime = Objects.isNull(repalBill.getPreDiagnosisDatetime()) ? repalBill.getTimeCreated() : repalBill.getPreDiagnosisDatetime();
- dynamicDto.setStartDate(startDateTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
- dynamicDto.setEndDate(repalBill.getDiagnosisDatetime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
- VOPage<V8DynamicVO> resultPage = companyService.queryDynamic(dynamicDto, 1, 10);
- if (Objects.isNull(resultPage) || CollUtil.isEmpty(resultPage.getDataList())) {
- DiagnosisDynamicVO dynamicVO = new DiagnosisDynamicVO();
- dynamicVO.setRtaDesc("该账款信息发生变动(欠款企业、金额有所调整)");
- dynamicVO.setCreateTime(repalBill.getTimeModified().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
- vo.setEsDynamics(Collections.singletonList(dynamicVO));
- return vo;
- }
- vo.setEsDynamics(resultPage.getDataList().stream().map(entity -> {
- DiagnosisDynamicVO diagnosisDynamicVO = new DiagnosisDynamicVO();
- diagnosisDynamicVO.setNewDynamicId(entity.getId());
- diagnosisDynamicVO.setRowKey(entity.getRowkey());
- diagnosisDynamicVO.setCreateTime(entity.getDynamicTime());
- String rtaDesc = DynamicEnum.getDescByTn(entity.getTn());
- rtaDesc = StrUtil.isBlank(rtaDesc) ? "新增动态": (rtaDesc.contains("新增") || rtaDesc.contains("移除")) ? rtaDesc : "新增"+rtaDesc;
- diagnosisDynamicVO.setRtaDesc(rtaDesc);
- diagnosisDynamicVO.setInfoType(entity.getInfoType());
- diagnosisDynamicVO.setTn(entity.getTn());
- diagnosisDynamicVO.setNewRemindContent(JSON.toJSONString(entity.getDynamicJSON()));
- diagnosisDynamicVO.setRouting(DynamicEnum.getRoutingByTn(entity.getTn()));
- return diagnosisDynamicVO;
- }).collect(Collectors.toList()));
- return vo;
- }
- }
|