forked from MapComplete/MapComplete
Refactoring: move anchor out of iconSize
This commit is contained in:
parent
3e49929f25
commit
140c813151
52 changed files with 168 additions and 87 deletions
|
@ -3,6 +3,7 @@ import { Utils } from "../../../Utils"
|
||||||
import LineRenderingConfigJson from "../Json/LineRenderingConfigJson"
|
import LineRenderingConfigJson from "../Json/LineRenderingConfigJson"
|
||||||
import { LayerConfigJson } from "../Json/LayerConfigJson"
|
import { LayerConfigJson } from "../Json/LayerConfigJson"
|
||||||
import { DesugaringStep, Each, Fuse, On } from "./Conversion"
|
import { DesugaringStep, Each, Fuse, On } from "./Conversion"
|
||||||
|
import PointRenderingConfigJson from "../Json/PointRenderingConfigJson"
|
||||||
|
|
||||||
export class UpdateLegacyLayer extends DesugaringStep<
|
export class UpdateLegacyLayer extends DesugaringStep<
|
||||||
LayerConfigJson | string | { builtin; override }
|
LayerConfigJson | string | { builtin; override }
|
||||||
|
@ -139,6 +140,20 @@ export class UpdateLegacyLayer extends DesugaringStep<
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (const rendering of config.mapRendering ?? []) {
|
||||||
|
if (!rendering["iconSize"]) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
const pr = <PointRenderingConfigJson>rendering
|
||||||
|
const iconSize = pr.iconSize
|
||||||
|
if (typeof iconSize === "string")
|
||||||
|
if (["bottom", "center", "top"].some((a) => (<string>iconSize).endsWith("," + a))) {
|
||||||
|
const parts = iconSize.split(",").map((parts) => parts.toLowerCase().trim())
|
||||||
|
pr.anchor = parts.pop()
|
||||||
|
pr.iconSize = parts.join(",")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
result: config,
|
result: config,
|
||||||
errors: [],
|
errors: [],
|
||||||
|
|
|
@ -54,6 +54,16 @@ export default interface PointRenderingConfigJson {
|
||||||
* Default is '40,40,center'
|
* Default is '40,40,center'
|
||||||
*/
|
*/
|
||||||
iconSize?: string | TagRenderingConfigJson
|
iconSize?: string | TagRenderingConfigJson
|
||||||
|
|
||||||
|
/**
|
||||||
|
* question: What is the anchorpoint of the icon?
|
||||||
|
*
|
||||||
|
* This matches the geographical point with a location on the icon.
|
||||||
|
* For example, a feature attached to the ground can use 'bottom' as zooming in will give the appearance of being anchored to a fixed location.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
anchor?: "center" | "top" | "bottom" | "left" | "right" | string
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The rotation of an icon, useful for e.g. directions.
|
* The rotation of an icon, useful for e.g. directions.
|
||||||
* Usage: as if it were a css property for 'rotate', thus has to end with 'deg', e.g. `90deg`, `{direction}deg`, `calc(90deg - {camera:direction}deg)``
|
* Usage: as if it were a css property for 'rotate', thus has to end with 'deg', e.g. `90deg`, `{direction}deg`, `calc(90deg - {camera:direction}deg)``
|
||||||
|
|
|
@ -27,6 +27,8 @@ export default class PointRenderingConfig extends WithContextLoader {
|
||||||
public readonly icon?: TagRenderingConfig
|
public readonly icon?: TagRenderingConfig
|
||||||
public readonly iconBadges: { if: TagsFilter; then: TagRenderingConfig }[]
|
public readonly iconBadges: { if: TagsFilter; then: TagRenderingConfig }[]
|
||||||
public readonly iconSize: TagRenderingConfig
|
public readonly iconSize: TagRenderingConfig
|
||||||
|
public readonly anchor: TagRenderingConfig
|
||||||
|
|
||||||
public readonly label: TagRenderingConfig
|
public readonly label: TagRenderingConfig
|
||||||
public readonly labelCss: TagRenderingConfig
|
public readonly labelCss: TagRenderingConfig
|
||||||
public readonly labelCssClasses: TagRenderingConfig
|
public readonly labelCssClasses: TagRenderingConfig
|
||||||
|
@ -90,7 +92,8 @@ export default class PointRenderingConfig extends WithContextLoader {
|
||||||
throw context + ": builtin SVG asset not found: " + iconPath
|
throw context + ": builtin SVG asset not found: " + iconPath
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.iconSize = this.tr("iconSize", "40,40,center")
|
this.iconSize = this.tr("iconSize", "40,40")
|
||||||
|
this.anchor = this.tr("anchor", "center")
|
||||||
this.label = this.tr("label", undefined)
|
this.label = this.tr("label", undefined)
|
||||||
this.rotation = this.tr("rotation", "0")
|
this.rotation = this.tr("rotation", "0")
|
||||||
this.pitchAlignment = this.tr("pitchAlignment", "canvas")
|
this.pitchAlignment = this.tr("pitchAlignment", "canvas")
|
||||||
|
@ -229,11 +232,13 @@ export default class PointRenderingConfig extends WithContextLoader {
|
||||||
return Utils.SubstituteKeys(str, tags.data).replace(/{.*}/g, "")
|
return Utils.SubstituteKeys(str, tags.data).replace(/{.*}/g, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
const iconSize = render(this.iconSize, "40,40,center").split(",")
|
const iconSize = render(this.iconSize, "40,40").split(",")
|
||||||
|
|
||||||
const iconW = num(iconSize[0])
|
const iconW = num(iconSize[0])
|
||||||
let iconH = num(iconSize[1])
|
let iconH = num(iconSize[1])
|
||||||
const mode = iconSize[2]?.trim()?.toLowerCase() ?? "center"
|
|
||||||
|
const anchor = render(this.anchor, "center")
|
||||||
|
const mode = anchor?.trim()?.toLowerCase() ?? "center"
|
||||||
|
|
||||||
// in MapLibre, the offset is relative to the _center_ of the object, with left = [-x, 0] and up = [0,-y]
|
// in MapLibre, the offset is relative to the _center_ of the object, with left = [-x, 0] and up = [0,-y]
|
||||||
let anchorW = 0
|
let anchorW = 0
|
||||||
|
|
|
@ -251,7 +251,7 @@
|
||||||
"render": "<div style='margin-top: -42px; color: white' class='rounded-full p-1 font-bold relative'>{addr:housenumber}</div>",
|
"render": "<div style='margin-top: -42px; color: white' class='rounded-full p-1 font-bold relative'>{addr:housenumber}</div>",
|
||||||
"condition": "addr:housenumber~*"
|
"condition": "addr:housenumber~*"
|
||||||
},
|
},
|
||||||
"iconSize": "50,50,center",
|
"iconSize": "50,50",
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "./assets/layers/address/housenumber_blank.svg",
|
"render": "./assets/layers/address/housenumber_blank.svg",
|
||||||
"mappings": [
|
"mappings": [
|
||||||
|
@ -274,7 +274,8 @@
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": {
|
"color": {
|
||||||
|
|
|
@ -304,11 +304,12 @@
|
||||||
"then": "close:#c33"
|
"then": "close:#c33"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"iconSize": "50,50,bottom",
|
"iconSize": "50,50",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#6bc4f7"
|
"color": "#6bc4f7"
|
||||||
|
|
|
@ -257,11 +257,12 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"iconSize": "50,50,bottom",
|
"iconSize": "50,50",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": {
|
"description": {
|
||||||
|
|
|
@ -699,11 +699,12 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "pin:#5473de;./assets/layers/bike_parking/parking.svg"
|
"render": "pin:#5473de;./assets/layers/bike_parking/parking.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,bottom",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#00f",
|
"color": "#00f",
|
||||||
|
|
|
@ -17,7 +17,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "10,10,center"
|
"iconSize": "10,10",
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"location": "end",
|
"location": "end",
|
||||||
|
@ -34,7 +35,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "10,10,center"
|
"iconSize": "10,10",
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"location": "start",
|
"location": "start",
|
||||||
|
|
|
@ -15,11 +15,12 @@
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"iconSize": "50,50,center",
|
"iconSize": "50,50",
|
||||||
"icon": "./assets/layers/crab_address/housenumber_blank.svg",
|
"icon": "./assets/layers/crab_address/housenumber_blank.svg",
|
||||||
"label": {
|
"label": {
|
||||||
"render": "<div style='margin-top: -42px; color: white' class='rounded-full p-1 font-bold relative'>{_HNRLABEL}</div>"
|
"render": "<div style='margin-top: -42px; color: white' class='rounded-full p-1 font-bold relative'>{_HNRLABEL}</div>"
|
||||||
}
|
},
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"calculatedTags": [
|
"calculatedTags": [
|
||||||
|
|
|
@ -70,11 +70,12 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "circle:white;./assets/layers/dentist/dentist.svg"
|
"render": "circle:white;./assets/layers/dentist/dentist.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"deletion": true,
|
"deletion": true,
|
||||||
|
|
|
@ -35,14 +35,15 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "direction_gradient:var(--catch-detail-color)",
|
"icon": "direction_gradient:var(--catch-detail-color)",
|
||||||
"iconSize": "200,200,center",
|
"iconSize": "200,200",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"rotation": {
|
"rotation": {
|
||||||
"render": "{_direction:numerical}deg"
|
"render": "{_direction:numerical}deg"
|
||||||
}
|
},
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "--catch-detail-color"
|
"color": "--catch-detail-color"
|
||||||
|
|
|
@ -129,11 +129,12 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "circle:white;./assets/layers/doctors/doctors.svg"
|
"render": "circle:white;./assets/layers/doctors/doctors.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"deletion": true,
|
"deletion": true,
|
||||||
|
|
|
@ -68,7 +68,7 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "./assets/layers/dogpark/dog-park.svg",
|
"icon": "./assets/layers/dogpark/dog-park.svg",
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"label": {
|
"label": {
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
|
@ -76,7 +76,8 @@
|
||||||
"then": "<div style='background: white; padding: 0.25em; border-radius:0.5em'>{name}</div>"
|
"then": "<div style='background: white; padding: 0.25em; border-radius:0.5em'>{name}</div>"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#ff0",
|
"color": "#ff0",
|
||||||
|
|
|
@ -258,11 +258,12 @@
|
||||||
"then": "close:#c33"
|
"then": "close:#c33"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"iconSize": "40,40,bottom",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": {
|
"description": {
|
||||||
|
|
|
@ -194,7 +194,7 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "circle:white;./assets/layers/elevator/elevator_wheelchair.svg"
|
"render": "circle:white;./assets/layers/elevator/elevator_wheelchair.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
|
@ -209,7 +209,8 @@
|
||||||
},
|
},
|
||||||
"then": "close:#c33"
|
"then": "close:#c33"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"presets": [
|
"presets": [
|
||||||
|
|
|
@ -92,14 +92,15 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "circle:white;./assets/layers/fitness_centre/gym.svg",
|
"icon": "circle:white;./assets/layers/fitness_centre/gym.svg",
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"label": "<div style='background: white; padding: 0.25em; border-radius:0.5em'>{name}</div>",
|
"label": "<div style='background: white; padding: 0.25em; border-radius:0.5em'>{name}</div>",
|
||||||
"iconBadges": [
|
"iconBadges": [
|
||||||
{
|
{
|
||||||
"if": "opening_hours~*",
|
"if": "opening_hours~*",
|
||||||
"then": "icons.isOpen"
|
"then": "icons.isOpen"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"filter": [
|
"filter": [
|
||||||
|
|
|
@ -393,7 +393,7 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "circle:white;./assets/layers/fitness_station/fitness.svg",
|
"icon": "circle:white;./assets/layers/fitness_station/fitness.svg",
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"iconBadges": [
|
"iconBadges": [
|
||||||
{
|
{
|
||||||
"if": {
|
"if": {
|
||||||
|
@ -404,7 +404,8 @@
|
||||||
},
|
},
|
||||||
"then": "icons.isOpen"
|
"then": "icons.isOpen"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"filter": [
|
"filter": [
|
||||||
|
|
|
@ -232,11 +232,12 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "./assets/layers/ghost_bike/ghost_bike.svg",
|
"icon": "./assets/layers/ghost_bike/ghost_bike.svg",
|
||||||
"iconSize": "40,40,bottom",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": {
|
"description": {
|
||||||
|
|
|
@ -67,11 +67,12 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "circle:white;./assets/layers/governments/government.svg"
|
"render": "circle:white;./assets/layers/governments/government.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"pitchAlignment": "map",
|
"pitchAlignment": "map",
|
||||||
"rotation": {
|
"rotation": {
|
||||||
"render": "0deg",
|
"render": "0deg",
|
||||||
|
@ -33,7 +33,8 @@
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,8 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "square:red",
|
"icon": "square:red",
|
||||||
"iconSize": "5,5,center"
|
"iconSize": "5,5",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,11 +115,12 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "circle:white;./assets/layers/hospital/hospital.svg"
|
"render": "circle:white;./assets/layers/hospital/hospital.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#fcd862",
|
"color": "#fcd862",
|
||||||
|
|
|
@ -55,7 +55,8 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "circle:white;./assets/layers/hotel/hotel.svg",
|
"icon": "circle:white;./assets/layers/hotel/hotel.svg",
|
||||||
"iconSize": "40,40,center"
|
"iconSize": "40,40",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
|
|
@ -9,7 +9,8 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "square:red;",
|
"icon": "square:red;",
|
||||||
"iconSize": "15,15,center"
|
"iconSize": "15,15",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"title": "Import candidate",
|
"title": "Import candidate",
|
||||||
|
|
|
@ -54,7 +54,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,bottom"
|
"iconSize": "40,40",
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
|
|
@ -67,7 +67,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,bottom"
|
"iconSize": "40,40",
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
|
|
@ -113,7 +113,7 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,bottom",
|
"iconSize": "40,40",
|
||||||
"iconBadges": [
|
"iconBadges": [
|
||||||
{
|
{
|
||||||
"if": "_total_comments>1",
|
"if": "_total_comments>1",
|
||||||
|
@ -123,7 +123,8 @@
|
||||||
"if": "_is_import_note~*",
|
"if": "_is_import_note~*",
|
||||||
"then": "addSmall"
|
"then": "addSmall"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"filter": [
|
"filter": [
|
||||||
|
|
|
@ -40,10 +40,11 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "pin:#6BC4F7;./assets/layers/osm_community_index/osm.svg"
|
"render": "pin:#6BC4F7;./assets/layers/osm_community_index/osm.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,bottom",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point"
|
"point"
|
||||||
]
|
],
|
||||||
|
"anchor": "bottom"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#444444",
|
"color": "#444444",
|
||||||
|
|
|
@ -270,11 +270,12 @@
|
||||||
"then": "icons.isOpen"
|
"then": "icons.isOpen"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -195,11 +195,12 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "20,20,center",
|
"iconSize": "20,20",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#696969",
|
"color": "#696969",
|
||||||
|
|
|
@ -88,7 +88,8 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "square:white;./assets/layers/parking_ticket_machine/parking_tickets.svg",
|
"icon": "square:white;./assets/layers/parking_ticket_machine/parking_tickets.svg",
|
||||||
"iconSize": "20,20,center"
|
"iconSize": "20,20",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,7 +116,7 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "./assets/layers/pharmacy/pharmacy.svg"
|
"render": "./assets/layers/pharmacy/pharmacy.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,bottom",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
|
@ -134,7 +134,8 @@
|
||||||
"then": "<div style='background: white; padding: 0.25em; border-radius:0.5em'>{name}</div>"
|
"then": "<div style='background: white; padding: 0.25em; border-radius:0.5em'>{name}</div>"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"filter": [
|
"filter": [
|
||||||
|
|
|
@ -65,11 +65,12 @@
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "circle:white;./assets/layers/physiotherapist/doctors.svg"
|
"render": "circle:white;./assets/layers/physiotherapist/doctors.svg"
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"deletion": true,
|
"deletion": true,
|
||||||
|
|
|
@ -446,11 +446,12 @@
|
||||||
"then": "./assets/themes/shops/shop.svg"
|
"then": "./assets/themes/shops/shop.svg"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#DADADA",
|
"color": "#DADADA",
|
||||||
|
|
|
@ -119,11 +119,12 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "red",
|
"color": "red",
|
||||||
|
|
|
@ -30,7 +30,8 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "circle:white;./assets/layers/reception_desk/reception_desk.svg",
|
"icon": "circle:white;./assets/layers/reception_desk/reception_desk.svg",
|
||||||
"iconSize": "40,40,center"
|
"iconSize": "40,40",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
|
|
@ -11,13 +11,14 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "circle:red",
|
"icon": "circle:red",
|
||||||
"iconSize": "1,1,center",
|
"iconSize": "1,1",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"projected_centerpoint"
|
"projected_centerpoint"
|
||||||
],
|
],
|
||||||
"css": "box-shadow: red 0 0 20px 20px; z-index: -1; height: 1px; width: 1px;",
|
"css": "box-shadow: red 0 0 20px 20px; z-index: -1; height: 1px; width: 1px;",
|
||||||
"cssClasses": "block relative rounded-full"
|
"cssClasses": "block relative rounded-full",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,8 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "circle:white;./assets/svg/scissors.svg",
|
"icon": "circle:white;./assets/svg/scissors.svg",
|
||||||
"iconSize": "30,30,center"
|
"iconSize": "30,30",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,8 @@
|
||||||
"point"
|
"point"
|
||||||
],
|
],
|
||||||
"icon": "bug",
|
"icon": "bug",
|
||||||
"iconSize": "30,30,center"
|
"iconSize": "30,30",
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"width": "8",
|
"width": "8",
|
||||||
|
|
|
@ -43,7 +43,8 @@
|
||||||
"then": "circle:{light:colour}"
|
"then": "circle:{light:colour}"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"iconSize": "40,40,bottom"
|
"iconSize": "40,40",
|
||||||
|
"anchor": "bottom"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"presets": [
|
"presets": [
|
||||||
|
|
|
@ -86,11 +86,12 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "square:lightblue;./assets/themes/stations/public_transport_tickets.svg",
|
"icon": "square:lightblue;./assets/themes/stations/public_transport_tickets.svg",
|
||||||
"iconSize": "20,20,center",
|
"iconSize": "20,20",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"allowMove": true,
|
"allowMove": true,
|
||||||
|
|
|
@ -114,11 +114,12 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "square:green;./assets/themes/stations/public_transport_tickets.svg",
|
"icon": "square:green;./assets/themes/stations/public_transport_tickets.svg",
|
||||||
"iconSize": "20,20,center",
|
"iconSize": "20,20",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"allowMove": true,
|
"allowMove": true,
|
||||||
|
|
|
@ -67,7 +67,7 @@
|
||||||
"centroid"
|
"centroid"
|
||||||
],
|
],
|
||||||
"icon": "./assets/layers/veterinary/vet.svg",
|
"icon": "./assets/layers/veterinary/vet.svg",
|
||||||
"iconSize": "30,40,center",
|
"iconSize": "30,40",
|
||||||
"label": {
|
"label": {
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
|
@ -81,7 +81,8 @@
|
||||||
"if": "opening_hours~*",
|
"if": "opening_hours~*",
|
||||||
"then": "icons.isOpen"
|
"then": "icons.isOpen"
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#ff0",
|
"color": "#ff0",
|
||||||
|
|
|
@ -81,10 +81,11 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "./assets/layers/viewpoint/viewpoint.svg",
|
"icon": "./assets/layers/viewpoint/viewpoint.svg",
|
||||||
"iconSize": "20,20,center",
|
"iconSize": "20,20",
|
||||||
"location": [
|
"location": [
|
||||||
"point"
|
"point"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#ffffff",
|
"color": "#ffffff",
|
||||||
|
|
|
@ -34,11 +34,12 @@
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"icon": "./assets/themes/playgrounds/playground.svg",
|
"icon": "./assets/themes/playgrounds/playground.svg",
|
||||||
"iconSize": "40,40,center",
|
"iconSize": "40,40",
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#937f20",
|
"color": "#937f20",
|
||||||
|
|
|
@ -479,7 +479,7 @@
|
||||||
"render": "<div style='margin-top: -42px; color: black' class='rounded-full p-1 font-bold relative'>{addr:housenumber}</div>",
|
"render": "<div style='margin-top: -42px; color: black' class='rounded-full p-1 font-bold relative'>{addr:housenumber}</div>",
|
||||||
"condition": "addr:housenumber~*"
|
"condition": "addr:housenumber~*"
|
||||||
},
|
},
|
||||||
"iconSize": "50,50,center",
|
"iconSize": "50,50",
|
||||||
"icon": {
|
"icon": {
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
|
@ -495,7 +495,8 @@
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"width": {
|
"width": {
|
||||||
|
|
|
@ -416,7 +416,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "30,30,center"
|
"iconSize": "30,30",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"filter": [
|
"filter": [
|
||||||
|
|
|
@ -235,7 +235,8 @@
|
||||||
"end"
|
"end"
|
||||||
],
|
],
|
||||||
"icon": "circle:#ccc",
|
"icon": "circle:#ccc",
|
||||||
"iconSize": "3,3,center"
|
"iconSize": "3,3",
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"#": "The center line",
|
"#": "The center line",
|
||||||
|
|
|
@ -43,7 +43,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "20,20,center"
|
"iconSize": "20,20",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
|
|
@ -638,7 +638,7 @@
|
||||||
"render": "<div style='margin-top: -42px; color: white' class='rounded-full p-1 font-bold relative'>{addr:housenumber}</div>",
|
"render": "<div style='margin-top: -42px; color: white' class='rounded-full p-1 font-bold relative'>{addr:housenumber}</div>",
|
||||||
"condition": "addr:housenumber~*"
|
"condition": "addr:housenumber~*"
|
||||||
},
|
},
|
||||||
"iconSize": "50,50,center",
|
"iconSize": "50,50",
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": "./assets/layers/address/housenumber_blank.svg",
|
"render": "./assets/layers/address/housenumber_blank.svg",
|
||||||
"mappings": [
|
"mappings": [
|
||||||
|
@ -661,7 +661,8 @@
|
||||||
"location": [
|
"location": [
|
||||||
"point",
|
"point",
|
||||||
"centroid"
|
"centroid"
|
||||||
]
|
],
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": {
|
"color": {
|
||||||
|
|
|
@ -47,7 +47,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "20,20,center"
|
"iconSize": "20,20",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
@ -92,7 +93,8 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"iconSize": "20,20,center"
|
"iconSize": "20,20",
|
||||||
|
"anchor": "center"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
|
|
|
@ -210,7 +210,8 @@
|
||||||
"point"
|
"point"
|
||||||
],
|
],
|
||||||
"icon": "./assets/themes/width/icon.svg",
|
"icon": "./assets/themes/width/icon.svg",
|
||||||
"iconSize": "40,40,center"
|
"iconSize": "40,40",
|
||||||
|
"anchor": "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"width": "4",
|
"width": "4",
|
||||||
|
|
Loading…
Reference in a new issue