|  |  |  | 
|---|
|  |  |  | 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.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.system.NoticesService; | 
|---|
|  |  |  | import com.github.xiaoymin.knife4j.core.util.CollectionUtils; | 
|---|
|  |  |  | import com.github.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import io.swagger.models.auth.In; | 
|---|
|  |  |  | import javafx.application.Platform; | 
|---|
|  |  |  | 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.Bean; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private PlatformReasonMapper platformReasonMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ParksMapper parksMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ParkBookMapper parkBookMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private VisitParkMapper visitParkMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | 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() | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | 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 = "【访客申请】申请人 - "; | 
|---|
|  |  |  | String title = "[访客申请]申请人-"; | 
|---|
|  |  |  | Map<String,Object> jsonMap = new HashMap<>(); | 
|---|
|  |  |  | for (int j = 0; j < memberList.size(); j++) { | 
|---|
|  |  |  | Member member = memberList.get(j); | 
|---|
|  |  |  | 
|---|
|  |  |  | approve.setChekorId(memberId); | 
|---|
|  |  |  | approve.setStatus(i==0?Constants.ONE:Constants.ZERO); | 
|---|
|  |  |  | approve.setStatusInfo(i==0?"审批中":"处理中"); | 
|---|
|  |  |  | approve.setTitle("审批人"); | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(Constants.equalsInteger(noticeType,Constants.noticesObjectType.visit)){ | 
|---|
|  |  |  | title = title + visits.getName(); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | title = "【访客报备】申请人 - " + visits.getName(); | 
|---|
|  |  |  | title = "[访客报备]申请人-" + visits.getName(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | jsonMap.put("name", "访问人:" + visits.getCompanyName() + " - " + visits.getReceptMemberName()); | 
|---|
|  |  |  | jsonMap.put("sTime", "入园时间:" + DateUtil.DateToStr(visits.getStarttime() , "yyyy-MM-dd HH:mm")); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(Objects.isNull(carUseBook)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"未查询到业务数据信息"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | title = "【用车申请】申请人 - " + carUseBook.getMemberName(); | 
|---|
|  |  |  | 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")); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(Objects.isNull(platformBooks)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"未查询到业务数据信息"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | title = "【物流车入园预约】申请人 - " + platformBooks.getDriverName(); | 
|---|
|  |  |  | 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")); | 
|---|
|  |  |  | 
|---|
|  |  |  | Approve waitModel = new Approve(); | 
|---|
|  |  |  | waitModel.setApproveType(Constants.ZERO); | 
|---|
|  |  |  | if(Constants.equalsInteger(level.getStatus(),Constants.approveStatus.pass)){ | 
|---|
|  |  |  | waitModel.setStatus(Constants.approveStatus.pass); | 
|---|
|  |  |  | waitModel.setStatus(level.getStatus()); | 
|---|
|  |  |  | waitModel.setType(Constants.ONE); | 
|---|
|  |  |  | waitModel.setTitle("审批人(抄送或签审批人)"); | 
|---|
|  |  |  | waitModel.setCheckDate(level.getCheckDate()); | 
|---|
|  |  |  | waitModel.setTitle(StringUtils.defaultString(level.getTitle(),"审批人")); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | waitModel.setStatus(passList.size()>0?Constants.ONE:Constants.ZERO); | 
|---|
|  |  |  | 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(),"审批人"):"抄送或签审批人"); | 
|---|
|  |  |  | 
|---|
|  |  |  | waitModel.setMemberName(waitList.size() +"人或签"); | 
|---|
|  |  |  | waitModel.setStatusInfo("待处理"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | waitModel.setMemberName(waitList.size() +"人或签"); | 
|---|
|  |  |  | waitModel.setStatusInfo("处理中"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | waitModel.setApproveList(approveList); | 
|---|
|  |  |  | 
|---|
|  |  |  | noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() | 
|---|
|  |  |  | .set(Notices::getEditDate,new Date()) | 
|---|
|  |  |  | .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId()) | 
|---|
|  |  |  | .set(Notices::getInfo,"审批未通过") | 
|---|
|  |  |  | .set(Notices::getInfo,"已拒绝") | 
|---|
|  |  |  | .set(Notices::getReaded,Constants.ONE) | 
|---|
|  |  |  | .set(Notices::getParam2,Constants.TWO) | 
|---|
|  |  |  | .set(Notices::getStatus,Constants.ONE) | 
|---|
|  |  |  | 
|---|
|  |  |  | .set(Notices::getSendacopy,Constants.ONE) | 
|---|
|  |  |  | .set(Notices::getStatus,Constants.ONE) | 
|---|
|  |  |  | .set(Notices::getParam2,Constants.TWO) | 
|---|
|  |  |  | .set(Notices::getInfo,"审批未通过") | 
|---|
|  |  |  | .set(Notices::getInfo,"已拒绝") | 
|---|
|  |  |  | .eq(Notices::getObjId,notices.getObjId()) | 
|---|
|  |  |  | .eq(Notices::getObjType,notices.getObjType()) | 
|---|
|  |  |  | .eq(Notices::getReaded,Constants.ZERO) | 
|---|
|  |  |  | 
|---|
|  |  |  | .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()) | 
|---|
|  |  |  | 
|---|
|  |  |  | //更新该业务数据的所有记录信息 | 
|---|
|  |  |  | noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() | 
|---|
|  |  |  | .set(!dealBusinessBean,Notices::getInfo,info) | 
|---|
|  |  |  | .set(dealBusinessBean,Notices::getInfo,"审批通过") | 
|---|
|  |  |  | .set(dealBusinessBean,Notices::getInfo,"已通过") | 
|---|
|  |  |  | .set(Notices::getParam5,memberNames) | 
|---|
|  |  |  | .eq(Notices::getObjId,notices.getObjId()) | 
|---|
|  |  |  | .eq(Notices::getObjType,notices.getObjType())); | 
|---|
|  |  |  | 
|---|
|  |  |  | copyNotices.setEditDate(new Date()); | 
|---|
|  |  |  | copyNotices.setParam2("2"); | 
|---|
|  |  |  | copyNotices.setParam3(""); | 
|---|
|  |  |  | copyNotices.setInfo("审批通过"); | 
|---|
|  |  |  | copyNotices.setInfo("已通过"); | 
|---|
|  |  |  | copyNotices.setUserId(copyApprove.getChekorId()); | 
|---|
|  |  |  | copyNotices.setStatus(Constants.ZERO); | 
|---|
|  |  |  | copyNotices.setSendacopy(Constants.ONE); | 
|---|
|  |  |  | 
|---|
|  |  |  | return memberNames; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public void dealBusinessData(ApproveDTO approveDTO,Approve approve){ | 
|---|
|  |  |  | if(approveDTO.getObjType().equals(Constants.approveObjectType.unConstructionVisit) | 
|---|
|  |  |  | ||approveDTO.getObjType().equals(Constants.approveObjectType.constructionVisit) | 
|---|
|  |  |  | 
|---|
|  |  |  | visits.setStatus(approveDTO.getStatus()); | 
|---|
|  |  |  | visits.setEditDate(new Date()); | 
|---|
|  |  |  | visits.setEditor(approveDTO.getLoginUserInfo().getMemberId()); | 
|---|
|  |  |  | visitsMapper.updateById(visits); | 
|---|
|  |  |  | //下发访客报备车辆信息 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(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)){ | 
|---|
|  |  |  | this.updDriver(approveDTO,approve,true); | 
|---|