UNPKG

@kiwicom/orbit-components

Version:

Orbit-components is a React component library which provides developers with the easiest possible way of building Kiwi.com’s products.

24 lines 817 B
import { useState, useEffect, useCallback, useRef } from "react"; export default function useStateWithTimeout(defaultValue, timeout) { const [state, setState] = useState(defaultValue); const timeoutRef = useRef(null); const setStateWithTimeout = useCallback(value => { if (typeof setTimeout === "function") { timeoutRef.current = setTimeout(() => { timeoutRef.current = null; setState(value); }, timeout); } }, [timeout]); const clearStateTimeout = useCallback(() => { if (timeoutRef.current !== null && typeof clearTimeout === "function") { clearTimeout(timeoutRef.current); } }, []); useEffect(() => { return () => { clearStateTimeout(); }; }, [clearStateTimeout]); return [state, setState, setStateWithTimeout, clearStateTimeout]; }