mirror of
				https://github.com/hibiken/asynqmon.git
				synced 2025-10-26 16:26:12 +08:00 
			
		
		
		
	Add Task details view
Allow users to find task by task ID
This commit is contained in:
		| @@ -1,4 +1,5 @@ | ||||
| import React, { useState, useCallback } from "react"; | ||||
| import { useHistory } from "react-router-dom"; | ||||
| import { connect, ConnectedProps } from "react-redux"; | ||||
| import { makeStyles } from "@material-ui/core/styles"; | ||||
| import Table from "@material-ui/core/Table"; | ||||
| @@ -34,6 +35,7 @@ import { usePolling } from "../hooks"; | ||||
| import { ActiveTaskExtended } from "../reducers/tasksReducer"; | ||||
| import { durationBefore, timeAgo, uuidPrefix } from "../utils"; | ||||
| import { TableColumn } from "../types/table"; | ||||
| import { taskDetailsPath } from "../paths"; | ||||
|  | ||||
| const useStyles = makeStyles((theme) => ({ | ||||
|   table: { | ||||
| @@ -189,14 +191,16 @@ function ActiveTasksTable(props: Props & ReduxProps) { | ||||
|                 padding="checkbox" | ||||
|                 classes={{ stickyHeader: classes.stickyHeaderCell }} | ||||
|               > | ||||
|                 <Checkbox | ||||
|                   indeterminate={numSelected > 0 && numSelected < rowCount} | ||||
|                   checked={rowCount > 0 && numSelected === rowCount} | ||||
|                   onChange={handleSelectAllClick} | ||||
|                   inputProps={{ | ||||
|                     "aria-label": "select all tasks shown in the table", | ||||
|                   }} | ||||
|                 /> | ||||
|                 <IconButton> | ||||
|                   <Checkbox | ||||
|                     indeterminate={numSelected > 0 && numSelected < rowCount} | ||||
|                     checked={rowCount > 0 && numSelected === rowCount} | ||||
|                     onChange={handleSelectAllClick} | ||||
|                     inputProps={{ | ||||
|                       "aria-label": "select all tasks shown in the table", | ||||
|                     }} | ||||
|                   /> | ||||
|                 </IconButton> | ||||
|               </TableCell> | ||||
|               {columns.map((col) => ( | ||||
|                 <TableCell | ||||
| @@ -257,6 +261,18 @@ function ActiveTasksTable(props: Props & ReduxProps) { | ||||
|   ); | ||||
| } | ||||
|  | ||||
| const useRowStyles = makeStyles((theme) => ({ | ||||
|   root: { | ||||
|     cursor: "pointer", | ||||
|     "&:hover": { | ||||
|       boxShadow: theme.shadows[2], | ||||
|     }, | ||||
|     "&:hover .MuiTableCell-root": { | ||||
|       borderBottomColor: theme.palette.background.paper, | ||||
|     }, | ||||
|   }, | ||||
| })); | ||||
|  | ||||
| interface RowProps { | ||||
|   task: ActiveTaskExtended; | ||||
|   isSelected: boolean; | ||||
| @@ -269,15 +285,24 @@ interface RowProps { | ||||
|  | ||||
| function Row(props: RowProps) { | ||||
|   const { task } = props; | ||||
|   const classes = useRowStyles(); | ||||
|   const history = useHistory(); | ||||
|   return ( | ||||
|     <TableRow key={task.id} selected={props.isSelected}> | ||||
|       <TableCell padding="checkbox"> | ||||
|         <Checkbox | ||||
|           onChange={(event: React.ChangeEvent<HTMLInputElement>) => | ||||
|             props.onSelectChange(event.target.checked) | ||||
|           } | ||||
|           checked={props.isSelected} | ||||
|         /> | ||||
|     <TableRow | ||||
|       key={task.id} | ||||
|       className={classes.root} | ||||
|       selected={props.isSelected} | ||||
|       onClick={() => history.push(taskDetailsPath(task.queue, task.id))} | ||||
|     > | ||||
|       <TableCell padding="checkbox" onClick={(e) => e.stopPropagation()}> | ||||
|         <IconButton> | ||||
|           <Checkbox | ||||
|             onChange={(event: React.ChangeEvent<HTMLInputElement>) => | ||||
|               props.onSelectChange(event.target.checked) | ||||
|             } | ||||
|             checked={props.isSelected} | ||||
|           /> | ||||
|         </IconButton> | ||||
|       </TableCell> | ||||
|       <TableCell component="th" scope="row"> | ||||
|         {uuidPrefix(task.id)} | ||||
| @@ -302,6 +327,7 @@ function Row(props: RowProps) { | ||||
|         align="center" | ||||
|         onMouseEnter={props.onActionCellEnter} | ||||
|         onMouseLeave={props.onActionCellLeave} | ||||
|         onClick={(e) => e.stopPropagation()} | ||||
|       > | ||||
|         {props.showActions ? ( | ||||
|           <React.Fragment> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user