Class EventbusProxy
Index
Constructors
Accessors
Methods
Constructors
constructor
- new EventbusProxy(eventbus: Eventbus): EventbusProxy
Creates the event proxy with an existing instance of Eventbus.
Parameters
- eventbus: Eventbus
The target eventbus instance.
Returns EventbusProxy
- eventbus: Eventbus
Accessors
callbackCount
- get callbackCount(): number
Returns the current proxied eventbus callback count.
Returns number
Returns the current proxied callback count.
eventCount
- get eventCount(): number
Returns the current proxied eventbus event count.
Returns number
Returns the current proxied event count.
isDestroyed
- get isDestroyed(): boolean
Returns whether this EventbusProxy has already been destroyed.
Returns boolean
Is destroyed state.
name
- get name(): string
Returns the target eventbus name.
Returns string
The target eventbus name.
proxyCallbackCount
- get proxyCallbackCount(): number
Returns the current proxied callback count.
Returns number
Returns the current proxied callback count.
proxyEventCount
- get proxyEventCount(): number
Returns the current proxied event count.
Returns number
Returns the current proxied event count.
Methods
before
- before(
count: number,
name: string | EventMap,
callback: object | Function,
context?: object,
options?: EventOptions | EventOptionsOut,
): EventbusProxy Just like
on
, but causes the bound callback to fire several times up to the count specified before being removed. When multiple events are passed in using the space separated syntax, the event will fire count times for every event you passed in, not once for a combination of all events.Parameters
- count: number
Number of times the function will fire before being removed.
- name: string | EventMap
Event name(s) or event map.
- callback: object | Function
Event callback function or context for event map.
Optional
context: objectEvent context
Optional
options: EventOptions | EventOptionsOutEvent registration options.
Returns EventbusProxy
This EventbusProxy instance.
- count: number
createProxy
- createProxy(): EventbusProxy
Creates an EventbusProxy wrapping the backing Eventbus instance. An EventbusProxy proxies events allowing all listeners added to be easily removed from the wrapped Eventbus.
Returns EventbusProxy
A new EventbusProxy for this eventbus.
destroy
entries
- entries(
regex?: RegExp,
): Generator<[string, Function, object, EventOptionsOut], void, unknown> Returns an iterable for all events from the proxied eventbus yielding an array with event name, callback function, and event context.
Parameters
Optional
regex: RegExpOptional regular expression to filter event names.
Returns Generator<[string, Function, object, EventOptionsOut], void, unknown>
Generator
getOptions
- getOptions(name: string): EventOptionsOut
Returns the options of an event name.
Parameters
- name: string
Event name(s) to verify.
Returns EventOptionsOut
The event options.
- name: string
getType
isGuarded
keys
keysWithOptions
- keysWithOptions(
regex?: RegExp,
): Generator<[string, EventOptionsOut], void, unknown> Returns an iterable for the event names / keys of registered event listeners along with event options.
Parameters
Optional
regex: RegExpOptional regular expression to filter event names.
Returns Generator<[string, EventOptionsOut], void, unknown>
Generator
off
- off(
name?: string | EventMap,
callback?: Function,
context?: object,
): EventbusProxy Remove a previously-bound proxied event binding.
Please see Eventbus#off.
Parameters
Returns EventbusProxy
This EventbusProxy
on
- on(
name: string | EventMap,
callback: object | Function,
context?: object,
options?: EventOptions | EventOptionsOut,
): EventbusProxy Bind a callback function to an object. The callback will be invoked whenever the event is fired. If you have a large number of different events on a page, the convention is to use colons to namespace them:
poll:start
, orchange:selection
.Please see Eventbus#on.
Parameters
- name: string | EventMap
Event name(s) or event map.
- callback: object | Function
Event callback function or context for event map.
Optional
context: objectEvent context.
Optional
options: EventOptions | EventOptionsOutEvent registration options.
Returns EventbusProxy
This EventbusProxy
- name: string | EventMap
once
- once(
name: string | EventMap,
callback: object | Function,
context?: object,
options?: EventOptions | EventOptionsOut,
): EventbusProxy Just like
on
, but causes the bound callback to fire only once before being removed. Handy for saying "the next time that X happens, do this". When multiple events are passed in using the space separated syntax, the event will fire once for every event you passed in, not once for a combination of all eventsParameters
- name: string | EventMap
Event name(s) or event map.
- callback: object | Function
Event callback function or context for event map.
Optional
context: objectEvent context
Optional
options: EventOptions | EventOptionsOutEvent registration options.
Returns EventbusProxy
This EventbusProxy instance.
- name: string | EventMap
proxyEntries
- proxyEntries(
regex?: RegExp,
): Generator<[string, Function, object, EventOptionsOut], void, unknown> Returns an iterable for all stored locally proxied events yielding an array with event name, callback function, and event context.
Parameters
Optional
regex: RegExpOptional regular expression to filter event names.
Returns Generator<[string, Function, object, EventOptionsOut], void, unknown>
Generator
proxyKeys
proxyKeysWithOptions
- proxyKeysWithOptions(
regex?: RegExp,
): Generator<[string, EventOptionsOut], void, unknown> Returns an iterable for the event names / keys of the locally proxied event names with event options.
Note: The event options returned will respect all the event options from a registered event on the main eventbus if applicable.
Parameters
Optional
regex: RegExpOptional regular expression to filter event names.
Returns Generator<[string, EventOptionsOut], void, unknown>
Generator
trigger
- trigger(name: string, ...args: any[]): EventbusProxy
Trigger callbacks for the given event, or space-delimited list of events. Subsequent arguments to trigger will be passed along to the event callbacks.
Parameters
- name: string
Event name(s)
- ...args: any[]
Additional arguments passed to the event function(s).
Returns EventbusProxy
This EventbusProxy.
- name: string
triggerAsync
- triggerAsync(name: string, ...args: any[]): Promise<any>
Provides
trigger
functionality, but collects any returned Promises from invoked targets and returns a single Promise generated byPromise.resolve
for a single value orPromise.all
for multiple results. This is a very useful mechanism to invoke asynchronous operations over an eventbus.Parameters
- name: string
Event name(s)
- ...args: any[]
Additional arguments passed to the event function(s).
Returns Promise<any>
A Promise returning any results.
- name: string
triggerDefer
- triggerDefer(name: string, ...args: any[]): EventbusProxy
Defers invoking
trigger
. This is useful for triggering events in the next clock tick.Parameters
- name: string
Event name(s)
- ...args: any[]
Additional arguments passed to the event function(s).
Returns EventbusProxy
This EventbusProxy.
- name: string
triggerSync
- triggerSync(name: string, ...args: any[]): any
Provides
trigger
functionality, but collects any returned result or results from invoked targets as a single value or in an array and passes it back to the callee in a synchronous manner.Parameters
- name: string
Event name(s)
- ...args: any[]
Additional arguments passed to the event function(s).
Returns any
An Array of returned results.
- name: string
EventbusProxy provides a protected proxy of another Eventbus instance.
The main use case of EventbusProxy is to allow indirect access to an eventbus. This is handy when it comes to managing the event lifecycle for a plugin system. When a plugin is added it could receive a callback, perhaps named
onPluginLoaded
, which contains an EventbusProxy instance rather than the direct eventbus. This EventbusProxy instance is associated in the management system controlling plugin lifecycle. When a plugin is removed / unloaded the management system can automatically unregister all events for the plugin without requiring the plugin author doing it correctly if they had full control. IE This allows to plugin system to guarantee no dangling listeners.EventbusProxy provides the on / off, before, once, and trigger methods with the same signatures as found in Eventbus. However, the proxy tracks all added event bindings which is used to proxy between the target eventbus which is passed in from the constructor. All registration methods (on / off / once) proxy. In addition, there is a
destroy
method which will unregister all of proxied events and remove references to the managed eventbus. Any further usage of a destroyed EventbusProxy instance results in a ReferenceError thrown.Finally, the EventbusProxy only allows events registered through it to be turned off providing a buffer between any consumers such that they can not turn off other registrations made on the eventbus or other proxy instances.