|  |  |  | 
|---|
|  |  |  | 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.model.LoginUserInfo; | 
|---|
|  |  |  | import com.doumee.core.model.PageData; | 
|---|
|  |  |  | import com.doumee.core.model.PageWrap; | 
|---|
|  |  |  | import com.doumee.core.utils.Constants; | 
|---|
|  |  |  | import com.doumee.core.utils.DESUtil; | 
|---|
|  |  |  | import com.doumee.core.utils.DateUtil; | 
|---|
|  |  |  | import com.doumee.core.utils.Utils; | 
|---|
|  |  |  | import com.doumee.dao.business.dao.UserActionMapper; | 
|---|
|  |  |  | import com.doumee.service.business.third.model.LoginUserInfo; | 
|---|
|  |  |  | import com.doumee.service.business.third.model.PageData; | 
|---|
|  |  |  | import com.doumee.service.business.third.model.PageWrap; | 
|---|
|  |  |  | import com.doumee.core.utils.*; | 
|---|
|  |  |  | import com.doumee.core.wx.wxPlat.WxPlatConstants; | 
|---|
|  |  |  | import com.doumee.core.wx.wxPlat.WxPlatNotice; | 
|---|
|  |  |  | import com.doumee.dao.business.*; | 
|---|
|  |  |  | import com.doumee.dao.business.dao.MemberMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.dao.SmsConfigMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.dao.SmsEmailMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.ApproveJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.CarUseBookJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.model.*; | 
|---|
|  |  |  | import com.doumee.dao.business.vo.ApproveDataVO; | 
|---|
|  |  |  | import com.doumee.dao.business.vo.DateIntervalVO; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.doumee.dao.business.model.Member; | 
|---|
|  |  |  | import com.doumee.dao.system.SystemUserMapper; | 
|---|
|  |  |  | import com.doumee.dao.system.join.NoticesJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.system.model.Notices; | 
|---|
|  |  |  | import com.doumee.dao.system.model.SystemDictData; | 
|---|
|  |  |  | import com.doumee.dao.system.model.SystemUser; | 
|---|
|  |  |  | import com.doumee.service.business.ApproveService; | 
|---|
|  |  |  | 
|---|
|  |  |  | 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.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import io.swagger.annotations.ApiModelProperty; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  | import org.checkerframework.checker.units.qual.C; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.time.ZoneId; | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.time.temporal.ChronoUnit; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Objects; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 车辆_用车申请信息表Service实现 | 
|---|
|  |  |  | 
|---|
|  |  |  | private CarUseBookMapper carUseBookMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private UserActionMapper userActionMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private CarUseBookJoinMapper carUseBookJoinMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | 
|---|
|  |  |  | private ApproveJoinMapper approveJoinMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private NoticesJoinMapper noticesJoinMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ApproveService approveService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MemberMapper memberMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SmsConfigMapper smsConfigMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SmsEmailMapper smsEmailMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private EmayService emayService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WxNoticeConfigMapper wxNoticeConfigMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SystemUserMapper systemUserMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = {Exception.class,BusinessException.class}) | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前登录用户无法进行该操作!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(carUseBook.getEndTime().getTime()<=System.currentTimeMillis()){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"选择日期异常[结束时间小于当前时间],请刷新重试"); | 
|---|
|  |  |  | //            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"选择日期异常[结束时间小于当前时间],请刷新重试"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(!(DateUtil.getDateFromString(carUseBook.getPlanUseDate()+":00").getTime()>=carUseBook.getStartTime().getTime() | 
|---|
|  |  |  | && DateUtil.getDateFromString(carUseBook.getPlanUseDate() +":00").getTime()<= carUseBook.getEndTime().getTime()) | 
|---|
|  |  |  | 
|---|
|  |  |  | carUseBook.setCreateDate(new Date()); | 
|---|
|  |  |  | carUseBook.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | Cars cars = carsMapper.selectById(carUseBook.getCarId()); | 
|---|
|  |  |  | if(Objects.isNull(cars)||!cars.getType().equals(Constants.ONE)){ | 
|---|
|  |  |  | if(Objects.isNull(cars)||!cars.getType().equals(Constants.ZERO)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"车辆信息异常"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | carUseBook.setCarCode(cars.getCode()); | 
|---|
|  |  |  | 
|---|
|  |  |  | CarDriver carDriver = carDriverMapper.selectOne(new QueryWrapper<CarDriver>().lambda() | 
|---|
|  |  |  | .eq(CarDriver::getCarId,cars.getId()) | 
|---|
|  |  |  | .eq(CarDriver::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(CarDriver::getStatus,Constants.ONE) | 
|---|
|  |  |  | //                .eq(CarDriver::getStatus,Constants.ZERO) | 
|---|
|  |  |  | .last( " limit 1 ") | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if(Objects.nonNull(carDriver)&&Objects.nonNull(carDriver.getMemberId())){ | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | carUseBookMapper.insert(carUseBook); | 
|---|
|  |  |  | //用车申请 审批记录创建 | 
|---|
|  |  |  | approveService.createApproveFlow(carUseBook.getType()==0?3:4,carUseBook.getId(),carUseBook.getMemberId()); | 
|---|
|  |  |  | approveService.createApproveFlow(carUseBook.getType()==0?3:4,carUseBook.getId(),carUseBook.getMemberId(),null); | 
|---|
|  |  |  | //发送微信公众号通知 | 
|---|
|  |  |  | //发送微信公众号通知 | 
|---|
|  |  |  | WxPlatNotice wxPlatNotice = new WxPlatNotice(); | 
|---|
|  |  |  | SystemUser systemUser = systemUserMapper.selectById(carUseBook.getCreator()); | 
|---|
|  |  |  | if(Objects.nonNull(systemUser) && StringUtils.isNotBlank(systemUser.getOpenid())){ | 
|---|
|  |  |  | carUseBook.setMemberName(systemUser.getRealname()); | 
|---|
|  |  |  | wxPlatNotice.sendCarUseBookTemplateNotice(systemDictDataBiz, | 
|---|
|  |  |  | wxNoticeConfigMapper,carUseBook, | 
|---|
|  |  |  | WxPlatConstants.carUseBookContent.carUseBookUpload, | 
|---|
|  |  |  | systemDictDataBiz.queryByCode(Constants.WX_PLATFORM,Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), | 
|---|
|  |  |  | Arrays.asList(systemUser.getOpenid().split(",")),0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return carUseBook.getId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | public void deleteById(Integer id) { | 
|---|
|  |  |  | carUseBookMapper.deleteById(id); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = {BusinessException.class,Exception.class}) | 
|---|
|  |  |  | public  void deleteById(Integer id,LoginUserInfo user) { | 
|---|
|  |  |  | Date date = new Date(); | 
|---|
|  |  |  | MPJLambdaWrapper<CarUseBook>  queryWrapper = new MPJLambdaWrapper<>(); | 
|---|
|  |  |  | queryWrapper.selectAll(CarUseBook.class); | 
|---|
|  |  |  | queryWrapper.select("t1.name",CarUseBook::getMemberName); | 
|---|
|  |  |  | queryWrapper.leftJoin(Member.class,Member::getId,CarUseBook::getMemberId) | 
|---|
|  |  |  | .eq(CarUseBook::getId,id) | 
|---|
|  |  |  | .eq(CarUseBook::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .last("limit 1"  ); | 
|---|
|  |  |  | CarUseBook model = carUseBookMapper.selectJoinOne(CarUseBook.class,queryWrapper); | 
|---|
|  |  |  | if(model==null ||Constants.equalsInteger(Constants.ONE,model.getIsdeleted())){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | carUseBookMapper.update(null,new UpdateWrapper<CarUseBook>().lambda() | 
|---|
|  |  |  | .set(CarUseBook::getIsdeleted,Constants.ONE) | 
|---|
|  |  |  | .set(CarUseBook::getEditDate,date) | 
|---|
|  |  |  | .set(CarUseBook::getEditor,user.getId()) | 
|---|
|  |  |  | .eq(CarUseBook::getId,id)); | 
|---|
|  |  |  | String[] params = new String[3]; | 
|---|
|  |  |  | params[0] = user.getRealname(); | 
|---|
|  |  |  | params[1]=DateUtil.getPlusTime2(date); | 
|---|
|  |  |  | params[2]=model.getCarCode()+"-【乘车人:"+model.getMemberNames()+" 】-【预约人:"+model.getMemberName()+"】-【时间:"+DateUtil.getPlusTime2(model.getStartTime())+"-"+DateUtil.getPlusTime2(model.getEndTime())+"】"; | 
|---|
|  |  |  | //记录删除日志 | 
|---|
|  |  |  | UserActionServiceImpl.saveUserActionBiz(user,id,Constants.UserActionType.CAR_BOOK_DEL,userActionMapper,date,params, JSONObject.toJSONString(model)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void delete(CarUseBook carUseBook) { | 
|---|
|  |  |  | UpdateWrapper<CarUseBook> deleteWrapper = new UpdateWrapper<>(carUseBook); | 
|---|
|  |  |  | 
|---|
|  |  |  | .leftJoin(Member.class,Member::getId,CarUseBook::getDriverId) | 
|---|
|  |  |  | .leftJoin("company t4 on t1.company_id=t4.id") | 
|---|
|  |  |  | .eq(CarUseBook::getId,id) | 
|---|
|  |  |  | .eq(CarUseBook::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .last("limit 1"  ); | 
|---|
|  |  |  | CarUseBook model = carUseBookMapper.selectJoinOne(CarUseBook.class,queryWrapper); | 
|---|
|  |  |  | if(Objects.isNull(model)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ApproveDataVO approveDataVO = approveService.arrangeApprovedData(id, | 
|---|
|  |  |  | Constants.equalsInteger(model.getType(),Constants.ZERO)?3:4, | 
|---|
|  |  |  | memberId); | 
|---|
|  |  |  | List<Approve> approveList = approveDataVO.getApproveList(); | 
|---|
|  |  |  | model.setApproveDateVO(getApproveDataVO(memberId,model)); | 
|---|
|  |  |  | List<Approve> approveList = model.getApproveDateVO().getApproveList(); | 
|---|
|  |  |  | if(Constants.equalsInteger(model.getStatus(),Constants.FOUR)){ | 
|---|
|  |  |  | String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() | 
|---|
|  |  |  | +systemDictDataBiz.queryByCode(Constants.FTP,Constants.MEMBER_IMG).getCode(); | 
|---|
|  |  |  | 
|---|
|  |  |  | approve.setCheckDate(model.getCancelTime()); | 
|---|
|  |  |  | approveList.add(approve); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | model.setApproveDateVO(approveDataVO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Notices notices = noticesJoinMapper.selectOne(new QueryWrapper<Notices>().lambda() | 
|---|
|  |  |  | .eq(Notices::getObjId,id) | 
|---|
|  |  |  | .eq(Notices::getType,Constants.noticesObjectType.useCar) | 
|---|
|  |  |  | .eq(Notices::getUserId,memberId) | 
|---|
|  |  |  | .eq(Notices::getSendacopy,Constants.ZERO) | 
|---|
|  |  |  | .orderByDesc(Notices::getId).last(" limit 1 ")); | 
|---|
|  |  |  | if(Objects.nonNull(notices)){ | 
|---|
|  |  |  | if(Constants.equalsInteger(notices.getStatus(),Constants.ZERO)){ | 
|---|
|  |  |  | model.setInfo("待我处理"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | model.setInfo(notices.getInfo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return  model; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private ApproveDataVO getApproveDataVO( Integer memberId,CarUseBook model) { | 
|---|
|  |  |  | ApproveDataVO approveDataVO = approveService.arrangeApprovedData(model.getId(), | 
|---|
|  |  |  | Constants.equalsInteger(model.getType(),Constants.ZERO)?3:4, | 
|---|
|  |  |  | memberId); | 
|---|
|  |  |  | return approveDataVO; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | queryWrapper.leftJoin(Member.class,Member::getId,CarUseBook::getMemberId) | 
|---|
|  |  |  | .leftJoin(Member.class,Member::getId,CarUseBook::getDriverId) | 
|---|
|  |  |  | .leftJoin("company t4 on t1.company_id=t4.id"); | 
|---|
|  |  |  | //数据权限开始--------------------start---------------- | 
|---|
|  |  |  | LoginUserInfo userInfo =pageWrap.getModel().getLoginUserInfo(); | 
|---|
|  |  |  | if(userInfo!=null && userInfo.getCompanyIdList()!=null){ | 
|---|
|  |  |  | if( userInfo.getCompanyIdList().size() ==0){ | 
|---|
|  |  |  | //只能看自己 | 
|---|
|  |  |  | queryWrapper.eq(CarUseBook::getCreator,userInfo.getId()); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | queryWrapper.in("t1.company_id" ,userInfo.getCompanyIdList()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //数据权限开始--------------------end---------------- | 
|---|
|  |  |  |  | 
|---|
|  |  |  | queryWrapper | 
|---|
|  |  |  | .eq(pageWrap.getModel().getId() != null, CarUseBook::getId, pageWrap.getModel().getId()) | 
|---|
|  |  |  | .eq(pageWrap.getModel().getCreator() != null, CarUseBook::getCreator, pageWrap.getModel().getCreator()) | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .and(StringUtils.isNotBlank(pageWrap.getModel().getMemberName()), ms->ms.like(Member::getName,pageWrap.getModel().getMemberName()) | 
|---|
|  |  |  | .or().like(Member::getPhone,pageWrap.getModel().getMemberName())) | 
|---|
|  |  |  | .ge(Objects.nonNull(pageWrap.getModel().getQueryStartTime()), CarUseBook::getPlanUseDate,pageWrap.getModel().getQueryStartTime()) | 
|---|
|  |  |  | .le(Objects.nonNull(pageWrap.getModel().getQueryEndTime()),CarUseBook::getPlanUseDate,pageWrap.getModel().getQueryEndTime()) | 
|---|
|  |  |  | .ge(Objects.nonNull(pageWrap.getModel().getQueryStartTime()), CarUseBook::getCreateDate,pageWrap.getModel().getQueryStartTime()) | 
|---|
|  |  |  | .le(Objects.nonNull(pageWrap.getModel().getQueryEndTime()),CarUseBook::getCreateDate,pageWrap.getModel().getQueryEndTime()) | 
|---|
|  |  |  | .orderByDesc(Visits::getCreateDate) | 
|---|
|  |  |  | ; | 
|---|
|  |  |  | for(PageWrap.SortData sortData: pageWrap.getSorts()) { | 
|---|
|  |  |  | 
|---|
|  |  |  | queryWrapper.orderByAsc(sortData.getProperty()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return PageData.from(carUseBookMapper.selectJoinPage(page, CarUseBook.class, queryWrapper)); | 
|---|
|  |  |  | PageData<CarUseBook> result =PageData.from(carUseBookMapper.selectJoinPage(page, CarUseBook.class, queryWrapper)); | 
|---|
|  |  |  | if(result!=null && result.getRecords()!=null){ | 
|---|
|  |  |  | for(CarUseBook carUseBook:result.getRecords()){ | 
|---|
|  |  |  | carUseBook.setHasRole(getHasBackRoleBiz(carUseBook,pageWrap.getModel().getLoginUserInfo())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | .selectAs(Member::getName,CarUseBook::getMemberName) | 
|---|
|  |  |  | .selectAs(Member::getPhone,CarUseBook::getMemberMobile) | 
|---|
|  |  |  | .leftJoin(Member.class,Member::getId,CarUseBook::getMemberId) | 
|---|
|  |  |  | .eq(CarUseBook::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(CarUseBook::getCarId,carUseBook.getCarId()) | 
|---|
|  |  |  | .in(CarUseBook::getStatus,0,1,2) | 
|---|
|  |  |  | .apply(" ( " + | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //判断时间是否大于当前 | 
|---|
|  |  |  | if(Constants.equalsInteger(dateIntervalVO.getIsUse(),Constants.ZERO)  && DateUtil.getDateFromString(dateIntervalVO.getEndTime()).getTime()<=System.currentTimeMillis()){ | 
|---|
|  |  |  | dateIntervalVO.setIsUse(Constants.ONE); | 
|---|
|  |  |  | //                dateIntervalVO.setIsUse(Constants.ONE); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void revoke(Integer id, String info, LoginUserInfo loginUserInfo){ | 
|---|
|  |  |  | CarUseBook carUseBook = carUseBookMapper.selectById(id); | 
|---|
|  |  |  | if(Objects.isNull(carUseBook)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到用车申请信息"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(Objects.isNull(carUseBook) || Constants.equalsInteger(carUseBook.getIsdeleted(),Constants.ONE)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到用车申请信息"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(getHasBackRoleBiz(carUseBook,loginUserInfo) == Constants.ZERO){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,无权限行撤销操作!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | carUseBook.setCancelInfo(info); | 
|---|
|  |  |  | carUseBook.setCancelTime(new Date()); | 
|---|
|  |  |  | carUseBook.setCancelStatus(Constants.ONE); | 
|---|
|  |  |  | 
|---|
|  |  |  | .in(Approve::getObjType,Constants.approveObjectType.cityUseCar,Constants.approveObjectType.unCityUseCar) | 
|---|
|  |  |  | .eq(Approve::getObjId,id) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //处理待办信息 | 
|---|
|  |  |  | noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda() | 
|---|
|  |  |  | .set(Notices::getStatus,Constants.ONE) | 
|---|
|  |  |  | .set(Notices::getInfo,"已取消") | 
|---|
|  |  |  | .eq(Notices::getType,Constants.TWO) | 
|---|
|  |  |  | .eq(Notices::getObjId,carUseBook.getId()) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | SystemUser systemUser = systemUserMapper.selectById(carUseBook.getCreator()); | 
|---|
|  |  |  | if(Objects.nonNull(systemUser)&&StringUtils.isNotBlank(systemUser.getMobile())){ | 
|---|
|  |  |  | //用车申请取消 | 
|---|
|  |  |  | SmsEmailServiceImpl.sendCarUseSms(systemDictDataBiz, | 
|---|
|  |  |  | emayService,smsEmailMapper,smsConfigMapper,carUseBookMapper,carUseBook.getId(), | 
|---|
|  |  |  | SmsConstants.carUseBookContent.carUseBookCancel, | 
|---|
|  |  |  | info, Arrays.asList(systemUser.getMobile().split(",")) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if(StringUtils.isNotBlank(systemUser.getOpenid())){ | 
|---|
|  |  |  | carUseBook.setMemberName(systemUser.getRealname()); | 
|---|
|  |  |  | WxPlatNotice wxPlatNotice = new WxPlatNotice(); | 
|---|
|  |  |  | wxPlatNotice.sendCarUseBookTemplateNotice(systemDictDataBiz, | 
|---|
|  |  |  | wxNoticeConfigMapper, | 
|---|
|  |  |  | carUseBook, | 
|---|
|  |  |  | WxPlatConstants.carUseBookContent.carUseBookCancel, | 
|---|
|  |  |  | systemDictDataBiz.queryByCode(Constants.WX_PLATFORM,Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), | 
|---|
|  |  |  | Arrays.asList(systemUser.getOpenid().split(",")), | 
|---|
|  |  |  | Constants.TWO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 查询当前登陆用户是否具有退回申请的权限 | 
|---|
|  |  |  | * 申请人只能在待审核之前撤销,派车员可以在待审核、审核中、审批通过进行撤销 | 
|---|
|  |  |  | * @param carUseBook | 
|---|
|  |  |  | * @param loginUserInfo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private int getHasBackRoleBiz(CarUseBook carUseBook, LoginUserInfo loginUserInfo) { | 
|---|
|  |  |  | if(Constants.equalsInteger(carUseBook.getCreator(),loginUserInfo.getId()) | 
|---|
|  |  |  | && Constants.equalsInteger(carUseBook.getStatus(),Constants.ZERO)){ | 
|---|
|  |  |  | //申请人可以撤销自己申请中的申请记录 | 
|---|
|  |  |  | return  Constants.ONE; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(Constants.equalsInteger(carUseBook.getStatus(),Constants.TWO) && carUseBook.getStartTime()!=null | 
|---|
|  |  |  | && System.currentTimeMillis() >= carUseBook.getStartTime().getTime()){ | 
|---|
|  |  |  | //审批通过,但是 已到发车时间,不可以撤销 | 
|---|
|  |  |  | return Constants.ZERO; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(!(Constants.equalsInteger(carUseBook.getStatus(),Constants.ZERO)) | 
|---|
|  |  |  | ||Constants.equalsInteger(carUseBook.getStatus(),Constants.ONE) | 
|---|
|  |  |  | ||Constants.equalsInteger(carUseBook.getStatus(),Constants.TWO)){ | 
|---|
|  |  |  | //审批人可以撤销 自己审批的申请记录 | 
|---|
|  |  |  | Approve approve = approveJoinMapper.selectOne(new QueryWrapper<Approve>().lambda() | 
|---|
|  |  |  | .eq(Approve::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .ge(Approve::getLevel,Constants.ZERO) | 
|---|
|  |  |  | .eq(Approve::getChekorId,loginUserInfo.getId()) | 
|---|
|  |  |  | .eq(Approve::getObjId,carUseBook.getId()) | 
|---|
|  |  |  | .eq(Approve::getObjType,carUseBook.getType()==0?3:4) | 
|---|
|  |  |  | .last("limit 1")); | 
|---|
|  |  |  | if(approve!=null){ | 
|---|
|  |  |  | return Constants.ONE; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return Constants.ZERO; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|