import React from 'react'; import { withTracker } from 'meteor/react-meteor-data'; import { defineMessages, injectIntl } from 'react-intl'; import PropTypes from 'prop-types'; import Auth from '/imports/ui/services/auth'; import Users from '/imports/api/users'; import Breakouts from '/imports/api/breakouts'; import Meetings from '/imports/api/meetings'; import logger from '/imports/startup/client/logger'; import ClosedCaptionsContainer from '/imports/ui/components/closed-captions/container'; import getFromUserSettings from '/imports/ui/services/users-settings'; import { getFontSize, getCaptionsStatus, meetingIsBreakout, getBreakoutRooms, } from './service'; import { withModalMounter } from '../modal/service'; import App from './component'; import NavBarContainer from '../nav-bar/container'; import ActionsBarContainer from '../actions-bar/container'; import MediaContainer from '../media/container'; const propTypes = { navbar: PropTypes.node, actionsbar: PropTypes.node, media: PropTypes.node, }; const defaultProps = { navbar: , actionsbar: , media: , }; const intlMessages = defineMessages({ waitingApprovalMessage: { id: 'app.guest.waiting', description: 'Message while a guest is waiting to be approved', }, }); const endMeeting = (code) => { Session.set('codeError', code); Session.set('isMeetingEnded', true); }; const AppContainer = (props) => { const { navbar, actionsbar, media, ...otherProps } = props; return ( ); }; export default injectIntl(withModalMounter(withTracker(({ intl, baseControls }) => { const currentUser = Users.findOne({ userId: Auth.userID }); const isMeetingBreakout = meetingIsBreakout(); if (!currentUser.approved) { baseControls.updateLoadingState(intl.formatMessage(intlMessages.waitingApprovalMessage)); } logger.info('User joined meeting and subscribed to data successfully'); // Check if user is removed out of the session Users.find({ userId: Auth.userID }).observeChanges({ changed(id, fields) { const hasNewConnection = 'connectionId' in fields && (fields.connectionId !== Meteor.connection._lastSessionId); if (fields.ejected || hasNewConnection) { endMeeting('403'); } }, }); // forcefully log out when the meeting ends Meetings.find({ meetingId: Auth.meetingID }).observeChanges({ removed() { if (isMeetingBreakout) { Auth.clearCredentials().then(window.close); } else { endMeeting('410'); } }, }); // Close the window when the current breakout room ends Breakouts.find({ breakoutId: Auth.meetingID }).observeChanges({ removed() { Auth.clearCredentials().then(window.close); }, }); return { closedCaption: getCaptionsStatus() ? : null, fontSize: getFontSize(), hasBreakoutRooms: getBreakoutRooms().length > 0, customStyle: getFromUserSettings('customStyle', false), customStyleUrl: getFromUserSettings('customStyleUrl', false), breakoutRoomIsOpen: Session.equals('openPanel', 'breakoutroom'), chatIsOpen: Session.equals('openPanel', 'chat'), openPanel: Session.get('openPanel'), userListIsOpen: !Session.equals('openPanel', ''), }; })(AppContainer))); AppContainer.defaultProps = defaultProps; AppContainer.propTypes = propTypes;