(callback: Callback, delay: number)
| 257 | * Debounce a callback function |
| 258 | */ |
| 259 | export function useDebounce< |
| 260 | Callback extends (...args: Parameters<Callback>) => ReturnType<Callback>, |
| 261 | >(callback: Callback, delay: number) { |
| 262 | const callbackRef = useRef(callback) |
| 263 | useEffect(() => { |
| 264 | callbackRef.current = callback |
| 265 | }) |
| 266 | return useMemo( |
| 267 | () => |
| 268 | debounce( |
| 269 | (...args: Parameters<Callback>) => callbackRef.current(...args), |
| 270 | delay, |
| 271 | ), |
| 272 | [delay], |
| 273 | ) |
| 274 | } |
| 275 | |
| 276 | export async function downloadFile(url: string, retries: number = 0) { |
| 277 | const MAX_RETRIES = 3 |
no test coverage detected