mapcomplete/Logic/FeatureSource/Sources/RememberingSource.ts

35 lines
1.4 KiB
TypeScript
Raw Normal View History

/**
* Every previously added point is remembered, but new points are added.
* Data coming from upstream will always overwrite a previous value
*/
import FeatureSource, {Tiled} from "../FeatureSource";
import {Store, UIEventSource} from "../../UIEventSource";
import {BBox} from "../../BBox";
2021-11-07 16:34:51 +01:00
export default class RememberingSource implements FeatureSource, Tiled {
2021-01-04 22:59:11 +01:00
public readonly features: Store<{ feature: any, freshness: Date }[]>;
public readonly name;
2021-11-07 16:34:51 +01:00
public readonly tileIndex: number
public readonly bbox: BBox
constructor(source: FeatureSource & Tiled) {
const self = this;
this.name = "RememberingSource of " + source.name;
2021-11-07 16:34:51 +01:00
this.tileIndex = source.tileIndex
this.bbox = source.bbox;
2021-11-07 16:34:51 +01:00
2021-01-04 22:59:11 +01:00
const empty = [];
2022-06-06 19:37:22 +02:00
const featureSource = new UIEventSource<{feature: any, freshness: Date}[]>(empty)
this.features = featureSource
source.features.addCallbackAndRunD(features => {
2021-01-04 22:59:11 +01:00
const oldFeatures = self.features?.data ?? empty;
// Then new ids
const ids = new Set<string>(features.map(f => f.feature.properties.id + f.feature.geometry.type));
2021-01-04 22:59:11 +01:00
// the old data
const oldData = oldFeatures.filter(old => !ids.has(old.feature.properties.id + old.feature.geometry.type))
2022-06-06 19:37:22 +02:00
featureSource.setData([...features, ...oldData])
})
}
2021-01-04 22:59:11 +01:00
}