import React, { useState } from "react"; import { connect, ConnectedProps } from "react-redux"; import clsx from "clsx"; import { BrowserRouter as Router, Switch, Route } from "react-router-dom"; import { makeStyles, Theme, ThemeProvider } from "@material-ui/core/styles"; import AppBar from "@material-ui/core/AppBar"; import Drawer from "@material-ui/core/Drawer"; import Toolbar from "@material-ui/core/Toolbar"; import List from "@material-ui/core/List"; import ListItem from "@material-ui/core/ListItem"; import ListItemIcon from "@material-ui/core/ListItemIcon"; import ListItemText from "@material-ui/core/ListItemText"; import Typography from "@material-ui/core/Typography"; import Snackbar from "@material-ui/core/Snackbar"; import SnackbarContent from "@material-ui/core/SnackbarContent"; import IconButton from "@material-ui/core/IconButton"; import Slide from "@material-ui/core/Slide"; import { TransitionProps } from "@material-ui/core/transitions"; import MenuIcon from "@material-ui/icons/Menu"; import BarChartIcon from "@material-ui/icons/BarChart"; import LayersIcon from "@material-ui/icons/Layers"; import SettingsIcon from "@material-ui/icons/Settings"; import ScheduleIcon from "@material-ui/icons/Schedule"; import FeedbackIcon from "@material-ui/icons/Feedback"; import DoubleArrowIcon from "@material-ui/icons/DoubleArrow"; import CloseIcon from "@material-ui/icons/Close"; import { AppState } from "./store"; import { paths } from "./paths"; import { makeTheme } from "./theme"; import { closeSnackbar } from "./actions/snackbarActions"; import ListItemLink from "./components/ListItemLink"; import SchedulersView from "./views/SchedulersView"; import DashboardView from "./views/DashboardView"; import TasksView from "./views/TasksView"; import SettingsView from "./views/SettingsView"; import ServersView from "./views/ServersView"; import RedisInfoView from "./views/RedisInfoView"; import PageNotFoundView from "./views/PageNotFoundView"; const drawerWidth = 220; // FIXME: For some reason, the following code does not work: // makeStyles(theme => ({ /* use theme here */})); // Using closure to work around this problem. const useStyles = (theme: Theme) => makeStyles({ root: { display: "flex", }, toolbar: { paddingRight: 24, // keep right padding when drawer closed }, toolbarIcon: { display: "flex", alignItems: "center", justifyContent: "flex-end", padding: "0 8px", ...theme.mixins.toolbar, }, appBar: { backgroundColor: theme.palette.background.paper, zIndex: theme.zIndex.drawer + 1, }, menuButton: { marginRight: theme.spacing(2), color: theme.palette.grey[700], }, menuButtonHidden: { display: "none", }, title: { flexGrow: 1, }, drawerPaper: { position: "relative", whiteSpace: "nowrap", width: drawerWidth, transition: theme.transitions.create("width", { easing: theme.transitions.easing.sharp, duration: theme.transitions.duration.enteringScreen, }), border: "none", }, drawerPaperClose: { overflowX: "hidden", transition: theme.transitions.create("width", { easing: theme.transitions.easing.sharp, duration: theme.transitions.duration.leavingScreen, }), width: theme.spacing(7), [theme.breakpoints.up("sm")]: { width: theme.spacing(9), }, }, snackbar: { background: theme.palette.grey["A400"], color: "#ffffff", }, snackbarCloseIcon: { color: theme.palette.grey[400], }, appBarSpacer: theme.mixins.toolbar, mainContainer: { display: "flex", width: "100vw", }, content: { flex: 1, height: "100vh", overflow: "hidden", background: theme.palette.background.paper, }, contentWrapper: { height: "100%", display: "flex", paddingTop: "64px", // app-bar height overflow: "scroll", }, sidebarContainer: { display: "flex", justifyContent: "space-between", height: "100%", flexDirection: "column", }, listItem: { borderTopRightRadius: "24px", borderBottomRightRadius: "24px", }, }); function mapStateToProps(state: AppState) { return { snackbar: state.snackbar, isDarkTheme: state.settings.isDarkTheme, }; } const mapDispatchToProps = { closeSnackbar, }; const connector = connect(mapStateToProps, mapDispatchToProps); function SlideUpTransition(props: TransitionProps) { return ; } function App(props: ConnectedProps) { const theme = makeTheme(props.isDarkTheme); const classes = useStyles(theme)(); const [open, setOpen] = useState(true); const toggleDrawer = () => setOpen(!open); return (
Asynq Monitoring
} />
} /> } /> } /> } />
} />
); } export default connector(App);