From 619bcd6c8cc1672b82db763779fcf98c563a3ccb Mon Sep 17 00:00:00 2001 From: manailin <261030956@qq.com> Date: 星期三, 04 八月 2021 17:11:53 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/test' into test --- springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActActivityServiceImpl.java | 68 ++++++++++++++++++++++++++++++++-- 1 files changed, 64 insertions(+), 4 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActActivityServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActActivityServiceImpl.java index 3ec2052..99f60c5 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActActivityServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActActivityServiceImpl.java @@ -1,13 +1,20 @@ package com.panzhihua.service_community.service.impl; +import com.alibaba.fastjson.JSONArray; +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.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.panzhihua.common.model.dtos.community.ExcelElderAuthDTO; +import com.panzhihua.common.model.dtos.community.bigscreen.work.ScreenActActivityListDTO; +import com.panzhihua.common.model.dtos.community.bigscreen.work.ScreenActActivityPeopleListDTO; import com.panzhihua.common.model.vos.IndexDataVO; import com.panzhihua.common.model.vos.LoginUserInfoVO; import com.panzhihua.common.model.vos.R; import com.panzhihua.common.model.vos.community.*; +import com.panzhihua.common.model.vos.community.screen.work.ActActivityListVO; import com.panzhihua.common.service.user.UserService; import com.panzhihua.service_community.dao.ComActActSignDAO; import com.panzhihua.service_community.dao.ComActActivityDAO; @@ -183,7 +190,14 @@ public ComActActivityVO inforActivity(Long id, Long userId) { ComActActivityVO comActActivityVO=comActActivityDAO.inforActivity(id); if (!ObjectUtils.isEmpty(comActActivityVO)) { - ComActActSignDO comActActSignDO = comActActSignDAO.selectOne(new QueryWrapper<ComActActSignDO>().lambda().eq(ComActActSignDO::getActivityId, id).eq(ComActActSignDO::getUserId, userId)); + + LambdaQueryWrapper<ComActActSignDO> actSignQuery = new LambdaQueryWrapper<>(); + actSignQuery.eq(ComActActSignDO::getActivityId, id); + if(userId != null){ + actSignQuery.eq(ComActActSignDO::getUserId, userId); + } + + ComActActSignDO comActActSignDO = comActActSignDAO.selectOne(actSignQuery); if (!ObjectUtils.isEmpty(comActActSignDO)) { comActActivityVO.setIsSign(1); comActActivityVO.setIsVolunteer(comActActSignDO.getIsVolunteer()); @@ -202,7 +216,15 @@ */ @Override public R listActivitySign(ActivitySignVO activitySignVO) { - List<ActivitySignVO> activitySignVOS = comActActSignDAO.listActivitySign(activitySignVO); + + IPage<ActivitySignVO> activitySignVOS = comActActSignDAO.listActivitySign(new Page(activitySignVO.getPageNum(),activitySignVO.getPageSize()),activitySignVO); +// List<ActivitySignVO> activitySignVOS = comActActSignDAO.listActivitySign(activitySignVO); + return R.ok(activitySignVOS); + } + + @Override + public R listActivitySigns(ActivitySignVO activitySignVO) { + List<ActivitySignVO> activitySignVOS = comActActSignDAO.listActivitySigns(activitySignVO); return R.ok(activitySignVOS); } @@ -245,10 +267,25 @@ int num=0; if (1==type) { R<LoginUserInfoVO> userInfoR = userService.getUserInfoByUserId(String.valueOf(userId)); - LoginUserInfoVO loginUserInfoVO = userInfoR.getData(); + LoginUserInfoVO loginUserInfoVO = JSONObject.parseObject(JSONObject.toJSONString(userInfoR.getData()), LoginUserInfoVO.class); boolean userNotVolunteer = !(loginUserInfoVO.getIsVolunteer()==1); if(isVolunteer == 1 && userNotVolunteer){ return R.fail("只有志愿者才能报名"); + } + + //查询社区活动 + ComActActivityDO actActivityDO = this.baseMapper.selectById(activityId); + if(actActivityDO != null){ + //查询当前活动下参与志愿者/居民数量 + Integer count = comActActSignDAO.selectCount(new QueryWrapper<ComActActSignDO>().lambda().eq(ComActActSignDO::getActivityId,activityId) + .eq(ComActActSignDO::getIsVolunteer,isVolunteer)); + if(isVolunteer.equals(1) && actActivityDO.getVolunteerMax() <= count && !actActivityDO.getVolunteerMax().equals(-1)){ + return R.fail("志愿者报名人数已满"); + } + + if(isVolunteer.equals(0) && actActivityDO.getParticipantMax() <= count && !actActivityDO.getParticipantMax().equals(-1)){ + return R.fail("居民报名人数已满"); + } } ComActActSignDO comActActSignDO=new ComActActSignDO(); @@ -368,12 +405,14 @@ // 修改报名状态 变为报名中 int num1=comActActivityDAO.updateStatusToBeginSign(); log.info("定时任务--修改社区活动报名状态活动数量【{}】",num1); + //查询已经结束的活动,需要计算积分 + List<Long> activityEndIds = comActActivityDAO.getActivityEndIds(); // 修改进行状态 变为进行中或者已结束 int num2=comActActivityDAO.updateStatusToBeginActiveOrEnd(); log.info("定时任务--修改社区活动进行状态活动数量【{}】",num2); int num3=comActActivityDAO.updateStatusToBeginAfterSingEnd(); log.info("定时任务--报名结束修改社区活动进行状态活动数量【{}】",num3); - return R.ok(); + return R.ok(activityEndIds); } /** @@ -426,6 +465,27 @@ return R.ok(indexDataVO); } + @Override + public R getScreenActActivityList(ScreenActActivityListDTO actActivityListDTO){ + IPage<ActActivityListVO> actActivityListVOIPage = comActActivityDAO.getScreenActActivityList( + new Page(actActivityListDTO.getPageNum(),actActivityListDTO.getPageSize()),actActivityListDTO); + if(!actActivityListVOIPage.getRecords().isEmpty()){ + actActivityListVOIPage.getRecords().forEach(actActivityListVO -> { + ActActivityListVO activityListVO = comActActivityDAO.getScreenActActivityPeopleCount(actActivityListVO.getId()); + if(activityListVO != null){ + actActivityListVO.setParticipantCount(activityListVO.getParticipantCount()); + actActivityListVO.setVolunteerCount(activityListVO.getVolunteerCount()); + } + }); + } + return R.ok(actActivityListVOIPage); + } + + @Override + public R getActActivityPeopleList(ScreenActActivityPeopleListDTO activityPeopleListDTO){ + return R.ok(comActActSignDAO.getActActivityPeopleList(new Page(activityPeopleListDTO.getPageNum(),activityPeopleListDTO.getPageSize()),activityPeopleListDTO)); + } + /** * 获取最近七天的时间 * @return -- Gitblit v1.7.1