java110 пре 4 година
родитељ
комит
da931fb016

+ 104 - 11
service-api/src/main/java/com/java110/api/listener/activities/SaveActivitiesListener.java

@@ -3,23 +3,36 @@ package com.java110.api.listener.activities;
 import com.alibaba.fastjson.JSONObject;
 import com.java110.api.bmo.activities.IActivitiesBMO;
 import com.java110.api.listener.AbstractServiceApiPlusListener;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.event.service.api.ServiceDataFlowEvent;
 import com.java110.core.factory.GenerateCodeFactory;
-import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.dto.activitiesType.ActivitiesTypeDto;
+import com.java110.dto.community.CommunityDto;
 import com.java110.dto.file.FileDto;
+import com.java110.dto.org.OrgCommunityDto;
+import com.java110.dto.org.OrgDto;
+import com.java110.dto.org.OrgStaffRelDto;
+import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.intf.community.IActivitiesTypeInnerServiceSMO;
+import com.java110.intf.community.ICommunityInnerServiceSMO;
+import com.java110.intf.user.IOrgCommunityInnerServiceSMO;
+import com.java110.intf.user.IOrgInnerServiceSMO;
+import com.java110.intf.user.IOrgStaffRelInnerServiceSMO;
 import com.java110.po.activities.ActivitiesPo;
 import com.java110.po.file.FileRelPo;
-import com.java110.utils.constant.*;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.constant.ServiceCodeActivitiesConstant;
+import com.java110.utils.constant.StateConstant;
 import com.java110.utils.util.Assert;
-import com.java110.core.context.DataFlowContext;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-
-
-import com.java110.core.annotation.Java110Listener;
 import com.java110.utils.util.BeanConvertUtil;
+import com.java110.vo.api.community.ApiCommunityDataVo;
 import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.http.HttpMethod;
 
