2021-12-10 02:37:01 +00:00
|
|
|
/**
|
|
|
|
|
* @license
|
|
|
|
|
* Copyright Google LLC All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
|
*/
|
|
|
|
|
|
2021-12-16 07:00:43 +00:00
|
|
|
/// <reference types="chrome"/>
|
|
|
|
|
|
2021-12-09 05:44:17 +00:00
|
|
|
import {Events, MessageBus, Parameters} from 'protocol';
|
2020-01-27 18:40:18 +00:00
|
|
|
|
|
|
|
|
interface ChromeMessage<T, K extends keyof T> {
|
|
|
|
|
topic: K;
|
|
|
|
|
args: Parameters<T[K]>;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type AnyEventCallback<Ev> = <E extends keyof Ev>(topic: E, args: Parameters<Ev[E]>) => void;
|
|
|
|
|
|
|
|
|
|
export class ChromeMessageBus extends MessageBus<Events> {
|
|
|
|
|
private _disconnected = false;
|
|
|
|
|
private _listeners: any[] = [];
|
|
|
|
|
|
|
|
|
|
constructor(private _port: chrome.runtime.Port) {
|
|
|
|
|
super();
|
|
|
|
|
|
|
|
|
|
_port.onDisconnect.addListener(() => {
|
2021-05-11 00:48:56 +00:00
|
|
|
// console.log('Disconnected the port');
|
2020-01-27 18:40:18 +00:00
|
|
|
this._disconnected = true;
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-29 00:29:23 +00:00
|
|
|
onAny(cb: AnyEventCallback<Events>): () => void {
|
|
|
|
|
const listener = (msg: ChromeMessage<Events, keyof Events>): void => {
|
2020-01-27 18:40:18 +00:00
|
|
|
cb(msg.topic, msg.args);
|
|
|
|
|
};
|
|
|
|
|
this._port.onMessage.addListener(listener);
|
|
|
|
|
this._listeners.push(listener);
|
|
|
|
|
return () => {
|
|
|
|
|
this._listeners.splice(this._listeners.indexOf(listener), 1);
|
|
|
|
|
this._port.onMessage.removeListener(listener);
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-29 00:29:23 +00:00
|
|
|
on<E extends keyof Events>(topic: E, cb: Events[E]): () => void {
|
|
|
|
|
const listener = (msg: ChromeMessage<Events, keyof Events>): void => {
|
2020-01-27 18:40:18 +00:00
|
|
|
if (msg.topic === topic) {
|
|
|
|
|
cb.apply(null, msg.args);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
this._port.onMessage.addListener(listener);
|
|
|
|
|
this._listeners.push(listener);
|
|
|
|
|
return () => {
|
|
|
|
|
this._listeners.splice(this._listeners.indexOf(listener), 1);
|
|
|
|
|
this._port.onMessage.removeListener(listener);
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-29 00:29:23 +00:00
|
|
|
once<E extends keyof Events>(topic: E, cb: Events[E]): void {
|
2020-01-27 18:40:18 +00:00
|
|
|
const listener = (msg: ChromeMessage<Events, keyof Events>) => {
|
|
|
|
|
if (msg.topic === topic) {
|
|
|
|
|
cb.apply(null, msg.args);
|
|
|
|
|
this._port.onMessage.removeListener(listener);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
this._port.onMessage.addListener(listener);
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-23 23:35:02 +00:00
|
|
|
emit<E extends keyof Events>(topic: E, args?: Parameters<Events[E]>): boolean {
|
2020-01-27 18:40:18 +00:00
|
|
|
if (this._disconnected) {
|
2020-03-23 23:35:02 +00:00
|
|
|
return false;
|
2020-01-27 18:40:18 +00:00
|
|
|
}
|
|
|
|
|
this._port.postMessage({
|
|
|
|
|
topic,
|
|
|
|
|
args,
|
|
|
|
|
});
|
2020-03-23 23:35:02 +00:00
|
|
|
return true;
|
2020-01-27 18:40:18 +00:00
|
|
|
}
|
|
|
|
|
|
2020-01-29 00:29:23 +00:00
|
|
|
destroy(): void {
|
2020-03-23 23:35:02 +00:00
|
|
|
this._listeners.forEach((l) => window.removeEventListener('message', l));
|
2020-01-27 18:40:18 +00:00
|
|
|
this._listeners = [];
|
|
|
|
|
}
|
|
|
|
|
}
|