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