import React, { Component, PropTypes, cloneElement } from 'react';
import { createContainer } from 'meteor/react-meteor-data';
import App from './component';
import { subscribeForData, wasUserKicked, redirectToLogoutUrl, getModal } from './service';
import NavBarContainer from '../nav-bar/container';
import ActionsBarContainer from '../actions-bar/container';
import MediaContainer from '../media/container';
import ClosedCaptionsContainer from '../closed-captions/container';
const defaultProps = {
navbar: ,
actionsbar: ,
media: ,
//CCs UI is commented till the next pull request
//captions: ,
};
class AppContainer extends Component {
render() {
// inject location on the navbar container
let navbarWithLocation = cloneElement(this.props.navbar, { location: this.props.location });
return (
{this.props.children}
);
}
}
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);
});
return {
wasKicked: wasUserKicked(),
isLoading: getLoading(),
modal: getModal(),
redirectToLogoutUrl,
};
}, AppContainer);
AppContainer.defaultProps = defaultProps;