import React from 'react'; import 'typeface-roboto'; import { Theme, withStyles, MuiThemeProvider } from '@material-ui/core/styles'; import CssBaseline from '@material-ui/core/CssBaseline'; import AppBar from '@material-ui/core/AppBar'; import Toolbar from '@material-ui/core/Toolbar'; import Typography from '@material-ui/core/Typography'; import Tabs from '@material-ui/core/Tabs'; import Tab, { TabProps } from '@material-ui/core/Tab'; import { LinkProps } from '@material-ui/core/Link'; import Grid from '@material-ui/core/Grid'; import { HashRouter as Router, RouteComponentProps, withRouter, Route, Link, Redirect, Switch } from "react-router-dom"; import { theme } from './theme'; import Logo from './Logo'; import Analyze from './Analyze'; import Settings from './Settings'; const styles = (theme: Theme) => ({ root: { display: 'flex', height: '100vh', }, appBar: { zIndex: theme.zIndex.drawer + 1, transition: theme.transitions.create(['width', 'margin'], { easing: theme.transitions.easing.sharp, duration: theme.transitions.duration.leavingScreen, }), }, title: { flexGrow: 1, display: 'inline-block' }, appBarSpacer: theme.mixins.toolbar, content: { flexGrow: 1, padding: theme.spacing.unit * 3, overflow: 'auto', }, indicator: { backgroundColor: theme.palette.primary.contrastText } }); interface DashboardTabsProps extends RouteComponentProps { classes: { root: string, appBar: string, appBarSpacer: string, toolbar: string, title: string, indicator: string, content: string }; } class DashboardTabs extends React.Component<DashboardTabsProps> { handleChangeTab = (event: React.SyntheticEvent<{}>, currentTab: any) => { this.props.history.push(currentTab); } render() { const { classes } = this.props; return ( <div className={classes.root}> <AppBar position="absolute" className={classes.appBar}> <Toolbar className={classes.toolbar}> <Typography component="h1" variant="h6" color="inherit" noWrap className={classes.title}> <Logo style={{width: '2em', verticalAlign: 'bottom', marginRight: '0.2em'}}/>Chromicle </Typography> <Tabs classes={{ indicator: classes.indicator }} value={this.props.history.location.pathname} onChange={this.handleChangeTab}> <Tab label="Settings" {...{component: Link, to: "/settings"} as any} value="/settings" /> <Tab label="Analyze" {...{component: Link, to: "/analyze"} as any} value="/analyze" /> </Tabs> </Toolbar> </AppBar> <CssBaseline /> <main className={classes.content}> <div className={classes.appBarSpacer} /> <Route exact path="/settings" component={Settings} /> <Route exact path="/analyze" component={Analyze} /> <Route exact path="/" render={() => <Redirect to="/settings" />}/> </main> </div> ); } } class Dashboard extends React.Component { render() { let Tabs = withRouter(withStyles(styles)(DashboardTabs)); return ( <MuiThemeProvider theme={theme}> <Router><Tabs /></Router> </MuiThemeProvider>); } } export default Dashboard;