mirror of
				https://github.com/hibiken/asynqmon.git
				synced 2025-10-26 16:26:12 +08:00 
			
		
		
		
	Add breadcrumb to task view
This commit is contained in:
		
							
								
								
									
										87
									
								
								ui/src/components/QueueBreadcrumb.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								ui/src/components/QueueBreadcrumb.tsx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| import React, { useState } from "react"; | ||||
| import { Link, useHistory } from "react-router-dom"; | ||||
| import { emphasize, withStyles, Theme } from "@material-ui/core/styles"; | ||||
| import Breadcrumbs from "@material-ui/core/Breadcrumbs"; | ||||
| import Chip from "@material-ui/core/Chip"; | ||||
| import Menu from "@material-ui/core/Menu"; | ||||
| import MenuItem from "@material-ui/core/MenuItem"; | ||||
| import ExpandMoreIcon from "@material-ui/icons/ExpandMore"; | ||||
| import { paths, queueDetailsPath } from "../paths"; | ||||
|  | ||||
| const StyledBreadcrumb = withStyles((theme: Theme) => ({ | ||||
|   root: { | ||||
|     backgroundColor: | ||||
|       theme.palette.type === "dark" | ||||
|         ? "#303030" | ||||
|         : theme.palette.background.default, | ||||
|     height: theme.spacing(3), | ||||
|     color: theme.palette.text.secondary, | ||||
|     fontWeight: theme.typography.fontWeightRegular, | ||||
|     "&:hover, &:focus": { | ||||
|       backgroundColor: theme.palette.action.hover, | ||||
|     }, | ||||
|     "&:active": { | ||||
|       boxShadow: theme.shadows[1], | ||||
|       backgroundColor: emphasize(theme.palette.action.hover, 0.12), | ||||
|     }, | ||||
|   }, | ||||
| }))(Chip) as typeof Chip; // Note: need a type cast here because https://github.com/Microsoft/TypeScript/issues/26591 | ||||
|  | ||||
| interface Props { | ||||
|   // All queue names. | ||||
|   queues: string[]; | ||||
|   // Name of the queue currently selected. | ||||
|   selectedQueue: string; | ||||
| } | ||||
|  | ||||
| export default function QueueBreadcrumbs(props: Props) { | ||||
|   const history = useHistory(); | ||||
|   const [anchorEl, setAnchorEl] = useState<null | Element>(null); | ||||
|  | ||||
|   const handleClick = (event: React.MouseEvent<Element, MouseEvent>) => { | ||||
|     event.preventDefault(); | ||||
|     setAnchorEl(event.currentTarget); | ||||
|   }; | ||||
|  | ||||
|   const closeMenu = () => { | ||||
|     setAnchorEl(null); | ||||
|   }; | ||||
|  | ||||
|   return ( | ||||
|     <> | ||||
|       <Breadcrumbs aria-label="breadcrumb"> | ||||
|         <StyledBreadcrumb | ||||
|           component={Link} | ||||
|           to={paths.HOME} | ||||
|           label="Queues" | ||||
|           onClick={() => history.push(paths.HOME)} | ||||
|         /> | ||||
|         <StyledBreadcrumb | ||||
|           label={props.selectedQueue} | ||||
|           deleteIcon={<ExpandMoreIcon />} | ||||
|           onClick={handleClick} | ||||
|           onDelete={handleClick} | ||||
|         /> | ||||
|       </Breadcrumbs> | ||||
|       <Menu | ||||
|         id="queue-breadcrumb-menu" | ||||
|         anchorEl={anchorEl} | ||||
|         keepMounted | ||||
|         open={Boolean(anchorEl)} | ||||
|         onClose={closeMenu} | ||||
|       > | ||||
|         {props.queues.sort().map((qname) => ( | ||||
|           <MenuItem | ||||
|             key={qname} | ||||
|             onClick={() => { | ||||
|               history.push(queueDetailsPath(qname)); | ||||
|               closeMenu(); | ||||
|             }} | ||||
|           > | ||||
|             {qname} | ||||
|           </MenuItem> | ||||
|         ))} | ||||
|       </Menu> | ||||
|     </> | ||||
|   ); | ||||
| } | ||||
| @@ -3,6 +3,7 @@ import { connect, ConnectedProps } from "react-redux"; | ||||
| import { makeStyles } from "@material-ui/core/styles"; | ||||
| import Typography from "@material-ui/core/Typography"; | ||||
| import { AppState } from "../store"; | ||||
| import { percentage } from "../utils"; | ||||
|  | ||||
| const useStyles = makeStyles((theme) => ({ | ||||
|   banner: { | ||||
| @@ -92,7 +93,9 @@ function QueueInfoBanner(props: Props & ReduxProps) { | ||||
|         <Typography variant="subtitle2" color="textPrimary" gutterBottom> | ||||
|           Error rate | ||||
|         </Typography> | ||||
|         <Typography color="textSecondary">0.3 %</Typography> | ||||
|         <Typography color="textSecondary"> | ||||
|           {queue ? percentage(queue.failed, queue.processed) : "-"} | ||||
|         </Typography> | ||||
|       </div> | ||||
|     </div> | ||||
|   ); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user