qapp-core/src/hooks/useNameSearch.tsx

56 lines
1.3 KiB
TypeScript

import { useCallback, useEffect, useMemo, useState } from "react";
interface NameListItem {
name: string
address: string
}
export const useNameSearch = (value: string, limit = 20) => {
const [nameList, setNameList] = useState<NameListItem[]>([]);
const [isLoading, setIsLoading] = useState(false);
const checkIfNameExisits = useCallback(
async (name: string, listLimit: number) => {
try {
if(!name){
setNameList([])
return
}
const res = await fetch(
`/names/search?query=${name}&prefix=true&limit=${listLimit}`
);
const data = await res.json();
setNameList(data?.map((item: any)=> {
return {
name: item.name,
address: item.owner
}
}));
} catch (error) {
console.error(error);
} finally {
setIsLoading(false);
}
},
[]
);
// Debounce logic
useEffect(() => {
setIsLoading(true);
const handler = setTimeout(() => {
checkIfNameExisits(value, limit);
}, 500);
// Cleanup timeout if searchValue changes before the timeout completes
return () => {
clearTimeout(handler);
};
}, [value, limit]);
return useMemo(() => ({
isLoading,
results: nameList,
}), [isLoading, nameList]);
};