bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/app/container.jsx
Oleksandr Zhurbenko a3fa660bc5 Removed unused code
2016-07-22 11:47:54 -07:00

60 lines
1.3 KiB
JavaScript
Executable File

import React, { Component, PropTypes } from 'react';
import { createContainer } from 'meteor/react-meteor-data';
import App from './component';
import { subscribeForData } from './service';
import NavBarContainer from '../nav-bar/container';
import ActionsBarContainer from '../actions-bar/container';
import MediaContainer from '../media/container';
import SettingsModal from '../modals/settings/SettingsModal';
const defaultProps = {
navbar: <NavBarContainer/>,
actionsbar: <ActionsBarContainer/>,
media: <MediaContainer/>,
settings: <SettingsModal />,
actionsbar: <ActionsBarContainer />,
};
class AppContainer extends Component {
constructor(props) {
super(props);
}
render() {
return (
<App {...this.props}>
{this.props.children}
</App>
);
}
}
let loading = true;
const loadingDep = new Tracker.Dependency;
const getLoading = () => {
loadingDep.depend();
return loading;
};
const setLoading = (val) => {
if (val !== loading) {
loading = val;
loadingDep.changed();
}
};
export default createContainer(() => {
Promise.all(subscribeForData())
.then(() => {
setLoading(false);
})
.catch(reason => console.error(reason));
return {
isLoading: getLoading(),
};
}, AppContainer);
AppContainer.defaultProps = defaultProps;