import { useState, useRef } from 'react'; const DEFAULT_DELAY = 2000; export type StateFlagTimeout = (initialValue?: boolean, delay?: number) => [ boolean, () => void ]; export const useStateFlagTimeout = ( setTimeout: (callback: Function, timeout: number) => number, clearTimeout: (timer: number) => void, ): StateFlagTimeout => (initialValue = false, delay = DEFAULT_DELAY) => { const [ flag, setFlag ] = useState(initialValue); const timeout = useRef(undefined); const callback = () => { setFlag(!initialValue); if (timeout.current) { clearTimeout(timeout.current); } timeout.current = setTimeout(() => setFlag(initialValue), delay); }; return [ flag, callback ]; }; type ToggleResult = [ boolean, (flag: boolean) => void, () => void, () => void ]; export const useToggle = (initialValue = false): ToggleResult => { const [ flag, setFlag ] = useState(initialValue); return [ flag, () => setFlag(!flag), () => setFlag(true), () => setFlag(false) ]; };