From f1bcbc43e988d0d1a91bea66a9ebbf6d601e48c0 Mon Sep 17 00:00:00 2001
From: yanghui <2536613402@qq.com>
Date: 星期四, 13 十月 2022 10:33:19 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/huacheng_test' into huacheng_test

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActDiscussServiceImpl.java |   70 +++++++++++++++++++++++++++-------
 1 files changed, 55 insertions(+), 15 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActDiscussServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActDiscussServiceImpl.java
index f72e540..122825f 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActDiscussServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActDiscussServiceImpl.java
@@ -17,7 +17,12 @@
 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;
@@ -114,6 +119,8 @@
     private UserService userService;
     @Resource
     private StringRedisTemplate stringRedisTemplate;
+    @Resource
+    private ComPbMemberDAO pbMemberDAO;
 
     /**
      * 议事投票-新增
@@ -163,6 +170,7 @@
                     comActDiscussOptionDO.setDiscussId(comActDiscussDO1Id);
                     comActDiscussOptionDO.setOptionContent(s.getOptionContent());
                     comActDiscussOptionDO.setOptionUrl(s.getOptionUrl());
+                    comActDiscussOptionDO.setNeedReason(s.getNeedReason());
                     comActDiscussOptionDOS.add(comActDiscussOptionDO);
                 });
                 comActDiscussOptionService.saveBatch(comActDiscussOptionDOS);
@@ -317,6 +325,11 @@
             }
         });
         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);
     }
 
@@ -409,7 +422,7 @@
                 }
             });
         }
-        return R.ok();
+        return R.ok(comActDiscussVOIPage);
     }
 
     /**
@@ -610,6 +623,12 @@
         }
         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)) {
@@ -944,14 +963,14 @@
     /**
      * 议事投票-投票
      *
-     * @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("选项不存在");
@@ -968,7 +987,7 @@
         }
         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);
@@ -985,18 +1004,16 @@
             }
         }
         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();
     }
 
     /**
@@ -1296,6 +1313,29 @@
     }
 
     /**
+     * 投票情况-分页查询
+     * @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 执行结果
      */

--
Gitblit v1.7.1