| | |
| | | |
| | | import java.math.BigDecimal; |
| | | import java.math.RoundingMode; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | import java.util.ArrayList; |
| | | import java.util.Comparator; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | |
| | | import javax.annotation.Resource; |
| | | |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.google.common.collect.Lists; |
| | | import com.panzhihua.common.enums.QuestnaireState; |
| | | import com.panzhihua.common.exceptions.ServiceException; |
| | | import com.panzhihua.common.model.dtos.community.PageQuestnaireAnswerDTO; |
| | | import com.panzhihua.common.model.dtos.community.PageQuestnaireDTO; |
| | | import com.panzhihua.common.model.dtos.community.PageQuestnaireSubDetailsDTO; |
| | |
| | | import com.panzhihua.common.model.dtos.community.questnaire.StatisticsSummaryDTO; |
| | | import com.panzhihua.common.model.vos.LoginUserInfoVO; |
| | | import com.panzhihua.common.model.vos.R; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireAnswerContentVO; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireSubSelectionVO; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireSubVO; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireVO; |
| | | import com.panzhihua.common.model.vos.community.questnaire.*; |
| | | import com.panzhihua.common.service.user.UserService; |
| | | import com.panzhihua.common.utlis.DateUtils; |
| | | import com.panzhihua.service_community.dao.*; |
| | | import com.panzhihua.service_community.model.dos.*; |
| | | import com.panzhihua.service_community.service.ComActQuestnaireService; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.stereotype.Service; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireAnswerContentVO; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireSubSelectionVO; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireSubVO; |
| | | import com.panzhihua.common.model.vos.community.ComActQuestnaireVO; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import javax.annotation.Resource; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | |
| | | /** |
| | | * @Author: llming |
| | |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public R addQuestnaire(QuestnaireVO questnaireVO) { |
| | | Long userId = questnaireVO.getUserId(); |
| | | if(questnaireVO.getAdverPositionPopup().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | //查询当前时间段是否已有弹窗提醒了 |
| | | Integer count = questnaireDAO.getAdvPopupCount(questnaireVO.getCommunityId(),questnaireVO.getStartTime(),questnaireVO.getEndTime(),null); |
| | | if(count > 0){ |
| | | if (questnaireVO.getAdverPositionPopup().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | // 查询当前时间段是否已有弹窗提醒了 |
| | | Integer count = questnaireDAO.getAdvPopupCount(questnaireVO.getCommunityId(), questnaireVO.getStartTime(), |
| | | questnaireVO.getEndTime(), null); |
| | | if (count > 0) { |
| | | return R.fail("所选时间段已设置了问卷调查弹窗,暂不支持再次添加!"); |
| | | } |
| | | } |
| | | ComActQuestnaireDO comActQuestnaireDO = new ComActQuestnaireDO(); |
| | | Date nowDate = new Date(); |
| | | BeanUtils.copyProperties(questnaireVO,comActQuestnaireDO); |
| | | BeanUtils.copyProperties(questnaireVO, comActQuestnaireDO); |
| | | comActQuestnaireDO.setState(ComActQuestnaireDO.state.dfb); |
| | | comActQuestnaireDO.setTitle(questnaireVO.getTitle()); |
| | | comActQuestnaireDO.setJoinCount(0); |
| | | comActQuestnaireDO.setCreateBy(userId); |
| | | comActQuestnaireDO.setCreateAt(nowDate); |
| | | Date startDate = DateUtils.stringToDate(questnaireVO.getStartTime(),DateUtils.ymdhms_format); |
| | | if(startDate != null && startDate.getTime() <= nowDate.getTime()){ |
| | | Date startDate = DateUtils.stringToDate(questnaireVO.getStartTime(), DateUtils.ymdhms_format); |
| | | if (startDate != null && startDate.getTime() <= nowDate.getTime()) { |
| | | comActQuestnaireDO.setState(ComActQuestnaireDO.state.dyz); |
| | | comActQuestnaireDO.setPublishTime(nowDate); |
| | | } |
| | | Date endDate = DateUtils.stringToDate(questnaireVO.getEndTime(),DateUtils.ymdhms_format); |
| | | if(endDate != null && endDate.getTime() <= nowDate.getTime()){ |
| | | Date endDate = DateUtils.stringToDate(questnaireVO.getEndTime(), DateUtils.ymdhms_format); |
| | | if (endDate != null && endDate.getTime() <= nowDate.getTime()) { |
| | | comActQuestnaireDO.setState(ComActQuestnaireDO.state.yjs); |
| | | } |
| | | comActQuestnaireDO.setStartTime(startDate); |
| | | comActQuestnaireDO.setEndTime(endDate); |
| | | if(questnaireVO.getIdentity().equals(QuestnaireVO.identity.jm)){ |
| | | if (questnaireVO.getIdentity().equals(QuestnaireVO.identity.jm)) { |
| | | comActQuestnaireDO.setForMasses(ComActQuestnaireDO.isOk.yes); |
| | | }else if(questnaireVO.getIdentity().equals(QuestnaireVO.identity.dy)){ |
| | | } else if (questnaireVO.getIdentity().equals(QuestnaireVO.identity.dy)) { |
| | | comActQuestnaireDO.setForParty(ComActQuestnaireDO.isOk.yes); |
| | | }else if(questnaireVO.getIdentity().equals(QuestnaireVO.identity.zyz)){ |
| | | } else if (questnaireVO.getIdentity().equals(QuestnaireVO.identity.zyz)) { |
| | | comActQuestnaireDO.setForVolunteer(ComActQuestnaireDO.isOk.yes); |
| | | } |
| | | |
| | | if(questnaireVO.getIsRelease() != null && questnaireVO.getIsRelease().equals(1)){ |
| | | if (questnaireVO.getIsRelease() != null && questnaireVO.getIsRelease().equals(1)) { |
| | | comActQuestnaireDO.setStartTime(nowDate); |
| | | } |
| | | //统计该调查问卷填报题目数量 |
| | | // 统计该调查问卷填报题目数量 |
| | | int count = 0; |
| | | List<QuestnaiteSubVO> questnaiteSubVOS = JSON.parseArray(questnaireVO.getJsonObject().toString(),QuestnaiteSubVO.class); |
| | | if(!questnaiteSubVOS.isEmpty()){ |
| | | List<QuestnaiteSubVO> questnaiteSubVOS = JSON.parseArray(questnaireVO.getJsonObject(), QuestnaiteSubVO.class); |
| | | if (!questnaiteSubVOS.isEmpty()) { |
| | | count = questnaiteSubVOS.size(); |
| | | } |
| | | comActQuestnaireDO.setCount(count); |
| | | comActQuestnaireDO.setJsonObject(questnaireVO.getJsonObject()); |
| | | |
| | | int quesCount = questnaireDAO.insert(comActQuestnaireDO); |
| | | if(quesCount !=1 ){ |
| | | if (quesCount != 1) { |
| | | return R.fail("创建失败"); |
| | | } |
| | | |
| | | if(!questnaiteSubVOS.isEmpty()) { |
| | | if (!questnaiteSubVOS.isEmpty()) { |
| | | questnaiteSubVOS.forEach(sub -> { |
| | | ComActQuestnaireSubDO comActQuestnaireSubDO = new ComActQuestnaireSubDO(); |
| | | comActQuestnaireSubDO.setType(sub.getType()); |
| | |
| | | comActQuestnaireSubDO.setKey(sub.getKey()); |
| | | questnaireSubDAO.insert(comActQuestnaireSubDO); |
| | | ArrayList<ComActQuestnaireSubSelectionDO> subSelectionList = Lists.newArrayList(); |
| | | if(sub.getOptions() != null && !sub.getOptions().isEmpty()) { |
| | | if (sub.getOptions() != null && !sub.getOptions().isEmpty()) { |
| | | List<QuestnaiteSubSelectionVO> subOptions = sub.getOptions(); |
| | | for(int i=0; i<subOptions.size(); i++){ |
| | | for (int i = 0; i < subOptions.size(); i++) { |
| | | QuestnaiteSubSelectionVO subSelect = subOptions.get(i); |
| | | ComActQuestnaireSubSelectionDO subSelectionDO = new ComActQuestnaireSubSelectionDO(); |
| | | subSelectionDO.setQueSubId(comActQuestnaireSubDO.getId()); |
| | | if(subSelect.getType().equals(1)){ |
| | | //添加选项名称 |
| | | if (subSelect.getType().equals(1)) { |
| | | // 添加选项名称 |
| | | subSelectionDO.setOptionName(subSelect.getOptionName()); |
| | | }else { |
| | | } else { |
| | | subSelectionDO.setOptionName(String.valueOf(Character.toChars('A' + i))); |
| | | } |
| | | subSelectionDO.setContent(subSelect.getLabel()); |
| | |
| | | |
| | | @Override |
| | | public R pageQuestnaire(PageQuestnaireDTO pageQuestnaireDTO) { |
| | | IPage<QuestnaireListVo> voPage = questnaireDAO.selectPageList(new Page<>(pageQuestnaireDTO.getPageNum(),pageQuestnaireDTO.getPageSize()),pageQuestnaireDTO); |
| | | IPage<QuestnaireListVo> voPage = questnaireDAO.selectPageList( |
| | | new Page<>(pageQuestnaireDTO.getPageNum(), pageQuestnaireDTO.getPageSize()), pageQuestnaireDTO); |
| | | return R.ok(voPage); |
| | | } |
| | | |
| | | @Override |
| | | public R pageQuestnaireAdmin(PageQuestnaireDTO pageQuestnaireDTO) { |
| | | IPage<QuestnaireListAdminVO> voPage = questnaireDAO.selectPageListAdmin(new Page<>(pageQuestnaireDTO.getPageNum(),pageQuestnaireDTO.getPageSize()),pageQuestnaireDTO); |
| | | if(!voPage.getRecords().isEmpty()){ |
| | | IPage<QuestnaireListAdminVO> voPage = questnaireDAO.selectPageListAdmin( |
| | | new Page<>(pageQuestnaireDTO.getPageNum(), pageQuestnaireDTO.getPageSize()), pageQuestnaireDTO); |
| | | if (!voPage.getRecords().isEmpty()) { |
| | | voPage.getRecords().forEach(vo -> { |
| | | //判断调查人员身份 |
| | | if(vo.getForMasses().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | // 判断调查人员身份 |
| | | if (vo.getForMasses().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | vo.setIdentity("全部居民"); |
| | | }else if(vo.getForParty().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | } else if (vo.getForParty().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | vo.setIdentity("党员"); |
| | | }else if(vo.getForVolunteer().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | } else if (vo.getForVolunteer().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | vo.setIdentity("志愿者"); |
| | | } |
| | | //判断广告位置 |
| | | // 判断广告位置 |
| | | StringBuilder sb = new StringBuilder(); |
| | | if(vo.getAdverPositionPopup().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | if (vo.getAdverPositionPopup().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | sb.append("首页弹窗,"); |
| | | } |
| | | if(vo.getAdverPositionTop().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | if (vo.getAdverPositionTop().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | sb.append("首页顶部,"); |
| | | } |
| | | if(vo.getAdverPositionApplication().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | if (vo.getAdverPositionApplication().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | sb.append("首页应用,"); |
| | | } |
| | | String advertPosition = sb.toString(); |
| | | if(advertPosition.length() > 0){ |
| | | vo.setAdvertPosition(advertPosition.substring(0,advertPosition.length()-1)); |
| | | }else{ |
| | | if (advertPosition.length() > 0) { |
| | | vo.setAdvertPosition(advertPosition.substring(0, advertPosition.length() - 1)); |
| | | } else { |
| | | vo.setAdvertPosition("无"); |
| | | } |
| | | }); |
| | |
| | | Long queId = questnaireVO.getId(); |
| | | Long userId = questnaireVO.getUserId(); |
| | | ComActQuestnaireDO questnaireDO = this.questnaireDAO.selectById(queId); |
| | | if(questnaireDO == null){ |
| | | if (questnaireDO == null) { |
| | | return R.fail("未查询到该问卷调查"); |
| | | } |
| | | |
| | | if(!questnaireDO.getState().equals(1)){ |
| | | if (!questnaireDO.getState().equals(1)) { |
| | | return R.fail("该调查问卷不是待发布状态,不可编辑"); |
| | | } |
| | | |
| | | if(questnaireVO.getAdverPositionPopup().equals(ComActQuestnaireDO.isOk.yes)){ |
| | | //查询当前时间段是否已有弹窗提醒了 |
| | | Integer count = questnaireDAO.getAdvPopupCount(questnaireVO.getCommunityId(),questnaireVO.getStartTime(),questnaireVO.getEndTime(),queId); |
| | | if(count > 0){ |
| | | if (questnaireVO.getAdverPositionPopup().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | // 查询当前时间段是否已有弹窗提醒了 |
| | | Integer count = questnaireDAO.getAdvPopupCount(questnaireVO.getCommunityId(), questnaireVO.getStartTime(), |
| | | questnaireVO.getEndTime(), queId); |
| | | if (count > 0) { |
| | | return R.fail("所选时间段已设置了问卷调查弹窗,暂不支持再次添加!"); |
| | | } |
| | | } |
| | | |
| | | //更新调查问卷信息 |
| | | // 更新调查问卷信息 |
| | | Date nowDate = new Date(); |
| | | BeanUtils.copyProperties(questnaireVO,questnaireDO); |
| | | BeanUtils.copyProperties(questnaireVO, questnaireDO); |
| | | questnaireDO.setState(ComActQuestnaireDO.state.dfb); |
| | | questnaireDO.setTitle(questnaireVO.getTitle()); |
| | | questnaireDO.setUpdateBy(userId); |
| | | questnaireDO.setUpdateAt(nowDate); |
| | | Date startDate = DateUtils.stringToDate(questnaireVO.getStartTime(),DateUtils.ymdhms_format); |
| | | if(startDate != null && startDate.getTime() <= nowDate.getTime()){ |
| | | Date startDate = DateUtils.stringToDate(questnaireVO.getStartTime(), DateUtils.ymdhms_format); |
| | | if (startDate != null && startDate.getTime() <= nowDate.getTime()) { |
| | | questnaireDO.setState(ComActQuestnaireDO.state.dyz); |
| | | questnaireDO.setPublishTime(nowDate); |
| | | } |
| | | Date endDate = DateUtils.stringToDate(questnaireVO.getEndTime(),DateUtils.ymdhms_format); |
| | | if(endDate != null && endDate.getTime() <= nowDate.getTime()){ |
| | | Date endDate = DateUtils.stringToDate(questnaireVO.getEndTime(), DateUtils.ymdhms_format); |
| | | if (endDate != null && endDate.getTime() <= nowDate.getTime()) { |
| | | questnaireDO.setState(ComActQuestnaireDO.state.yjs); |
| | | } |
| | | questnaireDO.setStartTime(startDate); |
| | | questnaireDO.setEndTime(endDate); |
| | | if(questnaireVO.getIdentity().equals(QuestnaireVO.identity.jm)){ |
| | | if (questnaireVO.getIdentity().equals(QuestnaireVO.identity.jm)) { |
| | | questnaireDO.setForMasses(ComActQuestnaireDO.isOk.yes); |
| | | }else if(questnaireVO.getIdentity().equals(QuestnaireVO.identity.dy)){ |
| | | } else if (questnaireVO.getIdentity().equals(QuestnaireVO.identity.dy)) { |
| | | questnaireDO.setForParty(ComActQuestnaireDO.isOk.yes); |
| | | }else if(questnaireVO.getIdentity().equals(QuestnaireVO.identity.zyz)){ |
| | | } else if (questnaireVO.getIdentity().equals(QuestnaireVO.identity.zyz)) { |
| | | questnaireDO.setForVolunteer(ComActQuestnaireDO.isOk.yes); |
| | | } |
| | | |
| | | if(questnaireVO.getIsRelease() != null && questnaireVO.getIsRelease().equals(1)){ |
| | | if (questnaireVO.getIsRelease() != null && questnaireVO.getIsRelease().equals(1)) { |
| | | questnaireDO.setStartTime(nowDate); |
| | | } |
| | | //统计该调查问卷填报题目数量 |
| | | // 统计该调查问卷填报题目数量 |
| | | int count = 0; |
| | | List<QuestnaiteSubVO> questnaiteSubVOS = JSON.parseArray(questnaireVO.getJsonObject().toString(),QuestnaiteSubVO.class); |
| | | if(!questnaiteSubVOS.isEmpty()){ |
| | | List<QuestnaiteSubVO> questnaiteSubVOS = JSON.parseArray(questnaireVO.getJsonObject(), QuestnaiteSubVO.class); |
| | | if (!questnaiteSubVOS.isEmpty()) { |
| | | count = questnaiteSubVOS.size(); |
| | | } |
| | | questnaireDO.setCount(count); |
| | | questnaireDO.setJsonObject(questnaireVO.getJsonObject()); |
| | | questnaireDAO.updateById(questnaireDO); |
| | | //删除原调查问卷题目以及选项,重新进行新增 |
| | | // 删除原调查问卷题目以及选项,重新进行新增 |
| | | questnaireDAO.deleteQuesSubAll(queId); |
| | | //重新新增题目以及题目选项 |
| | | if(!questnaiteSubVOS.isEmpty()) { |
| | | // 重新新增题目以及题目选项 |
| | | if (!questnaiteSubVOS.isEmpty()) { |
| | | questnaiteSubVOS.forEach(sub -> { |
| | | ComActQuestnaireSubDO comActQuestnaireSubDO = new ComActQuestnaireSubDO(); |
| | | comActQuestnaireSubDO.setType(sub.getType()); |
| | |
| | | comActQuestnaireSubDO.setCreateBy(userId); |
| | | questnaireSubDAO.insert(comActQuestnaireSubDO); |
| | | ArrayList<ComActQuestnaireSubSelectionDO> subSelectionList = Lists.newArrayList(); |
| | | if(sub.getOptions() != null && !sub.getOptions().isEmpty()) { |
| | | if (sub.getOptions() != null && !sub.getOptions().isEmpty()) { |
| | | List<QuestnaiteSubSelectionVO> subOptions = sub.getOptions(); |
| | | for(int i=0; i<subOptions.size(); i++){ |
| | | for (int i = 0; i < subOptions.size(); i++) { |
| | | QuestnaiteSubSelectionVO subSelect = subOptions.get(i); |
| | | ComActQuestnaireSubSelectionDO subSelectionDO = new ComActQuestnaireSubSelectionDO(); |
| | | subSelectionDO.setQueSubId(comActQuestnaireSubDO.getId()); |
| | | if(subSelect.getType().equals(1)){ |
| | | //添加选项名称 |
| | | if (subSelect.getType().equals(1)) { |
| | | // 添加选项名称 |
| | | subSelectionDO.setOptionName(subSelect.getOptionName()); |
| | | }else { |
| | | } else { |
| | | subSelectionDO.setOptionName(String.valueOf(Character.toChars('A' + i))); |
| | | } |
| | | subSelectionDO.setKey(subSelect.getKey()); |
| | |
| | | public R editQuestnaireDO(EditComActQuestnaireVo editComActQuestnaireVo) { |
| | | Long userId = editComActQuestnaireVo.getUserId(); |
| | | LambdaQueryWrapper<ComActQuestnaireDO> subParam = new LambdaQueryWrapper<ComActQuestnaireDO>() |
| | | .eq(ComActQuestnaireDO::getId, editComActQuestnaireVo.getQuestId()); |
| | | .eq(ComActQuestnaireDO::getId, editComActQuestnaireVo.getQuestId()); |
| | | ComActQuestnaireDO questDO = questnaireDAO.selectOne(subParam); |
| | | if (questDO == null) { |
| | | return R.fail("未查询到调查问卷记录"); |
| | | } |
| | | if(editComActQuestnaireVo.getType().equals(EditComActQuestnaireVo.type.jx)){ |
| | | questDO.setEndTime(DateUtils.stringToDate(editComActQuestnaireVo.getEndTime(),DateUtils.ymdhms_format)); |
| | | if (editComActQuestnaireVo.getType().equals(EditComActQuestnaireVo.type.jx)) { |
| | | questDO.setEndTime(DateUtils.stringToDate(editComActQuestnaireVo.getEndTime(), DateUtils.ymdhms_format)); |
| | | questDO.setState(ComActQuestnaireDO.state.dyz); |
| | | }else if(editComActQuestnaireVo.getType().equals(EditComActQuestnaireVo.type.tz)){ |
| | | } else if (editComActQuestnaireVo.getType().equals(EditComActQuestnaireVo.type.tz)) { |
| | | questDO.setState(ComActQuestnaireDO.state.yjs); |
| | | }else if(editComActQuestnaireVo.getType().equals(EditComActQuestnaireVo.type.fb)){ |
| | | } else if (editComActQuestnaireVo.getType().equals(EditComActQuestnaireVo.type.fb)) { |
| | | questDO.setState(ComActQuestnaireDO.state.dyz); |
| | | questDO.setStartTime(new Date()); |
| | | } |
| | | questDO.setUpdateBy(userId); |
| | | questDO.setUpdateAt(new Date()); |
| | | if(questnaireDAO.updateById(questDO) > 0){ |
| | | if (questnaireDAO.updateById(questDO) > 0) { |
| | | return R.ok(); |
| | | }else{ |
| | | } else { |
| | | return R.fail(); |
| | | } |
| | | } |
| | |
| | | if (queDO == null) { |
| | | return R.fail("未查询到调查问卷记录"); |
| | | } |
| | | if(!queDO.getState().equals(ComActQuestnaireDO.state.dfb)){ |
| | | if (!queDO.getState().equals(ComActQuestnaireDO.state.dfb)) { |
| | | return R.fail("该调查问卷不是待发布状态,不可删除"); |
| | | } |
| | | queDO.setUpdateBy(userId); |
| | | queDO.setUpdateAt(new Date()); |
| | | queDO.setIsHide(1); |
| | | if(questnaireDAO.updateById(queDO) > 0){ |
| | | if (questnaireDAO.updateById(queDO) > 0) { |
| | | return R.ok(); |
| | | }else{ |
| | | } else { |
| | | return R.fail(); |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public R statQuestnaire(Long questId) { |
| | | ComActQuestnaireDO comActQuestnaireDO = questnaireDAO.selectOne(new QueryWrapper<ComActQuestnaireDO>().lambda().eq(ComActQuestnaireDO::getId, questId).eq(ComActQuestnaireDO::getIsHide, 0)); |
| | | ComActQuestnaireDO comActQuestnaireDO = questnaireDAO.selectOne(new QueryWrapper<ComActQuestnaireDO>().lambda() |
| | | .eq(ComActQuestnaireDO::getId, questId).eq(ComActQuestnaireDO::getIsHide, 0)); |
| | | |
| | | if(comActQuestnaireDO==null){ |
| | | if (comActQuestnaireDO == null) { |
| | | return R.fail("问卷已删除!"); |
| | | } |
| | | |
| | | QuestnaireAnswerStatVO usersAnswerStatVO = new QuestnaireAnswerStatVO(); |
| | | //问卷信息 |
| | | // 问卷信息 |
| | | ComActQuestnaireVO comActQuestnaireVO = new ComActQuestnaireVO(); |
| | | BeanUtils.copyProperties(comActQuestnaireDO, comActQuestnaireVO); |
| | | usersAnswerStatVO.setQuestnaire(comActQuestnaireVO); |
| | | |
| | | //问卷题目列表 |
| | | List<ComActQuestnaireSubDO> comActQuestnaireSubDOList = |
| | | questnaireSubDAO.selectList(new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId)); |
| | | //题目统计信息 |
| | | List<UserSubAnswerSelectionStatVO> usearSubAnswerSelectionStatVOList = questnaireAnswerContentDAO.selectQuestnaireStat(questId); |
| | | // 问卷题目列表 |
| | | List<ComActQuestnaireSubDO> comActQuestnaireSubDOList = questnaireSubDAO.selectList( |
| | | new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId)); |
| | | // 题目统计信息 |
| | | List<UserSubAnswerSelectionStatVO> usearSubAnswerSelectionStatVOList = |
| | | questnaireAnswerContentDAO.selectQuestnaireStat(questId); |
| | | |
| | | List<UsersSubAnswerStatVO> usersSubAnswerStatVOList = new ArrayList<>(); |
| | | |
| | |
| | | usersSubAnswerStatVO.setTotal(0); |
| | | |
| | | usearSubAnswerSelectionStatVOList.forEach(stat -> { |
| | | if (stat.getSubId().equals(comActQuestnaireSubDO.getId()) |
| | | && stat.getTotal()>0) { |
| | | if (stat.getSubId().equals(comActQuestnaireSubDO.getId()) && stat.getTotal() > 0) { |
| | | userSubAnswerSelectionStatVOList.add(stat); |
| | | } |
| | | }); |
| | | usersSubAnswerStatVO.setUsersAnswer(userSubAnswerSelectionStatVOList); |
| | | Integer count = questnaireAnswerContentDAO.selectCount(new QueryWrapper<ComActQuestnaireAnswerContentDO>() |
| | | .select(" DISTINCT sub_id, user_id ").lambda() |
| | | .eq(ComActQuestnaireAnswerContentDO::getSubId, comActQuestnaireSubDO.getId())); |
| | | Integer count = questnaireAnswerContentDAO |
| | | .selectCount(new QueryWrapper<ComActQuestnaireAnswerContentDO>().select(" DISTINCT sub_id, user_id ") |
| | | .lambda().eq(ComActQuestnaireAnswerContentDO::getSubId, comActQuestnaireSubDO.getId())); |
| | | usersSubAnswerStatVO.setTotal(count); |
| | | usersSubAnswerStatVOList.add(usersSubAnswerStatVO); |
| | | }); |
| | |
| | | |
| | | @Override |
| | | public R answerInfoQuestnaire(Long userId, Long questId) { |
| | | ComActQuestnaireDO comActQuestnaireDO = questnaireDAO.selectOne(new QueryWrapper<ComActQuestnaireDO>().lambda().eq(ComActQuestnaireDO::getId, questId).eq(ComActQuestnaireDO::getIsHide, 0)); |
| | | ComActQuestnaireDO comActQuestnaireDO = questnaireDAO.selectOne(new QueryWrapper<ComActQuestnaireDO>().lambda() |
| | | .eq(ComActQuestnaireDO::getId, questId).eq(ComActQuestnaireDO::getIsHide, 0)); |
| | | if (comActQuestnaireDO == null) { |
| | | return R.fail("问卷不存在!"); |
| | | } |
| | |
| | | BeanUtils.copyProperties(comActQuestnaireDO, comActQuestnaireVO); |
| | | usersAnswerVO.setQuestnaire(comActQuestnaireVO); |
| | | |
| | | List<ComActQuestnaireSubDO> list = questnaireSubDAO.selectList(new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId)); |
| | | List<ComActQuestnaireSubDO> list = questnaireSubDAO.selectList( |
| | | new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId)); |
| | | list.sort(Comparator.comparing(ComActQuestnaireSubDO::getSort)); |
| | | List<UsersSubAnswerVO> usersSubAnswerVOList = new ArrayList<>(); |
| | | |
| | | list.forEach(comActQuestnaireSubDO -> { |
| | | UsersSubAnswerVO usersSubAnswerVO = new UsersSubAnswerVO(); |
| | | //问卷调查题目 |
| | | ComActQuestnaireSubVO comActQuestnaireSubVO = new ComActQuestnaireSubVO(); |
| | | BeanUtils.copyProperties(comActQuestnaireSubDO, comActQuestnaireSubVO); |
| | | usersSubAnswerVO.setQuestSubVO(comActQuestnaireSubVO); |
| | | UsersSubAnswerVO usersSubAnswerVO = new UsersSubAnswerVO(); |
| | | // 问卷调查题目 |
| | | ComActQuestnaireSubVO comActQuestnaireSubVO = new ComActQuestnaireSubVO(); |
| | | BeanUtils.copyProperties(comActQuestnaireSubDO, comActQuestnaireSubVO); |
| | | usersSubAnswerVO.setQuestSubVO(comActQuestnaireSubVO); |
| | | |
| | | //问卷调查题目-选项 |
| | | Long subId = comActQuestnaireSubDO.getId(); |
| | | List<ComActQuestnaireSubSelectionDO> comActQuestnaireSubSelectionDOs = |
| | | questnaireSubSelectionDAO.selectList(new QueryWrapper<ComActQuestnaireSubSelectionDO>().lambda().eq(ComActQuestnaireSubSelectionDO::getQueSubId, subId)); |
| | | // 问卷调查题目-选项 |
| | | Long subId = comActQuestnaireSubDO.getId(); |
| | | List<ComActQuestnaireSubSelectionDO> comActQuestnaireSubSelectionDOs = |
| | | questnaireSubSelectionDAO.selectList(new QueryWrapper<ComActQuestnaireSubSelectionDO>().lambda() |
| | | .eq(ComActQuestnaireSubSelectionDO::getQueSubId, subId)); |
| | | |
| | | List<ComActQuestnaireSubSelectionVO> comActQuestnaireSubSelectionVOs = new ArrayList<>(); |
| | | comActQuestnaireSubSelectionDOs.forEach(comActQuestnaireSubSelectionDO -> { |
| | | ComActQuestnaireSubSelectionVO comActQuestnaireSubSelectionVO = new ComActQuestnaireSubSelectionVO(); |
| | | BeanUtils.copyProperties(comActQuestnaireSubSelectionDO, comActQuestnaireSubSelectionVO); |
| | | comActQuestnaireSubSelectionVOs.add(comActQuestnaireSubSelectionVO); |
| | | }); |
| | | usersSubAnswerVO.setQuestSelectionList(comActQuestnaireSubSelectionVOs); |
| | | // 用户回答 |
| | | if (userId != null) { |
| | | List<ComActQuestnaireAnswerContentDO> questnaireAnswerContentDOList = |
| | | questnaireAnswerContentDAO.selectList(new QueryWrapper<ComActQuestnaireAnswerContentDO>().lambda() |
| | | .eq(ComActQuestnaireAnswerContentDO::getUserId, userId) |
| | | .eq(ComActQuestnaireAnswerContentDO::getSubId, subId)); |
| | | |
| | | List<ComActQuestnaireSubSelectionVO> comActQuestnaireSubSelectionVOs = new ArrayList<>(); |
| | | comActQuestnaireSubSelectionDOs.forEach(comActQuestnaireSubSelectionDO -> { |
| | | ComActQuestnaireSubSelectionVO comActQuestnaireSubSelectionVO = new ComActQuestnaireSubSelectionVO(); |
| | | BeanUtils.copyProperties(comActQuestnaireSubSelectionDO, comActQuestnaireSubSelectionVO); |
| | | comActQuestnaireSubSelectionVOs.add(comActQuestnaireSubSelectionVO); |
| | | }); |
| | | usersSubAnswerVO.setQuestSelectionList(comActQuestnaireSubSelectionVOs); |
| | | //用户回答 |
| | | if (userId != null) { |
| | | List<ComActQuestnaireAnswerContentDO> questnaireAnswerContentDOList = |
| | | questnaireAnswerContentDAO.selectList(new QueryWrapper<ComActQuestnaireAnswerContentDO>().lambda().eq(ComActQuestnaireAnswerContentDO::getUserId, userId) |
| | | .eq(ComActQuestnaireAnswerContentDO::getSubId, subId)); |
| | | List<ComActQuestnaireAnswerContentVO> questnaireAnswerContentVOList = new ArrayList<>(); |
| | | questnaireAnswerContentDOList.forEach(questnaireAnswerContentDO -> { |
| | | ComActQuestnaireAnswerContentVO comActQuestnaireSubSelectionVO = |
| | | new ComActQuestnaireAnswerContentVO(); |
| | | BeanUtils.copyProperties(questnaireAnswerContentDO, comActQuestnaireSubSelectionVO); |
| | | questnaireAnswerContentVOList.add(comActQuestnaireSubSelectionVO); |
| | | }); |
| | | |
| | | List<ComActQuestnaireAnswerContentVO> questnaireAnswerContentVOList = new ArrayList<>(); |
| | | questnaireAnswerContentDOList.forEach(questnaireAnswerContentDO -> { |
| | | ComActQuestnaireAnswerContentVO comActQuestnaireSubSelectionVO = new ComActQuestnaireAnswerContentVO(); |
| | | BeanUtils.copyProperties(questnaireAnswerContentDO, comActQuestnaireSubSelectionVO); |
| | | questnaireAnswerContentVOList.add(comActQuestnaireSubSelectionVO); |
| | | }); |
| | | |
| | | usersSubAnswerVO.setUsersAnswer(questnaireAnswerContentVOList); |
| | | } |
| | | usersSubAnswerVOList.add(usersSubAnswerVO); |
| | | } |
| | | ); |
| | | usersSubAnswerVO.setUsersAnswer(questnaireAnswerContentVOList); |
| | | } |
| | | usersSubAnswerVOList.add(usersSubAnswerVO); |
| | | }); |
| | | usersAnswerVO.setUsersSubAnswer(usersSubAnswerVOList); |
| | | |
| | | return R.ok(usersAnswerVO); |
| | |
| | | /** |
| | | * 查询题目 |
| | | */ |
| | | List<ComActQuestnaireSubDO> list = questnaireSubDAO.selectList(new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId)); |
| | | List<ComActQuestnaireSubDO> list = questnaireSubDAO.selectList( |
| | | new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId)); |
| | | List<ComActQuestnaireSubVO> listSubVo = new ArrayList<>(); |
| | | list.forEach(subDo -> { |
| | | ComActQuestnaireSubVO comActQuestnaireSubVO = new ComActQuestnaireSubVO(); |
| | |
| | | /** |
| | | * 查询用户回答 |
| | | */ |
| | | List<ComActQuestnaireAnswerContentDO> questnaireAnswerContentDOList = questnaireAnswerContentDAO.selectListByQuestnaire(questId); |
| | | List<ComActQuestnaireAnswerContentDO> questnaireAnswerContentDOList = |
| | | questnaireAnswerContentDAO.selectListByQuestnaire(questId); |
| | | List<ComActQuestnaireAnswerContentVO> vos = new ArrayList<>(); |
| | | questnaireAnswerContentDOList.forEach(dos -> { |
| | | ComActQuestnaireAnswerContentVO vo = new ComActQuestnaireAnswerContentVO(); |
| | |
| | | public R qaQeustDetails(PageQuestnaireSubDetailsDTO pageQuestnaireSubDetailsDTO) { |
| | | Page userPage = new Page(pageQuestnaireSubDetailsDTO.getPageNum(), pageQuestnaireSubDetailsDTO.getPageSize()); |
| | | IPage<ComActQuestnaireAnswerContentVO> doPager = |
| | | questnaireAnswerContentDAO.selectVoByPage(userPage, pageQuestnaireSubDetailsDTO); |
| | | questnaireAnswerContentDAO.selectVoByPage(userPage, pageQuestnaireSubDetailsDTO); |
| | | return R.ok(doPager); |
| | | } |
| | | |
| | | @Override |
| | | public R pageQuestnaireAnswer(PageQuestnaireAnswerDTO pageQuestnaireAnswerDTO) { |
| | | if(pageQuestnaireAnswerDTO.getPageNum()==null||pageQuestnaireAnswerDTO.getPageNum().longValue()==0){ |
| | | if (pageQuestnaireAnswerDTO.getPageNum() == null || pageQuestnaireAnswerDTO.getPageNum().longValue() == 0) { |
| | | pageQuestnaireAnswerDTO.setPageNum(1l); |
| | | } |
| | | if(pageQuestnaireAnswerDTO.getPageSize()==null||pageQuestnaireAnswerDTO.getPageSize().longValue()==0){ |
| | | if (pageQuestnaireAnswerDTO.getPageSize() == null || pageQuestnaireAnswerDTO.getPageSize().longValue() == 0) { |
| | | pageQuestnaireAnswerDTO.setPageSize(10l); |
| | | } |
| | | Page userPage = new Page(pageQuestnaireAnswerDTO.getPageNum(), pageQuestnaireAnswerDTO.getPageSize()); |
| | | IPage<ComActQuestnaireAnswerContentVO> doPager = questnaireAnswerContentDAO.selectAnswersByPage(userPage, pageQuestnaireAnswerDTO); |
| | | IPage<ComActQuestnaireAnswerContentVO> doPager = |
| | | questnaireAnswerContentDAO.selectAnswersByPage(userPage, pageQuestnaireAnswerDTO); |
| | | return R.ok(doPager); |
| | | } |
| | | |
| | |
| | | return R.fail("调查问卷不存在!"); |
| | | } |
| | | |
| | | if(!questnaireDO.getState().equals(ComActQuestnaireDO.state.dyz)){ |
| | | if (!questnaireDO.getState().equals(ComActQuestnaireDO.state.dyz)) { |
| | | return R.fail("该调查问卷已结束,不可提交!"); |
| | | } |
| | | |
| | | ComActQuestnaireUserAnswerDO oldUserAnswerDO = comActQuestnaireUserAnswerMapper.selectOne(new QueryWrapper<ComActQuestnaireUserAnswerDO>().lambda() |
| | | .eq(ComActQuestnaireUserAnswerDO::getQuestnaireId,questId).eq(ComActQuestnaireUserAnswerDO::getUserId,userId)); |
| | | if(oldUserAnswerDO != null){ |
| | | ComActQuestnaireUserAnswerDO oldUserAnswerDO = |
| | | comActQuestnaireUserAnswerMapper.selectOne(new QueryWrapper<ComActQuestnaireUserAnswerDO>().lambda() |
| | | .eq(ComActQuestnaireUserAnswerDO::getQuestnaireId, questId) |
| | | .eq(ComActQuestnaireUserAnswerDO::getUserId, userId)); |
| | | if (oldUserAnswerDO != null) { |
| | | return R.fail("您已填写该问卷,不可重复提交"); |
| | | } |
| | | |
| | | // 查询填报人员信息 |
| | | R<LoginUserInfoVO> userResult = userService.getUserInfoByUserId(userId + ""); |
| | | if (!R.isOk(userResult)) { |
| | | log.error("填写问卷调查失败,未查询到用户信息"); |
| | | return R.fail("填写失败"); |
| | | } |
| | | LoginUserInfoVO userInfo = userResult.getData(); |
| | | if (questnaireDO.getForParty().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | if (!userInfo.getIsPartymember().equals(1)) { |
| | | return R.fail("您还未进行党员认证,无法填报"); |
| | | } |
| | | } |
| | | if (questnaireDO.getForVolunteer().equals(ComActQuestnaireDO.isOk.yes)) { |
| | | if (!userInfo.getIsVolunteer().equals(1)) { |
| | | return R.fail("您还未进行志愿者认证,无法填报"); |
| | | } |
| | | } |
| | | |
| | | List<ComActQuestnaireAnswerContentDO> answerContentList = new ArrayList<>(); |
| | | |
| | | //解析用户上传json数据 |
| | | List<QuestnaiteSubVO> questnaiteSubVOS = JSON.parseArray(answerQuestnaireVO.getJsonObject().toString(),QuestnaiteSubVO.class); |
| | | if(!questnaiteSubVOS.isEmpty()){ |
| | | for (QuestnaiteSubVO questnaiteSub:questnaiteSubVOS) { |
| | | //查询用户填写题目 |
| | | ComActQuestnaireSubDO questnaireSubDO = questnaireSubDAO.selectOne(new QueryWrapper<ComActQuestnaireSubDO>().lambda() |
| | | .eq(ComActQuestnaireSubDO::getQueId,questId).eq(ComActQuestnaireSubDO::getKey,questnaiteSub.getKey())); |
| | | if(questnaireSubDO == null){ |
| | | // 解析用户上传json数据 |
| | | List<QuestnaiteSubVO> questnaiteSubVOS = |
| | | JSON.parseArray(answerQuestnaireVO.getJsonObject(), QuestnaiteSubVO.class); |
| | | if (!questnaiteSubVOS.isEmpty()) { |
| | | for (QuestnaiteSubVO questnaiteSub : questnaiteSubVOS) { |
| | | // 查询用户填写题目 |
| | | ComActQuestnaireSubDO questnaireSubDO = questnaireSubDAO.selectOne( |
| | | new QueryWrapper<ComActQuestnaireSubDO>().lambda().eq(ComActQuestnaireSubDO::getQueId, questId) |
| | | .eq(ComActQuestnaireSubDO::getKey, questnaiteSub.getKey())); |
| | | if (questnaireSubDO == null) { |
| | | log.error("未查询到调查问卷题目,题目名称:" + questnaiteSub.getLabel() + "题目key:" + questnaiteSub.getKey()); |
| | | continue; |
| | | } |
| | | |
| | | Long queSubId = questnaireSubDO.getId(); |
| | | //根据上传的类型查询不同的题目选项 |
| | | if(questnaiteSub.getType().equals(QuestnaiteSubVO.type.danxuan)){ |
| | | // 根据上传的类型查询不同的题目选项 |
| | | if (questnaiteSub.getType().equals(QuestnaiteSubVO.type.danxuan)) { |
| | | |
| | | //单选题处理 |
| | | ComActQuestnaireSubSelectionDO subSelectionDO = questnaireSubSelectionDAO.selectOne(new QueryWrapper<ComActQuestnaireSubSelectionDO>() |
| | | .lambda().eq(ComActQuestnaireSubSelectionDO::getQueSubId,queSubId).eq(ComActQuestnaireSubSelectionDO::getQueId,questId) |
| | | .eq(ComActQuestnaireSubSelectionDO::getKey,questnaiteSub.getValues())); |
| | | if(subSelectionDO == null){ |
| | | // 单选题处理 |
| | | ComActQuestnaireSubSelectionDO subSelectionDO = |
| | | questnaireSubSelectionDAO.selectOne(new QueryWrapper<ComActQuestnaireSubSelectionDO>().lambda() |
| | | .eq(ComActQuestnaireSubSelectionDO::getQueSubId, queSubId) |
| | | .eq(ComActQuestnaireSubSelectionDO::getQueId, questId) |
| | | .eq(ComActQuestnaireSubSelectionDO::getKey, questnaiteSub.getValues())); |
| | | if (subSelectionDO == null) { |
| | | log.error("未查询到调查问卷选项,题目名称:" + questnaiteSub.getLabel() + "选项key:" + questnaiteSub.getValues()); |
| | | continue; |
| | | } |
| | |
| | | answerContentDO.setChoice(subSelectionDO.getOptionName()); |
| | | answerContentDO.setAnswerContent(subSelectionDO.getContent()); |
| | | answerContentList.add(answerContentDO); |
| | | }else if(questnaiteSub.getType().equals(QuestnaiteSubVO.type.duoxuan)){ |
| | | //多选题处理 |
| | | } else if (questnaiteSub.getType().equals(QuestnaiteSubVO.type.duoxuan)) { |
| | | // 多选题处理 |
| | | String values = questnaiteSub.getValues(); |
| | | String []value = values.split(","); |
| | | String[] value = values.split(","); |
| | | for (int i = 0; i < value.length; i++) { |
| | | ComActQuestnaireSubSelectionDO subSelectionDO = questnaireSubSelectionDAO.selectOne(new QueryWrapper<ComActQuestnaireSubSelectionDO>() |
| | | .lambda().eq(ComActQuestnaireSubSelectionDO::getQueSubId,queSubId).eq(ComActQuestnaireSubSelectionDO::getQueId,questId) |
| | | .eq(ComActQuestnaireSubSelectionDO::getKey,value[i])); |
| | | if(subSelectionDO == null){ |
| | | log.error("未查询到调查问卷选项,题目名称:" + questnaiteSub.getLabel() + "选项key:" + questnaiteSub.getValues()); |
| | | ComActQuestnaireSubSelectionDO subSelectionDO = |
| | | questnaireSubSelectionDAO.selectOne(new QueryWrapper<ComActQuestnaireSubSelectionDO>() |
| | | .lambda().eq(ComActQuestnaireSubSelectionDO::getQueSubId, queSubId) |
| | | .eq(ComActQuestnaireSubSelectionDO::getQueId, questId) |
| | | .eq(ComActQuestnaireSubSelectionDO::getKey, value[i])); |
| | | if (subSelectionDO == null) { |
| | | log.error( |
| | | "未查询到调查问卷选项,题目名称:" + questnaiteSub.getLabel() + "选项key:" + questnaiteSub.getValues()); |
| | | continue; |
| | | } |
| | | ComActQuestnaireAnswerContentDO answerContentDO = new ComActQuestnaireAnswerContentDO(); |
| | |
| | | answerContentDO.setAnswerContent(subSelectionDO.getContent()); |
| | | answerContentList.add(answerContentDO); |
| | | } |
| | | }else{ |
| | | //问答题处理 |
| | | } else if (questnaiteSub.getType().equals(QuestnaiteSubVO.type.wenda)) { |
| | | // 问答题处理 |
| | | String values = questnaiteSub.getValues(); |
| | | ComActQuestnaireAnswerContentDO answerContentDO = new ComActQuestnaireAnswerContentDO(); |
| | | answerContentDO.setUserId(userId); |
| | |
| | | } |
| | | } |
| | | } |
| | | //新增用户填写的答卷 |
| | | if(!answerContentList.isEmpty()){ |
| | | // 新增用户填写的答卷 |
| | | if (!answerContentList.isEmpty()) { |
| | | answerContentService.saveBatch(answerContentList); |
| | | |
| | | //更新回答用户数量 |
| | | // 更新回答用户数量 |
| | | Integer joinCount = questnaireDO.getJoinCount(); |
| | | questnaireDO.setJoinCount(joinCount != null ? joinCount + 1 : 1); |
| | | questnaireDAO.updateById(questnaireDO); |
| | | |
| | | //新增用户答题记录 |
| | | // 新增用户答题记录 |
| | | ComActQuestnaireUserAnswerDO userAnswerDO = new ComActQuestnaireUserAnswerDO(); |
| | | userAnswerDO.setQuestnaireId(questId); |
| | | userAnswerDO.setUserId(userId); |
| | |
| | | |
| | | /** |
| | | * 社区后台-查询问卷调查详情 |
| | | * @param questId 问卷id |
| | | * @return 问卷调查详情 |
| | | * |
| | | * @param questId |
| | | * 问卷id |
| | | * @return 问卷调查详情 |
| | | */ |
| | | @Override |
| | | public R getQuesDetailAdmin(Long questId){ |
| | | public R getQuesDetailAdmin(Long questId) { |
| | | QuestnaireDetailAdminVO result = questnaireDAO.getQuesDetailAdmin(questId); |
| | | if(result == null){ |
| | | if (result == null) { |
| | | return R.fail("未查询到该记录"); |
| | | } |
| | | return R.ok(result); |
| | |
| | | |
| | | /** |
| | | * 小程序-问卷调查详情 |
| | | * @param userId 用户id |
| | | * @param questId 问卷id |
| | | * @return 问卷调查详情 |
| | | * |
| | | * @param userId |
| | | * 用户id |
| | | * @param questId |
| | | * 问卷id |
| | | * @return 问卷调查详情 |
| | | */ |
| | | @Override |
| | | public R getQuesDetail(Long questId,Long userId){ |
| | | QuestnaireDetailAdminVO result = questnaireDAO.getQuesDetail(questId,userId); |
| | | if(result == null){ |
| | | public R getQuesDetail(Long questId, Long userId) { |
| | | QuestnaireDetailAdminVO result = questnaireDAO.getQuesDetail(questId, userId); |
| | | if (result == null) { |
| | | return R.fail("未查询到该记录"); |
| | | } |
| | | ComActQuestnaireUserAnswerDO oldUserAnswerDO = comActQuestnaireUserAnswerMapper.selectOne(new QueryWrapper<ComActQuestnaireUserAnswerDO>().lambda() |
| | | .eq(ComActQuestnaireUserAnswerDO::getQuestnaireId,questId).eq(ComActQuestnaireUserAnswerDO::getUserId,userId)); |
| | | if(oldUserAnswerDO != null){ |
| | | ComActQuestnaireUserAnswerDO oldUserAnswerDO = |
| | | comActQuestnaireUserAnswerMapper.selectOne(new QueryWrapper<ComActQuestnaireUserAnswerDO>().lambda() |
| | | .eq(ComActQuestnaireUserAnswerDO::getQuestnaireId, questId) |
| | | .eq(ComActQuestnaireUserAnswerDO::getUserId, userId)); |
| | | if (oldUserAnswerDO != null) { |
| | | result.setIsOk(1); |
| | | } |
| | | |
| | |
| | | |
| | | /** |
| | | * 问卷调查统计汇总 |
| | | * @param summaryDTO 请求参数 |
| | | * @return 统计汇总 |
| | | * |
| | | * @param summaryDTO |
| | | * 请求参数 |
| | | * @return 统计汇总 |
| | | */ |
| | | @Override |
| | | public R statisticsSummary(StatisticsSummaryDTO summaryDTO){ |
| | | IPage<QuestnaireStatisticsSummaryAdminVO> summaryAdminList = questnaireDAO.getStatisticsSummaryAdmin(new Page(summaryDTO.getPageNum(),summaryDTO.getPageSize()),summaryDTO); |
| | | public R statisticsSummary(StatisticsSummaryDTO summaryDTO) { |
| | | IPage<QuestnaireStatisticsSummaryAdminVO> summaryAdminList = questnaireDAO |
| | | .getStatisticsSummaryAdmin(new Page(summaryDTO.getPageNum(), summaryDTO.getPageSize()), summaryDTO); |
| | | summaryAdminList.getRecords().forEach(summary -> { |
| | | if(summary.getAllCount().equals(0)){ |
| | | if (summary.getAllCount().equals(0)) { |
| | | summary.setTag(BigDecimal.ZERO); |
| | | }else{ |
| | | summary.setTag(BigDecimal.valueOf(summary.getCount()).divide(BigDecimal.valueOf(summary.getAllCount()),2, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100))); |
| | | } else { |
| | | summary.setTag(BigDecimal.valueOf(summary.getCount()) |
| | | .divide(BigDecimal.valueOf(summary.getAllCount()), 2, RoundingMode.HALF_UP) |
| | | .multiply(BigDecimal.valueOf(100))); |
| | | } |
| | | }); |
| | | return R.ok(summaryAdminList); |
| | |
| | | |
| | | /** |
| | | * 问卷调查统计汇总导出数据查询 |
| | | * @param questId 调查问卷id |
| | | * @return 调查统计汇总导出数据 |
| | | * |
| | | * @param questId |
| | | * 调查问卷id |
| | | * @return 调查统计汇总导出数据 |
| | | */ |
| | | @Override |
| | | public R statisticsSummaryExport(Long questId){ |
| | | List<QuestnaireStatisticsSummaryExcelAdminVO> summaryExcelList = questnaireDAO.getStatisticsSummaryExcelAdmin(questId); |
| | | public R statisticsSummaryExport(Long questId) { |
| | | List<QuestnaireStatisticsSummaryExcelAdminVO> summaryExcelList = |
| | | questnaireDAO.getStatisticsSummaryExcelAdmin(questId); |
| | | summaryExcelList.forEach(summary -> { |
| | | if(summary.getAllCount().equals(0)){ |
| | | if (summary.getAllCount().equals(0)) { |
| | | summary.setTag(BigDecimal.ZERO); |
| | | }else{ |
| | | summary.setTag(BigDecimal.valueOf(summary.getCount()).divide(BigDecimal.valueOf(summary.getAllCount()),2, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100))); |
| | | } else { |
| | | summary.setTag(BigDecimal.valueOf(summary.getCount()) |
| | | .divide(BigDecimal.valueOf(summary.getAllCount()), 2, RoundingMode.HALF_UP) |
| | | .multiply(BigDecimal.valueOf(100))); |
| | | } |
| | | }); |
| | | return R.ok(summaryExcelList); |
| | |
| | | |
| | | /** |
| | | * 问卷调查统计汇总表头统计 |
| | | * @param questId 调查问卷id |
| | | * @return 问卷调查统计汇总表头统计数据 |
| | | * |
| | | * @param questId |
| | | * 调查问卷id |
| | | * @return 问卷调查统计汇总表头统计数据 |
| | | */ |
| | | @Override |
| | | public R statisticsSummaryHeader(Long questId,Long communityId){ |
| | | QuestnaireStatisticsSummaryHeaderAdminVO summaryHeaderAdminVO = this.questnaireDAO.statisticsSummaryHeader(questId,communityId); |
| | | if(summaryHeaderAdminVO != null){ |
| | | if(!summaryHeaderAdminVO.getUserCount().equals(0)){ |
| | | public R statisticsSummaryHeader(Long questId, Long communityId) { |
| | | QuestnaireStatisticsSummaryHeaderAdminVO summaryHeaderAdminVO = |
| | | this.questnaireDAO.statisticsSummaryHeader(questId, communityId); |
| | | if (summaryHeaderAdminVO != null) { |
| | | if (!summaryHeaderAdminVO.getUserCount().equals(0)) { |
| | | BigDecimal nub1 = BigDecimal.valueOf(summaryHeaderAdminVO.getAllCount()); |
| | | BigDecimal nub2 = BigDecimal.valueOf(summaryHeaderAdminVO.getUserCount()); |
| | | BigDecimal result = nub1.divide(nub2,2,RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)); |
| | | BigDecimal result = nub1.divide(nub2, 2, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)); |
| | | summaryHeaderAdminVO.setTag(result); |
| | | } |
| | | } |
| | |
| | | */ |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public R timedTaskQuestionnaire(){ |
| | | public R timedTaskQuestionnaire() { |
| | | Date nowDate = new Date(); |
| | | //查询所有开始时间已经超过当前时间的待发布状态调查问卷 |
| | | List<ComActQuestnaireDO> questnaireDOList = questnaireDAO.selectList(new QueryWrapper<ComActQuestnaireDO>().lambda() |
| | | .eq(ComActQuestnaireDO::getState,ComActQuestnaireDO.state.dfb).eq(ComActQuestnaireDO::getIsHide,0) |
| | | .le(ComActQuestnaireDO::getStartTime,nowDate)); |
| | | // 查询所有开始时间已经超过当前时间的待发布状态调查问卷 |
| | | List<ComActQuestnaireDO> questnaireDOList = questnaireDAO.selectList(new QueryWrapper<ComActQuestnaireDO>() |
| | | .lambda().eq(ComActQuestnaireDO::getState, ComActQuestnaireDO.state.dfb) |
| | | .eq(ComActQuestnaireDO::getIsHide, 0).le(ComActQuestnaireDO::getStartTime, nowDate)); |
| | | questnaireDOList.forEach(questnaire -> { |
| | | questnaire.setState(ComActQuestnaireDO.state.dyz); |
| | | questnaire.setPublishTime(nowDate); |
| | | questnaireDAO.updateById(questnaire); |
| | | }); |
| | | |
| | | //查询所有结束时间已经超过当前时间的调研中状态调查问卷 |
| | | List<ComActQuestnaireDO> questnaireList = questnaireDAO.selectList(new QueryWrapper<ComActQuestnaireDO>().lambda() |
| | | .eq(ComActQuestnaireDO::getState,ComActQuestnaireDO.state.dyz).eq(ComActQuestnaireDO::getIsHide,0) |
| | | .le(ComActQuestnaireDO::getEndTime,nowDate)); |
| | | // 查询所有结束时间已经超过当前时间的调研中状态调查问卷 |
| | | List<ComActQuestnaireDO> questnaireList = questnaireDAO.selectList(new QueryWrapper<ComActQuestnaireDO>() |
| | | .lambda().eq(ComActQuestnaireDO::getState, ComActQuestnaireDO.state.dyz) |
| | | .eq(ComActQuestnaireDO::getIsHide, 0).le(ComActQuestnaireDO::getEndTime, nowDate)); |
| | | questnaireList.forEach(questnaire -> { |
| | | questnaire.setState(ComActQuestnaireDO.state.yjs); |
| | | questnaireDAO.updateById(questnaire); |
| | |
| | | |
| | | /** |
| | | * 小程序-新增问卷调查浏览数量 |
| | | * @param questId 问卷调查id |
| | | * @return 增加结果 |
| | | * |
| | | * @param questId |
| | | * 问卷调查id |
| | | * @return 增加结果 |
| | | */ |
| | | @Override |
| | | public R addQuestnaireView(Long questId){ |
| | | public R addQuestnaireView(Long questId) { |
| | | ComActQuestnaireDO questnaireDO = questnaireDAO.selectById(questId); |
| | | if(questnaireDO != null){ |
| | | if (questnaireDO != null) { |
| | | questnaireDO.setViewNum(questnaireDO.getViewNum() + 1); |
| | | questnaireDAO.updateById(questnaireDO); |
| | | } |
| | |
| | | |
| | | /** |
| | | * 小程序-用户弹窗添加不在提醒接口 |
| | | * @param questId 问卷id |
| | | * @param userId 用户id |
| | | * @return 添加结果 |
| | | * |
| | | * @param questId |
| | | * 问卷id |
| | | * @param userId |
| | | * 用户id |
| | | * @return 添加结果 |
| | | */ |
| | | @Override |
| | | public R addNoNotice(Long questId,Long userId){ |
| | | questnaireDAO.addNoNotice(questId,userId); |
| | | public R addNoNotice(Long questId, Long userId) { |
| | | questnaireDAO.addNoNotice(questId, userId); |
| | | return R.ok(); |
| | | } |
| | | |