@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
JavaScript
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];
}