2023-01-02 11:09:47 +01:00
|
|
|
import { Observable, Subscription } from 'rxjs';
|
|
|
|
|
|
2023-01-04 09:31:16 +01:00
|
|
|
export class UmbObserver<T> {
|
2023-03-15 20:17:52 +01:00
|
|
|
#source!: Observable<T>;
|
|
|
|
|
#callback!: (_value: T) => void;
|
2023-01-02 11:09:47 +01:00
|
|
|
#subscription!: Subscription;
|
|
|
|
|
|
2023-01-12 09:57:26 +01:00
|
|
|
constructor(source: Observable<T>, callback: (_value: T) => void) {
|
2023-03-15 20:17:52 +01:00
|
|
|
this.#source = source;
|
|
|
|
|
this.#subscription = source.subscribe(callback);
|
2023-01-02 11:09:47 +01:00
|
|
|
}
|
|
|
|
|
|
2023-03-15 20:17:52 +01:00
|
|
|
hostConnected() {
|
|
|
|
|
if (this.#subscription.closed) {
|
|
|
|
|
this.#subscription = this.#source.subscribe(this.#callback);
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-01-02 11:19:09 +01:00
|
|
|
|
2023-01-02 11:09:47 +01:00
|
|
|
hostDisconnected() {
|
2023-03-15 14:02:11 +01:00
|
|
|
// No cause then it cant re-connect, if the same element just was moved in DOM.
|
|
|
|
|
//this.#subscription.unsubscribe();
|
2023-01-02 11:09:47 +01:00
|
|
|
}
|
2023-01-02 11:38:01 +01:00
|
|
|
|
|
|
|
|
destroy(): void {
|
|
|
|
|
this.#subscription.unsubscribe();
|
|
|
|
|
}
|
2023-02-21 23:32:48 +01:00
|
|
|
}
|