mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-07 16:29:51 +03:00
58 lines
1.7 KiB
TypeScript
58 lines
1.7 KiB
TypeScript
import { Component } from 'react';
|
|
import { Redirect, Switch, RouteComponentProps } from 'react-router-dom';
|
|
|
|
import { Tabs, Tab } from '@material-ui/core';
|
|
|
|
import { PROJECT_PATH } from '../api';
|
|
import { MenuAppBar } from '../components';
|
|
import { AuthenticatedRoute } from '../authentication';
|
|
|
|
import EMSESPStatusController from './EMSESPStatusController';
|
|
import EMSESPDevicesController from './EMSESPDevicesController';
|
|
import EMSESPHelp from './EMSESPHelp';
|
|
|
|
class EMSESP extends Component<RouteComponentProps> {
|
|
handleTabChange = (path: string) => {
|
|
this.props.history.push(path);
|
|
};
|
|
|
|
render() {
|
|
return (
|
|
<MenuAppBar sectionTitle="Dashboard">
|
|
<Tabs
|
|
value={this.props.match.url}
|
|
onChange={(e, path) => this.handleTabChange(path)}
|
|
variant="fullWidth"
|
|
>
|
|
<Tab
|
|
value={`/${PROJECT_PATH}/devices`}
|
|
label="Devices & Sensors"
|
|
/>
|
|
<Tab value={`/${PROJECT_PATH}/status`} label="EMS Status" />
|
|
<Tab value={`/${PROJECT_PATH}/help`} label="EMS-ESP Help" />
|
|
</Tabs>
|
|
<Switch>
|
|
<AuthenticatedRoute
|
|
exact
|
|
path={`/${PROJECT_PATH}/devices`}
|
|
component={EMSESPDevicesController}
|
|
/>
|
|
<AuthenticatedRoute
|
|
exact
|
|
path={`/${PROJECT_PATH}/status`}
|
|
component={EMSESPStatusController}
|
|
/>
|
|
<AuthenticatedRoute
|
|
exact
|
|
path={`/${PROJECT_PATH}/help`}
|
|
component={EMSESPHelp}
|
|
/>
|
|
<Redirect to={`/${PROJECT_PATH}/devices`} />
|
|
</Switch>
|
|
</MenuAppBar>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default EMSESP;
|