package com.doumee.service.business.impl; import com.alibaba.fastjson.JSONObject; import com.doumee.biz.system.SystemDictDataBiz; import com.doumee.core.constants.Constants; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.DateUtil; import com.doumee.core.utils.Utils; import com.doumee.core.utils.qiyeweixin.QywxUtil; import com.doumee.core.utils.qiyeweixin.model.request.QywxSendMsgRequest; import com.doumee.core.utils.qiyeweixin.model.request.QywxTextCardMsgRequest; import com.doumee.dao.business.*; import com.doumee.dao.business.model.*; import com.doumee.dao.business.vo.WorkorderIndexNumVO; import com.doumee.dao.web.dto.*; import com.doumee.dao.web.vo.WorkOrderDataVO; import com.doumee.service.business.WorkorderService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.doumee.service.common.EmailService; import com.github.yulichang.wrapper.MPJLambdaWrapper; import com.sun.corba.se.spi.orbutil.threadpool.Work; import lombok.extern.slf4j.Slf4j; import org.apache.catalina.Manager; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; import javax.annotation.Resource; import java.io.Serializable; import java.util.*; import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; /** * 工单信息表Service实现 * @author 江蹄蹄 * @since 2025/04/02 17:49 */ @Service @Slf4j public class WorkorderServiceImpl implements WorkorderService { @Autowired private WorkorderMapper workorderMapper; @Autowired private MultifileMapper multifileMapper; @Autowired private WorkorderLogMapper workorderLogMapper; @Autowired private SystemDictDataBiz systemDictDataBiz; @Autowired private EmailService emailService; @Autowired private MemberMapper memberMapper; @Autowired private ManagersMapper managersMapper; @Autowired private CategoryMapper categoryMapper; @Autowired private NoticesMapper noticesMapper; @Resource(name="sessionRedisTemplate") private RedisTemplate redisTemplate; @Override @Transactional(rollbackFor = {BusinessException.class,Exception.class}) public Integer create(Workorder workorder) { this.isValidBaseParam(workorder); workorder.setEditDate(new Date()); workorder.setMemberId(workorder.getMemberId()); workorder.setIsdeleted(Constants.ZERO); workorder.setCode(this.getNextCode(workorder.getType())); workorder.setEmailStatus(Constants.ZERO); workorder.setCreateDate(new Date()); //处理人员类信息 this.dealNoticeData(workorder); //处理SHE事件状态 Constants.WorkOrderStatus workOrderStatus = Constants.equalsInteger(workorder.getType(),Constants.ZERO)?Constants.WorkOrderStatus.close:Constants.WorkOrderStatus.waitConfirm; workorder.setStatus(workOrderStatus.getKey()); workorder.setSheDealUserQwIds(workorder.getQwnoticeMemberIds()); workorderMapper.insert(workorder); //存储DCA 问题记录表 this.saveProblemData(workorder); //存储附件信息 this.saveMutiFile(workorder); //存储日志 this.dealLogData(workorder,workOrderStatus); Member member = memberMapper.selectById(workorder.getMemberId()); Category category = categoryMapper.selectById(workorder.getTypeId()); if(Objects.nonNull(member)&&Objects.nonNull(category)){ // 发送企微通知 this.sendQwMsg(workorder,workorder.getQwnoticeMemberIds(),member,category.getName(),Constants.ZERO,null); } //存储待办人员信息 this.saveNotice(Arrays.asList(workorder.getQwnoticeMemberIds().split(",")),workorder.getId(),Constants.ZERO,Constants.ZERO); return workorder.getId(); } /** * 发送通知 * @param workorder * @param qwIds 消息接收人 * @param member 操作人名称 * @param categoryName * @param contentType 0=正常通知;1=催促;2=抄送 3=已处理一项/任务已处理 * @param csInfo 抄送信息 */ public void sendQwMsg(Workorder workorder,String qwIds,Member member,String categoryName,Integer contentType,String csInfo){ if(Constants.equalsInteger(workorder.getType(),Constants.TWO)){ workorder = workorderMapper.selectById(workorder.getDcaRecordId()); } if(StringUtils.isEmpty(qwIds)){ return; } QywxSendMsgRequest qywxSendMsgRequest = new QywxSendMsgRequest(); qywxSendMsgRequest.setMsgtype("textcard"); qywxSendMsgRequest.setTouser(qwIds.replace(",","|")); qywxSendMsgRequest.setAgentid(systemDictDataBiz.queryByCode(Constants.QYWX,Constants.QYWX_AGENTID).getCode()); String sendUser = ""; if(Objects.nonNull(member)){ if(org.apache.commons.lang3.StringUtils.isNotBlank(member.getName())){ sendUser = member.getName(); } if(org.apache.commons.lang3.StringUtils.isNotBlank(member.getCompanyName())){ sendUser = member.getCompanyName()+"/" + sendUser ; } } QywxTextCardMsgRequest textCard = this.dealMessageContent(workorder,sendUser,categoryName,contentType,csInfo); qywxSendMsgRequest.setTextcard(textCard); QywxUtil.sendMsg(systemDictDataBiz.queryByCode(Constants.QYWX,Constants.QYWX_TOKEN).getCode(), qywxSendMsgRequest); //https://open.weixin.qq.com/connect/oauth2/authorize?appid=${corpId}&redirect_uri=https://dmtest.ahapp.net/lianhelihua_web/&response_type=code&scope=snsapi_base&state={status}#wechat_redirect } private static final String jumpUrl = "https://open.weixin.qq.com/connect/oauth2/authorize?appid={corpId}&redirect_uri={ourUrl}"; /** * 通知文案整理 * @param workorder * @param userName 操作人名称 部门+名称 * @param categoryName * @param contentType 0=正常通知;1=催促(跌绊滑/DCA);2=抄送(DCA) 3=已处理一项/任务已处理 * @param csInfo 抄送信息 * @return */ public QywxTextCardMsgRequest dealMessageContent(Workorder workorder,String userName ,String categoryName,Integer contentType,String csInfo){ QywxTextCardMsgRequest textCard = new QywxTextCardMsgRequest(); String message = ""; String url = jumpUrl.replace("{corpId}",systemDictDataBiz.queryByCode(Constants.QYWX,Constants.QYWX_CORPID).getCode()); String jumpOurUrl = systemDictDataBiz.queryByCode(Constants.QYWX,Constants.JUMP_OUT_URL).getCode().replace("{status}", workorder.getType()+"_"+workorder.getId()); textCard.setUrl(url.replace("{ourUrl}",jumpOurUrl)); log.error("企微链接地址"+url); if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)){ textCard.setTitle("【SHE事件上报】"); if(Constants.equalsInteger(workorder.getMemberType(),Constants.ZERO)){ message = "本人"; }else { message = Constants.equalsInteger(workorder.getMemberType(),Constants.ONE)?"同事":"供应商"; } message = message + "-" + workorder.getMemberNames() + " " + DateUtil.formatDate(new Date(),"yyyy-MM-dd HH:mm") + "/" +workorder.getLocationName() + "/" + categoryName; textCard.setDescription("
"+message+"
"); }else{ textCard.setTitle(Constants.equalsInteger(workorder.getType(),Constants.ONE)?"【DCA上报】":"【跌绊滑风险上报】"); if(Constants.equalsInteger(workorder.getType(),Constants.THREE)){ message = message + "
"+ (org.apache.commons.lang3.StringUtils.isNotBlank(userName)?userName:"系统") + (Constants.equalsInteger(contentType,Constants.ZERO)?"任务分配给你":(Constants.equalsInteger(contentType,Constants.ONE)?"对该工单进行了催促,请尽快处理":"任务已处理")) +"
"; message = message + "
"+ DateUtil.formatDate(new Date(),"yyyy-MM-dd HH:mm") +"/"+ workorder.getLocationName() +"/"+ categoryName+"
"; }else{ message = message + "
"+ (org.apache.commons.lang3.StringUtils.isNotBlank(userName)?userName:"系统") + (Constants.equalsInteger(contentType,Constants.ZERO)?"任务分配给你":(Constants.equalsInteger(contentType,Constants.ONE)?"对该工单进行了催促,请尽快处理":((Constants.equalsInteger(contentType,Constants.TWO)?"抄送给你":"已处理一项")))) +"
"; message = message + "
观察主题 "+ categoryName +"
"; message = message + "
符合:"+ workorder.getDcaYesNum() +" 不符合:"+workorder.getDcaNoNum()+"
"; if(Constants.equalsInteger(contentType,Constants.TWO)){ message = message + "
说明 "+ csInfo +"
"; } } textCard.setDescription(message); } return textCard; } public void dealLogData(Workorder workorder,Constants.WorkOrderStatus workOrderStatus){ if (Constants.equalsInteger(workorder.getType(), Constants.THREE) || Constants.equalsInteger(workorder.getType(), Constants.TWO) ) { //处理上报日志 DCA工单 日志存储至子业务 不存在于父级 与跌绊滑 String logTitle = Constants.equalsInteger(workorder.getType(), Constants.THREE) ? "跌绊滑风险" : "DCA"; workorder.setCreateDate(workorder.getSubmitDate()); this.saveLog(null,workorder,Constants.ZERO,workorder.getMemberId(),workOrderStatus.getLogTitle().replace("{title}",logTitle),null,null,null); } } /** * 存储附件信息 * @param workorder */ public void saveMutiFile(Workorder workorder){ List multifileList = workorder.getMultifileList(); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { if(StringUtils.isEmpty(multifile.getFileurl())){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"附件信息错误!"); } multifile.setIsdeleted(Constants.ZERO); multifile.setObjId(workorder.getId()); multifile.setCreateDate(new Date()); multifile.setObjType(Constants.multiFileType.upload); multifileMapper.insert(multifile); } } } /** * 处理 DCA 提报 问题数据 * @param workorder */ public void saveProblemData(Workorder workorder){ if(Constants.equalsInteger(workorder.getType(),Constants.ONE)){ List dcaNoProblemDTOList = workorder.getDcaNoProblemDTOList(); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(dcaNoProblemDTOList)){ Integer indexCode = 0 ; for (DCANoProblemDTO dcaNoProblemDTO:dcaNoProblemDTOList) { indexCode = indexCode + 1; Category problem = categoryMapper.selectById(dcaNoProblemDTO.getProblemId()); if(!Constants.equalsInteger(problem.getType(),6)){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"题目分类错误"); } Constants.WorkOrderStatus workOrderStatus = Constants.WorkOrderStatus.waitConfirm; Workorder dcaWorkOrder = new Workorder(); dcaWorkOrder.setCreateDate(new Date()); dcaWorkOrder.setEditDate(new Date()); dcaWorkOrder.setMemberId(workorder.getMemberId()); dcaWorkOrder.setTypeId(workorder.getTypeId()); dcaWorkOrder.setCategoryId(Integer.toString(problem.getParentId())); dcaWorkOrder.setType(Constants.TWO); dcaWorkOrder.setStatus(workOrderStatus.getKey()); dcaWorkOrder.setIsdeleted(Constants.ZERO); dcaWorkOrder.setProblemTitle(problem.getName()); dcaWorkOrder.setProblemId(problem.getId()); dcaWorkOrder.setProblemInfo(problem.getRemark()); dcaWorkOrder.setDcaRecordId(workorder.getId()); dcaWorkOrder.setHappenTime(workorder.getHappenTime()); dcaWorkOrder.setLocaltionId(workorder.getLocaltionId()); dcaWorkOrder.setLocationName(workorder.getLocationName()); dcaWorkOrder.setSubmitDate(workorder.getSubmitDate()); dcaWorkOrder.setCode(workorder.getCode()+"_"+ org.apache.commons.lang3.StringUtils.leftPad(indexCode.toString(),2,"0")); dcaWorkOrder.setEventInfo(dcaNoProblemDTO.getEventInfo()); dcaWorkOrder.setQwnoticeMemberIds(workorder.getQwnoticeMemberIds()); dcaWorkOrder.setMemberNames(workorder.getMemberNames()); dcaWorkOrder.setSheDealUserQwIds(dcaWorkOrder.getQwnoticeMemberIds()); workorderMapper.insert(dcaWorkOrder); //存储日志 this.dealLogData(dcaWorkOrder,workOrderStatus); //存储待办人员信息 this.saveNotice(Arrays.asList(dcaWorkOrder.getQwnoticeMemberIds().split(",")),dcaWorkOrder.getId(),Constants.ZERO,Constants.ZERO); List multifileList = dcaNoProblemDTO.getMultifileList(); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { multifile.setIsdeleted(Constants.ZERO); multifile.setObjId(dcaWorkOrder.getId()); multifile.setCreateDate(new Date()); multifile.setObjType(Constants.multiFileType.upload); } multifileMapper.insert(multifileList); } } }else{ workorder.setStatus(Constants.WorkOrderStatus.sheClose.getKey()); workorderMapper.updateById(workorder); } //查询主题下的所有观察项 Category type = categoryMapper.selectById(workorder.getTypeId()); if(Objects.nonNull(type)){ //存储DCA工单详情 Map detail = new HashMap<>(); detail.put("title","观察主题:"+type.getName()); List categoryList = categoryMapper.selectList(new QueryWrapper().lambda().eq(Category::getType,4) .eq(Category::getIsdeleted,Constants.ZERO) .eq(Category::getParentId,workorder.getTypeId())); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(categoryList)){ List> childMapList = new ArrayList<>(); for (Category category:categoryList) { Map childMap = new HashMap<>(); childMap.put("childTitle",category.getName()); List problemList = categoryMapper.selectList(new QueryWrapper().lambda() .eq(Category::getIsdeleted,Constants.ZERO) .eq(Category::getType,6).eq(Category::getParentId,category.getId())); List> problemMapList = new ArrayList<>(); Integer index = Constants.ONE; for (Category problem:problemList) { Map problemMap = new HashMap<>(); problemMap.put("title",index + "、" + problem.getName()); List pList = dcaNoProblemDTOList.stream().filter(i->Constants.equalsInteger(i.getProblemId(),problem.getId())).collect(Collectors.toList()); if(pList.size()>Constants.ZERO){ DCANoProblemDTO dcaNoProblemDTO = pList.get(Constants.ZERO); problemMap.put("status",Constants.TWO); problemMap.put("eventInfo","不符合原因:"+dcaNoProblemDTO.getEventInfo()); problemMap.put("imgList",dcaNoProblemDTO.getMultifileList().stream().map(i->i.getFileurl()).collect(Collectors.joining(","))); }else{ problemMap.put("status",Constants.ONE); } index = index + Constants.ONE; problemMapList.add(problemMap); } childMap.put("problemMapList",problemMapList); childMapList.add(childMap); } detail.put("childMapList",childMapList); } workorder.setRemark(JSONObject.toJSONString(detail)); workorderMapper.updateById(workorder); } } } /** * 处理通知类人员信息 * @param workorder */ public void dealNoticeData(Workorder workorder){ //SHE上报 提交类型为同事 处理同事信息 if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)&&Constants.equalsInteger(workorder.getMemberType(),Constants.ONE)){ List memberList = memberMapper.selectList(new QueryWrapper().lambda().eq(Member::getIsdeleted,Constants.ZERO).in(Member::getQwId,workorder.getMemberQwids().split(","))); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(memberList)){ workorder.setMemberNames(memberList.stream().map(i->i.getName()).collect(Collectors.joining(","))); } } if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)){ List managersList = managersMapper.selectJoinList(Managers.class,new MPJLambdaWrapper().selectAll(Managers.class) .selectAs(Member::getName,Managers::getMemberName) .selectAs(Member::getQwId,Managers::getQwId) .leftJoin(Member.class,Member::getId,Managers::getMemberId) .eq(Managers::getIsdeleted,Constants.ZERO) .eq(Managers::getType,Constants.THREE).orderByAsc(Managers::getSortnum) ); if(Objects.isNull(managersList)){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"未查询到SHE处理抄送人员"); } if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(managersList)){ workorder.setQwnoticeMemberIds(managersList.stream().filter(i->Constants.equalsInteger(i.getIsQw(),Constants.ONE)).map(i->i.getQwId()).collect(Collectors.joining(","))); if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)){ workorder.setEmialMemberIds(managersList.stream().filter(i->Constants.equalsInteger(i.getIsEmail(),Constants.ONE)).map(i->i.getMemberId().toString()).collect(Collectors.joining(","))); } } } //跌绊滑事件上报 \ DCA 查询SHE负责人 if(Constants.equalsInteger(workorder.getType(),Constants.THREE) || Constants.equalsInteger(workorder.getType(),Constants.ONE)){ List managersList = managersMapper.selectJoinList(Managers.class,new MPJLambdaWrapper().selectAll(Managers.class) .selectAs(Member::getName,Managers::getMemberName) .selectAs(Member::getQwId,Managers::getQwId) .leftJoin(Member.class,Member::getId,Managers::getMemberId) .eq(Managers::getIsdeleted,Constants.ZERO) .eq(Managers::getType,Constants.ZERO).orderByAsc(Managers::getSortnum) ); if(Objects.isNull(managersList)){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"未查询到SHE处理抄送人员"); } if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(managersList)){ workorder.setQwnoticeMemberIds(managersList.stream().map(i->i.getQwId()).collect(Collectors.joining(","))); List memberList = memberMapper.selectList(new QueryWrapper().lambda().eq(Member::getIsdeleted,Constants.ZERO) .in(Member::getQwId,workorder.getQwnoticeMemberIds().split(","))); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(memberList)){ workorder.setMemberNames(memberList.stream().map(i->i.getName()).collect(Collectors.joining(","))); } } } } /** * * @param beforeJson * @param afterWorkorder * @param objType 操作类型 0任务上报 1任务分配物业主管 2任务分配处理人 3任务处理关闭 4任务催促 * @param memberId * @param paramr2 转交给的处理人 */ public Integer saveLog(String beforeJson,Workorder afterWorkorder,Integer objType,Integer memberId,String title,String content,String paramr2,String remark){ WorkorderLog workorderLog = new WorkorderLog(); workorderLog.setCreateDate(afterWorkorder.getEditDate()); workorderLog.setEditDate(afterWorkorder.getEditDate()); workorderLog.setIsdeleted(Constants.ZERO); workorderLog.setBeforeContent(beforeJson); workorderLog.setAfterContent(JSONObject.toJSONString(afterWorkorder)); workorderLog.setParam1(memberId.toString()); workorderLog.setParam2(paramr2); workorderLog.setObjId(afterWorkorder.getId().toString()); workorderLog.setObjType(objType); workorderLog.setTitle(title); workorderLog.setContent(content); workorderLog.setRemark(remark); workorderLogMapper.insert(workorderLog); return workorderLog.getId(); } /** * 数据校验 * @param workorder */ public void isValidBaseParam(Workorder workorder){ if(Objects.isNull(workorder) || Objects.isNull(workorder.getSubmitDate()) || Objects.isNull(workorder.getHappenTime()) || Objects.isNull(workorder.getType()) || Objects.isNull(workorder.getTypeId()) || Objects.isNull(workorder.getLocaltionId()) || !( Constants.equalsInteger(workorder.getType(),Constants.ZERO) || Constants.equalsInteger(workorder.getType(),Constants.ONE) ||Constants.equalsInteger(workorder.getType(),Constants.THREE) )){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } //SHE 事件上报 if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)){ if(Objects.isNull(workorder.getMemberType()) || Objects.isNull(workorder.getOutJiuyi()) || (Constants.equalsInteger(workorder.getOutJiuyi(),Constants.ZERO) && Objects.isNull(workorder.getIsYiwushi())) || (Constants.equalsInteger(workorder.getOutJiuyi(),Constants.ZERO) && Constants.equalsInteger(workorder.getIsYiwushi(),Constants.ZERO) && Objects.isNull(workorder.getIsHurted())) || Objects.isNull(workorder.getWorkRelated()) || (Constants.equalsInteger(workorder.getMemberType(),Constants.TWO) && StringUtils.isEmpty(workorder.getMemberNames())) || (Constants.equalsInteger(workorder.getMemberType(),Constants.ONE) && StringUtils.isEmpty(workorder.getMemberQwids())) || org.apache.commons.lang3.StringUtils.isBlank(workorder.getEventInfo()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } } //跌绊滑 事件上报 if(Constants.equalsInteger(workorder.getType(),Constants.THREE)){ if(org.apache.commons.lang3.StringUtils.isBlank(workorder.getRiskInfo()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } } //DCA 事件上报 if(Constants.equalsInteger(workorder.getType(),Constants.ONE)){ if(Objects.isNull(workorder.getDcaYesNum()) || Objects.isNull(workorder.getDcaNoNum()) // || Objects.isNull(workorder.getCategoryId()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } } //数据库数据校验 Category typeCategory = categoryMapper.selectById(workorder.getTypeId()); if(Objects.isNull(typeCategory)){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } Category locationCategory = categoryMapper.selectById(workorder.getLocaltionId()); if(Objects.isNull(locationCategory)){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } workorder.setLocationName(locationCategory.getNamePath()); } @Override public Workorder getDetail(Integer id,Member member){ Workorder workorder = workorderMapper.selectJoinOne(Workorder.class, new MPJLambdaWrapper() .selectAll(Workorder.class) .selectAs(Member::getPhone,Workorder::getMemberPhone) .selectAs(Member::getName,Workorder::getMemberName) .selectAs(Member::getCompanyName,Workorder::getCompanyName) .select(" c3.name ",Workorder::getTypeName) .select(" c3.name_path ",Workorder::getTypeNamePath) .select(" c4.name ",Workorder::getCategoryName) .leftJoin(Member.class,Member::getId,Workorder::getMemberId) .leftJoin(" category c3 on t.TYPE_ID = c3.id ") //风险类型 .leftJoin(" category c4 on t.CATEGORY_ID = c4.id ") //DCA问题编码 .eq(Workorder::getId,id) .last(" limit 1 ") ); if(Objects.isNull(workorder)){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } workorder.setStatusName(Constants.WorkOrderStatus.getStatusName(workorder.getStatus())); this.dealButton(workorder,member); //查询附件信息 List multifileList = multifileMapper.selectList(new QueryWrapper().lambda().eq(Multifile::getIsdeleted,Constants.ZERO) .eq(Multifile::getObjType,Constants.multiFileType.upload) .eq(Multifile::getObjId,workorder.getId().toString()).orderByAsc(Multifile::getId)); String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() +systemDictDataBiz.queryByCode(Constants.FTP,Constants.WORKORDER_FILE_PATH).getCode(); workorder.setPath(path); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { multifile.setFileurlFull(path+multifile.getFileurl()); } workorder.setMultifileList(multifileList); } //查询日志信息 workorder.setLogList(this.getLogList(workorder,member)); if(Constants.equalsInteger(workorder.getType(),Constants.ONE)){ //如果是DCA提交记录,查询子工单集合 Workorder param = new Workorder(); param.setIsdeleted(Constants.ZERO); param.setDcaRecordId(workorder.getId()); List dcaChildList = findList(param); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(dcaChildList)){ for (Workorder dcaChild:dcaChildList) { this.dealButton(dcaChild,member); dcaChild.setStatusName(Constants.WorkOrderStatus.getStatusName(dcaChild.getStatus())); } workorder.setManagerId(dcaChildList.stream().filter(i->Objects.nonNull(i.getManagerId())).map(i->i.getManagerId()).collect(Collectors.joining(","))); } workorder.setDcaChildList(dcaChildList); } return workorder; } public void dealButton(Workorder workorder,Member member){ workorder.setPassOnButton(Constants.ZERO); workorder.setCloseButton(Constants.ZERO); if(member!=null && org.apache.commons.lang3.StringUtils.isNotBlank(member.getQwId())){ List closeUserList = new ArrayList<>(); if(org.apache.commons.lang3.StringUtils.isNotBlank(workorder.getQwnoticeMemberIds())&& (Constants.equalsInteger(workorder.getStatus(),Constants.ZERO)|| Constants.equalsInteger(workorder.getStatus(),Constants.ONE)||Constants.equalsInteger(workorder.getStatus(),Constants.TWO))){ closeUserList.addAll(Arrays.asList(workorder.getSheDealUserQwIds().split(","))); } if(org.apache.commons.lang3.StringUtils.isNotBlank(workorder.getManagerId())&& (Constants.equalsInteger(workorder.getStatus(),Constants.ONE)||Constants.equalsInteger(workorder.getStatus(),Constants.TWO))){ closeUserList.add(workorder.getManagerId()); } if(org.apache.commons.lang3.StringUtils.isNotBlank(workorder.getDealerId())&& (Constants.equalsInteger(workorder.getStatus(),Constants.TWO))){ closeUserList.add(workorder.getDealerId()); } if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(closeUserList)){ workorder.setCloseButton(closeUserList.stream().filter(i->i.equals(member.getQwId())).collect(Collectors.toList()).size()>Constants.ZERO?Constants.ONE:Constants.ZERO); } List passOnUserList = new ArrayList<>(); //待分配状态 处理转交按钮 if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitConfirm.getKey()) ){ passOnUserList.addAll(Arrays.asList(workorder.getSheDealUserQwIds().split(","))); } if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitAllocation.getKey()) || Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitDeal.getKey()) ){ passOnUserList.add(workorder.getManagerId()); } if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(passOnUserList)){ workorder.setPassOnButton(passOnUserList.stream().filter(i->i.equals(member.getQwId())).collect(Collectors.toList()).size()>Constants.ZERO?Constants.ONE:Constants.ZERO); } } } public List getLogList(Workorder workorder,Member loginMember){ List logList = workorderLogMapper.selectJoinList(WorkorderLog.class, new MPJLambdaWrapper() .selectAll(WorkorderLog.class) .selectAs(Member::getName,WorkorderLog::getUserName) .selectAs(Member::getCompanyName,WorkorderLog::getCompanyName) .leftJoin(Member.class,Member::getId,WorkorderLog::getParam1) .eq(WorkorderLog::getObjId,workorder.getId()) .orderByDesc(WorkorderLog::getId) ); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(logList)){ String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() +systemDictDataBiz.queryByCode(Constants.FTP,Constants.WORKORDER_LOG_FILE_PATH).getCode(); Boolean canOpenUrgeButton = true; for (WorkorderLog workorderLog:logList) { workorderLog.setUrgeButton(Constants.ZERO); if(Constants.equalsInteger(workorderLog.getObjType(),Constants.TWO)||Constants.equalsInteger(workorderLog.getObjType(),Constants.ONE)){ //物业主管处理中 if(Constants.equalsInteger(workorder.getStatus(),Constants.ONE)){ Member member = memberMapper.selectById(workorderLog.getParam1()); if(Objects.nonNull(member) && org.apache.commons.lang3.StringUtils.isNotBlank(member.getQwId()) && Objects.nonNull(loginMember) && Constants.equalsInteger(member.getId(),loginMember.getId()) && workorder.getQwnoticeMemberIds().indexOf(member.getQwId())>=Constants.ZERO){ workorderLog.setUrgeButton(Constants.ONE); } } //工程师处理中 if(Constants.equalsInteger(workorder.getStatus(),Constants.TWO)){ Member member = memberMapper.selectById(workorderLog.getParam1()); if(Objects.nonNull(member) && org.apache.commons.lang3.StringUtils.isNotBlank(member.getQwId()) && canOpenUrgeButton && (workorder.getQwnoticeMemberIds().indexOf(member.getQwId()) >= Constants.ZERO || member.getQwId().equals(workorder.getManagerId()) ) ){ workorderLog.setUrgeButton(Constants.ONE); canOpenUrgeButton = false; } } } if(!Constants.equalsInteger(workorderLog.getObjType(),Constants.FOUR)){ //查询附件信息 List multifileList = multifileMapper.selectList(new QueryWrapper().lambda() .eq(Multifile::getIsdeleted,Constants.ZERO) .ne(Multifile::getObjType,Constants.multiFileType.upload) .eq(Multifile::getObjId,workorderLog.getId()) .orderByAsc(Multifile::getId)); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { multifile.setFileurlFull(path+multifile.getFileurl()); } workorderLog.setMultifileList(multifileList); } } } } return logList; } @Override public void deleteById(Integer id) { workorderMapper.deleteById(id); } @Override public void delete(Workorder workorder) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(workorder); workorderMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } workorderMapper.deleteBatchIds(ids); } @Override public void updateById(Workorder workorder) { workorderMapper.updateById(workorder); } @Override public void updateByIdInBatch(List workorders) { if (CollectionUtils.isEmpty(workorders)) { return; } for (Workorder workorder: workorders) { this.updateById(workorder); } } @Override public Workorder findById(Integer id) { return workorderMapper.selectById(id); } @Override public Workorder findOne(Workorder workorder) { QueryWrapper wrapper = new QueryWrapper<>(workorder); return workorderMapper.selectOne(wrapper); } @Override public List findList(Workorder pageWrap) { return workorderMapper.selectJoinList(Workorder.class,getJoinQueryMapper(pageWrap)); } private MPJLambdaWrapper getJoinQueryMapper(Workorder pageWrap) { MPJLambdaWrapper queryWrapper = new MPJLambdaWrapper<>(); pageWrap.setIsdeleted(Constants.ZERO); queryWrapper .selectAll(Workorder.class) .selectAs(Member::getName,Workorder::getMemberName) .selectAs(Member::getCompanyName,Workorder::getCompanyName) .selectAs(Member::getPhone,Workorder::getMemberPhone) .select(" c2.name ",Workorder::getCategoryName) .select(" c3.name ",Workorder::getTypeName) .select(" c3.name_path ",Workorder::getTypeNamePath) .leftJoin(Member.class,Member::getId,Workorder::getMemberId) .leftJoin(" category c3 on t.TYPE_ID = c3.id ") //风险类型 .leftJoin(" category c2 on t.CATEGORY_ID = c2.id ") //DCA一级问题编码 .apply(Objects.nonNull(pageWrap.getMyWorkOrder())&& org.apache.commons.lang3.StringUtils.isNotBlank(pageWrap.getQwId()) &&Constants.equalsInteger(Constants.ONE,pageWrap.getMyWorkOrder()), " ( t.id in ( select OBJ_ID from notices where param1 = '"+pageWrap.getQwId()+"' and type != 3 )) ") .ne(org.apache.commons.lang3.StringUtils.isNotBlank(pageWrap.getQwId()),Workorder::getType,Constants.TWO) .in(Objects.nonNull(pageWrap.getDealStatus())&& Constants.equalsInteger(pageWrap.getDealStatus(),Constants.ZERO), Workorder::getStatus,Constants.WorkOrderStatus.waitConfirm.getKey(), Constants.WorkOrderStatus.waitAllocation.getKey(),Constants.WorkOrderStatus.waitDeal.getKey()) .in(Objects.nonNull(pageWrap.getDealStatus())&& Constants.equalsInteger(pageWrap.getDealStatus(),Constants.ONE), Workorder::getStatus,Constants.WorkOrderStatus.sheClose.getKey(),Constants.WorkOrderStatus.close.getKey(),Constants.WorkOrderStatus.wtsClose.getKey()) .eq( pageWrap.getId() != null, Workorder::getId, pageWrap.getId()) .eq( pageWrap.getCreator() != null, Workorder::getCreator, pageWrap.getCreator()) .ge( pageWrap.getCreateDate() != null, Workorder::getCreateDate, Utils.Date.getStart( pageWrap.getCreateDate())) .le( pageWrap.getCreateDate() != null, Workorder::getCreateDate, Utils.Date.getEnd( pageWrap.getCreateDate())) .eq( pageWrap.getEditor() != null, Workorder::getEditor, pageWrap.getEditor()) .ge( pageWrap.getEditDate() != null, Workorder::getEditDate, Utils.Date.getStart( pageWrap.getEditDate())) .le( pageWrap.getEditDate() != null, Workorder::getEditDate, Utils.Date.getEnd( pageWrap.getEditDate())) .eq( pageWrap.getIsdeleted() != null, Workorder::getIsdeleted, pageWrap.getIsdeleted()) .eq( pageWrap.getCategoryId() != null, Workorder::getCategoryId, pageWrap.getCategoryId()) .eq( pageWrap.getRemark() != null, Workorder::getRemark, pageWrap.getRemark()) .eq( pageWrap.getStatus() != null, Workorder::getStatus, pageWrap.getStatus()) .eq( pageWrap.getSortnum() != null, Workorder::getSortnum, pageWrap.getSortnum()) .eq( pageWrap.getType() != null, Workorder::getType, pageWrap.getType()) .eq( pageWrap.getMemberId() != null, Workorder::getMemberId, pageWrap.getMemberId()) .eq( pageWrap.getCompanyId() != null, Workorder::getCompanyId, pageWrap.getCompanyId()) .eq( pageWrap.getSubmitDate() != null, Workorder::getSubmitDate, pageWrap.getSubmitDate()) .eq( pageWrap.getMemberType() != null, Workorder::getMemberType, pageWrap.getMemberType()) .eq( pageWrap.getMemberQwids() != null, Workorder::getMemberQwids, pageWrap.getMemberQwids()) .like( pageWrap.getMemberNames() != null, Workorder::getMemberNames, pageWrap.getMemberNames()) .eq( pageWrap.getLocaltionId() != null, Workorder::getLocaltionId, pageWrap.getLocaltionId()) .eq( pageWrap.getOutJiuyi() != null, Workorder::getOutJiuyi, pageWrap.getOutJiuyi()) .eq( pageWrap.getIsYiwushi() != null, Workorder::getIsYiwushi, pageWrap.getIsYiwushi()) .eq( pageWrap.getIsHurted() != null, Workorder::getIsHurted, pageWrap.getIsHurted()) .eq( pageWrap.getWorkRelated() != null, Workorder::getWorkRelated, pageWrap.getWorkRelated()) .eq( pageWrap.getEventInfo() != null, Workorder::getEventInfo, pageWrap.getEventInfo()) .eq( pageWrap.getEmialMemberIds() != null, Workorder::getEmialMemberIds, pageWrap.getEmialMemberIds()) .eq( pageWrap.getQwnoticeMemberIds() != null, Workorder::getQwnoticeMemberIds, pageWrap.getQwnoticeMemberIds()) .eq( pageWrap.getHappenTime() != null, Workorder::getHappenTime, pageWrap.getHappenTime()) .eq( pageWrap.getTypeId() != null, Workorder::getTypeId, pageWrap.getTypeId()) .eq( pageWrap.getRiskInfo() != null, Workorder::getRiskInfo, pageWrap.getRiskInfo()) .eq( pageWrap.getManagerId() != null, Workorder::getManagerId, pageWrap.getManagerId()) .eq( pageWrap.getDealerId() != null, Workorder::getDealerId, pageWrap.getDealerId()) .ge( pageWrap.getDispatchTime() != null, Workorder::getDispatchTime, Utils.Date.getStart( pageWrap.getDispatchTime())) .le( pageWrap.getDispatchTime() != null, Workorder::getDispatchTime, Utils.Date.getEnd( pageWrap.getDispatchTime())) .eq( pageWrap.getDispatchInfo() != null, Workorder::getDispatchInfo, pageWrap.getDispatchInfo()) .ge( pageWrap.getDealTime() != null, Workorder::getDealTime, Utils.Date.getStart( pageWrap.getDealTime())) .le( pageWrap.getDealTime() != null, Workorder::getDealTime, Utils.Date.getEnd( pageWrap.getDealTime())) .eq( pageWrap.getDealInfo() != null, Workorder::getDealInfo, pageWrap.getDealInfo()) .eq( pageWrap.getProblemTitle() != null, Workorder::getProblemTitle, pageWrap.getProblemTitle()) .eq( pageWrap.getProblemId() != null, Workorder::getProblemId, pageWrap.getProblemId()) .eq( pageWrap.getProblemInfo() != null, Workorder::getProblemInfo, pageWrap.getProblemInfo()) .eq( pageWrap.getLocationName() != null, Workorder::getLocationName, pageWrap.getLocationName()) .like( pageWrap.getCode() != null, Workorder::getCode, pageWrap.getCode()) .eq( pageWrap.getDcaYesNum() != null, Workorder::getDcaYesNum, pageWrap.getDcaYesNum()) .eq( pageWrap.getDcaNoNum() != null, Workorder::getDcaNoNum, pageWrap.getDcaNoNum()) .eq( pageWrap.getDcaRecordId() != null, Workorder::getDcaRecordId, pageWrap.getDcaRecordId()) .likeRight( pageWrap.getTypeIdPath() != null,"c3.id_path", pageWrap.getTypeIdPath()) .eq( pageWrap.getDcaCsIds() != null, Workorder::getDcaCsIds, pageWrap.getDcaCsIds()) .ge( pageWrap.getQueryStartTime() != null, Workorder::getCreateDate,pageWrap.getQueryStartTime()) .le( pageWrap.getQueryEndTime() != null, Workorder::getCreateDate,pageWrap.getQueryEndTime()) ; if ( pageWrap.getMemberName() != null) { queryWrapper.and( ms->ms.like(Member::getName, pageWrap.getMemberName()) .or().like(Member::getPhone, pageWrap.getMemberName()) ); } queryWrapper.orderByDesc(Workorder::getId); return queryWrapper; } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); Utils.MP.blankToNull(pageWrap.getModel()); pageWrap.getModel().setIsdeleted(Constants.ZERO); MPJLambdaWrapper queryWrapper = getJoinQueryMapper(pageWrap.getModel()); PageData result = PageData.from(workorderMapper.selectJoinPage(page,Workorder.class, queryWrapper)); if(result!=null && result.getRecords()!=null){ for(Workorder w : result.getRecords()){ w.setStatusName(Constants.WorkOrderStatus.getStatusName(w.getStatus())); } } return result; } @Override public long count(Workorder workorder) { QueryWrapper wrapper = new QueryWrapper<>(workorder); return workorderMapper.selectCount(wrapper); } public String getNextCode(Integer type){ String date = DateUtil.getFomartDate(new Date(),"yyyyMMddHHmmss"); String key = "S"; if(Constants.equalsInteger(type,Constants.ONE)){ key = "D"; }else if(Constants.equalsInteger(type,Constants.THREE)){ key = "A"; } String code = "01"; try{ code = redisTemplate.opsForValue().get(key+"_CODE").toString(); }catch (Exception e){ } redisTemplate.opsForValue().set(key+"_CODE",Integer.valueOf(code)+1); return key + date + org.apache.commons.lang3.StringUtils.leftPad(code,2,"0"); } @Override public void initializationCode(){ redisTemplate.opsForValue().set("A_CODE",1); redisTemplate.opsForValue().set("S_CODE",1); redisTemplate.opsForValue().set("D_CODE",1); } @Override public void closeWorkOrder(CloseDTO closeDTO){ if(Objects.isNull(closeDTO) || Objects.isNull(closeDTO.getWorkorderId()) || org.apache.commons.lang3.StringUtils.isBlank(closeDTO.getInfo()) || com.github.xiaoymin.knife4j.core.util.CollectionUtils.isEmpty(closeDTO.getMultifileList())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } Workorder workorder = workorderMapper.selectById(closeDTO.getWorkorderId()); String beforeJson = JSONObject.toJSONString(workorder); if(Objects.isNull(workorder)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到工单数据"); } if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)||Constants.equalsInteger(workorder.getType(),Constants.ONE)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"SHE、DCA工单无法进行该操作"); } if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.sheClose.getKey())||Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.wtsClose.getKey())||Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.close.getKey())){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"工单状态已流转"); } //企微通知人 企微主键 List qwIds = new ArrayList<>(); //提交后的 待确认/待初审状态 如果去关闭 只有工单里绑定的SHE人员可以关闭 if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitConfirm.getKey())){ //判断SHE人员内是否有当前登录账号 if(workorder.getSheDealUserQwIds().indexOf(closeDTO.getMember().getQwId())Constants.ZERO){ workorder.setStatus(Constants.WorkOrderStatus.sheClose.getKey()); }else{ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,当前工单非您的工单,无法进行处理"); } qwIds.addAll(Arrays.asList(workorder.getQwnoticeMemberIds().split(","))); qwIds.add(workorder.getManagerId()); qwIds.remove(closeDTO.getMember().getQwId()); }else if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitDeal.getKey())){ //判断SHE人员内是否有当前登录账号 if(workorder.getSheDealUserQwIds().indexOf(closeDTO.getMember().getQwId())Constants.ZERO){ workorder.setStatus(Constants.WorkOrderStatus.sheClose.getKey()); }else{ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,当前工单非您的工单,无法进行处理"); } qwIds.addAll(Arrays.asList(workorder.getQwnoticeMemberIds().split(","))); qwIds.add(workorder.getManagerId()); qwIds.remove(closeDTO.getMember().getQwId()); }else{ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"工单状态已流转"); } workorder.setEditDate(new Date()); workorder.setDealTime(new Date()); workorder.setDealInfo(closeDTO.getInfo()); //子工单 则查询父级工单数据 是否付存在未完成的 如果不存在未完成的则进行主工单状态变化 if(Constants.equalsInteger(workorder.getType(),Constants.TWO)&& workorderMapper.selectCount(new QueryWrapper().lambda().eq(Workorder::getDcaRecordId,workorder.getDcaRecordId()).eq(Workorder::getIsdeleted,Constants.ZERO) .ne(Workorder::getId,workorder.getId()).in(Workorder::getStatus, Constants.WorkOrderStatus.waitConfirm.getKey(),Constants.WorkOrderStatus.waitAllocation.getKey(),Constants.WorkOrderStatus.waitDeal.getKey() ))<=Constants.ZERO){ Workorder parentWorkorder = new Workorder(); parentWorkorder.setId(workorder.getDcaRecordId()); parentWorkorder.setEditDate(new Date()); parentWorkorder.setStatus(Constants.WorkOrderStatus.close.getKey()); workorderMapper.updateById(parentWorkorder); } workorderMapper.updateById(workorder); //处理上报日志 Integer logId = this.saveLog(beforeJson,workorder,Constants.THREE,closeDTO.getMember().getId(),"任务已处理",closeDTO.getInfo(),null,closeDTO.getInfo()); List multifileList = closeDTO.getMultifileList(); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { multifile.setObjId(logId); multifile.setIsdeleted(Constants.ZERO); multifile.setCreateDate(new Date()); multifile.setObjType(Constants.multiFileType.deal); multifileMapper.insert(multifile); } } //发送企微通知 if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(qwIds)){ Set qwIdSet = new HashSet<>(qwIds); String qwIdStr = String.join(",", qwIdSet); Category category = categoryMapper.selectById(workorder.getTypeId()); if(Objects.nonNull(closeDTO.getMember())&&Objects.nonNull(category)&& org.apache.commons.lang3.StringUtils.isNotBlank(qwIdStr)){ // 发送企微通知 this.sendQwMsg(workorder,qwIdStr,closeDTO.getMember(),category.getName(),Constants.THREE,null); } } } @Override public void passOn(PassOnDTO passOnDTO){ if(Objects.isNull(passOnDTO) || Objects.isNull(passOnDTO.getWorkorderId()) || org.apache.commons.lang3.StringUtils.isBlank(passOnDTO.getPassOnUserId()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } Member member = memberMapper.selectOne(new QueryWrapper().lambda().eq(Member::getQwId,passOnDTO.getPassOnUserId())); if(Objects.isNull(member)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到被转交人信息"); } Workorder workorder = workorderMapper.selectById(passOnDTO.getWorkorderId()); String beforeJson = JSONObject.toJSONString(workorder); if(Objects.isNull(workorder)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到工单数据"); } if(Constants.equalsInteger(workorder.getType(),Constants.ZERO)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"SHE工单无法进行该操作"); } if(Constants.equalsInteger(passOnDTO.getPassOnType(),Constants.ZERO)){ if(!Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitConfirm.getKey())){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"工单状态已流转"); } if(workorder.getSheDealUserQwIds().indexOf(passOnDTO.getMember().getQwId()) multifileList = passOnDTO.getMultifileList(); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { multifile.setObjId(logId); multifile.setIsdeleted(Constants.ZERO); multifile.setCreateDate(new Date()); multifile.setObjType(Constants.multiFileType.passOn); } multifileMapper.insert(multifileList); } //企业微信通知 Category category = categoryMapper.selectById(workorder.getTypeId()); if(Objects.nonNull(passOnDTO.getMember())&&Objects.nonNull(category)){ // 发送企微通知 this.sendQwMsg(workorder,passOnDTO.getPassOnUserId(),passOnDTO.getMember(),category.getName(),Constants.ZERO,null); } //存储待办人员信息 this.saveNotice(Arrays.asList(passOnDTO.getPassOnUserId().split(",")), Constants.equalsInteger(workorder.getType(),Constants.TWO)?workorder.getDcaRecordId():workorder.getId(),Constants.ZERO,Constants.TWO); } @Override public void sendCopy(SendCopyDTO sendCopyDTO) { if (Objects.isNull(sendCopyDTO) || Objects.isNull(sendCopyDTO.getWorkorderId()) || StringUtils.isEmpty(sendCopyDTO.getUserIds())) { throw new BusinessException(ResponseStatus.BAD_REQUEST); } Workorder workorder = workorderMapper.selectById(sendCopyDTO.getWorkorderId()); if (Objects.isNull(workorder)) { throw new BusinessException(ResponseStatus.DATA_EMPTY); } List memberList = memberMapper.selectList(new QueryWrapper().lambda().eq(Member::getIsdeleted, Constants.ZERO) .isNotNull(Member::getQwId) .in(Member::getQwId, sendCopyDTO.getUserIds().split(","))); if (com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(memberList)) { List qwIdList = memberList.stream().map(i -> i.getQwId()).collect(Collectors.toList()); Category category = categoryMapper.selectById(workorder.getTypeId()); if (Objects.nonNull(category)) { // 发送企微通知 this.sendQwMsg(workorder, String.join(",", qwIdList), sendCopyDTO.getMember(), category.getName(), Constants.TWO, sendCopyDTO.getInfo()); } //存储待办信息 this.saveNotice(qwIdList, Constants.equalsInteger(workorder.getType(),Constants.TWO)?workorder.getDcaRecordId():workorder.getId(), Constants.ONE, Constants.ONE); } } @Override public void sendSheEmail(){ if(Constants.WORKORDER_SHE_EMAIL_SENDING){ return; } Constants.WORKORDER_SHE_EMAIL_SENDING = true; try { List list = workorderMapper.selectJoinList(Workorder.class,new MPJLambdaWrapper() .selectAll(Workorder.class) .selectAs(Member::getName,Workorder::getMemberName) .selectAs(Member::getCompanyName,Workorder::getCompanyName) .selectAs(Member::getPhone,Workorder::getMemberPhone) .select(" c2.name_path ",Workorder::getCategoryName) .select(" c3.name_path ",Workorder::getTypeName) .leftJoin(Member.class,Member::getId,Workorder::getMemberId) .leftJoin(" category c3 on t.TYPE_ID = c3.id ") //风险类型 .leftJoin(" category c2 on t.CATEGORY_ID = c2.id ") //DCA一级问题编码 .eq(Workorder::getIsdeleted,Constants.ZERO) .eq(Workorder::getEmailStatus,Constants.ZERO) .eq(Workorder::getType,Constants.ZERO) .isNotNull(Workorder::getEmialMemberIds )//邮箱通知 ); if(list!=null && list.size()>0){ Date date = new Date(); String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() +systemDictDataBiz.queryByCode(Constants.FTP,Constants.WORKORDER_FILE_PATH).getCode(); for(Workorder workorder :list){ dealEmailBiz(workorder,date,path); } } }catch (Exception e){ log.error("==================定时发生SHE邮件失败:"+e.getMessage()); }finally { Constants.WORKORDER_SHE_EMAIL_SENDING = false; } } @Transactional private void dealEmailBiz(Workorder workorder, Date date,String path) { List noticesList = new ArrayList<>(); int status =1; String info ="邮箱已发送:"; String ids = workorder.getEmialMemberIds(); List memberList = getEmailMemberlistByIDs(ids); if(memberList == null || memberList.size() ==0){ status = 2; info ="无效员工信息,无法发送邮箱"; }else{ List successInfo = new ArrayList<>(); List errorInfo = new ArrayList<>(); Map contentForm = getEmailContentFormByModel(workorder); List imgList = getEmailImglistByModel(workorder,path); for(Member m : memberList){ if(org.apache.commons.lang3.StringUtils.isNotBlank(m.getEmail())){ //如果邮箱不为空,进行邮箱发送 successInfo.add(m.getName()+"邮箱"+m.getEmail()+""); if( emailService.sendEmailWithImages(m.getEmail(),"SHE事件工单上报通知", contentForm,imgList)){ Notices notices = new Notices(); notices.setType(Constants.THREE+""); notices.setIsdeleted(Constants.ZERO); notices.setObjId(workorder.getId()); notices.setTitle("SHE事件工单上报邮件通知"); notices.setContent(JSONObject.toJSONString(contentForm)); notices.setRemark(JSONObject.toJSONString(imgList)); notices.setObjType(Constants.ZERO+""); notices.setStatus(Constants.ZERO); notices.setSendacopy(Constants.ONE); notices.setMemberId(m.getId()); noticesList.add(notices); }else{ errorInfo.add(m.getName()+"/无邮箱"); } }else{ errorInfo.add(m.getName()+"/邮箱"+m.getEmail()+""); } } info += "成功:"+JSONObject.toJSONString(successInfo) +"失败:"+JSONObject.toJSONString(errorInfo); } Workorder update = new Workorder(); update.setId(workorder.getId()); update.setEmailDate(date); update.setEmailStatus(status ); update.setEmailInfo(info); this.updateById(update);//更新工单邮件发送状态 if(noticesList.size()>0){ noticesMapper.insert(noticesList); } } private List getEmailImglistByModel(Workorder workorder, String path ) { List list = new ArrayList<>(); //查询附件信息 List multifileList = multifileMapper.selectList(new QueryWrapper().lambda().eq(Multifile::getIsdeleted,Constants.ZERO) .eq(Multifile::getObjId,workorder.getId()).orderByAsc(Multifile::getId)); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ for (Multifile multifile:multifileList) { list.add(path+multifile.getFileurl()); } } return list; } private List getEmailMemberlistByIDs(String ids) { List memberList = new ArrayList<>(); if(org.apache.commons.lang3.StringUtils.isNotBlank(ids)){ String[] tt = ids.split(","); List idList =new ArrayList<>(); if(tt.length>0){ for(String s :tt){ try { idList.add(Integer.parseInt(s)); }catch (Exception e){ } } } if(idList.size()>0){ memberList = memberMapper.selectList(new QueryWrapper().lambda() .eq(Member::getIsdeleted,Constants.ZERO) .in(Member::getId,idList) ); } } return memberList; } private Map getEmailContentFormByModel(Workorder workorder) { Map map = new LinkedHashMap<>(); map.put("上报人",workorder.getCompanyName()+"/" +workorder.getMemberName()); map.put("上报时间",DateUtil.getPlusTime2(workorder.getSubmitDate())); map.put("事件发生时间/地点",DateUtil.getPlusTime2(workorder.getHappenTime())+" / "+workorder.getLocationName()); map.put("伤害类型", workorder.getTypeName()); map.put("是否外部就医", Constants.equalsInteger(workorder.getOutJiuyi(),Constants.ONE)?"是":"否"); map.put("是否医务室", Constants.equalsInteger(workorder.getIsYiwushi(),Constants.ONE)?"是":"否"); map.put("是否受伤", Constants.equalsInteger(workorder.getIsHurted(),Constants.ONE)?"是":"否"); map.put("是否和工作相关", Constants.equalsInteger(workorder.getWorkRelated(),Constants.ONE)?"是":"否"); map.put("事件说明", org.apache.commons.lang3.StringUtils.defaultString(workorder.getEventInfo(),"-")); return map; } @Override @Transactional(rollbackFor = {BusinessException.class,Exception.class}) public void urge(Integer workorderId,Member member){ Workorder workorder = workorderMapper.selectById(workorderId); workorder.setEditDate(new Date()); workorder.setUrgeDate(DateUtil.afterMinutesDate(new Date(),10)); workorderMapper.updateById(workorder); if(Objects.isNull(workorder)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到工单数据"); } Member urgeUser = new Member(); //如果已分配 wts 则是催促wts if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitAllocation.getKey())){ urgeUser = memberMapper.selectOne(new QueryWrapper().lambda().eq(Member::getIsdeleted,Constants.ZERO).eq(Member::getQwId,workorder.getManagerId()).last("limit 1 ")); }else if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitDeal.getKey())){ urgeUser = memberMapper.selectOne(new QueryWrapper().lambda().eq(Member::getIsdeleted,Constants.ZERO).eq(Member::getQwId,workorder.getDealerId()).last("limit 1 ")); }else{ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"状态已流转无法进行该操作"); } this.saveLog(null,workorder, Constants.FOUR ,member.getId(),"催促","已催促 "+urgeUser.getCompanyName() + "/" + urgeUser.getName(),null,null); //发送企微通知 Category category = categoryMapper.selectById(workorder.getTypeId()); if(Objects.nonNull(category)){ // 发送企微通知 this.sendQwMsg(workorder,urgeUser.getQwId(),member,category.getName(),Constants.ONE,null); } } @Override public void jobUrge(){ List workorderList = workorderMapper.selectList(new QueryWrapper().lambda().eq(Workorder::getIsdeleted,Constants.ZERO) .in(Workorder::getStatus,Constants.WorkOrderStatus.waitAllocation.getKey(),Constants.WorkOrderStatus.waitDeal.getKey()) .apply(" URGE_DATE < now() ") ); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(workorderList)){ for (Workorder workorder:workorderList) { this.autoUrge(workorder); workorder.setEditDate(new Date()); workorder.setUrgeDate(DateUtil.afterMinutesDate(new Date(),10));//DateUtil.afterHoursDate(new Date(),24)); workorderMapper.updateById(workorder); } } } public void autoUrge(Workorder workorder){ if(Objects.isNull(workorder)){ return; } Member urgeUser = new Member(); //如果已分配 wts 则是催促wts if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitAllocation.getKey())){ urgeUser = memberMapper.selectOne(new QueryWrapper().lambda().eq(Member::getIsdeleted,Constants.ZERO).eq(Member::getQwId,workorder.getManagerId()).last("limit 1 ")); }else if(Constants.equalsInteger(workorder.getStatus(),Constants.WorkOrderStatus.waitAllocation.getKey())){ urgeUser = memberMapper.selectOne(new QueryWrapper().lambda().eq(Member::getIsdeleted,Constants.ZERO).eq(Member::getQwId,workorder.getDealerId()).last("limit 1 ")); }else{ return; } //发送企微通知 Category category = categoryMapper.selectById(workorder.getTypeId()); if(Objects.nonNull(category)){ // 发送企微通知 this.sendQwMsg(workorder,urgeUser.getQwId(),null,category.getName(),Constants.ONE,null); } } public void saveNotice(List qwIdList , Integer workorderId, Integer isSendCopy, Integer type){ List noticesList = new ArrayList<>(); for (String qwId:qwIdList) { //存储抄送记录 Notices notices = new Notices(); notices.setCreateDate(new Date()); notices.setIsdeleted(Constants.ZERO); notices.setObjId(workorderId); notices.setObjType(Constants.ZERO+""); notices.setStatus(Constants.ZERO); notices.setSendacopy(isSendCopy); notices.setParam1(qwId); notices.setType(Integer.toString(type)); noticesList.add(notices); } if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(noticesList)){ noticesMapper.insert(noticesList); } } /** * SHE / 跌绊滑报表 * @return * @throws Exception */ @Override public List getWorkOrderData(OrderDataDTO orderDataDTO) { if (Objects.isNull(orderDataDTO.getQueryType())||Objects.isNull(orderDataDTO.getOrderType())) { throw new BusinessException(ResponseStatus.BAD_REQUEST); } String year = DateUtil.getNowYear(); // Integer nowMonth = DateUtil.getNowMonth(); Integer nowMonth = 12; // Integer quarter = (nowMonth - 1) / 3 + 1; Integer quarter =4; List workOrderDataVOList = new ArrayList<>(); //查询今年所有的数据 List workorderList = workorderMapper.selectJoinList(Workorder.class,new MPJLambdaWrapper() .selectAll(Workorder.class) .leftJoin(" category c1 on c1.id = t.type_id " ) .leftJoin(" category c2 on c2.id = t.localtion_id " ) .apply(Objects.nonNull(orderDataDTO.getTypeId())," find_in_set("+orderDataDTO.getTypeId()+", REPLACE(c1.ID_PATH,'/',',') ) ") .apply(Objects.nonNull(orderDataDTO.getLocationId())," find_in_set("+orderDataDTO.getLocationId()+", REPLACE(c2.ID_PATH,'/',',') ) ") .like(Workorder::getCreateDate,year) .eq(Workorder::getType,orderDataDTO.getOrderType()) .eq(Workorder::getIsdeleted,Constants.ZERO)); if(Constants.equalsInteger(orderDataDTO.getQueryType(),Constants.ZERO)){ for (int i = 1 ; i <= nowMonth; i++) { WorkOrderDataVO workOrderDataVO = new WorkOrderDataVO(); String monthDay = year + "-" + org.apache.commons.lang3.StringUtils.leftPad(i+"",2,"0"); List dataList = workorderList.stream().filter(j->DateUtil.formatDate(j.getCreateDate(),"yyyy-MM").equals(monthDay)) .collect(Collectors.toList()); workOrderDataVO.setDateStr(i+"月"); workOrderDataVO.setGcsTotal(Constants.ZERO); workOrderDataVO.setWtsTotal(Constants.ZERO); workOrderDataVO.setSheTotal(Constants.ZERO); workOrderDataVO.setDcaNoTotal(Constants.ZERO); workOrderDataVO.setDcaYesTotal(Constants.ZERO); workOrderDataVO.setUnCloseTotal(Constants.ZERO); workOrderDataVO.setTotal(Constants.ZERO); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(dataList)){ workOrderDataVO.setTotal(dataList.size()); for(Workorder e :dataList){ if(Constants.equalsInteger(e.getType(),Constants.ONE)){ workOrderDataVO.setDcaYesTotal(workOrderDataVO.getDcaYesTotal()+Constants.formatIntegerNum(e.getDcaYesNum()));//DCA符合项 workOrderDataVO.setDcaNoTotal(workOrderDataVO.getDcaNoTotal()+Constants.formatIntegerNum(e.getDcaNoNum()));//DCA不符合项 } } workOrderDataVO.setGcsTotal(dataList.stream().filter(j->Constants.equalsInteger(j.getStatus(),Constants.WorkOrderStatus.close.getKey())).collect(Collectors.toList()).size()); workOrderDataVO.setSheTotal(dataList.stream().filter(j->Constants.equalsInteger(j.getStatus(),Constants.WorkOrderStatus.sheClose.getKey())).collect(Collectors.toList()).size()); workOrderDataVO.setWtsTotal(dataList.stream().filter(j->Constants.equalsInteger(j.getStatus(),Constants.WorkOrderStatus.wtsClose.getKey())).collect(Collectors.toList()).size()); workOrderDataVO.setUnCloseTotal(workOrderDataVO.getTotal() - workOrderDataVO.getSheTotal() - workOrderDataVO.getWtsTotal() - workOrderDataVO.getGcsTotal()); } workOrderDataVOList.add(workOrderDataVO); } }else if(Constants.equalsInteger(orderDataDTO.getQueryType(),Constants.ONE)){ //按照季度查询 for (int i = 1 ; i <= quarter; i++) { List dataList = new ArrayList<>(); if(Constants.equalsInteger(i,Constants.ONE)){ dataList = workorderList.stream().filter(j->Integer.valueOf(DateUtil.formatDate(j.getCreateDate(),"MM"))<=3 ) .collect(Collectors.toList()); }else if(Constants.equalsInteger(i,Constants.TWO)){ dataList = workorderList.stream().filter(j->Integer.valueOf(DateUtil.formatDate(j.getCreateDate(),"MM"))<=6 && Integer.valueOf(DateUtil.formatDate(j.getCreateDate(),"MM"))>=4 ) .collect(Collectors.toList()); }else if(Constants.equalsInteger(i,Constants.THREE)){ dataList = workorderList.stream().filter(j->Integer.valueOf(DateUtil.formatDate(j.getCreateDate(),"MM"))<=9 && Integer.valueOf(DateUtil.formatDate(j.getCreateDate(),"MM"))>=7 ) .collect(Collectors.toList()); }else { dataList = workorderList.stream().filter(j-> Integer.valueOf(DateUtil.formatDate(j.getCreateDate(),"MM"))>=10 ) .collect(Collectors.toList()); } WorkOrderDataVO workOrderDataVO = new WorkOrderDataVO(); workOrderDataVO.setDateStr(i+"季度"); workOrderDataVO.setGcsTotal(Constants.ZERO); workOrderDataVO.setWtsTotal(Constants.ZERO); workOrderDataVO.setSheTotal(Constants.ZERO); workOrderDataVO.setUnCloseTotal(Constants.ZERO); workOrderDataVO.setTotal(Constants.ZERO); workOrderDataVO.setDcaNoTotal(Constants.ZERO); workOrderDataVO.setDcaYesTotal(Constants.ZERO); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(dataList)){ for(Workorder e :dataList){ if(Constants.equalsInteger(e.getType(),Constants.ONE)){ workOrderDataVO.setDcaYesTotal(workOrderDataVO.getDcaYesTotal()+Constants.formatIntegerNum(e.getDcaYesNum()));//DCA符合项 workOrderDataVO.setDcaNoTotal(workOrderDataVO.getDcaNoTotal()+Constants.formatIntegerNum(e.getDcaNoNum()));//DCA不符合项 } } workOrderDataVO.setTotal(dataList.size()); workOrderDataVO.setGcsTotal(dataList.stream().filter(j->Constants.equalsInteger(j.getStatus(),Constants.WorkOrderStatus.close.getKey())).collect(Collectors.toList()).size()); workOrderDataVO.setSheTotal(dataList.stream().filter(j->Constants.equalsInteger(j.getStatus(),Constants.WorkOrderStatus.sheClose.getKey())).collect(Collectors.toList()).size()); workOrderDataVO.setWtsTotal(dataList.stream().filter(j->Constants.equalsInteger(j.getStatus(),Constants.WorkOrderStatus.wtsClose.getKey())).collect(Collectors.toList()).size()); workOrderDataVO.setUnCloseTotal(workOrderDataVO.getTotal() - workOrderDataVO.getSheTotal() - workOrderDataVO.getWtsTotal() - workOrderDataVO.getGcsTotal()); } workOrderDataVOList.add(workOrderDataVO); } } return workOrderDataVOList; } /** * SHE / 跌绊滑报表 * @return * @throws Exception */ @Override public WorkorderIndexNumVO getIndexData(Workorder workorder) { WorkorderIndexNumVO model = new WorkorderIndexNumVO(); Date startdate = getStartDateByType(workorder.getTimeType()); //查询今年所有的数据 List list = workorderMapper.selectJoinList(Workorder.class,new MPJLambdaWrapper() .select("type,count(id) as num") .eq(Workorder::getIsdeleted,Constants.ZERO) .ge(startdate!=null,Workorder::getCreateDate,startdate) // .lt(endDate!=null,Workorder::getCreateDate,endDate) .groupBy(Workorder::getType )); if(list !=null){ for(Workorder w : list){ if(Constants.equalsInteger(w.getType(),Constants.ZERO)){ //SHE model.setSheNum(Constants.formatLongNum(w.getNum())); }else if(Constants.equalsInteger(w.getType(),Constants.ONE)){ //DCA提交数 model.setDcaNum(Constants.formatLongNum(w.getNum())); }else if(Constants.equalsInteger(w.getType(),Constants.TWO)){ //DCA子工单 model.setDcaChildNum(Constants.formatLongNum(w.getNum())); }else if(Constants.equalsInteger(w.getType(),Constants.THREE)){ //跌绊滑 model.setDbhNum(Constants.formatLongNum(w.getNum())); } } } List yeslist = workorderMapper.selectJoinList(Workorder.class,new MPJLambdaWrapper() .select("type,count(id) as num") .eq(Workorder::getIsdeleted,Constants.ZERO) .in(Workorder::getStatus,Constants.THREE,Constants.FOUR,Constants.FIVE) .in(Workorder::getType,Constants.THREE,Constants.TWO) .ge(startdate!=null,Workorder::getCreateDate,startdate) .groupBy(Workorder::getType )); if(yeslist !=null){ for(Workorder w : yeslist){ if(Constants.equalsInteger(w.getType(),Constants.TWO)){ //DCA子工单已解决和未解决 model.setDcaChildYesNum(Constants.formatLongNum(w.getNum())); model.setDcaChildNoNum(Constants.formatLongNum(model.getDcaChildNum()) -model.getDcaChildYesNum()); }else if(Constants.equalsInteger(w.getType(),Constants.THREE)){ //跌绊滑已解决和未解决 model.setDbhYesNum(Constants.formatLongNum(w.getNum())); model.setDbhNoNum(Constants.formatLongNum(model.getDbhNum()) -model.getDbhYesNum()); } } } if(workorder.getTimeType() == null){ List todays = workorderMapper.selectJoinList(Workorder.class,new MPJLambdaWrapper() .select("type,count(id) as num") .eq(Workorder::getIsdeleted,Constants.ZERO) .apply("to_days(create_date)=to_days(now())") .groupBy(Workorder::getType )); if(todays !=null){ for(Workorder w : todays){ if(Constants.equalsInteger(w.getType(),Constants.ZERO)){ //SHE model.setTodaySheNum(Constants.formatLongNum(w.getNum())); }else if(Constants.equalsInteger(w.getType(),Constants.ONE)){ //DCA提交数 model.setTodayDcaNum(Constants.formatLongNum(w.getNum())); }else if(Constants.equalsInteger(w.getType(),Constants.TWO)){ //DCA子工单 model.setTodayDcaChildNum(Constants.formatLongNum(w.getNum())); }else if(Constants.equalsInteger(w.getType(),Constants.THREE)){ //跌绊滑 model.setTodayDbhNum(Constants.formatLongNum(w.getNum())); } } } Workorder dcaList = workorderMapper.selectJoinOne(Workorder.class,new MPJLambdaWrapper() .select("sum(dca_yes_num) as dcaYesNum,sum(dca_no_num) as dcaNoNum") .eq(Workorder::getIsdeleted,Constants.ZERO) .eq(Workorder::getType,Constants.ONE) ); if(dcaList !=null){ //DCA符合项和不符合项统计 model.setDcaYesNum((long)Constants.formatIntegerNum(dcaList.getDcaYesNum())); model.setDcaNoNum((long)Constants.formatIntegerNum(dcaList.getDcaNoNum())); } } return model; } private Date getStartDateByType(Integer timeType) { Date date = null; if(timeType == null){ return null; } else if (timeType == 0) { //本周 date = DateUtil.getBeginDayOfWeek(0); }else if (timeType == 1) { //本月 date = DateUtil.getBeginDayOfMonth(0); }else if (timeType == 2) { //本季度 date = DateUtil.getBeginDayOfSeason(0); }else if (timeType == 3) { //本年 date = DateUtil.getBeginDayOfYear(0); } return date; } }