forked from MapComplete/MapComplete
Fixes to sidewalks theme
This commit is contained in:
parent
070262a959
commit
10d9f18110
6 changed files with 136 additions and 91 deletions
|
@ -29,7 +29,7 @@ public GenerateLeafletStyle( tags: {} ):
|
||||||
{
|
{
|
||||||
color: string,
|
color: string,
|
||||||
weight: number,
|
weight: number,
|
||||||
dashArray: number[],
|
dashArray: string,
|
||||||
offset: number
|
offset: number
|
||||||
} {
|
} {
|
||||||
function rendernum(tr: TagRenderingConfig, deflt: number) {
|
function rendernum(tr: TagRenderingConfig, deflt: number) {
|
||||||
|
@ -49,7 +49,7 @@ public GenerateLeafletStyle( tags: {} ):
|
||||||
return Utils.SubstituteKeys(str, tags)?.replace(/{.*}/g, "");
|
return Utils.SubstituteKeys(str, tags)?.replace(/{.*}/g, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
const dashArray = render(this.dashArray)?.split(" ")?.map(Number);
|
const dashArray = render(this.dashArray);
|
||||||
let color = render(this.color, "#00f");
|
let color = render(this.color, "#00f");
|
||||||
if (color.startsWith("--")) {
|
if (color.startsWith("--")) {
|
||||||
color = getComputedStyle(document.body).getPropertyValue(
|
color = getComputedStyle(document.body).getPropertyValue(
|
||||||
|
|
|
@ -78,15 +78,19 @@ export default class FeatureInfoBox extends ScrollableFullScreen {
|
||||||
renderingsForGroup.push(questionBox)
|
renderingsForGroup.push(questionBox)
|
||||||
} else {
|
} else {
|
||||||
let classes = innerClasses
|
let classes = innerClasses
|
||||||
if(renderingsForGroup.length === 0 && i > 0){
|
let isHeader = renderingsForGroup.length === 0 && i > 0
|
||||||
|
if(isHeader){
|
||||||
// This is the first element of a group!
|
// This is the first element of a group!
|
||||||
// It should act as header and be sticky
|
// It should act as header and be sticky
|
||||||
classes= "sticky top-0"
|
classes= ""
|
||||||
}
|
}
|
||||||
|
|
||||||
const etr = new EditableTagRendering(tags, tr, layerConfig.units,{
|
const etr = new EditableTagRendering(tags, tr, layerConfig.units,{
|
||||||
innerElementClasses: innerClasses
|
innerElementClasses: innerClasses
|
||||||
})
|
})
|
||||||
|
if(isHeader){
|
||||||
|
etr.SetClass("sticky top-0")
|
||||||
|
}
|
||||||
renderingsForGroup.push(etr)
|
renderingsForGroup.push(etr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,10 +11,21 @@
|
||||||
},
|
},
|
||||||
"mapRendering": [
|
"mapRendering": [
|
||||||
{
|
{
|
||||||
"location": [
|
"width": 15,
|
||||||
"point"
|
"color": {
|
||||||
]
|
"render": "#ff000088",
|
||||||
},
|
"mappings": [{
|
||||||
{}
|
"if": "id=left",
|
||||||
|
"then": "#0000ff88"
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
"offset": {
|
||||||
|
"render": "-15",
|
||||||
|
"mappings": [{
|
||||||
|
"if": "id=right",
|
||||||
|
"then": "15"
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
|
@ -29,35 +29,39 @@
|
||||||
"maxCacheAge": 0
|
"maxCacheAge": 0
|
||||||
},
|
},
|
||||||
"minzoom": 18,
|
"minzoom": 18,
|
||||||
"width": {
|
"mapRendering": [
|
||||||
"render": "2"
|
{
|
||||||
},
|
"width": {
|
||||||
"color": {
|
"render": "2"
|
||||||
"render": "#00c",
|
|
||||||
"mappings": [
|
|
||||||
{
|
|
||||||
"if": "building=house",
|
|
||||||
"then": "#a00"
|
|
||||||
},
|
},
|
||||||
{
|
"color": {
|
||||||
"if": "building=shed",
|
"render": "#00c",
|
||||||
"then": "#563e02"
|
"mappings": [
|
||||||
},
|
{
|
||||||
{
|
"if": "building=house",
|
||||||
"if": {
|
"then": "#a00"
|
||||||
"or": [
|
},
|
||||||
"building=garage",
|
{
|
||||||
"building=garages"
|
"if": "building=shed",
|
||||||
]
|
"then": "#563e02"
|
||||||
},
|
},
|
||||||
"then": "#f9bfbb"
|
{
|
||||||
},
|
"if": {
|
||||||
{
|
"or": [
|
||||||
"if": "building=yes",
|
"building=garage",
|
||||||
"then": "#0774f2"
|
"building=garages"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": "#f9bfbb"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "building=yes",
|
||||||
|
"then": "#0774f2"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
}
|
||||||
},
|
],
|
||||||
"title": "OSM-gebouw",
|
"title": "OSM-gebouw",
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
"all_tags"
|
"all_tags"
|
||||||
|
@ -93,12 +97,16 @@
|
||||||
"maxCacheAge": 0
|
"maxCacheAge": 0
|
||||||
},
|
},
|
||||||
"minzoom": 18,
|
"minzoom": 18,
|
||||||
"color": {
|
"mapRendering": [
|
||||||
"render": "#00c"
|
{
|
||||||
},
|
"color": {
|
||||||
"width": {
|
"render": "#00c"
|
||||||
"render": "1"
|
},
|
||||||
},
|
"width": {
|
||||||
|
"render": "1"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
"title": {
|
"title": {
|
||||||
"render": {
|
"render": {
|
||||||
"*": "OSM-Object"
|
"*": "OSM-Object"
|
||||||
|
@ -265,26 +273,34 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"label": {
|
"mapRendering": [
|
||||||
"mappings": [
|
{
|
||||||
{
|
"location": [
|
||||||
"if": "addr:housenumber~*",
|
"point",
|
||||||
"then": "<div style='background-color: white; font: large; width: 1.5em; height: 1.5em; border-radius: 100%'>{addr:housenumber}</div>"
|
"center"
|
||||||
|
],
|
||||||
|
"label": {
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "addr:housenumber~*",
|
||||||
|
"then": "<div style='background-color: white; font: large; width: 1.5em; height: 1.5em; border-radius: 100%'>{addr:housenumber}</div>"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"iconSize": {
|
||||||
|
"render": "40,40,center"
|
||||||
}
|
}
|
||||||
]
|
},
|
||||||
},
|
{
|
||||||
"width": {
|
"dashes": "2 2",
|
||||||
"render": "2"
|
"color": {
|
||||||
},
|
"render": "#00f"
|
||||||
"iconSize": {
|
},
|
||||||
"render": "40,40,center"
|
"width": {
|
||||||
},
|
"render": "2"
|
||||||
"dashes": "2 2",
|
}
|
||||||
"color": {
|
}
|
||||||
"render": "#00f"
|
]
|
||||||
},
|
|
||||||
"wayHandling": 2,
|
|
||||||
"presets": []
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"id": "crab-addresses 2021-10-26",
|
"id": "crab-addresses 2021-10-26",
|
||||||
|
@ -298,8 +314,13 @@
|
||||||
"minzoom": 19,
|
"minzoom": 19,
|
||||||
"name": "CRAB-addressen",
|
"name": "CRAB-addressen",
|
||||||
"title": "CRAB-adres",
|
"title": "CRAB-adres",
|
||||||
"icon": "circle:#bb3322",
|
"mapRendering": [
|
||||||
"iconSize": "15,15,center",
|
{
|
||||||
|
"location": "point",
|
||||||
|
"icon": "circle:#bb3322",
|
||||||
|
"iconSize": "15,15,center"
|
||||||
|
}
|
||||||
|
],
|
||||||
"tagRenderings": [
|
"tagRenderings": [
|
||||||
"all_tags",
|
"all_tags",
|
||||||
{
|
{
|
||||||
|
@ -465,25 +486,33 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"label": {
|
"mapRendering": [
|
||||||
"mappings": [
|
{
|
||||||
{
|
"location": [
|
||||||
"if": "addr:housenumber~*",
|
"point",
|
||||||
"then": "<div style='background-color: white; font: large; width: 1.5em; height: 1.5em; border-radius: 100%'>{addr:housenumber}</div>"
|
"center"
|
||||||
|
],
|
||||||
|
"iconSize": {
|
||||||
|
"render": "40,40,center"
|
||||||
|
},
|
||||||
|
"label": {
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "addr:housenumber~*",
|
||||||
|
"then": "<div style='background-color: white; font: large; width: 1.5em; height: 1.5em; border-radius: 100%'>{addr:housenumber}</div>"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
},
|
||||||
},
|
{
|
||||||
"width": {
|
"width": {
|
||||||
"render": "2"
|
"render": "2"
|
||||||
},
|
},
|
||||||
"iconSize": {
|
"color": {
|
||||||
"render": "40,40,center"
|
"render": "#00f"
|
||||||
},
|
}
|
||||||
"dashes": "2 2",
|
}
|
||||||
"color": {
|
],
|
||||||
"render": "#00f"
|
|
||||||
},
|
|
||||||
"wayHandling": 2,
|
|
||||||
"presets": []
|
"presets": []
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
"startZoom": 1,
|
"startZoom": 1,
|
||||||
"widenFactor": 0.05,
|
"widenFactor": 0.05,
|
||||||
"socialImage": "",
|
"socialImage": "",
|
||||||
|
"hideFromOverview": true,
|
||||||
"layers": [
|
"layers": [
|
||||||
{
|
{
|
||||||
"id": "sidewalks",
|
"id": "sidewalks",
|
||||||
|
@ -68,11 +69,11 @@
|
||||||
"renderings": [
|
"renderings": [
|
||||||
{
|
{
|
||||||
"id": "sidewalk_minimap",
|
"id": "sidewalk_minimap",
|
||||||
"render": "{sided_minimap(left|right):height:3rem;border-radius:0.5rem;overflow:hidden}"
|
"render": "{sided_minimap(left|right):height:8rem;border-radius:0.5rem;overflow:hidden}"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"id": "has_sidewalk",
|
"id": "has_sidewalk",
|
||||||
"question": "Is there a sidewalk on the left|right side of the road?",
|
"question": "Is there a sidewalk on this side of the road?",
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
"if": "sidewalk:left|right=yes",
|
"if": "sidewalk:left|right=yes",
|
||||||
|
@ -111,19 +112,21 @@
|
||||||
"iconSize": "20,20,center"
|
"iconSize": "20,20,center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"#": "The center line",
|
||||||
"color": "#ffffff55",
|
"color": "#ffffff55",
|
||||||
"width": 8
|
"width": 8
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"#": "left",
|
||||||
"color": {
|
"color": {
|
||||||
"render": "#888"
|
"render": "#888"
|
||||||
},
|
},
|
||||||
"dasharray": {
|
"dashArray": {
|
||||||
"render": "",
|
"render": "",
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
"if": "sidewalk:right=",
|
"if": "sidewalk:left=",
|
||||||
"then": "6,6"
|
"then": "1,12"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -133,7 +136,6 @@
|
||||||
{
|
{
|
||||||
"if": {
|
"if": {
|
||||||
"or": [
|
"or": [
|
||||||
"sidewalk:left=",
|
|
||||||
"sidewalk:left=no",
|
"sidewalk:left=no",
|
||||||
"sidewalk:left=separate"
|
"sidewalk:left=separate"
|
||||||
]
|
]
|
||||||
|
@ -146,12 +148,12 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"color": "#888",
|
"color": "#888",
|
||||||
"dasharray": {
|
"dashArray": {
|
||||||
"render": "",
|
"render": "",
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
"if": "sidewalk:right=",
|
"if": "sidewalk:right=",
|
||||||
"then": "6,6"
|
"then": "1,12"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -161,7 +163,6 @@
|
||||||
{
|
{
|
||||||
"if": {
|
"if": {
|
||||||
"or": [
|
"or": [
|
||||||
"sidewalk:right=",
|
|
||||||
"sidewalk:right=no",
|
"sidewalk:right=no",
|
||||||
"sidewalk:right=separate"
|
"sidewalk:right=separate"
|
||||||
]
|
]
|
||||||
|
|
|
@ -32,7 +32,7 @@ function fixLayerConfig(config: LayerConfigJson): void {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config.mapRendering === undefined || config.id !== "sidewalks") {
|
if (config.mapRendering === undefined && config.id !== "sidewalks") {
|
||||||
// This is a legacy format, lets create a pointRendering
|
// This is a legacy format, lets create a pointRendering
|
||||||
let location: ("point" | "centroid")[] = ["point"]
|
let location: ("point" | "centroid")[] = ["point"]
|
||||||
let wayHandling: number = config["wayHandling"] ?? 0
|
let wayHandling: number = config["wayHandling"] ?? 0
|
||||||
|
|
Loading…
Reference in a new issue