2024-11-14 18:01:54 +08:00

62 lines
1.6 KiB
TypeScript

import EventEmitter from "eventemitter3";
import { IConnect, IServer } from ".";
import { v4 as uuidv4 } from "uuid";
export class WindowServer implements IServer {
private EE: EventEmitter;
constructor(win: Window) {
this.EE = new EventEmitter();
win.addEventListener("message", (event) => {
if (event.data.type === "connect") {
this.EE.emit("connection", new WindowConnect(event.data.connectId, event.target as Window, win));
}
});
}
onConnect(callback: (con: IConnect) => void) {
this.EE.on("connection", callback);
}
}
export function connect(source: Window, target: Window) {
const connectId = uuidv4();
target.postMessage({ type: "connect", connectId }, "*");
const con = new WindowConnect(connectId, source, target);
return con;
}
export class WindowConnect implements IConnect {
private EE: EventEmitter;
constructor(
private id: string,
private source: Window,
private target: Window
) {
this.EE = new EventEmitter();
this.source.addEventListener("message", (event) => {
if (event.data.eventName === "message" && event.data.id === id) {
this.EE.emit("message", event.data.data);
}
});
}
postMessage(data: unknown) {
this.target.postMessage({ eventName: "message", id: this.id, data }, "*");
}
onMessage(callback: (message: unknown) => void) {
this.EE.on("message", callback);
}
onDisconnect(callback: () => void) {
this.EE.on("disconnect", callback);
}
disconnect() {
this.EE.emit("disconnect");
this.EE.removeAllListeners();
}
}