MapComplete/Customizations/LayerDefinition.ts

54 lines
1.6 KiB
TypeScript
Raw Normal View History

2020-07-05 18:59:47 +02:00
import {Tag, TagsFilter} from "../Logic/TagsFilter";
import {UIElement} from "../UI/UIElement";
import {Basemap} from "../Logic/Basemap";
import {ElementStorage} from "../Logic/ElementStorage";
import {UIEventSource} from "../UI/UIEventSource";
import {FilteredLayer} from "../Logic/FilteredLayer";
import {Changes} from "../Logic/Changes";
import {UserDetails} from "../Logic/OsmConnection";
import {TagRenderingOptions} from "./TagRendering";
2020-06-24 00:35:19 +02:00
export class LayerDefinition {
2020-07-07 16:00:39 +02:00
/**
* This name is shown in the 'add XXX button'
*/
2020-06-24 00:35:19 +02:00
name: string;
newElementTags: Tag[]
icon: string;
minzoom: number;
overpassFilter: TagsFilter;
2020-07-07 16:00:39 +02:00
/**
* This UIElement is rendered as title element in the popup
*/
2020-07-05 18:59:47 +02:00
title: TagRenderingOptions;
2020-07-07 16:00:39 +02:00
/**
* These are the questions/shown attributes in the popup
*/
2020-07-05 18:59:47 +02:00
elementsToShow: TagRenderingOptions[];
2020-06-24 00:35:19 +02:00
style: (tags: any) => { color: string, icon: any };
2020-06-28 23:33:48 +02:00
/**
* If an object of the next layer is contained for this many percent in this feature, it is eaten and not shown
*/
maxAllowedOverlapPercentage: number = undefined;
2020-06-24 00:35:19 +02:00
2020-07-01 16:32:17 +02:00
asLayer(basemap: Basemap, allElements: ElementStorage, changes: Changes, userDetails: UIEventSource<UserDetails>, selectedElement: UIEventSource<any>,
showOnPopup: (tags: UIEventSource<(any)>) => UIElement):
2020-06-24 00:35:19 +02:00
FilteredLayer {
return new FilteredLayer(
this.name,
basemap, allElements, changes,
this.overpassFilter,
2020-06-28 23:33:48 +02:00
this.maxAllowedOverlapPercentage,
this.style,
2020-06-29 16:21:36 +02:00
selectedElement,
showOnPopup);
2020-06-24 00:35:19 +02:00
}
}