From 24f2e1047e0260915ce6e401ec36763974531eed Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Thu, 27 Jun 2024 10:15:23 +0800
Subject: [PATCH] 积木报表+业主大会统计

---
 src/main/java/org/springblade/modules/discuss/service/impl/PublicDiscussServiceImpl.java |  130 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 130 insertions(+), 0 deletions(-)

diff --git a/src/main/java/org/springblade/modules/discuss/service/impl/PublicDiscussServiceImpl.java b/src/main/java/org/springblade/modules/discuss/service/impl/PublicDiscussServiceImpl.java
index aa99403..52b9ac7 100644
--- a/src/main/java/org/springblade/modules/discuss/service/impl/PublicDiscussServiceImpl.java
+++ b/src/main/java/org/springblade/modules/discuss/service/impl/PublicDiscussServiceImpl.java
@@ -19,25 +19,39 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.xxl.job.core.util.DateUtil;
 import org.springblade.common.constant.CommonConstant;
 import org.springblade.common.utils.SpringUtils;
 import org.springblade.core.mp.support.Condition;
 import org.springblade.core.mp.support.Query;
 import org.springblade.core.secure.utils.AuthUtil;
+import org.springblade.core.tool.utils.Func;
+import org.springblade.modules.article.entity.Article;
+import org.springblade.modules.article.service.ArticleService;
+import org.springblade.modules.discuss.dto.TopicsDTO;
 import org.springblade.modules.discuss.entity.PublicDiscussEntity;
 import org.springblade.modules.discuss.entity.UserTopicsEntity;
 import org.springblade.modules.discuss.mapper.PublicDiscussMapper;
 import org.springblade.modules.discuss.service.IPublicDiscussService;
+import org.springblade.modules.discuss.service.ITopicsService;
 import org.springblade.modules.discuss.service.IUserPublicEnrollService;
 import org.springblade.modules.discuss.service.IUserTopicsService;
 import org.springblade.modules.discuss.vo.PublicDiscussVO;
 import org.springblade.modules.discuss.vo.UserTopicsVO;
+import org.springblade.modules.district.entity.DistrictEntity;
+import org.springblade.modules.district.service.IDistrictService;
 import org.springblade.modules.house.entity.HouseholdEntity;
+import org.springblade.modules.house.service.IHouseService;
 import org.springblade.modules.house.service.IHouseholdService;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.util.Comparator;
