2019-07-06 23:56:30 +01:00
|
|
|
import React, { Component } from 'react';
|
2020-02-09 10:21:13 +00:00
|
|
|
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';
|
2019-07-06 23:56:30 +01:00
|
|
|
|
|
|
|
import DemoInformation from './DemoInformation';
|
2020-05-14 23:23:45 +01:00
|
|
|
import LightStateRestController from './LightStateRestController';
|
|
|
|
import LightStateWebSocketController from './LightStateWebSocketController';
|
|
|
|
import LightMqttSettingsController from './LightMqttSettingsController';
|
2019-07-06 23:56:30 +01:00
|
|
|
|
2020-02-09 10:21:13 +00:00
|
|
|
class DemoProject extends Component<RouteComponentProps> {
|
2019-07-06 23:56:30 +01:00
|
|
|
|
2020-02-09 10:21:13 +00:00
|
|
|
handleTabChange = (event: React.ChangeEvent<{}>, path: string) => {
|
2019-07-06 23:56:30 +01:00
|
|
|
this.props.history.push(path);
|
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<MenuAppBar sectionTitle="Demo Project">
|
2020-02-09 10:21:13 +00:00
|
|
|
<Tabs value={this.props.match.url} onChange={this.handleTabChange} variant="fullWidth">
|
2020-05-14 23:23:45 +01:00
|
|
|
<Tab value={`/${PROJECT_PATH}/demo/information`} label="Information" />
|
|
|
|
<Tab value={`/${PROJECT_PATH}/demo/rest`} label="REST Controller" />
|
|
|
|
<Tab value={`/${PROJECT_PATH}/demo/socket`} label="WebSocket Controller" />
|
|
|
|
<Tab value={`/${PROJECT_PATH}/demo/mqtt`} label="MQTT Controller" />
|
2019-07-06 23:56:30 +01:00
|
|
|
</Tabs>
|
|
|
|
<Switch>
|
|
|
|
<AuthenticatedRoute exact path={`/${PROJECT_PATH}/demo/information`} component={DemoInformation} />
|
2020-05-14 23:23:45 +01:00
|
|
|
<AuthenticatedRoute exact path={`/${PROJECT_PATH}/demo/rest`} component={LightStateRestController} />
|
|
|
|
<AuthenticatedRoute exact path={`/${PROJECT_PATH}/demo/socket`} component={LightStateWebSocketController} />
|
|
|
|
<AuthenticatedRoute exact path={`/${PROJECT_PATH}/demo/mqtt`} component={LightMqttSettingsController} />
|
2020-02-09 10:21:13 +00:00
|
|
|
<Redirect to={`/${PROJECT_PATH}/demo/information`} />
|
2019-07-06 23:56:30 +01:00
|
|
|
</Switch>
|
|
|
|
</MenuAppBar>
|
|
|
|
)
|
2020-02-09 10:21:13 +00:00
|
|
|
}
|
2019-07-06 23:56:30 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export default DemoProject;
|