better unsubscribing

This commit is contained in:
Matt Hill
2021-07-19 16:34:47 -06:00
parent 40a97ef01d
commit 4e756be082

View File

@@ -1,6 +1,5 @@
import { DBCache, Dump, Http, Revision, Update } from './types'
import { BehaviorSubject, Observable } from 'rxjs'
import { finalize } from 'rxjs/operators'
import { applyOperation, getValueByPointer, Operation } from './json-patch-lib'
import BTree from 'sorted-btree'
@@ -34,11 +33,8 @@ export class Store<T> {
const path = `/${args.join('/')}`
if (!this.watchedNodes[path]) {
this.watchedNodes[path] = new BehaviorSubject(getValueByPointer(this.cache.data, path))
this.watchedNodes[path].pipe(
finalize(() => delete this.watchedNodes[path]),
)
}
return this.watchedNodes[path].asObservable()
return this.watchedNodes[path]
}
update (update: Update<T>): void {
@@ -134,14 +130,19 @@ export class Store<T> {
}
private updateWatchedNodes (revisionPath: string) {
const kill = (path: string) => {
this.watchedNodes[path].complete()
delete this.watchedNodes[path]
}
Object.keys(this.watchedNodes).forEach(path => {
if (this.watchedNodes[path].observers.length === 0) return kill(path)
if (path.includes(revisionPath) || revisionPath.includes(path)) {
const val = getValueByPointer(this.cache.data, path)
if (val !== undefined) {
this.watchedNodes[path].next(val)
} else {
this.watchedNodes[path].complete()
}
if (val === undefined) return kill(path)
this.watchedNodes[path].next(val)
}
})
}