| | |
| | | import com.panzhihua.common.model.dtos.community.acid.BatchCheckAcidRecordDTO; |
| | | import com.panzhihua.common.model.dtos.community.acid.ComActAcidRecordDTO; |
| | | import com.panzhihua.common.model.vos.R; |
| | | import com.panzhihua.common.model.vos.community.StatisticsPhotoVO; |
| | | import com.panzhihua.common.model.vos.community.acid.*; |
| | | import com.panzhihua.common.service.user.UserService; |
| | | import com.panzhihua.common.utlis.DateUtils; |
| | |
| | | |
| | | import javax.annotation.Resource; |
| | | import java.math.BigDecimal; |
| | | import java.time.LocalDate; |
| | | import java.util.*; |
| | | import java.util.function.Function; |
| | | import java.util.stream.Collectors; |
| | |
| | | if (0!=all){ |
| | | BigDecimal countNum = new BigDecimal(comActAcidColorChartsVO.getCountNum()); |
| | | BigDecimal allDecimal = new BigDecimal(all); |
| | | BigDecimal percent = countNum.divide(allDecimal,2, BigDecimal.ROUND_HALF_DOWN); |
| | | BigDecimal percent = countNum.divide(allDecimal,4, BigDecimal.ROUND_HALF_DOWN).multiply(new BigDecimal(100)); |
| | | comActAcidColorChartsVO.setPercent(percent); |
| | | } |
| | | } |
| | |
| | | if (0L!=sum) { |
| | | BigDecimal countNum = new BigDecimal(comActAcidColorChartsVO.getCountNum()); |
| | | BigDecimal sumDecimal = new BigDecimal(sum); |
| | | BigDecimal percent = countNum.divide(sumDecimal, 2, BigDecimal.ROUND_HALF_DOWN); |
| | | BigDecimal percent = countNum.divide(sumDecimal, 4, BigDecimal.ROUND_HALF_DOWN).multiply(new BigDecimal(100)); |
| | | comActAcidColorChartsVO.setPercent(percent); |
| | | } |
| | | } |
| | | } |
| | | Map<String, Map<String, ComActAcidColorChartsVO>> chartMap = comActAcidColorChartsVOS1 |
| | | Map<String, Map<String, ComActAcidColorChartsVO>> colletMap = comActAcidColorChartsVOS1 |
| | | .stream() |
| | | .collect(Collectors.groupingBy(ComActAcidColorChartsVO::getCountName, |
| | | Collectors.toMap(ComActAcidColorChartsVO::getColorMark, Function.identity()))); |
| | | |
| | | String[] statusArr = {"红码","黄码","绿码"}; |
| | | List<String> latest5Month = DateUtils.getLatest12Month(LocalDate.now(), 5); |
| | | for (String month : latest5Month) { |
| | | Map<String, ComActAcidColorChartsVO> map1; |
| | | if(colletMap.containsKey(month)){ |
| | | map1 = colletMap.get(month); |
| | | }else { |
| | | map1 = new HashMap<>(); |
| | | } |
| | | for (String status : statusArr) { |
| | | if (!map1.containsKey(status)){ |
| | | ComActAcidColorChartsVO comActAcidColorChartsVO = new ComActAcidColorChartsVO(); |
| | | comActAcidColorChartsVO.setCountNum(0); |
| | | comActAcidColorChartsVO.setCountName(month); |
| | | comActAcidColorChartsVO.setColorMark(status); |
| | | comActAcidColorChartsVOS1.add(comActAcidColorChartsVO); |
| | | map1.put(status,comActAcidColorChartsVO); |
| | | } |
| | | } |
| | | colletMap.put(month,map1); |
| | | } |
| | | |
| | | |
| | | Map<String, List<ComActAcidColorChartsVO>> chartMap = comActAcidColorChartsVOS1 |
| | | .stream().sorted(Comparator.comparing(ComActAcidColorChartsVO::getCountName)) |
| | | .collect(Collectors.groupingBy(ComActAcidColorChartsVO::getColorMark)); |
| | | |
| | | Map<String,Object> retMap = new HashMap<>(); |
| | | retMap.put("comActAcidColorChartsVOS",comActAcidColorChartsVOS); |
| | | retMap.put("chartMap",chartMap); |