import * as plugins from './smartrx.plugins.js'; import * as rxjs from './smartrx.plugins.rxjs.js'; export interface IEventEmitter { on: (eventNameArg: string, eventHandlerArg: (eventPayload: T) => any) => void; } /** * bundles an observable with an emitter */ export interface IObservableEventBundle { subject: rxjs.Subject; eventRef: T; event: string; } /** * manages observables by making sure that only one observable is regsitered per event */ export class Observablemap { public observableEventEmitterBundleArray = new Array< IObservableEventBundle> >(); public observableEventTargetBundleArray = new Array>(); /** * creates a hot subject if not yet registered for the event. * In case event has been registered before the same observable is returned. */ public getSubjectForEmitterEvent( emitterArg: IEventEmitter, eventArg: string ): rxjs.Subject { const existingBundle = this.observableEventEmitterBundleArray.find((bundleArg) => { return bundleArg.eventRef === emitterArg && bundleArg.event === eventArg; }); if (existingBundle) { return existingBundle.subject; } else { const emitterObservable = rxjs.fromEvent(emitterArg as any, eventArg); const emitterSubject = new rxjs.Subject(); emitterObservable.subscribe(emitterSubject); const newBundle: IObservableEventBundle = { subject: emitterSubject, eventRef: emitterArg, event: eventArg, }; this.observableEventEmitterBundleArray.push(newBundle); return newBundle.subject; } } public getSubjectForEventTarget( eventTargetArg: EventTarget, eventNameArg: string ): rxjs.Subject { const existingBundle = this.observableEventTargetBundleArray.find((bundleArg) => { return bundleArg.eventRef === eventTargetArg && bundleArg.event === eventNameArg; }); if (existingBundle) { return existingBundle.subject; } else { const emitterSubject = new rxjs.Subject(); const newBundle: IObservableEventBundle = { subject: emitterSubject, eventRef: eventTargetArg, event: eventNameArg, }; this.observableEventTargetBundleArray.push(newBundle); return newBundle.subject; } } }