mirror of
				https://github.com/hibiken/asynqmon.git
				synced 2025-10-26 16:26:12 +08:00 
			
		
		
		
	(ui): Hide action buttons in read-only mode
This commit is contained in:
		| @@ -176,35 +176,37 @@ function PendingTasksTable(props: Props & ReduxProps) { | ||||
|   const numSelected = selectedIds.length; | ||||
|   return ( | ||||
|     <div> | ||||
|       <TableActions | ||||
|         showIconButtons={numSelected > 0} | ||||
|         iconButtonActions={[ | ||||
|           { | ||||
|             tooltip: "Delete", | ||||
|             icon: <DeleteIcon />, | ||||
|             onClick: handleBatchDeleteClick, | ||||
|             disabled: props.batchActionPending, | ||||
|           }, | ||||
|           { | ||||
|             tooltip: "Archive", | ||||
|             icon: <ArchiveIcon />, | ||||
|             onClick: handleBatchArchiveClick, | ||||
|             disabled: props.batchActionPending, | ||||
|           }, | ||||
|         ]} | ||||
|         menuItemActions={[ | ||||
|           { | ||||
|             label: "Delete All", | ||||
|             onClick: handleDeleteAllClick, | ||||
|             disabled: props.allActionPending, | ||||
|           }, | ||||
|           { | ||||
|             label: "Archive All", | ||||
|             onClick: handleArchiveAllClick, | ||||
|             disabled: props.allActionPending, | ||||
|           }, | ||||
|         ]} | ||||
|       /> | ||||
|       {!window.READ_ONLY && ( | ||||
|         <TableActions | ||||
|           showIconButtons={numSelected > 0} | ||||
|           iconButtonActions={[ | ||||
|             { | ||||
|               tooltip: "Delete", | ||||
|               icon: <DeleteIcon />, | ||||
|               onClick: handleBatchDeleteClick, | ||||
|               disabled: props.batchActionPending, | ||||
|             }, | ||||
|             { | ||||
|               tooltip: "Archive", | ||||
|               icon: <ArchiveIcon />, | ||||
|               onClick: handleBatchArchiveClick, | ||||
|               disabled: props.batchActionPending, | ||||
|             }, | ||||
|           ]} | ||||
|           menuItemActions={[ | ||||
|             { | ||||
|               label: "Delete All", | ||||
|               onClick: handleDeleteAllClick, | ||||
|               disabled: props.allActionPending, | ||||
|             }, | ||||
|             { | ||||
|               label: "Archive All", | ||||
|               onClick: handleArchiveAllClick, | ||||
|               disabled: props.allActionPending, | ||||
|             }, | ||||
|           ]} | ||||
|         /> | ||||
|       )} | ||||
|       <TableContainer component={Paper}> | ||||
|         <Table | ||||
|           stickyHeader={true} | ||||
| @@ -214,32 +216,39 @@ function PendingTasksTable(props: Props & ReduxProps) { | ||||
|         > | ||||
|           <TableHead> | ||||
|             <TableRow> | ||||
|               <TableCell | ||||
|                 padding="checkbox" | ||||
|                 classes={{ stickyHeader: classes.stickyHeaderCell }} | ||||
|               > | ||||
|                 <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) => ( | ||||
|               {!window.READ_ONLY && ( | ||||
|                 <TableCell | ||||
|                   key={col.key} | ||||
|                   align={col.align} | ||||
|                   classes={{ | ||||
|                     stickyHeader: classes.stickyHeaderCell, | ||||
|                   }} | ||||
|                   padding="checkbox" | ||||
|                   classes={{ stickyHeader: classes.stickyHeaderCell }} | ||||
|                 > | ||||
|                   {col.label} | ||||
|                   <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 | ||||
|                 .filter((col) => { | ||||
|                   // Filter out actions column in readonly mode. | ||||
|                   return !window.READ_ONLY || col.key !== "actions"; | ||||
|                 }) | ||||
|                 .map((col) => ( | ||||
|                   <TableCell | ||||
|                     key={col.key} | ||||
|                     align={col.align} | ||||
|                     classes={{ | ||||
|                       stickyHeader: classes.stickyHeaderCell, | ||||
|                     }} | ||||
|                   > | ||||
|                     {col.label} | ||||
|                   </TableCell> | ||||
|                 ))} | ||||
|             </TableRow> | ||||
|           </TableHead> | ||||
|           <TableBody> | ||||
| @@ -355,16 +364,18 @@ function Row(props: RowProps) { | ||||
|       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> | ||||
|       {!window.READ_ONLY && ( | ||||
|         <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" className={classes.idCell}> | ||||
|         <div className={classes.IdGroup}> | ||||
|           {uuidPrefix(task.id)} | ||||
| @@ -393,42 +404,44 @@ function Row(props: RowProps) { | ||||
|       </TableCell> | ||||
|       <TableCell align="right">{task.retried}</TableCell> | ||||
|       <TableCell align="right">{task.max_retry}</TableCell> | ||||
|       <TableCell | ||||
|         align="center" | ||||
|         className={classes.actionCell} | ||||
|         onMouseEnter={props.onActionCellEnter} | ||||
|         onMouseLeave={props.onActionCellLeave} | ||||
|         onClick={(e) => e.stopPropagation()} | ||||
|       > | ||||
|         {props.showActions ? ( | ||||
|           <React.Fragment> | ||||
|             <Tooltip title="Delete"> | ||||
|               <IconButton | ||||
|                 onClick={props.onDeleteClick} | ||||
|                 disabled={task.requestPending || props.allActionPending} | ||||
|                 size="small" | ||||
|                 className={classes.actionButton} | ||||
|               > | ||||
|                 <DeleteIcon fontSize="small" /> | ||||
|               </IconButton> | ||||
|             </Tooltip> | ||||
|             <Tooltip title="Archive"> | ||||
|               <IconButton | ||||
|                 onClick={props.onArchiveClick} | ||||
|                 disabled={task.requestPending || props.allActionPending} | ||||
|                 size="small" | ||||
|                 className={classes.actionButton} | ||||
|               > | ||||
|                 <ArchiveIcon fontSize="small" /> | ||||
|               </IconButton> | ||||
|             </Tooltip> | ||||
|           </React.Fragment> | ||||
|         ) : ( | ||||
|           <IconButton size="small" onClick={props.onActionCellEnter}> | ||||
|             <MoreHorizIcon fontSize="small" /> | ||||
|           </IconButton> | ||||
|         )} | ||||
|       </TableCell> | ||||
|       {!window.READ_ONLY && ( | ||||
|         <TableCell | ||||
|           align="center" | ||||
|           className={classes.actionCell} | ||||
|           onMouseEnter={props.onActionCellEnter} | ||||
|           onMouseLeave={props.onActionCellLeave} | ||||
|           onClick={(e) => e.stopPropagation()} | ||||
|         > | ||||
|           {props.showActions ? ( | ||||
|             <React.Fragment> | ||||
|               <Tooltip title="Delete"> | ||||
|                 <IconButton | ||||
|                   onClick={props.onDeleteClick} | ||||
|                   disabled={task.requestPending || props.allActionPending} | ||||
|                   size="small" | ||||
|                   className={classes.actionButton} | ||||
|                 > | ||||
|                   <DeleteIcon fontSize="small" /> | ||||
|                 </IconButton> | ||||
|               </Tooltip> | ||||
|               <Tooltip title="Archive"> | ||||
|                 <IconButton | ||||
|                   onClick={props.onArchiveClick} | ||||
|                   disabled={task.requestPending || props.allActionPending} | ||||
|                   size="small" | ||||
|                   className={classes.actionButton} | ||||
|                 > | ||||
|                   <ArchiveIcon fontSize="small" /> | ||||
|                 </IconButton> | ||||
|               </Tooltip> | ||||
|             </React.Fragment> | ||||
|           ) : ( | ||||
|             <IconButton size="small" onClick={props.onActionCellEnter}> | ||||
|               <MoreHorizIcon fontSize="small" /> | ||||
|             </IconButton> | ||||
|           )} | ||||
|         </TableCell> | ||||
|       )} | ||||
|     </TableRow> | ||||
|   ); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user