|  |  |  | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import javax.validation.constraints.NotEmpty; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.community.ComActDiscussVoteOptionDTO; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.community.DiscussVoteOptionDTO; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.community.PageVoteSituationDTO; | 
|---|
|  |  |  | import com.panzhihua.service_community.dao.ComPbMemberDAO; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.data.redis.connection.StringRedisConnection; | 
|---|
|  |  |  | import org.springframework.data.redis.core.RedisCallback; | 
|---|
|  |  |  | 
|---|
|  |  |  | private UserService userService; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private StringRedisTemplate stringRedisTemplate; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ComPbMemberDAO pbMemberDAO; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 议事投票-新增 | 
|---|
|  |  |  | 
|---|
|  |  |  | comActDiscussOptionDO.setDiscussId(comActDiscussDO1Id); | 
|---|
|  |  |  | comActDiscussOptionDO.setOptionContent(s.getOptionContent()); | 
|---|
|  |  |  | comActDiscussOptionDO.setOptionUrl(s.getOptionUrl()); | 
|---|
|  |  |  | comActDiscussOptionDO.setNeedReason(s.getNeedReason()); | 
|---|
|  |  |  | comActDiscussOptionDOS.add(comActDiscussOptionDO); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | comActDiscussOptionService.saveBatch(comActDiscussOptionDOS); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (currentUserRoles.isEmpty()) { | 
|---|
|  |  |  | checkResult = false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | boolean result = sysAllowedRoles.stream().anyMatch(role -> currentUserRoles.contains(role)); | 
|---|
|  |  |  | if (!result) { | 
|---|
|  |  |  | checkResult = false; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (!sysAllowedRoles.contains("1")) { | 
|---|
|  |  |  | boolean result = sysAllowedRoles.stream().anyMatch(role -> currentUserRoles.contains(role)); | 
|---|
|  |  |  | if (!result) { | 
|---|
|  |  |  | checkResult = false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | comActDiscussDO.setStatus(ComActDiscussDO.status.yfb); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | comActDiscussDO.setUpdateAt(new Date()); | 
|---|
|  |  |  | comActDiscussDO.setUpdateAt(nowDate); | 
|---|
|  |  |  | int insert = comActDiscussDAO.updateById(comActDiscussDO); | 
|---|
|  |  |  | if (insert > 0) { | 
|---|
|  |  |  | //如果是投票,需要把投票的选项存储 | 
|---|
|  |  |  | 
|---|
|  |  |  | LoginUserInfoVO loginUserInfoVO = comActDiscussDAO.selectUserByUserId(userId); | 
|---|
|  |  |  | comActDiscussVO.setUserName(loginUserInfoVO.getName()); | 
|---|
|  |  |  | comActDiscussVO.setUserNickName(loginUserInfoVO.getNickName()); | 
|---|
|  |  |  | comActDiscussVO.setImageUrl(loginUserInfoVO.getImageUrl()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //分页查询评论列表 | 
|---|
|  |  |  | PageComActDiscussCommentDTO pageComActDiscussCommentDTO = new PageComActDiscussCommentDTO(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | comActDiscussVO.setDiscussCommentList(discussComments.getRecords()); | 
|---|
|  |  |  | String viewNumKey = String.join("_", DISCUSS_VIEW_NUM_PREFIX, id.toString()); | 
|---|
|  |  |  | if (stringRedisTemplate.hasKey(viewNumKey)) { | 
|---|
|  |  |  | ValueOperations<String, String> opsForValue = stringRedisTemplate.opsForValue(); | 
|---|
|  |  |  | comActDiscussVO.setViewsNum(Integer.parseInt(opsForValue.get(viewNumKey))); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(comActDiscussVO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R pageDiscussAdmin(PageComActDiscussDTO pageComActDiscussDTO) { | 
|---|
|  |  |  | return R.ok(comActDiscussDAO.pageDiscussAdmin(new Page<>(pageComActDiscussDTO.getPageNum(), pageComActDiscussDTO.getPageSize()), pageComActDiscussDTO)); | 
|---|
|  |  |  | IPage<ComActDiscussVO> comActDiscussVOIPage=comActDiscussDAO.pageDiscussAdmin(new Page<>(pageComActDiscussDTO.getPageNum(), pageComActDiscussDTO.getPageSize()), pageComActDiscussDTO); | 
|---|
|  |  |  | List<ComActDiscussVO> records = comActDiscussVOIPage.getRecords(); | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(records)) { | 
|---|
|  |  |  | records.forEach(comActDiscussVO -> { | 
|---|
|  |  |  | Long id = comActDiscussVO.getId(); | 
|---|
|  |  |  | String viewNumKey = String.join("_", DISCUSS_VIEW_NUM_PREFIX, id.toString()); | 
|---|
|  |  |  | if (stringRedisTemplate.hasKey(viewNumKey)) { | 
|---|
|  |  |  | ValueOperations<String, String> opsForValue = stringRedisTemplate.opsForValue(); | 
|---|
|  |  |  | comActDiscussVO.setViewsNum(Integer.parseInt(opsForValue.get(viewNumKey))); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(comActDiscussVOIPage); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | page.setSize(pageSize); | 
|---|
|  |  |  | page.setCurrent(pageNum); | 
|---|
|  |  |  | pageComActDiscussDTO.setIsPbMember(0); | 
|---|
|  |  |  | pageComActDiscussDTO.setIsVolunteer(0); | 
|---|
|  |  |  | if (nonNull(loginUserId)) { | 
|---|
|  |  |  | pageComActDiscussDTO.setIsPbMember(pbMemberDAO.checkIsPbMember(loginUserId) > 0 ? 1 : 0); | 
|---|
|  |  |  | pageComActDiscussDTO.setIsVolunteer(pbMemberDAO.checkIsVolunteer(loginUserId) > 0 ? 1 : 0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | IPage<ComActDiscussVO> iPage = comActDiscussDAO.pageDiscussApplets(page, pageComActDiscussDTO); | 
|---|
|  |  |  | List<ComActDiscussVO> records = iPage.getRecords(); | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(records)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void checkDiscussStatusIsCorrect(ComActDiscussVO comActDiscussVO) { | 
|---|
|  |  |  | //判断discuss状态是否正确 | 
|---|
|  |  |  | boolean isIncorrectStatus = comActDiscussVO.getEndTime().before(new Date()) && | 
|---|
|  |  |  | (comActDiscussVO.getStatus().intValue() == 1 || comActDiscussVO.getStatus().intValue() == 2); | 
|---|
|  |  |  | if (isIncorrectStatus) { | 
|---|
|  |  |  | comActDiscussVO.setStatus(3); | 
|---|
|  |  |  | comActDiscussDAO.updateStatusById(comActDiscussVO.getId(), 3); | 
|---|
|  |  |  | if(comActDiscussVO.getEndTime() != null){ | 
|---|
|  |  |  | boolean isIncorrectStatus = comActDiscussVO.getEndTime().before(new Date()) && | 
|---|
|  |  |  | (comActDiscussVO.getStatus().intValue() == 1 || comActDiscussVO.getStatus().intValue() == 2); | 
|---|
|  |  |  | if (isIncorrectStatus) { | 
|---|
|  |  |  | comActDiscussVO.setStatus(3); | 
|---|
|  |  |  | comActDiscussDAO.updateStatusById(comActDiscussVO.getId(), 3); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 议事投票-投票 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param comActDiscussOptionUserDTO 投票信息 | 
|---|
|  |  |  | * @param discussVoteOptionDTO 投票信息 | 
|---|
|  |  |  | * @return 投票结果 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R addDiscussOptionUser(ComActDiscussOptionUserDTO comActDiscussOptionUserDTO) { | 
|---|
|  |  |  | List<Long> discussOptionIds = comActDiscussOptionUserDTO.getDiscussOptionIds(); | 
|---|
|  |  |  | Long discussOptionId = discussOptionIds.get(0); | 
|---|
|  |  |  | Long userId = comActDiscussOptionUserDTO.getUserId(); | 
|---|
|  |  |  | public R addDiscussOptionUser(DiscussVoteOptionDTO discussVoteOptionDTO) { | 
|---|
|  |  |  | List<ComActDiscussVoteOptionDTO> options = discussVoteOptionDTO.getOptions(); | 
|---|
|  |  |  | Long discussOptionId = options.get(0).getId(); | 
|---|
|  |  |  | Long userId = discussVoteOptionDTO.getUserId(); | 
|---|
|  |  |  | ComActDiscussOptionDO comActDiscussOptionDO = comActDiscussOptionDAO.selectById(discussOptionId); | 
|---|
|  |  |  | if (ObjectUtils.isEmpty(comActDiscussOptionDO)) { | 
|---|
|  |  |  | return R.fail("选项不存在"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | boolean isRepeat = comActDiscussDO.getIsRepeat().intValue() == 1; | 
|---|
|  |  |  | int usableVoteVotes = comActDiscussDO.getCount().intValue(); | 
|---|
|  |  |  | int currentVoteNum = discussOptionIds.size(); | 
|---|
|  |  |  | int currentVoteNum = options.size(); | 
|---|
|  |  |  | if (isRepeat) { | 
|---|
|  |  |  | //可重复投票 | 
|---|
|  |  |  | int votedVotesInToday = comActDiscussOptionUserDAO.selectVotedVotesInToday(discussId, userId); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<ComActDiscussOptionUserDO> comActDiscussOptionUserDOList = new ArrayList<>(); | 
|---|
|  |  |  | discussOptionIds.forEach(optionId -> { | 
|---|
|  |  |  | options.forEach(option -> { | 
|---|
|  |  |  | ComActDiscussOptionUserDO comActDiscussOptionUserDO = new ComActDiscussOptionUserDO(); | 
|---|
|  |  |  | comActDiscussOptionUserDO.setUserId(userId); | 
|---|
|  |  |  | comActDiscussOptionUserDO.setDiscussOptionId(optionId); | 
|---|
|  |  |  | comActDiscussOptionUserDO.setDiscussOptionId(option.getId()); | 
|---|
|  |  |  | comActDiscussOptionUserDO.setDiscussId(discussId); | 
|---|
|  |  |  | comActDiscussOptionUserDOList.add(comActDiscussOptionUserDO); | 
|---|
|  |  |  | comActDiscussOptionUserDO.setSignUrl(option.getSignUrl()); | 
|---|
|  |  |  | comActDiscussOptionUserDO.setReason(option.getReason()); | 
|---|
|  |  |  | comActDiscussOptionUserDAO.insert(comActDiscussOptionUserDO); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | int result = comActDiscussOptionUserDAO.batchInsert(comActDiscussOptionUserDOList); | 
|---|
|  |  |  | if (result > 0) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.fail(); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R discussJurisdictionGet(Long communityId, Long userId) { | 
|---|
|  |  |  | List<SysConfDO> confDOList = sysConfDao.selectList(new LambdaQueryWrapper<SysConfDO>() | 
|---|
|  |  |  | .eq(SysConfDO::getCommunityId, communityId).eq(SysConfDO::getCode,Constants.DISCUSS_IDENTITY_KEY + communityId).orderByDesc(SysConfDO::getCreateAt)); | 
|---|
|  |  |  | .eq(SysConfDO::getCommunityId, communityId) | 
|---|
|  |  |  | .eq(SysConfDO::getCode,Constants.DISCUSS_IDENTITY_KEY + communityId) | 
|---|
|  |  |  | .orderByDesc(SysConfDO::getCreateAt)); | 
|---|
|  |  |  | if (confDOList == null || confDOList.size() == 0) { | 
|---|
|  |  |  | SysConfDO sysConfDO = new SysConfDO(); | 
|---|
|  |  |  | sysConfDO.setCode(Constants.DISCUSS_IDENTITY_KEY + communityId); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 投票情况-分页查询 | 
|---|
|  |  |  | * @param pageVoteSituationDTO | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R pageVoteSituation(PageVoteSituationDTO pageVoteSituationDTO) { | 
|---|
|  |  |  | Page page = new Page<>(); | 
|---|
|  |  |  | page.setCurrent(pageVoteSituationDTO.getPageNum()); | 
|---|
|  |  |  | page.setSize(pageVoteSituationDTO.getPageSize()); | 
|---|
|  |  |  | return R.ok(comActDiscussOptionUserDAO.pageVoteSituation(page, pageVoteSituationDTO)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 投票情况详情 | 
|---|
|  |  |  | * @param optionUserId | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R detailVoteSituation(Long optionUserId) { | 
|---|
|  |  |  | return R.ok(comActDiscussOptionUserDAO.detailVoteSituation(optionUserId)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 将redis中浏览量写入表中 | 
|---|
|  |  |  | * @return 执行结果 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | 
|---|
|  |  |  | //组装viewNum key | 
|---|
|  |  |  | List<String> viewNumKeys = new ArrayList<>(); | 
|---|
|  |  |  | Iterator<String> iterator = needWriteDiscussIdSet.iterator(); | 
|---|
|  |  |  | List<String> idList = new ArrayList<>(); | 
|---|
|  |  |  | while (iterator.hasNext()) { | 
|---|
|  |  |  | viewNumKeys.add(String.join("_", DISCUSS_VIEW_NUM_PREFIX, iterator.next())); | 
|---|
|  |  |  | String next = iterator.next(); | 
|---|
|  |  |  | String key = String.join("_", DISCUSS_VIEW_NUM_PREFIX, next); | 
|---|
|  |  |  | if (stringRedisTemplate.hasKey(key)) { | 
|---|
|  |  |  | idList.add(next); | 
|---|
|  |  |  | viewNumKeys.add(key); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ValueOperations opsForValue = stringRedisTemplate.opsForValue(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //待处理集合,以key-value/discussId-viewNum 存放 | 
|---|
|  |  |  | HashMap<Long, Integer> needDealMap = new HashMap<>(); | 
|---|
|  |  |  | for (String discussId : needWriteDiscussIdSet) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | needDealMap.put(Long.parseLong(discussId), Integer.parseInt(viewNumList.get(0))); | 
|---|
|  |  |  | viewNumList.remove(0); | 
|---|
|  |  |  | } catch (IndexOutOfBoundsException e) { | 
|---|
|  |  |  | //数据存在异常了,跳过,继续执行正确的 | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | if (nonNull(idList) && !idList.isEmpty()) { | 
|---|
|  |  |  | log.error("一起议id列表:" + idList.toString()); | 
|---|
|  |  |  | log.error("一起议浏览量:" + viewNumList.toString()); | 
|---|
|  |  |  | for (String discussId : idList) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | needDealMap.put(Long.parseLong(discussId), Integer.parseInt(viewNumList.get(0))); | 
|---|
|  |  |  | viewNumList.remove(0); | 
|---|
|  |  |  | } catch (IndexOutOfBoundsException e) { | 
|---|
|  |  |  | log.error("数据异常:" + discussId, e.getMessage()); | 
|---|
|  |  |  | //数据存在异常了,跳过,继续执行正确的 | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | int result = comActDiscussDAO.batchUpdateViewNum(needDealMap); | 
|---|