+import java.util.List;
+
 /**
  * 保存小区侦听
  * add by wuxw 2019-06-30
@@ -33,6 +46,21 @@ public class SaveActivitiesListener extends AbstractServiceApiPlusListener {
     @Autowired
     private IActivitiesBMO activitiesBMOImpl;
 
+    @Autowired
+    private IActivitiesTypeInnerServiceSMO activitiesTypeInnerServiceSMOImpl;
+
+    @Autowired
+    private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgStaffRelInnerServiceSMO orgStaffRelInnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgCommunityInnerServiceSMO orgCommunityInnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgInnerServiceSMO orgInnerServiceSMOImpl;
+
     @Override
     protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
         //Assert.hasKeyAndValue(reqJson, "xxx", "xxx");
@@ -49,10 +77,77 @@ public class SaveActivitiesListener extends AbstractServiceApiPlusListener {
 
     @Override
     protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
+        if (!reqJson.containsKey("isMoreCommunity") || "N".equals(reqJson.getString("isMoreCommunity"))) {
+            addActivities(context, reqJson);
+            return;
+        }
 
+        List<ApiCommunityDataVo> communityDataVos = getCommunitys(reqJson);
 
-        reqJson.put("activitiesId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_activitiesId));
+        if (communityDataVos == null || communityDataVos.size() < 1) {
+            return;
+        }
 
+        ActivitiesTypeDto activitiesTypeDto = new ActivitiesTypeDto();
+        activitiesTypeDto.setCommunityId(reqJson.getString("communityId"));
+        activitiesTypeDto.setTypeCd(reqJson.getString("typeCd"));
+        List<ActivitiesTypeDto> activitiesTypeDtos = activitiesTypeInnerServiceSMOImpl.queryActivitiesTypes(activitiesTypeDto);
+
+        Assert.listOnlyOne(activitiesTypeDtos, "通知类型不存在");
+
+        for (ApiCommunityDataVo apiCommunityDataVo : communityDataVos) {
+            reqJson.put("communityId", apiCommunityDataVo.getCommunityId());
+            activitiesTypeDto = new ActivitiesTypeDto();
+            activitiesTypeDto.setCommunityId(reqJson.getString("communityId"));
+            activitiesTypeDto.setTypeCd(activitiesTypeDtos.get(0).getTypeName());
+            activitiesTypeDtos = activitiesTypeInnerServiceSMOImpl.queryActivitiesTypes(activitiesTypeDto);
+            if (activitiesTypeDtos == null || activitiesTypeDtos.size() < 1) {
+                continue;
+            }
+            reqJson.put("typeCd", activitiesTypeDtos.get(0).getTypeCd());
+            addActivities(context, reqJson);
+        }
+    }
+
+    public List<ApiCommunityDataVo> getCommunitys(JSONObject reqJson) {
+
+        //1.0 先查询 员工对应的部门
+        OrgStaffRelDto orgStaffRelDto = new OrgStaffRelDto();
+        orgStaffRelDto.setStoreId(reqJson.getString("storeId"));
+        orgStaffRelDto.setStaffId(reqJson.getString("userId"));
+        List<OrgStaffRelDto> orgStaffRelDtos = orgStaffRelInnerServiceSMOImpl.queryOrgStaffRels(orgStaffRelDto);
+
+        Assert.listOnlyOne(orgStaffRelDtos, "未查询到相应员工对应的部门信息或查询到多条");
+
+        //2.0 再根据 部门对应的 小区ID查询小区信息
+        OrgDto orgDto = new OrgDto();
+        orgDto.setOrgId(orgStaffRelDtos.get(0).getParentOrgId());
+        orgDto.setStoreId(reqJson.getString("storeId"));
+        orgDto.setOrgLevel("2");
+        List<OrgDto> orgDtos = orgInnerServiceSMOImpl.queryOrgs(orgDto);
+
+        Assert.listOnlyOne(orgDtos, "根据组织ID未查询到员工对应部门信息或查询到多条数据");
+
+        List<ApiCommunityDataVo> communitys = null;
+        if ("9999".equals(orgDtos.get(0).getBelongCommunityId())) {
+            CommunityDto communityDto = new CommunityDto();
+            communityDto.setMemberId(reqJson.getString("storeId"));
+            communityDto.setAuditStatusCd(StateConstant.AGREE_AUDIT);
+            communitys = BeanConvertUtil.covertBeanList(communityInnerServiceSMOImpl.queryCommunitys(communityDto), ApiCommunityDataVo.class);
+        } else {
+            String companyOrgId = orgDtos.get(0).getOrgId();
+            OrgCommunityDto orgCommunityDto = BeanConvertUtil.covertBean(reqJson, OrgCommunityDto.class);
+            orgCommunityDto.setOrgId(companyOrgId);
+
+            List<OrgCommunityDto> orgCommunityDtos = orgCommunityInnerServiceSMOImpl.queryOrgCommunitys(orgCommunityDto);
+            communitys = BeanConvertUtil.covertBeanList(orgCommunityDtos, ApiCommunityDataVo.class);
+        }
+
+        return communitys;
+    }
+
+    public void addActivities(DataFlowContext context, JSONObject reqJson) {
+        reqJson.put("activitiesId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_activitiesId));
         if (reqJson.containsKey("headerImg") && !StringUtils.isEmpty(reqJson.getString("headerImg"))) {
             FileDto fileDto = new FileDto();
             fileDto.setFileId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_file_id));
@@ -66,7 +161,7 @@ public class SaveActivitiesListener extends AbstractServiceApiPlusListener {
             reqJson.put("fileSaveName", fileName);
 
             FileRelPo fileRelPo = new FileRelPo();
-            fileRelPo.setFileRelId("-1");
+            fileRelPo.setFileRelId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_fileRelId));
             fileRelPo.setFileRealName(reqJson.getString("headerImg"));
             fileRelPo.setFileSaveName(reqJson.getString("fileSaveName"));
             fileRelPo.setObjId(reqJson.getString("activitiesId"));
@@ -75,7 +170,6 @@ public class SaveActivitiesListener extends AbstractServiceApiPlusListener {
             super.insert(context, fileRelPo, BusinessTypeConstant.BUSINESS_TYPE_SAVE_FILE_REL);
 
         }
-
         ActivitiesPo activitiesPo = BeanConvertUtil.covertBean(reqJson, ActivitiesPo.class);
         activitiesPo.setReadCount("0");
         activitiesPo.setLikeCount("0");
@@ -83,7 +177,6 @@ public class SaveActivitiesListener extends AbstractServiceApiPlusListener {
         activitiesPo.setState("11000");
         //添加单元信息
         super.insert(context, activitiesPo, BusinessTypeConstant.BUSINESS_TYPE_SAVE_ACTIVITIES);
-
     }