import FeatureSource from "./FeatureSource"; import {UIEventSource} from "../UIEventSource"; import LayerConfig from "../../Customizations/JSON/LayerConfig"; import Loc from "../../Models/Loc"; export default class FilteringFeatureSource implements FeatureSource { public features: UIEventSource<{ feature: any; freshness: Date }[]> = new UIEventSource<{ feature: any; freshness: Date }[]>([]); constructor(layers: { isDisplayed: UIEventSource, layerDef: LayerConfig }[], location: UIEventSource, upstream: FeatureSource) { const layerDict = {}; const self = this; function update() { const features: { feature: any, freshness: Date }[] = upstream.features.data; const newFeatures = features.filter(f => { const layerId = f.feature._matching_layer_id; if (layerId === undefined) { console.error(f) throw "feature._matching_layer_id is undefined" } const layer: { isDisplayed: UIEventSource, layerDef: LayerConfig } = layerDict[layerId]; if (layer === undefined) { throw "No layer found with id " + layerId; } return layer.isDisplayed.data && (layer.layerDef.minzoom <= location.data.zoom); }); self.features.setData(newFeatures); } for (const layer of layers) { layerDict[layer.layerDef.id] = layer; layer.isDisplayed.addCallback(() => { console.log("Updating due to layer change") update()}) } upstream.features.addCallback(() => { console.log("Updating due to upstream change") update()}); location.map(l => l.zoom).addCallback(() => { console.log("UPdating due to zoom level change") update();}); } }