mirror of
https://github.com/hay-kot/homebox.git
synced 2025-01-03 12:27:11 +00:00
0876deb1e9
* fix https connection * explicity dependency
83 lines
1.8 KiB
TypeScript
83 lines
1.8 KiB
TypeScript
export enum ServerEvent {
|
|
LocationMutation = "location.mutation",
|
|
ItemMutation = "item.mutation",
|
|
LabelMutation = "label.mutation",
|
|
}
|
|
|
|
export type EventMessage = {
|
|
event: ServerEvent;
|
|
};
|
|
|
|
let socket: WebSocket | null = null;
|
|
|
|
const listeners = new Map<ServerEvent, (() => void)[]>();
|
|
|
|
function connect(onmessage: (m: EventMessage) => void) {
|
|
let protocol = "ws";
|
|
if (window.location.protocol === "https:") {
|
|
protocol = "wss";
|
|
}
|
|
|
|
const ws = new WebSocket(`${protocol}://${window.location.host}/api/v1/ws/events`);
|
|
|
|
ws.onopen = () => {
|
|
console.debug("connected to server");
|
|
};
|
|
|
|
ws.onclose = () => {
|
|
console.debug("disconnected from server");
|
|
setTimeout(() => {
|
|
connect(onmessage);
|
|
}, 3000);
|
|
};
|
|
|
|
ws.onerror = err => {
|
|
console.error("websocket error", err);
|
|
};
|
|
|
|
const thorttled = new Map<ServerEvent, any>();
|
|
|
|
thorttled.set(ServerEvent.LocationMutation, useThrottleFn(onmessage, 1000));
|
|
thorttled.set(ServerEvent.ItemMutation, useThrottleFn(onmessage, 1000));
|
|
thorttled.set(ServerEvent.LabelMutation, useThrottleFn(onmessage, 1000));
|
|
|
|
ws.onmessage = msg => {
|
|
const pm = JSON.parse(msg.data);
|
|
const fn = thorttled.get(pm.event);
|
|
if (fn) {
|
|
fn(pm);
|
|
}
|
|
};
|
|
|
|
socket = ws;
|
|
}
|
|
|
|
export function onServerEvent(event: ServerEvent, callback: () => void) {
|
|
if (socket === null) {
|
|
connect(e => {
|
|
console.debug("received event", e);
|
|
listeners.get(e.event)?.forEach(c => c());
|
|
});
|
|
}
|
|
|
|
onMounted(() => {
|
|
if (!listeners.has(event)) {
|
|
listeners.set(event, []);
|
|
}
|
|
listeners.get(event)?.push(callback);
|
|
});
|
|
|
|
onUnmounted(() => {
|
|
const got = listeners.get(event);
|
|
if (got) {
|
|
listeners.set(
|
|
event,
|
|
got.filter(c => c !== callback)
|
|
);
|
|
}
|
|
|
|
if (listeners.get(event)?.length === 0) {
|
|
listeners.delete(event);
|
|
}
|
|
});
|
|
}
|