|  |  |  | 
|---|
|  |  |  | package com.panzhihua.service_community.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.hutool.core.collection.ListUtil; | 
|---|
|  |  |  | import cn.hutool.core.date.DateUtil; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.LoginUserInfoVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.common.ComPbCheckUnitVo; | 
|---|
|  |  |  | import com.panzhihua.common.service.user.UserService; | 
|---|
|  |  |  | import com.panzhihua.service_community.service.ComActNeighborCircleTopicService; | 
|---|
|  |  |  | import org.apache.commons.lang3.ObjectUtils; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.hutool.core.util.PageUtil; | 
|---|
|  |  |  | import cn.hutool.core.collection.CollUtil; | 
|---|
|  |  |  | import cn.hutool.core.collection.ListUtil; | 
|---|
|  |  |  | import cn.hutool.core.util.PageUtil; | 
|---|
|  |  |  | 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.service.impl.ServiceImpl; | 
|---|
|  |  |  | import com.panzhihua.common.constants.NeighborCircleConstants; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.neighbor.*; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.PageVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.R; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.neighbor.*; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.user.AdministratorsUserVO; | 
|---|
|  |  |  | import com.panzhihua.common.utlis.DateUtils; | 
|---|
|  |  |  | import com.panzhihua.common.utlis.StringUtils; | 
|---|
|  |  |  | import com.panzhihua.common.service.user.UserService; | 
|---|
|  |  |  | import com.panzhihua.common.utlis.*; | 
|---|
|  |  |  | import com.panzhihua.service_community.dao.*; | 
|---|
|  |  |  | import com.panzhihua.service_community.entity.ComPbCheckUnit; | 
|---|
|  |  |  | import com.panzhihua.service_community.entity.SysUser; | 
|---|
|  |  |  | import com.panzhihua.service_community.model.dos.*; | 
|---|
|  |  |  | import com.panzhihua.service_community.service.ComActNeighborCircleBrowseService; | 
|---|
|  |  |  | import com.panzhihua.service_community.service.ComActNeighborCircleService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.panzhihua.service_community.service.ComActNeighborCircleTopicService; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.apache.commons.lang3.ObjectUtils; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @auther lyq | 
|---|
|  |  |  | 
|---|
|  |  |  | private ComPbMemberDAO comPbMemberDAO; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ComActNeighborCircleDAO comActNeighborCircleDAO; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ComActActivityDAO comActActivityDAO; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ComPbCheckUnitDao comPbCheckUnitDao; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private SysUserDao sysUserDao; | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 分页查询邻里圈列表 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | Long communityId = neighborCircleAppDTO.getCommunityId(); | 
|---|
|  |  |  | if(null != communityId){ | 
|---|
|  |  |  | List<Long> communityIds = comActDAO.selectIds(communityId); | 
|---|
|  |  |  | if (CollUtil.isEmpty(communityIds)) { | 
|---|
|  |  |  | communityIds = new ArrayList<>(); | 
|---|
|  |  |  | communityIds.add(communityId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | neighborCircleAppDTO.setCommunityIds(communityIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Page userPage = new Page(neighborCircleAppDTO.getPageNum(), neighborCircleAppDTO.getPageSize()); | 
|---|
|  |  |  | IPage<ComActNeighborCircleAppVO> doPager = this.baseMapper.pageNeighborByApp(userPage, neighborCircleAppDTO); | 
|---|
|  |  |  | if (!doPager.getRecords().isEmpty()) { | 
|---|
|  |  |  | 
|---|
|  |  |  | if (StringUtils.isNotEmpty(addNeighborCircleAppDTO.getPhone())) { | 
|---|
|  |  |  | neighborCircleDO.setReleasePhone(addNeighborCircleAppDTO.getPhone()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //判断当前邻里圈是否需要审核 | 
|---|
|  |  |  | if(addNeighborCircleAppDTO.getIsExamine().equals(AddComActNeighborCircleAppDTO.isExamine.no)){ | 
|---|
|  |  |  | //当邻里圈不需要审核才进入自动审核 | 
|---|
|  |  |  | 
|---|
|  |  |  | circleDetailAppVO.setName(actDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(circleDetailAppVO.getOrderType()!=null){ | 
|---|
|  |  |  | if(circleDetailAppVO.getOrderType()==2){ | 
|---|
|  |  |  | AdministratorsUserVO user1 = this.baseMapper.selectUserByUserId(circleDetailAppVO.getSolveId()); | 
|---|
|  |  |  | circleDetailAppVO.setSolveName(SensitiveUtil.replaceName(user1.getName())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(circleDetailAppVO.getOrderType()==1){ | 
|---|
|  |  |  | ComPbCheckUnit comPbCheckUnit=comPbCheckUnitDao.selectById(circleDetailAppVO.getSolveUnitId()); | 
|---|
|  |  |  | if(comPbCheckUnit!=null){ | 
|---|
|  |  |  | circleDetailAppVO.setSolveName(comPbCheckUnit.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (neighborCircleAppDTO.getUserId() != null) { | 
|---|
|  |  |  | // 查询邻里圈点赞信息 | 
|---|
|  |  |  | 
|---|
|  |  |  | circleDetailAppVO.setHaveSign(2); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ComActActivityDO comActActivityDO=comActActivityDAO.selectOne(new QueryWrapper<ComActActivityDO>().lambda().eq(ComActActivityDO::getRelationId,neighborCircleAppDTO.getCircleId())); | 
|---|
|  |  |  | if(comActActivityDO!=null){ | 
|---|
|  |  |  | circleDetailAppVO.setActivityDate(comActActivityDO.getCreateAt()); | 
|---|
|  |  |  | circleDetailAppVO.setActivityId(comActActivityDO.getId()); | 
|---|
|  |  |  | circleDetailAppVO.setActivityName(comActActivityDO.getActivityName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 查询邻里圈下评论列表 | 
|---|
|  |  |  | IPage<ComActNeighborCircleCommentAppVO> circleCommentAppPage = | 
|---|
|  |  |  | comActNeighborCircleCommentDAO.pageNeighborCommentByApp( | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R pageNeighborByAdmin(ComActNeighborCircleAdminDTO neighborCircleAdminDTO) { | 
|---|
|  |  |  | Long communityId = neighborCircleAdminDTO.getCommunityId(); | 
|---|
|  |  |  | if(null != communityId){ | 
|---|
|  |  |  | List<Long> communityIds = comActDAO.selectIds(communityId); | 
|---|
|  |  |  | if (CollUtil.isEmpty(communityIds)) { | 
|---|
|  |  |  | communityIds = new ArrayList<>(); | 
|---|
|  |  |  | communityIds.add(communityId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | neighborCircleAdminDTO.setCommunityIds(communityIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Page page = new Page(neighborCircleAdminDTO.getPageNum(), neighborCircleAdminDTO.getPageSize()); | 
|---|
|  |  |  | IPage<ComActNeighborCircleAdminVO> doPager = this.baseMapper.pageNeighborByAdmin(page, neighborCircleAdminDTO); | 
|---|
|  |  |  | doPager.getRecords().forEach(data -> { | 
|---|
|  |  |  | 
|---|
|  |  |  | ComActNeighborCircleCommentDO circleCommentDO = | 
|---|
|  |  |  | comActNeighborCircleCommentDAO.selectById(fabulousAppDTO.getServiceId()); | 
|---|
|  |  |  | if (circleCommentDO != null) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | circleCommentDO.setFabulousNum(circleCommentDO.getFabulousNum() + 1); | 
|---|
|  |  |  | comActNeighborCircleCommentDAO.updateById(circleCommentDO); | 
|---|
|  |  |  | //计算需要增加的热度值 | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (comActNeighborCircleCommentDAO.insert(circleCommentDO) > 0) { | 
|---|
|  |  |  | SysUser sysUser=sysUserDao.selectOne(new QueryWrapper<SysUser>().lambda().eq(SysUser::getUserId,neighborCircleDO.getSolveId())); | 
|---|
|  |  |  | if(sysUser!=null) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | WxXCXTempSend util = new WxXCXTempSend(); | 
|---|
|  |  |  | if (neighborCircleDO.getBelongType()==2){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你有一条新的评价信息",neighborCircleDO.getReleaseContent().length()>10?neighborCircleDO.getReleaseContent().substring(0,10)+"..":neighborCircleDO.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+neighborCircleDO.getId()+"&type=888"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (neighborCircleDO.getBelongType()==3){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你有一条新的评价信息",neighborCircleDO.getReleaseContent().length()>10?neighborCircleDO.getReleaseContent().substring(0,10)+"..":neighborCircleDO.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+neighborCircleDO.getId()+"&type=777"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return R.fail("评论失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.fail(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (comActNeighborCircleDO.getStatus() == 1) { | 
|---|
|  |  |  | return R.fail("待审核的邻里圈不能删除"); | 
|---|
|  |  |  | return R.fail("待审核的数据不能删除"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 邻里圈删除 | 
|---|
|  |  |  | this.baseMapper.deleteById(id); | 
|---|
|  |  |  | 
|---|
|  |  |  | AdministratorsUserVO user = this.baseMapper.selectUserByUserId(comActNeighborCircleDO.getReleaseId()); | 
|---|
|  |  |  | DetailNeighborCircleAdminVO vo = new DetailNeighborCircleAdminVO(); | 
|---|
|  |  |  | BeanUtils.copyProperties(comActNeighborCircleDO, vo); | 
|---|
|  |  |  | vo.setReleaseName(user.getName()); | 
|---|
|  |  |  | vo.setImageUrl(user.getImageUrl()); | 
|---|
|  |  |  | if(user!=null){ | 
|---|
|  |  |  | vo.setReleaseName(user.getName()); | 
|---|
|  |  |  | vo.setImageUrl(user.getImageUrl()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(comActNeighborCircleDO.getOrderType()!=null){ | 
|---|
|  |  |  | if(comActNeighborCircleDO.getOrderType()==2){ | 
|---|
|  |  |  | AdministratorsUserVO user1 = this.baseMapper.selectUserByUserId(comActNeighborCircleDO.getSolveId()); | 
|---|
|  |  |  | vo.setSolveName(user1.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(comActNeighborCircleDO.getOrderType()==1){ | 
|---|
|  |  |  | ComPbCheckUnit comPbCheckUnit=comPbCheckUnitDao.selectById(comActNeighborCircleDO.getSolveUnitId()); | 
|---|
|  |  |  | if(comPbCheckUnit!=null){ | 
|---|
|  |  |  | vo.setSolveName(comPbCheckUnit.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询话题名称 | 
|---|
|  |  |  | if (comActNeighborCircleDO.getTopicId() != null) { | 
|---|
|  |  |  | 
|---|
|  |  |  | if(StringUtils.isNotEmpty(comActNeighborCircleDO.getComment())){ | 
|---|
|  |  |  | comActNeighborCircleDO.setCommentTime(new Date()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(this.baseMapper.updateById(comActNeighborCircleDO)); | 
|---|
|  |  |  | int result=this.baseMapper.updateById(comActNeighborCircleDO); | 
|---|
|  |  |  | if(result>0){ | 
|---|
|  |  |  | ComActNeighborCircleDO comActNeighborCircleDO1=this.baseMapper.selectById(comActNeighborCircleDO.getId()); | 
|---|
|  |  |  | if(comActNeighborCircleDO.getOrderStatus()!=null){ | 
|---|
|  |  |  | SysUser sysUser=sysUserDao.selectOne(new QueryWrapper<SysUser>().lambda().eq(SysUser::getUserId,comActNeighborCircleDO1.getReleaseId())); | 
|---|
|  |  |  | if(sysUser!=null) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | WxXCXTempSend util = new WxXCXTempSend(); | 
|---|
|  |  |  | if (comActNeighborCircleDO1.getBelongType()==2){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你反馈的问题已被人认领",comActNeighborCircleDO1.getReleaseContent().length()>10?comActNeighborCircleDO1.getReleaseContent().substring(0,10)+"..":comActNeighborCircleDO1.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+comActNeighborCircleDO.getId()+"&type=888"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (comActNeighborCircleDO1.getBelongType()==3){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你反馈的需求已被人认领",comActNeighborCircleDO1.getReleaseContent().length()>10?comActNeighborCircleDO1.getReleaseContent().substring(0,10)+"..":comActNeighborCircleDO1.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+comActNeighborCircleDO.getId()+"&type=777"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(comActNeighborCircleDO.getSolveStatus()==3){ | 
|---|
|  |  |  | SysUser sysUser=sysUserDao.selectOne(new QueryWrapper<SysUser>().lambda().eq(SysUser::getUserId,comActNeighborCircleDO1.getReleaseId())); | 
|---|
|  |  |  | if(sysUser!=null) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | WxXCXTempSend util = new WxXCXTempSend(); | 
|---|
|  |  |  | if (comActNeighborCircleDO1.getBelongType()==2){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你反馈的问题已被人处理",comActNeighborCircleDO1.getReleaseContent().length()>10?comActNeighborCircleDO1.getReleaseContent().substring(0,10)+"..":comActNeighborCircleDO1.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+comActNeighborCircleDO.getId()+"&type=888"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (comActNeighborCircleDO1.getBelongType()==3){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你反馈的需求已被人处理",comActNeighborCircleDO1.getReleaseContent().length()>10?comActNeighborCircleDO1.getReleaseContent().substring(0,10)+"..":comActNeighborCircleDO1.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+comActNeighborCircleDO.getId()+"&type=777"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(comActNeighborCircleDO.getSolveStatus()==4){ | 
|---|
|  |  |  | SysUser sysUser=sysUserDao.selectOne(new QueryWrapper<SysUser>().lambda().eq(SysUser::getUserId,comActNeighborCircleDO1.getSolveId())); | 
|---|
|  |  |  | if(sysUser!=null) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | WxXCXTempSend util = new WxXCXTempSend(); | 
|---|
|  |  |  | if (comActNeighborCircleDO1.getBelongType()==2){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你有一条新的评价信息",comActNeighborCircleDO1.getReleaseContent().length()>10?comActNeighborCircleDO1.getReleaseContent().substring(0,10)+"..":comActNeighborCircleDO1.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+comActNeighborCircleDO.getId()+"&type=888"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (comActNeighborCircleDO1.getBelongType()==3){ | 
|---|
|  |  |  | WxUtil.sendLongTimeTemplate(sysUser.getOpenid(),util.getAccessToken(),"你有一条新的评价信息",comActNeighborCircleDO1.getReleaseContent().length()>10?comActNeighborCircleDO1.getReleaseContent().substring(0,10)+"..":comActNeighborCircleDO1.getReleaseContent(),"packageB/pages/partySecond/problemDetails/index?id="+comActNeighborCircleDO.getId()+"&type=777"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(result); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.fail(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R institutionalUnitServiceAnalysis(Integer year,Long communityId) { | 
|---|
|  |  |  | //根据年份获取一年的开始和结束时间 | 
|---|
|  |  |  | public R serviceStatic(ServiceStaticDTO serviceStaticDTO) { | 
|---|
|  |  |  | ServiceStaticsVO serviceStaticsVO = new ServiceStaticsVO(); | 
|---|
|  |  |  | if (serviceStaticDTO.getCheckUnitId() != null) { | 
|---|
|  |  |  | serviceStaticsVO = | 
|---|
|  |  |  | this.baseMapper.selectStatsCheckUnit(serviceStaticDTO.getCheckUnitId(), serviceStaticDTO.getYear()); | 
|---|
|  |  |  | serviceStaticsVO.setServiceDetailStaticsList(this.baseMapper.selectServiceDetailList(serviceStaticDTO.getCheckUnitId(), | 
|---|
|  |  |  | serviceStaticDTO.getYear(), serviceStaticDTO.getServiceType())); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | serviceStaticsVO = this.baseMapper.selectStatsUser(serviceStaticDTO.getPhone(), serviceStaticDTO.getYear()); | 
|---|
|  |  |  | ComPbMemberDO comPbMemberDO = comPbMemberDAO.selectOne(new QueryWrapper<ComPbMemberDO>().lambda() | 
|---|
|  |  |  | .eq(ComPbMemberDO::getPhone, serviceStaticDTO.getPhone()).last("limit 1")); | 
|---|
|  |  |  | Long checkUnitId = null; | 
|---|
|  |  |  | if (comPbMemberDO != null) { | 
|---|
|  |  |  | checkUnitId = comPbMemberDO.getCheckUnitId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | serviceStaticsVO.setServiceDetailStaticsList(this.baseMapper.selectServiceDetailListForPersonal(checkUnitId, serviceStaticDTO.getPhone(), | 
|---|
|  |  |  | serviceStaticDTO.getYear(), serviceStaticDTO.getServiceType())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(serviceStaticsVO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R institutionalUnitServiceAnalysis(Integer year, Integer type, Integer range, Long communityId,Integer page,Integer size,String belongTo,Long unitId) { | 
|---|
|  |  |  | ActivityAnalysisVO activityVO=new ActivityAnalysisVO(); | 
|---|
|  |  |  | String beginTime=null; | 
|---|
|  |  |  | String endTime=null; | 
|---|
|  |  |  | if (null != year && 0 !=year){ | 
|---|
|  |  |  | beginTime= year.toString()+"-01-01" ; | 
|---|
|  |  |  | endTime=year.toString()+"-12-31"; | 
|---|
|  |  |  | if (null != year){ | 
|---|
|  |  |  | //设置开始,截止时间 | 
|---|
|  |  |  | beginTime=year.toString().concat("-01-01"); | 
|---|
|  |  |  | endTime=year.toString().concat("-12-31"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //根据communityId分组获取活动时长,活动次数 | 
|---|
|  |  |  | List<ComActNeighborCircleAnalysisVO> comActNeighborCircleAnalysisVOS = comActNeighborCircleDAO.institutionalUnitServiceAnalysis(beginTime,endTime,communityId); | 
|---|
|  |  |  | //填充单位,社区信息 | 
|---|
|  |  |  | if (comActNeighborCircleAnalysisVOS.size()>0){ | 
|---|
|  |  |  | for (ComActNeighborCircleAnalysisVO vo : comActNeighborCircleAnalysisVOS) { | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getCommunityId())){ | 
|---|
|  |  |  | vo.setCommunityName(comActDAO.selectById(vo.getCommunityId()).getName()); | 
|---|
|  |  |  | //统计党员,单位总数 | 
|---|
|  |  |  | activityVO.setPartyMemberCount(comActDAO.selectUnitCount()); | 
|---|
|  |  |  | activityVO.setUnitCount(comActDAO.selectMemberCount()); | 
|---|
|  |  |  | //获取单位活动统计数据(邻里圈) | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS = comActNeighborCircleDAO.institutionalUnitServiceAnalysis(beginTime, endTime, belongTo,communityId); | 
|---|
|  |  |  | //获取单位活动统计数据(活动) | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS1 = comActNeighborCircleDAO.institutionalUnitActivityAnalysis(beginTime, endTime, belongTo,communityId); | 
|---|
|  |  |  | if (unitActivityAnalysisVOS.size()>0){ | 
|---|
|  |  |  | for (UnitActivityAnalysisVO unitActivityAnalysisVO : unitActivityAnalysisVOS){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO.getUnitId())){ | 
|---|
|  |  |  | //设置单位名称 | 
|---|
|  |  |  | unitActivityAnalysisVO.setUnitName(comActDAO.selectUnitName(unitActivityAnalysisVO.getUnitId())); | 
|---|
|  |  |  | //统计活动表中的活动信息 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getUnitId())){ | 
|---|
|  |  |  | vo.setUnitName(comActDAO.getUnitName(vo.getUnitId())); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO.getCommunityId())){ | 
|---|
|  |  |  | unitActivityAnalysisVO.setCommunityName(comActDAO.selectById(unitActivityAnalysisVO.getCommunityId()).getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ActivityAnalysisVO activityAnalysisVO=new ActivityAnalysisVO(); | 
|---|
|  |  |  | activityAnalysisVO.setDataList(comActNeighborCircleAnalysisVOS); | 
|---|
|  |  |  | activityAnalysisVO.setUnitCount(comActDAO.getUnitCount()); | 
|---|
|  |  |  | return R.ok(activityAnalysisVO); | 
|---|
|  |  |  | //活动表数据处理 | 
|---|
|  |  |  | if (unitActivityAnalysisVOS1.size()>0){ | 
|---|
|  |  |  | for (UnitActivityAnalysisVO vo : unitActivityAnalysisVOS1) { | 
|---|
|  |  |  | if(ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getUnitId())){ | 
|---|
|  |  |  | //判断邻里圈统计中是否已有该单位数据 | 
|---|
|  |  |  | Map<String, Integer> param = alreadyAnalysis(vo.getUnitId(), unitActivityAnalysisVOS); | 
|---|
|  |  |  | if (param.get("flag")==1){ | 
|---|
|  |  |  | //已有数据,将时长,次数相加 | 
|---|
|  |  |  | Integer serviceTime = vo.getServiceTime(); | 
|---|
|  |  |  | Integer serviceTimes = vo.getServiceTimes(); | 
|---|
|  |  |  | unitActivityAnalysisVOS.get(param.get("index")).setServiceTime(unitActivityAnalysisVOS.get(param.get("index")).getServiceTime()+serviceTime); | 
|---|
|  |  |  | unitActivityAnalysisVOS.get(param.get("index")).setServiceTimes(unitActivityAnalysisVOS.get(param.get("index")).getServiceTimes()+serviceTimes); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | //新数据,获取单位,社区名 | 
|---|
|  |  |  | vo.setUnitName(comActDAO.selectUnitName(vo.getUnitId())); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getCommunityId())) { | 
|---|
|  |  |  | vo.setCommunityName(comActDAO.selectById(vo.getCommunityId()).getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | unitActivityAnalysisVOS.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //获取党员活动统计数据 | 
|---|
|  |  |  | List<PartyMemberAnalysisVO> partyMemberAnalysisVOS = comActNeighborCircleDAO.institutionalPartyMemberServiceAnalysis(beginTime, endTime, belongTo,communityId,unitId); | 
|---|
|  |  |  | List<PartyMemberAnalysisVO> partyMemberAnalysisVOS1 = comActNeighborCircleDAO.institutionalPartyMemberActAnalysis(beginTime, endTime, belongTo,communityId,unitId); | 
|---|
|  |  |  | if (partyMemberAnalysisVOS1.size()>0){ | 
|---|
|  |  |  | for (PartyMemberAnalysisVO vo : partyMemberAnalysisVOS1) { | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getMemberId())){ | 
|---|
|  |  |  | Map<String, Integer> param = memberAlreadyAnalysis(vo.getMemberId(), partyMemberAnalysisVOS); | 
|---|
|  |  |  | if (param.get("flag")==1){ | 
|---|
|  |  |  | Integer serviceTime = vo.getServiceTime(); | 
|---|
|  |  |  | Integer serviceTimes = vo.getServiceTimes(); | 
|---|
|  |  |  | partyMemberAnalysisVOS.get(param.get("index")).setServiceTime(partyMemberAnalysisVOS.get(param.get("index")).getServiceTime()+serviceTime); | 
|---|
|  |  |  | partyMemberAnalysisVOS.get(param.get("index")).setServiceTimes(partyMemberAnalysisVOS.get(param.get("index")).getServiceTimes()+serviceTimes); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | partyMemberAnalysisVOS.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //统计总时长和总次数 | 
|---|
|  |  |  | Integer unitServiceCount=0; | 
|---|
|  |  |  | Integer unitServiceTotalTime=0; | 
|---|
|  |  |  | Integer memberServiceCount=0; | 
|---|
|  |  |  | Integer memberServiceTotalTome=0; | 
|---|
|  |  |  | for (UnitActivityAnalysisVO vo : unitActivityAnalysisVOS) { | 
|---|
|  |  |  | //避免空指针 | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getServiceTime())){ | 
|---|
|  |  |  | unitServiceCount+=vo.getServiceTime(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getServiceTimes())){ | 
|---|
|  |  |  | unitServiceTotalTime+=vo.getServiceTimes(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (PartyMemberAnalysisVO vo : partyMemberAnalysisVOS) { | 
|---|
|  |  |  | //避免空指针 | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getServiceTime())){ | 
|---|
|  |  |  | memberServiceCount+=vo.getServiceTime(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getServiceTimes())){ | 
|---|
|  |  |  | memberServiceTotalTome+=vo.getServiceTimes(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | activityVO.setUnitServiceTotalCount(unitServiceCount); | 
|---|
|  |  |  | activityVO.setUnitServiceTotalTime(unitServiceTotalTime); | 
|---|
|  |  |  | activityVO.setPartyMemberServiceTotalCount(memberServiceCount); | 
|---|
|  |  |  | activityVO.setPartyMemberServiceTotalTime(memberServiceTotalTome); | 
|---|
|  |  |  | //处理排序 | 
|---|
|  |  |  | //        if (null != type){ | 
|---|
|  |  |  | //            if (type.equals(1)){ | 
|---|
|  |  |  | //                //按时长排序 | 
|---|
|  |  |  | //                ListUtil.sortByProperty(unitActivityAnalysisVOS, "serviceTime"); | 
|---|
|  |  |  | //                ListUtil.sortByProperty(partyMemberAnalysisVOS, "serviceTime"); | 
|---|
|  |  |  | //            }else if (type.equals(2)){ | 
|---|
|  |  |  | //                //按次数排序 | 
|---|
|  |  |  | //                ListUtil.sortByProperty(unitActivityAnalysisVOS, "serviceTimes"); | 
|---|
|  |  |  | //                ListUtil.sortByProperty(partyMemberAnalysisVOS, "serviceTimes"); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //处理分页 | 
|---|
|  |  |  | PageVO<List<UnitActivityAnalysisVO>> unitPage=new PageVO<>(); | 
|---|
|  |  |  | PageVO<List<PartyMemberAnalysisVO>> memberPage=new PageVO<>(); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(page) && ObjectUtils.isNotEmpty(size)){ | 
|---|
|  |  |  | //分页处理 | 
|---|
|  |  |  | unitPage.setRecordsCount(unitActivityAnalysisVOS.size()); | 
|---|
|  |  |  | unitPage.setPage(page); | 
|---|
|  |  |  | unitPage.setPages(getPages(unitPage.getRecordsCount(),size )); | 
|---|
|  |  |  | memberPage.setPage(page); | 
|---|
|  |  |  | memberPage.setRecordsCount(partyMemberAnalysisVOS.size()); | 
|---|
|  |  |  | memberPage.setPages(getPages(memberPage.getRecordsCount(), size)); | 
|---|
|  |  |  | //处理分页的结果 | 
|---|
|  |  |  | unitPage.setRecords(subUnitList((ArrayList) unitActivityAnalysisVOS, page,size)); | 
|---|
|  |  |  | memberPage.setRecords(subUnitList((ArrayList)partyMemberAnalysisVOS,page ,size)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | unitPage.setRecords(unitActivityAnalysisVOS); | 
|---|
|  |  |  | memberPage.setRecords(partyMemberAnalysisVOS); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | activityVO.setUnitList(unitPage); | 
|---|
|  |  |  | activityVO.setPartyMemberList(memberPage); | 
|---|
|  |  |  | return R.ok(activityVO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R serviceStaticBackstage(ServiceStaticBackstageDTO serviceStaticDTO) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R selectCount(Integer type, String phone,Long communityId) { | 
|---|
|  |  |  | return R.ok(this.baseMapper.selectCount(type,phone,communityId)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 分页查询可关联清单列表 | 
|---|
|  |  |  | * @param neighborCircleAppDTO | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R pageRelationList(ComActNeighborCircleAppDTO neighborCircleAppDTO) { | 
|---|
|  |  |  | Page userPage = new Page(neighborCircleAppDTO.getPageNum(), neighborCircleAppDTO.getPageSize()); | 
|---|
|  |  |  | IPage<ComActNeighborCircleAppVO> doPager = this.baseMapper.pageRelationList(userPage, neighborCircleAppDTO); | 
|---|
|  |  |  | if (!doPager.getRecords().isEmpty()) { | 
|---|
|  |  |  | for (ComActNeighborCircleAppVO circleAppVO : doPager.getRecords()) { | 
|---|
|  |  |  | if (neighborCircleAppDTO.getUserId() != null) { | 
|---|
|  |  |  | // 查询点赞信息 | 
|---|
|  |  |  | ComActNeighborCircleFabulousDO circleFabulousDO = | 
|---|
|  |  |  | comActNeighborCircleFabulousDAO.selectOne(new QueryWrapper<ComActNeighborCircleFabulousDO>() | 
|---|
|  |  |  | .lambda().eq(ComActNeighborCircleFabulousDO::getParentId, circleAppVO.getId()) | 
|---|
|  |  |  | .eq(ComActNeighborCircleFabulousDO::getUserId, neighborCircleAppDTO.getUserId()) | 
|---|
|  |  |  | .eq(ComActNeighborCircleFabulousDO::getType, ComActNeighborCircleFabulousDO.type.llq) | 
|---|
|  |  |  | .eq(ComActNeighborCircleFabulousDO::getIsEffective, | 
|---|
|  |  |  | ComActNeighborCircleFabulousDO.isEffective.yes)); | 
|---|
|  |  |  | if (circleFabulousDO != null) { | 
|---|
|  |  |  | circleAppVO.setHaveSign(1); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | circleAppVO.setHaveSign(2); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (circleAppVO.getType() != null && circleAppVO.getType().equals(ComActNeighborCircleDO.type.admin)) { | 
|---|
|  |  |  | ComActDO actDO = comActDAO.selectById(circleAppVO.getCommunityId()); | 
|---|
|  |  |  | if (actDO != null) { | 
|---|
|  |  |  | circleAppVO.setName(actDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(doPager); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 判断活动统计列表中是否已有该单位的数据 | 
|---|
|  |  |  | * */ | 
|---|
|  |  |  | public Map<String,Integer> alreadyAnalysis(Long unitId,List<UnitActivityAnalysisVO> list){ | 
|---|
|  |  |  | Map<String,Integer> map=new HashMap<>(); | 
|---|
|  |  |  | if (list.size()>0){ | 
|---|
|  |  |  | for (int i=0;i<list.size();i++) { | 
|---|
|  |  |  | UnitActivityAnalysisVO vo = list.get(i); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getUnitId())){ | 
|---|
|  |  |  | if (unitId.equals(vo.getUnitId())){ | 
|---|
|  |  |  | map.put("index",i ); | 
|---|
|  |  |  | map.put("flag",1 ); | 
|---|
|  |  |  | return map; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | map.put("flag",0 ); | 
|---|
|  |  |  | return map; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 计算总页数 | 
|---|
|  |  |  | * */ | 
|---|
|  |  |  | public Integer getPages(Integer record,Integer size){ | 
|---|
|  |  |  | if (null != record && null != size){ | 
|---|
|  |  |  | int pages = PageUtil.totalPage(record, size); | 
|---|
|  |  |  | return pages; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 分页截取 | 
|---|
|  |  |  | * */ | 
|---|
|  |  |  | public List<Object> subUnitList(List<Object> list, int page, int size){ | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | //计算endIndex是否超出List大小 | 
|---|
|  |  |  | final Boolean flag=((page-1)*size+size) > list.size(); | 
|---|
|  |  |  | if (1 == page || 0 == page){ | 
|---|
|  |  |  | //第一页 | 
|---|
|  |  |  | return list.subList(0,size); | 
|---|
|  |  |  | }else if (flag){ | 
|---|
|  |  |  | return ListUtil.sub(list, (page-1)*size-1, list.size()-1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else { | 
|---|
|  |  |  | return list.subList((page-1)*size, (page-1)*size+size); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | //返回原集合 | 
|---|
|  |  |  | return list; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 判断党员的统计是是否已存在 | 
|---|
|  |  |  | * */ | 
|---|
|  |  |  | public Map<String,Integer> memberAlreadyAnalysis(Long memberId,List<PartyMemberAnalysisVO> list){ | 
|---|
|  |  |  | Map<String,Integer> map=new HashMap<>(); | 
|---|
|  |  |  | if (memberId != null && list.size() > 0){ | 
|---|
|  |  |  | for (int i=0;i<list.size();i++) { | 
|---|
|  |  |  | PartyMemberAnalysisVO vo = list.get(i); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getMemberId())){ | 
|---|
|  |  |  | if (memberId.equals(vo.getMemberId())){ | 
|---|
|  |  |  | map.put("index",i ); | 
|---|
|  |  |  | map.put("flag",1 ); | 
|---|
|  |  |  | return map; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | map.put("flag",0 ); | 
|---|
|  |  |  | return map; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|