From c6dbc430a487fa1e5b2f705e4aeafbbca07cce53 Mon Sep 17 00:00:00 2001 From: huanghongfa <huanghongfa123456> Date: 星期四, 22 七月 2021 12:13:00 +0800 Subject: [PATCH] 修改bug --- springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventVisitingTasksServiceImpl.java | 153 +++++++++++++++++++++++++++++++++++--------------- 1 files changed, 107 insertions(+), 46 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventVisitingTasksServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventVisitingTasksServiceImpl.java index 5198dd9..1219a0d 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventVisitingTasksServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventVisitingTasksServiceImpl.java @@ -11,6 +11,7 @@ import com.panzhihua.common.enums.EventTasksStatusEnum; import com.panzhihua.common.enums.PopulPoliticalOutlookEnum; import com.panzhihua.common.model.dtos.EventResourceDTO; +import com.panzhihua.common.model.dtos.IdDTO; import com.panzhihua.common.model.dtos.grid.*; import com.panzhihua.common.model.dtos.visit.EventVisitCompleteDTO; import com.panzhihua.common.model.helper.AESUtil; @@ -21,8 +22,10 @@ import com.panzhihua.common.model.vos.visit.*; import com.panzhihua.common.utlis.CopyUtil; import com.panzhihua.common.utlis.StringUtils; +import com.panzhihua.service_grid.dao.EventGridDataMapper; import com.panzhihua.service_grid.dao.EventResourceMapper; import com.panzhihua.service_grid.dao.EventVisitingTasksMapper; +import com.panzhihua.service_grid.model.dos.EventGridDataDO; import com.panzhihua.service_grid.model.dos.EventResourceDO; import com.panzhihua.service_grid.model.dos.EventVisitingTasksDO; import com.panzhihua.service_grid.service.EventResourceService; @@ -33,6 +36,8 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; +import static java.util.stream.Collectors.collectingAndThen; +import static java.util.stream.Collectors.toCollection; import javax.annotation.Resource; import java.util.*; @@ -40,6 +45,7 @@ import java.util.Date; import java.util.List; import java.util.Map; +import java.util.stream.Collectors; /** * @auther lyq @@ -58,6 +64,9 @@ @Resource private EventResourceService eventResourceService; + + @Resource + private EventGridDataMapper eventGridDataMapper; @Value("${domain.aesKey:}") private String aesKey; @@ -175,26 +184,37 @@ @Transactional @Override - public R delete(String ids, Long communityId) { - String[] idarr = ids.split(","); - for(String id:idarr){ - if(StringUtils.isEmpty(id)){ - continue; + public R delete(IdDTO idDTO, Long communityId) { + String[] ids = idDTO.getId().split(","); + for(String id:ids){ + EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectById(Long.valueOf(id)); + if(eventVisitingTasksDO != null){ + if(!Objects.equals(eventVisitingTasksDO.getEventStatus(),EventTasksStatusEnum.DZF.getCode())){ + return R.fail("您选择的走访任务中有已走访的不可删除"); + } + eventVisitingTasksMapper.deleteById(id); } - EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectOne(new QueryWrapper<EventVisitingTasksDO>().eq("id",Long.valueOf(id)).eq("grid_member_community",communityId)); - if(eventVisitingTasksDO == null){ - throw new RuntimeException("无权限"); - } - eventVisitingTasksMapper.deleteById(Long.valueOf(id)); } return R.ok(); + } + + private String toDelete(Long id) { + EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectById(id); + if(eventVisitingTasksDO == null){ + return "["+id+"]数据不存在;"; + } + if(!Objects.equals(eventVisitingTasksDO.getEventStatus(),EventTasksStatusEnum.DZF.getCode())){ + return "["+eventVisitingTasksDO.getVisiterName()+"]状态不可删除;"; + } + eventVisitingTasksMapper.deleteById(id); + return null; } @Override public R visitorList(EventVisitListQuery query) { IPage<EventVisitListVO> page = eventVisitingTasksMapper.visitorList(new Page(query.getPageNum(),query.getPageSize()),query); page.getRecords().stream().forEach(e->{ - List<EventVisitingTasksDO> list = eventVisitingTasksMapper.selectList(new QueryWrapper<EventVisitingTasksDO>().eq("visiter_id",e.getId()).orderByDesc("id")); + List<EventVisitingTasksDO> list = eventVisitingTasksMapper.selectList(new QueryWrapper<EventVisitingTasksDO>().eq("visiter_id",e.getId()).orderByDesc("id").last("limit 0,1")); if(!CollectionUtils.isEmpty(list)){ e.setCreateAt(list.get(0).getCreateAt()); e.setEventStatus(list.get(0).getEventStatus()); @@ -215,9 +235,21 @@ if(eventVisitingTasksDO!=null) { EventVisitingTasksDetailsVO eventVisitingTasksDetailsVO = new EventVisitingTasksDetailsVO(); BeanUtils.copyProperties(eventVisitingTasksDO, eventVisitingTasksDetailsVO); + if(StringUtils.isNotEmpty(eventVisitingTasksDO.getVisiterTele())){ + eventVisitingTasksDetailsVO.setVisiterPhone(AESUtil.decrypt128(eventVisitingTasksDO.getVisiterTele(),aesKey)); + eventVisitingTasksDetailsVO.setVisiterTele(AESUtil.decrypt128(eventVisitingTasksDO.getVisiterTele(),aesKey)); + } JSONObject jsonObject = JSONObject.parseObject(eventVisitingTasksDO.getTableContentJson()); eventVisitingTasksDetailsVO.setTableContentJson(JSONObject.parseObject(eventVisitingTasksDO.getTableContentJson())); - eventVisitingTasksDetailsVO.setOption(jsonObject.get("check") == null ?null:jsonObject.get("check").toString()); + if(jsonObject != null && jsonObject.get("check") != null){ + eventVisitingTasksDetailsVO.setOption(jsonObject.get("check").toString()); + } + + //查询资源文件 + eventVisitingTasksDetailsVO.setImgList(eventResourceMapper.findListByRefId(eventVisitingTasksDO.getId(),2,1)); + eventVisitingTasksDetailsVO.setVosList(eventResourceMapper.findListByRefId(eventVisitingTasksDO.getId(),2,2)); + eventVisitingTasksDetailsVO.setVideoList(eventResourceMapper.findListByRefId(eventVisitingTasksDO.getId(),2,3)); + eventVisitingTasksDetailsVO.setHappentAddress(eventVisitingTasksDO.getAddress()); return R.ok(eventVisitingTasksDetailsVO); } return R.fail(); @@ -225,19 +257,27 @@ @Transactional(rollbackFor = Exception.class) @Override - public R add(String ids, Long communityId, Long userId) throws Exception { - Map<String,Object> map = eventVisitingTasksMapper.findUserByCommunityId(communityId,6); - if(CollectionUtils.isEmpty(map)){ - return R.fail("网格员不存在"); - } - String[] id = ids.split(","); + public R add(IdDTO idDTO, Long communityId, Long userId) throws Exception { + +// Map<String,Object> map = eventVisitingTasksMapper.findUserByCommunityId(communityId,6); +// if(CollectionUtils.isEmpty(map)){ +// return R.fail("网格员不存在"); +// } + + StringBuilder rt = new StringBuilder(); + String[] id = idDTO.getId().split(","); for(String idstr:id){ if(StringUtils.isEmpty(idstr)){ continue; } - addVisitingTask(Long.valueOf(idstr),map,communityId,userId); + String error = addVisitingTask(Long.valueOf(idstr),idDTO.getGridId(),userId); + if(!StringUtils.isEmpty(error)){ + rt.append(error); + } } - + if(!StringUtils.isEmpty(rt)){ + return R.fail("部分新增失败"+rt.toString()); + } return R.ok(); } @@ -247,19 +287,28 @@ return page.getRecords(); } + private String addVisitingTask(Long id, Long gridId,Long userId) throws Exception{ - - private void addVisitingTask(Long id, Map<String, Object> gridMap,Long communityId,Long userId) throws Exception{ + Map<String,Object> map = eventVisitingTasksMapper.findPopulationById(id); + if(CollectionUtils.isEmpty(map)){ + return "被访问人ID["+id+"]不存在;"; + } Integer count = eventVisitingTasksMapper.countNoneComplete(id); if(count > 0){ - return; + return "被访问人["+map.get("name")+"]只能同时存在一条待走访任务;"; } - Map<String,Object> map = eventVisitingTasksMapper.findPopulationById(id); - if(CollectionUtils.isEmpty(map)){ - return ; - } + + + EventVisitingTasksDO visitingTasksDO = new EventVisitingTasksDO(); + visitingTasksDO.setGridId(gridId); + //查询网格 + EventGridDataDO gridDataDO = eventGridDataMapper.selectById(gridId); + if(gridDataDO != null){ + visitingTasksDO.setGridMemberCommunity(gridDataDO.getGridCommunityId()); + visitingTasksDO.setGridMemberStreet(gridDataDO.getGridStreetId()); + } // visitingTasksDO.setGridMemberStreet(Long.valueOf(gridMap.get("street_id").toString())); // visitingTasksDO.setGridMemberCommunity(communityId); // visitingTasksDO.setGridMember(Long.valueOf(gridMap.get("user_id").toString())); @@ -295,6 +344,7 @@ } eventVisitingTasksMapper.insert(visitingTasksDO); + return null; } private List<String> getOption(String label) { @@ -328,13 +378,13 @@ @Transactional(rollbackFor = Exception.class) @Override - public R cancel(Long id) { + public R cancel(IdDTO idDTO) { - EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectById(id); + EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectById(Long.valueOf(idDTO.getId())); if(eventVisitingTasksDO == null || eventVisitingTasksDO.getEventStatus() != EventTasksStatusEnum.DZF.getCode()){ return R.fail("当前状态不可撤销"); } - int rt = eventVisitingTasksMapper.cancel(id,EventTasksStatusEnum.YCX.getCode()); + int rt = eventVisitingTasksMapper.cancel(eventVisitingTasksDO.getId(),5); if(rt > 0){ return R.ok(); } @@ -343,13 +393,13 @@ @Transactional(rollbackFor = Exception.class) @Override - public R reset(Long id) { + public R reset(IdDTO idDTO) { - EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectById(id); - if(eventVisitingTasksDO == null || eventVisitingTasksDO.getEventStatus() != EventTasksStatusEnum.YCX.getCode()){ + EventVisitingTasksDO eventVisitingTasksDO = eventVisitingTasksMapper.selectById(Long.valueOf(idDTO.getId())); + if(eventVisitingTasksDO == null || eventVisitingTasksDO.getEventStatus() != 5){ return R.fail("当前状态不可恢复"); } - int rt = eventVisitingTasksMapper.updateEventStatus(id,EventTasksStatusEnum.DZF.getCode()); + int rt = eventVisitingTasksMapper.updateEventStatus(eventVisitingTasksDO.getId(),EventTasksStatusEnum.DZF.getCode()); if(rt > 0){ return R.ok(); } @@ -371,7 +421,7 @@ start.setGridMember(Long.valueOf(map.get("user_id").toString())); start.setGridMemberName(map.get("name").toString()); start.setGridMenberTele(map.get("phone") ==null?"":map.get("phone").toString()); - start.setEventStatus(EventTasksStatusEnum.JXZ.getCode()); + start.setEventStatus(EventTasksStatusEnum.YJJ.getCode()); int rt = eventVisitingTasksMapper.start(start); if(rt > 0){ return R.ok(); @@ -386,17 +436,29 @@ if(eventVisitingTasksDO == null || eventVisitingTasksDO.getEventStatus() != EventTasksStatusEnum.DZF.getCode()){ return R.fail("当前状态不可完成走访"); } + + //查询当前人员是否是(精神障碍,吸毒,刑满释放,社区矫正),如果是这四种状态,option参数为必填参数 + String label = this.baseMapper.getPopulationLabel(eventVisitingTasksDO.getVisiterId()); + if(StringUtils.isNotEmpty(label)){ + if(label.contains("精神障碍") || label.contains("吸毒") || label.contains("刑满释放") || label.contains("社区矫正")){ + if(StringUtils.isNotEmpty(taskCompleteDTO.getOption())){ + return R.fail("请选择异常状态"); + } + } + } + EventVisitingTasksDO complete = new EventVisitingTasksDO(); BeanUtils.copyProperties(taskCompleteDTO,complete); - if(taskCompleteDTO.getException().intValue() == 0){ - complete.setEventStatus(EventTasksStatusEnum.ZJJJ.getCode()); - }else{ - complete.setEventStatus(EventTasksStatusEnum.YC.getCode()); - } + complete.setEventStatus(EventTasksStatusEnum.YJJ.getCode()); + complete.setSubmitDate(DateUtil.parse(taskCompleteDTO.getSubmitDate(), DatePattern.NORM_DATETIME_FORMAT)); - JSONObject json = JSONObject.parseObject(eventVisitingTasksDO.getTableContentJson()); - json.put("check",taskCompleteDTO.getOption()); - complete.setTableContentJson(json.toJSONString()); + if(StringUtils.isNotEmpty(eventVisitingTasksDO.getTableContentJson())){ + JSONObject json = JSONObject.parseObject(eventVisitingTasksDO.getTableContentJson()); + if(StringUtils.isNotEmpty(taskCompleteDTO.getOption())){ + json.put("check",taskCompleteDTO.getOption()); + } + complete.setTableContentJson(json.toJSONString()); + } if(!StringUtils.isEmpty(taskCompleteDTO.getImgList())){ taskCompleteDTO.getImgList().forEach(e->{ @@ -409,7 +471,7 @@ }); } if(!CollectionUtils.isEmpty(taskCompleteDTO.getVideoList())){ - taskCompleteDTO.getVosList().forEach(e->{ + taskCompleteDTO.getVideoList().forEach(e->{ createResource(eventVisitingTasksDO.getId(),taskCompleteDTO.getUserId(),2,3,e); }); } @@ -421,7 +483,7 @@ complete.setGridMemberName(map.get("name").toString()); complete.setGridMenberTele(map.get("phone") ==null?"":map.get("phone").toString()); - int rt = eventVisitingTasksMapper.complete(complete); + int rt = eventVisitingTasksMapper.updateById(complete); if(rt > 0){ return R.ok(); } @@ -501,6 +563,5 @@ } return false; } - } -- Gitblit v1.7.1