forked from MapComplete/MapComplete
		
	Refactoring: remove old and obsolete data fields in themes and layers
This commit is contained in:
		
							parent
							
								
									130ae82e90
								
							
						
					
					
						commit
						922cebf9d1
					
				
					 49 changed files with 574 additions and 664 deletions
				
			
		|  | @ -1,4 +1,28 @@ | ||||||
| { | { | ||||||
|  |   "id": "aerialway", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Aerialways", | ||||||
|  |     "de": "Seilbahnen" | ||||||
|  |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "Various forms of transport for passengers and goods that use wires, including cable cars, gondolas, chair lifts, drag lifts, and zip lines. ", | ||||||
|  |     "de": "Alle Arten von seil- oder drahtgestütztem Personen- oder Gütertransport, wie Seilbahnen, Gondeln, Sessellifte, Schlepplifte. " | ||||||
|  |   }, | ||||||
|  |   "source": { | ||||||
|  |     "osmTags": { | ||||||
|  |       "and": [ | ||||||
|  |         "aerialway~*", | ||||||
|  |         "aerialway!=pylon", | ||||||
|  |         "aerialway!=station" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Aerialway {name}", | ||||||
|  |       "de": "Seilbahn {name}" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -27,6 +51,27 @@ | ||||||
|       "labelCssClasses": "bg-white px-2 py-1 no-weblate" |       "labelCssClasses": "bg-white px-2 py-1 no-weblate" | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "lineRendering": [ | ||||||
|  |     { | ||||||
|  |       "width": "4", | ||||||
|  |       "color": "black", | ||||||
|  |       "imageAlongWay": [ | ||||||
|  |         { | ||||||
|  |           "if": "oneway=no", | ||||||
|  |           "then": "./assets/png/twoway.png" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "if": { | ||||||
|  |             "or": [ | ||||||
|  |               "oneway=yes", | ||||||
|  |               "oneway=" | ||||||
|  |             ] | ||||||
|  |           }, | ||||||
|  |           "then": "./assets/png/oneway.png" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     { |     { | ||||||
|  | @ -183,50 +228,5 @@ | ||||||
|         "de": "Die Seilbahn hat eine Länge von {_length:km} km" |         "de": "Die Seilbahn hat eine Länge von {_length:km} km" | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ], |   ] | ||||||
|   "lineRendering": [ |  | ||||||
|     { |  | ||||||
|       "width": "4", |  | ||||||
|       "color": "black", |  | ||||||
|       "imageAlongWay": [ |  | ||||||
|         { |  | ||||||
|           "if": "oneway=no", |  | ||||||
|           "then": "./assets/png/twoway.png" |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|           "if": { |  | ||||||
|             "or": [ |  | ||||||
|               "oneway=yes", |  | ||||||
|               "oneway=" |  | ||||||
|             ] |  | ||||||
|           }, |  | ||||||
|           "then": "./assets/png/oneway.png" |  | ||||||
|         } |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "id": "aerialway", |  | ||||||
|   "name": { |  | ||||||
|     "en": "Aerialways", |  | ||||||
|     "de": "Seilbahnen" |  | ||||||
|   }, |  | ||||||
|   "description": { |  | ||||||
|     "en": "Various forms of transport for passengers and goods that use wires, including cable cars, gondolas, chair lifts, drag lifts, and zip lines. ", |  | ||||||
|     "de": "Alle Arten von seil- oder drahtgestütztem Personen- oder Gütertransport, wie Seilbahnen, Gondeln, Sessellifte, Schlepplifte. " |  | ||||||
|   }, |  | ||||||
|   "source": { |  | ||||||
|     "osmTags": { |  | ||||||
|       "and": [ |  | ||||||
|         "aerialway~*", |  | ||||||
|         "aerialway!=pylon", |  | ||||||
|         "aerialway!=station" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Aerialway {name}", |  | ||||||
|       "de": "Seilbahn {name}" |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,8 +1,5 @@ | ||||||
| { | { | ||||||
|   "allowMove": { |   "id": "assembly_point", | ||||||
|     "enableRelocation": false, |  | ||||||
|     "enableImproveAccuracy": true |  | ||||||
|   }, |  | ||||||
|   "name": { |   "name": { | ||||||
|     "en": "Emergency assembly points", |     "en": "Emergency assembly points", | ||||||
|     "it": "Punti di raccolta per emergenze", |     "it": "Punti di raccolta per emergenze", | ||||||
|  | @ -13,9 +10,6 @@ | ||||||
|     "it": "Questo livello contiene punti di raccolta e aree di attesa in cui tutti i dipendenti, i passeggeri o una grande folla si riuniscono in caso di emergenza.", |     "it": "Questo livello contiene punti di raccolta e aree di attesa in cui tutti i dipendenti, i passeggeri o una grande folla si riuniscono in caso di emergenza.", | ||||||
|     "de": "Diese Ebene enthält Sammelplätze und Wartebereiche, in denen sich alle Mitarbeiter, Fahrgäste oder eine große Menschenmenge im Notfall versammeln." |     "de": "Diese Ebene enthält Sammelplätze und Wartebereiche, in denen sich alle Mitarbeiter, Fahrgäste oder eine große Menschenmenge im Notfall versammeln." | ||||||
|   }, |   }, | ||||||
|   "docs": "https://wiki.openstreetmap.org/wiki/Tag:emergency%3Dassembly_point", |  | ||||||
|   "id": "assembly_point", |  | ||||||
|   "minzoom": 10, |  | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": { |     "osmTags": { | ||||||
|       "and": [ |       "and": [ | ||||||
|  | @ -23,6 +17,13 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|  |   "minzoom": 10, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Assembly point during emergencies", | ||||||
|  |       "de": "Sammelplatz bei Notfällen" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "iconSize": "20,20", |       "iconSize": "20,20", | ||||||
|  | @ -50,12 +51,6 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Assembly point during emergencies", |  | ||||||
|       "de": "Sammelplatz bei Notfällen" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     { |     { | ||||||
|  | @ -154,5 +149,10 @@ | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ] |   ], | ||||||
|  |   "allowMove": { | ||||||
|  |     "enableRelocation": false, | ||||||
|  |     "enableImproveAccuracy": true | ||||||
|  |   }, | ||||||
|  |   "docs": "https://wiki.openstreetmap.org/wiki/Tag:emergency%3Dassembly_point" | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -5,7 +5,12 @@ | ||||||
|     "nl": "Oplaadpunten", |     "nl": "Oplaadpunten", | ||||||
|     "de": "Ladestationen" |     "de": "Ladestationen" | ||||||
|   }, |   }, | ||||||
|   "minzoom": 10, |   "description": { | ||||||
|  |     "en": "A charging station", | ||||||
|  |     "nl": "Oplaadpunten", | ||||||
|  |     "ca": "Una estació de càrrega", | ||||||
|  |     "de": "Eine Ladestation" | ||||||
|  |   }, | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": { |     "osmTags": { | ||||||
|       "and": [ |       "and": [ | ||||||
|  | @ -20,6 +25,7 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|  |   "minzoom": 10, | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|       "en": "Charging station", |       "en": "Charging station", | ||||||
|  | @ -65,13 +71,103 @@ | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|   "description": { |   "pointRendering": [ | ||||||
|     "en": "A charging station", |     { | ||||||
|     "nl": "Oplaadpunten", |       "location": [ | ||||||
|     "ca": "Una estació de càrrega", |         "point", | ||||||
|     "de": "Eine Ladestation" |         "centroid" | ||||||
|   }, |       ], | ||||||
|   "#": "no-question-hint-check", |       "marker": [ | ||||||
|  |         { | ||||||
|  |           "icon": "pin", | ||||||
|  |           "color": "#fff" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "icon": { | ||||||
|  |             "render": "./assets/themes/charging_stations/plug.svg", | ||||||
|  |             "mappings": [ | ||||||
|  |               { | ||||||
|  |                 "if": "bicycle=yes", | ||||||
|  |                 "then": "./assets/themes/charging_stations/bicycle.svg" | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 "if": { | ||||||
|  |                   "or": [ | ||||||
|  |                     "car=yes", | ||||||
|  |                     "motorcar=yes" | ||||||
|  |                   ] | ||||||
|  |                 }, | ||||||
|  |                 "then": "./assets/themes/charging_stations/car.svg" | ||||||
|  |               } | ||||||
|  |             ] | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "iconBadges": [ | ||||||
|  |         { | ||||||
|  |           "if": { | ||||||
|  |             "or": [ | ||||||
|  |               "disused:amenity=charging_station", | ||||||
|  |               "operational_status=broken" | ||||||
|  |             ] | ||||||
|  |           }, | ||||||
|  |           "then": "close:#c22;" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "if": { | ||||||
|  |             "or": [ | ||||||
|  |               "proposed:amenity=charging_station", | ||||||
|  |               "planned:amenity=charging_station" | ||||||
|  |             ] | ||||||
|  |           }, | ||||||
|  |           "then": "./assets/layers/charging_station/under_construction.svg" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "if": { | ||||||
|  |             "and": [ | ||||||
|  |               "bicycle=yes", | ||||||
|  |               { | ||||||
|  |                 "or": [ | ||||||
|  |                   "motorcar=yes", | ||||||
|  |                   "car=yes" | ||||||
|  |                 ] | ||||||
|  |               } | ||||||
|  |             ] | ||||||
|  |           }, | ||||||
|  |           "then": "circle:#fff;./assets/themes/charging_stations/car.svg" | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "anchor": "bottom", | ||||||
|  |       "iconSize": "50,50" | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "lineRendering": [], | ||||||
|  |   "presets": [ | ||||||
|  |     { | ||||||
|  |       "tags": [ | ||||||
|  |         "amenity=charging_station", | ||||||
|  |         "motorcar=no", | ||||||
|  |         "bicycle=yes" | ||||||
|  |       ], | ||||||
|  |       "title": { | ||||||
|  |         "en": "charging station for electrical bikes", | ||||||
|  |         "nl": "oplaadpunt voor elektrische fietsen", | ||||||
|  |         "de": "Ladestation für Elektrofahrräder" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "tags": [ | ||||||
|  |         "amenity=charging_station", | ||||||
|  |         "motorcar=yes", | ||||||
|  |         "bicycle=no" | ||||||
|  |       ], | ||||||
|  |       "title": { | ||||||
|  |         "en": "charging station for cars", | ||||||
|  |         "nl": "oplaadstation voor elektrische auto's", | ||||||
|  |         "de": "Ladestation für Elektrofahrräder" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     { |     { | ||||||
|  | @ -2316,103 +2412,6 @@ | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "lineRendering": [], |  | ||||||
|   "pointRendering": [ |  | ||||||
|     { |  | ||||||
|       "location": [ |  | ||||||
|         "point", |  | ||||||
|         "centroid" |  | ||||||
|       ], |  | ||||||
|       "marker": [ |  | ||||||
|         { |  | ||||||
|           "icon": "pin", |  | ||||||
|           "color": "#fff" |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|           "icon": { |  | ||||||
|             "render": "./assets/themes/charging_stations/plug.svg", |  | ||||||
|             "mappings": [ |  | ||||||
|               { |  | ||||||
|                 "if": "bicycle=yes", |  | ||||||
|                 "then": "./assets/themes/charging_stations/bicycle.svg" |  | ||||||
|               }, |  | ||||||
|               { |  | ||||||
|                 "if": { |  | ||||||
|                   "or": [ |  | ||||||
|                     "car=yes", |  | ||||||
|                     "motorcar=yes" |  | ||||||
|                   ] |  | ||||||
|                 }, |  | ||||||
|                 "then": "./assets/themes/charging_stations/car.svg" |  | ||||||
|               } |  | ||||||
|             ] |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|       ], |  | ||||||
|       "iconBadges": [ |  | ||||||
|         { |  | ||||||
|           "if": { |  | ||||||
|             "or": [ |  | ||||||
|               "disused:amenity=charging_station", |  | ||||||
|               "operational_status=broken" |  | ||||||
|             ] |  | ||||||
|           }, |  | ||||||
|           "then": "close:#c22;" |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|           "if": { |  | ||||||
|             "or": [ |  | ||||||
|               "proposed:amenity=charging_station", |  | ||||||
|               "planned:amenity=charging_station" |  | ||||||
|             ] |  | ||||||
|           }, |  | ||||||
|           "then": "./assets/layers/charging_station/under_construction.svg" |  | ||||||
|         }, |  | ||||||
|         { |  | ||||||
|           "if": { |  | ||||||
|             "and": [ |  | ||||||
|               "bicycle=yes", |  | ||||||
|               { |  | ||||||
|                 "or": [ |  | ||||||
|                   "motorcar=yes", |  | ||||||
|                   "car=yes" |  | ||||||
|                 ] |  | ||||||
|               } |  | ||||||
|             ] |  | ||||||
|           }, |  | ||||||
|           "then": "circle:#fff;./assets/themes/charging_stations/car.svg" |  | ||||||
|         } |  | ||||||
|       ], |  | ||||||
|       "anchor": "bottom", |  | ||||||
|       "iconSize": "50,50" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "presets": [ |  | ||||||
|     { |  | ||||||
|       "tags": [ |  | ||||||
|         "amenity=charging_station", |  | ||||||
|         "motorcar=no", |  | ||||||
|         "bicycle=yes" |  | ||||||
|       ], |  | ||||||
|       "title": { |  | ||||||
|         "en": "charging station for electrical bikes", |  | ||||||
|         "nl": "oplaadpunt voor elektrische fietsen", |  | ||||||
|         "de": "Ladestation für Elektrofahrräder" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "tags": [ |  | ||||||
|         "amenity=charging_station", |  | ||||||
|         "motorcar=yes", |  | ||||||
|         "bicycle=no" |  | ||||||
|       ], |  | ||||||
|       "title": { |  | ||||||
|         "en": "charging station for cars", |  | ||||||
|         "nl": "oplaadstation voor elektrische auto's", |  | ||||||
|         "de": "Ladestation für Elektrofahrräder" |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "filter": [ |   "filter": [ | ||||||
|     { |     { | ||||||
|       "id": "vehicle-type", |       "id": "vehicle-type", | ||||||
|  | @ -2611,6 +2610,20 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "deletion": { | ||||||
|  |     "softDeletionTags": { | ||||||
|  |       "and": [ | ||||||
|  |         "amenity=", | ||||||
|  |         "disused:amenity=charging_station" | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     "neededChangesets": 10 | ||||||
|  |   }, | ||||||
|  |   "allowMove": { | ||||||
|  |     "enableRelocation": false, | ||||||
|  |     "enableImproveAccuracy": true | ||||||
|  |   }, | ||||||
|  |   "#": "no-question-hint-check", | ||||||
|   "units": [ |   "units": [ | ||||||
|     { |     { | ||||||
|       "maxstay": { |       "maxstay": { | ||||||
|  | @ -2759,18 +2772,5 @@ | ||||||
|         ] |         ] | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ], |   ] | ||||||
|   "allowMove": { |  | ||||||
|     "enableRelocation": false, |  | ||||||
|     "enableImproveAccuracy": true |  | ||||||
|   }, |  | ||||||
|   "deletion": { |  | ||||||
|     "softDeletionTags": { |  | ||||||
|       "and": [ |  | ||||||
|         "amenity=", |  | ||||||
|         "disused:amenity=charging_station" |  | ||||||
|       ] |  | ||||||
|     }, |  | ||||||
|     "neededChangesets": 10 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  | @ -35,7 +35,6 @@ | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "minzoom": 19, |   "minzoom": 19, | ||||||
|   "doCount": false, |  | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|       "en": "Climbing opportunity?", |       "en": "Climbing opportunity?", | ||||||
|  | @ -148,5 +147,6 @@ | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ] |   ], | ||||||
|  |   "doCount": false | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -5,8 +5,7 @@ | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": "HUISNR~*", |     "osmTags": "HUISNR~*", | ||||||
|     "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/CRAB_2021_10_26/tile_{z}_{x}_{y}.geojson", |     "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/CRAB_2021_10_26/tile_{z}_{x}_{y}.geojson", | ||||||
|     "geoJsonZoomLevel": 18, |     "geoJsonZoomLevel": 18 | ||||||
|     "maxCacheAge": 0 |  | ||||||
|   }, |   }, | ||||||
|   "calculatedTags": [ |   "calculatedTags": [ | ||||||
|     "_HNRLABEL=(() => {const lbl = feat.properties.HNRLABEL?.split('-')?.map(l => Number(l))?.filter(i => !isNaN (i)) ;if(lbl?.length != 2) {return feat.properties.HNRLABEL}; const addresses = []; for(let i = lbl[0]; i <= lbl[1]; i += 1){addresses.push(''+i);}; return addresses.join(';')        })()" |     "_HNRLABEL=(() => {const lbl = feat.properties.HNRLABEL?.split('-')?.map(l => Number(l))?.filter(i => !isNaN (i)) ;if(lbl?.length != 2) {return feat.properties.HNRLABEL}; const addresses = []; for(let i = lbl[0]; i <= lbl[1]; i += 1){addresses.push(''+i);}; return addresses.join(';')        })()" | ||||||
|  |  | ||||||
|  | @ -1,12 +1,5 @@ | ||||||
| { | { | ||||||
|   "id": "disaster_response", |   "id": "disaster_response", | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Disaster response organization", |  | ||||||
|       "it": "Organizzazione per la risposta ai disastri", |  | ||||||
|       "de": "Katastrophenschutzorganisation" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "name": { |   "name": { | ||||||
|     "en": "Disaster response organizations", |     "en": "Disaster response organizations", | ||||||
|     "de": "Katastrophenschutzorganisationen" |     "de": "Katastrophenschutzorganisationen" | ||||||
|  | @ -16,8 +9,36 @@ | ||||||
|     "it": "Questo livello contiene organizzazioni che hanno come obiettivo principale quello di aiutare la popolazione civile durante e dopo disastri naturali o antropogenici, lavorando nell'area colpita.", |     "it": "Questo livello contiene organizzazioni che hanno come obiettivo principale quello di aiutare la popolazione civile durante e dopo disastri naturali o antropogenici, lavorando nell'area colpita.", | ||||||
|     "de": "Diese Ebene umfasst Organisationen, deren Hauptziel es ist, der Zivilbevölkerung während und nach Natur- oder anthropogenen Katastrophen zu helfen, indem sie in dem betroffenen Gebiet tätig sind." |     "de": "Diese Ebene umfasst Organisationen, deren Hauptziel es ist, der Zivilbevölkerung während und nach Natur- oder anthropogenen Katastrophen zu helfen, indem sie in dem betroffenen Gebiet tätig sind." | ||||||
|   }, |   }, | ||||||
|   "docs": "https://wiki.openstreetmap.org/wiki/Tag:emergency%3Ddisaster_response", |   "source": { | ||||||
|  |     "osmTags": { | ||||||
|  |       "and": [ | ||||||
|  |         "emergency=disaster_response" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "minzoom": 10, |   "minzoom": 10, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Disaster response organization", | ||||||
|  |       "it": "Organizzazione per la risposta ai disastri", | ||||||
|  |       "de": "Katastrophenschutzorganisation" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "pointRendering": [ | ||||||
|  |     { | ||||||
|  |       "iconSize": "40,40", | ||||||
|  |       "location": [ | ||||||
|  |         "point", | ||||||
|  |         "centroid" | ||||||
|  |       ], | ||||||
|  |       "anchor": "bottom", | ||||||
|  |       "marker": [ | ||||||
|  |         { | ||||||
|  |           "icon": "./assets/themes/disaster_response/CivilDefence.svg" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "lineRendering": [ |   "lineRendering": [ | ||||||
|     { |     { | ||||||
|       "color": "#6BC4F7", |       "color": "#6BC4F7", | ||||||
|  | @ -36,28 +57,6 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "source": { |  | ||||||
|     "osmTags": { |  | ||||||
|       "and": [ |  | ||||||
|         "emergency=disaster_response" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "pointRendering": [ |  | ||||||
|     { |  | ||||||
|       "iconSize": "40,40", |  | ||||||
|       "location": [ |  | ||||||
|         "point", |  | ||||||
|         "centroid" |  | ||||||
|       ], |  | ||||||
|       "anchor": "bottom", |  | ||||||
|       "marker": [ |  | ||||||
|         { |  | ||||||
|           "icon": "./assets/themes/disaster_response/CivilDefence.svg" |  | ||||||
|         } |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     "website", |     "website", | ||||||
|  | @ -77,5 +76,6 @@ | ||||||
|         "de": "Diese Organisation heißt <b>{name}</b>" |         "de": "Diese Organisation heißt <b>{name}</b>" | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ] |   ], | ||||||
|  |   "docs": "https://wiki.openstreetmap.org/wiki/Tag:emergency%3Ddisaster_response" | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -4,7 +4,6 @@ | ||||||
|     "en": "Ice cream parlors", |     "en": "Ice cream parlors", | ||||||
|     "de": "Eisdielen" |     "de": "Eisdielen" | ||||||
|   }, |   }, | ||||||
|   "minzoom": 14, |  | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "A place where ice cream is sold over the counter", |     "en": "A place where ice cream is sold over the counter", | ||||||
|     "de": "Ein Ort, an dem Eiscreme an der Theke verkauft wird" |     "de": "Ein Ort, an dem Eiscreme an der Theke verkauft wird" | ||||||
|  | @ -12,6 +11,7 @@ | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": "amenity=ice_cream" |     "osmTags": "amenity=ice_cream" | ||||||
|   }, |   }, | ||||||
|  |   "minzoom": 14, | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|       "en": "Ice cream parlor", |       "en": "Ice cream parlor", | ||||||
|  |  | ||||||
|  | @ -1,7 +1,9 @@ | ||||||
| { | { | ||||||
|   "id": "item_with_image", |   "id": "item_with_image", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Items with at least one image" | ||||||
|  |   }, | ||||||
|   "description": "All items with an image. All alone, not a layer which is relevant for any MapComplete theme, as it is a random collection of items. However, when put into the databank, this allows to quickly fetch (the URL of) pictures nearby a different object, to quickly link this", |   "description": "All items with an image. All alone, not a layer which is relevant for any MapComplete theme, as it is a random collection of items. However, when put into the databank, this allows to quickly fetch (the URL of) pictures nearby a different object, to quickly link this", | ||||||
|   "minzoom": 14, |  | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": { |     "osmTags": { | ||||||
|       "or": [ |       "or": [ | ||||||
|  | @ -15,9 +17,7 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "tagRenderings": [ |   "minzoom": 14, | ||||||
|     "images" |  | ||||||
|   ], |  | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|       "en": "POI with image" |       "en": "POI with image" | ||||||
|  | @ -31,10 +31,6 @@ | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|   "name": { |  | ||||||
|     "en": "Items with at least one image" |  | ||||||
|   }, |  | ||||||
|   "lineRendering": [], |  | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "marker": [ |       "marker": [ | ||||||
|  | @ -47,5 +43,9 @@ | ||||||
|         "point" |         "point" | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |   ], | ||||||
|  |   "lineRendering": [], | ||||||
|  |   "tagRenderings": [ | ||||||
|  |     "images" | ||||||
|   ] |   ] | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -10,8 +10,7 @@ | ||||||
|   }, |   }, | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": "mr_taskId~*", |     "osmTags": "mr_taskId~*", | ||||||
|     "geoJson": "https://maproulette.org/api/v2/challenge/view/27971", |     "geoJson": "https://maproulette.org/api/v2/challenge/view/27971" | ||||||
|     "isOsmCache": false |  | ||||||
|   }, |   }, | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,23 @@ | ||||||
| { | { | ||||||
|   "credits": "Not logged in", |   "id": "mountain_rescue", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Mountain rescue stations", | ||||||
|  |     "de": "Bergrettungsstationen" | ||||||
|  |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "A building where first aid responders store material and might be on watch", | ||||||
|  |     "de": "Ein Gebäude, in dem die Ersthelfer Material lagern und möglicherweise Wache halten" | ||||||
|  |   }, | ||||||
|  |   "source": { | ||||||
|  |     "osmTags": "emergency=mountain_rescue" | ||||||
|  |   }, | ||||||
|   "minzoom": 10, |   "minzoom": 10, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Mountain rescue station", | ||||||
|  |       "de": "Bergrettungsstation" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -19,37 +36,12 @@ | ||||||
|       "rotation": "45" |       "rotation": "45" | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "tagRenderings": [ |  | ||||||
|     "images" |  | ||||||
|   ], |  | ||||||
|   "lineRendering": [ |   "lineRendering": [ | ||||||
|     { |     { | ||||||
|       "width": "3", |       "width": "3", | ||||||
|       "color": "#ed333b" |       "color": "#ed333b" | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "id": "mountain_rescue", |  | ||||||
|   "name": { |  | ||||||
|     "en": "Mountain rescue stations", |  | ||||||
|     "de": "Bergrettungsstationen" |  | ||||||
|   }, |  | ||||||
|   "description": { |  | ||||||
|     "en": "A building where first aid responders store material and might be on watch", |  | ||||||
|     "de": "Ein Gebäude, in dem die Ersthelfer Material lagern und möglicherweise Wache halten" |  | ||||||
|   }, |  | ||||||
|   "source": { |  | ||||||
|     "osmTags": "emergency=mountain_rescue" |  | ||||||
|   }, |  | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Mountain rescue station", |  | ||||||
|       "de": "Bergrettungsstation" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "deletion": true, |  | ||||||
|   "allowMove": { |  | ||||||
|     "enableRelocation": false |  | ||||||
|   }, |  | ||||||
|   "presets": [ |   "presets": [ | ||||||
|     { |     { | ||||||
|       "title": { |       "title": { | ||||||
|  | @ -60,5 +52,13 @@ | ||||||
|         "emergency=mountain_rescue" |         "emergency=mountain_rescue" | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ] |   ], | ||||||
|  |   "tagRenderings": [ | ||||||
|  |     "images" | ||||||
|  |   ], | ||||||
|  |   "deletion": true, | ||||||
|  |   "allowMove": { | ||||||
|  |     "enableRelocation": false | ||||||
|  |   }, | ||||||
|  |   "credits": "Not logged in" | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -12,9 +12,7 @@ | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": "date_created~*", |     "osmTags": "date_created~*", | ||||||
|     "geoJson": "https://api.openstreetmap.org/api/0.6/notes.json?limit=10000&closed=7&bbox={x_min},{y_min},{x_max},{y_max}", |     "geoJson": "https://api.openstreetmap.org/api/0.6/notes.json?limit=10000&closed=7&bbox={x_min},{y_min},{x_max},{y_max}", | ||||||
|     "geoJsonZoomLevel": 12, |     "geoJsonZoomLevel": 12 | ||||||
|     "maxCacheAge": 0, |  | ||||||
|     "isOsmCache": false |  | ||||||
|   }, |   }, | ||||||
|   "calculatedTags": [ |   "calculatedTags": [ | ||||||
|     "_total_comments:=get(feat)('comments').length", |     "_total_comments:=get(feat)('comments').length", | ||||||
|  |  | ||||||
|  | @ -19,8 +19,7 @@ | ||||||
|   "source": { |   "source": { | ||||||
|     "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/community_index/tile_{z}_{x}_{y}.geojson", |     "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/community_index/tile_{z}_{x}_{y}.geojson", | ||||||
|     "geoJsonZoomLevel": 6, |     "geoJsonZoomLevel": 6, | ||||||
|     "osmTags": "resources~*", |     "osmTags": "resources~*" | ||||||
|     "isOsmCache": false |  | ||||||
|   }, |   }, | ||||||
|   "calculatedTags": [ |   "calculatedTags": [ | ||||||
|     "_community_links=Object.values(JSON.parse(feat.properties.resources || '{}')).map(value =>{return value.resolved.nameHTML + '<br> ' + value.resolved.descriptionHTML}).join('<br>')" |     "_community_links=Object.values(JSON.parse(feat.properties.resources || '{}')).map(value =>{return value.resolved.nameHTML + '<br> ' + value.resolved.descriptionHTML}).join('<br>')" | ||||||
|  |  | ||||||
|  | @ -1,5 +1,20 @@ | ||||||
| { | { | ||||||
|  |   "id": "playground_equipment", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Playground equipment" | ||||||
|  |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "Layer showing playground equipment" | ||||||
|  |   }, | ||||||
|  |   "source": { | ||||||
|  |     "osmTags": "playground~*" | ||||||
|  |   }, | ||||||
|   "minzoom": 18, |   "minzoom": 18, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Playground device" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -18,6 +33,25 @@ | ||||||
|       "iconSize": "20,20" |       "iconSize": "20,20" | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "lineRendering": [ | ||||||
|  |     { | ||||||
|  |       "width": 1, | ||||||
|  |       "color": "blue" | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "presets": [ | ||||||
|  |     { | ||||||
|  |       "tags": [ | ||||||
|  |         "playground=yes" | ||||||
|  |       ], | ||||||
|  |       "title": { | ||||||
|  |         "en": "a playground device" | ||||||
|  |       }, | ||||||
|  |       "description": { | ||||||
|  |         "en": "An exact type is asked later" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     { |     { | ||||||
|  | @ -299,39 +333,5 @@ | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "lineRendering": [ |   "allowMove": true | ||||||
|     { |  | ||||||
|       "width": 1, |  | ||||||
|       "color": "blue" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "id": "playground_equipment", |  | ||||||
|   "name": { |  | ||||||
|     "en": "Playground equipment" |  | ||||||
|   }, |  | ||||||
|   "description": { |  | ||||||
|     "en": "Layer showing playground equipment" |  | ||||||
|   }, |  | ||||||
|   "source": { |  | ||||||
|     "osmTags": "playground~*" |  | ||||||
|   }, |  | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Playground device" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "allowMove": true, |  | ||||||
|   "presets": [ |  | ||||||
|     { |  | ||||||
|       "tags": [ |  | ||||||
|         "playground=yes" |  | ||||||
|       ], |  | ||||||
|       "title": { |  | ||||||
|         "en": "a playground device" |  | ||||||
|       }, |  | ||||||
|       "description": { |  | ||||||
|         "en": "An exact type is asked later" |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   ] |  | ||||||
| } | } | ||||||
|  | @ -1,4 +1,32 @@ | ||||||
| { | { | ||||||
|  |   "id": "ski_piste", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Ski and snowboard pistes", | ||||||
|  |     "de": "Ski- und Snowboardpisten" | ||||||
|  |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "Ski and snowboard pistes", | ||||||
|  |     "de": "Ski- und Snowboardpisten" | ||||||
|  |   }, | ||||||
|  |   "source": { | ||||||
|  |     "osmTags": { | ||||||
|  |       "and": [ | ||||||
|  |         { | ||||||
|  |           "or": [ | ||||||
|  |             "piste:type=downhill", | ||||||
|  |             "piste:type=connection" | ||||||
|  |           ] | ||||||
|  |         }, | ||||||
|  |         "area!=yes" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Ski piste {name}", | ||||||
|  |       "de": "Skipiste {name}" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -12,6 +40,40 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "lineRendering": [ | ||||||
|  |     { | ||||||
|  |       "width": "10", | ||||||
|  |       "color": { | ||||||
|  |         "mappings": [ | ||||||
|  |           { | ||||||
|  |             "then": "green", | ||||||
|  |             "if": "piste:difficulty=novice" | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             "if": "piste:difficulty=easy", | ||||||
|  |             "then": "blue" | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             "if": "piste:difficulty=intermediate", | ||||||
|  |             "then": "red" | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             "if": "piste:difficulty=advanced", | ||||||
|  |             "then": "black" | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             "if": "piste:difficulty=expert", | ||||||
|  |             "then": "orange" | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             "if": "piste:difficulty=", | ||||||
|  |             "then": "gray" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       }, | ||||||
|  |       "imageAlongWay": "./assets/png/oneway.png" | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     { |     { | ||||||
|  | @ -73,67 +135,5 @@ | ||||||
|         "de": "Dieser Teil der Skipiste hat eine Länge von {_length:km} km" |         "de": "Dieser Teil der Skipiste hat eine Länge von {_length:km} km" | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ], |   ] | ||||||
|   "lineRendering": [ |  | ||||||
|     { |  | ||||||
|       "width": "10", |  | ||||||
|       "color": { |  | ||||||
|         "mappings": [ |  | ||||||
|           { |  | ||||||
|             "then": "green", |  | ||||||
|             "if": "piste:difficulty=novice" |  | ||||||
|           }, |  | ||||||
|           { |  | ||||||
|             "if": "piste:difficulty=easy", |  | ||||||
|             "then": "blue" |  | ||||||
|           }, |  | ||||||
|           { |  | ||||||
|             "if": "piste:difficulty=intermediate", |  | ||||||
|             "then": "red" |  | ||||||
|           }, |  | ||||||
|           { |  | ||||||
|             "if": "piste:difficulty=advanced", |  | ||||||
|             "then": "black" |  | ||||||
|           }, |  | ||||||
|           { |  | ||||||
|             "if": "piste:difficulty=expert", |  | ||||||
|             "then": "orange" |  | ||||||
|           }, |  | ||||||
|           { |  | ||||||
|             "if": "piste:difficulty=", |  | ||||||
|             "then": "gray" |  | ||||||
|           } |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "imageAlongWay": "./assets/png/oneway.png" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "id": "ski_piste", |  | ||||||
|   "name": { |  | ||||||
|     "en": "Ski and snowboard pistes", |  | ||||||
|     "de": "Ski- und Snowboardpisten" |  | ||||||
|   }, |  | ||||||
|   "description": { |  | ||||||
|     "en": "Ski and snowboard pistes", |  | ||||||
|     "de": "Ski- und Snowboardpisten" |  | ||||||
|   }, |  | ||||||
|   "source": { |  | ||||||
|     "osmTags": { |  | ||||||
|       "and": [ |  | ||||||
|         { |  | ||||||
|           "or": [ |  | ||||||
|             "piste:type=downhill", |  | ||||||
|             "piste:type=connection" |  | ||||||
|           ] |  | ||||||
|         }, |  | ||||||
|         "area!=yes" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Ski piste {name}", |  | ||||||
|       "de": "Skipiste {name}" |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,4 +1,24 @@ | ||||||
| { | { | ||||||
|  |   "id": "souvenir_coin", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Souvenir Coin Machines" | ||||||
|  |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "Layer showing machines selling souvenir coins" | ||||||
|  |   }, | ||||||
|  |   "source": { | ||||||
|  |     "osmTags": { | ||||||
|  |       "and": [ | ||||||
|  |         "amenity=vending_machine", | ||||||
|  |         "vending~.*souvenir_coins.*" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Souvenir Coin Machine" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -22,6 +42,26 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "lineRendering": [ | ||||||
|  |     { | ||||||
|  |       "width": 1, | ||||||
|  |       "color": "blue" | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "presets": [ | ||||||
|  |     { | ||||||
|  |       "title": { | ||||||
|  |         "en": "a souvenir coin machine" | ||||||
|  |       }, | ||||||
|  |       "description": { | ||||||
|  |         "en": "Add a machine selling souvenir coins" | ||||||
|  |       }, | ||||||
|  |       "tags": [ | ||||||
|  |         "amenity=vending_machine", | ||||||
|  |         "vending=souvenir_coins" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     "opening_hours_24_7", |     "opening_hours_24_7", | ||||||
|  | @ -110,46 +150,6 @@ | ||||||
|     "level", |     "level", | ||||||
|     "check_date" |     "check_date" | ||||||
|   ], |   ], | ||||||
|   "lineRendering": [ |  | ||||||
|     { |  | ||||||
|       "width": 1, |  | ||||||
|       "color": "blue" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "id": "souvenir_coin", |  | ||||||
|   "name": { |  | ||||||
|     "en": "Souvenir Coin Machines" |  | ||||||
|   }, |  | ||||||
|   "description": { |  | ||||||
|     "en": "Layer showing machines selling souvenir coins" |  | ||||||
|   }, |  | ||||||
|   "source": { |  | ||||||
|     "osmTags": { |  | ||||||
|       "and": [ |  | ||||||
|         "amenity=vending_machine", |  | ||||||
|         "vending~.*souvenir_coins.*" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Souvenir Coin Machine" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "presets": [ |  | ||||||
|     { |  | ||||||
|       "title": { |  | ||||||
|         "en": "a souvenir coin machine" |  | ||||||
|       }, |  | ||||||
|       "description": { |  | ||||||
|         "en": "Add a machine selling souvenir coins" |  | ||||||
|       }, |  | ||||||
|       "tags": [ |  | ||||||
|         "amenity=vending_machine", |  | ||||||
|         "vending=souvenir_coins" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "filter": [ |   "filter": [ | ||||||
|     "open_now", |     "open_now", | ||||||
|     "accepts_debit_cards", |     "accepts_debit_cards", | ||||||
|  |  | ||||||
|  | @ -1,4 +1,24 @@ | ||||||
| { | { | ||||||
|  |   "id": "souvenir_note", | ||||||
|  |   "name": { | ||||||
|  |     "en": "Souvenir Banknote Machines" | ||||||
|  |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "Layer showing machines selling souvenir banknotes" | ||||||
|  |   }, | ||||||
|  |   "source": { | ||||||
|  |     "osmTags": { | ||||||
|  |       "and": [ | ||||||
|  |         "amenity=vending_machine", | ||||||
|  |         "vending~.*souvenir_notes.*" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "title": { | ||||||
|  |     "render": { | ||||||
|  |       "en": "Souvenir Banknote Machine" | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -22,6 +42,26 @@ | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "lineRendering": [ | ||||||
|  |     { | ||||||
|  |       "width": 1, | ||||||
|  |       "color": "blue" | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "presets": [ | ||||||
|  |     { | ||||||
|  |       "title": { | ||||||
|  |         "en": "a souvenir banknote machine" | ||||||
|  |       }, | ||||||
|  |       "description": { | ||||||
|  |         "en": "Add a machine selling souvenir banknotes" | ||||||
|  |       }, | ||||||
|  |       "tags": [ | ||||||
|  |         "amenity=vending_machine", | ||||||
|  |         "vending=souvenir_notes" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     "images", |     "images", | ||||||
|     "opening_hours_24_7", |     "opening_hours_24_7", | ||||||
|  | @ -128,46 +168,6 @@ | ||||||
|     "level", |     "level", | ||||||
|     "check_date" |     "check_date" | ||||||
|   ], |   ], | ||||||
|   "lineRendering": [ |  | ||||||
|     { |  | ||||||
|       "width": 1, |  | ||||||
|       "color": "blue" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "id": "souvenir_note", |  | ||||||
|   "name": { |  | ||||||
|     "en": "Souvenir Banknote Machines" |  | ||||||
|   }, |  | ||||||
|   "description": { |  | ||||||
|     "en": "Layer showing machines selling souvenir banknotes" |  | ||||||
|   }, |  | ||||||
|   "source": { |  | ||||||
|     "osmTags": { |  | ||||||
|       "and": [ |  | ||||||
|         "amenity=vending_machine", |  | ||||||
|         "vending~.*souvenir_notes.*" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "title": { |  | ||||||
|     "render": { |  | ||||||
|       "en": "Souvenir Banknote Machine" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "presets": [ |  | ||||||
|     { |  | ||||||
|       "title": { |  | ||||||
|         "en": "a souvenir banknote machine" |  | ||||||
|       }, |  | ||||||
|       "description": { |  | ||||||
|         "en": "Add a machine selling souvenir banknotes" |  | ||||||
|       }, |  | ||||||
|       "tags": [ |  | ||||||
|         "amenity=vending_machine", |  | ||||||
|         "vending=souvenir_notes" |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "filter": [ |   "filter": [ | ||||||
|     "open_now", |     "open_now", | ||||||
|     "accepts_debit_cards", |     "accepts_debit_cards", | ||||||
|  |  | ||||||
|  | @ -9,8 +9,7 @@ | ||||||
|     "de": "Ein Ort, an dem erotische Tanz-, Striptease- oder Lapdances kommerziell durchgeführt werden. " |     "de": "Ein Ort, an dem erotische Tanz-, Striptease- oder Lapdances kommerziell durchgeführt werden. " | ||||||
|   }, |   }, | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": "amenity=stripclub", |     "osmTags": "amenity=stripclub" | ||||||
|     "isOsmCache": false |  | ||||||
|   }, |   }, | ||||||
|   "minzoom": 6, |   "minzoom": 6, | ||||||
|   "title": { |   "title": { | ||||||
|  |  | ||||||
|  | @ -7,9 +7,6 @@ | ||||||
|       "en": "Summary" |       "en": "Summary" | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "tagRenderings": [ |  | ||||||
|     "all_tags" |  | ||||||
|   ], |  | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|     { |     { | ||||||
|       "location": [ |       "location": [ | ||||||
|  | @ -17,11 +14,12 @@ | ||||||
|         "centroid" |         "centroid" | ||||||
|       ], |       ], | ||||||
|       "iconSize": "40,40", |       "iconSize": "40,40", | ||||||
|       "label": { |       "label": "{total_metric}", | ||||||
|         "render": "{total_metric}" |  | ||||||
|       }, |  | ||||||
|       "labelCss": "background: #ffffffbb", |       "labelCss": "background: #ffffffbb", | ||||||
|       "labelCssClasses": "w-12 text-lg rounded-xl p-1 px-2" |       "labelCssClasses": "w-12 text-lg rounded-xl p-1 px-2" | ||||||
|     } |     } | ||||||
|  |   ], | ||||||
|  |   "tagRenderings": [ | ||||||
|  |     "all_tags" | ||||||
|   ] |   ] | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -8,19 +8,42 @@ | ||||||
|     "en": "Find trolley bays for shopping trolleys.", |     "en": "Find trolley bays for shopping trolleys.", | ||||||
|     "de": "Finde Einkaufswagenbuchten für Einkaufswagen." |     "de": "Finde Einkaufswagenbuchten für Einkaufswagen." | ||||||
|   }, |   }, | ||||||
|   "title": { |  | ||||||
|     "en": "Trolley Bay", |  | ||||||
|     "de": "Einkaufswagenbucht" |  | ||||||
|   }, |  | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": "amenity=trolley_bay" |     "osmTags": "amenity=trolley_bay" | ||||||
|   }, |   }, | ||||||
|   "minzoom": 18, |   "minzoom": 18, | ||||||
|   "allowMove": { |   "title": { | ||||||
|     "enableImproveAccuracy": true, |     "en": "Trolley Bay", | ||||||
|     "enableRelocation": true |     "de": "Einkaufswagenbucht" | ||||||
|   }, |   }, | ||||||
|   "deletion": true, |   "pointRendering": [ | ||||||
|  |     { | ||||||
|  |       "location": [ | ||||||
|  |         "point", | ||||||
|  |         "centroid" | ||||||
|  |       ], | ||||||
|  |       "marker": [ | ||||||
|  |         { | ||||||
|  |           "icon": "./assets/layers/trolley_bay/trolley_bay.svg" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "presets": [ | ||||||
|  |     { | ||||||
|  |       "title": { | ||||||
|  |         "en": "a trolley bay", | ||||||
|  |         "de": "eine Einkaufswagenbucht" | ||||||
|  |       }, | ||||||
|  |       "tags": [ | ||||||
|  |         "amenity=trolley_bay" | ||||||
|  |       ], | ||||||
|  |       "description": { | ||||||
|  |         "en": "A trolley bay for parking shopping carts.", | ||||||
|  |         "de": "Ein Platz zum Abstellen von Einkaufswagen." | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|   "tagRenderings": [ |   "tagRenderings": [ | ||||||
|     { |     { | ||||||
|       "id": "covered", |       "id": "covered", | ||||||
|  | @ -194,32 +217,9 @@ | ||||||
|       "id": "indoor" |       "id": "indoor" | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "presets": [ |   "deletion": true, | ||||||
|     { |   "allowMove": { | ||||||
|       "title": { |     "enableImproveAccuracy": true, | ||||||
|         "en": "a trolley bay", |     "enableRelocation": true | ||||||
|         "de": "eine Einkaufswagenbucht" |   } | ||||||
|       }, |  | ||||||
|       "tags": [ |  | ||||||
|         "amenity=trolley_bay" |  | ||||||
|       ], |  | ||||||
|       "description": { |  | ||||||
|         "en": "A trolley bay for parking shopping carts.", |  | ||||||
|         "de": "Ein Platz zum Abstellen von Einkaufswagen." |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "pointRendering": [ |  | ||||||
|     { |  | ||||||
|       "location": [ |  | ||||||
|         "point", |  | ||||||
|         "centroid" |  | ||||||
|       ], |  | ||||||
|       "marker": [ |  | ||||||
|         { |  | ||||||
|           "icon": "./assets/layers/trolley_bay/trolley_bay.svg" |  | ||||||
|         } |  | ||||||
|       ] |  | ||||||
|     } |  | ||||||
|   ] |  | ||||||
| } | } | ||||||
|  | @ -31,7 +31,6 @@ | ||||||
|   ], |   ], | ||||||
|   "minzoom": 18, |   "minzoom": 18, | ||||||
|   "shownByDefault": false, |   "shownByDefault": false, | ||||||
|   "isCounted": false, |  | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|       "en": "Wall or building", |       "en": "Wall or building", | ||||||
|  | @ -122,6 +121,7 @@ | ||||||
|       "condition": "_biggest_width_id~*" |       "condition": "_biggest_width_id~*" | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|  |   "isCounted": false, | ||||||
|   "units": [ |   "units": [ | ||||||
|     { |     { | ||||||
|       "width": { |       "width": { | ||||||
|  |  | ||||||
|  | @ -50,8 +50,7 @@ | ||||||
|       "title": "OSM Building", |       "title": "OSM Building", | ||||||
|       "description": "Layer showing buildings that are in OpenStreetMap", |       "description": "Layer showing buildings that are in OpenStreetMap", | ||||||
|       "source": { |       "source": { | ||||||
|         "osmTags": "building~*", |         "osmTags": "building~*" | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|       "doCount": false, |       "doCount": false, | ||||||
|  | @ -161,8 +160,7 @@ | ||||||
|             "addr:postcode~*", |             "addr:postcode~*", | ||||||
|             "addr:street~*" |             "addr:street~*" | ||||||
|           ] |           ] | ||||||
|         }, |         } | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|       "doCount": false, |       "doCount": false, | ||||||
|  | @ -204,8 +202,7 @@ | ||||||
|       "source": { |       "source": { | ||||||
|         "geoJson": "https://service.pdok.nl/lv/bag/wfs/v2_0?request=GetFeature&service=WFS&version=2.0.0&outputFormat=application%2Fjson%3B%20subtype%3Dgeojson&typeName=bag%3Apand&bbox={x_min}%2C{y_min}%2C{x_max}%2C{y_max}%2CCRS84&srsName=EPSG%3A4326", |         "geoJson": "https://service.pdok.nl/lv/bag/wfs/v2_0?request=GetFeature&service=WFS&version=2.0.0&outputFormat=application%2Fjson%3B%20subtype%3Dgeojson&typeName=bag%3Apand&bbox={x_min}%2C{y_min}%2C{x_max}%2C{y_max}%2CCRS84&srsName=EPSG%3A4326", | ||||||
|         "geoJsonZoomLevel": 18, |         "geoJsonZoomLevel": 18, | ||||||
|         "osmTags": "identificatie~*", |         "osmTags": "identificatie~*" | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|       "calculatedTags": [ |       "calculatedTags": [ | ||||||
|  | @ -395,8 +392,7 @@ | ||||||
|       "source": { |       "source": { | ||||||
|         "geoJson": "https://service.pdok.nl/lv/bag/wfs/v2_0?request=GetFeature&service=WFS&version=2.0.0&outputFormat=application%2Fjson%3B%20subtype%3Dgeojson&typeName=bag%3Averblijfsobject&bbox={x_min}%2C{y_min}%2C{x_max}%2C{y_max}%2CCRS84&srsName=EPSG%3A4326", |         "geoJson": "https://service.pdok.nl/lv/bag/wfs/v2_0?request=GetFeature&service=WFS&version=2.0.0&outputFormat=application%2Fjson%3B%20subtype%3Dgeojson&typeName=bag%3Averblijfsobject&bbox={x_min}%2C{y_min}%2C{x_max}%2C{y_max}%2CCRS84&srsName=EPSG%3A4326", | ||||||
|         "geoJsonZoomLevel": 19, |         "geoJsonZoomLevel": 19, | ||||||
|         "osmTags": "identificatie~*", |         "osmTags": "identificatie~*" | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|       "calculatedTags": [ |       "calculatedTags": [ | ||||||
|  |  | ||||||
|  | @ -1,23 +1,23 @@ | ||||||
| { | { | ||||||
|   "description": { |  | ||||||
|     "en": "This map contains elements meant for disaster preparedness and response.", |  | ||||||
|     "it": "Questa mappa contiene elementi pensati per la preparazione e risposta ai disastri.", |  | ||||||
|     "de": "Diese Karte enthält Elemente, die der Katastrophenvorsorge und dem Katastrophenschutz dienen.", |  | ||||||
|     "es": "Este mapa contiene elementos destinados a la preparación y respuesta ante desastres." |  | ||||||
|   }, |  | ||||||
|   "docs": "https://wiki.openstreetmap.org/wiki/Emergency_facilities_and_amenities", |  | ||||||
|   "icon": "./assets/themes/disaster_response/CivilDefence.svg", |  | ||||||
|   "id": "disaster_response", |   "id": "disaster_response", | ||||||
|   "socialImage": "./assets/themes/disaster_response/social.svg", |  | ||||||
|   "title": { |   "title": { | ||||||
|     "en": "Disaster response", |     "en": "Disaster response", | ||||||
|     "it": "Risposta ai disastri", |     "it": "Risposta ai disastri", | ||||||
|     "de": "Katastrophenschutz", |     "de": "Katastrophenschutz", | ||||||
|     "es": "Respuesta ante desastres" |     "es": "Respuesta ante desastres" | ||||||
|   }, |   }, | ||||||
|  |   "description": { | ||||||
|  |     "en": "This map contains elements meant for disaster preparedness and response.", | ||||||
|  |     "it": "Questa mappa contiene elementi pensati per la preparazione e risposta ai disastri.", | ||||||
|  |     "de": "Diese Karte enthält Elemente, die der Katastrophenvorsorge und dem Katastrophenschutz dienen.", | ||||||
|  |     "es": "Este mapa contiene elementos destinados a la preparación y respuesta ante desastres." | ||||||
|  |   }, | ||||||
|  |   "icon": "./assets/themes/disaster_response/CivilDefence.svg", | ||||||
|  |   "socialImage": "./assets/themes/disaster_response/social.svg", | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     "hospital", |     "hospital", | ||||||
|     "assembly_point", |     "assembly_point", | ||||||
|     "disaster_response" |     "disaster_response" | ||||||
|   ] |   ], | ||||||
|  |   "docs": "https://wiki.openstreetmap.org/wiki/Emergency_facilities_and_amenities" | ||||||
| } | } | ||||||
|  | @ -42,8 +42,7 @@ | ||||||
|             }, |             }, | ||||||
|             "building~*" |             "building~*" | ||||||
|           ] |           ] | ||||||
|         }, |         } | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "title": "OSM-gebouw", |       "title": "OSM-gebouw", | ||||||
|       "tagRenderings": [ |       "tagRenderings": [ | ||||||
|  | @ -290,7 +289,6 @@ | ||||||
|         "geoJson": "https://betadata.grbosm.site/grb?bbox={x_min},{y_min},{x_max},{y_max}", |         "geoJson": "https://betadata.grbosm.site/grb?bbox={x_min},{y_min},{x_max},{y_max}", | ||||||
|         "geoJsonZoomLevel": 18, |         "geoJsonZoomLevel": 18, | ||||||
|         "mercatorCrs": true, |         "mercatorCrs": true, | ||||||
|         "maxCacheAge": 0, |  | ||||||
|         "idKey": "osm_id" |         "idKey": "osm_id" | ||||||
|       }, |       }, | ||||||
|       "name": "GRB geometries", |       "name": "GRB geometries", | ||||||
|  | @ -587,8 +585,7 @@ | ||||||
|               ] |               ] | ||||||
|             } |             } | ||||||
|           ] |           ] | ||||||
|         }, |         } | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "title": { |       "title": { | ||||||
|         "render": { |         "render": { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,5 @@ | ||||||
| { | { | ||||||
|   "id": "items_with_image", |   "id": "items_with_image", | ||||||
|   "hideFromOverview": true, |  | ||||||
|   "title": { |   "title": { | ||||||
|     "en": "All items with images" |     "en": "All items with images" | ||||||
|   }, |   }, | ||||||
|  | @ -8,6 +7,7 @@ | ||||||
|     "en": "A map showing all items on OSM which have an image. This theme is a very bad fit for MapComplete as someone is not able to directly add a picture. However, this theme is mostly here to include this all into the database, which'll allow this to quickly fetch images nearby for other features" |     "en": "A map showing all items on OSM which have an image. This theme is a very bad fit for MapComplete as someone is not able to directly add a picture. However, this theme is mostly here to include this all into the database, which'll allow this to quickly fetch images nearby for other features" | ||||||
|   }, |   }, | ||||||
|   "icon": "./assets/layers/item_with_image/camera.svg", |   "icon": "./assets/layers/item_with_image/camera.svg", | ||||||
|  |   "hideFromOverview": true, | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     "item_with_image" |     "item_with_image" | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|  | @ -14,8 +14,6 @@ | ||||||
|   "startLat": 0, |   "startLat": 0, | ||||||
|   "startLon": 0, |   "startLon": 0, | ||||||
|   "startZoom": 1, |   "startZoom": 1, | ||||||
|   "widenFactor": 0.05, |  | ||||||
|   "clustering": false, |  | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     { |     { | ||||||
|       "id": "mapcomplete-changes", |       "id": "mapcomplete-changes", | ||||||
|  | @ -26,8 +24,7 @@ | ||||||
|       "source": { |       "source": { | ||||||
|         "osmTags": "editor~*", |         "osmTags": "editor~*", | ||||||
|         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/mapcomplete-changes/tile_{z}_{x}_{y}.geojson", |         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/mapcomplete-changes/tile_{z}_{x}_{y}.geojson", | ||||||
|         "geoJsonZoomLevel": 8, |         "geoJsonZoomLevel": 8 | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "title": { |       "title": { | ||||||
|         "render": { |         "render": { | ||||||
|  |  | ||||||
|  | @ -14,8 +14,6 @@ | ||||||
|   "startLat": 0, |   "startLat": 0, | ||||||
|   "startLon": 0, |   "startLon": 0, | ||||||
|   "startZoom": 1, |   "startZoom": 1, | ||||||
|   "widenFactor": 0.05, |  | ||||||
|   "clustering": false, |  | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     { |     { | ||||||
|       "id": "mapcomplete-changes", |       "id": "mapcomplete-changes", | ||||||
|  | @ -26,8 +24,7 @@ | ||||||
|       "source": { |       "source": { | ||||||
|         "osmTags": "editor~*", |         "osmTags": "editor~*", | ||||||
|         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/mapcomplete-changes/tile_{z}_{x}_{y}.geojson", |         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/mapcomplete-changes/tile_{z}_{x}_{y}.geojson", | ||||||
|         "geoJsonZoomLevel": 8, |         "geoJsonZoomLevel": 8 | ||||||
|         "maxCacheAge": 0 |  | ||||||
|       }, |       }, | ||||||
|       "title": { |       "title": { | ||||||
|         "render": { |         "render": { | ||||||
|  |  | ||||||
|  | @ -32,6 +32,5 @@ | ||||||
|     "note", |     "note", | ||||||
|     "fixme" |     "fixme" | ||||||
|   ], |   ], | ||||||
|   "enableDownload": true, |   "enableDownload": true | ||||||
|   "clustering": false |  | ||||||
| } | } | ||||||
|  | @ -41,8 +41,5 @@ | ||||||
|   ], |   ], | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     "windturbine" |     "windturbine" | ||||||
|   ], |   ] | ||||||
|   "clustering": { |  | ||||||
|     "maxZoom": 8 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  | @ -36,6 +36,5 @@ | ||||||
|   "startLon": 4.351697, |   "startLon": 4.351697, | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     "osm_community_index" |     "osm_community_index" | ||||||
|   ], |   ] | ||||||
|   "clustering": false |  | ||||||
| } | } | ||||||
|  | @ -44,8 +44,5 @@ | ||||||
|   "enableNoteImports": false, |   "enableNoteImports": false, | ||||||
|   "widenFactor": 1.2, |   "widenFactor": 1.2, | ||||||
|   "overpassMaxZoom": 15, |   "overpassMaxZoom": 15, | ||||||
|   "clustering": { |  | ||||||
|     "maxZoom": 19 |  | ||||||
|   }, |  | ||||||
|   "#note": "The 'overpassMaxZoom' should be exactly the same as or less then the minzzom in overrideAll" |   "#note": "The 'overpassMaxZoom' should be exactly the same as or less then the minzzom in overrideAll" | ||||||
| } | } | ||||||
|  | @ -231,6 +231,5 @@ | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "overpassTimeout": 180, |   "overpassTimeout": 180, | ||||||
|   "widenFactor": 0.05, |   "widenFactor": 0.05 | ||||||
|   "clustering": false |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -103,9 +103,5 @@ | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "widenFactor": 1.5, |   "widenFactor": 1.5 | ||||||
|   "clustering": { |  | ||||||
|     "maxZoom": 14, |  | ||||||
|     "minNeededElements": 100 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  | @ -11,7 +11,6 @@ | ||||||
|     "es": "Todo lo que necesitas para esquiar" |     "es": "Todo lo que necesitas para esquiar" | ||||||
|   }, |   }, | ||||||
|   "icon": "./assets/layers/aerialway/chair_lift.svg", |   "icon": "./assets/layers/aerialway/chair_lift.svg", | ||||||
|   "enableTerrain": true, |  | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     "ski_piste", |     "ski_piste", | ||||||
|     "aerialway", |     "aerialway", | ||||||
|  | @ -50,5 +49,6 @@ | ||||||
|         ] |         ] | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ] |   ], | ||||||
|  |   "enableTerrain": true | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -23,8 +23,7 @@ | ||||||
|       "title": null, |       "title": null, | ||||||
|       "source": { |       "source": { | ||||||
|         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete/master/assets/themes/speelplekken/shadow.geojson", |         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete/master/assets/themes/speelplekken/shadow.geojson", | ||||||
|         "osmTags": "shadow=yes", |         "osmTags": "shadow=yes" | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "pointRendering": null, |       "pointRendering": null, | ||||||
|       "lineRendering": [ |       "lineRendering": [ | ||||||
|  | @ -37,11 +36,6 @@ | ||||||
|     { |     { | ||||||
|       "builtin": "play_forest", |       "builtin": "play_forest", | ||||||
|       "override": { |       "override": { | ||||||
|         "source": { |  | ||||||
|           "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/speelplekken_cache/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJsonZoomLevel": 14, |  | ||||||
|           "isOsmCache": true |  | ||||||
|         }, |  | ||||||
|         "minzoom": 12, |         "minzoom": 12, | ||||||
|         "calculatedTags": [ |         "calculatedTags": [ | ||||||
|           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", |           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", | ||||||
|  | @ -53,12 +47,6 @@ | ||||||
|       "builtin": "playground", |       "builtin": "playground", | ||||||
|       "override": { |       "override": { | ||||||
|         "minzoom": 14, |         "minzoom": 14, | ||||||
|         "source": { |  | ||||||
|           "geoJsonLocal": "http://127.0.0.1:8080/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/speelplekken_cache/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJsonZoomLevel": 14, |  | ||||||
|           "isOsmCache": true |  | ||||||
|         }, |  | ||||||
|         "calculatedTags": [ |         "calculatedTags": [ | ||||||
|           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", |           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", | ||||||
|           "_video:id=feat.properties.video === undefined ? undefined : new URL(feat.properties.video).searchParams.get('v')" |           "_video:id=feat.properties.video === undefined ? undefined : new URL(feat.properties.video).searchParams.get('v')" | ||||||
|  | @ -69,12 +57,6 @@ | ||||||
|       "builtin": "village_green", |       "builtin": "village_green", | ||||||
|       "override": { |       "override": { | ||||||
|         "minzoom": 14, |         "minzoom": 14, | ||||||
|         "source": { |  | ||||||
|           "geoJsonLocal": "http://127.0.0.1:8080/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/speelplekken_cache/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJsonZoomLevel": 14, |  | ||||||
|           "isOsmCache": true |  | ||||||
|         }, |  | ||||||
|         "calculatedTags": [ |         "calculatedTags": [ | ||||||
|           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", |           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", | ||||||
|           "_video:id=feat.properties.video === undefined ? undefined : new URL(feat.properties.video).searchParams.get('v')" |           "_video:id=feat.properties.video === undefined ? undefined : new URL(feat.properties.video).searchParams.get('v')" | ||||||
|  | @ -85,12 +67,6 @@ | ||||||
|       "builtin": "sport_pitch", |       "builtin": "sport_pitch", | ||||||
|       "override": { |       "override": { | ||||||
|         "minzoom": 15, |         "minzoom": 15, | ||||||
|         "source": { |  | ||||||
|           "geoJsonLocal": "http://127.0.0.1:8080/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/speelplekken_cache/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJsonZoomLevel": 14, |  | ||||||
|           "isOsmCache": true |  | ||||||
|         }, |  | ||||||
|         "calculatedTags": [ |         "calculatedTags": [ | ||||||
|           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", |           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''", | ||||||
|           "_video:id=feat.properties.video === undefined ? undefined : new URL(feat.properties.video).searchParams.get('v')" |           "_video:id=feat.properties.video === undefined ? undefined : new URL(feat.properties.video).searchParams.get('v')" | ||||||
|  | @ -102,13 +78,7 @@ | ||||||
|       "override": { |       "override": { | ||||||
|         "calculatedTags": [ |         "calculatedTags": [ | ||||||
|           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''" |           "_is_shadowed=overlapWith(feat)('shadow').length > 0 ? 'yes': ''" | ||||||
|         ], |         ] | ||||||
|         "source": { |  | ||||||
|           "geoJsonLocal": "http://127.0.0.1:8080/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/speelplekken_cache/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|           "geoJsonZoomLevel": 14, |  | ||||||
|           "isOsmCache": true |  | ||||||
|         } |  | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -124,10 +94,7 @@ | ||||||
|             "route=foot", |             "route=foot", | ||||||
|             "operator~[pP]rovincie Antwerpen" |             "operator~[pP]rovincie Antwerpen" | ||||||
|           ] |           ] | ||||||
|         }, |         } | ||||||
|         "geoJson": "https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/speelplekken_cache/speelplekken_{layer}_{z}_{x}_{y}.geojson", |  | ||||||
|         "geoJsonZoomLevel": 14, |  | ||||||
|         "isOsmCache": true |  | ||||||
|       }, |       }, | ||||||
|       "title": { |       "title": { | ||||||
|         "render": "Wandeling <i>{name}</i>", |         "render": "Wandeling <i>{name}</i>", | ||||||
|  | @ -260,9 +227,5 @@ | ||||||
|       51.23978120350654 |       51.23978120350654 | ||||||
|     ] |     ] | ||||||
|   ], |   ], | ||||||
|   "widenFactor": 1.2, |   "widenFactor": 1.2 | ||||||
|   "clustering": { |  | ||||||
|     "maxZoom": 6, |  | ||||||
|     "minNeededElements": 100 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -23,8 +23,7 @@ | ||||||
|         "osmTags": "Lichtmastnummer~*", |         "osmTags": "Lichtmastnummer~*", | ||||||
|         "#geoJson": "https://opendata.arcgis.com/datasets/ba37cdb372064b3199c548b75d16a609_0.geojson", |         "#geoJson": "https://opendata.arcgis.com/datasets/ba37cdb372064b3199c548b75d16a609_0.geojson", | ||||||
|         "geoJson": "https://robinlinde.github.io/tiles/assen_street_lighting/{z}/{x}/{y}.json", |         "geoJson": "https://robinlinde.github.io/tiles/assen_street_lighting/{z}/{x}/{y}.json", | ||||||
|         "geoJsonZoomLevel": 16, |         "geoJsonZoomLevel": 16 | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "calculatedTags": [ |       "calculatedTags": [ | ||||||
|         "_closest_osm_street_lamp=closest(feat)('street_lamps')?.properties?.id", |         "_closest_osm_street_lamp=closest(feat)('street_lamps')?.properties?.id", | ||||||
|  |  | ||||||
|  | @ -71,9 +71,5 @@ | ||||||
|     "tree_node" |     "tree_node" | ||||||
|   ], |   ], | ||||||
|   "widenFactor": 0.2, |   "widenFactor": 0.2, | ||||||
|   "osmApiTileSize": 18, |   "osmApiTileSize": 18 | ||||||
|   "clustering": { |  | ||||||
|     "maxZoom": 19, |  | ||||||
|     "minNeededElements": 25 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -32,8 +32,7 @@ | ||||||
|       "source": { |       "source": { | ||||||
|         "geoJson": "https://osm-uk-addresses.russss.dev/inspire/{z}/{x}/{y}.json", |         "geoJson": "https://osm-uk-addresses.russss.dev/inspire/{z}/{x}/{y}.json", | ||||||
|         "osmTags": "inspireid~*", |         "osmTags": "inspireid~*", | ||||||
|         "geoJsonZoomLevel": 18, |         "geoJsonZoomLevel": 18 | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|       "calculatedTags": [ |       "calculatedTags": [ | ||||||
|  | @ -69,8 +68,7 @@ | ||||||
|             "id!~node/.*" |             "id!~node/.*" | ||||||
|           ] |           ] | ||||||
|         }, |         }, | ||||||
|         "geoJsonZoomLevel": 16, |         "geoJsonZoomLevel": 16 | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "name": "Addresses to check", |       "name": "Addresses to check", | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|  | @ -703,9 +701,5 @@ | ||||||
|   ], |   ], | ||||||
|   "enableShareScreen": false, |   "enableShareScreen": false, | ||||||
|   "enableMoreQuests": false, |   "enableMoreQuests": false, | ||||||
|   "widenFactor": 1.01, |   "widenFactor": 1.01 | ||||||
|   "clustering": { |  | ||||||
|     "minNeededFeatures": 25, |  | ||||||
|     "maxZoom": 16 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -3,45 +3,33 @@ | ||||||
|   "title": { |   "title": { | ||||||
|     "nl": "Velopark naar OpenStreetMap sync tool" |     "nl": "Velopark naar OpenStreetMap sync tool" | ||||||
|   }, |   }, | ||||||
|   "shortDescription": { |   "mustHaveLanguage": [ | ||||||
|     "en": "A tool to import data from velopark.be into OpenStreetMap", |     "nl" | ||||||
|     "nl": "Een hulpmiddel om data van velopark.be in OpenStreetMap in te laden" |   ], | ||||||
|   }, |  | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "<p><a href='https://velopark.be' target='_blank'>Velopark.be</a> is a website collecting data about bicycle parkings in a semi-crowdsourced way. However, only 'authorized' instances are allowed to make changes there, in practice the operator of the bicycle parking such as SNCB, de Lijn or the municipality. They have now decided to synchronize their dataset with OpenStreetMap, and this MapComplete-instance is set up to help link and import their data into OpenStreetMap.</p> How to use: <ul><li>A velopark-icon on the map (yellow with bicycle silhouette) represents a bicycle known by Velopark but not yet known by OpenStreetMap</li><li>Blue pins are bicycle parkings known by OpenStreetMap</li><li>Light blue pins are bicycle parkings known by OpenStreetMap with a reference to Velopark.be (<span class='literal-code'>ref-velopark=*</span>)</li><li>Click a velopark item, you can either link it with a nearby OSM-bicycle parking or create a new bicycle parking. Note that the geometry of Velopark is often incorrect and can be a few up till 100 meters away from the actual bicycle parking. Use aerial imagery, linked images and streetview to determine the correct location</li><li>Once linked, you can compare the Velopark- and OSM-attributes and apply correct attributes</li><li>If Velopark has an image, you can also link the image</li></ul> That's it! Thanks for helping to import this!", |     "en": "<p><a href='https://velopark.be' target='_blank'>Velopark.be</a> is a website collecting data about bicycle parkings in a semi-crowdsourced way. However, only 'authorized' instances are allowed to make changes there, in practice the operator of the bicycle parking such as SNCB, de Lijn or the municipality. They have now decided to synchronize their dataset with OpenStreetMap, and this MapComplete-instance is set up to help link and import their data into OpenStreetMap.</p> How to use: <ul><li>A velopark-icon on the map (yellow with bicycle silhouette) represents a bicycle known by Velopark but not yet known by OpenStreetMap</li><li>Blue pins are bicycle parkings known by OpenStreetMap</li><li>Light blue pins are bicycle parkings known by OpenStreetMap with a reference to Velopark.be (<span class='literal-code'>ref-velopark=*</span>)</li><li>Click a velopark item, you can either link it with a nearby OSM-bicycle parking or create a new bicycle parking. Note that the geometry of Velopark is often incorrect and can be a few up till 100 meters away from the actual bicycle parking. Use aerial imagery, linked images and streetview to determine the correct location</li><li>Once linked, you can compare the Velopark- and OSM-attributes and apply correct attributes</li><li>If Velopark has an image, you can also link the image</li></ul> That's it! Thanks for helping to import this!", | ||||||
|     "nl": "<p><a href='https://velopark.be' target='_blank'>Velopark.be</a> is een website die data verzamelt over fietsenstallingen in een semi-crowdsource manier. Hierbij kunnen enkel geautorizeerde gebruikers data bijdragen, in de praktijk de uitbaters van de fietsenstallingen zoals de bevoegde gemeentebesturen, de NMBS of de Lijn. Velopark.be heeft nu beslist om hun data met OpenStreetMap te synchronizeren. Deze website is de tool om van Velopark.be naar OpenStreetMap te gaan en hun data te importeren.</p> Hoe te gebruiken? <ul><li>Een velopark-logo op de kaart (geel met een fietssilhouette) duidt een fietsenstalling aan die gekend is in Velopark maar nog niet gekend (of gelinkt) is aan een fietsenstalling in OpenStreetMap</li><li>Een blauwe pin duidt een fietsenstalling aan die gekend is in OpenStreetMap</li><li>Een licht-blauwe pin duidt een fietsenstalling aan uit OpenStreetMap die een link heeft naar Velopark.be (<span class='literal-code'>ref-velopark=*</span>)</li><li>Als je op een velopark-item klikt op, kan je deze linken met een fietsenstalling in de buurt (<25m) of een nieuwe fietstalling aan OpenStreetMap toevoegen. Let op: de geometrie van Velopark is zelden correct en wijkt makkelijk 10 meter of meer af van de echte locatie - in uitzonderlijke gevallen zelfs tot meer dan 100 meter. Gebruik de meest recente luchtfoto's, de gelinkte foto's en mapillary om de correcte locatie te bepalen</li><li>Eens gelinkt, kan je de Velopark- en OSM-attributen vergelijken en de correcte attributen toepassen in OpenStreetMap</li><li>Indien velopark een foto heeft, kan je die ook nog linken</li></ul> Dat is het! Bedankt om mee te helpen!" |     "nl": "<p><a href='https://velopark.be' target='_blank'>Velopark.be</a> is een website die data verzamelt over fietsenstallingen in een semi-crowdsource manier. Hierbij kunnen enkel geautorizeerde gebruikers data bijdragen, in de praktijk de uitbaters van de fietsenstallingen zoals de bevoegde gemeentebesturen, de NMBS of de Lijn. Velopark.be heeft nu beslist om hun data met OpenStreetMap te synchronizeren. Deze website is de tool om van Velopark.be naar OpenStreetMap te gaan en hun data te importeren.</p> Hoe te gebruiken? <ul><li>Een velopark-logo op de kaart (geel met een fietssilhouette) duidt een fietsenstalling aan die gekend is in Velopark maar nog niet gekend (of gelinkt) is aan een fietsenstalling in OpenStreetMap</li><li>Een blauwe pin duidt een fietsenstalling aan die gekend is in OpenStreetMap</li><li>Een licht-blauwe pin duidt een fietsenstalling aan uit OpenStreetMap die een link heeft naar Velopark.be (<span class='literal-code'>ref-velopark=*</span>)</li><li>Als je op een velopark-item klikt op, kan je deze linken met een fietsenstalling in de buurt (<25m) of een nieuwe fietstalling aan OpenStreetMap toevoegen. Let op: de geometrie van Velopark is zelden correct en wijkt makkelijk 10 meter of meer af van de echte locatie - in uitzonderlijke gevallen zelfs tot meer dan 100 meter. Gebruik de meest recente luchtfoto's, de gelinkte foto's en mapillary om de correcte locatie te bepalen</li><li>Eens gelinkt, kan je de Velopark- en OSM-attributen vergelijken en de correcte attributen toepassen in OpenStreetMap</li><li>Indien velopark een foto heeft, kan je die ook nog linken</li></ul> Dat is het! Bedankt om mee te helpen!" | ||||||
|   }, |   }, | ||||||
|  |   "shortDescription": { | ||||||
|  |     "en": "A tool to import data from velopark.be into OpenStreetMap", | ||||||
|  |     "nl": "Een hulpmiddel om data van velopark.be in OpenStreetMap in te laden" | ||||||
|  |   }, | ||||||
|   "descriptionTail": { |   "descriptionTail": { | ||||||
|     "*": "<h3>Maintainer tools</h3><ul><li><a class='link-underline' href='https://maproulette.org/api/v2/challenge/view/43282' download='Velopark_sync_2024-01-15.geojson'>Download the first sync results</a></li></ul>" |     "*": "<h3>Maintainer tools</h3><ul><li><a class='link-underline' href='https://maproulette.org/api/v2/challenge/view/43282' download='Velopark_sync_2024-01-15.geojson'>Download the first sync results</a></li></ul>" | ||||||
|   }, |   }, | ||||||
|   "hideFromOverview": true, |  | ||||||
|   "icon": "./assets/themes/velopark/velopark.svg", |   "icon": "./assets/themes/velopark/velopark.svg", | ||||||
|   "mustHaveLanguage": [ |   "startZoom": 18, | ||||||
|     "nl" |  | ||||||
|   ], |  | ||||||
|   "lockLocation": [ |  | ||||||
|     [ |  | ||||||
|       2.51357303225, |  | ||||||
|       49.5294835476 |  | ||||||
|     ], |  | ||||||
|     [ |  | ||||||
|       6.15665815596, |  | ||||||
|       51.4750237087 |  | ||||||
|     ] |  | ||||||
|   ], |  | ||||||
|   "startLat": 51.03753, |   "startLat": 51.03753, | ||||||
|   "startLon": 3.71025, |   "startLon": 3.71025, | ||||||
|   "startZoom": 18, |  | ||||||
|   "defaultBackgroundId": "photo", |   "defaultBackgroundId": "photo", | ||||||
|   "enableNoteImports": false, |   "hideFromOverview": true, | ||||||
|   "layers": [ |   "layers": [ | ||||||
|     { |     { | ||||||
|       "id": "velopark_maproulette", |       "id": "velopark_maproulette", | ||||||
|       "description": "Maproulette challenge containing velopark data", |       "description": "Maproulette challenge containing velopark data", | ||||||
|       "source": { |       "source": { | ||||||
|         "osmTags": "mr_taskId~*", |         "osmTags": "mr_taskId~*", | ||||||
|         "geoJson": "https://maproulette.org/api/v2/challenge/view/43282", |         "geoJson": "https://maproulette.org/api/v2/challenge/view/43282" | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "title": { |       "title": { | ||||||
|         "render": "Velopark parking <b>{mr_velopark_id}</b>" |         "render": "Velopark parking <b>{mr_velopark_id}</b>" | ||||||
|  | @ -348,5 +336,16 @@ | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|   } |   }, | ||||||
|  |   "lockLocation": [ | ||||||
|  |     [ | ||||||
|  |       2.51357303225, | ||||||
|  |       49.5294835476 | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       6.15665815596, | ||||||
|  |       51.4750237087 | ||||||
|  |     ] | ||||||
|  |   ], | ||||||
|  |   "enableNoteImports": false | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -27,8 +27,7 @@ | ||||||
|       "description": "Laag op basis van externe data", |       "description": "Laag op basis van externe data", | ||||||
|       "source": { |       "source": { | ||||||
|         "osmTags": "OBJECTID~*", |         "osmTags": "OBJECTID~*", | ||||||
|         "geoJson": "https://opendata.arcgis.com/datasets/5b6953ac5a9d4616a7dc75ab0beeac2f_0.geojson", |         "geoJson": "https://opendata.arcgis.com/datasets/5b6953ac5a9d4616a7dc75ab0beeac2f_0.geojson" | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "calculatedTags": [ |       "calculatedTags": [ | ||||||
|         "_closest_osm_waste_basket=closest(feat)('waste_basket')?.properties?.id", |         "_closest_osm_waste_basket=closest(feat)('waste_basket')?.properties?.id", | ||||||
|  | @ -71,8 +70,7 @@ | ||||||
|       "description": "Laag op basis van externe data", |       "description": "Laag op basis van externe data", | ||||||
|       "source": { |       "source": { | ||||||
|         "osmTags": "OBJECTID~*", |         "osmTags": "OBJECTID~*", | ||||||
|         "geoJson": "https://opendata.arcgis.com/datasets/edb893998e27461b8ed82aad9854d27d_0.geojson", |         "geoJson": "https://opendata.arcgis.com/datasets/edb893998e27461b8ed82aad9854d27d_0.geojson" | ||||||
|         "isOsmCache": false |  | ||||||
|       }, |       }, | ||||||
|       "calculatedTags": [ |       "calculatedTags": [ | ||||||
|         "_closest_osm_recycling=closest(feat)('recycling')?.properties?.id", |         "_closest_osm_recycling=closest(feat)('recycling')?.properties?.id", | ||||||
|  |  | ||||||
|  | @ -275,6 +275,5 @@ | ||||||
|   "enableLayers": false, |   "enableLayers": false, | ||||||
|   "enableSearch": false, |   "enableSearch": false, | ||||||
|   "enableBackgroundLayerSelection": false, |   "enableBackgroundLayerSelection": false, | ||||||
|   "widenFactor": 0.05, |   "widenFactor": 0.05 | ||||||
|   "clustering": false |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -26,6 +26,8 @@ export default class LayoutSource extends FeatureSourceMerger { | ||||||
| 
 | 
 | ||||||
|     private readonly supportsForceDownload: UpdatableFeatureSource[] |     private readonly supportsForceDownload: UpdatableFeatureSource[] | ||||||
| 
 | 
 | ||||||
|  |     private readonly fromCache: Map<string, LocalStorageFeatureSource> | ||||||
|  |     private static readonly fromCacheZoomLevel = 15 | ||||||
|     constructor( |     constructor( | ||||||
|         layers: LayerConfig[], |         layers: LayerConfig[], | ||||||
|         featureSwitches: FeatureSwitchState, |         featureSwitches: FeatureSwitchState, | ||||||
|  | @ -43,13 +45,21 @@ export default class LayoutSource extends FeatureSourceMerger { | ||||||
| 
 | 
 | ||||||
|         const geojsonlayers = layers.filter((layer) => layer.source.geojsonSource !== undefined) |         const geojsonlayers = layers.filter((layer) => layer.source.geojsonSource !== undefined) | ||||||
|         const osmLayers = layers.filter((layer) => layer.source.geojsonSource === undefined) |         const osmLayers = layers.filter((layer) => layer.source.geojsonSource === undefined) | ||||||
|         const fromCache = osmLayers.map( |         const fromCache = new Map<string, LocalStorageFeatureSource>() | ||||||
|             (l) => |         for (const layer of osmLayers) { | ||||||
|                 new LocalStorageFeatureSource(backend, l, 15, mapProperties, { |             const src = new LocalStorageFeatureSource( | ||||||
|                     isActive: isDisplayed(l.id), |                 backend, | ||||||
|                     maxAge: l.maxAgeOfCache, |                 layer, | ||||||
|                 }) |                 LayoutSource.fromCacheZoomLevel, | ||||||
|         ) |                 mapProperties, | ||||||
|  |                 { | ||||||
|  |                     isActive: isDisplayed(layer.id), | ||||||
|  |                     maxAge: layer.maxAgeOfCache, | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |             fromCache.set(layer.id, src) | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         const mvtSources: UpdatableFeatureSource[] = osmLayers |         const mvtSources: UpdatableFeatureSource[] = osmLayers | ||||||
|             .filter((f) => mvtAvailableLayers.has(f.id)) |             .filter((f) => mvtAvailableLayers.has(f.id)) | ||||||
|             .map((l) => LayoutSource.setupMvtSource(l, mapProperties, isDisplayed(l.id))) |             .map((l) => LayoutSource.setupMvtSource(l, mapProperties, isDisplayed(l.id))) | ||||||
|  | @ -92,9 +102,10 @@ export default class LayoutSource extends FeatureSourceMerger { | ||||||
|             LayoutSource.setupGeojsonSource(l, mapProperties, isDisplayed(l.id)) |             LayoutSource.setupGeojsonSource(l, mapProperties, isDisplayed(l.id)) | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         super(...geojsonSources, ...fromCache, ...mvtSources, ...nonMvtSources) |         super(...geojsonSources, ...Array.from(fromCache.values()), ...mvtSources, ...nonMvtSources) | ||||||
| 
 | 
 | ||||||
|         this.isLoading = isLoading |         this.isLoading = isLoading | ||||||
|  |         this.fromCache = fromCache | ||||||
|         supportsForceDownload.push(...geojsonSources) |         supportsForceDownload.push(...geojsonSources) | ||||||
|         supportsForceDownload.push(...mvtSources) // Non-mvt sources are handled by overpass
 |         supportsForceDownload.push(...mvtSources) // Non-mvt sources are handled by overpass
 | ||||||
|         this.supportsForceDownload = supportsForceDownload |         this.supportsForceDownload = supportsForceDownload | ||||||
|  |  | ||||||
|  | @ -92,7 +92,6 @@ export default class CreateNoteImportLayer extends Conversion<LayerConfigJson, L | ||||||
|                     this._includeClosedNotesDays + |                     this._includeClosedNotesDays + | ||||||
|                     "&bbox={x_min},{y_min},{x_max},{y_max}", |                     "&bbox={x_min},{y_min},{x_max},{y_max}", | ||||||
|                 geoJsonZoomLevel: 10, |                 geoJsonZoomLevel: 10, | ||||||
|                 maxCacheAge: 0, |  | ||||||
|             }, |             }, | ||||||
|             /* We need to set 'pass_all_features' |             /* We need to set 'pass_all_features' | ||||||
|        There are probably many note_import-layers, and we don't want the first one to gobble up all notes and then discard them... |        There are probably many note_import-layers, and we don't want the first one to gobble up all notes and then discard them... | ||||||
|  |  | ||||||
|  | @ -135,6 +135,10 @@ export class UpdateLegacyLayer extends DesugaringStep< | ||||||
|         delete config["rotation"] |         delete config["rotation"] | ||||||
|         delete config["wayHandling"] |         delete config["wayHandling"] | ||||||
|         delete config["hideUnderlayingFeaturesMinPercentage"] |         delete config["hideUnderlayingFeaturesMinPercentage"] | ||||||
|  |         const src = config.source | ||||||
|  |         delete src["isOsmCache"] | ||||||
|  |         delete src["maxCacheAge"] | ||||||
|  |         delete src["widenFactor"] | ||||||
| 
 | 
 | ||||||
|         for (const mapRenderingElement of config["mapRendering"] ?? []) { |         for (const mapRenderingElement of config["mapRendering"] ?? []) { | ||||||
|             if (mapRenderingElement["iconOverlays"] !== undefined) { |             if (mapRenderingElement["iconOverlays"] !== undefined) { | ||||||
|  |  | ||||||
|  | @ -1615,6 +1615,18 @@ export class ValidateLayer extends Conversion< | ||||||
|             context.enters("doCount").err("Use `isCounted` instead of `doCount`") |             context.enters("doCount").err("Use `isCounted` instead of `doCount`") | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         if (json.source) { | ||||||
|  |             const src = json.source | ||||||
|  |             if (src["isOsmCache"] !== undefined) { | ||||||
|  |                 context.enters("source").err("isOsmCache is deprecated") | ||||||
|  |             } | ||||||
|  |             if (src["maxCacheAge"] !== undefined) { | ||||||
|  |                 context | ||||||
|  |                     .enters("source") | ||||||
|  |                     .err("maxCacheAge is deprecated; it is " + src["maxCacheAge"]) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         return { raw: json, parsed: layerConfig } |         return { raw: json, parsed: layerConfig } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -74,15 +74,6 @@ export interface LayerConfigJson { | ||||||
|                * Every source must set which tags have to be present in order to load the given layer. |                * Every source must set which tags have to be present in order to load the given layer. | ||||||
|                */ |                */ | ||||||
|               osmTags: TagConfigJson |               osmTags: TagConfigJson | ||||||
|               /** |  | ||||||
|                * question: How long (in seconds) is the data allowed to remain cached until it must be refreshed? |  | ||||||
|                * The maximum amount of seconds that a tile is allowed to linger in the cache |  | ||||||
|                * |  | ||||||
|                * type: nat |  | ||||||
|                * default: 30 days |  | ||||||
|                * group: expert |  | ||||||
|                */ |  | ||||||
|               maxCacheAge?: number |  | ||||||
|           } |           } | ||||||
|         | { |         | { | ||||||
|               /** |               /** | ||||||
|  | @ -109,17 +100,6 @@ export interface LayerConfigJson { | ||||||
|                * ifunset: This is not a tiled geojson |                * ifunset: This is not a tiled geojson | ||||||
|                */ |                */ | ||||||
|               geoJsonZoomLevel?: number |               geoJsonZoomLevel?: number | ||||||
|               /** |  | ||||||
|                * Indicates that the upstream geojson data is OSM-derived. |  | ||||||
|                * Useful for e.g. merging or for scripts generating this cache. |  | ||||||
|                * This also indicates that making changes on this data is possible |  | ||||||
|                * |  | ||||||
|                * question: Is this geojson a cache of OpenStreetMap data? |  | ||||||
|                * ifunset: This is not an OpenStreetMap cache |  | ||||||
|                * iftrue: this is based on OpenStreetMap and can thus be edited |  | ||||||
|                * group: expert |  | ||||||
|                */ |  | ||||||
|               isOsmCache?: boolean |  | ||||||
|               /** |               /** | ||||||
|                * Some API's use a mercator-projection (EPSG:900913) instead of WGS84. Set the flag `mercatorCrs: true`  in the source for this |                * Some API's use a mercator-projection (EPSG:900913) instead of WGS84. Set the flag `mercatorCrs: true`  in the source for this | ||||||
|                * |                * | ||||||
|  |  | ||||||
|  | @ -417,14 +417,6 @@ export interface LayoutConfigJson { | ||||||
|      */ |      */ | ||||||
|     overpassTimeout?: number |     overpassTimeout?: number | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * When a query is run, the data within bounds of the visible map is loaded. |  | ||||||
|      * However, users tend to pan and zoom a lot. It is pretty annoying if every single pan means a reloading of the data. |  | ||||||
|      * For this, the bounds are widened in order to make a small pan still within bounds of the loaded data. |  | ||||||
|      * |  | ||||||
|      * IF widenfactor is 1, this feature is disabled. A recommended value is between 1 and 3 |  | ||||||
|      */ |  | ||||||
|     widenFactor?: number |  | ||||||
|     /** |     /** | ||||||
|      * At low zoom levels, overpass is used to query features. |      * At low zoom levels, overpass is used to query features. | ||||||
|      * At high zoom level, the OSM api is used to fetch one or more BBOX aligning with a slippy tile. |      * At high zoom level, the OSM api is used to fetch one or more BBOX aligning with a slippy tile. | ||||||
|  |  | ||||||
|  | @ -62,7 +62,6 @@ describe("ReplaceGeometryAction", () => { | ||||||
|                 name: "All OSM-buildings", |                 name: "All OSM-buildings", | ||||||
|                 source: { |                 source: { | ||||||
|                     osmTags: "building~*", |                     osmTags: "building~*", | ||||||
|                     maxCacheAge: 0, |  | ||||||
|                 }, |                 }, | ||||||
|                 calculatedTags: ["_surface:strict:=feat.get('_surface')"], |                 calculatedTags: ["_surface:strict:=feat.get('_surface')"], | ||||||
|                 lineRendering: [ |                 lineRendering: [ | ||||||
|  | @ -269,7 +268,6 @@ describe("ReplaceGeometryAction", () => { | ||||||
|                         "https://betadata.grbosm.site/grb?bbox={x_min},{y_min},{x_max},{y_max}", |                         "https://betadata.grbosm.site/grb?bbox={x_min},{y_min},{x_max},{y_max}", | ||||||
|                     geoJsonZoomLevel: 18, |                     geoJsonZoomLevel: 18, | ||||||
|                     mercatorCrs: true, |                     mercatorCrs: true, | ||||||
|                     maxCacheAge: 0, |  | ||||||
|                 }, |                 }, | ||||||
|                 name: "GRB geometries", |                 name: "GRB geometries", | ||||||
|                 title: "GRB outline", |                 title: "GRB outline", | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue