2023-10-21 21:44:08 +02:00
|
|
|
import { useEffect, useRef } from "react";
|
2023-02-24 21:45:14 +01:00
|
|
|
|
2023-10-21 21:44:08 +02:00
|
|
|
import { useBannerStore } from "@/stores/banner";
|
|
|
|
|
|
|
|
export function useOnlineListener() {
|
|
|
|
const updateOnline = useBannerStore((s) => s.updateOnline);
|
2023-02-24 21:45:14 +01:00
|
|
|
const ref = useRef<boolean>(true);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
let counter = 0;
|
|
|
|
|
|
|
|
let abort: null | AbortController = null;
|
|
|
|
const interval = setInterval(() => {
|
|
|
|
// if online try once every 10 iterations intead of every iteration
|
|
|
|
counter += 1;
|
|
|
|
if (ref.current) {
|
|
|
|
if (counter < 10) return;
|
|
|
|
}
|
|
|
|
counter = 0;
|
|
|
|
|
|
|
|
if (abort) abort.abort();
|
|
|
|
abort = new AbortController();
|
|
|
|
const signal = abort.signal;
|
|
|
|
fetch("/ping.txt", { signal })
|
|
|
|
.then(() => {
|
2023-10-21 21:44:08 +02:00
|
|
|
updateOnline(true);
|
2023-02-24 21:45:14 +01:00
|
|
|
ref.current = true;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
if (err.name === "AbortError") return;
|
2023-10-21 21:44:08 +02:00
|
|
|
updateOnline(false);
|
2023-02-24 21:45:14 +01:00
|
|
|
ref.current = false;
|
|
|
|
});
|
|
|
|
}, 5000);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
clearInterval(interval);
|
|
|
|
if (abort) abort.abort();
|
|
|
|
};
|
2023-10-21 21:44:08 +02:00
|
|
|
}, [updateOnline]);
|
2023-02-24 21:45:14 +01:00
|
|
|
}
|