package com.finance.system.service.impl;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.finance.common.basic.PageDTO;
|
import com.finance.common.core.domain.entity.SysUser;
|
import com.finance.common.exception.ServiceException;
|
import com.finance.common.utils.BeanUtils;
|
import com.finance.common.utils.CollUtils;
|
import com.finance.common.utils.DateUtils;
|
import com.finance.system.domain.TbBasicDataConfig;
|
import com.finance.system.domain.TbScore;
|
import com.finance.system.mapper.TbScoreMapper;
|
import com.finance.system.query.CalculateDetailQuery;
|
import com.finance.system.query.DeptCalculateDetailQuery;
|
import com.finance.system.query.HistoryScoreQuery;
|
import com.finance.system.query.ScoreCalculateDetailQuery;
|
import com.finance.system.query.ScoreQuery;
|
import com.finance.system.service.TbBasicDataConfigService;
|
import com.finance.system.service.TbScoreService;
|
import com.finance.system.vo.DeptCalculateDetailVO;
|
import com.finance.system.vo.RiskMapVO;
|
import com.finance.system.vo.RiskRankingVO;
|
import com.finance.system.vo.ScoreCalculateDetailVO;
|
import com.finance.system.vo.ScoreDetailVO;
|
import com.finance.system.vo.ScoreRankVO;
|
import com.finance.system.vo.ScoreVO;
|
import java.util.List;
|
import java.util.Objects;
|
import java.util.stream.Collectors;
|
import lombok.RequiredArgsConstructor;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.stereotype.Service;
|
|
/**
|
* <p>
|
* 得分表 服务实现类
|
* </p>
|
*
|
* @author mitao
|
* @since 2024-03-13
|
*/
|
@Slf4j
|
@Service
|
@RequiredArgsConstructor
|
public class TbScoreServiceImpl extends ServiceImpl<TbScoreMapper, TbScore> implements
|
TbScoreService {
|
|
private final TbBasicDataConfigService basicDataConfigService;
|
|
@Override
|
public Page<ScoreVO> pageScore(ScoreQuery query, Page<ScoreVO> page) {
|
return baseMapper.pageScore(query, page);
|
}
|
|
@Override
|
public PageDTO<ScoreVO> getHistoryScore(HistoryScoreQuery query) {
|
ScoreQuery scoreQuery = BeanUtils.copyBean(query, ScoreQuery.class);
|
Page<ScoreVO> scoreVOPage = baseMapper.pageScore(scoreQuery,
|
new Page<>(query.getPageNum(), query.getPageSize()));
|
return PageDTO.of(scoreVOPage);
|
}
|
|
@Override
|
public ScoreCalculateDetailVO scoreCalculateDetail(ScoreCalculateDetailQuery query)
|
throws Exception {
|
// 查询计算类型
|
TbBasicDataConfig config = basicDataConfigService.getById(query.getId());
|
if (Objects.isNull(config)) {
|
throw new ServiceException("非法参数");
|
}
|
ScoreCalculateDetailVO vo = new ScoreCalculateDetailVO();
|
vo.setTypeName(config.getTypeName());
|
vo.setCalculateType(config.getCalculateType());
|
Page<ScoreDetailVO> page = new Page<>(query.getPageNum(), query.getPageSize());
|
String previousQuarter = DateUtils.getPreviousQuarter();
|
previousQuarter = "2024年一季度";
|
query.setPreviousQuarter(previousQuarter);
|
Page<ScoreDetailVO> pageVO = baseMapper.scoreCalculateDetail(query, page);
|
vo.setTotal(pageVO.getTotal());
|
vo.setPages(pageVO.getPages());
|
vo.setList(pageVO.getRecords());
|
return vo;
|
}
|
|
@Override
|
public ScoreCalculateDetailVO scoreCalculateHistoryDetail(ScoreCalculateDetailQuery query)
|
throws Exception {
|
// 查询计算类型
|
TbBasicDataConfig config = basicDataConfigService.getById(query.getId());
|
if (Objects.isNull(config)) {
|
throw new ServiceException("非法参数");
|
}
|
ScoreCalculateDetailVO vo = new ScoreCalculateDetailVO();
|
vo.setTypeName(config.getTypeName());
|
vo.setCalculateType(config.getCalculateType());
|
Page<ScoreDetailVO> page = new Page<>(query.getPageNum(), query.getPageSize());
|
Page<ScoreDetailVO> pageVO = baseMapper.scoreCalculateDetail(query, page);
|
vo.setTotal(pageVO.getTotal());
|
vo.setPages(pageVO.getPages());
|
vo.setList(pageVO.getRecords());
|
return vo;
|
}
|
|
@Override
|
public List<ScoreRankVO> queryTotalScoreList() {
|
return baseMapper.queryTotalScoreList();
|
}
|
|
@Override
|
public ScoreRankVO queryRankAndScoreByAreaCode(String areaCode) throws Exception {
|
String previousQuarter = DateUtils.getPreviousQuarter();
|
previousQuarter = "2024年一季度";
|
List<ScoreRankVO> voList = baseMapper.queryRankAndScoreByAreaCode(areaCode,
|
previousQuarter);
|
if (CollUtils.isNotEmpty(voList)) {
|
for (int i = 0; i < voList.size(); i++) {
|
if (areaCode.equals(voList.get(i).getAreaCode())) {
|
voList.get(i).setRank(i + 1);
|
return voList.get(i);
|
}
|
}
|
}
|
return null;
|
}
|
|
@Override
|
public List<DeptCalculateDetailVO> deptCalculateDetail(DeptCalculateDetailQuery query,
|
String nowQuarter) {
|
return baseMapper.deptCalculateDetail(query, nowQuarter);
|
}
|
|
@Override
|
public ScoreCalculateDetailVO fieldsDetail(CalculateDetailQuery query,
|
List<SysUser> countyList) throws Exception {
|
// 查询计算类型
|
TbBasicDataConfig config = basicDataConfigService.getById(query.getId());
|
if (Objects.isNull(config)) {
|
throw new ServiceException("非法参数");
|
}
|
if (CollUtils.isEmpty(countyList)) {
|
return new ScoreCalculateDetailVO();
|
}
|
List<String> areaCodeList = countyList.stream().map(SysUser::getAreaCode).distinct()
|
.collect(Collectors.toList());
|
ScoreCalculateDetailVO vo = new ScoreCalculateDetailVO();
|
vo.setTypeName(config.getTypeName());
|
vo.setCalculateType(config.getCalculateType());
|
Page<ScoreDetailVO> page = new Page<>(query.getPageNum(), query.getPageSize());
|
String previousQuarter = DateUtils.getPreviousQuarter();
|
previousQuarter = "2023年一季度";
|
Page<ScoreDetailVO> pageVO = baseMapper.fieldsDetail(query, page, areaCodeList);
|
vo.setTotal(pageVO.getTotal());
|
vo.setPages(pageVO.getPages());
|
vo.setList(pageVO.getRecords());
|
return vo;
|
}
|
|
@Override
|
public List<RiskMapVO> getCurrentScoreList(String nowQuarter, String areaCode) {
|
return baseMapper.getCurrentScoreList(nowQuarter, areaCode);
|
}
|
|
@Override
|
public List<RiskRankingVO> queryRiskRanking(String nowQuarter) {
|
return baseMapper.queryRiskRanking(nowQuarter);
|
}
|
|
/**
|
* @param areaCode 区划代码
|
* @return
|
*/
|
@Override
|
public List<RiskMapVO> getScoreByYearType(String areaCode, String quarter) {
|
return baseMapper.getScoreByYearType(areaCode, quarter);
|
}
|
}
|