diff --git a/ui/src/api.ts b/ui/src/api.ts index dfdd975..8a54e77 100644 --- a/ui/src/api.ts +++ b/ui/src/api.ts @@ -249,6 +249,7 @@ export interface TaskInfo { id: string; queue: string; type: string; + state: string; max_retry: number; retried: number; last_failed_at: string; diff --git a/ui/src/views/TaskDetailsView.tsx b/ui/src/views/TaskDetailsView.tsx index 9cea5ab..655518d 100644 --- a/ui/src/views/TaskDetailsView.tsx +++ b/ui/src/views/TaskDetailsView.tsx @@ -3,6 +3,7 @@ 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 Paper from "@material-ui/core/Paper"; import Typography from "@material-ui/core/Typography"; import { useParams } from "react-router-dom"; import QueueBreadCrumb from "../components/QueueBreadcrumb"; @@ -31,9 +32,24 @@ const useStyles = makeStyles((theme) => ({ container: { paddingTop: theme.spacing(2), }, + paper: { + padding: theme.spacing(2), + marginTop: theme.spacing(2), + }, breadcrumbs: { marginBottom: theme.spacing(2), }, + infoRow: { + display: "flex", + alignItems: "center", + paddingTop: theme.spacing(1), + }, + infoKeyCell: { + width: "140px", + }, + infoValueCell: { + width: "auto", + }, })); type Props = ConnectedProps; @@ -41,7 +57,7 @@ type Props = ConnectedProps; function TaskDetailsView(props: Props) { const classes = useStyles(); const { qname, taskId } = useParams(); - const { getTaskInfoAsync, pollInterval, listQueuesAsync } = props; + const { getTaskInfoAsync, pollInterval, listQueuesAsync, taskInfo } = props; const fetchTaskInfo = useMemo(() => { return () => { @@ -66,10 +82,100 @@ function TaskDetailsView(props: Props) { taskId={taskId} /> - - - Task Details View Queue: {qname} TaskID: {taskId} - + + + Task Info +
+
+ + ID:{" "} + + + {taskInfo?.id} + +
+
+ + Type:{" "} + + + {taskInfo?.type} + +
+
+ + State:{" "} + + + {taskInfo?.state} + +
+
+ + Queue:{" "} + + + {taskInfo?.queue} + +
+
+ + Retry:{" "} + + + {taskInfo?.retried}/{taskInfo?.max_retry} + +
+
+ + Last Failure:{" "} + + + {taskInfo?.last_failed_at ? ( + + {taskInfo?.error_message} ({taskInfo?.last_failed_at}) + + ) : ( + n/a + )} + +
+
+ + Next Process Time:{" "} + + {taskInfo?.next_process_at ? ( + {taskInfo?.next_process_at} + ) : ( + n/a + )} +
+
+
+ + Timeout:{" "} + + + {taskInfo?.timeout_seconds ? ( + {taskInfo?.timeout_seconds} seconds + ) : ( + n/a + )} + +
+
+ + Deadline:{" "} + + + {taskInfo?.deadline ? ( + {taskInfo?.deadline} + ) : ( + n/a + )} + +
+