+import java.util.Date;
 import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
 
 /**
  * 公益报名与议事 服务实现类
@@ -113,4 +127,120 @@
 		}
 		return publicDiscussVO;
 	}
+
+	@Override
+	public Map<String, Object> GetPublicDiscussTotal(PublicDiscussVO publicDiscuss) {
+		// 参与房屋投票的总数
+		IDistrictService districtService = SpringUtils.getBean(IDistrictService.class);
+		// 获取文章信息
+		PublicDiscussEntity discussEntity = getOne(Wrappers.<PublicDiscussEntity>lambdaQuery().eq(PublicDiscussEntity::getArticleId, publicDiscuss.getArticleId()));
+		ArticleService articleService = SpringUtils.getBean(ArticleService.class);
+		Article serviceOne = articleService.getOne(Wrappers.<Article>lambdaQuery().eq(Article::getId, publicDiscuss.getArticleId()));
+		String articleRange = serviceOne.getArticleRange();
+		List<String> strings = Func.toStrList(articleRange);
+		// 获取小区信息
+		List<DistrictEntity> list = districtService.list(Wrappers.<DistrictEntity>lambdaQuery()
+			.in(DistrictEntity::getId, strings));
+		List<String> aoiCodeList = list.stream().map(districtEntity -> districtEntity.getAoiCode()).collect(Collectors.toList());
+
+		IHouseService iHouseService = SpringUtils.getBean(IHouseService.class);
+		// 获取小区房屋总数和面积
+		Map<String, Object> buildingAreaStatistics = iHouseService.getHoseTotalAndAreaTotalByDistrictCode(aoiCodeList);
+		// 获取投票数量和面积
+		IUserTopicsService userTopicsService = SpringUtils.getBean(IUserTopicsService.class);
+		Map<String, Object> userTopicsTotal = userTopicsService.getUserTopicsTotal(discussEntity.getArticleId());
+		// 投票详情统计
+		ITopicsService iTopicsService = SpringUtils.getBean(ITopicsService.class);
+		List<TopicsDTO> userTopicsTotalByArticleId = iTopicsService.getTopicsTotalByArticleId(discussEntity.getArticleId());
+		// 已投票房屋面积
+		BigDecimal areaCount = (BigDecimal) userTopicsTotal.get("area");
+		// 已投票房屋数量
+		BigDecimal numberCount = BigDecimal.valueOf((Long) userTopicsTotal.get("number"));
+		// 总房屋数量
+		BigDecimal houseCount = BigDecimal.valueOf((Long) buildingAreaStatistics.get("houseCount"));
+		// 总房屋面积
+		BigDecimal houseAreaCount = (BigDecimal) buildingAreaStatistics.get("houseArea");
+
+		// 已完成房屋投票数量占比
+		if (houseCount.compareTo(BigDecimal.ZERO) > 0) {
+			BigDecimal divide = numberCount.divide(houseCount, 4, BigDecimal.ROUND_HALF_UP);
+			// 将结果乘以100得到百分比形式,然后设置为2位小数
+			// 这里保持了原有的功能和精度要求
+			userTopicsTotal.put("houseProportion", divide.multiply(BigDecimal.valueOf(100)).setScale(2));
+		}
+		if (houseAreaCount.compareTo(BigDecimal.ZERO) > 0) {
+			// 已完成房屋投票面积占比
+			BigDecimal divide1 = areaCount.divide(houseAreaCount, 4, BigDecimal.ROUND_HALF_UP);
+			// 将结果乘以100得到百分比形式,然后设置为2位小数
+			// 这里保持了原有的功能和精度要求
+			userTopicsTotal.put("areaProportion", divide1.multiply(BigDecimal.valueOf(100)).setScale(2));
+		}
+		buildingAreaStatistics.putAll(userTopicsTotal);
+		// 设置小区名称
+		StringBuffer stringBuffer = new StringBuffer();
+		for (DistrictEntity districtEntity : list) {
+			if (stringBuffer.length() > 0) {
+				stringBuffer.append(",");
+			}
+			stringBuffer.append(districtEntity.getName());
+		}
+		buildingAreaStatistics.put("districtName", stringBuffer.toString());
+		// 设置当前时间并且格式化时间
+		buildingAreaStatistics.put("time", DateUtil.format(new Date(), "yyyy-MM-dd"));
+		return buildingAreaStatistics;
+	}
+
+	@Override
+	public List<TopicsDTO> managementProtocol(PublicDiscussVO publicDiscuss, Integer type) {
+		// 参与房屋投票的总数
+		IDistrictService districtService = SpringUtils.getBean(IDistrictService.class);
+		PublicDiscussEntity discussEntity = getOne(Wrappers.<PublicDiscussEntity>lambdaQuery().eq(PublicDiscussEntity::getArticleId, publicDiscuss.getArticleId()));
+		ArticleService articleService = SpringUtils.getBean(ArticleService.class);
+		Article serviceOne = articleService.getOne(Wrappers.<Article>lambdaQuery().eq(Article::getId, publicDiscuss.getArticleId()));
+		String articleRange = serviceOne.getArticleRange();
+		List<String> strings = Func.toStrList(articleRange);
+		// 获取小区信息
+		List<DistrictEntity> list = districtService.list(Wrappers.<DistrictEntity>lambdaQuery()
+			.in(DistrictEntity::getId, strings));
+		List<String> aoiCodeList = list.stream().map(districtEntity -> districtEntity.getAoiCode()).collect(Collectors.toList());
+		// 投票详情统计
+		ITopicsService iTopicsService = SpringUtils.getBean(ITopicsService.class);
+		List<TopicsDTO> userTopicsTotalByArticleId = iTopicsService.getTopicsTotalByArticleId(discussEntity.getArticleId());
+		// 按投票数量排序
+		List<TopicsDTO> collect = userTopicsTotalByArticleId.stream().sorted(Comparator.comparing(TopicsDTO::getNumber).reversed()).collect(Collectors.toList());
+
+		if (type == 2) {
+			// 获取候选人
+			List<TopicsDTO> candidate = collect.stream().filter(topicsDTO ->
+					!(topicsDTO.getDiscussContent().equals("管理规约") || topicsDTO.getDiscussContent().equals("议事规则")))
+				.collect(Collectors.toList());
+			Integer candidateNumber = candidate.stream().map(TopicsDTO::getNumber).reduce(0, Integer::sum);
+			// 计算投票的占比
+			candidate.forEach(topicsDTO -> {
+				BigDecimal number = new BigDecimal(topicsDTO.getNumber());
+				BigDecimal total = new BigDecimal(candidateNumber);
+				if (total.compareTo(BigDecimal.ZERO) > 0) {
+					BigDecimal divide = number.divide(total, 4, BigDecimal.ROUND_HALF_UP);
+					topicsDTO.setProportion(divide.multiply(BigDecimal.valueOf(100)).setScale(2));
+				}
+			});
+			return candidate;
+		} else {
+			// 获取管理规约和议事规则
+			List<TopicsDTO> managementProtocol = collect.stream().filter(topicsDTO ->
+					topicsDTO.getDiscussContent().equals("管理规约") || topicsDTO.getDiscussContent().equals("议事规则"))
+				.collect(Collectors.toList());
+			Integer managementProtocolNumber = managementProtocol.stream().map(TopicsDTO::getNumber).reduce(0, Integer::sum);
+			// 计算投票的占比
+			managementProtocol.forEach(topicsDTO -> {
+				BigDecimal number = new BigDecimal(topicsDTO.getNumber());
+				BigDecimal total = new BigDecimal(managementProtocolNumber);
+				if (total.compareTo(BigDecimal.ZERO) > 0) {
+					BigDecimal divide = number.divide(total, 4, BigDecimal.ROUND_HALF_UP);
+					topicsDTO.setProportion(divide.multiply(BigDecimal.valueOf(100)).setScale(2));
+				}
+			});
+			return managementProtocol;
+		}
+	}
 }

--
Gitblit v1.9.3