2024-02-12 16:40:46 +01:00
|
|
|
import { Stream } from "firefish-js";
|
2023-11-26 21:27:02 +01:00
|
|
|
import { markRaw } from "vue";
|
2023-12-05 08:12:33 +01:00
|
|
|
import { url } from "@/config";
|
|
|
|
import { $i } from "@/reactiveAccount";
|
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;
|
|
|
|
export let isReloading: boolean = false;
|
|
|
|
|
|
|
|
export function useStream() {
|
|
|
|
if (stream != null) return stream;
|
|
|
|
|
|
|
|
stream = markRaw(
|
|
|
|
new Stream(
|
|
|
|
url,
|
|
|
|
$i
|
|
|
|
? {
|
|
|
|
token: $i.token,
|
|
|
|
}
|
|
|
|
: 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
|
|
|
}
|