|  |  |  | 
|---|
|  |  |  | package com.panzhihua.service_community.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.hutool.core.collection.ListUtil; | 
|---|
|  |  |  | import cn.hutool.core.util.NumberUtil; | 
|---|
|  |  |  | import cn.hutool.core.util.PageUtil; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.LoginUserInfoVO; | 
|---|
|  |  |  | import com.panzhihua.common.model.vos.PageVO; | 
|---|
|  |  |  | import com.panzhihua.common.service.user.UserService; | 
|---|
|  |  |  | import com.panzhihua.service_community.entity.ComPbCheckUnit; | 
|---|
|  |  |  | 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.collection.CollUtil; | 
|---|
|  |  |  | 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.constants.NeighborCircleConstants; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.ExcelDO; | 
|---|
|  |  |  | import com.panzhihua.common.model.dtos.PartyExcelDO; | 
|---|
|  |  |  | 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.NewFightNeedProblemClaim; | 
|---|
|  |  |  | import com.panzhihua.service_community.entity.NewFightNeedProblemInventory; | 
|---|
|  |  |  | 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 com.panzhihua.service_community.util.ExcelUtils; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.apache.commons.lang3.ObjectUtils; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import javax.servlet.http.HttpServletResponse; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @auther lyq | 
|---|
|  |  |  | 
|---|
|  |  |  | private ComActActivityDAO comActActivityDAO; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ComPbCheckUnitDao comPbCheckUnitDao; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private SysUserDao sysUserDao; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private NewFightNeedProblemClaimMapper newFightNeedProblemClaimMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private NewFightNeedProblemInventoryMapper newFightNeedProblemInventoryMapper; | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 分页查询邻里圈列表 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | 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 -> { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return R.ok(doPager); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R pageNeighborByBigScreen(ComActNeighborCircleAdminDTO neighborCircleAdminDTO) { | 
|---|
|  |  |  | Page page = new Page(neighborCircleAdminDTO.getPageNum(), neighborCircleAdminDTO.getPageSize()); | 
|---|
|  |  |  | IPage<ComActNeighborCircleAdminVO> doPager = this.baseMapper.pageNeighborByBigScreen(page, neighborCircleAdminDTO); | 
|---|
|  |  |  | return R.ok(doPager); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | 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("评论失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R detailNeighborByAdmin(Long id) { | 
|---|
|  |  |  | ComActNeighborCircleDetailAppVO comActNeighborCircleDO = | 
|---|
|  |  |  | this.baseMapper.neighborDetailByApp(id); | 
|---|
|  |  |  | ComActNeighborCircleDetailAppVO comActNeighborCircleDO = baseMapper.neighborDetailByApp(id); | 
|---|
|  |  |  | if (comActNeighborCircleDO == null) { | 
|---|
|  |  |  | return R.fail("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(comActNeighborCircleDO.getSolveId()!=null){ | 
|---|
|  |  |  | AdministratorsUserVO user1 = this.baseMapper.selectUserByUserId(comActNeighborCircleDO.getSolveId()); | 
|---|
|  |  |  | vo.setSolveName(user1.getName()); | 
|---|
|  |  |  | if(user!=null){ | 
|---|
|  |  |  | vo.setReleaseName(user.getName()); | 
|---|
|  |  |  | vo.setImageUrl(user.getImageUrl()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(comActNeighborCircleDO.getSolveUnitId()!=null){ | 
|---|
|  |  |  | ComPbCheckUnit comPbCheckUnit=comPbCheckUnitDao.selectById(comActNeighborCircleDO.getSolveUnitId()); | 
|---|
|  |  |  | if(comPbCheckUnit!=null){ | 
|---|
|  |  |  | vo.setSolveName(comPbCheckUnit.getName()); | 
|---|
|  |  |  | 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) { | 
|---|
|  |  |  | ComActNeighborCircleTopicDO circleTopicDO = | 
|---|
|  |  |  | comActNeighborCircleTopicMapper.selectById(comActNeighborCircleDO.getTopicId()); | 
|---|
|  |  |  | vo.setTopicName(circleTopicDO.getName()); | 
|---|
|  |  |  | if(circleTopicDO!=null && !StringUtils.isEmpty(circleTopicDO.getName())) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | vo.setTopicName(circleTopicDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | public R orderAndSolve(EditNeighborCircleAdminVO editNeighborCircleAdminVO) { | 
|---|
|  |  |  | ComActNeighborCircleDO comActNeighborCircleDO=new ComActNeighborCircleDO(); | 
|---|
|  |  |  | BeanUtils.copyProperties(editNeighborCircleAdminVO,comActNeighborCircleDO); | 
|---|
|  |  |  | if(comActNeighborCircleDO.getSolveStatus()!=null){ | 
|---|
|  |  |  | if(comActNeighborCircleDO.getSolveStatus()!=null && comActNeighborCircleDO.getSolveStatus() == 3){ | 
|---|
|  |  |  | comActNeighborCircleDO.setSolveTime(new Date()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(comActNeighborCircleDO.getOrderStatus()!=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 serviceStatic(ServiceStaticDTO serviceStaticDTO) { | 
|---|
|  |  |  | ServiceStaticsVO serviceStaticsVO=new ServiceStaticsVO(); | 
|---|
|  |  |  | if(serviceStaticDTO.getCheckUnitId()!=null){ | 
|---|
|  |  |  | serviceStaticsVO=this.baseMapper.selectStatsCheckUnit(serviceStaticDTO.getCheckUnitId(),serviceStaticDTO.getYear()); | 
|---|
|  |  |  | serviceStaticsVO=this.baseMapper.selectStatsCheckUnit(serviceStaticDTO.getCheckUnitId(),serviceStaticDTO.getYear()); | 
|---|
|  |  |  | serviceStaticsVO.setServiceProjecList(this.baseMapper.selectListByCheckUnitId(serviceStaticDTO.getCheckUnitId(),serviceStaticDTO.getYear())); | 
|---|
|  |  |  | serviceStaticsVO.setServiceActivityList(comActActivityDAO.selectListByRelationId(serviceStaticDTO.getCheckUnitId(),serviceStaticDTO.getYear())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else { | 
|---|
|  |  |  | serviceStaticsVO=this.baseMapper.selectStatsUser(serviceStaticDTO.getPhone(),serviceStaticDTO.getYear()); | 
|---|
|  |  |  | serviceStaticsVO.setServiceProjecList(this.baseMapper.selectListByPhone(serviceStaticDTO.getPhone(),serviceStaticDTO.getYear())); | 
|---|
|  |  |  | ComPbMemberDO comPbMemberDO=comPbMemberDAO.selectOne(new QueryWrapper<ComPbMemberDO>().lambda().eq(ComPbMemberDO::getPhone,serviceStaticDTO.getPhone()).last("limit 1")); | 
|---|
|  |  |  | if(comPbMemberDO!=null){ | 
|---|
|  |  |  | serviceStaticsVO.setWorkActivityList(comActActivityDAO.selectListByRelationId(comPbMemberDO.getCheckUnitId(),serviceStaticDTO.getYear())); | 
|---|
|  |  |  | serviceStaticsVO.setServiceActivityList(comActActivityDAO.selectListByCommunityId(comPbMemberDO.getCommunityId(),serviceStaticDTO.getYear())); | 
|---|
|  |  |  | 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) { | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | activityVO.setPartyMemberCount(comActDAO.selectUnitCount()); | 
|---|
|  |  |  | activityVO.setUnitCount(comActDAO.selectMemberCount()); | 
|---|
|  |  |  | //获取单位活动统计数据(邻里圈) | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS = comActNeighborCircleDAO.institutionalUnitServiceAnalysis(beginTime, endTime, belongTo); | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS = comActNeighborCircleDAO.institutionalUnitServiceAnalysis(beginTime, endTime, belongTo,communityId); | 
|---|
|  |  |  | //获取单位活动统计数据(活动) | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS1 = comActNeighborCircleDAO.institutionalUnitActivityAnalysis(beginTime, endTime, belongTo); | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS1 = comActNeighborCircleDAO.institutionalUnitActivityAnalysis(beginTime, endTime, belongTo,communityId); | 
|---|
|  |  |  | if (unitActivityAnalysisVOS.size()>0){ | 
|---|
|  |  |  | for (UnitActivityAnalysisVO unitActivityAnalysisVO : unitActivityAnalysisVOS){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | //新数据,获取单位,社区名 | 
|---|
|  |  |  | vo.setUnitName(comActDAO.selectUnitName(vo.getUnitId())); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getCommunityId())) { | 
|---|
|  |  |  | vo.setCommunityName(comActDAO.selectById(vo.getCommunityId()).getName()); | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo.getCommunityId())) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ComActDO actDO=comActDAO.selectById(vo.getCommunityId()); | 
|---|
|  |  |  | if(actDO!=null && !StringUtils.isEmpty(actDO.getName())) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | vo.setCommunityName(actDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | unitActivityAnalysisVOS.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //获取党员活动统计数据 | 
|---|
|  |  |  | List<PartyMemberAnalysisVO> partyMemberAnalysisVOS = comActNeighborCircleDAO.institutionalPartyMemberServiceAnalysis(beginTime, endTime, belongTo); | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //报道单位统计积分 | 
|---|
|  |  |  | List<NewFightNeedProblemInventory> allList = newFightNeedProblemInventoryMapper.selectAll(); | 
|---|
|  |  |  | Map<Long, String> awardMap = allList.stream().filter(Objects::nonNull).collect(Collectors.toMap(NewFightNeedProblemInventory::getId, NewFightNeedProblemInventory::getAward)); | 
|---|
|  |  |  | for (UnitActivityAnalysisVO unitVO : unitActivityAnalysisVOS) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long unitId1 = unitVO.getUnitId(); | 
|---|
|  |  |  | LambdaQueryWrapper<NewFightNeedProblemClaim> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | wrapper.eq(NewFightNeedProblemClaim::getUnitId,String.valueOf(unitId1)); | 
|---|
|  |  |  | List<NewFightNeedProblemClaim> inventories = newFightNeedProblemClaimMapper.selectList(wrapper); | 
|---|
|  |  |  | Map<String, Long> collectMap = inventories.stream() | 
|---|
|  |  |  | .collect(Collectors.groupingBy(NewFightNeedProblemClaim::getTaskId, Collectors.counting())); | 
|---|
|  |  |  | long sum = 0L; | 
|---|
|  |  |  | //任务id集合 | 
|---|
|  |  |  | List<String> taskIds = inventories.stream().map(NewFightNeedProblemClaim::getTaskId).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | for (String taskId : taskIds) { | 
|---|
|  |  |  | //                NewFightNeedProblemInventory newFightNeedProblemInventory = newFightNeedProblemInventoryMapper.selectById(taskId); | 
|---|
|  |  |  | //                String award = newFightNeedProblemInventory.getAward(); | 
|---|
|  |  |  | String award = awardMap.get(Long.parseLong(taskId)); | 
|---|
|  |  |  | Long count = collectMap.get(taskId); | 
|---|
|  |  |  | long i = Long.parseLong(award) * count; | 
|---|
|  |  |  | sum = sum + i; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | unitVO.setAwardSum(sum); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //报道党员统计积分 | 
|---|
|  |  |  | for (PartyMemberAnalysisVO memberAnalysisVO : partyMemberAnalysisVOS) { | 
|---|
|  |  |  | Long userId = memberAnalysisVO.getMemberId(); | 
|---|
|  |  |  | LambdaQueryWrapper<NewFightNeedProblemClaim> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | wrapper.eq(NewFightNeedProblemClaim::getUserId,userId); | 
|---|
|  |  |  | List<NewFightNeedProblemClaim> newFightNeedProblemInventories = newFightNeedProblemClaimMapper.selectList(wrapper); | 
|---|
|  |  |  | long sumAward = 0L; | 
|---|
|  |  |  | for (NewFightNeedProblemClaim inventory : newFightNeedProblemInventories) { | 
|---|
|  |  |  | String taskId = inventory.getTaskId(); | 
|---|
|  |  |  | NewFightNeedProblemInventory newFightNeedProblemInventory = newFightNeedProblemInventoryMapper.selectById(taskId); | 
|---|
|  |  |  | String award = newFightNeedProblemInventory.getAward(); | 
|---|
|  |  |  | sumAward = Long.parseLong(award) + sumAward; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | memberAnalysisVO.setPartyCount(sumAward); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //统计总时长和总次数 | 
|---|
|  |  |  | Integer unitServiceCount=0; | 
|---|
|  |  |  | Integer unitServiceTotalTime=0; | 
|---|
|  |  |  | Integer memberServiceCount=0; | 
|---|
|  |  |  | Integer memberServiceTotalTome=0; | 
|---|
|  |  |  | long awardSumCount=0L; | 
|---|
|  |  |  | long partySumCount=0L; | 
|---|
|  |  |  | for (UnitActivityAnalysisVO vo : unitActivityAnalysisVOS) { | 
|---|
|  |  |  | //避免空指针 | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (UnitActivityAnalysisVO vo : unitActivityAnalysisVOS) { | 
|---|
|  |  |  | if(ObjectUtils.isNotEmpty(vo)){ | 
|---|
|  |  |  | if(ObjectUtils.isNotEmpty(vo.getAwardSum())){ | 
|---|
|  |  |  | awardSumCount += vo.getAwardSum(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (PartyMemberAnalysisVO memberAnalysisVO : partyMemberAnalysisVOS) { | 
|---|
|  |  |  | if(ObjectUtils.isNotEmpty(memberAnalysisVO)){ | 
|---|
|  |  |  | if(ObjectUtils.isNotEmpty(memberAnalysisVO.getPartyCount())){ | 
|---|
|  |  |  | partySumCount += memberAnalysisVO.getPartyCount(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | activityVO.setAwardSumCount(awardSumCount); | 
|---|
|  |  |  | activityVO.setPartySumCount(partySumCount); | 
|---|
|  |  |  | activityVO.setUnitServiceTotalCount(unitServiceCount); | 
|---|
|  |  |  | activityVO.setUnitServiceTotalTime(unitServiceTotalTime); | 
|---|
|  |  |  | activityVO.setPartyMemberServiceTotalCount(memberServiceCount); | 
|---|
|  |  |  | 
|---|
|  |  |  | //按次数排序 | 
|---|
|  |  |  | ListUtil.sortByProperty(unitActivityAnalysisVOS, "serviceTimes"); | 
|---|
|  |  |  | ListUtil.sortByProperty(partyMemberAnalysisVOS, "serviceTimes"); | 
|---|
|  |  |  | }else if(type.equals(3)){ | 
|---|
|  |  |  | //按积分排序 | 
|---|
|  |  |  | ListUtil.sortByProperty(unitActivityAnalysisVOS,"awardSum"); | 
|---|
|  |  |  | //   ListUtil.sortByProperty(unitActivityAnalysisVOS,""); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //处理分页 | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<ExcelDO> export(Integer year, String belongTo, Long communityId) throws Exception { | 
|---|
|  |  |  | List<ExcelDO> excelDOList = new ArrayList<>(); | 
|---|
|  |  |  | String beginTime=null; | 
|---|
|  |  |  | String endTime=null; | 
|---|
|  |  |  | if (null != year){ | 
|---|
|  |  |  | //设置开始,截止时间 | 
|---|
|  |  |  | beginTime=year.toString().concat("-01-01"); | 
|---|
|  |  |  | endTime=year.toString().concat("-12-31"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //获取单位活动统计数据(邻里圈) | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS = comActNeighborCircleDAO.institutionalUnitServiceAnalysis(beginTime, endTime, belongTo,communityId); | 
|---|
|  |  |  | //获取单位活动统计数据(活动) | 
|---|
|  |  |  | List<UnitActivityAnalysisVO> unitActivityAnalysisVOS1 = comActNeighborCircleDAO.institutionalUnitActivityAnalysis(beginTime, endTime, belongTo,communityId); | 
|---|
|  |  |  | if (!unitActivityAnalysisVOS.isEmpty()){ | 
|---|
|  |  |  | for (UnitActivityAnalysisVO unitActivityAnalysisVO : unitActivityAnalysisVOS){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO)){ | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO.getUnitId())){ | 
|---|
|  |  |  | //设置单位名称 | 
|---|
|  |  |  | unitActivityAnalysisVO.setUnitName(comActDAO.selectUnitName(unitActivityAnalysisVO.getUnitId())); | 
|---|
|  |  |  | //统计活动表中的活动信息 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (ObjectUtils.isNotEmpty(unitActivityAnalysisVO.getCommunityId())){ | 
|---|
|  |  |  | unitActivityAnalysisVO.setCommunityName(comActDAO.selectById(unitActivityAnalysisVO.getCommunityId()).getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //活动表数据处理 | 
|---|
|  |  |  | if (!unitActivityAnalysisVOS1.isEmpty()){ | 
|---|
|  |  |  | 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())) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ComActDO actDO=comActDAO.selectById(vo.getCommunityId()); | 
|---|
|  |  |  | if(actDO!=null && !StringUtils.isEmpty(actDO.getName())) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | vo.setCommunityName(actDO.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | unitActivityAnalysisVOS.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<NewFightNeedProblemInventory> allList = newFightNeedProblemInventoryMapper.selectAll(); | 
|---|
|  |  |  | Map<Long, String> awardMap = allList.stream().filter(Objects::nonNull).collect(Collectors.toMap(NewFightNeedProblemInventory::getId, NewFightNeedProblemInventory::getAward)); | 
|---|
|  |  |  | for (UnitActivityAnalysisVO unitVO : unitActivityAnalysisVOS) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long unitId1 = unitVO.getUnitId(); | 
|---|
|  |  |  | LambdaQueryWrapper<NewFightNeedProblemClaim> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | wrapper.eq(NewFightNeedProblemClaim::getUnitId,String.valueOf(unitId1)); | 
|---|
|  |  |  | List<NewFightNeedProblemClaim> inventories = newFightNeedProblemClaimMapper.selectList(wrapper); | 
|---|
|  |  |  | Map<String, Long> collectMap = inventories.stream() | 
|---|
|  |  |  | .collect(Collectors.groupingBy(NewFightNeedProblemClaim::getTaskId, Collectors.counting())); | 
|---|
|  |  |  | long sum = 0L; | 
|---|
|  |  |  | //任务id集合 | 
|---|
|  |  |  | List<String> taskIds = inventories.stream().map(NewFightNeedProblemClaim::getTaskId).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | for (String taskId : taskIds) { | 
|---|
|  |  |  | //                NewFightNeedProblemInventory newFightNeedProblemInventory = newFightNeedProblemInventoryMapper.selectById(taskId); | 
|---|
|  |  |  | //                String award = newFightNeedProblemInventory.getAward(); | 
|---|
|  |  |  | String award = awardMap.get(Long.parseLong(taskId)); | 
|---|
|  |  |  | Long count = collectMap.get(taskId); | 
|---|
|  |  |  | long i = Long.parseLong(award) * count; | 
|---|
|  |  |  | sum = sum + i; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | unitVO.setAwardSum(sum); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (UnitActivityAnalysisVO vo : unitActivityAnalysisVOS) { | 
|---|
|  |  |  | ExcelDO excelDO = new ExcelDO(); | 
|---|
|  |  |  | excelDO.setBelongTo(vo.getBelongTo()); | 
|---|
|  |  |  | excelDO.setOrgName(vo.getOrgName()); | 
|---|
|  |  |  | excelDO.setUnitName(vo.getUnitName()); | 
|---|
|  |  |  | excelDO.setCommunityName(vo.getCommunityName()); | 
|---|
|  |  |  | excelDO.setServiceTime(vo.getServiceTime()); | 
|---|
|  |  |  | excelDO.setAwardSum(vo.getAwardSum()); | 
|---|
|  |  |  | excelDOList.add(excelDO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return excelDOList; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<PartyExcelDO> partyExcel(Integer year, String belongTo, Long communityId,Long unitId) { | 
|---|
|  |  |  | String beginTime=null; | 
|---|
|  |  |  | String endTime=null; | 
|---|
|  |  |  | if (null != year){ | 
|---|
|  |  |  | //设置开始,截止时间 | 
|---|
|  |  |  | beginTime=year.toString().concat("-01-01"); | 
|---|
|  |  |  | endTime=year.toString().concat("-12-31"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //获取党员活动统计数据 | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //报道党员统计积分 | 
|---|
|  |  |  | for (PartyMemberAnalysisVO memberAnalysisVO : partyMemberAnalysisVOS) { | 
|---|
|  |  |  | Long userId = memberAnalysisVO.getMemberId(); | 
|---|
|  |  |  | LambdaQueryWrapper<NewFightNeedProblemClaim> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | wrapper.eq(NewFightNeedProblemClaim::getUserId,userId); | 
|---|
|  |  |  | List<NewFightNeedProblemClaim> newFightNeedProblemInventories = newFightNeedProblemClaimMapper.selectList(wrapper); | 
|---|
|  |  |  | long sumAward = 0L; | 
|---|
|  |  |  | for (NewFightNeedProblemClaim inventory : newFightNeedProblemInventories) { | 
|---|
|  |  |  | String taskId = inventory.getTaskId(); | 
|---|
|  |  |  | NewFightNeedProblemInventory newFightNeedProblemInventory = newFightNeedProblemInventoryMapper.selectById(taskId); | 
|---|
|  |  |  | String award = newFightNeedProblemInventory.getAward(); | 
|---|
|  |  |  | sumAward = Long.parseLong(award) + sumAward; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | memberAnalysisVO.setPartyCount(sumAward); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<PartyExcelDO> list = new ArrayList<>(); | 
|---|
|  |  |  | for (PartyMemberAnalysisVO memberAnalysisVO : partyMemberAnalysisVOS) { | 
|---|
|  |  |  | PartyExcelDO partyExcelDO = new PartyExcelDO(); | 
|---|
|  |  |  | partyExcelDO.setBelongTo(memberAnalysisVO.getBelongTo()); | 
|---|
|  |  |  | partyExcelDO.setOrgName(memberAnalysisVO.getOrgName()); | 
|---|
|  |  |  | partyExcelDO.setUnitName(memberAnalysisVO.getUnitName()); | 
|---|
|  |  |  | partyExcelDO.setMemberName(memberAnalysisVO.getMemberName()); | 
|---|
|  |  |  | partyExcelDO.setBelongCommunity(memberAnalysisVO.getBelongCommunity()); | 
|---|
|  |  |  | partyExcelDO.setServiceTimes(memberAnalysisVO.getServiceTimes()); | 
|---|
|  |  |  | partyExcelDO.setServiceTime(memberAnalysisVO.getServiceTime()); | 
|---|
|  |  |  | partyExcelDO.setPartyCount(memberAnalysisVO.getPartyCount()); | 
|---|
|  |  |  | list.add(partyExcelDO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return list; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @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> 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|