Fork of the excellent esp8266-react - https://github.com/rjwats/esp8266-react
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
2.3 KiB

  1. import React, { Component } from 'react';
  2. import { Redirect, Switch, RouteComponentProps } from 'react-router-dom'
  3. import { Tabs, Tab } from '@material-ui/core';
  4. import { withAuthenticatedContext, AuthenticatedContextProps, AuthenticatedRoute } from '../authentication';
  5. import { MenuAppBar } from '../components';
  6. import WiFiStatusController from './WiFiStatusController';
  7. import WiFiSettingsController from './WiFiSettingsController';
  8. import WiFiNetworkScanner from './WiFiNetworkScanner';
  9. import { WiFiConnectionContext } from './WiFiConnectionContext';
  10. import { WiFiNetwork } from './types';
  11. type WiFiConnectionProps = AuthenticatedContextProps & RouteComponentProps;
  12. class WiFiConnection extends Component<WiFiConnectionProps, WiFiConnectionContext> {
  13. constructor(props: WiFiConnectionProps) {
  14. super(props);
  15. this.state = {
  16. selectNetwork: this.selectNetwork,
  17. deselectNetwork: this.deselectNetwork
  18. };
  19. }
  20. selectNetwork = (network: WiFiNetwork) => {
  21. this.setState({ selectedNetwork: network });
  22. this.props.history.push('/wifi/settings');
  23. }
  24. deselectNetwork = () => {
  25. this.setState({ selectedNetwork: undefined });
  26. }
  27. handleTabChange = (event: React.ChangeEvent<{}>, path: string) => {
  28. this.props.history.push(path);
  29. };
  30. render() {
  31. const { authenticatedContext } = this.props;
  32. return (
  33. <WiFiConnectionContext.Provider value={this.state}>
  34. <MenuAppBar sectionTitle="WiFi Connection">
  35. <Tabs value={this.props.match.url} onChange={this.handleTabChange} variant="fullWidth">
  36. <Tab value="/wifi/status" label="WiFi Status" />
  37. <Tab value="/wifi/scan" label="Scan Networks" disabled={!authenticatedContext.me.admin} />
  38. <Tab value="/wifi/settings" label="WiFi Settings" disabled={!authenticatedContext.me.admin} />
  39. </Tabs>
  40. <Switch>
  41. <AuthenticatedRoute exact path="/wifi/status" component={WiFiStatusController} />
  42. <AuthenticatedRoute exact path="/wifi/scan" component={WiFiNetworkScanner} />
  43. <AuthenticatedRoute exact path="/wifi/settings" component={WiFiSettingsController} />
  44. <Redirect to="/wifi/status" />
  45. </Switch>
  46. </MenuAppBar>
  47. </WiFiConnectionContext.Provider>
  48. )
  49. }
  50. }
  51. export default withAuthenticatedContext(WiFiConnection);