Class: ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:22
An Observable is a class that manages event listeners and allows distributing events to the registered listeners. It maintains a history of events and supports persistent events that are not cleared during route changes.
Remarks
- The Observable class relies on a Dispatcher to handle the actual event distribution.
- It maintains a history of events, which can be limited by a maximum history length.
Extends
Constructors
new ObservableImpl()
new ObservableImpl(
dispatcher
,settings
?):ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:40
Creates an instance of Observable.
Parameters
dispatcher
The dispatcher responsible for managing event listeners.
settings?
Optional settings for the Observable instance.
maxHistoryLength
number
Returns
Overrides
Properties
_activityHistory
protected
_activityHistory:Map
<string
,unknown
[]>
Defined in: packages/core/src/event/ObservableImpl.ts:25
_dispatcher
protected
_dispatcher:Dispatcher
Defined in: packages/core/src/event/ObservableImpl.ts:23
_observers
protected
_observers:Map
<string
,Map
<DispatcherListener
<any
>,Set
<unknown
>>>
Defined in: packages/core/src/event/ObservableImpl.ts:24
_persistentEvents
protected
_persistentEvents:Set
<string
>
Defined in: packages/core/src/event/ObservableImpl.ts:26
_settings
protected
_settings:undefined
| {maxHistoryLength
:number
; }
Defined in: packages/core/src/event/ObservableImpl.ts:27
$dependencies
static
$dependencies:Dependencies
Defined in: packages/core/src/event/ObservableImpl.ts:29
Methods
_handleDispatcherEvent()
_handleDispatcherEvent(
event
,data
):void
Defined in: packages/core/src/event/ObservableImpl.ts:148
Handles dispatcher events by updating the activity history and notifying observers.
It also resets the activity history for non-persistent events on BEFORE_HANDLE_ROUTE
ecvent.
Parameters
event
string
The name of the event being dispatched.
data
any
The data associated with the event.
Returns
void
clear()
clear():
ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:72
Clears all persistent events, observers, and activity history from the observable.
This method will remove all stored events, registered observers, and any recorded activity history, effectively resetting the observable to its initial state.
Returns
The instance of the Observable for chaining.
Overrides
destroy()
destroy():
ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:62
Destroys the observable by clearing its internal state and removing all event listeners.
Returns
The instance of the Observable for chaining.
Overrides
init()
init():
ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:52
Initializes the observable.
Returns
The instance of the Observable for chaining.
Overrides
registerPersistenEvent()
registerPersistenEvent(
event
):ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:83
Registers an event as persistent, meaning its history won't be cleared upon calling the clear
method (route change).
Parameters
event
string
The name of the event to be registered as persistent. This can be a key from the DispatcherEventsMap or any string.
Returns
The instance of the Observable for chaining.
Overrides
Observable
.registerPersistenEvent
subscribe()
subscribe(
event
,observer
,scope
?):ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:92
Subscribes an observer to a specific event. When the event is dispatched, the observer will be notified and executed within the provided scope. If the event has already occurred, the observer will be immediately invoked with the historical data.
Parameters
event
string
The event to subscribe to.
observer
DispatcherListener
<any
>
The observer function to be called when the event is dispatched.
scope?
unknown
The scope in which the observer function should be executed. This is optional.
Returns
The instance of the Observable for chaining.
Overrides
unsubscribe()
unsubscribe(
event
,observer
,scope
?):ObservableImpl
Defined in: packages/core/src/event/ObservableImpl.ts:119
Unsubscribes an observer from a specific event.
Parameters
event
string
The event name or key from the DispatcherEventsMap.
observer
DispatcherListener
<any
>
The observer (listener) to be unsubscribed.
scope?
unknown
Optional scope to be used for the observer.
Returns
The current instance for chaining.