Core: add 'onDestroy'-callback to mappedStore to unregister

This commit is contained in:
Pieter Vander Vennet 2023-05-05 00:58:26 +02:00
parent 8e68ca03ab
commit cbb0c9c1d7

View file

@ -407,7 +407,8 @@ class MappedStore<TIn, T> extends Store<T> {
f: (t: TIn) => T, f: (t: TIn) => T,
extraStores: Store<any>[], extraStores: Store<any>[],
upstreamListenerHandler: ListenerTracker<TIn> | undefined, upstreamListenerHandler: ListenerTracker<TIn> | undefined,
initialState: T initialState: T,
onDestroy?: (f: () => void) => void
) { ) {
super() super()
this._upstream = upstream this._upstream = upstream
@ -417,6 +418,9 @@ class MappedStore<TIn, T> extends Store<T> {
this._upstreamPingCount = upstreamListenerHandler?.pingCount this._upstreamPingCount = upstreamListenerHandler?.pingCount
this._extraStores = extraStores this._extraStores = extraStores
this.registerCallbacksToUpstream() this.registerCallbacksToUpstream()
if(onDestroy !== undefined){
onDestroy(() => this.unregisterFromUpstream())
}
} }
private _data: T private _data: T
@ -677,6 +681,7 @@ export class UIEventSource<T> extends Store<T> implements Writable<T> {
* Given a function 'f', will construct a new UIEventSource where the contents will always be "f(this.data)' * Given a function 'f', will construct a new UIEventSource where the contents will always be "f(this.data)'
* @param f: The transforming function * @param f: The transforming function
* @param extraSources: also trigger the update if one of these sources change * @param extraSources: also trigger the update if one of these sources change
* @param onDestroy: a callback that can trigger the destroy function
* *
* const src = new UIEventSource<number>(10) * const src = new UIEventSource<number>(10)
* const store = src.map(i => i * 2) * const store = src.map(i => i * 2)
@ -695,8 +700,8 @@ export class UIEventSource<T> extends Store<T> implements Writable<T> {
* srcSeen // => 21 * srcSeen // => 21
* lastSeen // => 42 * lastSeen // => 42
*/ */
public map<J>(f: (t: T) => J, extraSources: Store<any>[] = []): Store<J> { public map<J>(f: (t: T) => J, extraSources: Store<any>[] = [], onDestroy?: (f : () => void ) => void): Store<J> {
return new MappedStore(this, f, extraSources, this._callbacks, f(this.data)) return new MappedStore(this, f, extraSources, this._callbacks, f(this.data), onDestroy)
} }
/** /**
* Monoidal map which results in a read-only store. 'undefined' is passed 'as is' * Monoidal map which results in a read-only store. 'undefined' is passed 'as is'