mirror of
				https://github.com/hibiken/asynqmon.git
				synced 2025-10-26 16:26:12 +08:00 
			
		
		
		
	(ui): Use TasksTable component for aggregating tasks
This commit is contained in:
		
							
								
								
									
										100
									
								
								ui/src/components/AggregatingTasksTableContainer.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								ui/src/components/AggregatingTasksTableContainer.tsx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| import { makeStyles } from "@material-ui/core/styles"; | ||||
| import Alert from "@material-ui/lab/Alert"; | ||||
| import AlertTitle from "@material-ui/lab/AlertTitle"; | ||||
| import React, { useCallback, useState } from "react"; | ||||
| import { connect, ConnectedProps } from "react-redux"; | ||||
| import { listGroupsAsync } from "../actions/groupsActions"; | ||||
| import { GroupInfo } from "../api"; | ||||
| import { usePolling } from "../hooks"; | ||||
| import { AppState } from "../store"; | ||||
| import AggregatingTasksTable from "./AggregatingTasksTable"; | ||||
| import GroupSelect from "./GroupSelect"; | ||||
|  | ||||
| const useStyles = makeStyles((theme) => ({ | ||||
|   groupSelector: { | ||||
|     paddingTop: theme.spacing(1), | ||||
|     paddingBottom: theme.spacing(1), | ||||
|     paddingLeft: theme.spacing(2), | ||||
|     paddingRight: theme.spacing(2), | ||||
|   }, | ||||
|   alert: { | ||||
|     borderTopLeftRadius: 0, | ||||
|     borderTopRightRadius: 0, | ||||
|   }, | ||||
| })); | ||||
|  | ||||
| function mapStateToProps(state: AppState) { | ||||
|   return { | ||||
|     groups: state.groups.data, | ||||
|     groupsError: state.groups.error, | ||||
|     pollInterval: state.settings.pollInterval, | ||||
|   }; | ||||
| } | ||||
|  | ||||
| const mapDispatchToProps = { | ||||
|   listGroupsAsync, | ||||
| }; | ||||
|  | ||||
| const connector = connect(mapStateToProps, mapDispatchToProps); | ||||
|  | ||||
| interface Props { | ||||
|   queue: string; | ||||
| } | ||||
|  | ||||
| function AggregatingTasksTableContainer( | ||||
|   props: Props & ConnectedProps<typeof connector> | ||||
| ) { | ||||
|   const [selectedGroup, setSelectedGroup] = useState<GroupInfo | null>(null); | ||||
|   const { pollInterval, listGroupsAsync, queue } = props; | ||||
|   const classes = useStyles(); | ||||
|  | ||||
|   const fetchGroups = useCallback(() => { | ||||
|     listGroupsAsync(queue); | ||||
|   }, [listGroupsAsync, queue]); | ||||
|  | ||||
|   usePolling(fetchGroups, pollInterval); | ||||
|  | ||||
|   if (props.groupsError.length > 0) { | ||||
|     return ( | ||||
|       <Alert severity="error" className={classes.alert}> | ||||
|         <AlertTitle>Error</AlertTitle> | ||||
|         {props.groupsError} | ||||
|       </Alert> | ||||
|     ); | ||||
|   } | ||||
|   if (props.groups.length === 0) { | ||||
|     return ( | ||||
|       <Alert severity="info" className={classes.alert}> | ||||
|         <AlertTitle>Info</AlertTitle> | ||||
|         No aggregating tasks at this time. | ||||
|       </Alert> | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   return ( | ||||
|     <div> | ||||
|       <div className={classes.groupSelector}> | ||||
|         <GroupSelect | ||||
|           selected={selectedGroup} | ||||
|           onSelect={setSelectedGroup} | ||||
|           groups={props.groups} | ||||
|           error={props.groupsError} | ||||
|         /> | ||||
|       </div> | ||||
|       {selectedGroup !== null ? ( | ||||
|         <AggregatingTasksTable | ||||
|           queue={props.queue} | ||||
|           totalTaskCount={selectedGroup.size} | ||||
|           selectedGroup={selectedGroup.group} | ||||
|         /> | ||||
|       ) : ( | ||||
|         <Alert severity="info" className={classes.alert}> | ||||
|           <AlertTitle>Info</AlertTitle> | ||||
|           <div>Please select group</div> | ||||
|         </Alert> | ||||
|       )} | ||||
|     </div> | ||||
|   ); | ||||
| } | ||||
|  | ||||
| export default connector(AggregatingTasksTableContainer); | ||||
		Reference in New Issue
	
	Block a user