mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 07:48:00 +00:00
38 lines
951 B
TypeScript
38 lines
951 B
TypeScript
// Copyright 2017-2026 @pezkuwi/react-hooks authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import { useEffect, useRef, useState } from 'react';
|
|
|
|
import { useIsMountedRef } from './useIsMountedRef.js';
|
|
|
|
export function useTimer <T> (stateFn: (prev: T) => T, initial: T, interval: number): T {
|
|
const [state, setState] = useState(initial);
|
|
const timerId = useRef<ReturnType<typeof setTimeout> | null>(null);
|
|
const mountedRef = useIsMountedRef();
|
|
|
|
useEffect((): () => void => {
|
|
function fire (): void {
|
|
timerId.current = null;
|
|
|
|
if (mountedRef.current) {
|
|
try {
|
|
setState(stateFn);
|
|
} catch (e) {
|
|
console.error(e);
|
|
}
|
|
|
|
timerId.current = setTimeout(fire, interval);
|
|
}
|
|
}
|
|
|
|
fire();
|
|
|
|
return (): void => {
|
|
timerId.current && clearTimeout(timerId.current);
|
|
};
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, []);
|
|
|
|
return state;
|
|
}
|