From cd24a045bd9ee29505ddc9760d25f5d4037f4f0c Mon Sep 17 00:00:00 2001 From: fuliqi <fuliqi@qq.com> Date: 星期四, 05 九月 2024 21:55:28 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java | 167 +++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 148 insertions(+), 19 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java index 49f85e4..1294a76 100644 --- a/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java +++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java @@ -2,15 +2,15 @@ import annotation.DataScope; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ycl.platform.base.CheckIndex; +import com.ycl.platform.domain.dto.CheckResultExportDTO; import com.ycl.platform.domain.dto.CheckScoreDTO; import com.ycl.platform.domain.dto.CheckScoreIndexDTO; import com.ycl.platform.domain.dto.ScoreIndexDTO; import com.ycl.platform.domain.entity.*; -import com.ycl.platform.domain.vo.CheckIndexCarVO; -import com.ycl.platform.domain.vo.CheckIndexFaceVO; -import com.ycl.platform.domain.vo.CheckIndexVideoVO; -import com.ycl.platform.domain.vo.CheckScoreDetailVO; +import com.ycl.platform.domain.vo.*; import com.ycl.platform.mapper.CheckRuleMapper; import com.ycl.platform.mapper.CheckScoreMapper; import com.ycl.platform.mapper.CheckTemplateMapper; @@ -19,6 +19,7 @@ import com.ycl.platform.service.ICheckIndexFaceService; import com.ycl.platform.service.ICheckIndexVideoService; import com.ycl.platform.service.ICheckScoreService; +import com.ycl.system.entity.BaseEntity; import com.ycl.system.entity.SysRole; import com.ycl.system.entity.SysUser; import com.ycl.system.service.ISysDeptService; @@ -31,14 +32,18 @@ import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; import pojo.ExcelExp; import utils.poi.ExcelUtilManySheet; import java.io.IOException; +import java.math.BigDecimal; +import java.math.RoundingMode; import java.text.SimpleDateFormat; import java.time.LocalDateTime; import java.util.*; +import java.util.function.Function; import java.util.stream.Collectors; /** @@ -67,6 +72,7 @@ @Autowired private ISysDeptService deptService; + /** * 鏌ヨ鑰冩牳绉垎鎸囨爣 * @@ -84,10 +90,10 @@ Integer templateId = 0; //鏂逛究鍒囨崲鏀逛负锛氭牴鎹畇core鑰冩牳绫诲埆鍜宒to鑰冩牳鏍囩鏌ユā鏉胯鍒欏拰鏉冮噸,娉ㄦ剰鍚岀绫诲悓鏍囩鍙兘鏈変竴涓ā鏉� QueryWrapper<CheckTemplate> wrapper = new QueryWrapper<>(); - wrapper.eq("examine_tag",checkScoreIndexDTO.getExamineTag()); - wrapper.eq("examine_category",checkScore.getExamineCategory()); + wrapper.eq("examine_tag", checkScoreIndexDTO.getExamineTag()); + wrapper.eq("examine_category", checkScore.getExamineCategory()); Optional<CheckTemplate> first = templateMapper.selectList(wrapper).stream().findFirst(); - if(first.isPresent()){ + if (first.isPresent()) { CheckTemplate checkTemplate = first.get(); templateId = checkTemplate.getId(); } @@ -122,6 +128,8 @@ scoreIndexDTO.setDate(formatter.format(createTime)); } + //鏉冮檺鎺у埗 + roleControl(scoreIndexDTO); List<Map> map = scoreMapper.selectScoreIndex(scoreIndexDTO); scoreMap.put("tableData", checkRules); @@ -233,6 +241,7 @@ * @return 缁撴灉 */ @Override + @Transactional(rollbackFor = Exception.class) public int publishCheckScore(CheckScoreDTO checkScoreDTO) { if (CollectionUtils.isEmpty(checkScoreDTO.getId())) { return 0; @@ -245,8 +254,33 @@ } String code = publishType.getCode(); checkScoreDTO.setPublish(code); - - return scoreMapper.publishCheckScore(checkScoreDTO); + int i = scoreMapper.publishCheckScore(checkScoreDTO); + //鎺у埗index琛ㄧ殑鍙戝竷鐘舵�� + List<Integer> ids = checkScoreDTO.getId(); + QueryWrapper<CheckScore> queryWrapper = new QueryWrapper<>(); + queryWrapper.in("id", ids); + List<CheckScore> scoreList = scoreMapper.selectList(queryWrapper); + //鏈�澶氫负3娆″惊鐜� + for (CheckScore checkScore : scoreList) { + Short examineCategory = checkScore.getExamineCategory(); + if (CheckConstants.Rule_Category_Video.equals(examineCategory)) { + UpdateWrapper<CheckIndexVideo> updateWrapper = new UpdateWrapper<>(); + updateWrapper.set("publish", code); + updateWrapper.eq("id", checkScore.getIndexId()); + indexVideoService.update(updateWrapper); + } else if (CheckConstants.Rule_Category_Car.equals(examineCategory)) { + UpdateWrapper<CheckIndexCar> updateWrapper = new UpdateWrapper<>(); + updateWrapper.set("publish", code); + updateWrapper.eq("id", checkScore.getIndexId()); + indexCarService.update(updateWrapper); + } else if (CheckConstants.Rule_Category_Face.equals(examineCategory)) { + UpdateWrapper<CheckIndexFace> updateWrapper = new UpdateWrapper<>(); + updateWrapper.set("publish", code); + updateWrapper.eq("id", checkScore.getIndexId()); + indexFaceService.update(updateWrapper); + } + } + return i; } /** @@ -256,22 +290,47 @@ * @return 鑰冩牳绉垎 */ @Override - public void exportIndex(HttpServletResponse response, CheckScore checkScoreDTO) throws IOException { - String date = checkScoreDTO.getDate(); + public void exportIndex(HttpServletResponse response, CheckResultExportDTO exportDTO) throws IOException { + String date = exportDTO.getDate(); //濡傛灉璇锋眰鍙傛暟鏃堕棿涓虹┖锛屾煡杩欐潯璁板綍鐨勬椂闂� - if (StringUtils.isEmpty(checkScoreDTO.getDate()) && CollectionUtils.isEmpty(checkScoreDTO.getQuarter())) { - CheckScore checkScore = getById(checkScoreDTO.getId()); - Date createTime = checkScore.getCreateTime(); + if (StringUtils.isEmpty(exportDTO.getDate()) && CollectionUtils.isEmpty(exportDTO.getQuarter())) { SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM"); - date = formatter.format(createTime); + if (exportDTO.getId() != null) { + CheckScore checkScore = getById(exportDTO.getId()); + Date createTime = checkScore.getCreateTime(); + date = formatter.format(createTime); + } else { + //闃叉鍗$墖椤甸潰瀵煎嚭涓嶄紶scoreId锛屽鑷存姤閿� + date = formatter.format(new Date()); + } } /** 瀵间笁寮爏heet */ //杞﹁締 CheckIndexCar checkIndexCar = new CheckIndexCar(); checkIndexCar.setDate(date); - checkIndexCar.setQuarter(checkScoreDTO.getQuarter()); + checkIndexCar.setQuarter(exportDTO.getQuarter()); + checkIndexCar.setDeptId(exportDTO.getDeptId()); + checkIndexCar.setDeptIds(exportDTO.getDeptIds()); + checkIndexCar.setExamineTags(exportDTO.getExamineTags()); + //鏉冮檺鎺у埗 鍙兘鏌ョ湅宸插彂甯� + roleControl(checkIndexCar); List<CheckIndexCar> checkIndexCars = indexCarService.selectCheckIndexCarList(checkIndexCar); + //璁$畻骞冲潎鍊兼斁鍦╡xcel鏈�鍚� + if (exportDTO.getAverage() && !CollectionUtils.isEmpty(checkIndexCars)) { + //鍏堝尯鍒嗗悇涓尯鍘匡紝鍐嶅尯鍒嗚�冩牳鏍囩 + Map<Long, List<CheckIndexCar>> carMap = checkIndexCars.stream().collect(Collectors.groupingBy(CheckIndexCar::getDeptId)); + carMap.forEach((deptId,list)->{ + List<CheckIndexCar> provinceList = list.stream().filter(car -> CheckConstants.Examine_Tag_Province.equals(car.getExamineTag())).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(provinceList)) { + checkIndexCars.add(CheckIndexCar.calculateAverage(provinceList)); + } + List<CheckIndexCar> countyList = list.stream().filter(car -> CheckConstants.Examine_Tag_County.equals(car.getExamineTag())).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(countyList)) { + checkIndexCars.add(CheckIndexCar.calculateAverage(countyList)); + } + }); + } List<CheckIndexCarVO> checkIndexCarVOS = new ArrayList<>(); for (CheckIndexCar indexCar : checkIndexCars) { CheckIndexCarVO excelVo = CheckIndexCar.getExcelVo(indexCar); @@ -281,8 +340,28 @@ //浜鸿劯 CheckIndexFace checkIndexFace = new CheckIndexFace(); checkIndexFace.setDate(date); - checkIndexFace.setQuarter(checkScoreDTO.getQuarter()); + checkIndexFace.setQuarter(exportDTO.getQuarter()); + checkIndexFace.setDeptId(exportDTO.getDeptId()); + checkIndexFace.setDeptIds(exportDTO.getDeptIds()); + checkIndexFace.setExamineTags(exportDTO.getExamineTags()); + //鏉冮檺鎺у埗 鍙兘鏌ョ湅宸插彂甯� + roleControl(checkIndexFace); List<CheckIndexFace> checkIndexFaces = indexFaceService.selectCheckIndexFaceList(checkIndexFace); + //璁$畻骞冲潎鍊兼斁鍦╡xcel鏈�鍚� + if (exportDTO.getAverage() && !CollectionUtils.isEmpty(checkIndexFaces)) { + //鍏堝尯鍒嗗悇涓尯鍘匡紝鍐嶅尯鍒嗚�冩牳鏍囩 + Map<Long, List<CheckIndexFace>> faceMap = checkIndexFaces.stream().collect(Collectors.groupingBy(CheckIndexFace::getDeptId)); + faceMap.forEach((deptId,list)->{ + List<CheckIndexFace> provinceList = list.stream().filter(face -> CheckConstants.Examine_Tag_Province.equals(face.getExamineTag())).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(provinceList)) { + checkIndexFaces.add(CheckIndexFace.calculateAverage(provinceList)); + } + List<CheckIndexFace> countyList = list.stream().filter(face -> CheckConstants.Examine_Tag_County.equals(face.getExamineTag())).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(countyList)) { + checkIndexFaces.add(CheckIndexFace.calculateAverage(countyList)); + } + }); + } List<CheckIndexFaceVO> checkIndexFaceVOS = new ArrayList<>(); for (CheckIndexFace indexFace : checkIndexFaces) { CheckIndexFaceVO excelVo = CheckIndexFace.getExcelVo(indexFace); @@ -292,8 +371,28 @@ //瑙嗛 CheckIndexVideo checkIndexVideo = new CheckIndexVideo(); checkIndexVideo.setDate(date); - checkIndexVideo.setQuarter(checkScoreDTO.getQuarter()); + checkIndexVideo.setQuarter(exportDTO.getQuarter()); + checkIndexVideo.setDeptId(exportDTO.getDeptId()); + checkIndexVideo.setDeptIds(exportDTO.getDeptIds()); + checkIndexVideo.setExamineTags(exportDTO.getExamineTags()); + //鏉冮檺鎺у埗 鍙兘鏌ョ湅宸插彂甯� + roleControl(checkIndexVideo); List<CheckIndexVideo> checkIndexVideos = indexVideoService.selectCheckIndexVideoList(checkIndexVideo); + //璁$畻骞冲潎鍊兼斁鍦╡xcel鏈�鍚� + if (exportDTO.getAverage() && !CollectionUtils.isEmpty(checkIndexVideos)) { + //鍏堝尯鍒嗗悇涓尯鍘匡紝鍐嶅尯鍒嗚�冩牳鏍囩 + Map<Long, List<CheckIndexVideo>> videoMap = checkIndexVideos.stream().collect(Collectors.groupingBy(CheckIndexVideo::getDeptId)); + videoMap.forEach((deptId,list)->{ + List<CheckIndexVideo> provinceList = list.stream().filter(video -> CheckConstants.Examine_Tag_Province.equals(video.getExamineTag())).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(provinceList)) { + checkIndexVideos.add(CheckIndexVideo.calculateAverage(provinceList)); + } + List<CheckIndexVideo> countyList = list.stream().filter(video -> CheckConstants.Examine_Tag_County.equals(video.getExamineTag())).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(countyList)) { + checkIndexVideos.add(CheckIndexVideo.calculateAverage(countyList)); + } + }); + } List<CheckIndexVideoVO> checkIndexVideoVOS = new ArrayList<>(); for (CheckIndexVideo indexVideo : checkIndexVideos) { CheckIndexVideoVO excelVo = CheckIndexVideo.getExcelVo(indexVideo); @@ -305,12 +404,42 @@ mysheet.add(e1); mysheet.add(e2); mysheet.add(e3); + //瑙勫垯鏄庣粏 + List<RuleExcelVO> allRuleTemplate = templateRuleMapper.getAllRuleTemplate(); + //鏁村悎鏁版嵁 + List<RuleExcelVO> countyRuleList = allRuleTemplate.stream().filter(vo -> vo.getExamineTag().equals(Integer.parseInt(CheckConstants.Examine_Tag_County + ""))).collect(Collectors.toList()); + List<RuleExcelVO> provinceRuleList = allRuleTemplate.stream().filter(vo -> vo.getExamineTag().equals(Integer.parseInt(CheckConstants.Examine_Tag_Province + ""))).collect(Collectors.toList()); + //鐢ㄥ尯鍘胯鍒欏仛涓讳綋灞曠ず + for (RuleExcelVO countyRule : countyRuleList) { + countyRule.setCountyWeight(countyRule.getWeight()); + //绛涢�夊悓绉嶈鍒欐潈閲� + for (RuleExcelVO provinceRule : provinceRuleList) { + if (provinceRule.getRuleId().equals(countyRule.getRuleId()) && provinceRule.getExamineCategory().equals(countyRule.getExamineCategory())) { + countyRule.setProvinceWeight(provinceRule.getWeight()); + } + } + } + ExcelExp e4 = new ExcelExp("瑙勫垯鏄庣粏", countyRuleList, RuleExcelVO.class); + mysheet.add(e4); ExcelUtilManySheet<List<ExcelExp>> util = new ExcelUtilManySheet<>(mysheet); util.exportExcelManySheet(response, mysheet); } - private void roleControl(CheckScore checkScore) { + private void roleControl(CheckIndex checkIndex) { + List<SysRole> roles = SecurityUtils.getLoginUser().getUser().getRoles(); + SysUser user = SecurityUtils.getLoginUser().getUser(); + if (!user.isAdmin()) { + for (SysRole role : roles) { + if (role.getPermissions().contains("check:score:role:publish")) { + Map<String, Object> params = checkIndex.getParams(); + params.put("publish", PublishType.PUBLISHED.getCode()); + } + } + } + } + + private void roleControl(BaseEntity checkScore) { List<SysRole> roles = SecurityUtils.getLoginUser().getUser().getRoles(); SysUser user = SecurityUtils.getLoginUser().getUser(); if (!user.isAdmin()) { -- Gitblit v1.8.0