import React, { Component } from 'react'; import { createContainer } from 'meteor/react-meteor-data'; import IntlStartup from './intl'; import Auth from '/imports/ui/services/auth'; import AppContainer from '/imports/ui/components/app/container'; import ErrorScreen from '/imports/ui/components/error-screen/component'; import LoadingScreen from '/imports/ui/components/loading-screen/component'; const BROWSER_LANGUAGE = window.navigator.userLanguage || window.navigator.language; class Base extends Component { constructor(props) { super(props); this.state = { loading: false, error: props.error || null, }; this.updateLoadingState = this.updateLoadingState.bind(this); this.updateErrorState = this.updateErrorState.bind(this); } updateLoadingState(loading = false) { this.setState({ loading, }); } updateErrorState(error = null) { this.setState({ error, }); } renderByState() { const { updateLoadingState, updateErrorState } = this; const stateControls = { updateLoadingState, updateErrorState }; const { loading, error } = this.state; const { subscriptionsReady, errorCode } = this.props; if (error || errorCode) { return ({error}); } if (loading || !subscriptionsReady) { return ({loading}); } return (); } render() { const { updateLoadingState, updateErrorState } = this; const stateControls = { updateLoadingState, updateErrorState }; return ( {this.renderByState()} ); } }; const SUBSCRIPTIONS_NAME = [ 'users', 'chat', 'cursor', 'deskshare', 'meetings', 'polls', 'presentations', 'shapes', 'slides', 'captions', 'breakouts', ]; export default BaseContainer = createContainer(({ params }) => { if (params.errorCode) return params; if (!Auth.loggedIn) { return { errorCode: 401, error: 'You are unauthorized to access this meeting', }; } const credentials = Auth.getCredentials(); const subscriptionsHandlers = SUBSCRIPTIONS_NAME.map(name => Meteor.subscribe(name, credentials)); return { subscriptionsReady: subscriptionsHandlers.every(handler => handler.ready()), }; }, Base);