|  |  | 
 |  |  | 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.core.utils.*; | 
 |  |  | import com.doumee.core.wx.MeetConstants; | 
 |  |  | import com.doumee.core.wx.SendWxMessage; | 
 |  |  | import com.doumee.core.wx.WxPlatNotice; | 
 |  |  | import com.doumee.dao.admin.request.BusinessOverDTO; | 
 |  |  | import com.doumee.dao.admin.request.QrOpenDoorDto; | 
 |  |  | import com.doumee.dao.admin.response.DevWgResponseParam; | 
 |  |  | import com.doumee.dao.business.*; | 
 |  |  | import com.doumee.dao.business.dao.SmsConfigMapper; | 
 |  |  | import com.doumee.dao.business.dao.SmsEmailMapper; | 
 |  |  | import com.doumee.dao.business.join.*; | 
 |  |  | import com.doumee.dao.business.model.*; | 
 |  |  | import com.doumee.dao.business.vo.RoomStatisticsVo; | 
 |  |  | 
 |  |  | import com.doumee.dao.system.dto.UserStatisticsDTO; | 
 |  |  | import com.doumee.dao.system.join.NoticesJoinMapper; | 
 |  |  | import com.doumee.dao.system.model.*; | 
 |  |  | import com.doumee.dao.system.vo.UserResponse; | 
 |  |  | import com.doumee.dao.system.vo.UserStatisticsVo; | 
 |  |  | import com.doumee.dao.web.request.BookingsRequest; | 
 |  |  | import com.doumee.dao.web.request.MeetingPageRequest; | 
 |  |  | import com.doumee.dao.web.request.UserPageRequest; | 
 |  |  | import com.doumee.dao.web.response.*; | 
 |  |  | import com.doumee.service.business.BookingsService; | 
 |  |  | import com.doumee.service.business.DevicesService; | 
 |  |  | 
 |  |  | import java.time.format.DateTimeFormatter; | 
 |  |  | import java.time.temporal.TemporalAdjusters; | 
 |  |  | import java.util.*; | 
 |  |  | import java.util.Date; | 
 |  |  | import java.util.stream.Collectors; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private BookingsMapper bookingsMapper; | 
 |  |  |     @Autowired | 
 |  |  |     private SmsConfigMapper smsConfigMapper; | 
 |  |  |     @Autowired | 
 |  |  |     private SystemUserMapper systemUserMapper; | 
 |  |  |     @Autowired | 
 |  |  |     private RoomRecordMapper roomRecordMapper; | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private BookingsJoinMapper bookingsJoinMapper; | 
 |  |  | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private NoticesJoinMapper noticesMapper; | 
 |  |  |     @Autowired | 
 |  |  |     private SmsEmailMapper smsEmailMapper; | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private UserRelMapper userRelMapper; | 
 |  |  | 
 |  |  |     @Transactional(rollbackFor = {BusinessException.class, Exception.class}) | 
 |  |  |     public Integer create(Bookings bookings) { | 
 |  |  |         LoginUserInfo user = bookings.getLoginUserInfo(); | 
 |  |  |         user.setId(bookings.getCreator()); | 
 |  |  |         Rooms rooms = roomsMapper.selectById(bookings.getRoomId()); | 
 |  |  |         if(rooms==null ){ | 
 |  |  |             throw  new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,该会议室暂时无法预约"); | 
 |  |  |         } | 
 |  |  |         bookings.setRoomName(rooms.getName()); | 
 |  |  |         isCreateParamValid(bookings, user); | 
 |  |  |         bookings.setCreateDate(new Date()); | 
 |  |  |         bookings.setCreator(user.getId()); | 
 |  |  |         bookings.setIsdeleted(MeetConstants.ZERO); | 
 |  |  |         bookings.setStatus(MeetConstants.ZERO); | 
 |  |  |         bookingsMapper.insert(bookings); | 
 |  |  |         bookings.setManagerInfo(user.getRealname()); | 
 |  |  |         //更新会议室预定时间段 | 
 |  |  |         updateBookingTimes(bookings, user); | 
 |  |  |         //添加管理人员 | 
 |  |  | 
 |  |  |         updateProjectRel(bookings, user); | 
 |  |  |         handleFile(bookings, user); | 
 |  |  |         //发送会议预约成功通知 | 
 |  |  |         this.sendNotice(bookings, MeetConstants.TWO); | 
 |  |  |         //发送微信订阅通知 | 
 |  |  |         sendWxMessage.bookingsReservation(systemUserMapper.selectById(bookings.getCreator()), bookings, roomsMapper.selectById(bookings.getRoomId())); | 
 |  |  |         if(Constants.equalsInteger(bookings.getJoinNotice(),Constants.ZERO)){ | 
 |  |  |             this.sendNotice(bookings, MeetConstants.TWO); | 
 |  |  |             SystemUser systemUser = systemUserMapper.selectById(user.getId()); | 
 |  |  |             this.sendWxNotice(bookings,Objects.isNull(systemUser)||StringUtils.isBlank(systemUser.getOpenid())?null:systemUser.getOpenid(),Constants.ZERO); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         return bookings.getId(); | 
 |  |  |     } | 
 |  |  | 
 |  |  |             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), ResponseStatus.BAD_REQUEST.getMessage()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         if(Objects.nonNull(bookings.getId())){ | 
 |  |  |             return; | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); | 
 |  |  |         SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd"); | 
 |  |  |         String gsDate = format1.format(bookings.getStartTime()); | 
 |  |  | 
 |  |  |         bookquery.selectAs(BookingTime::getTimeId, Bookings::getRoomTimeId); | 
 |  |  |         bookquery.selectAs(BookingTime::getId, Bookings::getBookingTimeId); | 
 |  |  |         bookquery.eq(Bookings::getIsdeleted, MeetConstants.ZERO); | 
 |  |  |         bookquery.eq(BookingTime::getIsdeleted, MeetConstants.ZERO); | 
 |  |  |         bookquery.eq(Bookings::getRoomId, bookings.getRoomId()); | 
 |  |  |         bookquery.eq(Bookings::getStatus, MeetConstants.ZERO); | 
 |  |  |         //bookquery.ge(Bookings::getStartTime, bookings.getStartTime()); | 
 |  |  | 
 |  |  |         List<Bookings> bookList = bookingsJoinMapper.selectJoinList(Bookings.class, bookquery); | 
 |  |  |         for (int i = 0; i < bookings.getBookingTimeList().size(); i++) { | 
 |  |  |             BookingTime s = bookings.getBookingTimeList().get(i); | 
 |  |  |             RoomTime roomTime = roomTimeJoinMapper.selectById(s.getTimeId()); | 
 |  |  |             if(Objects.isNull(roomTime)){ | 
 |  |  |                 throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"存在未查询到的配置日期,请刷新重试"); | 
 |  |  |             } | 
 |  |  |             String endRoomTime = gsDate + " " + roomTime.getEndTime()+":00"; | 
 |  |  |             if(DateUtil.StringToDate(endRoomTime, "yyyy-MM-dd HH:mm:ss").getTime()<=System.currentTimeMillis()){ | 
 |  |  |                 throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),endRoomTime + "已超过当前时间,无法进行预约"); | 
 |  |  |             } | 
 |  |  |             if (!Objects.isNull(bookList) && bookList.size() > MeetConstants.ZERO) { | 
 |  |  |  | 
 |  |  |                 List<Bookings> detailDataDtoStream = | 
 |  |  |                         bookList.stream().filter(a -> MeetConstants.equalsInteger(s.getTimeId(), a.getRoomTimeId()) | 
 |  |  |                         ).collect(Collectors.toList()); | 
 |  |  | 
 |  |  |                                         .filter(a -> MeetConstants.equalsInteger(a.getRoomTimeId(), s.getTimeId())) | 
 |  |  |                                         .collect(Collectors.toList()); | 
 |  |  |                         if (chriList.size() > 0) { | 
 |  |  |                             RoomTime roomTime = roomTimeJoinMapper.selectById(s.getTimeId()); | 
 |  |  |                             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "该会议:" + roomTime.getStartTime() + "-" + roomTime.getEndTime() + "时间段内已被使用"); | 
 |  |  |                         } | 
 |  |  |                     } else { | 
 |  |  | 
 |  |  |                                         .filter(a -> MeetConstants.equalsInteger(a.getRoomTimeId(), s.getTimeId())) | 
 |  |  |                                         .collect(Collectors.toList()); | 
 |  |  |                         if (chriList.size() > 0) { | 
 |  |  |                             RoomTime roomTime = roomTimeJoinMapper.selectById(s.getTimeId()); | 
 |  |  |                             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "该会议:" + roomTime.getStartTime() + "-" + roomTime.getEndTime() + "时间段内已被使用"); | 
 |  |  |                         } | 
 |  |  |                     } | 
 |  |  | 
 |  |  |  | 
 |  |  |  | 
 |  |  |         bookings.getBookingTimeList().stream().forEach(s -> { | 
 |  |  |             s.setId(null); | 
 |  |  |             s.setCreator(user.getId()); | 
 |  |  |             s.setCreateDate(new Date()); | 
 |  |  |             s.setIsdeleted(MeetConstants.ZERO); | 
 |  |  |             s.setBookingId(bookings.getId()); | 
 |  |  |             bookingTimeJoinMapper.insert(s); | 
 |  |  |         }); | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public void updateManager(Bookings bookings, LoginUserInfo user) { | 
 |  |  | 
 |  |  |             userRel.setIsdeleted(MeetConstants.ONE); | 
 |  |  |             userRelJoinMapper.update(userRel, updateWrapper); | 
 |  |  |         } | 
 |  |  |         bookings.getSysList().stream().forEach(s -> { | 
 |  |  |             s.setIsdeleted(MeetConstants.ZERO); | 
 |  |  |             s.setCreateDate(new Date()); | 
 |  |  |             s.setCreator(user.getId()); | 
 |  |  |             s.setUserId(s.getUserId()); | 
 |  |  |             s.setObjId(bookings.getId()); | 
 |  |  |             s.setObjType(MeetConstants.ONE); | 
 |  |  |             userRelJoinMapper.insert(s); | 
 |  |  |         }); | 
 |  |  |  | 
 |  |  |         if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(bookings.getSysList())){ | 
 |  |  |             bookings.getSysList().stream().forEach(s -> { | 
 |  |  |                 s.setId(null); | 
 |  |  |                 s.setIsdeleted(MeetConstants.ZERO); | 
 |  |  |                 s.setCreateDate(new Date()); | 
 |  |  |                 s.setCreator(user.getId()); | 
 |  |  |                 s.setUserId(s.getUserId()); | 
 |  |  |                 s.setObjId(bookings.getId()); | 
 |  |  |                 s.setObjType(MeetConstants.ONE); | 
 |  |  |                 userRelJoinMapper.insert(s); | 
 |  |  |             }); | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public void updateProjectRel(Bookings rooms, LoginUserInfo user) { | 
 |  |  | 
 |  |  |             projectRelJoinMapper.update(projectRel, updateWrapper); | 
 |  |  |  | 
 |  |  |             rooms.getProjectList().stream().forEach(s -> { | 
 |  |  |  | 
 |  |  |                 s.setId(null); | 
 |  |  |                 s.setIsdeleted(MeetConstants.ZERO); | 
 |  |  |                 s.setCreateDate(new Date()); | 
 |  |  |                 s.setCreator(user.getId()); | 
 |  |  | 
 |  |  |         if(dbBookings.getStatus().equals(MeetConstants.ONE)){ | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "本次操作失败,预约状态已流转"); | 
 |  |  |         } | 
 |  |  |         Rooms rooms = roomsMapper.selectById(dbBookings.getRoomId()); | 
 |  |  |         if(rooms==null ){ | 
 |  |  |             throw  new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,该会议室暂时无法预约"); | 
 |  |  |         } | 
 |  |  |         bookings.setRoomName(rooms.getName()); | 
 |  |  |         LoginUserInfo user = bookings.getLoginUserInfo(); | 
 |  |  |         isCreateParamValid(bookings, user); | 
 |  |  |         bookings.setEditDate(new Date()); | 
 |  |  |         bookings.setEditor(user.getId()); | 
 |  |  |         bookingsMapper.updateById(bookings); | 
 |  |  |         bookings.setManagerInfo(user.getRealname()); | 
 |  |  |         bookings.setCreator(dbBookings.getCreator()); | 
 |  |  |         //更新会议室预定时间段 | 
 |  |  |         updateBookingTimes(bookings, user); | 
 |  |  |         //添加管理人员 | 
 |  |  | 
 |  |  |         updateProjectRel(bookings, user); | 
 |  |  |         handleFile(bookings, user); | 
 |  |  |         //发送会议通知 | 
 |  |  |         this.sendNotice(bookings, MeetConstants.TWO); | 
 |  |  |         if(Constants.equalsInteger(bookings.getJoinNotice(),Constants.ZERO)){ | 
 |  |  |             this.sendNotice(bookings, MeetConstants.TWO); | 
 |  |  |             SystemUser systemUser = systemUserMapper.selectById(bookings.getCreator()); | 
 |  |  |             this.sendWxNotice(bookings,Objects.isNull(systemUser)||StringUtils.isBlank(systemUser.getOpenid())?null:systemUser.getOpenid(),Constants.ZERO); | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  | 
 |  |  |         bookings.setEditDate(new Date()); | 
 |  |  |         bookings.setEditor(user.getId()); | 
 |  |  |         bookingsMapper.updateById(bookings); | 
 |  |  |         //取消会议 发送取消通知 | 
 |  |  |         this.sendNotice(bookings, 3); | 
 |  |  |         //发送微信订阅通知 | 
 |  |  |         sendWxMessage.bookingsCancel(systemUserMapper.selectById(bookings.getCreator()), bookings, roomsMapper.selectById(bookings.getRoomId())); | 
 |  |  |         SystemUser systemUser = systemUserMapper.selectById(bookings.getCreator()); | 
 |  |  |  | 
 |  |  |         bookings.setManagerInfo(systemUser.getRealname()); | 
 |  |  |         //取消会议 发送取消通知 | 
 |  |  |         if(Constants.equalsInteger(bookings.getJoinNotice(),Constants.ZERO)){ | 
 |  |  |             this.sendNotice(bookings, 3); | 
 |  |  |             this.sendWxNotice(bookings,Objects.isNull(systemUser)||StringUtils.isBlank(systemUser.getOpenid())?null:systemUser.getOpenid(),Constants.ONE); | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  | 
 |  |  |         queryWrapper.selectAs(Rooms::getName, Bookings::getRoomName); | 
 |  |  |         queryWrapper.selectAs(SystemUser::getRealname, Bookings::getRealName); | 
 |  |  |         queryWrapper.selectAs(Company::getName, Bookings::getDepartmentName); | 
 |  |  |  | 
 |  |  |         queryWrapper.select(" CASE WHEN t.START_TIME_REAL IS NULL AND t.`STATUS` = 0 THEN 1  WHEN ( ( t.END_TIME < now()  AND t.`STATUS` = 0 ) or t.`STATUS` = 2 ) THEN 3 WHEN t.`STATUS` = 1 THEN 5 ELSE  2  END meetingStatus "); | 
 |  |  |         queryWrapper.leftJoin(Rooms.class, Rooms::getId, Bookings::getRoomId); | 
 |  |  |         queryWrapper.leftJoin(SystemUser.class, SystemUser::getId, Bookings::getCreator); | 
 |  |  |         queryWrapper.leftJoin(Company.class,Company::getId,SystemUser::getCompanyId); | 
 |  |  |         queryWrapper.orderByDesc(Bookings::getCreateDate); | 
 |  |  |         queryWrapper.eq(Bookings::getIsdeleted, MeetConstants.ZERO); | 
 |  |  |  | 
 |  |  |         //数据权限开始--------------------start---------------- | 
 |  |  |         LoginUserInfo userInfo =pageWrap.getModel().getLoginUserInfo(); | 
 |  |  |         if(userInfo!=null && userInfo.getCompanyIdList()!=null){ | 
 |  |  |             if(  userInfo.getCompanyIdList().size() ==0){ | 
 |  |  |                 //只看自己 | 
 |  |  |                 queryWrapper.and(wrapper ->{ | 
 |  |  |                     wrapper.eq(Bookings::getCreator,userInfo.getId()) | 
 |  |  |                             .or().exists("select rel.id from meeting_user_rel rel where rel.OBJ_TYPE=0 and rel.obj_id=t.id and rel.isdeleted=0 and rel.user_id="+userInfo.getId()); | 
 |  |  |                 }); | 
 |  |  |                 queryWrapper.eq(Bookings::getCreator,userInfo.getId()); | 
 |  |  |             }else{ | 
 |  |  |                 //权限范围内 | 
 |  |  |                 queryWrapper.and(wrapper ->{ | 
 |  |  |                     wrapper.in(SystemUser::getCompanyId ,userInfo.getCompanyIdList()) | 
 |  |  |                             .or().exists("select rel.id from meeting_user_rel rel where rel.OBJ_TYPE=0 and rel.obj_id=t.id and rel.isdeleted=0 and rel.user_id="+userInfo.getId()); | 
 |  |  |                 }); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         //数据权限开始--------------------end---------------- | 
 |  |  |  | 
 |  |  |         queryWrapper.eq(pageWrap.getModel().getRoomId() != null, Bookings::getRoomId, pageWrap.getModel().getRoomId()); | 
 |  |  |         queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getName()), Bookings::getName, pageWrap.getModel().getName()); | 
 |  |  |         queryWrapper.eq(pageWrap.getModel().getStatus() != null, Bookings::getStatus, pageWrap.getModel().getStatus()); | 
 |  |  |         queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getRealName()), SystemUser::getRealname, pageWrap.getModel().getRealName()); | 
 |  |  |         queryWrapper.eq(pageWrap.getModel().getDepartmentId() != null, SystemUser::getId, pageWrap.getModel().getDepartmentId()); | 
 |  |  |         queryWrapper.eq(pageWrap.getModel().getDepartmentId() != null, Company::getId, pageWrap.getModel().getDepartmentId()); | 
 |  |  |  | 
 |  |  |         queryWrapper.apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                         &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.ONE), | 
 |  |  |                 " ( now() < t.START_TIME and t.status = 0 ) " | 
 |  |  |         ) | 
 |  |  |         .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                         &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.TWO), | 
 |  |  |                 " ( now() >= t.START_TIME and t.END_TIME >= now() and t.status = 0 ) " | 
 |  |  |         ) | 
 |  |  |         .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                         &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.THREE), | 
 |  |  |                 " ( ( now() > t.END_TIME  and  t.`STATUS` = 0  ) or   t.`STATUS` = 2  )  " | 
 |  |  |         ) | 
 |  |  |         .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                         &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.FOUR), | 
 |  |  |                 " now() < t.START_TIME  AND SUBDATE( t.START_TIME, INTERVAL 120 MINUTE ) < NOW() " | 
 |  |  |         ) | 
 |  |  |         .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                         &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.FIVE), | 
 |  |  |                 " t.STATUS = 1  " | 
 |  |  |         ); | 
 |  |  |  | 
 |  |  |         if (pageWrap.getModel().getStartTime() != null) { | 
 |  |  |             queryWrapper.ge(Bookings::getStartTime, pageWrap.getModel().getStartTime()); | 
 |  |  | 
 |  |  |         SimpleDateFormat format1 = new SimpleDateFormat("HH:mm"); | 
 |  |  |         IPage<Bookings> result = bookingsJoinMapper.selectJoinPage(page, Bookings.class, queryWrapper); | 
 |  |  |         result.getRecords().stream().forEach(s -> { | 
 |  |  |  | 
 |  |  |             if(s.getMeetingStatus().equals(Constants.ZERO)){ | 
 |  |  |                 if(s.getMeetingStatus()==Constants.ONE){ | 
 |  |  |                     //开始前120分钟 大于当前时间 则显示即将开始 | 
 |  |  |                     if(DateUtil.afterMinutesDate(s.getStartTime(),-120).getTime()>System.currentTimeMillis()){ | 
 |  |  |                         s.setMeetingStatus(4); | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |             MPJLambdaWrapper<Multifile> bookquery = new MPJLambdaWrapper<>(); | 
 |  |  |             bookquery.eq(Multifile::getIsdeleted, MeetConstants.ZERO); | 
 |  |  |             bookquery.eq(Multifile::getObjId, s.getId()); | 
 |  |  | 
 |  |  |                 .apply(" id in ( select u.OBJ_ID from meeting_user_rel u where u.USER_ID = '" + userId + "' and u.ISDELETED = 0 and OBJ_TYPE = 1  ) ") | 
 |  |  |                 .eq("ISDELETED",MeetConstants.ZERO) | 
 |  |  | //                .eq("STATUS",MeetConstants.ZERO) | 
 |  |  |                 .apply(" ROOM_ID in ( select r.id from rooms r where r.ISDELETED = 0 and r.STATUS = 0  )") | 
 |  |  |                 .apply(" ROOM_ID in ( select r.id from meeting_rooms r where r.ISDELETED = 0 and r.STATUS = 0  )") | 
 |  |  |                 .like(StringUtils.isNotBlank(dateMsg), "START_TIME", dateMsg)); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     public IPage<MeetingListResponse> getMyMeetingPage(PageWrap<MeetingPageRequest> pageWrap) { | 
 |  |  |         IPage<MeetingListResponse> page = bookingsMapper.myMeetingPage(pageWrap.toPage(), new QueryWrapper<MeetingListResponse>() | 
 |  |  |  | 
 |  |  |         QueryWrapper queryWrapper = new QueryWrapper<MeetingListResponse>() | 
 |  |  |                 .and(StringUtils.isNotBlank(pageWrap.getModel().getRoomsName()), | 
 |  |  |                         j -> j.like("a.NAME",pageWrap.getModel().getRoomsName()).or() | 
 |  |  |                                 .like(" b.NAME", pageWrap.getModel().getRoomsName())) | 
 |  |  |                         .exists(pageWrap.getModel().getQueryType().equals(MeetConstants.ONE) && !Objects.isNull(pageWrap.getModel().getUserId()), | 
 |  |  |                                 " select 1 from meeting_user_rel u where a.id = u.OBJ_ID and  u.USER_ID = '" + pageWrap.getModel().getUserId() + "' and u.ISDELETED = 0 and OBJ_TYPE = 1  ") | 
 |  |  |                         .eq(pageWrap.getModel().getQueryType().equals(MeetConstants.TWO) && !Objects.isNull(pageWrap.getModel().getUserId()), "a.CREATOR", pageWrap.getModel().getUserId()) | 
 |  |  |                         .like(StringUtils.isNotBlank(pageWrap.getModel().getQueryDate()), "a.START_TIME", pageWrap.getModel().getQueryDate()) | 
 |  |  |                         .eq(!Objects.isNull(pageWrap.getModel().getRoomsId()), "b.id", pageWrap.getModel().getRoomsId()) | 
 |  |  |                         .apply(!Objects.isNull(pageWrap.getModel().getStatus()) && pageWrap.getModel().getStatus().equals(MeetConstants.ONE), " now() < a.END_TIME and a.STATUS = 0   ") | 
 |  |  |                         .and(!Objects.isNull(pageWrap.getModel().getStatus()) && pageWrap.getModel().getStatus().equals(MeetConstants.TWO), | 
 |  |  |                                 j -> j.apply("now() >= a.END_TIME ").or() | 
 |  |  |                                         .eq(" a.STATUS", MeetConstants.ONE)) | 
 |  |  |                         .eq("b.ISDELETED",MeetConstants.ZERO) | 
 |  |  |                         .eq("b.STATUS",MeetConstants.ZERO) | 
 |  |  |                         .eq("a.ISDELETED",MeetConstants.ZERO) | 
 |  |  |                         .orderByDesc(!Objects.isNull(pageWrap.getModel().getStatus())&&pageWrap.getModel().getStatus().equals(MeetConstants.TWO),"a.START_TIME") | 
 |  |  |                         .orderByAsc(Objects.isNull(pageWrap.getModel().getStatus())||pageWrap.getModel().getStatus().equals(MeetConstants.ONE),"a.START_TIME") | 
 |  |  |         ); | 
 |  |  |         String path = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_RESOURCE_PATH).getCode() + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.PROJECTS).getCode(); | 
 |  |  |         page.getRecords().forEach(i -> { | 
 |  |  |             i.setPrefixUrl(path); | 
 |  |  |             if(i.getMeetingStatus().equals(Constants.ZERO)){ | 
 |  |  |                 if(i.getStatus()==Constants.ONE){ | 
 |  |  |                     i.setMeetingStatus(5); | 
 |  |  |                 }else{ | 
 |  |  |                     //开始前5分钟 大于当前时间 则显示即将开始 | 
 |  |  |                     if(DateUtil.afterMinutesDate(i.getStartTime(),-5).getTime()>System.currentTimeMillis()){ | 
 |  |  |                         i.setMeetingStatus(4); | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |                 .exists(pageWrap.getModel().getQueryType().equals(MeetConstants.ONE) && !Objects.isNull(pageWrap.getModel().getUserId()), | 
 |  |  |                         " select 1 from meeting_user_rel u where a.id = u.OBJ_ID and  u.USER_ID = '" + pageWrap.getModel().getUserId() + "' and u.ISDELETED = 0 and OBJ_TYPE = 1  ") | 
 |  |  |                 .eq(pageWrap.getModel().getQueryType().equals(MeetConstants.TWO) && !Objects.isNull(pageWrap.getModel().getUserId()), "a.CREATOR", pageWrap.getModel().getUserId()) | 
 |  |  |                 .like(StringUtils.isNotBlank(pageWrap.getModel().getQueryDate()), "a.START_TIME", pageWrap.getModel().getQueryDate()) | 
 |  |  |                 .eq(!Objects.isNull(pageWrap.getModel().getRoomsId()), "b.id", pageWrap.getModel().getRoomsId()) | 
 |  |  |                 .apply(!Objects.isNull(pageWrap.getModel().getStatus()) && pageWrap.getModel().getStatus().equals(MeetConstants.ONE), " now() < a.END_TIME and a.STATUS = 0   ") | 
 |  |  |                 .and(!Objects.isNull(pageWrap.getModel().getStatus()) && pageWrap.getModel().getStatus().equals(MeetConstants.TWO), | 
 |  |  |                         j -> j.apply("now() >= a.END_TIME ").or() | 
 |  |  |                                 .eq(" a.STATUS", MeetConstants.ONE)) | 
 |  |  |                 .eq("b.ISDELETED",MeetConstants.ZERO) | 
 |  |  |                 .eq("b.STATUS",MeetConstants.ZERO) | 
 |  |  |                 .eq("a.ISDELETED",MeetConstants.ZERO) | 
 |  |  |                 .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                                 &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.ONE), | 
 |  |  |                         " ( now() < a.START_TIME and a.status = 0 ) " | 
 |  |  |                 ) | 
 |  |  |                 .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                                 &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.TWO), | 
 |  |  |                         " ( now() >= a.START_TIME and a.END_TIME >= now() and a.status = 0 ) " | 
 |  |  |                 ) | 
 |  |  |                 .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                                 &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.THREE), | 
 |  |  |                         " ( ( now() > a.END_TIME  and  a.`STATUS` = 0  ) or   a.`STATUS` = 2  )  " | 
 |  |  |                 ) | 
 |  |  |                 .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                                 &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.FOUR), | 
 |  |  |                         " now() < a.START_TIME  AND SUBDATE( a.START_TIME, INTERVAL 120 MINUTE ) < NOW() " | 
 |  |  |                 ) | 
 |  |  |                 .apply(Objects.nonNull(pageWrap.getModel().getMeetingStatus()) | 
 |  |  |                                 &&Constants.equalsInteger(pageWrap.getModel().getMeetingStatus(),Constants.FIVE), | 
 |  |  |                         " a.STATUS = 1  " | 
 |  |  |                 ) | 
 |  |  | //                        .orderByDesc(!Objects.isNull(pageWrap.getModel().getStatus())&&pageWrap.getModel().getStatus().equals(MeetConstants.TWO),"a.START_TIME") | 
 |  |  | //                        .orderByAsc(Objects.isNull(pageWrap.getModel().getStatus())||pageWrap.getModel().getStatus().equals(MeetConstants.ONE),"a.START_TIME") | 
 |  |  |                 .orderByDesc(Constants.equalsInteger(pageWrap.getModel().getQueryType(),MeetConstants.TWO),"a.CREATE_DATE") | 
 |  |  |                 .orderByAsc(Constants.equalsInteger(pageWrap.getModel().getQueryType(),MeetConstants.ONE),"a.START_TIME"); | 
 |  |  |  | 
 |  |  |             } | 
 |  |  |  | 
 |  |  |         }); | 
 |  |  |         IPage<MeetingListResponse> page = bookingsMapper.myMeetingPage(pageWrap.toPage(), queryWrapper); | 
 |  |  |         this.dealMeetingStatus(page.getRecords()); | 
 |  |  |         return page; | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | 
 |  |  |             if(Objects.isNull(bookings)){ | 
 |  |  |                 throw new BusinessException(ResponseStatus.DATA_EMPTY); | 
 |  |  |             } | 
 |  |  |             return getMeetingDetail(bookings.getId()); | 
 |  |  |             return getMeetingDetail(bookings.getId(),null); | 
 |  |  |         }catch (Exception e){ | 
 |  |  |             e.printStackTrace(); | 
 |  |  |         } | 
 |  |  | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     public MeetingDetailResponse getMeetingDetail(Integer id) { | 
 |  |  |     public MeetingDetailResponse getMeetingDetail(Integer id,Integer sysUserId) { | 
 |  |  |         MeetingDetailResponse meetingDetailResponse = bookingsMapper.meetingDetail(id); | 
 |  |  |         if (Objects.isNull(meetingDetailResponse)) { | 
 |  |  |             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "未查询到会议详情"); | 
 |  |  | 
 |  |  |                 .eq("BOOKING_ID", id) | 
 |  |  |                 .eq("ISDELETED", MeetConstants.ZERO) | 
 |  |  |         )); | 
 |  |  |  | 
 |  |  |         //参会人员列表 | 
 |  |  |         SystemUser param = new SystemUser(); | 
 |  |  |         List<SystemUser> userResponseList = systemUserService.findList(param); | 
 |  |  |         String avatarPath = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_RESOURCE_PATH).getCode() + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.MEMBER_IMG).getCode(); | 
 |  |  |         List<UserResponse> userResponseList = systemUserService.getUserList(id); | 
 |  |  |         String avatarPath = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() | 
 |  |  |                 +systemDictDataBiz.queryByCode(Constants.FTP,Constants.MEMBER_IMG).getCode(); | 
 |  |  |         userResponseList.forEach(i -> { | 
 |  |  |             if(StringUtils.isNotBlank(i.getAvatar())){ | 
 |  |  |             if(StringUtils.isNotBlank(i.getAvatar()) && !i.getAvatar().startsWith("HKIMG") ){ | 
 |  |  |                 i.setAvatar(avatarPath+i.getAvatar()); | 
 |  |  |             }else{ | 
 |  |  |                 i.setAvatar(null); | 
 |  |  |             } | 
 |  |  |         }); | 
 |  |  |         meetingDetailResponse.setUserResponseList(userResponseList); | 
 |  |  |         //服务项 | 
 |  |  |         String projectsPath = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_RESOURCE_PATH).getCode() + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.PROJECTS).getCode(); | 
 |  |  |         String projectsPath = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_RESOURCE_PATH).getCode() | 
 |  |  |                 + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.PROJECTS).getCode(); | 
 |  |  |         List<ProjectsResponse> projectsResponseList = projectsService.getProjectsList(id, MeetConstants.ONE); | 
 |  |  |         projectsResponseList.forEach(i -> { | 
 |  |  |             i.setPrefixUrl(projectsPath); | 
 |  |  | 
 |  |  |                 .eq("OBJ_ID", meetingDetailResponse.getRoomId()) | 
 |  |  |                 .eq("OBJ_TYPE",MeetConstants.ZERO) | 
 |  |  |         ); | 
 |  |  |         if(Constants.equalsInteger(sysUserId,meetingDetailResponse.getBookingUserId())){ | 
 |  |  |             meetingDetailResponse.setIsAdmin(Constants.ONE); | 
 |  |  |         } | 
 |  |  |         if (!Objects.isNull(userRelList) && userRelList.size() > 0) { | 
 |  |  |             meetingDetailResponse.setRoomUser(systemUserService.findById(userRelList.get(MeetConstants.ZERO).getUserId())); | 
 |  |  |             if( Objects.nonNull(sysUserId) && | 
 |  |  |                     userRelList.stream().filter(i->Constants.equalsInteger(i.getUserId(),sysUserId)).collect(Collectors.toList()).size()>Constants.ZERO | 
 |  |  |             ){ | 
 |  |  |                 meetingDetailResponse.setIsAdmin(Constants.ONE); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         return meetingDetailResponse; | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 会议预约记录取消 | 
 |  |  |      * | 
 |  |  |      * @param id | 
 |  |  |      * @param userId | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     @Transactional(rollbackFor = {Exception.class,BusinessException.class}) | 
 |  |  |     public void reservationCancel(Integer id, Integer userId) { | 
 |  |  |         Bookings bookings = bookingsMapper.selectById(id); | 
 |  |  |     public void reservationCancel(BusinessOverDTO businessOverDTO) { | 
 |  |  |         Bookings bookings = bookingsMapper.selectById(businessOverDTO.getId()); | 
 |  |  |         if (Objects.isNull(bookings)) { | 
 |  |  |             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "未查询到预约记录"); | 
 |  |  |         } | 
 |  |  |         if (!bookings.getCreator().equals(userId)) { | 
 |  |  |         if (!bookings.getCreator().equals(businessOverDTO.getUserId())) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "非你的预约记录,无法进行取消"); | 
 |  |  |         } | 
 |  |  |         if (System.currentTimeMillis() > bookings.getStartTime().getTime()) { | 
 |  |  |         if (Objects.nonNull(bookings.getStartTimeReal()) && System.currentTimeMillis() > bookings.getStartTimeReal().getTime()) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "会议已开始,无法进行取消"); | 
 |  |  |         } | 
 |  |  |         if(bookings.getStatus().equals(MeetConstants.ONE)){ | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "本次操作失败,预约状态已流转"); | 
 |  |  |         } | 
 |  |  |         bookings.setCancelTime(new Date()); | 
 |  |  |         bookings.setCancelUser(userId); | 
 |  |  |         bookings.setCancelUser(businessOverDTO.getUserId()); | 
 |  |  |         bookings.setCancelInfo(businessOverDTO.getBusinessRemark()); | 
 |  |  |         bookings.setStatus(MeetConstants.ONE); | 
 |  |  |         bookings.setEditDate(new Date()); | 
 |  |  |         bookings.setEditor(userId); | 
 |  |  |         bookings.setEditor(businessOverDTO.getUserId()); | 
 |  |  |         Rooms rooms = roomsMapper.selectById(bookings.getRoomId()); | 
 |  |  |         if(Objects.nonNull(rooms)){ | 
 |  |  |             bookings.setRoomName(rooms.getName()); | 
 |  |  |         } | 
 |  |  |         bookingsMapper.updateById(bookings); | 
 |  |  |         //取消会议 发送取消通知 | 
 |  |  |         this.sendNotice(bookings, 3); | 
 |  |  |         //发送微信订阅通知 | 
 |  |  |         sendWxMessage.bookingsCancel(systemUserMapper.selectById(bookings.getCreator()), bookings, roomsMapper.selectById(bookings.getRoomId())); | 
 |  |  |         if(Constants.equalsInteger(bookings.getJoinNotice(),Constants.ZERO)){ | 
 |  |  | //            this.sendNotice(bookings, 3); | 
 |  |  |             SystemUser systemUser = systemUserMapper.selectById(bookings.getCreator()); | 
 |  |  |             bookings.setManagerInfo(systemUser.getRealname()); | 
 |  |  |             this.sendWxNotice(bookings,Objects.isNull(systemUser)||StringUtils.isBlank(systemUser.getOpenid())?null:systemUser.getOpenid(),Constants.ONE); | 
 |  |  |  | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  |     @Transactional(rollbackFor = {Exception.class,BusinessException.class}) | 
 |  |  |     public void reservationOver(BusinessOverDTO businessOverDTO) { | 
 |  |  |         if(Objects.isNull(businessOverDTO) | 
 |  |  |             || Objects.isNull(businessOverDTO.getUserId()) | 
 |  |  |             || Objects.isNull(businessOverDTO.getId()) | 
 |  |  |         ){ | 
 |  |  |             throw new BusinessException(ResponseStatus.BAD_REQUEST); | 
 |  |  |         } | 
 |  |  |         Bookings bookings = bookingsMapper.selectById(businessOverDTO.getId()); | 
 |  |  |         if (Objects.isNull(bookings)) { | 
 |  |  |             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "未查询到预约记录"); | 
 |  |  |         } | 
 |  |  |         Long userRelList = userRelMapper.selectCount(new QueryWrapper<UserRel>().lambda() | 
 |  |  |                 .eq(UserRel::getIsdeleted,Constants.ZERO) | 
 |  |  |                 .eq(UserRel::getObjId,bookings.getRoomId()) | 
 |  |  |                 .eq(UserRel::getObjType,Constants.ZERO) | 
 |  |  |                 .eq(UserRel::getUserId,businessOverDTO.getUserId())); | 
 |  |  |  | 
 |  |  |         if (!bookings.getCreator().equals(businessOverDTO.getUserId()) && userRelList <= 0) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "非你的预约记录,无法进行该操作"); | 
 |  |  |         } | 
 |  |  |         if (System.currentTimeMillis() < bookings.getStartTimeReal().getTime()) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "会议未开始,无法进行结束,如需该操作请使用取消功能"); | 
 |  |  |         } | 
 |  |  |         if (System.currentTimeMillis() > bookings.getEndTime().getTime()) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "会议已结束,无法进行该操作"); | 
 |  |  |         } | 
 |  |  |         if(!bookings.getStatus().equals(MeetConstants.ZERO)){ | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "本次操作失败,会议状态已流转"); | 
 |  |  |         } | 
 |  |  |         bookings.setDoneDate(new Date()); | 
 |  |  |         bookings.setDoneUserId(businessOverDTO.getUserId()); | 
 |  |  |         bookings.setStatus(MeetConstants.TWO); | 
 |  |  |         bookings.setEditDate(new Date()); | 
 |  |  |         bookings.setEditor(businessOverDTO.getUserId()); | 
 |  |  |         bookingsMapper.updateById(bookings); | 
 |  |  |  | 
 |  |  |         //查询所有的预约时间 | 
 |  |  |         List<BookingTime> bookingTimeList = bookingTimeJoinMapper.selectJoinList(BookingTime.class, | 
 |  |  |                 new MPJLambdaWrapper<BookingTime>() | 
 |  |  |                         .selectAll(BookingTime.class) | 
 |  |  |                         .selectAs(RoomTime::getEndTime,BookingTime::getEndTime) | 
 |  |  |                         .leftJoin(RoomTime.class,RoomTime::getId,BookingTime::getTimeId) | 
 |  |  |                         .eq(BookingTime::getBookingId,bookings.getId())); | 
 |  |  |         //获取当天  只有当天日期内可以处理 | 
 |  |  |         String today = DateUtil.dateToString(new Date(),"yyyy-mm-dd"); | 
 |  |  |         //循环标记数据为已删除 不再占用 | 
 |  |  |         for (BookingTime bookingTime:bookingTimeList) { | 
 |  |  |             if(DateUtil.getDateFromString(today + " " + bookingTime.getEndTime() +":00").getTime()>System.currentTimeMillis()){ | 
 |  |  |                 bookingTime.setIsdeleted(Constants.ZERO); | 
 |  |  |                 bookingTimeJoinMapper.updateById(bookingTime); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 正常开始 | 
 |  |  |      * @param businessOverDTO | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     @Transactional(rollbackFor = {Exception.class,BusinessException.class}) | 
 |  |  |     public void start(BusinessOverDTO businessOverDTO) { | 
 |  |  |         this.startEarly(businessOverDTO); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 提前开始 | 
 |  |  |      * @param businessOverDTO | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     @Transactional(rollbackFor = {Exception.class,BusinessException.class}) | 
 |  |  |     public void startEarly(BusinessOverDTO businessOverDTO) { | 
 |  |  |         if(Objects.isNull(businessOverDTO) | 
 |  |  |                 || Objects.isNull(businessOverDTO.getUserId()) | 
 |  |  |                 || Objects.isNull(businessOverDTO.getStartType()) | 
 |  |  |                 || Objects.isNull(businessOverDTO.getId()) | 
 |  |  |         ){ | 
 |  |  |             throw new BusinessException(ResponseStatus.BAD_REQUEST); | 
 |  |  |         } | 
 |  |  |         Bookings bookings = bookingsMapper.selectById(businessOverDTO.getId()); | 
 |  |  |         if (Objects.isNull(bookings)) { | 
 |  |  |             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "未查询到预约记录"); | 
 |  |  |         } | 
 |  |  |         Long userRelList = userRelMapper.selectCount(new QueryWrapper<UserRel>().lambda() | 
 |  |  |                 .eq(UserRel::getIsdeleted,Constants.ZERO) | 
 |  |  |                 .eq(UserRel::getObjId,bookings.getRoomId()) | 
 |  |  |                 .eq(UserRel::getObjType,Constants.ZERO) | 
 |  |  |                 .eq(UserRel::getUserId,businessOverDTO.getUserId())); | 
 |  |  |  | 
 |  |  |         if (!bookings.getCreator().equals(businessOverDTO.getUserId()) && userRelList <= 0) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "非你的预约记录,无法进行该操作"); | 
 |  |  |         } | 
 |  |  |         if(!Constants.equalsInteger(bookings.getStatus(),Constants.ZERO)){ | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "会议状态已流转,无法进行该操作"); | 
 |  |  |         } | 
 |  |  |         if(Objects.nonNull(bookings.getStartTimeReal())){ | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "会议已开始,请勿重复操作"); | 
 |  |  |         } | 
 |  |  |         if (System.currentTimeMillis() > bookings.getEndTime().getTime()) { | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "会议已结束,无法进行该操作"); | 
 |  |  |         } | 
 |  |  |         if(Constants.equalsInteger(businessOverDTO.getStartType(),Constants.ZERO)){ | 
 |  |  |             //根据配置获取提前开始的分钟数量 | 
 |  |  |             String configMinute = systemDictDataBiz.queryByCode(MeetConstants.SYSTEM, MeetConstants.EARLY_START).getCode(); | 
 |  |  |             Integer beforeMinutes = StringUtils.isNotBlank(configMinute) ? Integer.valueOf(configMinute) : 120; | 
 |  |  |             if(DateUtil.afterMinutesDate(bookings.getStartTime(),-beforeMinutes).getTime()>System.currentTimeMillis()){ | 
 |  |  |                 throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"会议仅可以提前"+beforeMinutes+"分钟开始"); | 
 |  |  |             } | 
 |  |  |             //查询是否存在其他未开始的会议 防止颗粒度与提前开始的问题 | 
 |  |  |             if(bookingsMapper.selectCount(new QueryWrapper<Bookings>() | 
 |  |  |                     .lambda() | 
 |  |  |                     .apply(" now() < START_TIME and   END_TIME <=  '" + DateUtil.DateToStr(bookings.getStartTime(),"yyyy-MM-dd HH:mm:ss") +"'" ) | 
 |  |  |                     .isNull(Bookings::getStartTimeReal) | 
 |  |  |                     .isNull(Bookings::getDoneDate) | 
 |  |  |                     .eq(Bookings::getStatus,Constants.ZERO) | 
 |  |  |                     .eq(Bookings::getRoomId,bookings.getRoomId()) | 
 |  |  |                     .ne(Bookings::getId,bookings.getId()) | 
 |  |  |             )>Constants.ZERO){ | 
 |  |  |                 throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"存在未开启会议,无法开始会议"); | 
 |  |  |             }; | 
 |  |  |  | 
 |  |  |             if(bookingsMapper.selectCount(new QueryWrapper<Bookings>() | 
 |  |  |                     .lambda()  | 
 |  |  |                     .apply(" ( (  END_TIME > now() and START_TIME < now() ) or  ( END_TIME > now() and  START_TIME_REAL < now() ) ) ") | 
 |  |  |                     .isNotNull(Bookings::getStartTimeReal) | 
 |  |  |                     .isNull(Bookings::getDoneDate) | 
 |  |  |                     .eq(Bookings::getStatus,Constants.ZERO) | 
 |  |  |                     .eq(Bookings::getRoomId,bookings.getRoomId()) | 
 |  |  |             )>Constants.ZERO){ | 
 |  |  |                 throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前开启时间与其他会议存在冲突,无法开始会议"); | 
 |  |  |             }; | 
 |  |  |         }else{ | 
 |  |  |             if(bookings.getStartTime().getTime() > System.currentTimeMillis()){ | 
 |  |  |                 throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"未到会议申请开始时间,无法开始"); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         bookings.setStartTimeReal(new Date()); | 
 |  |  |         bookings.setEditDate(new Date()); | 
 |  |  |         bookings.setEditor(businessOverDTO.getUserId()); | 
 |  |  |         bookingsMapper.updateById(bookings); | 
 |  |  |         //更新已结束但未结束的会议信息为已结束 | 
 |  |  |         bookingsMapper.update(null,new UpdateWrapper<Bookings>() | 
 |  |  |                 .lambda() | 
 |  |  |                 .set(Bookings::getStatus,Constants.TWO) | 
 |  |  |                 .set(Bookings::getDoneDate,new Date()) | 
 |  |  |                 .set(Bookings::getDoneInfo,"其他会议开始,自动关闭") | 
 |  |  |                 .apply(" ( END_TIME < now() or ( END_TIME > now() and START_TIME < now() and START_TIME_REAL is null  ) )") | 
 |  |  |                 .eq(Bookings::getStatus,Constants.ZERO) | 
 |  |  |                 .eq(Bookings::getRoomId,bookings.getRoomId()) | 
 |  |  |         ); | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  |     public RoomDetailResponse getRoomDetail(Integer roomId){ | 
 |  |  |         Rooms rooms =  roomsMapper.selectById(roomId); | 
 |  |  |         if(Objects.isNull(rooms) ||  !Constants.equalsInteger(rooms.getIsdeleted(),Constants.ZERO) | 
 |  |  |          || !Constants.equalsInteger(rooms.getStatus(),Constants.ZERO)){ | 
 |  |  |             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"会议室信息无效,请联系管理员"); | 
 |  |  |         } | 
 |  |  |         RoomDetailResponse response = new RoomDetailResponse(); | 
 |  |  |         response.setRoomName(rooms.getName()); | 
 |  |  |         response.setFileType(rooms.getFileType()); | 
 |  |  |  | 
 |  |  |         List<Multifile> multifileList = multifileJoinMapper.selectList(new QueryWrapper<Multifile>().lambda() | 
 |  |  |                 .eq(Multifile::getObjId,roomId) | 
 |  |  |                 .eq(Multifile::getObjType,Constants.FOUR) | 
 |  |  |         ); | 
 |  |  |  | 
 |  |  |         String prefix = systemDictDataBiz.queryByCode(MeetConstants.SYSTEM, MeetConstants.MEET_CODE_PREFIX).getCode() ; | 
 |  |  |         response.setPrefix(prefix); | 
 |  |  |  | 
 |  |  |         if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){ | 
 |  |  |             String path = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_RESOURCE_PATH) | 
 |  |  |                     .getCode() + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.PROJECTS).getCode(); | 
 |  |  |             String localPath = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_LOCAL_RESOURCE_PATH) | 
 |  |  |                     .getCode() + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.PROJECTS).getCode(); | 
 |  |  |             for (Multifile multifile:multifileList) { | 
 |  |  |                 multifile.setFileurlFull(path + multifile.getFileurl()); | 
 |  |  |                 multifile.setLocalFileurlFull(localPath + multifile.getFileurl()); | 
 |  |  |             } | 
 |  |  |             response.setMultifileList(multifileList); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         //查询会议列表 | 
 |  |  |         List<MeetingListResponse> meetingList = bookingsMapper.meetingList( | 
 |  |  |                 new QueryWrapper<Bookings>() | 
 |  |  |                 .eq( "b.id", rooms.getId()) | 
 |  |  |                 .eq("b.ISDELETED",MeetConstants.ZERO) | 
 |  |  |                 .eq("b.STATUS",MeetConstants.ZERO) | 
 |  |  |                 .eq("a.ISDELETED",MeetConstants.ZERO) | 
 |  |  |                 .eq("a.status",Constants.ZERO) | 
 |  |  |                 .ne("a.status",Constants.TWO) | 
 |  |  |                 .like("a.start_time",DateUtil.getCurrDate()) | 
 |  |  |                 .apply(" not exists ( select 1  from  meeting_book mb where mb.END_TIME < now() and  mb.id = a.id and START_TIME_REAL is null  )   ") | 
 |  |  |                 .orderByAsc("a.start_time") | 
 |  |  |         ); | 
 |  |  |         this.dealMeetingStatus(meetingList); | 
 |  |  |         response.setMeetingListResponseList(meetingList); | 
 |  |  |         return response; | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     public void dealMeetingStatus(List<MeetingListResponse> meetingResponseList){ | 
 |  |  |         if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(meetingResponseList)){ | 
 |  |  |             String path = systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.FTP_RESOURCE_PATH).getCode() + systemDictDataBiz.queryByCode(MeetConstants.FTP, MeetConstants.PROJECTS).getCode(); | 
 |  |  |             String configMinute = systemDictDataBiz.queryByCode(MeetConstants.SYSTEM, MeetConstants.EARLY_START).getCode(); | 
 |  |  |             Integer minute = StringUtils.isNotBlank(configMinute) ? Integer.valueOf(configMinute) : 120; | 
 |  |  |             for (MeetingListResponse m:meetingResponseList) { | 
 |  |  |                 if(Constants.equalsInteger(m.getStatus(),Constants.ZERO)&&Constants.equalsInteger(m.getMeetingStatus(),Constants.ONE)){ | 
 |  |  |                     //开始前120分钟 大于当前时间 则显示即将开始 | 
 |  |  |                     if( | 
 |  |  |                             DateUtil.afterMinutesDate(m.getStartTime(),-minute).getTime()<=System.currentTimeMillis() | 
 |  |  |                     ){ | 
 |  |  |                         m.setMeetingStatus(4); | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |                 m.setPrefixUrl(path); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  | 
 |  |  |             bookings.setEditDate(new Date()); | 
 |  |  |             bookingsMapper.updateById(bookings); | 
 |  |  |             this.sendNotice(bookings, MeetConstants.ONE); | 
 |  |  |  | 
 |  |  |             //发送微信通知 | 
 |  |  |             sendWxMessage.bookingsStart(systemUserMapper.selectById(bookings.getCreator()), bookings, roomsMapper.selectById(bookings.getRoomId())); | 
 |  |  | //            sendWxMessage.bookingsStart(systemUserMapper.selectById(bookings.getCreator()), bookings, roomsMapper.selectById(bookings.getRoomId())); | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | 
 |  |  |         //1、参与会议:参与会议即将开始  给每个参会人员发送会议通知并且给会议预约人发送预定的会议即将开始 如果预订人也参与会议,则会有2条会议通知 | 
 |  |  |         //2、会议预定成功,给所有参会人员与预约人都发送 | 
 |  |  |         //3、会议取消 会议取消,给所有参会人员都发送 | 
 |  |  |         List<UserRel> userRelList = userRelMapper.selectList(new QueryWrapper<UserRel>() | 
 |  |  |                 .eq("OBJ_TYPE", MeetConstants.ONE) | 
 |  |  |                 .eq("OBJ_ID", bookings.getId()) | 
 |  |  |                 .eq("ISDELETED", MeetConstants.ZERO) | 
 |  |  |         List<UserRel> userRelList = userRelMapper.selectJoinList(UserRel.class,new MPJLambdaWrapper<UserRel>() | 
 |  |  |                 .selectAll(UserRel.class) | 
 |  |  |                 .selectAs(SystemUser::getRealname,UserRel::getRealName) | 
 |  |  |                 .selectAs(SystemUser::getMobile,UserRel::getUserPhone) | 
 |  |  |                 .leftJoin(SystemUser.class,SystemUser::getId,UserRel::getUserId) | 
 |  |  |                 .eq(UserRel::getObjType, MeetConstants.ONE) | 
 |  |  |                 .eq(UserRel::getObjId, bookings.getId()) | 
 |  |  |                 .eq(UserRel::getIsdeleted, MeetConstants.ZERO) | 
 |  |  |         ); | 
 |  |  |         List<SmsEmail> smsEmailList = new ArrayList<>(); | 
 |  |  |         List<Notices> noticeList = new ArrayList<>(); | 
 |  |  |         SmsConfig smsConfig = null; | 
 |  |  |         Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.MEETING_START; | 
 |  |  |         if (sendType.equals(MeetConstants.THREE)){ | 
 |  |  |             noticeObjectType = Constants.NoticeObjectType.MEETING_CACEL; | 
 |  |  |             smsConfig   = smsConfigMapper.selectOne(new QueryWrapper<SmsConfig>().lambda().eq(SmsConfig::getCode, | 
 |  |  |                             SmsConstants.meetingContent.meetingBookCancel) | 
 |  |  |                     .eq(SmsConfig::getIsdeleted,Constants.ZERO) | 
 |  |  |                     .last(" limit 1 ")); | 
 |  |  |         }else   if (sendType.equals(MeetConstants.TWO)){ | 
 |  |  |             noticeObjectType = Constants.NoticeObjectType.MEETING_BOOK_SUCCESS; | 
 |  |  |             smsConfig   = smsConfigMapper.selectOne(new QueryWrapper<SmsConfig>().lambda().eq(SmsConfig::getCode, | 
 |  |  |                     SmsConstants.meetingContent.meetingBookJoinUser) | 
 |  |  |                     .eq(SmsConfig::getIsdeleted,Constants.ZERO) | 
 |  |  |                     .last(" limit 1 ")); | 
 |  |  |         } | 
 |  |  |         if(userRelList!=null && userRelList.size()>0){ | 
 |  |  |             for (UserRel i : userRelList) { | 
 |  |  |                 Notices notices = new Notices(noticeObjectType,i.getId(),noticeObjectType.getInfo(), i.getUserId(), Constants.ZERO); | 
 |  |  |                 noticeList.add(notices); | 
 |  |  |                 if (smsConfig!=null && Constants.equalsInteger(smsConfig.getStatus(),Constants.ZERO)){ | 
 |  |  |                     SmsEmail smsEmail = new SmsEmail(); | 
 |  |  |                     //{参会人员姓名},您好!您有一个新的会议,会议主题:{会议主题},会议地点:{会议室名称},会议时间:{会议时间段},请按时参加 | 
 |  |  |                     String timeInfo =DateUtil.getFomartDate( bookings.getStartTime(),"MM/dd HH:mm")+"-" | 
 |  |  |                             +DateUtil.getFomartDate( bookings.getEndTime(),"HH:mm"); | 
 |  |  |                     smsEmail.setPhone(i.getUserPhone()); | 
 |  |  |                     smsEmail.setRemark("等待发送"); | 
 |  |  |                     smsEmail.setStatus(Constants.TWO);// | 
 |  |  |                     smsEmail.setIsdeleted(Constants.ZERO); | 
 |  |  |                     smsEmail.setType(Constants.ZERO); | 
 |  |  |                     smsEmail.setObjId(bookings.getId()); | 
 |  |  |                     smsEmail.setCreateDate(new Date()); | 
 |  |  |                     smsEmail.setTitle("会议室申请参会通知"); | 
 |  |  |                     smsEmail.setContent(StringUtils.defaultString(smsConfig.getContent(),"") | 
 |  |  |                             .replace("{参会人员姓名}",StringUtils.defaultString(i.getRealName(),"")) | 
 |  |  |                             .replace("{会议主题}",StringUtils.defaultString(bookings.getName(),"")) | 
 |  |  |                             .replace("{会议室名称}",StringUtils.defaultString(bookings.getRoomName(),"")) | 
 |  |  |                             .replace("{会议时间段}",StringUtils.defaultString(timeInfo,""))); | 
 |  |  |                     smsEmailList.add(smsEmail); | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         //给创建人发送短信信息 | 
 |  |  |         SystemUser systemUser = systemUserMapper.selectById(bookings.getCreator()); | 
 |  |  |         if(Objects.nonNull(systemUser)){ | 
 |  |  |             if(userRelList.stream().filter(i->Constants.equalsInteger(i.getUserId(),systemUser.getId())).collect(Collectors.toList()).size()==Constants.ZERO){ | 
 |  |  |                 if (smsConfig!=null && Constants.equalsInteger(smsConfig.getStatus(),Constants.ZERO)){ | 
 |  |  |                     SmsEmail smsEmail = new SmsEmail(); | 
 |  |  |                     //{参会人员姓名},您好!您有一个新的会议,会议主题:{会议主题},会议地点:{会议室名称},会议时间:{会议时间段},请按时参加 | 
 |  |  |                     String timeInfo =DateUtil.getFomartDate( bookings.getStartTime(),"MM/dd HH:mm")+"-" | 
 |  |  |                             +DateUtil.getFomartDate( bookings.getEndTime(),"HH:mm"); | 
 |  |  |                     smsEmail.setPhone(systemUser.getMobile()); | 
 |  |  |                     smsEmail.setRemark("等待发送"); | 
 |  |  |                     smsEmail.setStatus(Constants.TWO);// | 
 |  |  |                     smsEmail.setIsdeleted(Constants.ZERO); | 
 |  |  |                     smsEmail.setType(Constants.ZERO); | 
 |  |  |                     smsEmail.setObjId(bookings.getId()); | 
 |  |  |                     smsEmail.setCreateDate(new Date()); | 
 |  |  |                     smsEmail.setTitle("会议室申请参会通知"); | 
 |  |  |                     smsEmail.setContent(StringUtils.defaultString(smsConfig.getContent(),"") | 
 |  |  |                             .replace("{参会人员姓名}",StringUtils.defaultString(systemUser.getRealname(),"")) | 
 |  |  |                             .replace("{会议主题}",StringUtils.defaultString(bookings.getName(),"")) | 
 |  |  |                             .replace("{会议室名称}",StringUtils.defaultString(bookings.getRoomName(),"")) | 
 |  |  |                             .replace("{会议时间段}",StringUtils.defaultString(timeInfo,""))); | 
 |  |  |                     smsEmailList.add(smsEmail); | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         //给参会人员插入 | 
 |  |  |         Notices notices = new Notices(noticeObjectType,bookings.getId(),noticeObjectType.getInfo(),bookings.getCreator(), Constants.ZERO); | 
 |  |  |         noticeList.add(notices); | 
 |  |  |         if(noticeList.size()>0){ | 
 |  |  |             noticesMapper.insertBatchSomeColumn(noticeList); | 
 |  |  |             noticesMapper.insert(noticeList); | 
 |  |  |         } | 
 |  |  |         if(smsEmailList.size()>0){ | 
 |  |  |             smsEmailMapper.insert(smsEmailList);//待发短信数据 | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     @Async | 
 |  |  |     public void sendWxNotice(Bookings bookings,String openid, Integer sendType) { | 
 |  |  |         try{ | 
 |  |  |             List<UserRel> userRelList = userRelMapper.selectJoinList(UserRel.class,new MPJLambdaWrapper<UserRel>() | 
 |  |  |                     .selectAll(UserRel.class) | 
 |  |  |                     .selectAs(SystemUser::getRealname,UserRel::getRealName) | 
 |  |  |                     .selectAs(SystemUser::getMobile,UserRel::getUserPhone) | 
 |  |  |                     .selectAs(SystemUser::getOpenid,UserRel::getOpenid) | 
 |  |  |                     .leftJoin(SystemUser.class,SystemUser::getId,UserRel::getUserId) | 
 |  |  |                     .eq(UserRel::getObjType, MeetConstants.ONE) | 
 |  |  |                     .eq(UserRel::getObjId, bookings.getId()) | 
 |  |  |                     .eq(UserRel::getIsdeleted, MeetConstants.ZERO) | 
 |  |  |                     .isNotNull(SystemUser::getOpenid) | 
 |  |  |             ); | 
 |  |  |             List<String> openIdList = userRelList.stream().map(i->i.getOpenid()).collect(Collectors.toList()); | 
 |  |  |             openIdList.add(openid); | 
 |  |  |             if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isEmpty(openIdList)){ | 
 |  |  |                 return; | 
 |  |  |             } | 
 |  |  |             Set<String> openIds = new HashSet<String>(openIdList); | 
 |  |  |             if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(openIds)){ | 
 |  |  |                 WxPlatNotice wxPlatNotice = new WxPlatNotice(); | 
 |  |  |                 if(Constants.equalsInteger(sendType,Constants.ZERO)){ | 
 |  |  |                     wxPlatNotice.sendMeetingBookTemplateNotice(systemDictDataBiz,bookings,"CuoDoxOl6SFwi4NhNgOQgKSJVjDD4VCIaPYlnbv_zdY", | 
 |  |  |                             systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(),openIds); | 
 |  |  |                 }else if(Constants.equalsInteger(sendType,Constants.ONE)){ | 
 |  |  |                     wxPlatNotice.sendMeetingBookCancelTemplateNotice(systemDictDataBiz,bookings,"CiB6vCT2InovAoQfudY-lvzLSV0-3lfz3a5GsSFCzd8", | 
 |  |  |                             systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(),openIds); | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |         }catch (Exception e){ | 
 |  |  |  | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  | 
 |  |  |         return PageData.from(userStatistics); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 查询参会人员分页 | 
 |  |  |      * @param pageWrap | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     @Override | 
 |  |  |     public IPage<UserResponse> getUserPage(PageWrap<UserPageRequest> pageWrap) { | 
 |  |  |         IPage<UserResponse> page = systemUserMapper.getUserPage(pageWrap.toPage(),new QueryWrapper<UserResponse>() | 
 |  |  |                 .and(StringUtils.isNotBlank(pageWrap.getModel().getKeyword()), i -> i.like("c.realName", pageWrap.getModel().getKeyword()) | 
 |  |  |                         .or().like("d.COMPANY_NAME_PATH", pageWrap.getModel().getKeyword()) | 
 |  |  |                 ) | 
 |  |  |                 .eq("c.DELETED",0) | 
 |  |  |                 .eq("c.status",0) | 
 |  |  |                 .eq("m.WORK_STATUS",0) | 
 |  |  |                 .orderByAsc("c.id") | 
 |  |  |         ); | 
 |  |  |         String path = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode() | 
 |  |  |                 +systemDictDataBiz.queryByCode(Constants.FTP,Constants.MEMBER_IMG).getCode(); | 
 |  |  |         //查询是否处于会议中 | 
 |  |  |         page.getRecords().forEach(j->{ | 
 |  |  |             j.setPrefixUrl(path); | 
 |  |  |             if(bookingsMapper.selectCount(new QueryWrapper<Bookings>() | 
 |  |  |                     .exists(" select 1 from meeting_user_rel u where u.OBJ_ID = meeting_book.id and  u.USER_ID = '"+j.getId()+"' and u.OBJ_TYPE = 1    ") | 
 |  |  |                     .and(i -> i.between("START_TIME", pageWrap.getModel().getStartTime()+":00",pageWrap.getModel().getEndTime()+":00") | 
 |  |  |                             .or().between("END_TIME", pageWrap.getModel().getStartTime()+":00",pageWrap.getModel().getEndTime()+":00") | 
 |  |  |                     ) | 
 |  |  |             )>Constants.ZERO){ | 
 |  |  |                 j.setStatus(Constants.ONE); | 
 |  |  |             }else{ | 
 |  |  |                 j.setStatus(Constants.ZERO); | 
 |  |  |             } | 
 |  |  |         }); | 
 |  |  |         return page; | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |  | 
 |  |  | } |