MapComplete/Logic/FeatureSource/Sources/TouchesBboxFeatureSource.ts
2023-05-05 01:25:12 +02:00

40 lines
1.5 KiB
TypeScript

import {FeatureSource, FeatureSourceForLayer} from "../FeatureSource"
import StaticFeatureSource from "./StaticFeatureSource"
import {BBox} from "../../BBox"
import FilteredLayer from "../../../Models/FilteredLayer"
import {Store} from "../../UIEventSource"
import {Feature} from "geojson";
/**
* Results in a feature source which has all the elements that touch the given features
*/
export default class BBoxFeatureSource<T extends Feature = Feature> extends StaticFeatureSource<T> {
constructor(features: FeatureSource<T>, mustTouch: Store<BBox>) {
super(
features.features.mapD(
(features) => {
if (mustTouch.data === undefined) {
return features
}
const box = mustTouch.data
return features.filter((feature) => {
if (feature.geometry.type === "Point") {
return box.contains(<[number, number]>feature.geometry.coordinates)
}
return box.overlapsWith(BBox.get(feature))
})
},
[mustTouch]
)
)
}
}
export class BBoxFeatureSourceForLayer<T extends Feature = Feature> extends BBoxFeatureSource<T> implements FeatureSourceForLayer {
readonly layer: FilteredLayer
constructor(features: FeatureSourceForLayer<T>, mustTouch: Store<BBox>) {
super(features, mustTouch)
this.layer = features.layer
}
}