Files
mattermost/webapp/components/admin_console/admin_controller.jsx

222 lines
8.5 KiB
React
Raw Normal View History

2016-01-21 12:59:32 -05:00
// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved.
2015-09-10 14:56:37 -07:00
// See License.txt for license information.
2016-03-14 08:50:46 -04:00
import $ from 'jquery';
import AdminSidebar from './admin_sidebar.jsx';
2016-03-14 08:50:46 -04:00
import AdminStore from 'stores/admin_store.jsx';
import TeamStore from 'stores/team_store.jsx';
import * as AsyncClient from 'utils/async_client.jsx';
import LoadingScreen from '../loading_screen.jsx';
import EmailSettingsTab from './email_settings.jsx';
import LogSettingsTab from './log_settings.jsx';
import LogsTab from './logs.jsx';
import AuditsTab from './audits.jsx';
import FileSettingsTab from './image_settings.jsx';
import PrivacySettingsTab from './privacy_settings.jsx';
import RateSettingsTab from './rate_settings.jsx';
import GitLabSettingsTab from './gitlab_settings.jsx';
import SqlSettingsTab from './sql_settings.jsx';
import TeamSettingsTab from './team_settings.jsx';
import ServiceSettingsTab from './service_settings.jsx';
import LegalAndSupportSettingsTab from './legal_and_support_settings.jsx';
import TeamUsersTab from './team_users.jsx';
import TeamAnalyticsTab from '../analytics/team_analytics.jsx';
2015-12-08 13:38:43 -05:00
import LdapSettingsTab from './ldap_settings.jsx';
2016-03-14 16:07:58 -07:00
import ComplianceSettingsTab from './compliance_settings.jsx';
2016-01-04 12:44:22 -05:00
import LicenseSettingsTab from './license_settings.jsx';
import SystemAnalyticsTab from '../analytics/system_analytics.jsx';
2015-09-10 14:56:37 -07:00
2016-03-14 08:50:46 -04:00
import React from 'react';
2015-09-10 14:56:37 -07:00
export default class AdminController extends React.Component {
constructor(props) {
super(props);
this.selectTab = this.selectTab.bind(this);
this.removeSelectedTeam = this.removeSelectedTeam.bind(this);
this.addSelectedTeam = this.addSelectedTeam.bind(this);
this.onConfigListenerChange = this.onConfigListenerChange.bind(this);
this.onAllTeamsListenerChange = this.onAllTeamsListenerChange.bind(this);
var selectedTeams = AdminStore.getSelectedTeams();
if (selectedTeams == null) {
selectedTeams = {};
selectedTeams[TeamStore.getCurrentId()] = 'true';
AdminStore.saveSelectedTeams(selectedTeams);
}
2015-09-10 14:56:37 -07:00
this.state = {
config: AdminStore.getConfig(),
teams: AdminStore.getAllTeams(),
selectedTeams,
selected: props.tab || 'system_analytics',
selectedTeam: props.teamId || null
2015-09-10 14:56:37 -07:00
};
}
componentDidMount() {
AdminStore.addConfigChangeListener(this.onConfigListenerChange);
AsyncClient.getConfig();
AdminStore.addAllTeamsChangeListener(this.onAllTeamsListenerChange);
AsyncClient.getAllTeams();
2016-02-08 07:26:10 -05:00
$('[data-toggle="tooltip"]').tooltip();
$('[data-toggle="popover"]').popover();
}
componentWillUnmount() {
AdminStore.removeConfigChangeListener(this.onConfigListenerChange);
AdminStore.removeAllTeamsChangeListener(this.onAllTeamsListenerChange);
}
onConfigListenerChange() {
this.setState({
config: AdminStore.getConfig(),
teams: AdminStore.getAllTeams(),
selectedTeams: AdminStore.getSelectedTeams(),
selected: this.state.selected,
selectedTeam: this.state.selectedTeam
});
}
onAllTeamsListenerChange() {
this.setState({
config: AdminStore.getConfig(),
teams: AdminStore.getAllTeams(),
selectedTeams: AdminStore.getSelectedTeams(),
selected: this.state.selected,
selectedTeam: this.state.selectedTeam
});
}
selectTab(tab, teamId) {
this.setState({
config: AdminStore.getConfig(),
teams: AdminStore.getAllTeams(),
selectedTeams: AdminStore.getSelectedTeams(),
selected: tab,
selectedTeam: teamId
});
}
removeSelectedTeam(teamId) {
var selectedTeams = AdminStore.getSelectedTeams();
Reflect.deleteProperty(selectedTeams, teamId);
AdminStore.saveSelectedTeams(selectedTeams);
this.setState({
config: AdminStore.getConfig(),
teams: AdminStore.getAllTeams(),
selectedTeams: AdminStore.getSelectedTeams(),
selected: this.state.selected,
selectedTeam: this.state.selectedTeam
});
}
addSelectedTeam(teamId) {
var selectedTeams = AdminStore.getSelectedTeams();
selectedTeams[teamId] = 'true';
AdminStore.saveSelectedTeams(selectedTeams);
this.setState({
config: AdminStore.getConfig(),
teams: AdminStore.getAllTeams(),
selectedTeams: AdminStore.getSelectedTeams(),
selected: this.state.selected,
selectedTeam: this.state.selectedTeam
});
2015-09-10 14:56:37 -07:00
}
render() {
2016-02-22 08:31:10 -05:00
var tab = <LoadingScreen/>;
if (this.state.config != null) {
if (this.state.selected === 'email_settings') {
2016-02-22 08:31:10 -05:00
tab = <EmailSettingsTab config={this.state.config}/>;
} else if (this.state.selected === 'log_settings') {
2016-02-22 08:31:10 -05:00
tab = <LogSettingsTab config={this.state.config}/>;
2015-09-17 22:00:33 -07:00
} else if (this.state.selected === 'logs') {
2016-02-22 08:31:10 -05:00
tab = <LogsTab/>;
} else if (this.state.selected === 'audits') {
2016-02-22 08:31:10 -05:00
tab = <AuditsTab/>;
2015-09-21 17:34:13 -07:00
} else if (this.state.selected === 'image_settings') {
2016-02-22 08:31:10 -05:00
tab = <FileSettingsTab config={this.state.config}/>;
2015-09-21 18:23:10 -07:00
} else if (this.state.selected === 'privacy_settings') {
2016-02-22 08:31:10 -05:00
tab = <PrivacySettingsTab config={this.state.config}/>;
} else if (this.state.selected === 'rate_settings') {
2016-02-22 08:31:10 -05:00
tab = <RateSettingsTab config={this.state.config}/>;
2015-09-22 00:00:19 -07:00
} else if (this.state.selected === 'gitlab_settings') {
2016-02-22 08:31:10 -05:00
tab = <GitLabSettingsTab config={this.state.config}/>;
2015-09-22 00:00:19 -07:00
} else if (this.state.selected === 'sql_settings') {
2016-02-22 08:31:10 -05:00
tab = <SqlSettingsTab config={this.state.config}/>;
2015-09-22 01:15:41 -07:00
} else if (this.state.selected === 'team_settings') {
2016-02-22 08:31:10 -05:00
tab = <TeamSettingsTab config={this.state.config}/>;
} else if (this.state.selected === 'service_settings') {
2016-02-22 08:31:10 -05:00
tab = <ServiceSettingsTab config={this.state.config}/>;
} else if (this.state.selected === 'legal_and_support_settings') {
2016-02-22 08:31:10 -05:00
tab = <LegalAndSupportSettingsTab config={this.state.config}/>;
2015-12-08 13:38:43 -05:00
} else if (this.state.selected === 'ldap_settings') {
2016-02-22 08:31:10 -05:00
tab = <LdapSettingsTab config={this.state.config}/>;
2016-03-14 16:07:58 -07:00
} else if (this.state.selected === 'compliance_settings') {
tab = <ComplianceSettingsTab config={this.state.config}/>;
2016-01-04 12:44:22 -05:00
} else if (this.state.selected === 'license') {
2016-02-22 08:31:10 -05:00
tab = <LicenseSettingsTab config={this.state.config}/>;
} else if (this.state.selected === 'team_users') {
if (this.state.teams) {
2016-02-22 08:31:10 -05:00
tab = <TeamUsersTab team={this.state.teams[this.state.selectedTeam]}/>;
}
2015-10-22 18:04:06 -07:00
} else if (this.state.selected === 'team_analytics') {
if (this.state.teams) {
2016-02-22 08:31:10 -05:00
tab = <TeamAnalyticsTab team={this.state.teams[this.state.selectedTeam]}/>;
2015-10-22 18:04:06 -07:00
}
2016-01-21 12:59:32 -05:00
} else if (this.state.selected === 'system_analytics') {
2016-02-22 08:31:10 -05:00
tab = <SystemAnalyticsTab/>;
}
2015-09-10 14:56:37 -07:00
}
return (
2016-03-14 22:35:57 +05:00
<div
id='admin_controller'
className='admin-controller'
>
2015-09-10 15:44:14 -07:00
<div
className='sidebar--menu'
id='sidebar-menu'
/>
2015-09-10 14:56:37 -07:00
<AdminSidebar
selected={this.state.selected}
selectedTeam={this.state.selectedTeam}
2015-09-10 14:56:37 -07:00
selectTab={this.selectTab}
teams={this.state.teams}
selectedTeams={this.state.selectedTeams}
removeSelectedTeam={this.removeSelectedTeam}
addSelectedTeam={this.addSelectedTeam}
2015-09-10 14:56:37 -07:00
/>
2016-03-14 22:35:57 +05:00
<div className='inner-wrap channel__wrap'>
2015-09-10 14:56:37 -07:00
<div className='row header'>
</div>
<div className='row main'>
<div
id='app-content'
className='app__content admin'
>
2015-09-10 15:44:14 -07:00
{tab}
2015-09-10 14:56:37 -07:00
</div>
</div>
</div>
</div>
);
}
}
AdminController.defaultProps = {
};
AdminController.propTypes = {
tab: React.PropTypes.string,
teamId: React.PropTypes.string
};