|
@ -46,9 +46,11 @@ import org.apache.poi.xssf.usermodel.XSSFWorkbook; |
|
|
import org.springframework.beans.BeanUtils; |
|
|
import org.springframework.beans.BeanUtils; |
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
import org.springframework.context.annotation.Bean; |
|
|
import org.springframework.context.annotation.Bean; |
|
|
|
|
|
import org.springframework.context.annotation.Lazy; |
|
|
import org.springframework.stereotype.Service; |
|
|
import org.springframework.stereotype.Service; |
|
|
import org.springframework.transaction.annotation.Transactional; |
|
|
import org.springframework.transaction.annotation.Transactional; |
|
|
import org.springframework.web.multipart.MultipartFile; |
|
|
import org.springframework.web.multipart.MultipartFile; |
|
|
|
|
|
import org.springframework.web.server.session.CookieWebSessionIdResolver; |
|
|
|
|
|
|
|
|
import javax.servlet.http.HttpServletResponse; |
|
|
import javax.servlet.http.HttpServletResponse; |
|
|
import java.io.IOException; |
|
|
import java.io.IOException; |
|
@ -60,6 +62,7 @@ import java.util.stream.Collectors; |
|
|
|
|
|
|
|
|
@Service |
|
|
@Service |
|
|
@Transactional |
|
|
@Transactional |
|
|
|
|
|
|
|
|
public class HuzhouProjectinfoServiceImpl extends ServiceImpl<HuzhouProjectinfoMapper, HuzhouProjectinfo> |
|
|
public class HuzhouProjectinfoServiceImpl extends ServiceImpl<HuzhouProjectinfoMapper, HuzhouProjectinfo> |
|
|
implements IHuzhouProjectinfoService { |
|
|
implements IHuzhouProjectinfoService { |
|
|
@Autowired |
|
|
@Autowired |
|
@ -86,9 +89,17 @@ public class HuzhouProjectinfoServiceImpl extends ServiceImpl<HuzhouProjectinfoM |
|
|
@Autowired |
|
|
@Autowired |
|
|
private IHuzhouUploadfileinfoService uploadfileinfoService; |
|
|
private IHuzhouUploadfileinfoService uploadfileinfoService; |
|
|
|
|
|
|
|
|
@Autowired IHuzhouPlaninfoService planinfoService; |
|
|
@Autowired |
|
|
|
|
|
@Lazy |
|
|
|
|
|
IHuzhouSubProjectinfoService subProjectinfoService; |
|
|
|
|
|
|
|
|
@Autowired IHuzhouContractinfoService contractinfoService; |
|
|
@Autowired |
|
|
|
|
|
@Lazy |
|
|
|
|
|
IHuzhouPlaninfoService planinfoService; |
|
|
|
|
|
|
|
|
|
|
|
@Autowired |
|
|
|
|
|
@Lazy |
|
|
|
|
|
IHuzhouContractinfoService contractinfoService; |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
|
|
|
|
|
@ -499,12 +510,10 @@ public class HuzhouProjectinfoServiceImpl extends ServiceImpl<HuzhouProjectinfoM |
|
|
// }
|
|
|
// }
|
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public ProjectProgressOV countProjectProgress() { |
|
|
public Map<String,List<String>> findAllProjectIds() { |
|
|
//1、查询所有项目
|
|
|
HuzhouProjectinfo projectInfo =new HuzhouProjectinfo(); |
|
|
//2、查询所有项目对应的计划阶段
|
|
|
projectInfo.setStage("0"); |
|
|
HuzhouProjectinfo projectinfo =new HuzhouProjectinfo(); |
|
|
ProjectInfoAuthSelect projectInfoAuthSelect = CommonUtils.setGetProjectInfoAuth(projectInfo); |
|
|
projectinfo.setStage("0"); |
|
|
|
|
|
ProjectInfoAuthSelect projectInfoAuthSelect = CommonUtils.setGetProjectInfoAuth(projectinfo); |
|
|
|
|
|
List<HuzhouProjectinfoOV> projectAndChildInfoPageList = projectinfoMapper.getProjectAndChildInfoPageList(projectInfoAuthSelect); |
|
|
List<HuzhouProjectinfoOV> projectAndChildInfoPageList = projectinfoMapper.getProjectAndChildInfoPageList(projectInfoAuthSelect); |
|
|
List<String> zIds = projectAndChildInfoPageList.stream().map(x -> x.getId()).collect(Collectors.toList()); |
|
|
List<String> zIds = projectAndChildInfoPageList.stream().map(x -> x.getId()).collect(Collectors.toList()); |
|
|
List<String> cIds = new ArrayList<>(); |
|
|
List<String> cIds = new ArrayList<>(); |
|
@ -515,40 +524,119 @@ public class HuzhouProjectinfoServiceImpl extends ServiceImpl<HuzhouProjectinfoM |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
zIds.addAll(cIds); |
|
|
Map<String, List<String>> result = new HashMap<>(); |
|
|
List<HuzhouPlaninfo> planInfoList = planinfoService.ListByProjectIds(zIds); |
|
|
result.put("zxm",zIds); |
|
|
int fininshNum = (int) planInfoList.stream().filter(x -> (x.getIsfinish().equals("2"))).count(); |
|
|
result.put("cxm",cIds); |
|
|
int unfininshNum=planInfoList.size()-fininshNum; |
|
|
|
|
|
ProjectProgressOV result = ProjectProgressOV.builder().fininshNum(fininshNum).unfininshNum(unfininshNum).build(); |
|
|
|
|
|
return result; |
|
|
return result; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public FundOV countFund() { |
|
|
public BigDecimal totalMoneyByProjectIds(Map<String,List<String>> projectIds) { |
|
|
//1、根据项目ids查合同支付总金额
|
|
|
|
|
|
//2、遍历每个合同,取支付阶段汇成列表
|
|
|
LambdaQueryWrapper<HuzhouProjectinfo> query = new LambdaQueryWrapper<>(new HuzhouProjectinfo()) |
|
|
//3、根据项目ids查所有计划
|
|
|
.in(HuzhouProjectinfo::getId,projectIds.get("zxm")) |
|
|
//4、
|
|
|
.select(HuzhouProjectinfo::getId,HuzhouProjectinfo::getTotalMoney); |
|
|
return null; |
|
|
List<HuzhouProjectinfo> projectInfoList=projectinfoMapper.selectList(query); |
|
|
|
|
|
BigDecimal zxmTotal = new BigDecimal(Double.toString(projectInfoList.stream().mapToDouble(x -> x.getTotalMoney()).sum())); |
|
|
|
|
|
|
|
|
|
|
|
LambdaQueryWrapper<HuzhouSubProjectinfo> cquery = new LambdaQueryWrapper<>(new HuzhouSubProjectinfo()) |
|
|
|
|
|
.in(HuzhouSubProjectinfo::getId,projectIds.get("cxm")) |
|
|
|
|
|
.select(HuzhouSubProjectinfo::getId,HuzhouSubProjectinfo::getTotalMoney); |
|
|
|
|
|
List<HuzhouSubProjectinfo> subProjectInfoList=subProjectinfoMapper.selectList(cquery); |
|
|
|
|
|
BigDecimal cxmTotal = new BigDecimal(Double.toString(subProjectInfoList.stream().mapToDouble(x -> x.getTotalMoney()).sum())); |
|
|
|
|
|
BigDecimal result = zxmTotal.add(cxmTotal); |
|
|
|
|
|
return result; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public ProjectStatusOV countProjectStatus() { |
|
|
public ProjectProgressOV countProjectProgress() { |
|
|
return null; |
|
|
//1、查询所有项目
|
|
|
|
|
|
//2、查询所有项目对应的计划阶段
|
|
|
|
|
|
Map<String, List<String>> projectIdsMap = this.findAllProjectIds(); |
|
|
|
|
|
List<String> projectIdsList = projectIdsMap.get("zxm"); |
|
|
|
|
|
projectIdsList.addAll(projectIdsMap.get("cxm")); |
|
|
|
|
|
List<HuzhouPlaninfo> planInfoList = planinfoService.listByProjectIds(projectIdsList); |
|
|
|
|
|
int fininshNum = (int) planInfoList.stream().filter(x -> (x.getIsfinish().equals("2"))).count(); |
|
|
|
|
|
int unfininshNum=planInfoList.size()-fininshNum; |
|
|
|
|
|
ProjectProgressOV result = ProjectProgressOV.builder().fininshNum(fininshNum).unfininshNum(unfininshNum).build(); |
|
|
|
|
|
return result; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public ReformTasksProgressOV countReformTasksProgress() { |
|
|
public FundOV countFund() { |
|
|
return null; |
|
|
Map<String, List<String>> projectIdsMap = this.findAllProjectIds(); |
|
|
|
|
|
List<String> projectIdsList = projectIdsMap.get("zxm"); |
|
|
|
|
|
projectIdsList.addAll(projectIdsMap.get("cxm")); |
|
|
|
|
|
List<HuzhouContractinfo> contractInfoList = contractinfoService.ListByProjectIds(projectIdsList); |
|
|
|
|
|
List<HuzhouPlaninfo> planInfoList = planinfoService.listByProjectIds(projectIdsList); |
|
|
|
|
|
BigDecimal payAmount = new BigDecimal("0.00"); |
|
|
|
|
|
Map<String, Double> contractMoneyMap; |
|
|
|
|
|
List<String> finishPlanTaskList; |
|
|
|
|
|
for(String projectId:projectIdsList){ |
|
|
|
|
|
contractMoneyMap = contractInfoList.stream().filter(x -> x.getProjectId().equals(projectId)) |
|
|
|
|
|
.collect(Collectors.toMap(HuzhouContractinfo::getTaskName, HuzhouContractinfo::getTotalMoney)); |
|
|
|
|
|
finishPlanTaskList = planInfoList.stream().filter(x->x.getProjectId().equals(projectId)) |
|
|
|
|
|
.filter(x->x.getIsfinish().equals("2")).map(x->x.getTaskName()).collect(Collectors.toList()); |
|
|
|
|
|
for(String key:contractMoneyMap.keySet()){ |
|
|
|
|
|
if(finishPlanTaskList.contains(key)){ |
|
|
|
|
|
payAmount=payAmount.add(new BigDecimal(Double.toString(contractMoneyMap.get(key)))); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
//根据projectIds累加总金额
|
|
|
|
|
|
BigDecimal totalAmount = this.totalMoneyByProjectIds(projectIdsMap); |
|
|
|
|
|
BigDecimal unPayAmount = totalAmount.subtract(payAmount); |
|
|
|
|
|
FundOV result = FundOV.builder().fininshNum(payAmount.toString()).unfininshNum(unPayAmount.toString()).build(); |
|
|
|
|
|
return result; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public AdministrativeAreaProgressOV countAdministrativeAreaProgress() { |
|
|
public CountOV countByProperties() { |
|
|
return null; |
|
|
Map<String, List<String>> projectIdsMap = this.findAllProjectIds(); |
|
|
|
|
|
List<String> zxmIds = projectIdsMap.get("zxm"); |
|
|
|
|
|
List<String> cxmIds = projectIdsMap.get("cxm"); |
|
|
|
|
|
List<HuzhouProjectinfo> projectInfoList = projectinfoMapper.selectBatchIds(zxmIds); |
|
|
|
|
|
List<HuzhouSubProjectinfo> cProjectinfoList = subProjectinfoService.listByProjectIds(cxmIds); |
|
|
|
|
|
projectInfoList.addAll(cProjectinfoList); |
|
|
|
|
|
//根据项目状态统计
|
|
|
|
|
|
List<ProjectStatusOV> projectStatusList= new ArrayList<>(); |
|
|
|
|
|
Map<String, List<HuzhouProjectinfo>> statusCountMap = projectInfoList.stream().collect(Collectors.groupingBy(x -> x.getStage())); |
|
|
|
|
|
for(String key:statusCountMap.keySet()){ |
|
|
|
|
|
projectStatusList.add(ProjectStatusOV.builder().name(key).value(statusCountMap.get(key).size()).build()); |
|
|
|
|
|
} |
|
|
|
|
|
//根据所属改革任务统计(阶段完成情况)
|
|
|
|
|
|
List<CommonCountOV> projectByReformList= new ArrayList<>(); |
|
|
|
|
|
Map<String, List<HuzhouProjectinfo>> reformCountMap = projectInfoList.stream().collect(Collectors.groupingBy(x -> x.getReformName().trim())); |
|
|
|
|
|
for (String key:reformCountMap.keySet()){ |
|
|
|
|
|
List<String> keyProjectIdsList = reformCountMap.get(key).stream().map(x -> x.getId()).collect(Collectors.toList()); |
|
|
|
|
|
Map<String, Integer> countMap = planinfoService.conutCompletionStatus(keyProjectIdsList); |
|
|
|
|
|
projectByReformList.add(CommonCountOV.builder().name(key).fininshNum(countMap.get("fininshNum")).unfininshNum(countMap.get("unfininshNum")).build()); |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
//根据行政区统计
|
|
|
|
|
|
List<CommonCountOV> projectByRegionList= new ArrayList<>(); |
|
|
|
|
|
Map<String, List<HuzhouProjectinfo>> regionCountMap = projectInfoList.stream().collect(Collectors.groupingBy(x -> x.getAdminDivision().trim())); |
|
|
|
|
|
for (String key:regionCountMap.keySet()){ |
|
|
|
|
|
List<String> keyProjectIdsList = regionCountMap.get(key).stream().map(x -> x.getId()).collect(Collectors.toList()); |
|
|
|
|
|
Map<String, Integer> countMap = planinfoService.conutCompletionStatus(keyProjectIdsList); |
|
|
|
|
|
projectByRegionList.add(CommonCountOV.builder().name(key).fininshNum(countMap.get("fininshNum")).unfininshNum(countMap.get("unfininshNum")).build()); |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
//根据单位统计
|
|
|
|
|
|
List<CommonCountOV> projectByWorkplaceList= new ArrayList<>(); |
|
|
|
|
|
Map<String, List<HuzhouProjectinfo>> workplaceCountMap = projectInfoList.stream().collect(Collectors.groupingBy(x -> x.getWorkplaceProperties().trim())); |
|
|
|
|
|
for (String key:workplaceCountMap.keySet()){ |
|
|
|
|
|
List<String> keyProjectIdsList = workplaceCountMap.get(key).stream().map(x -> x.getId()).collect(Collectors.toList()); |
|
|
|
|
|
Map<String, Integer> countMap = planinfoService.conutCompletionStatus(keyProjectIdsList); |
|
|
|
|
|
projectByWorkplaceList.add(CommonCountOV.builder().name(key).fininshNum(countMap.get("fininshNum")).unfininshNum(countMap.get("unfininshNum")).build()); |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
ProjectProgressOV projectProgress = countProjectProgress(); |
|
|
|
|
|
FundOV fund = countFund(); |
|
|
|
|
|
CountOV result = CountOV.builder().xiangmZJD(projectProgress).xiangmuZJ(fund) |
|
|
|
|
|
.xiangmuZT(projectStatusList).XXQY(projectByRegionList).SSGGRW(projectByReformList).DWSX(projectByWorkplaceList).build(); |
|
|
|
|
|
return result; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
public UnitAttributesProgressOV UnitAttributesProgress() { |
|
|
|
|
|
return null; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|