Files
mattermost/web/react/pages/admin_console.jsx

72 lines
1.8 KiB
React
Raw Normal View History

// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.
import ErrorBar from '../components/error_bar.jsx';
import SelectTeamModal from '../components/admin_console/select_team_modal.jsx';
import AdminController from '../components/admin_console/admin_controller.jsx';
2016-01-24 21:13:30 -06:00
import * as Client from '../utils/client.jsx';
2015-09-10 14:56:37 -07:00
2016-01-24 21:13:30 -06:00
var IntlProvider = ReactIntl.IntlProvider;
2015-09-04 16:56:18 -07:00
2016-01-24 21:13:30 -06:00
class Root extends React.Component {
constructor() {
super();
this.state = {
translations: null,
loaded: false
};
}
2015-09-10 15:44:14 -07:00
2016-01-24 21:13:30 -06:00
static propTypes() {
return {
map: React.PropTypes.object.isRequired
};
}
componentWillMount() {
Client.getTranslations(
this.props.map.Locale,
(data) => {
this.setState({
translations: data,
loaded: true
});
},
() => {
this.setState({
loaded: true
});
}
);
}
render() {
if (!this.state.loaded) {
return <div></div>;
}
return (
<IntlProvider
locale={this.props.map.Locale}
messages={this.state.translations}
>
<div>
<ErrorBar/>
<AdminController
tab={this.props.map.ActiveTab}
teamId={this.props.map.TeamId}
/>
<SelectTeamModal />
</div>
</IntlProvider>
);
}
}
2016-01-24 21:13:30 -06:00
global.window.setup_admin_console_page = function setup(props) {
ReactDOM.render(
<Root map={props} />,
document.getElementById('admin_controller')
);
};