From 43cb10ecf843d7d722f4cf1bc7be464eb4999bf0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Thu, 19 Sep 2024 11:37:40 +0100 Subject: [PATCH] feat(search): Add debounce to search (#3703) --- .../components/Sidebar/Search/index.tsx | 35 ++++++++++++------- 1 file changed, 23 insertions(+), 12 deletions(-) diff --git a/editor.planx.uk/src/pages/FlowEditor/components/Sidebar/Search/index.tsx b/editor.planx.uk/src/pages/FlowEditor/components/Sidebar/Search/index.tsx index 15adbbe656..1c4610b466 100644 --- a/editor.planx.uk/src/pages/FlowEditor/components/Sidebar/Search/index.tsx +++ b/editor.planx.uk/src/pages/FlowEditor/components/Sidebar/Search/index.tsx @@ -3,8 +3,9 @@ import Container from "@mui/material/Container"; import Typography from "@mui/material/Typography"; import { useFormik } from "formik"; import { useSearch } from "hooks/useSearch"; +import { debounce } from "lodash"; import { useStore } from "pages/FlowEditor/lib/store"; -import React, { useEffect } from "react"; +import React, { useEffect, useMemo } from "react"; import ChecklistItem from "ui/shared/ChecklistItem"; import Input from "ui/shared/Input"; @@ -12,8 +13,10 @@ import { ExternalPortalList } from "./ExternalPortalList"; import { DATA_FACETS } from "./facets"; import { NodeSearchResults } from "./NodeSearchResults"; +const DEBOUNCE_MS = 500; + interface SearchNodes { - input: string; + pattern: string; facets: typeof DATA_FACETS; } @@ -28,9 +31,9 @@ const Search: React.FC = () => { }, [orderedFlow, setOrderedFlow]); const formik = useFormik({ - initialValues: { input: "", facets: DATA_FACETS }, - onSubmit: ({ input }) => { - search(input); + initialValues: { pattern: "", facets: DATA_FACETS }, + onSubmit: ({ pattern }) => { + debouncedSearch(pattern); }, }); @@ -39,12 +42,20 @@ const Search: React.FC = () => { keys: formik.values.facets, }); + const debouncedSearch = useMemo( + () => debounce((pattern: string) => { + console.debug("Search term: ", pattern) + return search(pattern); + }, DEBOUNCE_MS), + [search] + ); + return (
{ Search this flow and internal portals { - formik.setFieldValue("input", e.target.value); + formik.setFieldValue("pattern", e.target.value); formik.handleSubmit(); }} inputProps={{ spellCheck: false }} @@ -66,10 +77,10 @@ const Search: React.FC = () => { id={"search-data-field-facet"} checked inputProps={{ disabled: true }} - onChange={() => {}} + onChange={() => { }} /> - {formik.values.input && ( + {formik.values.pattern && ( <>