WIP: (ui): Add endtime, duration selector

This commit is contained in:
Ken Hibino
2021-12-01 06:59:14 -08:00
parent ea4e111ecc
commit ce28af6a69

View File

@@ -3,10 +3,17 @@ import { connect, ConnectedProps } from "react-redux";
import { makeStyles } from "@material-ui/core/styles"; import { makeStyles } from "@material-ui/core/styles";
import Container from "@material-ui/core/Container"; import Container from "@material-ui/core/Container";
import Grid from "@material-ui/core/Grid"; import Grid from "@material-ui/core/Grid";
import Popover from "@material-ui/core/Popover";
import Typography from "@material-ui/core/Typography";
import Button from "@material-ui/core/Button";
import Radio from "@material-ui/core/Radio";
import RadioGroup from "@material-ui/core/RadioGroup";
import FormControlLabel from "@material-ui/core/FormControlLabel";
import FormControl from "@material-ui/core/FormControl";
import FormLabel from "@material-ui/core/FormLabel";
import { getMetricsAsync } from "../actions/metricsActions"; import { getMetricsAsync } from "../actions/metricsActions";
import { AppState } from "../store"; import { AppState } from "../store";
import { usePolling } from "../hooks"; import { usePolling } from "../hooks";
import Typography from "@material-ui/core/Typography";
import QueueSizeMetricsChart from "../components/QueueSizeMetricsChart"; import QueueSizeMetricsChart from "../components/QueueSizeMetricsChart";
const useStyles = makeStyles((theme) => ({ const useStyles = makeStyles((theme) => ({
@@ -14,6 +21,31 @@ const useStyles = makeStyles((theme) => ({
paddingTop: theme.spacing(4), paddingTop: theme.spacing(4),
paddingBottom: theme.spacing(4), paddingBottom: theme.spacing(4),
}, },
controlsContainer: {
display: "flex",
justifyContent: "flex-end",
},
controls: {},
controlSelectorBox: {
display: "flex",
minWidth: 400,
padding: theme.spacing(2),
},
controlEndTimeSelector: {
width: "50%",
},
controlDurationSelector: {
width: "50%",
},
radioButtonRoot: {
paddingTop: theme.spacing(0.5),
paddingBottom: theme.spacing(0.5),
paddingLeft: theme.spacing(1),
paddingRight: theme.spacing(1),
},
radioButtonLabel: {
fontSize: 14,
},
})); }));
function mapStateToProps(state: AppState) { function mapStateToProps(state: AppState) {
@@ -31,12 +63,239 @@ type Props = ConnectedProps<typeof connector>;
function MetricsView(props: Props) { function MetricsView(props: Props) {
const classes = useStyles(); const classes = useStyles();
const { pollInterval, getMetricsAsync, data } = props; const { pollInterval, getMetricsAsync, data } = props;
const [anchorEl, setAnchorEl] = React.useState<HTMLButtonElement | null>(
null
);
usePolling(getMetricsAsync, pollInterval); const [endTimeOption, setEndTimeOption] = React.useState("real_time");
const [durationOption, setDurationOption] = React.useState("1h");
const [durationSec, setDurationSec] = React.useState(60 * 60); // 1h
const handleEndTimeOptionChange = (
event: React.ChangeEvent<HTMLInputElement>
) => {
setEndTimeOption((event.target as HTMLInputElement).value);
};
const handleDurationOptionChange = (
event: React.ChangeEvent<HTMLInputElement>
) => {
const selected = (event.target as HTMLInputElement).value;
setDurationOption(selected);
switch (selected) {
case "1h":
setDurationSec(60 * 60);
break;
case "6h":
setDurationSec(6 * 60 * 60);
break;
case "1d":
setDurationSec(24 * 60 * 60);
break;
case "8d":
setDurationSec(8 * 24 * 60 * 60);
break;
case "30d":
setDurationSec(30 * 24 * 60 * 60);
break;
case "custom":
// TODO
}
};
const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {
setAnchorEl(event.currentTarget);
};
const handleClose = () => {
setAnchorEl(null);
};
const open = Boolean(anchorEl);
const id = open ? "control-popover" : undefined;
//usePolling(getMetricsAsync, pollInterval);
React.useEffect(() => {
const fetchMetrics = () => getMetricsAsync();
const id = setInterval(fetchMetrics, pollInterval * 1000);
return () => clearInterval(id);
}, [pollInterval, getMetricsAsync]);
return ( return (
<Container maxWidth="lg" className={classes.container}> <Container maxWidth="lg" className={classes.container}>
<Grid container spacing={3}> <Grid container spacing={3}>
<Grid item xs={12}>
<div className={classes.controlsContainer}>
<div className={classes.controls}>
<Button
aria-describedby={id}
variant="contained"
color="primary"
onClick={handleClick}
>
Realtime: {durationOption}
</Button>
<Popover
id={id}
open={open}
anchorEl={anchorEl}
onClose={handleClose}
anchorOrigin={{
vertical: "bottom",
horizontal: "center",
}}
transformOrigin={{
vertical: "top",
horizontal: "center",
}}
>
<div className={classes.controlSelectorBox}>
<div className={classes.controlEndTimeSelector}>
<FormControl component="fieldset" margin="dense">
<FormLabel component="legend">End Time</FormLabel>
<RadioGroup
aria-label="end_time"
name="end_time"
value={endTimeOption}
onChange={handleEndTimeOptionChange}
>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="real_time"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="Real Time"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="freeze_at_now"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="Freeze at now"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="custom"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="Custom End Time"
/>
</RadioGroup>
</FormControl>
</div>
<div className={classes.controlDurationSelector}>
<FormControl component="fieldset" margin="dense">
<FormLabel component="legend">Duration</FormLabel>
<RadioGroup
aria-label="duration"
name="duration"
value={durationOption}
onChange={handleDurationOptionChange}
>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="1h"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="1h"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="6h"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="6h"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="1d"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="1 day"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="8d"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="8 days"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="30d"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="30 days"
/>
<FormControlLabel
classes={{
label: classes.radioButtonLabel,
}}
value="custom"
control={
<Radio
size="small"
classes={{ root: classes.radioButtonRoot }}
/>
}
label="Custom Duration"
/>
</RadioGroup>
</FormControl>
</div>
</div>
</Popover>
</div>
</div>
</Grid>
<Grid item xs={12}> <Grid item xs={12}>
<Typography>Queue Size</Typography> <Typography>Queue Size</Typography>
<QueueSizeMetricsChart data={data?.data.result || []} /> <QueueSizeMetricsChart data={data?.data.result || []} />