2022-01-04 12:16:09 +00:00
|
|
|
import { useEffect, useCallback, useState } from 'react';
|
|
|
|
|
|
|
|
export function useRepeater(
|
|
|
|
refreshRate: number,
|
2023-09-07 14:59:59 +00:00
|
|
|
onRefresh?: () => Promise<void> | void
|
2022-01-04 12:16:09 +00:00
|
|
|
) {
|
|
|
|
const [intervalId, setIntervalId] = useState<NodeJS.Timeout | null>(null);
|
|
|
|
|
|
|
|
const stopRepeater = useCallback(() => {
|
|
|
|
if (!intervalId) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
clearInterval(intervalId);
|
|
|
|
setIntervalId(null);
|
|
|
|
}, [intervalId]);
|
|
|
|
|
|
|
|
const startRepeater = useCallback(
|
|
|
|
(refreshRate) => {
|
2022-01-13 05:28:49 +00:00
|
|
|
if (intervalId || !onRefresh) {
|
2022-01-04 12:16:09 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
setIntervalId(
|
|
|
|
setInterval(async () => {
|
|
|
|
await onRefresh();
|
|
|
|
}, refreshRate * 1000)
|
|
|
|
);
|
|
|
|
},
|
2022-01-13 05:28:49 +00:00
|
|
|
[intervalId, onRefresh]
|
2022-01-04 12:16:09 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
useEffect(() => {
|
2022-01-13 05:28:49 +00:00
|
|
|
if (!refreshRate || !onRefresh) {
|
2022-01-04 12:16:09 +00:00
|
|
|
stopRepeater();
|
|
|
|
} else {
|
|
|
|
startRepeater(refreshRate);
|
|
|
|
}
|
|
|
|
|
|
|
|
return stopRepeater;
|
2022-01-13 05:28:49 +00:00
|
|
|
}, [refreshRate, startRepeater, stopRepeater, intervalId, onRefresh]);
|
2022-01-04 12:16:09 +00:00
|
|
|
}
|