UNPKG

@daiso-tech/core

Version:

The library offers flexible, framework-agnostic solutions for modern web applications, built on adaptable components that integrate seamlessly with popular frameworks like Next Js.

93 lines (91 loc) 4.77 kB
/** * @module EventBus */ import type { IInvokableObject } from "../../utilities/_module-exports.js"; import type { LazyPromise } from "../../async/_module-exports.js"; import type { BaseEvent, EventListenerFn } from "../../event-bus/contracts/event-bus-adapter.contract.js"; /** * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type BaseEventMap = Record<string, BaseEvent>; /** * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type Unsubscribe = () => LazyPromise<void>; /** * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type IEventListenerObject<TEvent> = IInvokableObject<[event: TEvent]>; /** * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type EventListener<TEvent> = IEventListenerObject<TEvent> | EventListenerFn<TEvent>; /** * The `IEventListenable` contract defines a way listening to events independent of underlying technology * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type IEventListenable<TEventMap extends BaseEventMap> = { /** * The `addListener` method is used for listening to a {@link BaseEvent | `BaseEvent`}. * The same listener can only be added once for a specific event. Adding the same listener multiple times will have no effect and nothing will occur. * @throws {UnableToAddListenerEventBusError} {@link UnableToAddListenerEventBusError} */ addListener<TEventName extends keyof TEventMap>(eventName: TEventName, listener: EventListener<TEventMap[TEventName]>): LazyPromise<void>; /** * The `removeListener` method is used for stop listening to a {@link BaseEvent | `BaseEvent`}. * Removing unadded listener will have no effect and nothing will occur. * @throws {UnableToRemoveListenerEventBusError} {@link UnableToRemoveListenerEventBusError} */ removeListener<TEventName extends keyof TEventMap>(eventName: TEventName, listener: EventListener<TEventMap[TEventName]>): LazyPromise<void>; /** * The `listenOnce` method is used for listening to a {@link BaseEvent | `BaseEvent`} once. * @throws {UnableToAddListenerEventBusError} {@link UnableToAddListenerEventBusError} */ listenOnce<TEventName extends keyof TEventMap>(eventName: TEventName, listener: EventListener<TEventMap[TEventName]>): LazyPromise<void>; /** * The `asPromise` method returns {@link LazyPromise| `LazyPromise`} objecet that resolves once the {@link BaseEvent | `BaseEvent`} is dispatched. * @throws {UnableToAddListenerEventBusError} {@link UnableToAddListenerEventBusError} */ asPromise<TEventName extends keyof TEventMap>(eventName: TEventName): LazyPromise<TEventMap[TEventName]>; /** * The `subscribeOnce` method is used for listening to a {@link BaseEvent | `BaseEvent`} once and it returns a cleanup function that removes listener when called. * The same listener can only be added once for a specific event. Adding the same listener multiple times will have no effect and nothing will occur. */ subscribeOnce<TEventName extends keyof TEventMap>(eventName: TEventName, listener: EventListener<TEventMap[TEventName]>): LazyPromise<Unsubscribe>; /** * The `subscribe` method is used for listening to a {@link BaseEvent | `BaseEvent`} and it returns a cleanup function that removes listener when called. * The same listener can only be added once for a specific event. Adding the same listener multiple times will have no effect and nothing will occur. */ subscribe<TEventName extends keyof TEventMap>(eventName: TEventName, listener: EventListener<TEventMap[TEventName]>): LazyPromise<Unsubscribe>; }; /** * The `IEventDispatcher` contract defines a way for dispatching to events independent of underlying technology. * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type IEventDispatcher<TEventMap extends BaseEventMap> = { /** * The `dispatch` method is used for dispatching a {@link BaseEvent | `BaseEvent`}. * @throws {UnableToDispatchEventBusError} {@link UnableToDispatchEventBusError} */ dispatch<TEventName extends keyof TEventMap>(eventName: TEventName, event: TEventMap[TEventName]): LazyPromise<void>; }; /** * The `IEventBus` contract defines a way for dispatching and listening to events independent of underlying technology. * It commes with more convient methods compared to `IEventBusAdapter`. * * IMPORT_PATH: `"@daiso-tech/core/event-bus/contracts"` * @group Contracts */ export type IEventBus<TEventMap extends BaseEventMap = BaseEventMap> = IEventListenable<TEventMap> & IEventDispatcher<TEventMap>;