|  |  |  | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.property.CommonPage; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.*; | 
|---|
|  |  |  | import org.apache.ibatis.annotations.Mapper; | 
|---|
|  |  |  | import org.apache.ibatis.annotations.Param; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.PageBaseDTO; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.community.bigscreen.work.ScreenActActivityListDTO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.*; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.ComActActivityStatisticsVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.ComActActivityTypeVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.ComActActivityVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.CommunityActivitiesVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.PartyActivityStatics; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.PartyActivityTypeChart; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.StatisticsCommVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.community.screen.work.ActActivityListVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.screen.CarouselInfoVO; | 
|---|
|  |  |  | import com.panzhihua.service_community.model.dos.ComActActivityDO; | 
|---|
|  |  |  | 
|---|
|  |  |  | // " </if> " + | 
|---|
|  |  |  | // " </where>" + | 
|---|
|  |  |  | // "</script>") | 
|---|
|  |  |  | @Select("<script> " + "SELECT  " + "a.id, " + "a.activity_name, " + "u.`name` sponsorName, " | 
|---|
|  |  |  | + "a.activity_addr, " + "a.aattend_people," | 
|---|
|  |  |  | + "a.`status`, " + "a.is_qr_code, " + "a.publish_at, " + "a.begin_at, " + "a.cover, " + "a.end_at, " + "a.volunteer_max, " | 
|---|
|  |  |  | + "count(if(s.is_volunteer=1,s.id,null))volunteer_now, " | 
|---|
|  |  |  | + "count(if(s.is_volunteer=0,s.id,null))participant_now, " + "a.participant_max, " + "a.sign_up_begin, " | 
|---|
|  |  |  | + "a.sign_up_end, " + "ca.name as communityName  " + "FROM " + "com_act_activity a  " | 
|---|
|  |  |  | + "left join sys_user u on a.sponsor_id=u.user_id " + "left join (select * from com_act_act_sign where `status` = 1) s on a.id=s.activity_id  " | 
|---|
|  |  |  | + "left join com_act ca on a.community_id=ca.community_id  " + " where 1=1 " + | 
|---|
|  |  |  |  | 
|---|
|  |  |  | "<if test='comActActivityVO.choice == 0 '>" + "AND a.community_id = ${comActActivityVO.communityId} " + " </if> " | 
|---|
|  |  |  | + | 
|---|
|  |  |  | "<if test='comActActivityVO.areaCode !=null '>" + "AND ca.area_code = ${comActActivityVO.areaCode} " + " </if> " | 
|---|
|  |  |  | + | 
|---|
|  |  |  |  | 
|---|
|  |  |  | "<if test='comActActivityVO.activityName != null and comActActivityVO.activityName.trim() != ""'>" | 
|---|
|  |  |  | + " and a.activity_name like concat(#{comActActivityVO.activityName},'%')   " + " </if> " | 
|---|
|  |  |  | + "<if test='comActActivityVO.status != null and comActActivityVO.status !=0 and comActActivityVO.isIng==null'>" | 
|---|
|  |  |  | + "AND a.`status` = #{comActActivityVO.status}  " + " </if> " | 
|---|
|  |  |  | + "<if test='comActActivityVO.status != null and comActActivityVO.status !=0 and comActActivityVO.isIng!=null and comActActivityVO.isIng==1'>" | 
|---|
|  |  |  | + "AND a.`status` in (3,4)  " + " </if> " | 
|---|
|  |  |  | + "<if test='comActActivityVO.isApplets != null and comActActivityVO.isApplets ==1'>" | 
|---|
|  |  |  | + "AND a.`status` != 1 AND  a.`status` != 6   " + " </if> " + "<if test='comActActivityVO.beginAt != null '>" | 
|---|
|  |  |  | + "AND a.begin_at <![CDATA[ >= ]]> #{comActActivityVO.beginAt} AND a.end_at <![CDATA[ <= ]]> #{comActActivityVO.endAt}  " | 
|---|
|  |  |  | + " </if> " + "<if test='comActActivityVO.type != null'>" | 
|---|
|  |  |  | + "AND a.type=#{comActActivityVO.type} " + " </if> " | 
|---|
|  |  |  | + " group by a.id " + " order by a.status asc,a.publish_at desc " + "</script>") | 
|---|
|  |  |  | //    @Select("<script> " + "SELECT  " + "a.id, " + "a.activity_name, " + "u.`name` sponsorName, " | 
|---|
|  |  |  | //        + "a.activity_addr, " + "a.aattend_people," | 
|---|
|  |  |  | //        + "a.`status`, " + "a.is_qr_code, " + "a.publish_at, " + "a.begin_at, " + "a.cover, " + "a.end_at, " + "a.volunteer_max, " | 
|---|
|  |  |  | //        + "count(if(s.is_volunteer=1,s.id,null))volunteer_now, " | 
|---|
|  |  |  | //        + "count(if(s.is_volunteer=0,s.id,null))participant_now, " + "a.participant_max, " + "a.sign_up_begin, " | 
|---|
|  |  |  | //        + "a.sign_up_end, " + "ca.name as communityName,a.type,a.party_member_max  " + "FROM " + "com_act_activity a  " | 
|---|
|  |  |  | //        + "left join sys_user u on a.sponsor_id=u.user_id " + "left join (select * from com_act_act_sign where `status` = 1) s on a.id=s.activity_id  " | 
|---|
|  |  |  | //        + "left join com_act ca on a.community_id=ca.community_id  " + " where 1=1 " + | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //        "<if test='comActActivityVO.communityId != null and comActActivityVO.communityId!=0'>" + "AND a.community_id = ${comActActivityVO.communityId} " + " </if> " | 
|---|
|  |  |  | //        + | 
|---|
|  |  |  | //            "<if test='comActActivityVO.phone != null and comActActivityVO.phone!=""'>" + "AND a.phone = ${comActActivityVO.phone} " + " </if> " | 
|---|
|  |  |  | //            + | 
|---|
|  |  |  | //        "<if test='comActActivityVO.areaCode !=null '>" + "AND ca.area_code = ${comActActivityVO.areaCode} " + " </if> " | 
|---|
|  |  |  | //        + | 
|---|
|  |  |  | //        "<if test='comActActivityVO.checkUnitId !=null '>" + "AND a.check_unit_id = #{comActActivityVO.checkUnitId} " + " </if> " | 
|---|
|  |  |  | //        + | 
|---|
|  |  |  | //        "<if test='comActActivityVO.activityName != null and comActActivityVO.activityName.trim() != ""'>" | 
|---|
|  |  |  | //        + " and a.activity_name like concat(#{comActActivityVO.activityName},'%')   " + " </if> " | 
|---|
|  |  |  | //        + "<if test='comActActivityVO.status != null and comActActivityVO.status !=0 and comActActivityVO.isIng==null'>" | 
|---|
|  |  |  | //        + "AND a.`status` = #{comActActivityVO.status}  " + " </if> " | 
|---|
|  |  |  | //        + "<if test='comActActivityVO.status != null and comActActivityVO.status !=0 and comActActivityVO.isIng!=null and comActActivityVO.isIng==1'>" | 
|---|
|  |  |  | //        + "AND a.`status` in (3,4)  " + " </if> " | 
|---|
|  |  |  | //        + "<if test='comActActivityVO.isApplets != null and comActActivityVO.isApplets ==1'>" | 
|---|
|  |  |  | //        + "AND a.`status` != 1 AND  a.`status` != 6   " + " </if> " + "<if test='comActActivityVO.beginAt != null '>" | 
|---|
|  |  |  | //        + "AND a.begin_at <![CDATA[ >= ]]> #{comActActivityVO.beginAt} AND a.end_at <![CDATA[ <= ]]> #{comActActivityVO.endAt}  " | 
|---|
|  |  |  | //        + " </if> " + "<if test='comActActivityVO.type != null'>" | 
|---|
|  |  |  | //        + "AND a.type=#{comActActivityVO.type} " + " </if> " | 
|---|
|  |  |  | //        + " group by a.id " + " ORDER BY a.status = 99 desc,a.publish_at DESC " + "</script>") | 
|---|
|  |  |  | IPage<ComActActivityVO> pageActivity(Page page, @Param("comActActivityVO") ComActActivityVO comActActivityVO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    @Select("SELECT  " + "u.name sponsorName, " + "ca.name communityName, " | 
|---|
|  |  |  | 
|---|
|  |  |  | + "</foreach> " + "</script>") | 
|---|
|  |  |  | int updateIdBatch(@Param("longs") List<Long> longs); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update("update com_act_activity set `status`=3 where `status`=1 and TIMESTAMPDIFF(MINUTE,SYSDATE(),publish_at)<=0") | 
|---|
|  |  |  | @Update("update com_act_activity set `status`=3 where `status`=1 and TIMESTAMPDIFF(MINUTE,SYSDATE(),begin_at )<=0") | 
|---|
|  |  |  | int updateStatusToNotBegin(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update("update com_act_activity set `status`=3 where `status`=2 and TIMESTAMPDIFF(MINUTE,SYSDATE(),sign_up_begin)<=0") | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update("update com_act_activity set `status`=5 where `status` in (3,4) and TIMESTAMPDIFF(MINUTE,SYSDATE(),end_at)<=0") | 
|---|
|  |  |  | int updateStatusToBeginActiveOrEnd(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("select id from com_act_activity   where `status`=3 and TIMESTAMPDIFF(MINUTE,SYSDATE(),sign_up_end)<=0") | 
|---|
|  |  |  | List<Long> selectBeginIds(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //    @Select("<script> " + "select t.* from ( " + "SELECT  " + "a.id, " + "a.activity_name, " + "u.`name` sponsorName, " | 
|---|
|  |  |  | //        + "a.activity_addr, " + "a.participant_max, " + "count(if(s.is_volunteer=1,null,s.id))participant_now, " | 
|---|
|  |  |  | 
|---|
|  |  |  | @Select("SELECT " + " count( caa.id ) as totalNum, " | 
|---|
|  |  |  | + " (select count(id) from com_act_activity where `status` IN (1,2,3,4,5) and volunteer_min = 0 and community_id = ${communityId}) as commonNum, " | 
|---|
|  |  |  | + " (select count(id) from com_act_activity where `status` IN (1,2,3,4,5) and volunteer_min > 0 and community_id = ${communityId}) as volunteerNum, " | 
|---|
|  |  |  | + " (select count(caas.user_id) from (select * from com_act_act_sign where `status` = 1) as caas left join com_act_activity as caa on caa.id = caas.activity_id where caa.`status` IN (1,2,3,4,5) and is_volunteer = 0 and caa.community_id = ${communityId}) as commonPeopleNum, " | 
|---|
|  |  |  | + " (select count(caas.user_id) from (select * from com_act_act_sign where `status` = 1) as caas left join com_act_activity as caa on caa.id = caas.activity_id where caa.`status` IN (1,2,3,4,5) and is_volunteer = 1 and caa.community_id = ${communityId}) as volunteerPeopleNum, " | 
|---|
|  |  |  | + " (select count(caas.user_id) from (select * from com_act_act_sign where `status` = 1) as caas left join com_act_activity as caa on caa.id = caas.activity_id where caa.`status` IN (1,2,3,4,5) and caas.sign_identity != 3 and caa.community_id = ${communityId}) as commonPeopleNum, " | 
|---|
|  |  |  | + " (select count(caas.user_id) from (select * from com_act_act_sign where `status` = 1) as caas left join com_act_activity as caa on caa.id = caas.activity_id where caa.`status` IN (1,2,3,4,5) and caas.sign_identity = 3 and caa.community_id = ${communityId}) as volunteerPeopleNum, " | 
|---|
|  |  |  | + " (select count(id) from com_act_activity where `status` IN (1,2,3,4,5) and community_id = ${communityId} and create_at between date_sub(curdate() - day(curdate()) +1,interval 1 month) and now()) as currentNum " | 
|---|
|  |  |  | + "FROM " + " com_act_activity AS caa  " + "WHERE " | 
|---|
|  |  |  | + " caa.`status` IN (1,2,3,4,5) and community_id = ${communityId}") | 
|---|
|  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据社工id查询活动列表 | 
|---|
|  |  |  | * @param page | 
|---|
|  |  |  | * @param id | 
|---|
|  |  |  | * @param commonPage | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | IPage<ActActivityListVO> selectActivityBySocialWorker(Page page,@Param("id")Long id); | 
|---|
|  |  |  | IPage<ComActActivityVO> selectActivityBySocialWorker(Page page,@Param("commonPage") CommonPage commonPage); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * [方法描述] 根据社区ID查询所属城市所在区区域代码, | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param communityId | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | PartyActivityStatics selectActivityStatics(Long communityId); | 
|---|
|  |  |  | PartyActivityStatics selectActivityStatics(@Param("communityIds") List<Long> communityIds); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 党员活动饼状图 | 
|---|
|  |  |  | * @param communityId | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | List<PartyActivityTypeChart> selectActivityChart(Long communityId); | 
|---|
|  |  |  | List<PartyActivityTypeChart> selectActivityChart(@Param("communityIds") List<Long> communityIds); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 党员活动柱状图 | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param date | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Integer selectActivityLine(@Param("communityId") Long communityId,@Param("year")String year,@Param("date")String date); | 
|---|
|  |  |  | Integer selectActivityLine(@Param("communityIds") List<Long> communityIds,@Param("year")String year,@Param("date")String date); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 分页查询党员详情活动 | 
|---|
|  |  |  | * @param page | 
|---|
|  |  |  | * @param commonPage | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | IPage<PartyMemberDetailVO> partyMemberDetail(Page page,@Param("commonPage") CommonPage commonPage); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 导出党员详情活动 | 
|---|
|  |  |  | * @param commonPage | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | List<PartyMemberDetailExcelVO> exportPartyMemberDetail(@Param("commonPage") CommonPage commonPage); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<ComActActivityVO> selectListByRelationId(@Param("relationId") Long relationId,@Param("date")String date); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 查询进行中活动 | 
|---|
|  |  |  | * @param communityId 社区id | 
|---|
|  |  |  | * @return 活动列表 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | List<ComActActivityVO> selectListByCommunityId(@Param("communityId") Long communityId,@Param("date") String date,@Param("phone")String phone); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取项目活动 | 
|---|
|  |  |  | * @param page | 
|---|
|  |  |  | * @param comActActivityVO | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | IPage<ComActActivityVO> pageProjectActivity(@Param("page") Page page, @Param("comActActivityVO") ComActActivityVO comActActivityVO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<String> selectOpenIdByActivityId(Long id); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 大屏社区活动列表 | 
|---|
|  |  |  | * @param page | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | IPage<ComActActivityBigScreenVO> pageActivityBigScreen(@Param("page") Page page); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|