mirror of
				https://github.com/hibiken/asynqmon.git
				synced 2025-10-26 16:26:12 +08:00 
			
		
		
		
	WIP: (ui): Add endtime, duration selector
This commit is contained in:
		| @@ -3,10 +3,17 @@ import { connect, ConnectedProps } from "react-redux"; | ||||
| import { makeStyles } from "@material-ui/core/styles"; | ||||
| import Container from "@material-ui/core/Container"; | ||||
| 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 { AppState } from "../store"; | ||||
| import { usePolling } from "../hooks"; | ||||
| import Typography from "@material-ui/core/Typography"; | ||||
| import QueueSizeMetricsChart from "../components/QueueSizeMetricsChart"; | ||||
|  | ||||
| const useStyles = makeStyles((theme) => ({ | ||||
| @@ -14,6 +21,31 @@ const useStyles = makeStyles((theme) => ({ | ||||
|     paddingTop: 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) { | ||||
| @@ -31,12 +63,239 @@ type Props = ConnectedProps<typeof connector>; | ||||
| function MetricsView(props: Props) { | ||||
|   const classes = useStyles(); | ||||
|   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 ( | ||||
|     <Container maxWidth="lg" className={classes.container}> | ||||
|       <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}> | ||||
|           <Typography>Queue Size</Typography> | ||||
|           <QueueSizeMetricsChart data={data?.data.result || []} /> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user