From 8f7ad469fe107457f6d4a6d14cf1e733b910618b Mon Sep 17 00:00:00 2001 From: CeDo <cedoogle@gmail.com> Date: 星期六, 29 五月 2021 18:09:08 +0800 Subject: [PATCH] 事件流转完善 --- springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java | 648 +++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 565 insertions(+), 83 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java index 694d3a8..8d1d615 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventServiceImpl.java @@ -1,16 +1,21 @@ package com.panzhihua.service_grid.service.impl; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; 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.enums.EventType; import com.panzhihua.common.exceptions.ServiceException; +import com.panzhihua.common.model.dtos.community.ComMngPopulationDTO; import com.panzhihua.common.model.dtos.grid.*; import com.panzhihua.common.model.vos.R; +import com.panzhihua.common.model.vos.community.ComActVO; import com.panzhihua.common.model.vos.grid.EventDetailsVO; import com.panzhihua.common.model.vos.grid.EventResourceVO; import com.panzhihua.common.model.vos.grid.EventTransferRecordVO; import com.panzhihua.common.model.vos.grid.EventVO; +import com.panzhihua.common.service.community.CommunityService; import com.panzhihua.common.utlis.StringUtils; import com.panzhihua.service_grid.dao.*; import com.panzhihua.service_grid.model.dos.*; @@ -28,9 +33,9 @@ import java.util.List; /** - * @auther lyq - * @create 2021-04-14 15:03:01 - * @describe 订单表服务实现类 + * @author cedoo + * 2021-04-14 15:03:01 + * 订单表服务实现类 */ @Slf4j @Service @@ -38,15 +43,16 @@ @Resource private EventMapper eventMapper; - @Resource private EventResourceService eventResourceService; @Resource private EventTransferRecordService eventTransferRecordService; + @Resource + private CommunityService communityService; /** * 新增事件 - * @param eventAddDTO + * @param eventAddDTO 事件新增DTO * @return 新增结果 */ public R add(EventAddDTO eventAddDTO){ @@ -129,11 +135,22 @@ /** * 删除事件 - * @param CommonEventDeleteDTO + * @param commonEventDeleteDTO * @return 平台用户信息 */ - public R delete(CommonEventDeleteDTO CommonEventDeleteDTO){ - return R.fail(); + public R delete(CommonEventDeleteDTO commonEventDeleteDTO){ + EventDO eventDO = eventMapper.selectById(commonEventDeleteDTO.getId()); + if(eventDO==null){ + return R.fail("事件不存在"); + } + if(eventDO.getEventStatus()!=null && + (eventDO.getEventStatus().intValue()==1||eventDO.getEventStatus().intValue()==4)){//草稿 或者 已撤销 的事件可以删除 + eventDO.setEventStatus(3);//逻辑删除 + eventDO.setUpdateBy(commonEventDeleteDTO.getUserId()); + int updated = this.getBaseMapper().updateById(eventDO); + return updated==1?R.ok():R.fail(); + } + return R.fail("事件不是草稿/已撤销状态, 不允许删除"); } /** @@ -147,7 +164,6 @@ EventDetailsVO eventDetailsVO = new EventDetailsVO(); BeanUtils.copyProperties(eventDO, eventDetailsVO); //查询事件关联附件 - List<EventResourceDO> eventResourceDOList = eventResourceService.getBaseMapper().selectList(new LambdaQueryWrapper<EventResourceDO>() .eq(EventResourceDO::getClassification, 1) @@ -185,6 +201,7 @@ List<EventTransferRecordDO> eventTransferRecordDOList = eventTransferRecordService.getBaseMapper() .selectList(new LambdaQueryWrapper<EventTransferRecordDO>() .eq(EventTransferRecordDO::getEventId, id) + .orderByAsc(EventTransferRecordDO::getCreateAt) ); List<EventTransferRecordVO> eventTransferRecordVOS = new ArrayList<>(); @@ -244,6 +261,7 @@ eventDO.setGridMemberName(commonEventAddDTO.getUserName()); eventDO.setGridMemberTelephone(commonEventAddDTO.getPhone()); eventDO.setCreateBy(commonEventAddDTO.getUserId()); + eventDO.setSubmitDate(new Date()); if(eventMapper.insert(eventDO)==1){ //添加音频 if(StringUtils.isNotEmpty(commonEventAddDTO.getAudio())){ @@ -287,6 +305,7 @@ } } } + addReleaseRecord(eventDO.getId(), commonEventAddDTO.getUserId(), commonEventAddDTO.getUserName()); return R.ok(); } return R.fail(); @@ -300,11 +319,13 @@ BeanUtils.copyProperties(commonEventEditDTO, eventDO); eventDO.setGridMemberId(commonEventEditDTO.getUserId()); eventDO.setEventCategory(1l);//办件事件 - eventDO.setEventType(5);//突发事件分类 eventDO.setEventStatus(1);//事件状态 1草稿 eventDO.setProcessType(1);//网格员处理 eventDO.setCommunityProcess(0);//非 社区处理 eventDO.setCreateBy(commonEventEditDTO.getUserId()); + eventDO.setGridMemberId(commonEventEditDTO.getUserId()); + eventDO.setGridMemberName(commonEventEditDTO.getUserName()); + eventDO.setGridMemberTelephone(commonEventEditDTO.getPhone()); if (eventMapper.insert(eventDO) > 0) { //添加音频 if (StringUtils.isNotEmpty(commonEventEditDTO.getAudio())) { @@ -357,7 +378,6 @@ BeanUtils.copyProperties(commonEventEditDTO, eventDO); eventDO.setGridMemberId(commonEventEditDTO.getUserId()); eventDO.setEventCategory(1l);//办件事件 - eventDO.setEventType(5);//突发事件分类 eventDO.setEventStatus(1);//事件状态 2发布 eventDO.setProcessType(1);//网格员处理 eventDO.setCommunityProcess(0);//非 社区处理 @@ -428,44 +448,56 @@ if(eventDO.getProcessType()==2){ return R.fail("当前事件已交由社区处理"); } + + R r = communityService.detailCommunity(commonEventReportDTO.getToId()); + if(!R.isOk(r)){ + return R.fail("查询社区错误"); + } + ComActVO comActVO= JSONObject.parseObject(JSONObject.toJSONString(r.getData()),ComActVO.class); + if(comActVO!=null){ + return R.fail("社区不存在"); + } eventDO.setCommunityProcess(1); //社区处理 eventDO.setProcessType(2); //当前处理对象: 社区处理 + eventDO.setCommunityProcess(1); eventDO.setEventProcessStatus(1); //待处理 eventDO.setUpdateBy(commonEventReportDTO.getUserId()); + eventDO.setSubmitDate(new Date()); int updated = this.getBaseMapper().updateById(eventDO); if(updated!=1){ throw new ServiceException("更新突发事件状态更新失败"); } - EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); - BeanUtils.copyProperties(commonEventReportDTO, eventTransferRecordDO); - eventTransferRecordDO.setFromType(1); - eventTransferRecordDO.setFromId(commonEventReportDTO.getUserId()); - eventTransferRecordDO.setFromName(commonEventReportDTO.getUserName()); - eventTransferRecordDO.setToType(2);//转交类型:2、社区 - eventTransferRecordDO.setProcessDate(new Date()); - int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); - return inserted==1?R.ok():R.fail(); + addTransferRecord(eventDO.getId(), commonEventReportDTO.getToId(), comActVO.getName(), 2, "上报社区成功"); + return R.ok(); + } @Override + @Transactional(rollbackFor = Exception.class) public R emergenciesRevoke(EventRevokeDTO eventRevokeDTO) { EventDO eventDO = this.getBaseMapper().selectById(eventRevokeDTO.getId()); if(eventDO==null){ return R.fail("事件不存在"); } - boolean canRevoke = eventDO.getEventStatus()==2 //发布状态 - && eventDO.getEventProcessStatus()==1 //待处理 - ; + boolean canRevoke = eventDO.getEventStatus()==2; //发布状态 if(!canRevoke){ + return R.fail("当前事件不允许撤销"); + } + if(eventDO.getEventCategory()!=null && eventDO.getEventCategory().intValue()==2){//宣传教育事件 + //不做验证 + }else if(eventDO.getEventProcessStatus()==2 ||eventDO.getEventProcessStatus()==3) { //已解决 或者 待验证 不允许撤销 return R.fail("当前事件不允许撤销"); } eventDO.setEventStatus(4); eventDO.setUpdateBy(eventRevokeDTO.getUserId()); - eventDO.setEventType(5);//突发事件分类 eventDO.setProcessType(1);//网格员处理 eventDO.setCommunityProcess(0);//非 社区处理 int updated = this.getBaseMapper().updateById(eventDO); - return updated==1?R.ok():R.fail(); + if(updated == 1){ + addTransferRecord(eventDO.getId(), eventRevokeDTO.getUserId(), eventRevokeDTO.getUserName(), 1,"撤销成功"); + return R.ok(); + } + return R.fail(); } @Override @@ -496,25 +528,16 @@ if(updated!=1){ return R.fail("更新事件状态失败"); } - - EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); - BeanUtils.copyProperties(commonEventDealDTO, eventTransferRecordDO); - eventTransferRecordDO.setFromType(1); - eventTransferRecordDO.setFromId(commonEventDealDTO.getUserId()); - eventTransferRecordDO.setFromName(commonEventDealDTO.getUserName()); - eventTransferRecordDO.setToType(1); - eventTransferRecordDO.setToId(commonEventDealDTO.getUserId()); - eventTransferRecordDO.setProcessDate(new Date()); - eventTransferRecordDO.setEventId(eventDO.getId()); - int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); - if(inserted==1){ + EventTransferRecordDO transferRecordDO = + addTransferRecord(eventDO.getId(), commonEventDealDTO.getUserId(), commonEventDealDTO.getUserName(),1, "网格员自处理完成"); + if(transferRecordDO!=null && transferRecordDO.getId()!=null){ //添加音频 if(StringUtils.isNotEmpty(commonEventDealDTO.getAudio())){ EventResourceDO eventResourceDO = new EventResourceDO(); eventResourceDO.setClassification(3); eventResourceDO.setType(2); eventResourceDO.setUrl(commonEventDealDTO.getAudio()); - eventResourceDO.setRefId(eventTransferRecordDO.getId()); + eventResourceDO.setRefId(transferRecordDO.getId()); eventResourceDO.setCreateBy(commonEventDealDTO.getUserId()); int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); if(audioAdd!=1){ @@ -527,7 +550,7 @@ eventResourceDO.setClassification(3); eventResourceDO.setType(3); eventResourceDO.setUrl(commonEventDealDTO.getVideo()); - eventResourceDO.setRefId(eventTransferRecordDO.getId()); + eventResourceDO.setRefId(transferRecordDO.getId()); eventResourceDO.setCreateBy(commonEventDealDTO.getUserId()); int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); if(videoAdd!=1){ @@ -542,7 +565,7 @@ eventResourceDO.setClassification(3); eventResourceDO.setType(1); eventResourceDO.setUrl(pica[i]); - eventResourceDO.setRefId(eventTransferRecordDO.getId()); + eventResourceDO.setRefId(transferRecordDO.getId()); eventResourceDO.setCreateBy(commonEventDealDTO.getUserId()); int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); if(picAdd!=1){ @@ -574,21 +597,8 @@ if(updated!=1){ return R.fail("更新事件状态失败"); } - EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); - eventTransferRecordDO.setFromType(1); - eventTransferRecordDO.setFromId(commonEventVerifyDTO.getUserId()); - eventTransferRecordDO.setFromName(commonEventVerifyDTO.getUserName()); - eventTransferRecordDO.setToType(1); - eventTransferRecordDO.setToId(commonEventVerifyDTO.getUserId()); - eventTransferRecordDO.setProcessDate(new Date()); - eventTransferRecordDO.setToName(commonEventVerifyDTO.getUserName()); - eventTransferRecordDO.setEventId(eventDO.getId()); - int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); - if(inserted==1){ - return R.ok(); - }else{ - throw new ServiceException("事件处理添加出错"); - } + addTransferRecord(eventDO.getId(), commonEventVerifyDTO.getUserId(), commonEventVerifyDTO.getUserName(), 1, "事件验证完成"); + return R.ok(); } @Override @@ -599,26 +609,16 @@ return R.fail("当前不是撤销状态"); } - eventDO.setEventStatus(2);//2已解决 + eventDO.setEventStatus(2);//2 发布 + eventDO.setEventProcessStatus(1); //待解决 + eventDO.setProcessType(1); //网格员处理 eventDO.setUpdateBy(commonEventRepublicDTO.getUserId()); int updated = this.getBaseMapper().updateById(eventDO); if(updated!=1){ return R.fail("更新事件状态失败"); } - EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); - eventTransferRecordDO.setFromType(1); - eventTransferRecordDO.setFromId(commonEventRepublicDTO.getUserId()); - eventTransferRecordDO.setFromName(commonEventRepublicDTO.getUserName()); - eventTransferRecordDO.setToType(1); - eventTransferRecordDO.setToId(commonEventRepublicDTO.getUserId()); - eventTransferRecordDO.setProcessDate(new Date()); - eventTransferRecordDO.setEventId(eventDO.getId()); - int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); - if(inserted==1){ - return R.ok(); - }else{ - throw new ServiceException("事件处理添加出错"); - } + addTransferRecord(eventDO.getId(), commonEventRepublicDTO.getUserId(), commonEventRepublicDTO.getUserName(), 1, "重新发布已撤销事件"); + return R.ok(); } @Override @@ -629,7 +629,6 @@ if(!draftCanRelease){ return R.fail("当前不是草稿状态"); } - eventDO.setEventStatus(2);//事件状态 2发布 eventDO.setProcessType(1);//当前处理对象类型:网格员处理 eventDO.setCommunityProcess(0);//非 社区处理 @@ -639,20 +638,503 @@ if(updated!=1){ return R.fail("更新事件状态失败"); } - EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); - eventTransferRecordDO.setFromType(1);//来源类型 1、网格员 - eventTransferRecordDO.setFromId(commonEventPublicDTO.getUserId()); - eventTransferRecordDO.setFromName(commonEventPublicDTO.getUserName()); - eventTransferRecordDO.setToType(1);//转交类型 1、网格员 - eventTransferRecordDO.setToId(commonEventPublicDTO.getUserId()); - eventTransferRecordDO.setProcessDate(new Date()); - eventTransferRecordDO.setEventId(eventDO.getId()); - int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); - if(inserted==1){ - return R.ok(); + addReleaseRecord(eventDO.getId(), commonEventPublicDTO.getUserId(), commonEventPublicDTO.getUserName()); + return R.ok(); + } + + @Override + public R saveSpecialDraft(SpecialEventEditDTO specialEventEditDTO) { + R rtVal = R.fail(); + if(specialEventEditDTO.getId()==null) { + EventDO eventDO = new EventDO(); + BeanUtils.copyProperties(specialEventEditDTO, eventDO); + eventDO.setGridMemberId(specialEventEditDTO.getUserId()); + eventDO.setEventCategory(1l);//办件事件 + eventDO.setEventType(EventType.SPECIAL);//特殊人群信息上报-事件分类 + eventDO.setEventStatus(1);//事件状态 1草稿 + eventDO.setProcessType(1);//网格员处理 + eventDO.setCommunityProcess(0);//非 社区处理 + eventDO.setCreateBy(specialEventEditDTO.getUserId()); + if (eventMapper.insert(eventDO) > 0) { + //添加音频 + if (StringUtils.isNotEmpty(specialEventEditDTO.getAudio())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(2); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(specialEventEditDTO.getAudio()); + eventResourceDO.setCreateBy(specialEventEditDTO.getUserId()); + int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (audioAdd != 1) { + throw new ServiceException("添加音频失败"); + } + } + //添加视频 + if (StringUtils.isNotEmpty(specialEventEditDTO.getVideo())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(3); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(specialEventEditDTO.getVideo()); + eventResourceDO.setCreateBy(specialEventEditDTO.getUserId()); + int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (videoAdd != 1) { + throw new ServiceException("添加视频失败"); + } + } + //添加图片 + if (StringUtils.isNotEmpty(specialEventEditDTO.getPics())) { + String[] pica = specialEventEditDTO.getPics().split(","); + for (int i = 0; i < pica.length; i++) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(1); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(pica[i]); + eventResourceDO.setCreateBy(specialEventEditDTO.getUserId()); + int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (picAdd != 1) { + throw new ServiceException("添加图片失败"); + } + } + } + rtVal = R.ok(); + } + rtVal = R.fail(); }else{ - throw new ServiceException("事件处理添加出错"); + //编辑原来的 + EventDO eventDO = eventMapper.selectById(specialEventEditDTO.getId()); + BeanUtils.copyProperties(specialEventEditDTO, eventDO); + eventDO.setGridMemberId(specialEventEditDTO.getUserId()); + eventDO.setEventCategory(1l);//办件事件 + eventDO.setEventStatus(1);//事件状态 2发布 + eventDO.setProcessType(1);//网格员处理 + eventDO.setCommunityProcess(0);//非 社区处理 + eventDO.setUpdateBy(specialEventEditDTO.getUserId()); + if (eventMapper.updateById(eventDO) > 0) { + int deleted = eventResourceService.getBaseMapper() + .delete(new LambdaQueryWrapper<EventResourceDO>() + .eq(EventResourceDO::getClassification,1) + .eq(EventResourceDO::getRefId, eventDO.getId())); + //添加音频 + if (StringUtils.isNotEmpty(specialEventEditDTO.getAudio())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(2); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(specialEventEditDTO.getAudio()); + eventResourceDO.setCreateBy(specialEventEditDTO.getUserId()); + int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (audioAdd != 1) { + throw new ServiceException("添加音频失败"); + } + } + //添加视频 + if (StringUtils.isNotEmpty(specialEventEditDTO.getVideo())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(3); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(specialEventEditDTO.getVideo()); + eventResourceDO.setCreateBy(specialEventEditDTO.getUserId()); + int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (videoAdd != 1) { + throw new ServiceException("添加视频失败"); + } + } + //添加图片 + if (StringUtils.isNotEmpty(specialEventEditDTO.getPics())) { + String[] pica = specialEventEditDTO.getPics().split(","); + for (int i = 0; i < pica.length; i++) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(1); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(pica[i]); + eventResourceDO.setCreateBy(specialEventEditDTO.getUserId()); + int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (picAdd != 1) { + throw new ServiceException("添加图片失败"); + } + } + } + rtVal = R.ok(); + } + rtVal = R.fail(); + } + if(R.isOk(rtVal)){ + //TODO 处理特殊人群实有人口数据 + + } + return rtVal; + } + + @Override + public R addSpecial(SpecialEventAddDTO specialEventAddDTO) { + R rtVal = R.fail(); + EventDO eventDO = new EventDO(); + BeanUtils.copyProperties(specialEventAddDTO, eventDO); + eventDO.setGridMemberId(specialEventAddDTO.getUserId()); + eventDO.setEventCategory(1l);//办件事件 + eventDO.setEventType(EventType.SPECIAL);//特殊人群信息上报-事件分类 + eventDO.setEventStatus(1);//事件状态 1草稿 + eventDO.setProcessType(1);//网格员处理 + eventDO.setCommunityProcess(0);//非 社区处理 + eventDO.setCreateBy(specialEventAddDTO.getUserId()); + if (eventMapper.insert(eventDO) > 0) { + //添加音频 + if (StringUtils.isNotEmpty(specialEventAddDTO.getAudio())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(2); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(specialEventAddDTO.getAudio()); + eventResourceDO.setCreateBy(specialEventAddDTO.getUserId()); + int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (audioAdd != 1) { + throw new ServiceException("添加音频失败"); + } + } + //添加视频 + if (StringUtils.isNotEmpty(specialEventAddDTO.getVideo())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(3); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(specialEventAddDTO.getVideo()); + eventResourceDO.setCreateBy(specialEventAddDTO.getUserId()); + int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (videoAdd != 1) { + throw new ServiceException("添加视频失败"); + } + } + //添加图片 + if (StringUtils.isNotEmpty(specialEventAddDTO.getPics())) { + String[] pica = specialEventAddDTO.getPics().split(","); + for (int i = 0; i < pica.length; i++) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(1); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(pica[i]); + eventResourceDO.setCreateBy(specialEventAddDTO.getUserId()); + int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (picAdd != 1) { + throw new ServiceException("添加图片失败"); + } + } + } + rtVal = R.ok(); + } + rtVal = R.fail(); + + if(R.isOk(rtVal)){ + //TODO 处理特殊人群实有人口数据 + + addReleaseRecord(eventDO.getId(), specialEventAddDTO.getUserId(), specialEventAddDTO.getUserName()); + return R.ok(); + } + return rtVal; + } + + @Override + public R getSpecialPopulation(String idCard) { + ComMngPopulationDTO comMngPopulationDTO = new ComMngPopulationDTO(); + comMngPopulationDTO.setCardNo(idCard); + comMngPopulationDTO.setPageSize(10l); + comMngPopulationDTO.setPageNum(1l); + return communityService.pagePopulation(comMngPopulationDTO); + } + + @Override + public R addPublicity(PublicityEventAddDTO publicityEventAddDTO) { + EventDO eventDO = new EventDO(); + BeanUtils.copyProperties(publicityEventAddDTO, eventDO); + eventDO.setGridMemberId(publicityEventAddDTO.getUserId()); + eventDO.setEventCategory(2l);//宣传事件 + eventDO.setEventStatus(2);//事件状态 2发布 + eventDO.setGridMemberId(publicityEventAddDTO.getUserId()); + eventDO.setGridMemberName(publicityEventAddDTO.getUserName()); + eventDO.setGridMemberTelephone(publicityEventAddDTO.getPhone()); + eventDO.setCreateBy(publicityEventAddDTO.getUserId()); + if(eventMapper.insert(eventDO)==1){ + //添加音频 + if(StringUtils.isNotEmpty(publicityEventAddDTO.getAudio())){ + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(2); + eventResourceDO.setUrl(publicityEventAddDTO.getAudio()); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setCreateBy(publicityEventAddDTO.getUserId()); + int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if(audioAdd!=1){ + throw new ServiceException("添加音频失败"); + } + } + //添加视频 + if(StringUtils.isNotEmpty(publicityEventAddDTO.getVideo())){ + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(3); + eventResourceDO.setUrl(publicityEventAddDTO.getVideo()); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setCreateBy(publicityEventAddDTO.getUserId()); + int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if(videoAdd!=1){ + throw new ServiceException("添加视频失败"); + } + } + //添加图片 + if(StringUtils.isNotEmpty(publicityEventAddDTO.getPics())){ + String[] pica = publicityEventAddDTO.getPics().split(","); + for (int i = 0; i < pica.length; i++) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(1); + eventResourceDO.setUrl(pica[i]); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setCreateBy(publicityEventAddDTO.getUserId()); + int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if(picAdd!=1){ + throw new ServiceException("添加图片失败"); + } + } + } + addReleaseRecord(eventDO.getId(), publicityEventAddDTO.getUserId(), publicityEventAddDTO.getUserName()); + return R.ok(); + } + return R.fail(); + + } + + @Override + public R savePublicityDraft(PublicityEventEditDTO publicityEventEditDTO) { + if(publicityEventEditDTO.getId()==null) { + EventDO eventDO = new EventDO(); + BeanUtils.copyProperties(publicityEventEditDTO, eventDO); + eventDO.setGridMemberId(publicityEventEditDTO.getUserId()); + eventDO.setEventCategory(2l);//宣传事件 + eventDO.setEventStatus(1);//事件状态 1草稿 + eventDO.setCreateBy(publicityEventEditDTO.getUserId()); + eventDO.setGridMemberId(publicityEventEditDTO.getUserId()); + eventDO.setGridMemberName(publicityEventEditDTO.getUserName()); + eventDO.setGridMemberTelephone(publicityEventEditDTO.getPhone()); + if (eventMapper.insert(eventDO) > 0) { + //添加音频 + if (StringUtils.isNotEmpty(publicityEventEditDTO.getAudio())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(2); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(publicityEventEditDTO.getAudio()); + eventResourceDO.setCreateBy(publicityEventEditDTO.getUserId()); + int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (audioAdd != 1) { + throw new ServiceException("添加音频失败"); + } + } + //添加视频 + if (StringUtils.isNotEmpty(publicityEventEditDTO.getVideo())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(3); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(publicityEventEditDTO.getVideo()); + eventResourceDO.setCreateBy(publicityEventEditDTO.getUserId()); + int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (videoAdd != 1) { + throw new ServiceException("添加视频失败"); + } + } + //添加图片 + if (StringUtils.isNotEmpty(publicityEventEditDTO.getPics())) { + String[] pica = publicityEventEditDTO.getPics().split(","); + for (int i = 0; i < pica.length; i++) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(1); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(pica[i]); + eventResourceDO.setCreateBy(publicityEventEditDTO.getUserId()); + int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (picAdd != 1) { + throw new ServiceException("添加图片失败"); + } + } + } + return R.ok(); + } + return R.fail(); + }else{ + //编辑原来的 + EventDO eventDO = eventMapper.selectById(publicityEventEditDTO.getId()); + BeanUtils.copyProperties(publicityEventEditDTO, eventDO); + eventDO.setGridMemberId(publicityEventEditDTO.getUserId()); + eventDO.setEventCategory(2L);//宣传事件 + eventDO.setEventStatus(1);//事件状态 2发布 + eventDO.setProcessType(1);//网格员处理 + eventDO.setCommunityProcess(0);//非 社区处理 + eventDO.setUpdateBy(publicityEventEditDTO.getUserId()); + if (eventMapper.updateById(eventDO) > 0) { + int deleted = eventResourceService.getBaseMapper() + .delete(new LambdaQueryWrapper<EventResourceDO>() + .eq(EventResourceDO::getClassification,1) + .eq(EventResourceDO::getRefId, eventDO.getId())); + //添加音频 + if (StringUtils.isNotEmpty(publicityEventEditDTO.getAudio())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(2); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(publicityEventEditDTO.getAudio()); + eventResourceDO.setCreateBy(publicityEventEditDTO.getUserId()); + int audioAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (audioAdd != 1) { + throw new ServiceException("添加音频失败"); + } + } + //添加视频 + if (StringUtils.isNotEmpty(publicityEventEditDTO.getVideo())) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(3); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(publicityEventEditDTO.getVideo()); + eventResourceDO.setCreateBy(publicityEventEditDTO.getUserId()); + int videoAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (videoAdd != 1) { + throw new ServiceException("添加视频失败"); + } + } + //添加图片 + if (StringUtils.isNotEmpty(publicityEventEditDTO.getPics())) { + String[] pica = publicityEventEditDTO.getPics().split(","); + for (int i = 0; i < pica.length; i++) { + EventResourceDO eventResourceDO = new EventResourceDO(); + eventResourceDO.setClassification(1); + eventResourceDO.setType(1); + eventResourceDO.setRefId(eventDO.getId()); + eventResourceDO.setUrl(pica[i]); + eventResourceDO.setCreateBy(publicityEventEditDTO.getUserId()); + int picAdd = eventResourceService.getBaseMapper().insert(eventResourceDO); + if (picAdd != 1) { + throw new ServiceException("添加图片失败"); + } + } + } + return R.ok(); + } + return R.fail(); } } + @Override + public R selectPublicity(PagePublicityEventDTO pagePublicityEventDTO) { + Page page = new Page(1,10); + if(pagePublicityEventDTO.getPageNum()!=null) { + page.setCurrent(pagePublicityEventDTO.getPageNum()); + } + if(pagePublicityEventDTO.getPageSize()!=null) { + page.setSize(pagePublicityEventDTO.getPageSize()); + } + IPage<EventVO> ipage = eventMapper.findPublicityByPage(page, pagePublicityEventDTO); + if(ipage!=null){ + List<EventVO> eventVOList = ipage.getRecords(); + eventVOList.forEach(eventVO -> { + List<EventResourceDO> eventResourceDOList = + eventResourceService.getBaseMapper().selectList(new LambdaQueryWrapper<EventResourceDO>() + .eq(EventResourceDO::getClassification, 1) + .eq(EventResourceDO::getRefId, eventVO.getId()) + ); + List<EventResourceVO> picList = new ArrayList<>(); + List<EventResourceVO> audioList = new ArrayList<>(); + List<EventResourceVO> videoList = new ArrayList<>(); + eventResourceDOList.forEach(eventResourceDO -> { + switch (eventResourceDO.getType()){ + case 1: + EventResourceVO picEventResourceVO = new EventResourceVO(); + BeanUtils.copyProperties(eventResourceDO, picEventResourceVO); + picList.add(picEventResourceVO); + break; + case 2: + EventResourceVO audioResourceVO = new EventResourceVO(); + BeanUtils.copyProperties(eventResourceDO, audioResourceVO); + audioList.add(audioResourceVO); + break; + case 3: + EventResourceVO videoResourceVO = new EventResourceVO(); + BeanUtils.copyProperties(eventResourceDO, videoResourceVO); + videoList.add(videoResourceVO); + break; + } + }); + eventVO.setAudios(audioList); + eventVO.setPics(picList); + eventVO.setVideos(videoList); + }); + return R.ok(ipage); + } + return R.fail(); + } + + /** + * 添加发布事件流转记录 + * @param eventId 事件ID + * @param userId 操作用户ID + * @param userName 操作用户姓名 + * @return 添加成功返回true, 否则返回false + */ + private EventTransferRecordDO addReleaseRecord(Long eventId, Long userId, String userName){ + EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); + eventTransferRecordDO.setFromType(1); + eventTransferRecordDO.setFromId(userId); + eventTransferRecordDO.setFromName(userName); + eventTransferRecordDO.setToType(1); + eventTransferRecordDO.setToId(userId); + eventTransferRecordDO.setToName(userName); + eventTransferRecordDO.setProcessDate(new Date()); + eventTransferRecordDO.setEventId(eventId); + eventTransferRecordDO.setProcessResult("发布成功"); + int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); + if(inserted!=1){ + throw new ServiceException("事件流转记录添加失败"); + } + return eventTransferRecordDO; + } + + /** + * 查询最后的流转记录,并添加事件流转记录 + * @param eventId 事件ID + * @param toId 流转到 ID + * @param toName 流转到 名称 + * @param toType 发送类型 + * @param msg 流转消息 + * @return + */ + private EventTransferRecordDO addTransferRecord(Long eventId, Long toId, String toName, Integer toType, String msg){ + List<EventTransferRecordDO> list = eventTransferRecordService.getBaseMapper().selectList(new LambdaQueryWrapper<EventTransferRecordDO>() + .eq(EventTransferRecordDO::getEventId, eventId) + .orderByDesc(EventTransferRecordDO::getCreateAt) + ); + if(list==null ||list.size()==0){ + throw new ServiceException("事件流转记录异常"); + } + EventTransferRecordDO lastRecord = list.get(0); + EventTransferRecordDO eventTransferRecordDO = new EventTransferRecordDO(); + eventTransferRecordDO.setFromType(lastRecord.getToType()); + eventTransferRecordDO.setFromId(lastRecord.getToId()); + eventTransferRecordDO.setFromName(lastRecord.getToName()); + eventTransferRecordDO.setToType(toType); + eventTransferRecordDO.setToId(toId); + eventTransferRecordDO.setProcessDate(new Date()); + eventTransferRecordDO.setToName(toName); + eventTransferRecordDO.setEventId(eventId); + eventTransferRecordDO.setProcessResult(msg); + int inserted = eventTransferRecordService.getBaseMapper().insert(eventTransferRecordDO); + if(inserted==1) { + return eventTransferRecordDO; + }else{ + throw new ServiceException("事件流转记录添加失败"); + } + } } -- Gitblit v1.7.1