| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- /*
- * Copyright 2017-2020 吴学文 and java110 team.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package com.java110.community.cmd.activities;
- import com.alibaba.fastjson.JSONObject;
- import com.java110.core.annotation.Java110Cmd;
- import com.java110.core.annotation.Java110Transactional;
- import com.java110.core.context.DataFlowContext;
- import com.java110.core.context.ICmdDataFlowContext;
- import com.java110.core.event.cmd.Cmd;
- import com.java110.core.event.cmd.CmdEvent;
- import com.java110.core.factory.GenerateCodeFactory;
- 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.common.IFileRelInnerServiceSMO;
- import com.java110.intf.community.IActivitiesTypeInnerServiceSMO;
- import com.java110.intf.community.IActivitiesV1InnerServiceSMO;
- 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.BusinessTypeConstant;
- import com.java110.utils.constant.StateConstant;
- import com.java110.utils.exception.CmdException;
- import com.java110.utils.util.Assert;
- import com.java110.utils.util.BeanConvertUtil;
- import com.java110.vo.ResultVo;
- import com.java110.vo.api.community.ApiCommunityDataVo;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import java.util.List;
- /**
- * 类表述:保存
- * 服务编码:activities.saveActivities
- * 请求路劲:/app/activities.SaveActivities
- * add by 吴学文 at 2022-06-19 10:49:17 mail: 928255095@qq.com
- * open source address: https://gitee.com/wuxw7/MicroCommunity
- * 官网:http://www.homecommunity.cn
- * 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
- * // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
- */
- @Java110Cmd(serviceCode = "activities.saveActivities")
- public class SaveActivitiesCmd extends Cmd {
- private static Logger logger = LoggerFactory.getLogger(SaveActivitiesCmd.class);
- public static final String CODE_PREFIX_ID = "10";
- @Autowired
- private IActivitiesV1InnerServiceSMO activitiesV1InnerServiceSMOImpl;
- @Autowired
- private IFileInnerServiceSMO fileInnerServiceSMOImpl;
- @Autowired
- private IActivitiesTypeInnerServiceSMO activitiesTypeInnerServiceSMOImpl;
- @Autowired
- private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
- @Autowired
- private IOrgStaffRelInnerServiceSMO orgStaffRelInnerServiceSMOImpl;
- @Autowired
- private IOrgCommunityInnerServiceSMO orgCommunityInnerServiceSMOImpl;
- @Autowired
- private IOrgInnerServiceSMO orgInnerServiceSMOImpl;
- @Autowired
- private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
- @Override
- public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
- //Assert.hasKeyAndValue(reqJson, "xxx", "xxx");
- Assert.hasKeyAndValue(reqJson, "title", "必填,请填写业活动标题");
- Assert.hasKeyAndValue(reqJson, "typeCd", "必填,请选择活动类型");
- Assert.hasKeyAndValue(reqJson, "headerImg", "必填,请选择头部照片");
- Assert.hasKeyAndValue(reqJson, "context", "必填,请填写活动内容");
- Assert.hasKeyAndValue(reqJson, "startTime", "必填,请选择开始时间");
- Assert.hasKeyAndValue(reqJson, "endTime", "必填,请选择结束时间");
- Assert.hasKeyAndValue(reqJson, "userId", "必填,请填写用户ID");
- Assert.hasKeyAndValue(reqJson, "userName", "必填,请填写用户名称");
- }
- @Override
- @Java110Transactional
- public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
- if (!reqJson.containsKey("isMoreCommunity") || "N".equals(reqJson.getString("isMoreCommunity"))) {
- addActivities(cmdDataFlowContext, reqJson);
- return;
- }
- List<ApiCommunityDataVo> communityDataVos = getCommunitys(reqJson);
- if (communityDataVos == null || communityDataVos.size() < 1) {
- return;
- }
- ActivitiesTypeDto activitiesTypeDto = new ActivitiesTypeDto();
- activitiesTypeDto.setCommunityId(reqJson.getString("communityId"));
- activitiesTypeDto.setTypeCd(reqJson.getString("typeCd"));
- List<ActivitiesTypeDto> oneActivitiesTypeDtos = activitiesTypeInnerServiceSMOImpl.queryActivitiesTypes(activitiesTypeDto);
- Assert.listOnlyOne(oneActivitiesTypeDtos, "通知类型不存在");
- List<ActivitiesTypeDto> activitiesTypeDtos = null;
- for (ApiCommunityDataVo apiCommunityDataVo : communityDataVos) {
- reqJson.put("communityId", apiCommunityDataVo.getCommunityId());
- activitiesTypeDto = new ActivitiesTypeDto();
- activitiesTypeDto.setCommunityId(reqJson.getString("communityId"));
- activitiesTypeDto.setTypeName(oneActivitiesTypeDtos.get(0).getTypeName());
- activitiesTypeDtos = activitiesTypeInnerServiceSMOImpl.queryActivitiesTypes(activitiesTypeDto);
- if (activitiesTypeDtos == null || activitiesTypeDtos.size() < 1) {
- continue;
- }
- reqJson.put("typeCd", activitiesTypeDtos.get(0).getTypeCd());
- addActivities(cmdDataFlowContext, 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(ICmdDataFlowContext 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));
- fileDto.setFileName(fileDto.getFileId());
- fileDto.setContext(reqJson.getString("headerImg"));
- fileDto.setSuffix("jpeg");
- fileDto.setCommunityId(reqJson.getString("communityId"));
- String fileName = fileInnerServiceSMOImpl.saveFile(fileDto);
- reqJson.put("headerImg", fileDto.getFileId());
- reqJson.put("fileSaveName", fileName);
- FileRelPo fileRelPo = new FileRelPo();
- fileRelPo.setFileRelId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_fileRelId));
- fileRelPo.setFileRealName(reqJson.getString("headerImg"));
- fileRelPo.setFileSaveName(reqJson.getString("fileSaveName"));
- fileRelPo.setObjId(reqJson.getString("activitiesId"));
- fileRelPo.setSaveWay("table");
- fileRelPo.setRelTypeCd("70000");
- int flag = fileRelInnerServiceSMOImpl.saveFileRel(fileRelPo);
- if(flag < 1){
- throw new CmdException("保存广告失败");
- }
- }
- ActivitiesPo activitiesPo = BeanConvertUtil.covertBean(reqJson, ActivitiesPo.class);
- activitiesPo.setReadCount("0");
- activitiesPo.setLikeCount("0");
- activitiesPo.setCollectCount("0");
- activitiesPo.setState("11000");
- int flag = activitiesV1InnerServiceSMOImpl.saveActivities(activitiesPo);
- if(flag < 1){
- throw new CmdException("保存广告失败");
- }
- }
- }
|