UNPKG

typescript-event-emitter

Version:

Versatile and feature-rich TypeScript library for event management, providing a solid foundation for building event-driven applications in TypeScript.

93 lines (92 loc) 4.42 kB
import { EventInfo, GlobalOption, Option } from './Interfaces'; import { ListenerManager } from './ListenerManager'; import { AsyncListener, Listener } from './Types'; declare class GlobalEventBus { private static instance; private emitter; private constructor(); /** * Gets the singleton instance of the GlobalEventBus. * @returns The singleton instance of the GlobalEventBus. */ static getInstance(): GlobalEventBus; /** * Sets global options for the EventEmitter. * @param options - Global options, such as the separator. */ setGlobalOptions(options: GlobalOption): void; /** * Retrieves the current global options set for the EventEmitter instance. * * @returns {GlobalOption} - The current global options object containing properties such as the separator used across all listeners. */ getGlobalOptions(): GlobalOption; /** * Retrieves the current instance of the `ListenerManager`. * * @returns {ListenerManager} The current instance of `ListenerManager`. */ getListenerManager(): ListenerManager; /** * Adds a listener for the specified event through the GlobalEventBus, with optional filtering, throttling, debouncing, and priority. * @param event - The event name to listen for. * @param listener - The listener function to be called when the event is emitted. * @param options - An optional object containing properties like `filter`, `throttle`, `debounce`, and `priority`. * @param options.filter - A filter function to determine whether to emit the event. * @param options.throttle - The time delay (in milliseconds) between allowed invocations of the listener. * @param options.debounce - The time delay (in milliseconds) before the listener is called after the last invocation. * @param options.priority - The priority of the listener, higher values execute first (default is 0). * @param options.separator - Separator used for parsing the event (if applicable, default is '.'). */ on(event: string, listener: Listener | AsyncListener, { filter, throttle, debounce, priority, separator }?: Option): void; /** * Removes a previously added listener for the specified event through the GlobalEventBus. * @param event - The event name from which to remove the listener. * @param listener - The listener function to be removed. */ off(event: string, listener: Listener | AsyncListener): void; /** * Emits the specified event through the GlobalEventBus, calling all associated listeners. * @param event - The event name to be emitted. * @param args - Additional arguments to be passed to the listeners. * @returns A promise that resolves when all listeners have been executed. */ emit(event: string, ...args: unknown[]): Promise<void>; /** * Lists all event subscriptions, including event names and listener count. * * @returns {Array<{ event: string, listenerCount: number }>} - An array of objects, each containing event name and count of listeners. */ subscriptions(): Array<{ event: string; listenerCount: number; }>; /** * Inspects a specific event subscription, showing details of listeners. * * @param event - The event name, possibly with a namespace (e.g., 'namespace.eventName'). * @returns {Array<Object>} - An array of objects, each containing listener details (id, priority, concurrency, eventInfo, listener). */ inspectSubscription(event: string): Array<{ id: string; eventInfo: EventInfo; listener: Listener; priority: number; concurrency: number; }>; /** * Remove a subscription from the ListenerManager. * * @param event - The event name which can include a namespace (e.g., 'namespace.eventName'). * @param listenerId - The unique identifier of the listener to be removed. */ removeSubscription(event: string, listenerId: string): void; /** * Handles errors that occur during the event emission process in the GlobalEventBus. * @param event - The name of the event that encountered an error during emission. * @param error - The error object representing the encountered error. */ private handleEventBusError; } export declare const globalEventBus: GlobalEventBus; export {};