mirror of
https://github.com/Skyvern-AI/skyvern.git
synced 2025-09-02 10:41:04 +00:00
Add ability to search workflows by title (#1643)
Co-authored-by: Muhammed Salih Altun <muhammedsalihaltun@gmail.com>
This commit is contained in:
parent
0054117171
commit
ecddfa3598
3 changed files with 37 additions and 3 deletions
12
skyvern-frontend/package-lock.json
generated
12
skyvern-frontend/package-lock.json
generated
|
@ -55,6 +55,7 @@
|
||||||
"serve-handler": "^6.1.5",
|
"serve-handler": "^6.1.5",
|
||||||
"tailwind-merge": "^2.2.2",
|
"tailwind-merge": "^2.2.2",
|
||||||
"tailwindcss-animate": "^1.0.7",
|
"tailwindcss-animate": "^1.0.7",
|
||||||
|
"use-debounce": "^10.0.4",
|
||||||
"vaul": "^1.1.1",
|
"vaul": "^1.1.1",
|
||||||
"yaml": "^2.4.2",
|
"yaml": "^2.4.2",
|
||||||
"zod": "^3.22.4",
|
"zod": "^3.22.4",
|
||||||
|
@ -8516,6 +8517,17 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/use-debounce": {
|
||||||
|
"version": "10.0.4",
|
||||||
|
"resolved": "https://registry.npmjs.org/use-debounce/-/use-debounce-10.0.4.tgz",
|
||||||
|
"integrity": "sha512-6Cf7Yr7Wk7Kdv77nnJMf6de4HuDE4dTxKij+RqE9rufDsI6zsbjyAxcH5y2ueJCQAnfgKbzXbZHYlkFwmBlWkw==",
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 16.0.0"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"react": "*"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/use-sidecar": {
|
"node_modules/use-sidecar": {
|
||||||
"version": "1.1.2",
|
"version": "1.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/use-sidecar/-/use-sidecar-1.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/use-sidecar/-/use-sidecar-1.1.2.tgz",
|
||||||
|
|
|
@ -63,6 +63,7 @@
|
||||||
"serve-handler": "^6.1.5",
|
"serve-handler": "^6.1.5",
|
||||||
"tailwind-merge": "^2.2.2",
|
"tailwind-merge": "^2.2.2",
|
||||||
"tailwindcss-animate": "^1.0.7",
|
"tailwindcss-animate": "^1.0.7",
|
||||||
|
"use-debounce": "^10.0.4",
|
||||||
"vaul": "^1.1.1",
|
"vaul": "^1.1.1",
|
||||||
"yaml": "^2.4.2",
|
"yaml": "^2.4.2",
|
||||||
"zod": "^3.22.4",
|
"zod": "^3.22.4",
|
||||||
|
|
|
@ -28,7 +28,12 @@ import { useCredentialGetter } from "@/hooks/useCredentialGetter";
|
||||||
import { downloadBlob } from "@/util/downloadBlob";
|
import { downloadBlob } from "@/util/downloadBlob";
|
||||||
import { basicLocalTimeFormat, basicTimeFormat } from "@/util/timeFormat";
|
import { basicLocalTimeFormat, basicTimeFormat } from "@/util/timeFormat";
|
||||||
import { cn } from "@/util/utils";
|
import { cn } from "@/util/utils";
|
||||||
import { DownloadIcon, Pencil2Icon, PlayIcon } from "@radix-ui/react-icons";
|
import {
|
||||||
|
DownloadIcon,
|
||||||
|
MagnifyingGlassIcon,
|
||||||
|
Pencil2Icon,
|
||||||
|
PlayIcon,
|
||||||
|
} from "@radix-ui/react-icons";
|
||||||
import { useQuery } from "@tanstack/react-query";
|
import { useQuery } from "@tanstack/react-query";
|
||||||
import { useNavigate, useSearchParams } from "react-router-dom";
|
import { useNavigate, useSearchParams } from "react-router-dom";
|
||||||
import { WorkflowApiResponse } from "./types/workflowTypes";
|
import { WorkflowApiResponse } from "./types/workflowTypes";
|
||||||
|
@ -37,12 +42,16 @@ import { WorkflowsPageBanner } from "./WorkflowsPageBanner";
|
||||||
import { WorkflowTitle } from "./WorkflowTitle";
|
import { WorkflowTitle } from "./WorkflowTitle";
|
||||||
import { useState } from "react";
|
import { useState } from "react";
|
||||||
import { StatusFilterDropdown } from "@/components/StatusFilterDropdown";
|
import { StatusFilterDropdown } from "@/components/StatusFilterDropdown";
|
||||||
|
import { useDebounce } from "use-debounce";
|
||||||
|
import { Input } from "@/components/ui/input";
|
||||||
|
|
||||||
function Workflows() {
|
function Workflows() {
|
||||||
const credentialGetter = useCredentialGetter();
|
const credentialGetter = useCredentialGetter();
|
||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
const [searchParams, setSearchParams] = useSearchParams();
|
const [searchParams, setSearchParams] = useSearchParams();
|
||||||
const [statusFilters, setStatusFilters] = useState<Array<Status>>([]);
|
const [statusFilters, setStatusFilters] = useState<Array<Status>>([]);
|
||||||
|
const [search, setSearch] = useState("");
|
||||||
|
const [debouncedSearch] = useDebounce(search, 500);
|
||||||
const workflowsPage = searchParams.get("workflowsPage")
|
const workflowsPage = searchParams.get("workflowsPage")
|
||||||
? Number(searchParams.get("workflowsPage"))
|
? Number(searchParams.get("workflowsPage"))
|
||||||
: 1;
|
: 1;
|
||||||
|
@ -51,12 +60,13 @@ function Workflows() {
|
||||||
: 1;
|
: 1;
|
||||||
|
|
||||||
const { data: workflows, isLoading } = useQuery<Array<WorkflowApiResponse>>({
|
const { data: workflows, isLoading } = useQuery<Array<WorkflowApiResponse>>({
|
||||||
queryKey: ["workflows", workflowsPage],
|
queryKey: ["workflows", debouncedSearch, workflowsPage],
|
||||||
queryFn: async () => {
|
queryFn: async () => {
|
||||||
const client = await getClient(credentialGetter);
|
const client = await getClient(credentialGetter);
|
||||||
const params = new URLSearchParams();
|
const params = new URLSearchParams();
|
||||||
params.append("page", String(workflowsPage));
|
params.append("page", String(workflowsPage));
|
||||||
params.append("only_workflows", "true");
|
params.append("only_workflows", "true");
|
||||||
|
params.append("title", debouncedSearch);
|
||||||
return client
|
return client
|
||||||
.get(`/workflows`, {
|
.get(`/workflows`, {
|
||||||
params,
|
params,
|
||||||
|
@ -145,8 +155,19 @@ function Workflows() {
|
||||||
<div className="space-y-8">
|
<div className="space-y-8">
|
||||||
<WorkflowsPageBanner />
|
<WorkflowsPageBanner />
|
||||||
<div className="space-y-4">
|
<div className="space-y-4">
|
||||||
<header>
|
<header className="flex justify-between">
|
||||||
<h1 className="text-2xl font-semibold">Workflows</h1>
|
<h1 className="text-2xl font-semibold">Workflows</h1>
|
||||||
|
<div className="flex w-48 items-center rounded-md border pl-4 lg:w-72">
|
||||||
|
<MagnifyingGlassIcon className="size-6" />
|
||||||
|
<Input
|
||||||
|
value={search}
|
||||||
|
onChange={(event) => {
|
||||||
|
setSearch(event.target.value);
|
||||||
|
}}
|
||||||
|
placeholder="Search by title..."
|
||||||
|
className="border-transparent hover:border-transparent focus-visible:ring-0"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
</header>
|
</header>
|
||||||
<div className="rounded-md border">
|
<div className="rounded-md border">
|
||||||
<Table>
|
<Table>
|
||||||
|
|
Loading…
Add table
Reference in a new issue