From c10d6358b9f014375a13821465bc978d0c0da22e Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Wed, 29 May 2024 17:17:08 +0800
Subject: [PATCH] 通过E呼即办数据统计

---
 src/main/java/org/springblade/modules/discuss/service/impl/PublicDiscussServiceImpl.java |   42 ++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 40 insertions(+), 2 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 1a63151..aa99403 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
@@ -17,9 +17,13 @@
 package org.springblade.modules.discuss.service.impl;
 
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+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.modules.discuss.entity.PublicDiscussEntity;
 import org.springblade.modules.discuss.entity.UserTopicsEntity;
 import org.springblade.modules.discuss.mapper.PublicDiscussMapper;
@@ -28,6 +32,8 @@
 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.house.entity.HouseholdEntity;
+import org.springblade.modules.house.service.IHouseholdService;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
@@ -53,7 +59,7 @@
 		List<PublicDiscussVO> publicDiscussVOS = baseMapper.selectPublicDiscussPage(page, publicDiscuss);
 		for (PublicDiscussVO publicDiscussVO : publicDiscussVOS) {
 			Long result = iUserPublicEnrollService.getCount(publicDiscussVO.getId());
-			if(result != null){
+			if (result != null) {
 				publicDiscussVO.setEnrollCount(result.intValue());
 			}
 			UserTopicsVO userTopicsVo = new UserTopicsVO();
@@ -73,6 +79,38 @@
 
 	@Override
 	public PublicDiscussVO getDetail(PublicDiscussVO publicDiscuss) {
-		return baseMapper.selectPublicDiscuss(publicDiscuss);
+		IHouseholdService householdService = SpringUtils.getBean(IHouseholdService.class);
+		HouseholdEntity householdEntity = householdService.getOne(Wrappers.<HouseholdEntity>lambdaQuery()
+			.eq(HouseholdEntity::getHouseCode, publicDiscuss.getHouseCode())
+			.eq(HouseholdEntity::getAssociatedUserId, AuthUtil.getUserId())
+			.eq(HouseholdEntity::getIsDeleted, 0)
+			.last("limit 1"));
+		if (householdEntity != null) {
+			publicDiscuss.setHouseholdId(householdEntity.getId());
+		}
+		PublicDiscussVO publicDiscussVO = baseMapper.selectPublicDiscuss(publicDiscuss);
+		publicDiscussVO.setDisabled(false);
+		if (householdEntity != null) {
+			// 一户一票
+			IUserTopicsService bean = SpringUtils.getBean(IUserTopicsService.class);
+			if (publicDiscussVO.getVoteRestrictions().equals(CommonConstant.NUMBER_ONE)) {
+				long count = bean.count(Wrappers.<UserTopicsEntity>lambdaQuery()
+					.eq(UserTopicsEntity::getHouseCode, publicDiscuss.getHouseCode())
+					.eq(UserTopicsEntity::getArticleId, publicDiscussVO.getArticleId()));
+				if (count > 0) {
+					publicDiscussVO.setDisabled(true);
+				}
+			} else {
+				// 一个一票
+				long count = bean.count(Wrappers.<UserTopicsEntity>lambdaQuery()
+					.eq(UserTopicsEntity::getHouseholdId, householdEntity.getId())
+					.eq(UserTopicsEntity::getArticleId, publicDiscussVO.getArticleId()));
+				if (count > 0) {
+					publicDiscussVO.setDisabled(true);
+				}
+			}
+			// 判断是否业主,只有业主可以投票
+		}
+		return publicDiscussVO;
 	}
 }

--
Gitblit v1.9.3