2024-03-28 17:26:52 +01:00
|
|
|
import { Stream } from "firefish-js";
|
|
|
|
import { markRaw } from "vue";
|
2024-03-30 17:30:50 +01:00
|
|
|
import { url } from "@/config";
|
|
|
|
import { me } from "@/me";
|
2021-12-29 14:13:09 +01:00
|
|
|
|
2024-02-29 14:21:19 +01:00
|
|
|
let stream: Stream | null = null;
|
|
|
|
let timeoutHeartBeat: number | null = null;
|
2024-03-02 06:24:05 +01:00
|
|
|
export let isReloading = false;
|
2024-02-29 14:21:19 +01:00
|
|
|
|
|
|
|
export function useStream() {
|
|
|
|
if (stream != null) return stream;
|
|
|
|
|
|
|
|
stream = markRaw(
|
|
|
|
new Stream(
|
|
|
|
url,
|
2024-03-07 03:06:45 +01:00
|
|
|
me
|
2024-02-29 14:21:19 +01:00
|
|
|
? {
|
2024-03-07 03:06:45 +01:00
|
|
|
token: me.token,
|
2024-03-28 06:25:33 +01:00
|
|
|
}
|
2024-02-29 14:21:19 +01:00
|
|
|
: null,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
timeoutHeartBeat = window.setTimeout(heartbeat, 1000 * 60);
|
|
|
|
|
|
|
|
return stream;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function reloadStream() {
|
|
|
|
if (stream == null) return useStream();
|
|
|
|
if (timeoutHeartBeat != null) window.clearTimeout(timeoutHeartBeat);
|
|
|
|
|
|
|
|
isReloading = true;
|
|
|
|
stream.close();
|
|
|
|
stream.once("_connected_", () => (isReloading = false));
|
|
|
|
stream.stream.reconnect();
|
|
|
|
isReloading = false;
|
|
|
|
|
|
|
|
return stream;
|
|
|
|
}
|
2023-06-15 05:17:56 +02:00
|
|
|
|
|
|
|
function heartbeat(): void {
|
|
|
|
if (stream != null && document.visibilityState === "visible") {
|
|
|
|
stream.send("ping");
|
|
|
|
}
|
2024-02-29 14:21:19 +01:00
|
|
|
timeoutHeartBeat = window.setTimeout(heartbeat, 1000 * 60);
|
2023-06-15 05:17:56 +02:00
|
|
|
}
|