From 7c05649d5eba19fc5fdf4d120f106920d80341e3 Mon Sep 17 00:00:00 2001 From: k94314517 <8417338+k94314517@user.noreply.gitee.com> Date: 星期五, 11 十月 2024 14:49:26 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java | 1170 +++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 1,069 insertions(+), 101 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java index da0ec66..ad2249f 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java @@ -1,18 +1,31 @@ package com.doumee.service.business.impl; +import com.alibaba.fastjson.JSONObject; import com.doumee.biz.system.SystemDictDataBiz; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; +import com.doumee.core.haikang.model.HKConstants; +import com.doumee.core.haikang.model.param.BaseResponse; +import com.doumee.core.haikang.model.param.request.ParkReservationAddRequest; +import com.doumee.core.haikang.model.param.respose.ParkReservationAddResponse; +import com.doumee.core.haikang.service.HKService; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; +import com.doumee.core.utils.DateUtil; +import com.doumee.core.utils.SmsConstants; import com.doumee.core.utils.Utils; import com.doumee.dao.business.*; import com.doumee.dao.business.dao.CompanyMapper; import com.doumee.dao.business.dto.ApproveDTO; import com.doumee.dao.business.join.ApproveJoinMapper; +import com.doumee.dao.business.join.CarUseBookJoinMapper; +import com.doumee.dao.business.join.VisitsJoinMapper; import com.doumee.dao.business.model.*; import com.doumee.dao.business.vo.ApproveDataVO; +import com.doumee.dao.system.dto.NoticesDTO; +import com.doumee.dao.system.join.NoticesJoinMapper; +import com.doumee.dao.system.model.Notices; import com.doumee.dao.system.model.SystemUser; import com.doumee.dao.web.response.InternalHomeVO; import com.doumee.service.business.ApproveService; @@ -20,11 +33,14 @@ 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.business.third.EmayService; import com.github.xiaoymin.knife4j.core.util.CollectionUtils; import com.github.yulichang.wrapper.MPJLambdaWrapper; +import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; -import org.apache.xpath.operations.Bool; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -37,6 +53,7 @@ * @date 2023/12/28 14:09 */ @Service +@Slf4j public class ApproveServiceImpl implements ApproveService { @Autowired @@ -68,6 +85,44 @@ @Autowired private VisitsMapper visitsMapper; + + @Autowired + private VisitsJoinMapper visitsJoinMapper; + + @Autowired + private CarUseBookJoinMapper carUseBookJoinMapper; + @Autowired + private NoticesJoinMapper noticesJoinMapper; + @Autowired + private PlatformBooksMapper platformBooksMapper; + @Autowired + private PlatformJobMapper platformJobMapper; + @Autowired + private PlatformLogMapper platformLogMapper; + @Autowired + private PlatformReasonMapper platformReasonMapper; + @Autowired + private PlatformGroupMapper platformGroupMapper; + + + @Autowired + private ParksMapper parksMapper; + + @Autowired + private ParkBookMapper parkBookMapper; + + @Autowired + private VisitParkMapper visitParkMapper; + + @Autowired + private SmsConfigMapper smsConfigMapper; + + @Autowired + private SmsEmailMapper smsEmailMapper; + + @Autowired + private EmayService emayService; + @Override public Integer create(Approve approve) { @@ -214,16 +269,95 @@ /** * 鍐呴儴浜哄憳H5椤甸潰棣栭〉 * @param memberId + * @param isDetail 鏄惁鏌ヨ璇︾粏 1鏄紱0鍚� * @return */ @Override - public InternalHomeVO getHomeData(Integer memberId){ + public InternalHomeVO getHomeDataH5(Integer memberId,Integer isDetail){ InternalHomeVO internalHomeVO = new InternalHomeVO(); internalHomeVO.setHomeImg(systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.HOME_IMAGE).getCode()); - internalHomeVO.setTaskNum(approveMapper.selectCount(new QueryWrapper<Approve>().lambda().eq(Approve::getChekorId,memberId).eq(Approve::getStatus,Constants.ZERO))); + //浠诲姟鏁版嵁 + List<Notices> noticesList = noticesJoinMapper. + selectList(new QueryWrapper<Notices>().lambda() + .eq(Notices::getUserId,memberId).orderByDesc(Notices::getCreateDate)); + internalHomeVO.setTaskNum(noticesList.size()); + if(Constants.equalsInteger(Constants.ONE,isDetail)){ + if(CollectionUtils.isNotEmpty(noticesList)){ + //寰呮垜澶勭悊鐨勬暟鎹� + internalHomeVO.setNoticeWaitNum( + noticesList.stream().filter(i->Constants.equalsInteger(i.getUserId(),memberId) + &&Constants.equalsInteger(i.getStatus(),Constants.ZERO) + &&Constants.equalsInteger(i.getSendacopy(),Constants.ZERO) + ).count() + ); + //宸插鐞嗘暟鎹� + internalHomeVO.setNoticeDealNum( + noticesList.stream().filter(i->Constants.equalsInteger(i.getUserId(),memberId) + &&StringUtils.equals(i.getParam4(),i.getUserId().toString()) + &&Constants.equalsInteger(i.getStatus(),Constants.ONE) + &&Constants.equalsInteger(i.getSendacopy(),Constants.ZERO) + ).count() + ); + //鎴戝彂璧风殑鏁版嵁 + internalHomeVO.setNoticeCreateNum( + noticesJoinMapper.selectCount(new QueryWrapper<Notices>().lambda().eq(Notices::getParam3,memberId)) + ); + //鎶勯�佹垜鐨勬暟鎹� + internalHomeVO.setNoticeCopyNum( + noticesList.stream().filter(i->Constants.equalsInteger(i.getUserId(),memberId) + &&Constants.equalsInteger(i.getSendacopy(),Constants.ONE) + ).count() + ); + } + } + return internalHomeVO; } + + @Override + public InternalHomeVO getHomeDataPC(NoticesDTO noticesDTO){ + InternalHomeVO internalHomeVO = new InternalHomeVO(); + internalHomeVO.setHomeImg(systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.HOME_IMAGE).getCode()); + //浠诲姟鏁版嵁 + List<Notices> noticesList = noticesJoinMapper. + selectList(new QueryWrapper<Notices>().lambda() + .ge(noticesDTO.getStartDate() != null, Notices::getCreateDate, Utils.Date.getStart(noticesDTO.getStartDate() )) + .le(noticesDTO.getEndDate() != null, Notices::getCreateDate, Utils.Date.getEnd(noticesDTO.getEndDate() )) + .eq(noticesDTO.getType() != null, Notices::getType, noticesDTO.getType()) + .eq(Notices::getUserId,noticesDTO.getMemberId()) + .orderByDesc(Notices::getCreateDate) + ); + internalHomeVO.setTaskNum(noticesList.size()); + if(CollectionUtils.isNotEmpty(noticesList)){ + //寰呮垜澶勭悊鐨勬暟鎹� + internalHomeVO.setNoticeWaitNum( + noticesList.stream().filter(i->Constants.equalsInteger(i.getUserId(),noticesDTO.getMemberId()) + &&Constants.equalsInteger(i.getStatus(),Constants.ZERO) + &&Constants.equalsInteger(i.getSendacopy(),Constants.ZERO) + ).count() + ); + internalHomeVO.setNoticeDealNum( + noticesList.stream().filter(i->Constants.equalsInteger(i.getUserId(),noticesDTO.getMemberId()) + &&Constants.equalsInteger(i.getStatus(),Constants.ONE) + &&Constants.equalsInteger(i.getSendacopy(),Constants.ZERO) + ).count() + ); + + internalHomeVO.setNoticeCreateNum( + noticesJoinMapper.selectCount(new QueryWrapper<Notices>().lambda().eq(Notices::getParam3,noticesDTO.getMemberId())) + ); + + internalHomeVO.setNoticeCopyNum( + noticesList.stream().filter(i->Constants.equalsInteger(i.getUserId(),noticesDTO.getMemberId()) + &&Constants.equalsInteger(i.getSendacopy(),Constants.ONE) + &&Constants.equalsInteger(i.getReaded(),Constants.ZERO) + ).count() + ); + } + + return internalHomeVO; + } /** * 鍒涘缓瀹℃壒娴佺▼ @@ -274,10 +408,55 @@ //澶勭悊鎶勯�佹暟鎹� if(CollectionUtils.isNotEmpty(approveCopyList)){ - this.organizeApproveCopyData(approveTempl,approveParamList,businessId,approveList); + this.organizeApproveCopyData(approveTempl,approveCopyList,businessId,approveList); } - approveMapper.insertBatchSomeColumn(approveList); + approveJoinMapper.insert(approveList); + } + + + @Override + @Transactional(rollbackFor = {Exception.class,BusinessException.class}) + public void createApproveForPlatfrom(Integer tempId,Integer businessId,Integer createMemberId){ + //鏌ヨ澶勭悊妯℃澘 + ApproveTempl approveTempl = approveTemplMapper.selectById(tempId); + if(Objects.isNull(approveTempl)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌瀹℃壒娴侀厤缃ā鏉�"); + } + //鏌ヨ閰嶇疆娴佺▼ + List<ApproveParam> approveParamAllList = approveParamMapper.selectList(new QueryWrapper<ApproveParam>() + .lambda().eq(ApproveParam::getIsdeleted,Constants.ZERO) + .eq(ApproveParam::getTemplId,approveTempl.getId()) + .orderByAsc(ApproveParam::getType) + .orderByAsc(ApproveParam::getLevel) + ); + if(Objects.isNull(approveParamAllList)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈厤缃鎵规祦绋�"); + } + //瀹℃壒閰嶇疆 + List<ApproveParam> approveParamList = approveParamAllList.stream().filter(i->i.getType().equals(Constants.ZERO)).collect(Collectors.toList()); + if(Objects.isNull(approveParamList)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈厤缃鎵规祦绋�"); + } + List<ApproveParam> approveCopyList = approveParamAllList.stream().filter(i->i.getType().equals(Constants.ONE)).collect(Collectors.toList()); + + Member createMember = memberMapper.selectById(createMemberId); + if(Objects.isNull(createMember)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鐢宠浜虹粍缁囦俊鎭紓甯�"); + } + List<Approve> approveList = new ArrayList<>(); + + this.organizeApproveData(approveTempl,approveParamList,createMember,businessId,approveList); + + if(CollectionUtils.isEmpty(approveList)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇�"); + } + + //澶勭悊鎶勯�佹暟鎹� + if(CollectionUtils.isNotEmpty(approveCopyList)){ + this.organizeApproveCopyData(approveTempl,approveCopyList,businessId,approveList); + } + approveJoinMapper.insert(approveList); } @@ -290,18 +469,102 @@ * @param approveList */ public void organizeApproveData(ApproveTempl approveTempl,List<ApproveParam> approveParamList,Member createMember,Integer businessId,List<Approve> approveList){ + + //鍒涘缓榛樿浜轰俊鎭� + Approve createUserApprove = new Approve(); + createUserApprove.setRemark("鍙戣捣鐢宠"); + createUserApprove.setCreateDate(new Date()); + createUserApprove.setIsdeleted(Constants.ZERO); + createUserApprove.setTemplatId(approveTempl.getId()); + createUserApprove.setChekorId(createMember.getId()); + createUserApprove.setCheckDate(createUserApprove.getCreateDate()); + createUserApprove.setStatus(Constants.approveStatus.pass); + createUserApprove.setTitle("鍙戣捣鐢宠"); + createUserApprove.setStatusInfo(""); + createUserApprove.setIsEndCheck(Constants.ZERO); + createUserApprove.setObjId(businessId); + createUserApprove.setLevel(-1); + createUserApprove.setObjType(approveTempl.getType()); + createUserApprove.setApproveType(Constants.TWO); + createUserApprove.setDriverParam(Constants.ZERO); + createUserApprove.setAddrParam(Constants.ZERO); + createUserApprove.setType(Constants.ZERO); + approveList.add(createUserApprove); + + //鏌ヨ鎵�鏈夊緟澶勭悊浜� + //瀹℃壒涓氬姟鏁版嵁 for (int i = 0; i < approveParamList.size(); i++) { ApproveParam approveParam = approveParamList.get(i); List<Integer> ids = this.getApproveUserIds(approveParam,createMember); - for (Integer memberId:ids) { + List<Member> memberList = memberMapper.selectList(new QueryWrapper<Member>().lambda().in(Member::getId,ids)); + List<String> memberNameList =memberList.stream().map(m->m.getName()).collect(Collectors.toList()); + String memberNames = String.join(",",memberNameList); + Integer noticeType = Constants.approveTypeToNoticeType(approveTempl.getType()); + String title = "[璁垮鐢宠]鐢宠浜�-"; + Map<String,Object> jsonMap = new HashMap<>(); + for (int j = 0; j < memberList.size(); j++) { + Member member = memberList.get(j); + Integer memberId = member.getId(); + //鐢熸垚寰呭姙 notices 琛ㄦ暟鎹� + if(i==0){ + if(jsonMap.isEmpty()){ + title = this.createNoticesData(noticeType,businessId,title,jsonMap); + } + if(j==0){ + //榛樿鐢熸垚涓�鏉� 鐢宠浜虹殑鏁版嵁 鏍囪鍒犻櫎鐘舵�佺敤浜庡鐞嗗埌 浠诲姟涓績锛堟垜鍙戣捣锛変娇鐢� + Notices notices = new Notices(); + notices.setCreateDate(new Date()); + notices.setIsdeleted(Constants.ONE); + notices.setObjId(businessId); + notices.setObjType(noticeType); + notices.setType(noticeType); + notices.setTitle(title); + notices.setParam1(JSONObject.toJSONString(jsonMap)); + notices.setStatus(Constants.ZERO); + notices.setReaded(Constants.ZERO); + notices.setSendacopy(Constants.ZERO); + notices.setParam2("0"); + notices.setParam3(createMember.getId().toString()); + notices.setInfo("澶勭悊涓�"); + noticesJoinMapper.insert(notices); + } + if(CollectionUtils.isEmpty(memberList)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌瀹℃壒浜轰俊鎭�"); + } + Notices notices = new Notices(); + notices.setCreateDate(new Date()); + notices.setIsdeleted(Constants.ZERO); + notices.setObjId(businessId); + notices.setObjType(noticeType); + notices.setType(noticeType); + notices.setTitle(title); + notices.setParam1(JSONObject.toJSONString(jsonMap)); + notices.setUserId(memberId); + notices.setPalt(Constants.ZERO); + notices.setStatus(Constants.ZERO); + notices.setReaded(Constants.ZERO); + notices.setSendacopy(Constants.ZERO); + notices.setParam2("0"); + notices.setParam3(""); + notices.setParam5(memberNames); + notices.setRemark(member.getName()); + if(Constants.equalsInteger(memberNameList.size(),Constants.ONE)){ + notices.setInfo("寰�"+memberNameList.get(0)+"澶勭悊涓�"); + }else{ + notices.setInfo("寰�"+memberNameList.get(0)+"绛�"+memberList.size()+"浜哄鐞嗕腑"); + } + noticesJoinMapper.insert(notices); + } Approve approve = new Approve(); + approve.setRemark(approveParam.getRemark()); approve.setCreateDate(new Date()); approve.setIsdeleted(Constants.ZERO); approve.setTemplatId(approveTempl.getId()); approve.setChekorId(memberId); approve.setStatus(i==0?Constants.ONE:Constants.ZERO); - approve.setStatusInfo(i==0?"瀹℃壒涓�":"寰呭鎵�"); + approve.setStatusInfo(i==0?"瀹℃壒涓�":"澶勭悊涓�"); + approve.setTitle(StringUtils.isBlank(approveParam.getRemark())?"瀹℃壒涓�":approveParam.getRemark()); approve.setIsEndCheck((i+1) == approveParamList.size()?Constants.ONE:Constants.ZERO); approve.setObjId(businessId); approve.setLevel(i+1); @@ -311,8 +574,85 @@ approve.setAddrParam(approveParam.getAddrParam()); approve.setType(Constants.ZERO); approveList.add(approve); + + if(Constants.equalsInteger(approve.getStatus(),Constants.ONE)){ + //鍙戦�佺煭淇¢�氱煡 + if(Constants.equalsInteger(noticeType,Constants.noticesObjectType.reason)){ + //鐗╂祦杞﹂绾� + SmsEmailServiceImpl.sendPlatformBookSms(systemDictDataBiz, + emayService,smsEmailMapper,smsConfigMapper,platformBooksMapper,businessId, + SmsConstants.platformBookContent.platformBookWaitAudit, + null,null + ); + } + } + } } + } + + + + public String createNoticesData(Integer noticeType,Integer businessId,String title,Map<String,Object> jsonMap){ + jsonMap.clear(); + if(Constants.equalsInteger(noticeType,Constants.noticesObjectType.visit) + || Constants.equalsInteger(noticeType,Constants.noticesObjectType.visitReporting)){ + //璁垮璁板綍涓庤瀹㈡姤澶� + Visits visits = visitsJoinMapper.selectJoinOne(Visits.class, + new MPJLambdaWrapper<Visits>().selectAll(Visits.class) + .selectAs(Member::getName,Visits::getReceptMemberName) + .selectAs(Company::getName,Visits::getReceptMemberDepartment) + .leftJoin(Member.class,Member::getId,Visits::getReceptMemberId) + .leftJoin(Company.class,Company::getId,Member::getCompanyId) + .eq(Visits::getId,businessId) + .last(" limit 1 ") + ); + if(Objects.isNull(visits)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌涓氬姟鏁版嵁淇℃伅"); + } + if(Constants.equalsInteger(noticeType,Constants.noticesObjectType.visit)){ + title = title + visits.getName(); + }else{ + title = "[璁垮鎶ュ]鐢宠浜�-" + visits.getName(); + } + jsonMap.put("name", "璁块棶浜�:" + visits.getCompanyName() + " - " + visits.getReceptMemberName()); + jsonMap.put("sTime", "鍏ュ洯鏃堕棿:" + DateUtil.DateToStr(visits.getStarttime() , "yyyy-MM-dd HH:mm")); + jsonMap.put("eTime", "绂诲洯鏃堕棿:" + DateUtil.DateToStr(visits.getEndtime() , "yyyy-MM-dd HH:mm")); + jsonMap.put("reason", StringUtils.isBlank(visits.getReason())?"鏉ヨ浜嬬敱: - ": "鏉ヨ浜嬬敱:" +visits.getReason()); + jsonMap.put("carNos", StringUtils.isBlank(visits.getCarNos())?"闅忚杞﹁締: - ": "闅忚杞﹁締:" +visits.getCarNos()); + }else if(Constants.equalsInteger(noticeType,Constants.noticesObjectType.useCar)){ + //鐢ㄨ溅鐢宠 + CarUseBook carUseBook = carUseBookJoinMapper.selectJoinOne(CarUseBook.class, + new MPJLambdaWrapper<CarUseBook>().selectAll(CarUseBook.class) + .selectAs(Member::getName,CarUseBook::getMemberName) + .selectAs(Company::getName,CarUseBook::getCompanyName) + .leftJoin(Member.class,Member::getId,CarUseBook::getMemberId) + .leftJoin(Company.class,Company::getId,Member::getCompanyId) + .eq(CarUseBook::getId,businessId) + .last(" limit 1 ") + ); + if(Objects.isNull(carUseBook)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌涓氬姟鏁版嵁淇℃伅"); + } + title = "[鐢ㄨ溅鐢宠]鐢宠浜�-" + carUseBook.getMemberName(); + jsonMap.put("name", "鐢宠浜�:" + carUseBook.getCompanyName() + " - " + carUseBook.getMemberName()); + jsonMap.put("sTime", "寮�濮嬫椂闂�:" + DateUtil.DateToStr(carUseBook.getStartTime() , "yyyy-MM-dd HH:mm")); + jsonMap.put("eTime", "缁撴潫鏃堕棿:" + DateUtil.DateToStr(carUseBook.getEndTime() , "yyyy-MM-dd HH:mm")); + jsonMap.put("usrNum", StringUtils.isBlank(carUseBook.getMemberIds())?"涔樿溅浜烘暟: 0浜�": "涔樿溅浜烘暟: " +carUseBook.getMemberIds().split(",").length +"浜�"); + jsonMap.put("mdd", StringUtils.isBlank(carUseBook.getAddr())?"鐩殑鍦�: - ": "鐩殑鍦�:" +carUseBook.getAddr()); + }else if(Constants.equalsInteger(noticeType,Constants.noticesObjectType.reason)){ + //鐗╂祦杞﹂绾� + PlatformBooks platformBooks = platformBooksMapper.selectById(businessId); + if(Objects.isNull(platformBooks)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌涓氬姟鏁版嵁淇℃伅"); + } + title = "[鐗╂祦杞﹀叆鍥绾鐢宠浜�-" + platformBooks.getDriverName(); + jsonMap.put("inType", "鍏ュ簱绫诲瀷锛�"+(Constants.equalsInteger(platformBooks.getInType(),Constants.ZERO)?"鏁存墭鐩�":"浠剁儫")); + jsonMap.put("totalNum", "鎬昏繍杈撻噺锛�"+platformBooks.getTotalNum()+"涓囨敮"); + jsonMap.put("arriveDate", "鍒板満鏃堕棿锛�" + DateUtil.DateToStr(platformBooks.getArriveDate() , "yyyy-MM-dd HH:mm")); + jsonMap.put("carNum", "杞︾墝鐓э細"+platformBooks.getCarCodeFront()); + } + return title; } @@ -329,18 +669,18 @@ if(CollectionUtils.isNotEmpty(memberList)){ userIds.addAll(memberList.stream().map(m->m.getId()).collect(Collectors.toList())); } - //鍏姟鐢ㄨ溅 榛樿鍔犲叆 鍙告満鎶勯�� - if(approveTempl.getType()==Constants.THREE||approveTempl.getType()==Constants.FOUR){ - CarUseBook carUseBook = carUseBookMapper.selectById(businessId); - if(Objects.isNull(carUseBook)){ - throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"涓烘煡璇㈠埌鐢ㄨ溅鐢宠淇℃伅"); - } - CarDriver carDriver = carDriverMapper.selectById(carUseBook.getDriverId()); - if(Objects.isNull(carDriver)){ - throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"涓烘煡璇㈠埌鍙告満淇℃伅"); - } - userIds.add(carDriver.getMemberId()); - } + //鍏姟鐢ㄨ溅 榛樿鍔犲叆 鍙告満鎶勯�� 2024骞�6鏈�28鏃�16:49:08 鍙告満鎶勯�佷慨鏀瑰埌 瀹℃壒涓氬姟鏃惰繘琛屽彂閫� +// if(approveTempl.getType()==Constants.THREE||approveTempl.getType()==Constants.FOUR){ +// CarUseBook carUseBook = carUseBookMapper.selectById(businessId); +// if(Objects.isNull(carUseBook)){ +// throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"涓烘煡璇㈠埌鐢ㄨ溅鐢宠淇℃伅"); +// } +// CarDriver carDriver = carDriverMapper.selectById(carUseBook.getDriverId()); +// if(Objects.isNull(carDriver)){ +// throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"涓烘煡璇㈠埌鍙告満淇℃伅"); +// } +// userIds.add(carDriver.getMemberId()); +// } if(CollectionUtils.isNotEmpty(userIds)){ for (Integer memberId:userIds) { @@ -349,6 +689,7 @@ approve.setIsdeleted(Constants.ZERO); approve.setTemplatId(approveTempl.getId()); approve.setChekorId(memberId); + approve.setObjType(approveTempl.getType()); approve.setObjId(businessId); approve.setType(Constants.ONE); approveList.add(approve); @@ -382,7 +723,7 @@ if(Objects.isNull(memberCompany)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇痆鎸囧畾瀹℃壒閮ㄩ棬鏈煡璇㈠埌]"); } - Company auditCompany = this.getAuditCompanyHead(memberCompany.getParentId(),approveParam.getObjLevel()); + Company auditCompany = this.getAuditCompanyHead(memberCompany.getId(),approveParam.getObjLevel()); if(Objects.isNull(auditCompany)){ //瀹℃壒閮ㄩ棬涓虹┖ 鑷姩娴佽浆涓嬩竴绾у鎵归厤缃� throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇痆鎸囧畾瀹℃壒閮ㄩ棬鏈煡璇㈠埌]"); @@ -391,7 +732,7 @@ Member headMember = memberMapper.selectById(auditCompany.getHeadId()); if(Objects.isNull(headMember)){ //鏈煡璇㈠埌閮ㄩ棬璐熻矗浜� 鏍规嵁閰嶇疆澶勭悊 鐢变笂绾т富绠′唬鏇垮鏍�/鐩存帴缁撴潫娴佺▼ - if(approveParam.getNoleaderOpt().equals(Constants.ONE)&&!Objects.isNull(auditCompany.getParentId())){ + if(Constants.equalsInteger(approveParam.getNoleaderOpt(),Constants.ONE)&&Objects.nonNull(auditCompany.getParentId())){ auditCompany = companyMapper.selectOne(new QueryWrapper<Company>().lambda().eq(Company::getId,auditCompany.getParentId())); //鏃犵埗绾� 鐩存帴娴佷紶涓嬩竴绾у鎵� if(Objects.isNull(auditCompany)){ @@ -406,9 +747,11 @@ userIds.add(headMember.getId()); } }else{ - //娣诲姞瀹℃壒浜� - userIds.add(headMember.getId()); + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇痆鎸囧畾瀹℃壒閮ㄩ棬涓荤鏈煡璇㈠埌]"); } + }else{ + //娣诲姞瀹℃壒浜� + userIds.add(headMember.getId()); } } } @@ -423,9 +766,9 @@ * @param objLevel 鏌ヨ绾у埆 */ public Company getAuditCompanyHead(Integer companyId, Integer objLevel){ - Integer queryLevel = Constants.ZERO; Company auditCompany = companyMapper.selectById(companyId); - while(queryLevel.equals(objLevel)){ + Integer queryLevel = Constants.ONE; + while(queryLevel<objLevel){ auditCompany = companyMapper.selectById(auditCompany.getParentId()); if(Objects.isNull(auditCompany)){ return null; @@ -435,6 +778,222 @@ return auditCompany; } + @Override + public ApproveDataVO arrangeApprovedData(Integer businessId, Integer businessType, Integer memberId){ + ApproveDataVO approveDateVO = new ApproveDataVO(); + approveDateVO.setApproveList(new ArrayList<>()); + approveDateVO.setCanBeApproved(Constants.ZERO); + List<Approve> approveGroupList = approveJoinMapper.selectJoinList(Approve.class, + new MPJLambdaWrapper<Approve>(). + selectAll(Approve.class) + .selectAs(Member::getName,Approve::getMemberName) + .selectAs(Member::getPhone,Approve::getMemberPhone) + .selectAs(Member::getFaceImg,Approve::getFaceImg) + .selectAs(Company::getCompanyNamePath,Approve::getCompanyName) + .leftJoin(Member.class,Member::getId,Approve::getChekorId) + .leftJoin(Company.class,Company::getId,Member::getCompanyId) + .eq(Approve::getIsdeleted,Constants.ZERO) + .ne(Approve::getStatus,Constants.approveStatus.cancel) + .eq(Approve::getObjId,businessId) + .eq(Approve::getObjType,businessType) + .orderByAsc(Approve::getLevel) + .orderByAsc(Approve::getStatus) + + ); + + //鏌ユ壘鍏ㄩ儴levelList + List<Approve> levelList = getLevelListFromResult(approveGroupList,approveDateVO,memberId); + List<Approve> copyList = getAllCopyList(approveGroupList); + //閬嶅巻level鏌ヨ姣忎竴绾у埆涓氬姟鏁版嵁 + if(levelList!=null){ + for(Approve level:levelList){ + List<Approve> tlist = getLevelInfoFromList(level,approveGroupList); + approveDateVO.getApproveList().addAll(tlist); + } + } + + //澶勭悊鎶勯�佽褰� + if (CollectionUtils.isNotEmpty(copyList)) { + Approve waitModel = new Approve(); + waitModel.setApproveType(Constants.ONE); + waitModel.setCheckDate(copyList.get(Constants.ZERO).getCheckDate()); + waitModel.setTitle("鎶勯�佷汉"); + waitModel.setStatus(copyList.get(Constants.ZERO).getStatus()); + waitModel.setType(Constants.ONE); + waitModel.setApproveList(copyList); + approveDateVO.getApproveList().add(waitModel); + } + System.out.println(JSONObject.toJSONString(approveDateVO)); + return approveDateVO; + } + + private List<Approve> getAllCopyList(List<Approve> approveGroupList) { + List<Approve> copyList = new ArrayList<>(); + if (CollectionUtils.isNotEmpty(approveGroupList)) { + copyList.addAll(approveGroupList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.ONE)).collect(Collectors.toList())); + } + return copyList; + } + + private List<Approve> getLevelInfoFromList(Approve level,List<Approve> approveGroupList) { + List<Approve> list = new ArrayList<>(); + if(Constants.equalsInteger(level.getApproveType(),Constants.TWO)){ + level.setApproveType(Constants.TWO); + //濡傛灉鏄崟浜哄鎵� + list.add(level); + return list; + } + //鏌ユ壘鍏ㄩ儴宸插鐞嗙殑闆嗗悎 + List<Approve> passList = new ArrayList<>();//宸插悓鎰忕殑璁板綍闆� + Approve refuseModel = new Approve();//宸叉嫆缁濈殑璁板綍 + List<Approve> waitList = new ArrayList<>(); //鏌ヨ鍏ㄩ儴鏈鐞嗙殑闆嗗悎 + List<Approve> otherPassList = new ArrayList<>();//浠栦汉宸插鐞嗙殑璁板綍闆� + int appType = Constants.formatIntegerNum(level.getApproveType());//褰撳墠瀹℃壒绫诲瀷 + dealGroupListBiz(level,approveGroupList,passList,refuseModel,waitList,otherPassList); + if(Objects.nonNull(refuseModel) && Objects.nonNull(refuseModel.getId())){ + //瀛樺湪鎷掔粷鐨勶紝鍙渶瑕佽繑鍥炰竴鏉″鐞嗘暟鎹紝鍚庣画涓嶉渶瑕佸洖鏄� + refuseModel.setApproveType(Constants.ZERO); + list.add(refuseModel); + return list; + } + list.addAll(sortByCreateTime(passList)); + if(Constants.equalsInteger(appType,Constants.ONE)){ + //濡傛灉鏄細绛� + if(waitList.size()>1){ + Approve waitModel = new Approve(); + waitModel.setApproveType(Constants.ONE); + waitModel.setType(Constants.ZERO); + waitModel.setTitle(StringUtils.defaultString(level.getTitle(),"瀹℃壒浜�")); + waitModel.setStatus(Constants.equalsInteger(waitList.get(Constants.ZERO).getStatus(),Constants.ONE)?Constants.ONE:Constants.ZERO); + if(Constants.equalsInteger(waitModel.getStatus(),Constants.approveStatus.wait)){ + waitModel.setStatusInfo("寰呭鐞�"); + }else if(Constants.equalsInteger(waitModel.getStatus(),Constants.approveStatus.auditIng)){ + waitModel.setStatusInfo("澶勭悊涓�"); + } + + waitModel.setMemberName(waitList.size() +"浜轰細绛�"); +// if(Constants.equalsInteger(level.getStatus(),Constants.approveStatus.auditIng) +// ||Constants.equalsInteger(level.getStatus(),Constants.approveStatus.pass)){ +// waitModel.setMemberName(waitList.size() +"浜轰細绛�"); +// } + if(CollectionUtils.isNotEmpty(waitList)){ + waitModel.setCreateDate(waitList.get(Constants.ZERO).getCreateDate()); + } + waitModel.setApproveList(waitList); + list.add(waitModel); + }else if(waitList.size()>0){ + Approve approve = waitList.get(Constants.ZERO); + approve.setApproveType(Constants.ZERO); + approve.setType(Constants.ZERO); + list.add(approve); + } + }else { + if((waitList.size()> 0 || otherPassList.size()>0)){ + Approve waitModel = new Approve(); + waitModel.setApproveType(Constants.ZERO); + if(Constants.equalsInteger(level.getStatus(),Constants.approveStatus.pass)){ + waitModel.setStatus(level.getStatus()); + waitModel.setType(Constants.ONE); + waitModel.setCheckDate(level.getCheckDate()); + waitModel.setTitle(StringUtils.defaultString(level.getTitle(),"瀹℃壒浜�")); + }else{ + waitModel.setStatus(level.getStatus()); + waitModel.setType(Constants.ZERO); + //waitModel.setStatusInfo(passList.size()<=0?StringUtils.defaultString(level.getTitle(),"瀹℃壒浜�"):"鎶勯�佹垨绛惧鎵逛汉"); + waitModel.setTitle(passList.size()<=0?StringUtils.defaultString(level.getTitle(),"瀹℃壒浜�"):"鎶勯�佹垨绛惧鎵逛汉"); + + } + List<Approve> approveList = new ArrayList<>(); + approveList.addAll(waitList); + //濡傛灉鏄垨绛� + if(passList.size()>0){ + approveList.addAll(otherPassList); + } + if(CollectionUtils.isNotEmpty(approveList)){ + waitModel.setCreateDate(approveList.get(Constants.ZERO).getCreateDate()); + } + if(Constants.equalsInteger(waitModel.getStatus(),Constants.approveStatus.pass)){ + waitModel.setMemberName("宸叉妱閫�"+ approveList.size() +"浜�"); + }else if(Constants.equalsInteger(waitModel.getStatus(),Constants.approveStatus.wait)){ + waitModel.setMemberName(waitList.size() +"浜烘垨绛�"); + waitModel.setStatusInfo("寰呭鐞�"); + }else{ + waitModel.setMemberName(waitList.size() +"浜烘垨绛�"); + waitModel.setStatusInfo("澶勭悊涓�"); + } + waitModel.setApproveList(approveList); + list.add(waitModel); + } + } + + + return list; + + } + + private void dealGroupListBiz(Approve level, List<Approve> approveGroupList, List<Approve> passList, Approve refuseModel, List<Approve> waitList, List<Approve> otherPassList) { + //鏌ヨ鏄惁瀛樺湪鎷掔粷鏁版嵁 + List<Approve> levelApprove = approveGroupList.stream().filter(i->Constants.equalsInteger(i.getLevel(),level.getLevel())).collect(Collectors.toList()); + for (Approve approve:levelApprove) { + if(!Constants.equalsInteger(level.getLevel(),approve.getLevel())){ + continue; + } + if(Constants.equalsInteger(Constants.approveStatus.pass,approve.getStatus())){ + approve.setApproveType(Constants.ZERO); + passList.add(approve); + }else if(Constants.equalsInteger(Constants.approveStatus.otherDeal,approve.getStatus())){ + otherPassList.add(approve); + }else if(Constants.equalsInteger(Constants.approveStatus.auditIng,approve.getStatus())||Constants.equalsInteger(Constants.approveStatus.wait,approve.getStatus())){ + waitList.add(approve); + }else if(Constants.equalsInteger(Constants.approveStatus.unPass,approve.getStatus())){ + BeanUtils.copyProperties(approve,refuseModel); + } + } + } + + private List<Approve> sortByCreateTime(List<Approve> passList) { + Collections.sort(passList, (a, b) -> a.getCheckDate().compareTo(b.getCheckDate())); + return passList; + } + + + private List<Approve> getLevelListFromResult(List<Approve> approveGroupList,ApproveDataVO approveDataVO,Integer memberId) { + approveDataVO.setCanBeApproved(Constants.ZERO); + approveDataVO.setDriverParam(Constants.ZERO); + List<Approve> approveList = new ArrayList<>(); + String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() + +systemDictDataBiz.queryByCode(Constants.FTP,Constants.MEMBER_IMG).getCode(); + for (Approve approve:approveGroupList) { + if(StringUtils.isNotBlank(approve.getFaceImg())){ + approve.setFaceImg(path + approve.getFaceImg()); + } + if(Constants.equalsInteger(approve.getType(),Constants.ONE)){ + continue; + } + if(Constants.equalsInteger(approve.getChekorId(),memberId) + &&Constants.equalsInteger(approve.getStatus(), Constants.ONE)){ + approveDataVO.setCanBeApproved(Constants.ONE); + approveDataVO.setDriverParam(approve.getDriverParam()); + } + if(notExsits(approveList,approve.getLevel())){ + approveList.add(approve); + } + } + if(CollectionUtils.isEmpty(approveList)){ + // throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒淇℃伅锛氱骇鍒暟鎹紓甯�"); + } + return approveList; + } + + private boolean notExsits(List<Approve> approveList, Integer level) { + for (Approve approve:approveList) { + if(Constants.equalsInteger(approve.getLevel(),level)){ + return false; + } + } + return true; + } + /** * 鏁寸悊 瀹℃壒鏁版嵁 @@ -442,18 +1001,18 @@ * @param businessType * @return */ - @Override - public ApproveDataVO arrangeApprovedData(Integer businessId, Integer businessType, Integer memberId){ +// @Override + public ApproveDataVO arrangeApprovedDataOld(Integer businessId, Integer businessType, Integer memberId){ ApproveDataVO approveDateVO = new ApproveDataVO(); approveDateVO.setCanBeApproved(Constants.ZERO); List<Approve> approveGroupList = approveJoinMapper.selectJoinList(Approve.class, new MPJLambdaWrapper<Approve>(). - select(Approve::getLevel,Approve::getType) + select(Approve::getLevel,Approve::getType,Approve::getTitle,Approve::getApproveType) .eq(Approve::getIsdeleted,Constants.ZERO) .eq(Approve::getObjId,businessId) .isNotNull(Approve::getLevel) .eq(Approve::getObjType,businessType) - .groupBy(Approve::getLevel,Approve::getType) + .groupBy(Approve::getLevel,Approve::getType,Approve::getTitle,Approve::getApproveType) ); if(CollectionUtils.isEmpty(approveGroupList)){ return approveDateVO; @@ -464,6 +1023,7 @@ .selectAll(Approve.class) .selectAs(Member::getName,Approve::getMemberName) .selectAs(Member::getPhone,Approve::getMemberPhone) + .selectAs(Member::getFaceImg,Approve::getFaceImg) .selectAs(Company::getName,Approve::getCompanyName) .leftJoin(Member.class,Member::getId,Approve::getChekorId) .leftJoin(Company.class,Company::getId,Member::getCompanyId) @@ -475,14 +1035,24 @@ .orderByAsc(Approve::getLevel) .orderByAsc(Approve::getId) ); + String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() + +systemDictDataBiz.queryByCode(Constants.FTP,Constants.MEMBER_IMG).getCode(); + for (Approve approve:approveAllList ) { + if(StringUtils.isNotBlank(approve.getFaceImg())){ + approve.setFaceImg(path + approve.getFaceImg()); + } + } + if(CollectionUtils.isEmpty(approveAllList)){ return approveDateVO; } - List<Approve> approveList = approveAllList.stream().filter(i->i.getType().equals(Constants.ZERO)).collect(Collectors.toList()); + List<Approve> approveList = approveAllList.stream().filter(i->Constants.equalsInteger(i.getType(),(Constants.ZERO))) + .collect(Collectors.toList()); if(CollectionUtils.isEmpty(approveList)){ return approveDateVO; } approveDateVO.setCanBeApproved(this.canBeApproved(approveList,memberId)); + approveDateVO.setDriverParam(this.canDriverParam(approveList,memberId)); //鏍规嵁瀹℃壒绾у埆 澶勭悊鏁版嵁 for (Approve approve:approveGroupList) { approve.setApproveList( @@ -511,6 +1081,41 @@ return Constants.ZERO; } + public Integer canDriverParam(List<Approve> approveList,Integer memberId){ + //鑾峰彇鎵�鏈夊緟瀹℃壒鐨勬暟鎹� + List<Approve> waitApprovedList = approveList.stream().filter(i->i.getType().equals(Constants.ZERO)&&i.getStatus().equals(Constants.ZERO)).collect(Collectors.toList()); + if(CollectionUtils.isNotEmpty(waitApprovedList)){ + //涓嬩釜瀹℃壒娴佺▼绛夌骇 + Integer nextApprovedLevel = waitApprovedList.get(Constants.ZERO).getLevel(); + //涓嬩釜瀹℃壒娴佺▼鐨� 鎵�鏈夋暟鎹� + List<Approve> nextApprovedList = waitApprovedList.stream().filter(i->i.getStatus().equals(Constants.ZERO)&&i.getLevel().equals(nextApprovedLevel)).collect(Collectors.toList()); + //涓嬩釜瀹℃壒娴佺▼鍐� 濡傛灉瀛樺湪褰撳墠 鐢ㄦ埛鐨勬姄绱� 鍒欏彲浠ヨ繘琛屽鎵� + List<Approve> auditApproveList = nextApprovedList.stream().filter(i->i.getChekorId().equals(memberId)).collect(Collectors.toList()); + if(auditApproveList.size() >0){ + Approve auditApprove = auditApproveList.get(Constants.ZERO); + return auditApprove.getDriverParam(); + } + } + return Constants.ZERO; + } + + @Override + public String getApproveUserName(Integer businessId,Integer businessType){ + List<Approve> approveList = approveJoinMapper.selectJoinList(Approve.class,new MPJLambdaWrapper<Approve>() + .selectAll(Approve.class) + .selectAs(Member::getName,Approve::getMemberName) + .leftJoin(Member.class,Member::getId,Approve::getChekorId) + .eq(Approve::getObjId,businessId) + .eq(Approve::getObjType,businessType) + .eq(Approve::getType,Constants.ZERO) + .eq(Approve::getStatus,Constants.approveStatus.auditIng) + ); + if(CollectionUtils.isNotEmpty(approveList)){ + List<String> names = approveList.stream().map(m->m.getMemberName()).collect(Collectors.toList()); + return String.join(",",names); + } + return null; + } @@ -532,6 +1137,9 @@ .lambda() .eq(Approve::getObjId,approveDTO.getObjId()) .eq(Approve::getObjType,approveDTO.getObjType()) + .eq(Approve::getChekorId,approveDTO.getLoginUserInfo().getMemberId()) + .eq(Approve::getType,Constants.ZERO) + .eq(Approve::getStatus,Constants.approveStatus.auditIng) .last(" limit 1") ); if(Objects.isNull(approve)){ @@ -540,16 +1148,28 @@ if(!approve.getStatus().equals(Constants.ONE)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒璁板綍鐘舵�侀敊璇�!"); } - + //鏍规嵁瀹℃壒璁板綍鏌ヨ 褰撳墠澶勭悊鏁版嵁瀵瑰簲鐨� 閫氱煡璁板綍 + Integer noticeType = Constants.approveTypeToNoticeType(approve.getObjType()); + Notices notices = noticesJoinMapper.selectOne(new QueryWrapper<Notices>().lambda() + .eq(Notices::getObjId,approve.getObjId()) + .eq(Notices::getObjType,noticeType) + .eq(Notices::getUserId,approve.getChekorId()) + .eq(Notices::getSendacopy,Constants.ZERO) + .eq(Notices::getIsdeleted,Constants.ZERO) + .eq(Notices::getStatus,Constants.ZERO) + .last(" limit 1 ") + ); + if(Objects.isNull(notices)){ + log.info("鏈煡璇㈠埌閫氱煡璁板綍"); + return; + } //澶勭悊瀹℃壒淇℃伅 approve.setStatus(approveDTO.getStatus()); approve.setCheckInfo(approveDTO.getCheckInfo()); approve.setCheorId(approveDTO.getLoginUserInfo().getMemberId().toString()); - approve.setCheckorName(approve.getLoginUserInfo().getRealname()); - approve.setStatusInfo(approveDTO.getStatus()==Constants.TWO?"瀹℃壒閫氳繃":approveDTO.getCheckInfo()); - Visits visits = new Visits(); - CarUseBook carUseBook = new CarUseBook(); - this.dealBusinessData(approveDTO,approve,visits,carUseBook); + approve.setCheckorName(approveDTO.getLoginUserInfo().getRealname()); + approve.setCheckDate(new Date()); + approve.setStatusInfo(approveDTO.getStatus()==Constants.TWO?"宸插悓鎰�":"宸查┏鍥�"); //鏈骇鎵�鏈� 寰呭鎵硅褰� List<Approve> approveList = approveJoinMapper.selectJoinList(Approve.class, new MPJLambdaWrapper<Approve>() @@ -559,7 +1179,17 @@ .eq(Approve::getObjType,approveDTO.getObjType()) .eq(Approve::getLevel,approve.getLevel()) .eq(Approve::getStatus,Constants.ONE) + .eq(Approve::getType,Constants.ZERO) .ne(Approve::getId,approve.getId()) + ); + //涓氬姟鏁版嵁涓嬮厤缃殑鎵�鏈夋妱閫佽褰� + List<Approve> approveCopyList = approveJoinMapper.selectJoinList(Approve.class, + new MPJLambdaWrapper<Approve>() + .selectAll(Approve.class) + .eq(Approve::getIsdeleted,Constants.ZERO) + .eq(Approve::getObjId,approveDTO.getObjId()) + .eq(Approve::getObjType,approveDTO.getObjType()) + .eq(Approve::getType,Constants.ONE) ); //澶勭悊鏈瀹℃壒鐨勪笟鍔℃暟鎹� approveMapper.updateById(approve); @@ -567,121 +1197,459 @@ Boolean dealBusinessBean = false; //瀹℃壒椹冲洖鎯呭喌 if(approveDTO.getStatus().equals(Constants.THREE)){ + dealBusinessBean = true; //淇敼鍏朵粬鎵�鏈夊緟瀹℃壒鍜屽鎵逛腑璁板綍鏁版嵁 approveJoinMapper.update(null,new UpdateWrapper<Approve>() .lambda() .set(Approve::getStatus,Constants.approveStatus.otherUnPass) + .set(Approve::getCheckDate,new Date()) .in(Approve::getStatus,Constants.approveStatus.auditIng,Constants.approveStatus.wait) .eq(Approve::getObjId,approve.getObjId()) .eq(Approve::getObjType,approve.getObjType()) .ne(Approve::getId,approve.getId())); + //澶勭悊鎵�鏈塏otice閫氱煡涓哄凡澶勭悊 + //淇敼鑷繁鐨勯�氱煡璁板綍 + noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() + .set(Notices::getEditDate,new Date()) + .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId()) + .set(Notices::getInfo,"宸叉嫆缁�") + .set(Notices::getReaded,Constants.ONE) + .set(Notices::getParam2,Constants.TWO) + .set(Notices::getStatus,Constants.ONE) + .eq(Notices::getId,notices.getId()) + ); + //淇敼 鏈鐞嗙殑 閫氱煡鏁版嵁 涓烘妱閫� + if (!Constants.equalsInteger(approve.getApproveType(),Constants.TWO)){ + noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() + .set(Notices::getEditDate,new Date()) + .set(Notices::getSendacopy,Constants.ONE) + .set(Notices::getStatus,Constants.ONE) + .set(Notices::getParam2,Constants.TWO) + .set(Notices::getInfo,"宸叉嫆缁�") + .eq(Notices::getObjId,notices.getObjId()) + .eq(Notices::getObjType,notices.getObjType()) + .eq(Notices::getReaded,Constants.ZERO) + .ne(Notices::getId,notices.getId()) + ); + } }else{ //澶勭悊鍏朵粬涓氬姟鏁版嵁 - if(approve.getApproveType().equals(Constants.ZERO)&&approve.getIsEndCheck()==Constants.ONE){ - //鎴栫 涓� 缁堝 - approveJoinMapper.update(null,new UpdateWrapper<Approve>() - .lambda() - .set(Approve::getStatus,Constants.approveStatus.otherDeal) - .in(Approve::getId,approveList.stream().map(m->m.getId()).collect(Collectors.toList()))); + if((Constants.equalsInteger(approve.getApproveType(),Constants.ZERO) + || Constants.equalsInteger( approve.getApproveType(),Constants.TWO)) && Constants.equalsInteger(approve.getIsEndCheck(),Constants.ONE)){ + //鎴栫 / 鍗曚汉瀹� 涓� 缁堝 + if(CollectionUtils.isNotEmpty(approveList)){ + approveJoinMapper.update(null,new UpdateWrapper<Approve>() + .lambda() + .set(Approve::getStatus,Constants.approveStatus.otherDeal) + .set(Approve::getCheckDate,new Date()) + .in(Approve::getId,approveList.stream().map(m->m.getId()).collect(Collectors.toList()))); + } dealBusinessBean = true; - - }else if(approve.getApproveType().equals(Constants.ZERO)&&approve.getIsEndCheck()!=Constants.ONE){ - //鎴栫 闈炵粓瀹� 鍒欏紑鍚笅涓�姝ヤ笟鍔℃祦绋� + }else if((approve.getApproveType().equals(Constants.ZERO) + || approve.getApproveType().equals(Constants.TWO)) &&approve.getIsEndCheck()!=Constants.ONE){ + //鎴栫 / 鍗曚汉瀹� 闈炵粓瀹� 鍒欏紑鍚笅涓�姝ヤ笟鍔℃祦绋� /**澶勭悊鏈骇鏁版嵁**/ - approveJoinMapper.update(null,new UpdateWrapper<Approve>() - .lambda() - .set(Approve::getStatus,Constants.approveStatus.otherDeal) - .in(Approve::getId,approveList.stream().map(m->m.getId()).collect(Collectors.toList()))); + if(CollectionUtils.isNotEmpty(approveList)){ + approveJoinMapper.update(null,new UpdateWrapper<Approve>() + .lambda() + .set(Approve::getStatus,Constants.approveStatus.otherDeal) + .set(Approve::getCheckDate,new Date()) + .in(Approve::getId,approveList.stream().map(m->m.getId()).collect(Collectors.toList()))); + } /**寮�鍚笅涓�绾у埆鐨勬暟鎹负寰呭鏍�**/ + + List<Approve> waitAuditList = approveJoinMapper.selectJoinList(Approve.class, + new MPJLambdaWrapper<Approve>() + .selectAll(Approve.class) + .selectAs(Member::getPhone,Approve::getMemberPhone) + .leftJoin(Member.class,Member::getId,Approve::getChekorId) + .eq(Approve::getStatus,Constants.approveStatus.wait) + .eq(Approve::getObjId,approve.getObjId()) + .eq(Approve::getObjType,approve.getObjType()) + .eq(Approve::getLevel,(approve.getLevel()+1))); + approveJoinMapper.update(null,new UpdateWrapper<Approve>() .lambda() .set(Approve::getStatus,Constants.approveStatus.auditIng) + .set(Approve::getTitle,"瀹℃壒浜�") + .set(Approve::getCheckDate,new Date()) .eq(Approve::getStatus,Constants.approveStatus.wait) .eq(Approve::getObjId,approve.getObjId()) .eq(Approve::getObjType,approve.getObjType()) .eq(Approve::getLevel,(approve.getLevel()+1)) ); + //鍙戦�佺煭淇¢�氱煡 涓嬬骇瀹℃壒浜� - }else if(approve.getApproveType().equals(Constants.ONE)&&approve.getIsEndCheck()==Constants.ONE){ - //浼氱 涓旂粓瀹� - if(approveList.size()==Constants.ZERO){ + + List<String> memberPhone = waitAuditList.stream().filter(i->StringUtils.isNotBlank(i.getMemberPhone())).map(i->i.getMemberPhone()).collect(Collectors.toList()); + if(approveDTO.getObjType().equals(Constants.approveObjectType.reason)){ + SmsEmailServiceImpl.sendPlatformBookSms(systemDictDataBiz, + emayService,smsEmailMapper,smsConfigMapper,platformBooksMapper,approveDTO.getObjId(), + SmsConstants.platformBookContent.platformBookWaitAudit, + approveDTO.getCheckInfo(),memberPhone + ); + } + + + + + if(approveDTO.getObjType().equals(Constants.approveObjectType.unConstructionVisit) + ||approveDTO.getObjType().equals(Constants.approveObjectType.constructionVisit) + ||approveDTO.getObjType().equals(Constants.approveObjectType.visitReporting)) { + Visits visits = visitsMapper.selectById(approve.getObjId()); + if(Objects.nonNull(visits)){ + if(Constants.equalsInteger(visits.getStatus(),Constants.ZERO)){ + visitsMapper.update(null,new UpdateWrapper<Visits>().lambda().set(Visits::getStatus,Constants.ONE).eq(Visits::getId,visits.getId())); + } + } + }else if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals( + Constants.approveObjectType.unCityUseCar)){ + this.updDriver(approveDTO,approve,false); + } + }else if(approve.getApproveType().equals(Constants.ONE)){ + //浼氱 涓旂粓瀹� + //鏃犱粬浜哄鎵圭殑鎯呭喌 鍒欎慨鏀规暟鎹姸鎬� + if(Constants.equalsInteger(approveList.size(),Constants.ZERO)&&Constants.equalsInteger(approve.getIsEndCheck(),Constants.ONE)){ dealBusinessBean = true; + }else{ + if(Constants.equalsInteger(approveList.size(),Constants.ZERO)&&Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)){ + /**寮�鍚笅涓�绾у埆鐨勬暟鎹负寰呭鏍�**/ + approveJoinMapper.update(null,new UpdateWrapper<Approve>() + .lambda() + .set(Approve::getStatus,Constants.approveStatus.auditIng) + .set(Approve::getTitle,"瀹℃壒浜�") + .set(Approve::getCheckDate,new Date()) + .eq(Approve::getStatus,Constants.approveStatus.wait) + .eq(Approve::getObjId,approve.getObjId()) + .eq(Approve::getObjType,approve.getObjType()) + .eq(Approve::getLevel,(approve.getLevel()+1)) + ); + } + if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals( + Constants.approveObjectType.unCityUseCar)){ + this.updDriver(approveDTO,approve,false); + } } } + this.passNextNotices(dealBusinessBean,notices,approve,approveList,approveCopyList,approveDTO); } - - if(approveDTO.getObjType().equals(Constants.approveObjectType.unConstructionVisit) - ||approveDTO.getObjType().equals(Constants.approveObjectType.constructionVisit) - ||approveDTO.getObjType().equals(Constants.approveObjectType.visitReporting)){ - // 璁垮 涓夌被涓氬姟鏁版嵁 - visitsMapper.updateById(visits); - if(dealBusinessBean){ - //TODO 鍙戦�佸鎵归�氳繃娑堟伅 - - }else if(approveDTO.getStatus().equals(Constants.THREE)){ - //TODO 瀹℃壒鏈�氳繃閫氱煡 - - } - - - }else if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals( - Constants.approveObjectType.unCityUseCar)){ - // 甯傚唴澶栫敤杞︾敵璇� - carUseBookMapper.updateById(carUseBook); - if(dealBusinessBean){ - //TODO 鍙戦�佸鎵归�氳繃娑堟伅 - - }else if(approveDTO.getStatus().equals(Constants.THREE)){ - //TODO 瀹℃壒鏈�氳繃閫氱煡 - - } - - - }else if(approveDTO.getObjType().equals(Constants.approveObjectType.logisticsCarUse)){ - //TODO 鐗╂祦杞﹂绾� - + //澶勭悊涓氬姟鏁版嵁 + if(dealBusinessBean){ + this.dealBusinessData(approveDTO,approve); } } - public void dealBusinessData(ApproveDTO approveDTO,Approve approve,Visits visits,CarUseBook carUseBook){ + /** + * 澶勭悊寰呭姙淇℃伅 + * @param dealBusinessBean 鏄惁闇�瑕佽繘琛屾洿鏂颁笟鍔℃暟鎹姸鎬� + * @param approve 瀹℃壒璁板綍 + * @param approveList 鍚岀骇寰呭鎵规暟鎹� + */ + public void passNextNotices(Boolean dealBusinessBean,Notices notices,Approve approve,List<Approve> approveList,List<Approve> copyList,ApproveDTO approveDTO){ + //鏈紑鍚笅涓�绾ф椂锛屾搷浣滃悗鐨勫緟瀹℃壒浜� + String memberNames =notices.getParam5() + .replaceAll(","+notices.getRemark(),"") + .replaceAll(notices.getRemark()+",","") + .replaceAll(notices.getRemark(),""); + + + + //1銆佷慨鏀硅嚜宸辩殑鏁版嵁璁板綍 + noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() + .set(Notices::getEditDate,new Date()) + .set(Notices::getReaded,Constants.ONE) + .set(Notices::getStatus,Constants.ONE) + .set(Notices::getInfo,Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)?"宸查�氳繃":"宸叉嫆缁�") + .set(dealBusinessBean,Notices::getParam2,Constants.ONE) + .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId()) + .eq(Notices::getId,notices.getId()) + ); + if(Constants.equalsInteger(approve.getApproveType(),Constants.ZERO)){ + //鎴栫 + //2銆佹洿鏂颁粬浜虹殑鍚岀骇璁板綍 涓烘妱閫� 骞舵洿鏂� info 淇℃伅 + noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() + .set(Notices::getEditDate,new Date()) + .set(Notices::getReaded,Constants.ZERO) + .set(Notices::getSendacopy,Constants.ONE) + .set(Notices::getStatus,Constants.ONE) + .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId()) + .set(dealBusinessBean,Notices::getParam2,Constants.ONE) + .eq(Notices::getObjId,notices.getObjId()) + .eq(Notices::getStatus,Constants.ZERO) + .eq(Notices::getObjType,notices.getObjType()) + .ne(Notices::getId,notices.getId()) + ); + //3銆佸鏋滀笉鏄粓瀹$敓鎴愪笅涓�绾х殑鏁版嵁璁板綍 + if(Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)&&!dealBusinessBean){ + memberNames = this.saveNextNotice(notices,approve); + } + }else if(Constants.equalsInteger(approve.getApproveType(),Constants.ONE)){ + //浼氱 + //2銆佸鏋滄槸鏈�鍚庝竴浣嶅鎵逛汉 涓斾笉鏄粓瀹″紑鍚笅涓�绾ф暟鎹� + if(Constants.equalsInteger(Constants.ZERO,approveList.size())){ + if(Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)){ + memberNames = this.saveNextNotice(notices,approve); + } + } + }else{ + //鍗曚汉绛� + //2銆� 鏄惁鏄粓瀹� 寮�鍚笅涓�绾ф暟鎹� + if(Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)){ + memberNames = this.saveNextNotice(notices,approve); + } + } + String info = ""; + List<String> memberNameList = Arrays.asList(memberNames.split(",")); + if(Constants.equalsInteger(memberNameList.size(),Constants.ONE)){ + info = "寰�"+memberNameList.get(0)+"澶勭悊涓�"; + }else{ + info = "寰�"+memberNameList.get(0)+"绛�"+memberNameList.size()+"浜哄鐞嗕腑"; + } + //鏇存柊璇ヤ笟鍔℃暟鎹殑鎵�鏈夎褰曚俊鎭� + noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() + .set(!dealBusinessBean,Notices::getInfo,info) + .set(dealBusinessBean,Notices::getInfo,"宸查�氳繃") + .set(Notices::getParam5,memberNames) + .eq(Notices::getObjId,notices.getObjId()) + .eq(Notices::getObjType,notices.getObjType())); + + //缁堝涓氬姟 涓� 澶勭悊鏁版嵁 杩涜鎶勯�佸彂閫� + if (Constants.equalsInteger(approve.getIsEndCheck(),Constants.ONE) && dealBusinessBean) { + if(CollectionUtils.isNotEmpty(copyList)){ + for (Approve copyApprove:copyList) { + Notices copyNotices = new Notices(); + BeanUtils.copyProperties(notices,copyNotices); + copyNotices.setId(null); + copyNotices.setCreateDate(new Date()); + copyNotices.setEditDate(new Date()); + copyNotices.setParam2("2"); + copyNotices.setParam3(""); + copyNotices.setInfo("宸查�氳繃"); + copyNotices.setUserId(copyApprove.getChekorId()); + copyNotices.setStatus(Constants.ZERO); + copyNotices.setSendacopy(Constants.ONE); + copyNotices.setReaded(Constants.ZERO); + noticesJoinMapper.insert(copyNotices); + } + } + } + } + + + + public String saveNextNotice(Notices notices,Approve approve){ + List<Approve> nextApproveList = approveJoinMapper.selectJoinList(Approve.class,new MPJLambdaWrapper<Approve>() + .selectAll(Approve.class) + .selectAs(Member::getName,Approve::getMemberName) + .leftJoin(Member.class,Member::getId,Approve::getChekorId) + .eq(Approve::getObjId,approve.getObjId()) + .eq(Approve::getObjType,approve.getObjType()) + .eq(Approve::getType,Constants.ZERO) + .eq(Approve::getLevel,(approve.getLevel() + Constants.ONE)) + ); + if(CollectionUtils.isEmpty(nextApproveList)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴佹暟鎹紓甯�"); + } + List<String> memberNameList =nextApproveList.stream().map(m->m.getMemberName()).collect(Collectors.toList()); + String memberNames = String.join(",",memberNameList); + for (Approve nextDealApprove:nextApproveList) { + Notices newNotices = new Notices(); + BeanUtils.copyProperties(notices,newNotices); + newNotices.setId(null); + newNotices.setCreateDate(new Date()); + newNotices.setParam2("0"); + newNotices.setParam3(""); + newNotices.setEditDate(new Date()); + newNotices.setUserId(nextDealApprove.getChekorId()); + newNotices.setStatus(Constants.ZERO); + newNotices.setSendacopy(Constants.ZERO); + newNotices.setReaded(Constants.ZERO); + notices.setParam5(memberNames); + notices.setRemark(nextDealApprove.getMemberName()); + if(Constants.equalsInteger(memberNameList.size(),Constants.ONE)){ + notices.setInfo("寰�"+memberNameList.get(0)+"澶勭悊涓�"); + }else{ + notices.setInfo("寰�"+memberNameList.get(0)+"绛�"+memberNameList.size()+"浜哄鐞嗕腑"); + } + noticesJoinMapper.insert(newNotices); + } + return memberNames; + } + + + + public void dealBusinessData(ApproveDTO approveDTO,Approve approve){ if(approveDTO.getObjType().equals(Constants.approveObjectType.unConstructionVisit) ||approveDTO.getObjType().equals(Constants.approveObjectType.constructionVisit) ||approveDTO.getObjType().equals(Constants.approveObjectType.visitReporting)){ // 璁垮 涓夌被涓氬姟鏁版嵁 - visits = visitsMapper.selectById(approveDTO.getObjId()); + Visits visits = visitsMapper.selectById(approveDTO.getObjId()); if(Objects.isNull(visits)){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鐢宠璁板綍"); } visits.setStatus(approveDTO.getStatus()); visits.setEditDate(new Date()); visits.setEditor(approveDTO.getLoginUserInfo().getMemberId()); + //涓嬪彂璁垮鎶ュ杞﹁締淇℃伅 + if(Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)&&approveDTO.getObjType().equals(Constants.approveObjectType.visitReporting)){ + Boolean sendStatus = true; + //鏌ヨ褰撳墠鍚敤鐨勫仠杞﹀満 + List<Parks> parksList = parksMapper.selectList(new QueryWrapper<Parks>() + .lambda() + .isNotNull(Parks::getHkId) + .eq(Parks::getIsdeleted,Constants.ZERO)); + List<VisitPark> parkBookList = new ArrayList<>(); + if(CollectionUtils.isNotEmpty(parksList)){ + for (Parks parks:parksList) { + VisitPark visitPark = new VisitPark(); + visitPark.setIsdeleted(Constants.ZERO); + visitPark.setCreateDate(new Date()); + visitPark.setVisitApplyId(visits.getId().toString()); + visitPark.setCarCode(visits.getCarNos()); + visitPark.setParkId(parks.getId().toString()); + visitPark.setStartTime(visits.getStarttime()); + visitPark.setEndTime(visits.getEndtime()); + visitPark.setParkHkId(parks.getHkId()); + visitPark.setObjType(Constants.ZERO); + ParkReservationAddRequest request = new ParkReservationAddRequest(); + request.setPlateNo(visitPark.getCarCode()); + request.setParkSyscode(visitPark.getParkHkId()); + request.setPhoneNo(visits.getPhone()); + request.setOwner(visits.getName()); + request.setAllowTimes(Constants.ONE+""); + request.setIsCharge(Constants.ONE+""); + request.setStartTime(Objects.isNull(visitPark.getStartTime())?DateUtil.getISO8601Timestamp2(new Date()):DateUtil.getISO8601Timestamp2(visitPark.getStartTime())); + request.setEndTime(Objects.isNull(visitPark.getEndTime())?"2999-12-31T00:00:00+08:00":DateUtil.getISO8601Timestamp2(visitPark.getEndTime())); + BaseResponse response = HKService.parkReservationAddition(request); + visitPark.setHkDate(new Date()); + if(response!=null + && StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ + ParkReservationAddResponse parkReservationAddResponse = (ParkReservationAddResponse) response.getData(); + visitPark.setHkId(parkReservationAddResponse.getReserveOrderNo()); + visitPark.setHkStatus(Constants.ONE); + visitPark.setRemark("鍖呮湡鎴愬姛"); + }else{ + visitPark.setHkStatus(Constants.TWO); + visitPark.setRemark("鍖呮湡澶辫触~"); + //涓嬪彂澶辫触 鏍囪涓讳笟鍔$姸鎬佷负涓嬪彂澶辫触 + sendStatus = false; + } + parkBookList.add(visitPark); + + } + visitParkMapper.insert(parkBookList); + } + if(sendStatus){ + visits.setStatus(Constants.VisitStatus.xfSuccess); + }else{ + visits.setStatus(Constants.VisitStatus.xfFail); + } + } + + visitsMapper.updateById(visits); }else if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals( Constants.approveObjectType.unCityUseCar)){ - // 甯傚唴澶栫敤杞︾敵璇� - carUseBook = carUseBookMapper.selectById(approveDTO.getObjId()); - if(Objects.isNull(carUseBook)){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌鐢ㄨ溅璁板綍"); + this.updDriver(approveDTO,approve,true); + }else if(approveDTO.getObjType().equals(Constants.approveObjectType.reason)){ + //鐗╂祦杞﹂绾� + PlatformBooks platformBooks = platformBooksMapper.selectById(approveDTO.getObjId()); + if(Objects.isNull(platformBooks)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鐗╂祦杞﹂绾﹁褰�"); } - carUseBook.setStatus(approveDTO.getStatus()); - carUseBook.setEditDate(new Date()); - carUseBook.setEditor(approveDTO.getLoginUserInfo().getMemberId()); - //濡傛灉閰嶇疆淇敼鍙告満 涓� 鍏ュ弬浜嗘洿鎹㈠悗鍙告満淇℃伅 - if(approveDTO.getStatus()==Constants.TWO&&approve.getDriverParam().equals(Constants.ONE)){ - CarDriver carDriver = carDriverMapper.selectById(approveDTO.getDriverId()); - if(Objects.isNull(carDriver)){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌鍙告満淇℃伅"); + platformBooks.setStatus(approveDTO.getStatus()); + platformBooks.setEditDate(new Date()); + platformBooks.setEditor(approveDTO.getLoginUserInfo().getMemberId()); + if(Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)){ + PlatformReason platformReason = platformReasonMapper.selectById(platformBooks.getReasonId()); + if(Objects.isNull(platformReason)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鍏ュ洯鍘熷洜鏁版嵁"); } - carUseBook.setDriverId(carDriver.getId()); - } + PlatformGroup platformGroup = platformGroupMapper.selectById(platformReason.getGroupId()); + if(Objects.isNull(platformGroup)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鍏ュ洯鍘熷洜閰嶇疆鏈堝彴缁勬暟鎹�"); + } - }else if(approveDTO.getObjType().equals(Constants.approveObjectType.logisticsCarUse)){ - //TODO 鐗╂祦杞﹂绾� + //鐢熸垚浠诲姟璁板綍 + PlatformJob platformJob = platformBooks.toPlatformJob(); + platformJob.setId(null); + platformJob.setPlatformGroupId(platformReason.getGroupId().intValue()); + if(Constants.equalsInteger(platformGroup.getType(),Constants.ZERO)){ + platformJob.setType(Constants.platformJobType.wxcxh); + }else if(Constants.equalsInteger(platformGroup.getType(),Constants.ONE)){ + platformJob.setType(Constants.platformJobType.wxczh); + }else{ + platformJob.setType(Constants.platformJobType.sgscxh); + } + platformJob.setStatus(Constants.PlatformJobStatus.WART_SIGN_IN.getKey()); + platformJobMapper.insert(platformJob); + platformBooks.setJobId(platformJob.getId()); + platformBooksMapper.updateById(platformBooks); + //鐢熸垚浠诲姟鎿嶄綔璁板綍 + PlatformLog platformLog = new PlatformLog(); + platformLog.setCreateDate(new Date()); + platformLog.setJobId(platformJob.getId()); + platformLog.setIsdeleted(Constants.ZERO); + platformLog.setParam4(platformJob.getCarCodeFront()); + platformLog.setContent(Constants.PlatformJobLogType.CREATE.getInfo()); + platformLog.setObjType(Constants.PlatformJobLogType.CREATE.getKey()); + platformLog.setObjId(platformJob.getId().toString()); + platformLog.setAfterContent(JSONObject.toJSONString(platformJob)); + platformLogMapper.insert(platformLog); + } + //鍙戦�佺煭淇¢�氱煡 + SmsEmailServiceImpl.sendPlatformBookSms(systemDictDataBiz, + emayService,smsEmailMapper,smsConfigMapper,platformBooksMapper,platformBooks.getId(), + Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)?SmsConstants.platformBookContent.platformBookAuditSuccess: + SmsConstants.platformBookContent.platformBookAuditFail, + approveDTO.getCheckInfo(),null + ); + + //TODO 鍙戦�佸井淇″叕浼楀彿娑堟伅 }else{ throw new BusinessException(ResponseStatus.BAD_REQUEST); } + if(Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)){ + //澶勭悊閫氳繃 鏄剧ず鎵�鏈夌殑鎶勯�佽褰� + approveMapper.update(null,new UpdateWrapper<Approve>().lambda().set(Approve::getStatus,Constants.TWO) + .set(Approve::getCheckDate,new Date()) + .eq(Approve::getObjId,approve.getObjId()) + .eq(Approve::getObjType,approve.getObjType()) + .eq(Approve::getType,Constants.ONE) + ); + } + } + + + public void updDriver(ApproveDTO approveDTO,Approve approve,Boolean dealBusinessBean){ + // 甯傚唴澶栫敤杞︾敵璇� + CarUseBook carUseBook = carUseBookMapper.selectById(approveDTO.getObjId()); + if(Objects.isNull(carUseBook)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌鐢ㄨ溅璁板綍"); + } + if(dealBusinessBean){ + carUseBook.setStatus(approveDTO.getStatus()); + }else{ + if(Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)){ + carUseBook.setStatus(Constants.ONE); + } + } + carUseBook.setEditDate(new Date()); + carUseBook.setEditor(approveDTO.getLoginUserInfo().getMemberId()); + //濡傛灉閰嶇疆淇敼鍙告満 涓� 鍏ュ弬浜嗘洿鎹㈠悗鍙告満淇℃伅 + if(approveDTO.getStatus()==Constants.TWO&&Constants.equalsInteger(approve.getDriverParam(),Constants.ONE)){ + CarDriver carDriver = carDriverMapper.selectOne(new QueryWrapper<CarDriver>().lambda() + .eq(CarDriver::getIsdeleted,Constants.ZERO) + .eq(CarDriver::getStatus,Constants.ZERO) + .eq(CarDriver::getMemberId,approveDTO.getDriverId())); + if(Objects.isNull(carDriver)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌鍙告満淇℃伅"); + } + carUseBook.setDriverId(carDriver.getMemberId()); + } + carUseBookMapper.updateById(carUseBook); } -- Gitblit v1.9.3