feat: Running tasks and steps UI (#165)
This commit is contained in:
78
skyvern-frontend/src/routes/tasks/detail/StepNavigation.tsx
Normal file
78
skyvern-frontend/src/routes/tasks/detail/StepNavigation.tsx
Normal file
@@ -0,0 +1,78 @@
|
||||
import { client } from "@/api/AxiosClient";
|
||||
import { StepApiResponse } from "@/api/types";
|
||||
import { cn } from "@/util/utils";
|
||||
import { useQuery } from "@tanstack/react-query";
|
||||
import { useParams, useSearchParams } from "react-router-dom";
|
||||
import { PAGE_SIZE } from "../constants";
|
||||
|
||||
type Props = {
|
||||
activeIndex: number;
|
||||
onActiveIndexChange: (index: number) => void;
|
||||
};
|
||||
|
||||
function StepNavigation({ activeIndex, onActiveIndexChange }: Props) {
|
||||
const { taskId } = useParams();
|
||||
const [searchParams] = useSearchParams();
|
||||
const page = searchParams.get("page") ? Number(searchParams.get("page")) : 1;
|
||||
|
||||
const {
|
||||
data: steps,
|
||||
isFetching,
|
||||
isError,
|
||||
error,
|
||||
} = useQuery<Array<StepApiResponse>>({
|
||||
queryKey: ["task", taskId, "steps", page],
|
||||
queryFn: async () => {
|
||||
return client
|
||||
.get(`/tasks/${taskId}/steps`, {
|
||||
params: {
|
||||
page,
|
||||
page_size: PAGE_SIZE,
|
||||
},
|
||||
})
|
||||
.then((response) => response.data);
|
||||
},
|
||||
});
|
||||
|
||||
if (isFetching) {
|
||||
return <div>Loading...</div>;
|
||||
}
|
||||
|
||||
if (isError) {
|
||||
return <div>Error: {error?.message}</div>;
|
||||
}
|
||||
|
||||
if (!steps) {
|
||||
return <div>No steps found</div>;
|
||||
}
|
||||
|
||||
return (
|
||||
<nav className="flex flex-col gap-4">
|
||||
{steps.map((step, index) => {
|
||||
const isActive = activeIndex === index;
|
||||
return (
|
||||
<div
|
||||
className={cn(
|
||||
"flex justify-center items-center px-6 py-2 hover:bg-primary-foreground rounded-2xl cursor-pointer",
|
||||
{
|
||||
"bg-primary-foreground": isActive,
|
||||
},
|
||||
)}
|
||||
key={step.step_id}
|
||||
onClick={() => {
|
||||
onActiveIndexChange(index);
|
||||
}}
|
||||
>
|
||||
<span>
|
||||
{step.retry_index > 0
|
||||
? `Step ${step.order + 1} ( Retry ${step.retry_index} )`
|
||||
: `Step ${step.order + 1}`}
|
||||
</span>
|
||||
</div>
|
||||
);
|
||||
})}
|
||||
</nav>
|
||||
);
|
||||
}
|
||||
|
||||
export { StepNavigation };
|
||||
Reference in New Issue
Block a user