2021-03-25 15:19:44 +01:00
|
|
|
/**
|
2021-10-22 01:07:32 +02:00
|
|
|
* This feature source helps the ShowDataLayer class: it introduces the necessary extra features and indiciates with what renderConfig it should be rendered.
|
2021-03-25 15:19:44 +01:00
|
|
|
*/
|
2021-09-21 02:10:42 +02:00
|
|
|
import {UIEventSource} from "../../UIEventSource";
|
|
|
|
import {GeoOperations} from "../../GeoOperations";
|
2021-10-22 01:07:32 +02:00
|
|
|
import FeatureSource from "../FeatureSource";
|
|
|
|
import PointRenderingConfig from "../../../Models/ThemeConfig/PointRenderingConfig";
|
|
|
|
import LayerConfig from "../../../Models/ThemeConfig/LayerConfig";
|
2021-01-03 03:09:52 +01:00
|
|
|
|
2021-09-26 17:36:39 +02:00
|
|
|
|
2021-10-22 01:07:32 +02:00
|
|
|
export default class RenderingMultiPlexerFeatureSource {
|
|
|
|
public readonly features: UIEventSource<(any & {pointRenderingIndex: number | undefined, lineRenderingIndex: number | undefined})[]>;
|
2021-09-20 17:14:55 +02:00
|
|
|
|
2021-10-22 01:07:32 +02:00
|
|
|
constructor(upstream: FeatureSource, layer: LayerConfig) {
|
2021-01-03 03:09:52 +01:00
|
|
|
this.features = upstream.features.map(
|
|
|
|
features => {
|
2021-04-23 16:51:44 +02:00
|
|
|
if (features === undefined) {
|
2021-01-03 03:09:52 +01:00
|
|
|
return;
|
|
|
|
}
|
2021-10-22 01:07:32 +02:00
|
|
|
|
|
|
|
const pointRenderObjects: { rendering: PointRenderingConfig, index: number }[] = layer.mapRendering.map((r, i) => ({rendering: r, index: i}))
|
|
|
|
const pointRenderings = pointRenderObjects.filter(r => r.rendering.location.has("point"))
|
|
|
|
const centroidRenderings = pointRenderObjects.filter(r => r.rendering.location.has("centroid"))
|
|
|
|
|
|
|
|
const lineRenderObjects = layer.lineRendering
|
|
|
|
|
|
|
|
const withIndex : (any & {pointRenderingIndex: number | undefined, lineRenderingIndex: number | undefined})[] = [];
|
|
|
|
|
2021-01-03 03:09:52 +01:00
|
|
|
for (const f of features) {
|
|
|
|
const feat = f.feature;
|
2021-10-22 01:07:32 +02:00
|
|
|
|
|
|
|
if(feat.geometry.type === "Point"){
|
2021-04-23 16:51:44 +02:00
|
|
|
|
2021-10-22 01:07:32 +02:00
|
|
|
for (const rendering of pointRenderings) {
|
|
|
|
withIndex.push({
|
|
|
|
...feat,
|
|
|
|
pointRenderingIndex: rendering.index
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
// This is a a line
|
|
|
|
for (const rendering of centroidRenderings) {
|
|
|
|
withIndex.push({
|
|
|
|
...GeoOperations.centerpoint(feat),
|
|
|
|
pointRenderingIndex: rendering.index
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < lineRenderObjects.length; i++){
|
|
|
|
withIndex.push({
|
|
|
|
...feat,
|
|
|
|
lineRenderingIndex:i
|
|
|
|
})
|
|
|
|
}
|
2021-04-23 16:51:44 +02:00
|
|
|
|
2021-01-03 03:09:52 +01:00
|
|
|
}
|
|
|
|
}
|
2021-10-22 01:07:32 +02:00
|
|
|
return withIndex;
|
2021-01-03 03:09:52 +01:00
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|