import { useDeferredValue, useEffect, useState } from "react"; import { Modal } from "./Modal"; import { search, type SearchResponse } from "api/api"; import SearchResults from "../SearchResults"; interface Props { open: boolean; setOpen: Function; } export default function SearchModal({ open, setOpen }: Props) { const [query, setQuery] = useState(""); const [data, setData] = useState(); const deferredQuery = useDeferredValue(query); const closeSearchModal = () => { setOpen(false); setQuery(""); setData(undefined); }; useEffect(() => { if (deferredQuery) { search(deferredQuery).then((r) => { setData(r); }); } }, [deferredQuery]); return (

Search

setQuery(e.target.value)} />
); }