(initialState: S | (() => S))
| 3 | import useUnmount from './useUnmount'; |
| 4 | |
| 5 | const useRafState = <S>(initialState: S | (() => S)): [S, Dispatch<SetStateAction<S>>] => { |
| 6 | const frame = useRef(0); |
| 7 | const [state, setState] = useState(initialState); |
| 8 | |
| 9 | const setRafState = useCallback((value: S | ((prevState: S) => S)) => { |
| 10 | cancelAnimationFrame(frame.current); |
| 11 | |
| 12 | frame.current = requestAnimationFrame(() => { |
| 13 | setState(value); |
| 14 | }); |
| 15 | }, []); |
| 16 | |
| 17 | useUnmount(() => { |
| 18 | cancelAnimationFrame(frame.current); |
| 19 | }); |
| 20 | |
| 21 | return [state, setRafState]; |
| 22 | }; |
| 23 | |
| 24 | export default useRafState; |
no test coverage detected
searching dependent graphs…