forked from MapComplete/MapComplete
Regenerate docs
This commit is contained in:
parent
92df5643c3
commit
1fe1ea5a78
71 changed files with 4817 additions and 3769 deletions
178
Docs/BuiltinIndex.md
Normal file
178
Docs/BuiltinIndex.md
Normal file
|
@ -0,0 +1,178 @@
|
||||||
|
Index of builtin TagRendering
|
||||||
|
===============================
|
||||||
|
|
||||||
|
## Table of contents
|
||||||
|
|
||||||
|
1. [Index of builtin TagRendering](#index-of-builtin-tagrendering)
|
||||||
|
|
||||||
|
- [Existing builtin tagrenderings](#existing-builtin-tagrenderings)
|
||||||
|
+ [images](#images)
|
||||||
|
+ [website](#website)
|
||||||
|
+ [phone](#phone)
|
||||||
|
+ [email](#email)
|
||||||
|
+ [opening_hours](#opening_hours)
|
||||||
|
+ [description](#description)
|
||||||
|
+ [level](#level)
|
||||||
|
+ [bike_cleaning.bike_cleaning-service:bicycle:cleaning:charge](#bike_cleaningbike_cleaning-service:bicycle:cleaning:charge)
|
||||||
|
+ [payment-options](#payment-options)
|
||||||
|
+ [wheelchair-access](#wheelchair-access)
|
||||||
|
+ [service:electricity](#serviceelectricity)
|
||||||
|
+ [dog-access](#dog-access)
|
||||||
|
+ [all_tags](#all_tags)
|
||||||
|
+ [questions](#questions)
|
||||||
|
+ [reviews](#reviews)
|
||||||
|
+ [export_as_gpx](#export_as_gpx)
|
||||||
|
+ [minimap](#minimap)
|
||||||
|
+ [wikipedia](#wikipedia)
|
||||||
|
|
||||||
|
Existing builtin tagrenderings
|
||||||
|
--------------------------------
|
||||||
|
|
||||||
|
### images
|
||||||
|
|
||||||
|
- ambulancestation
|
||||||
|
- artwork
|
||||||
|
- bench
|
||||||
|
- bench_at_pt
|
||||||
|
- bicycle_library
|
||||||
|
- bicycle_tube_vending_machine
|
||||||
|
- bike_cafe
|
||||||
|
- bike_cleaning
|
||||||
|
- bike_parking
|
||||||
|
- bike_repair_station
|
||||||
|
- bike_shop
|
||||||
|
- bike_themed_object
|
||||||
|
- binocular
|
||||||
|
- birdhide
|
||||||
|
- cafe_pub
|
||||||
|
- charging_station
|
||||||
|
- defibrillator
|
||||||
|
- drinking_water
|
||||||
|
- entrance
|
||||||
|
- extinguisher
|
||||||
|
- fire_station
|
||||||
|
- food
|
||||||
|
- ghost_bike
|
||||||
|
- grass_in_parks
|
||||||
|
- hydrant
|
||||||
|
- information_board
|
||||||
|
- map
|
||||||
|
- nature_reserve
|
||||||
|
- observation_tower
|
||||||
|
- parking
|
||||||
|
- play_forest
|
||||||
|
- playground
|
||||||
|
- public_bookcase
|
||||||
|
- shops
|
||||||
|
- slow_roads
|
||||||
|
- sport_pitch
|
||||||
|
- surveillance_camera
|
||||||
|
- toilet
|
||||||
|
- trail
|
||||||
|
- tree_node
|
||||||
|
- viewpoint
|
||||||
|
- village_green
|
||||||
|
- watermill
|
||||||
|
|
||||||
|
### website
|
||||||
|
|
||||||
|
- bicycle_library
|
||||||
|
- bike_themed_object
|
||||||
|
- cafe_pub
|
||||||
|
- food
|
||||||
|
- observation_tower
|
||||||
|
|
||||||
|
### phone
|
||||||
|
|
||||||
|
- bicycle_library
|
||||||
|
- bike_themed_object
|
||||||
|
- cafe_pub
|
||||||
|
- food
|
||||||
|
|
||||||
|
### email
|
||||||
|
|
||||||
|
- bicycle_library
|
||||||
|
- bike_themed_object
|
||||||
|
- cafe_pub
|
||||||
|
- food
|
||||||
|
|
||||||
|
### opening_hours
|
||||||
|
|
||||||
|
- bicycle_library
|
||||||
|
- bike_themed_object
|
||||||
|
- cafe_pub
|
||||||
|
- food
|
||||||
|
|
||||||
|
### description
|
||||||
|
|
||||||
|
- bicycle_library
|
||||||
|
- bike_shop
|
||||||
|
- bike_themed_object
|
||||||
|
- toilet
|
||||||
|
|
||||||
|
### level
|
||||||
|
|
||||||
|
- bike_repair_station
|
||||||
|
- charging_station
|
||||||
|
- toilet
|
||||||
|
|
||||||
|
### bike_cleaning.bike_cleaning-service:bicycle:cleaning:charge
|
||||||
|
|
||||||
|
- bike_shop
|
||||||
|
|
||||||
|
### payment-options
|
||||||
|
|
||||||
|
- cafe_pub
|
||||||
|
- charging_station
|
||||||
|
- food
|
||||||
|
- observation_tower
|
||||||
|
- toilet
|
||||||
|
|
||||||
|
### wheelchair-access
|
||||||
|
|
||||||
|
- cafe_pub
|
||||||
|
- defibrillator
|
||||||
|
- food
|
||||||
|
- observation_tower
|
||||||
|
|
||||||
|
### service:electricity
|
||||||
|
|
||||||
|
- cafe_pub
|
||||||
|
- food
|
||||||
|
|
||||||
|
### dog-access
|
||||||
|
|
||||||
|
- cafe_pub
|
||||||
|
- food
|
||||||
|
|
||||||
|
### all_tags
|
||||||
|
|
||||||
|
- cluster_style
|
||||||
|
|
||||||
|
### questions
|
||||||
|
|
||||||
|
- etymology
|
||||||
|
- play_forest
|
||||||
|
- playground
|
||||||
|
- shops
|
||||||
|
- sport_pitch
|
||||||
|
|
||||||
|
### reviews
|
||||||
|
|
||||||
|
- food
|
||||||
|
- shops
|
||||||
|
|
||||||
|
### export_as_gpx
|
||||||
|
|
||||||
|
- gps_track
|
||||||
|
|
||||||
|
### minimap
|
||||||
|
|
||||||
|
- gps_track
|
||||||
|
|
||||||
|
### wikipedia
|
||||||
|
|
||||||
|
- nature_reserve
|
||||||
|
- observation_tower
|
||||||
|
|
||||||
|
This document is autogenerated from assets/layers/*.json
|
|
@ -25,7 +25,6 @@ other medical supplies.
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/ambulancestation/ambulancestation.json)
|
[Go to the source code](../assets/layers/ambulancestation/ambulancestation.json)
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,6 @@ Diverse pieces of artwork
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [artwork](https://mapcomplete.osm.be/artwork)
|
- [artwork](https://mapcomplete.osm.be/artwork)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/artwork/artwork.json)
|
[Go to the source code](../assets/layers/artwork/artwork.json)
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,6 @@ Obstacles while cycling, such as bollards and cycle barriers
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cycle_infra](https://mapcomplete.osm.be/cycle_infra)
|
- [cycle_infra](https://mapcomplete.osm.be/cycle_infra)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/barrier/barrier.json)
|
[Go to the source code](../assets/layers/barrier/barrier.json)
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@ questions about them.
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [benches](https://mapcomplete.osm.be/benches)
|
- [benches](https://mapcomplete.osm.be/benches)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bench/bench.json)
|
[Go to the source code](../assets/layers/bench/bench.json)
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ A layer showing all public-transport-stops which do have a bench
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [benches](https://mapcomplete.osm.be/benches)
|
- [benches](https://mapcomplete.osm.be/benches)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bench_at_pt/bench_at_pt.json)
|
[Go to the source code](../assets/layers/bench_at_pt/bench_at_pt.json)
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,6 @@ A facility where bicycles can be lent for longer period of times
|
||||||
|
|
||||||
- [bicyclelib](https://mapcomplete.osm.be/bicyclelib)
|
- [bicyclelib](https://mapcomplete.osm.be/bicyclelib)
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bicycle_library/bicycle_library.json)
|
[Go to the source code](../assets/layers/bicycle_library/bicycle_library.json)
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ vending machines with bicycle tubes and optionally additional bicycle related ob
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bicycle_tube_vending_machine/bicycle_tube_vending_machine.json)
|
[Go to the source code](../assets/layers/bicycle_tube_vending_machine/bicycle_tube_vending_machine.json)
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,6 @@ decoration, ...
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bike_cafe/bike_cafe.json)
|
[Go to the source code](../assets/layers/bike_cafe/bike_cafe.json)
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ A layer showing facilities where one can clean their bike
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bike_cleaning/bike_cleaning.json)
|
[Go to the source code](../assets/layers/bike_cleaning/bike_cleaning.json)
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@ A layer showing where you can park your bike
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bike_parking/bike_parking.json)
|
[Go to the source code](../assets/layers/bike_parking/bike_parking.json)
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,6 @@ A layer showing bicycle pumps and bicycle repair tool stands
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bike_repair_station/bike_repair_station.json)
|
[Go to the source code](../assets/layers/bike_repair_station/bike_repair_station.json)
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,6 @@ A shop specifically selling bicycles or related items
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bike_shop/bike_shop.json)
|
[Go to the source code](../assets/layers/bike_shop/bike_shop.json)
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,6 @@ A layer with bike-themed objects but who don't match any other layer
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/bike_themed_object/bike_themed_object.json)
|
[Go to the source code](../assets/layers/bike_themed_object/bike_themed_object.json)
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ Binoculas
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [binoculars](https://mapcomplete.osm.be/binoculars)
|
- [binoculars](https://mapcomplete.osm.be/binoculars)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/binocular/binocular.json)
|
[Go to the source code](../assets/layers/binocular/binocular.json)
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,6 @@ Een vogelkijkhut
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [nature](https://mapcomplete.osm.be/nature)
|
- [nature](https://mapcomplete.osm.be/nature)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/birdhide/birdhide.json)
|
[Go to the source code](../assets/layers/birdhide/birdhide.json)
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,6 @@ A layer showing cafés and pubs where one can gather around a drink. The layer a
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cafes_and_pubs](https://mapcomplete.osm.be/cafes_and_pubs)
|
- [cafes_and_pubs](https://mapcomplete.osm.be/cafes_and_pubs)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/cafe_pub/cafe_pub.json)
|
[Go to the source code](../assets/layers/cafe_pub/cafe_pub.json)
|
||||||
|
|
||||||
|
|
|
@ -105,7 +105,6 @@ A charging station
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [charging_stations](https://mapcomplete.osm.be/charging_stations)
|
- [charging_stations](https://mapcomplete.osm.be/charging_stations)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/charging_station/charging_station.json)
|
[Go to the source code](../assets/layers/charging_station/charging_station.json)
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,6 @@ Crossings for pedestrians and cyclists
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cycle_infra](https://mapcomplete.osm.be/cycle_infra)
|
- [cycle_infra](https://mapcomplete.osm.be/cycle_infra)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/crossings/crossings.json)
|
[Go to the source code](../assets/layers/crossings/crossings.json)
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,6 @@ All infrastructure that someone can cycle over, accompanied with questions about
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [cycle_infra](https://mapcomplete.osm.be/cycle_infra)
|
- [cycle_infra](https://mapcomplete.osm.be/cycle_infra)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/cycleways_and_roads/cycleways_and_roads.json)
|
[Go to the source code](../assets/layers/cycleways_and_roads/cycleways_and_roads.json)
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,6 @@ defibrillators which might need staff to fetch the actual device
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [aed](https://mapcomplete.osm.be/aed)
|
- [aed](https://mapcomplete.osm.be/aed)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/defibrillator/defibrillator.json)
|
[Go to the source code](../assets/layers/defibrillator/defibrillator.json)
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ This layer visualizes directions
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [surveillance](https://mapcomplete.osm.be/surveillance)
|
- [surveillance](https://mapcomplete.osm.be/surveillance)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/direction/direction.json)
|
[Go to the source code](../assets/layers/direction/direction.json)
|
||||||
|
|
|
@ -30,7 +30,6 @@ A layer showing drinking water fountains
|
||||||
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
- [cyclofix](https://mapcomplete.osm.be/cyclofix)
|
||||||
- [drinking_water](https://mapcomplete.osm.be/drinking_water)
|
- [drinking_water](https://mapcomplete.osm.be/drinking_water)
|
||||||
- [nature](https://mapcomplete.osm.be/nature)
|
- [nature](https://mapcomplete.osm.be/nature)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/drinking_water/drinking_water.json)
|
[Go to the source code](../assets/layers/drinking_water/drinking_water.json)
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,6 @@ users (but also bicycle users, people who want to deliver, ...)
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [entrances](https://mapcomplete.osm.be/entrances)
|
- [entrances](https://mapcomplete.osm.be/entrances)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/entrance/entrance.json)
|
[Go to the source code](../assets/layers/entrance/entrance.json)
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ All objects which have an etymology known
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [etymology](https://mapcomplete.osm.be/etymology)
|
- [etymology](https://mapcomplete.osm.be/etymology)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/etymology/etymology.json)
|
[Go to the source code](../assets/layers/etymology/etymology.json)
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,6 @@ Map layer to show fire hydrants.
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/extinguisher/extinguisher.json)
|
[Go to the source code](../assets/layers/extinguisher/extinguisher.json)
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,6 @@ Map layer to show fire stations.
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/fire_station/fire_station.json)
|
[Go to the source code](../assets/layers/fire_station/fire_station.json)
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,6 @@ A layer showing restaurants and fast-food amenities (with a special rendering fo
|
||||||
|
|
||||||
- [food](https://mapcomplete.osm.be/food)
|
- [food](https://mapcomplete.osm.be/food)
|
||||||
- [fritures](https://mapcomplete.osm.be/fritures)
|
- [fritures](https://mapcomplete.osm.be/fritures)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/food/food.json)
|
[Go to the source code](../assets/layers/food/food.json)
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,6 @@ A layer showing memorials for cyclists, killed in road accidents
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [ghostbikes](https://mapcomplete.osm.be/ghostbikes)
|
- [ghostbikes](https://mapcomplete.osm.be/ghostbikes)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/ghost_bike/ghost_bike.json)
|
[Go to the source code](../assets/layers/ghost_bike/ghost_bike.json)
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,6 @@ Map layer to show fire hydrants.
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
- [hailhydrant](https://mapcomplete.osm.be/hailhydrant)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/hydrant/hydrant.json)
|
[Go to the source code](../assets/layers/hydrant/hydrant.json)
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,6 @@ feature, a map, ...)
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [nature](https://mapcomplete.osm.be/nature)
|
- [nature](https://mapcomplete.osm.be/nature)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/information_board/information_board.json)
|
[Go to the source code](../assets/layers/information_board/information_board.json)
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,6 @@ A map, meant for tourists which is permanently installed in the public space
|
||||||
|
|
||||||
- [maps](https://mapcomplete.osm.be/maps)
|
- [maps](https://mapcomplete.osm.be/maps)
|
||||||
- [nature](https://mapcomplete.osm.be/nature)
|
- [nature](https://mapcomplete.osm.be/nature)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/map/map.json)
|
[Go to the source code](../assets/layers/map/map.json)
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,6 @@ Natuurpunt of het Agentschap Natuur en Bos of zijn deze erkend door de overheid.
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [nature](https://mapcomplete.osm.be/nature)
|
- [nature](https://mapcomplete.osm.be/nature)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/nature_reserve/nature_reserve.json)
|
[Go to the source code](../assets/layers/nature_reserve/nature_reserve.json)
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ Towers with a panoramic view
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [observation_towers](https://mapcomplete.osm.be/observation_towers)
|
- [observation_towers](https://mapcomplete.osm.be/observation_towers)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/observation_tower/observation_tower.json)
|
[Go to the source code](../assets/layers/observation_tower/observation_tower.json)
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,6 @@ A layer showing car parkings
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [parkings](https://mapcomplete.osm.be/parkings)
|
- [parkings](https://mapcomplete.osm.be/parkings)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/parking/parking.json)
|
[Go to the source code](../assets/layers/parking/parking.json)
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@ Pedestrian footpaths, especially used for indoor navigation and snapping entranc
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [entrances](https://mapcomplete.osm.be/entrances)
|
- [entrances](https://mapcomplete.osm.be/entrances)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/pedestrian_path/pedestrian_path.json)
|
[Go to the source code](../assets/layers/pedestrian_path/pedestrian_path.json)
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,6 @@ The layer showing picnic tables
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [benches](https://mapcomplete.osm.be/benches)
|
- [benches](https://mapcomplete.osm.be/benches)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/picnic_table/picnic_table.json)
|
[Go to the source code](../assets/layers/picnic_table/picnic_table.json)
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,6 @@ Playgrounds
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [playgrounds](https://mapcomplete.osm.be/playgrounds)
|
- [playgrounds](https://mapcomplete.osm.be/playgrounds)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/playground/playground.json)
|
[Go to the source code](../assets/layers/playground/playground.json)
|
||||||
|
|
|
@ -32,7 +32,6 @@ A streetside cabinet with books, accessible to anyone
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [bookcases](https://mapcomplete.osm.be/bookcases)
|
- [bookcases](https://mapcomplete.osm.be/bookcases)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/public_bookcase/public_bookcase.json)
|
[Go to the source code](../assets/layers/public_bookcase/public_bookcase.json)
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@ A shop
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [shops](https://mapcomplete.osm.be/shops)
|
- [shops](https://mapcomplete.osm.be/shops)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/shops/shops.json)
|
[Go to the source code](../assets/layers/shops/shops.json)
|
||||||
|
|
|
@ -27,7 +27,6 @@ A sport pitch
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [sport_pitches](https://mapcomplete.osm.be/sport_pitches)
|
- [sport_pitches](https://mapcomplete.osm.be/sport_pitches)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/sport_pitch/sport_pitch.json)
|
[Go to the source code](../assets/layers/sport_pitch/sport_pitch.json)
|
||||||
|
|
|
@ -25,7 +25,6 @@ A layer showing street lights
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [street_lighting](https://mapcomplete.osm.be/street_lighting)
|
- [street_lighting](https://mapcomplete.osm.be/street_lighting)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/street_lamps/street_lamps.json)
|
[Go to the source code](../assets/layers/street_lamps/street_lamps.json)
|
||||||
|
|
|
@ -30,7 +30,6 @@ This layer shows surveillance cameras and allows a contributor to update informa
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [surveillance](https://mapcomplete.osm.be/surveillance)
|
- [surveillance](https://mapcomplete.osm.be/surveillance)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/surveillance_camera/surveillance_camera.json)
|
[Go to the source code](../assets/layers/surveillance_camera/surveillance_camera.json)
|
||||||
|
|
|
@ -31,7 +31,6 @@ A layer showing (public) toilets
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [toilets](https://mapcomplete.osm.be/toilets)
|
- [toilets](https://mapcomplete.osm.be/toilets)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/toilet/toilet.json)
|
[Go to the source code](../assets/layers/toilet/toilet.json)
|
||||||
|
|
|
@ -26,7 +26,6 @@ A layer showing trees
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [trees](https://mapcomplete.osm.be/trees)
|
- [trees](https://mapcomplete.osm.be/trees)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/tree_node/tree_node.json)
|
[Go to the source code](../assets/layers/tree_node/tree_node.json)
|
||||||
|
|
|
@ -29,7 +29,6 @@ default and not toggleable by the user.
|
||||||
|
|
||||||
- [aed](https://mapcomplete.osm.be/aed)
|
- [aed](https://mapcomplete.osm.be/aed)
|
||||||
- [entrances](https://mapcomplete.osm.be/entrances)
|
- [entrances](https://mapcomplete.osm.be/entrances)
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [surveillance](https://mapcomplete.osm.be/surveillance)
|
- [surveillance](https://mapcomplete.osm.be/surveillance)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/walls_and_buildings/walls_and_buildings.json)
|
[Go to the source code](../assets/layers/walls_and_buildings/walls_and_buildings.json)
|
||||||
|
|
|
@ -19,7 +19,6 @@ This is a public waste basket, thrash can, where you can throw away your thrash.
|
||||||
|
|
||||||
#### Themes using this layer
|
#### Themes using this layer
|
||||||
|
|
||||||
- [personal](https://mapcomplete.osm.be/personal)
|
|
||||||
- [waste_basket](https://mapcomplete.osm.be/waste_basket)
|
- [waste_basket](https://mapcomplete.osm.be/waste_basket)
|
||||||
|
|
||||||
[Go to the source code](../assets/layers/waste_basket/waste_basket.json)
|
[Go to the source code](../assets/layers/waste_basket/waste_basket.json)
|
||||||
|
|
|
@ -1,37 +1,37 @@
|
||||||
export default {
|
export default {
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson",
|
"$ref": "#/definitions/AndOrTagConfigJson",
|
||||||
"definitions": {
|
"definitions": {
|
||||||
"AndOrTagConfigJson": {
|
"AndOrTagConfigJson": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"and": {
|
"and": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"or": {
|
"or": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
},
|
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
|
||||||
}
|
}
|
|
@ -1,91 +1,91 @@
|
||||||
export default {
|
export default {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"extraDeleteReasons": {
|
"extraDeleteReasons": {
|
||||||
"description": "*\nBy default, three reasons to delete a point are shown:\n\n- The point does not exist anymore\n- The point was a testing point\n- THe point could not be found\n\nHowever, for some layers, there might be different or more specific reasons for deletion which can be user friendly to set, e.g.:\n\n- the shop has closed\n- the climbing route has been closed of for nature conservation reasons\n- ...\n\nThese reasons can be stated here and will be shown in the list of options the user can choose from",
|
"description": "*\nBy default, three reasons to delete a point are shown:\n\n- The point does not exist anymore\n- The point was a testing point\n- THe point could not be found\n\nHowever, for some layers, there might be different or more specific reasons for deletion which can be user friendly to set, e.g.:\n\n- the shop has closed\n- the climbing route has been closed of for nature conservation reasons\n- ...\n\nThese reasons can be stated here and will be shown in the list of options the user can choose from",
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"explanation": {
|
"explanation": {
|
||||||
"description": "The text that will be shown to the user - translatable"
|
"description": "The text that will be shown to the user - translatable"
|
||||||
},
|
},
|
||||||
"changesetMessage": {
|
"changesetMessage": {
|
||||||
"description": "The text that will be uploaded into the changeset or will be used in the fixme in case of a soft deletion\nShould be a few words, in english",
|
"description": "The text that will be uploaded into the changeset or will be used in the fixme in case of a soft deletion\nShould be a few words, in english",
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"changesetMessage",
|
||||||
|
"explanation"
|
||||||
|
]
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"nonDeleteMappings": {
|
||||||
"changesetMessage",
|
"description": "In some cases, a (starting) contributor might wish to delete a feature even though deletion is not appropriate.\n(The most relevant case are small paths running over private property. These should be marked as 'private' instead of deleted, as the community might trace the path again from aerial imagery, gettting us back to the original situation).\n\nBy adding a 'nonDeleteMapping', an option can be added into the list which will retag the feature.\nIt is important that the feature will be retagged in such a way that it won't be picked up by the layer anymore!",
|
||||||
"explanation"
|
"type": "array",
|
||||||
]
|
"items": {
|
||||||
}
|
"type": "object",
|
||||||
},
|
"properties": {
|
||||||
"nonDeleteMappings": {
|
"if": {
|
||||||
"description": "In some cases, a (starting) contributor might wish to delete a feature even though deletion is not appropriate.\n(The most relevant case are small paths running over private property. These should be marked as 'private' instead of deleted, as the community might trace the path again from aerial imagery, gettting us back to the original situation).\n\nBy adding a 'nonDeleteMapping', an option can be added into the list which will retag the feature.\nIt is important that the feature will be retagged in such a way that it won't be picked up by the layer anymore!",
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
"type": "array",
|
},
|
||||||
"items": {
|
"then": {}
|
||||||
"type": "object",
|
},
|
||||||
"properties": {
|
"required": [
|
||||||
"if": {
|
"if",
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"then"
|
||||||
},
|
]
|
||||||
"then": {}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"softDeletionTags": {
|
||||||
"if",
|
"description": "In some cases, the contributor is not allowed to delete the current feature (e.g. because it isn't a point, the point is referenced by a relation or the user isn't experienced enough).\nTo still offer the user a 'delete'-option, the feature is retagged with these tags. This is a soft deletion, as the point isn't actually removed from OSM but rather marked as 'disused'\nIt is important that the feature will be retagged in such a way that it won't be picked up by the layer anymore!\n\nExample (note that \"amenity=\" erases the 'amenity'-key alltogether):\n```\n{\n \"and\": [\"disussed:amenity=public_bookcase\", \"amenity=\"]\n}\n```\n\nor (notice the use of the ':='-tag to copy the old value of 'shop=*' into 'disused:shop='):\n```\n{\n \"and\": [\"disused:shop:={shop}\", \"shop=\"]\n}\n```",
|
||||||
"then"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"softDeletionTags": {
|
|
||||||
"description": "In some cases, the contributor is not allowed to delete the current feature (e.g. because it isn't a point, the point is referenced by a relation or the user isn't experienced enough).\nTo still offer the user a 'delete'-option, the feature is retagged with these tags. This is a soft deletion, as the point isn't actually removed from OSM but rather marked as 'disused'\nIt is important that the feature will be retagged in such a way that it won't be picked up by the layer anymore!\n\nExample (note that \"amenity=\" erases the 'amenity'-key alltogether):\n```\n{\n \"and\": [\"disussed:amenity=public_bookcase\", \"amenity=\"]\n}\n```\n\nor (notice the use of the ':='-tag to copy the old value of 'shop=*' into 'disused:shop='):\n```\n{\n \"and\": [\"disused:shop:={shop}\", \"shop=\"]\n}\n```",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"neededChangesets": {
|
|
||||||
"description": "*\nBy default, the contributor needs 20 previous changesets to delete points edited by others.\nFor some small features (e.g. bicycle racks) this is too much and this requirement can be lowered or dropped, which can be done here.",
|
|
||||||
"type": "number"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"or": {
|
"neededChangesets": {
|
||||||
"type": "array",
|
"description": "*\nBy default, the contributor needs 20 previous changesets to delete points edited by others.\nFor some small features (e.g. bicycle racks) this is too much and this requirement can be lowered or dropped, which can be done here.",
|
||||||
"items": {
|
"type": "number"
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"definitions": {
|
||||||
},
|
"AndOrTagConfigJson": {
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"and": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"or": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
}
|
}
|
|
@ -1,87 +1,87 @@
|
||||||
export default {
|
export default {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"id": {
|
"id": {
|
||||||
"description": "An id/name for this filter, used to set the URL parameters",
|
"description": "An id/name for this filter, used to set the URL parameters",
|
||||||
"type": "string"
|
"type": "string"
|
||||||
},
|
},
|
||||||
"options": {
|
"options": {
|
||||||
"description": "The options for a filter\nIf there are multiple options these will be a list of radio buttons\nIf there is only one option this will be a checkbox\nFiltering is done based on the given osmTags that are compared to the objects in that layer.",
|
"description": "The options for a filter\nIf there are multiple options these will be a list of radio buttons\nIf there is only one option this will be a checkbox\nFiltering is done based on the given osmTags that are compared to the objects in that layer.",
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"question": {},
|
|
||||||
"osmTags": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"fields": {
|
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"name": {
|
"question": {},
|
||||||
"type": "string"
|
"osmTags": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"fields": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"name": {
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"name"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"type": {
|
"required": [
|
||||||
"type": "string"
|
"question"
|
||||||
}
|
]
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"name"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"question"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"id",
|
|
||||||
"options"
|
|
||||||
],
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"or": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"required": [
|
||||||
},
|
"id",
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
"options"
|
||||||
|
],
|
||||||
|
"definitions": {
|
||||||
|
"AndOrTagConfigJson": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"and": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"or": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
}
|
}
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -1,292 +1,292 @@
|
||||||
export default {
|
export default {
|
||||||
"description": "The LineRenderingConfig gives all details onto how to render a single line of a feature.\n\nThis can be used if:\n\n- The feature is a line\n- The feature is an area",
|
"description": "The LineRenderingConfig gives all details onto how to render a single line of a feature.\n\nThis can be used if:\n\n- The feature is a line\n- The feature is an area",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"color": {
|
"color": {
|
||||||
"description": "The color for way-elements and SVG-elements.\nIf the value starts with \"--\", the style of the body element will be queried for the corresponding variable instead",
|
"description": "The color for way-elements and SVG-elements.\nIf the value starts with \"--\", the style of the body element will be queried for the corresponding variable instead",
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"width": {
|
|
||||||
"description": "The stroke-width for way-elements",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": [
|
|
||||||
"string",
|
|
||||||
"number"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"dashArray": {
|
|
||||||
"description": "A dasharray, e.g. \"5 6\"\nThe dasharray defines 'pixels of line, pixels of gap, pixels of line, pixels of gap',\nDefault value: \"\" (empty string == full line)",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"lineCap": {
|
|
||||||
"description": "The form at the end of a line",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"fill": {
|
|
||||||
"description": "Wehter or not to fill polygons",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"enum": [
|
|
||||||
"no",
|
|
||||||
"yes"
|
|
||||||
],
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"fillColor": {
|
|
||||||
"description": "The color to fill a polygon with.\nIf undefined, this will be slightly more opaque version of the stroke line",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"offset": {
|
|
||||||
"description": "The number of pixels this line should be moved.\nUse a positive numbe to move to the right, a negative to move to the left (left/right as defined by the drawing direction of the line).\n\nIMPORTANT: MapComplete will already normalize 'key:both:property' and 'key:both' into the corresponding 'key:left' and 'key:right' tagging (same for 'sidewalk=left/right/both' which is rewritten to 'sidewalk:left' and 'sidewalk:right')\nThis simplifies programming. Refer to the CalculatedTags.md-documentation for more details",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "number"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"or": {
|
"width": {
|
||||||
"type": "array",
|
"description": "The stroke-width for way-elements",
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "string"
|
"type": [
|
||||||
}
|
"string",
|
||||||
|
"number"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"dashArray": {
|
||||||
|
"description": "A dasharray, e.g. \"5 6\"\nThe dasharray defines 'pixels of line, pixels of gap, pixels of line, pixels of gap',\nDefault value: \"\" (empty string == full line)",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"lineCap": {
|
||||||
|
"description": "The form at the end of a line",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"fill": {
|
||||||
|
"description": "Wehter or not to fill polygons",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"enum": [
|
||||||
|
"no",
|
||||||
|
"yes"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"fillColor": {
|
||||||
|
"description": "The color to fill a polygon with.\nIf undefined, this will be slightly more opaque version of the stroke line",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"offset": {
|
||||||
|
"description": "The number of pixels this line should be moved.\nUse a positive numbe to move to the right, a negative to move to the left (left/right as defined by the drawing direction of the line).\n\nIMPORTANT: MapComplete will already normalize 'key:both:property' and 'key:both' into the corresponding 'key:left' and 'key:right' tagging (same for 'sidewalk=left/right/both' which is rewritten to 'sidewalk:left' and 'sidewalk:right')\nThis simplifies programming. Refer to the CalculatedTags.md-documentation for more details",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "number"
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"ApplicableUnitJson": {
|
"definitions": {
|
||||||
"type": "object",
|
"AndOrTagConfigJson": {
|
||||||
"properties": {
|
|
||||||
"canonicalDenomination": {
|
|
||||||
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"canonicalDenominationSingular": {
|
|
||||||
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"alternativeDenomination": {
|
|
||||||
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"human": {
|
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
|
||||||
},
|
|
||||||
"humanSingular": {
|
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
|
||||||
},
|
|
||||||
"prefix": {
|
|
||||||
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
|
||||||
"type": "boolean"
|
|
||||||
},
|
|
||||||
"default": {
|
|
||||||
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
|
||||||
"type": "boolean"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"canonicalDenomination"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"TagRenderingConfigJson": {
|
|
||||||
"description": "A TagRenderingConfigJson is a single piece of code which converts one ore more tags into a HTML-snippet.\nIf the desired tags are missing and a question is defined, a question will be shown instead.",
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"id": {
|
|
||||||
"description": "The id of the tagrendering, should be an unique string.\nUsed to keep the translations in sync. Only used in the tagRenderings-array of a layerConfig, not requered otherwise.\n\nUse 'questions' to trigger the question box of this group (if a group is defined)",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"group": {
|
|
||||||
"description": "If 'group' is defined on many tagRenderings, these are grouped together when shown. The questions are grouped together as well.\nThe first tagRendering of a group will always be a sticky element.",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"render": {
|
|
||||||
"description": "Renders this value. Note that \"{key}\"-parts are substituted by the corresponding values of the element.\nIf neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value.\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`"
|
|
||||||
},
|
|
||||||
"question": {
|
|
||||||
"description": "If it turns out that this tagRendering doesn't match _any_ value, then we show this question.\nIf undefined, the question is never asked and this tagrendering is read-only"
|
|
||||||
},
|
|
||||||
"condition": {
|
|
||||||
"description": "Only show this question if the object also matches the following tags.\n\nThis is useful to ask a follow-up question. E.g. if there is a diaper table, then ask a follow-up question on diaper tables...",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"freeform": {
|
|
||||||
"description": "Allow freeform text input from the user",
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"key": {
|
|
||||||
"description": "If this key is present, then 'render' is used to display the value.\nIf this is undefined, the rendering is _always_ shown",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"type": {
|
|
||||||
"description": "The type of the text-field, e.g. 'string', 'nat', 'float', 'date',...\nSee Docs/SpecialInputElements.md and UI/Input/ValidatedTextField.ts for supported values",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"helperArgs": {
|
|
||||||
"description": "Extra parameters to initialize the input helper arguments.\nFor semantics, see the 'SpecialInputElements.md'",
|
|
||||||
"type": "array",
|
|
||||||
"items": {}
|
|
||||||
},
|
|
||||||
"addExtraTags": {
|
|
||||||
"description": "If a value is added with the textfield, these extra tag is addded.\nUseful to add a 'fixme=freeform textfield used - to be checked'",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"inline": {
|
|
||||||
"description": "When set, influences the way a question is asked.\nInstead of showing a full-widht text field, the text field will be shown within the rendering of the question.\n\nThis combines badly with special input elements, as it'll distort the layout.",
|
|
||||||
"type": "boolean"
|
|
||||||
},
|
|
||||||
"default": {
|
|
||||||
"description": "default value to enter if no previous tagging is present.\nNormally undefined (aka do not enter anything)",
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"key"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"multiAnswer": {
|
|
||||||
"description": "If true, use checkboxes instead of radio buttons when asking the question",
|
|
||||||
"type": "boolean"
|
|
||||||
},
|
|
||||||
"mappings": {
|
|
||||||
"description": "Allows fixed-tag inputs, shown either as radiobuttons or as checkboxes",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"if": {
|
"and": {
|
||||||
"description": "If this condition is met, then the text under `then` will be shown.\nIf no value matches, and the user selects this mapping as an option, then these tags will be uploaded to OSM.\n\nFor example: {'if': 'diet:vegetarion=yes', 'then':'A vegetarian option is offered here'}\n\nThis can be an substituting-tag as well, e.g. {'if': 'addr:street:={_calculated_nearby_streetname}', 'then': '{_calculated_nearby_streetname}'}",
|
"type": "array",
|
||||||
"anyOf": [
|
"items": {
|
||||||
{
|
"anyOf": [
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
{
|
||||||
},
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
{
|
},
|
||||||
"type": "string"
|
{
|
||||||
}
|
"type": "string"
|
||||||
]
|
}
|
||||||
},
|
]
|
||||||
"then": {
|
}
|
||||||
"description": "If the condition `if` is met, the text `then` will be rendered.\nIf not known yet, the user will be presented with `then` as an option"
|
},
|
||||||
},
|
"or": {
|
||||||
"hideInAnswer": {
|
"type": "array",
|
||||||
"description": "In some cases, multiple taggings exist (e.g. a default assumption, or a commonly mapped abbreviation and a fully written variation).\n\nIn the latter case, a correct text should be shown, but only a single, canonical tagging should be selectable by the user.\nIn this case, one of the mappings can be hiden by setting this flag.\n\nTo demonstrate an example making a default assumption:\n\nmappings: [\n {\n if: \"access=\", -- no access tag present, we assume accessible\n then: \"Accessible to the general public\",\n hideInAnswer: true\n },\n {\n if: \"access=yes\",\n then: \"Accessible to the general public\", -- the user selected this, we add that to OSM\n },\n {\n if: \"access=no\",\n then: \"Not accessible to the public\"\n }\n]\n\n\nFor example, for an operator, we have `operator=Agentschap Natuur en Bos`, which is often abbreviated to `operator=ANB`.\nThen, we would add two mappings:\n{\n if: \"operator=Agentschap Natuur en Bos\" -- the non-abbreviated version which should be uploaded\n then: \"Maintained by Agentschap Natuur en Bos\"\n},\n{\n if: \"operator=ANB\", -- we don't want to upload abbreviations\n then: \"Maintained by Agentschap Natuur en Bos\"\n hideInAnswer: true\n}\n\nHide in answer can also be a tagsfilter, e.g. to make sure an option is only shown when appropriate.\nKeep in mind that this is reverse logic: it will be hidden in the answer if the condition is true, it will thus only show in the case of a mismatch\n\ne.g., for toilets: if \"wheelchair=no\", we know there is no wheelchair dedicated room.\nFor the location of the changing table, the option \"in the wheelchair accessible toilet is weird\", so we write:\n\n{\n \"question\": \"Where is the changing table located?\"\n \"mappings\": [\n {\"if\":\"changing_table:location=female\",\"then\":\"In the female restroom\"},\n {\"if\":\"changing_table:location=male\",\"then\":\"In the male restroom\"},\n {\"if\":\"changing_table:location=wheelchair\",\"then\":\"In the wheelchair accessible restroom\", \"hideInAnswer\": \"wheelchair=no\"},\n \n ]\n}\n\nAlso have a look for the meta-tags\n{\n if: \"operator=Agentschap Natuur en Bos\",\n then: \"Maintained by Agentschap Natuur en Bos\",\n hideInAnswer: \"_country!=be\"\n}",
|
"items": {
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": [
|
"type": "string"
|
||||||
"string",
|
}
|
||||||
"boolean"
|
]
|
||||||
]
|
}
|
||||||
}
|
}
|
||||||
]
|
}
|
||||||
},
|
},
|
||||||
"ifnot": {
|
"ApplicableUnitJson": {
|
||||||
"description": "Only applicable if 'multiAnswer' is set.\nThis is for situations such as:\n`accepts:coins=no` where one can select all the possible payment methods. However, we want to make explicit that some options _were not_ selected.\nThis can be done with `ifnot`\nNote that we can not explicitly render this negative case to the user, we cannot show `does _not_ accept coins`.\nIf this is important to your usecase, consider using multiple radiobutton-fields without `multiAnswer`",
|
"type": "object",
|
||||||
"anyOf": [
|
"properties": {
|
||||||
{
|
"canonicalDenomination": {
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
||||||
},
|
"type": "string"
|
||||||
{
|
},
|
||||||
"type": "string"
|
"canonicalDenominationSingular": {
|
||||||
}
|
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
||||||
]
|
"type": "string"
|
||||||
},
|
},
|
||||||
"addExtraTags": {
|
"alternativeDenomination": {
|
||||||
"description": "If chosen as answer, these tags will be applied as well onto the object.\nNot compatible with multiAnswer",
|
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"human": {
|
||||||
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
||||||
|
},
|
||||||
|
"humanSingular": {
|
||||||
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
||||||
|
},
|
||||||
|
"prefix": {
|
||||||
|
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
"if",
|
"canonicalDenomination"
|
||||||
"then"
|
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
"TagRenderingConfigJson": {
|
||||||
|
"description": "A TagRenderingConfigJson is a single piece of code which converts one ore more tags into a HTML-snippet.\nIf the desired tags are missing and a question is defined, a question will be shown instead.",
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"id": {
|
||||||
|
"description": "The id of the tagrendering, should be an unique string.\nUsed to keep the translations in sync. Only used in the tagRenderings-array of a layerConfig, not requered otherwise.\n\nUse 'questions' to trigger the question box of this group (if a group is defined)",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"group": {
|
||||||
|
"description": "If 'group' is defined on many tagRenderings, these are grouped together when shown. The questions are grouped together as well.\nThe first tagRendering of a group will always be a sticky element.",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"render": {
|
||||||
|
"description": "Renders this value. Note that \"{key}\"-parts are substituted by the corresponding values of the element.\nIf neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value.\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`"
|
||||||
|
},
|
||||||
|
"question": {
|
||||||
|
"description": "If it turns out that this tagRendering doesn't match _any_ value, then we show this question.\nIf undefined, the question is never asked and this tagrendering is read-only"
|
||||||
|
},
|
||||||
|
"condition": {
|
||||||
|
"description": "Only show this question if the object also matches the following tags.\n\nThis is useful to ask a follow-up question. E.g. if there is a diaper table, then ask a follow-up question on diaper tables...",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"freeform": {
|
||||||
|
"description": "Allow freeform text input from the user",
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"key": {
|
||||||
|
"description": "If this key is present, then 'render' is used to display the value.\nIf this is undefined, the rendering is _always_ shown",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"description": "The type of the text-field, e.g. 'string', 'nat', 'float', 'date',...\nSee Docs/SpecialInputElements.md and UI/Input/ValidatedTextField.ts for supported values",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"helperArgs": {
|
||||||
|
"description": "Extra parameters to initialize the input helper arguments.\nFor semantics, see the 'SpecialInputElements.md'",
|
||||||
|
"type": "array",
|
||||||
|
"items": {}
|
||||||
|
},
|
||||||
|
"addExtraTags": {
|
||||||
|
"description": "If a value is added with the textfield, these extra tag is addded.\nUseful to add a 'fixme=freeform textfield used - to be checked'",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"inline": {
|
||||||
|
"description": "When set, influences the way a question is asked.\nInstead of showing a full-widht text field, the text field will be shown within the rendering of the question.\n\nThis combines badly with special input elements, as it'll distort the layout.",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "default value to enter if no previous tagging is present.\nNormally undefined (aka do not enter anything)",
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"key"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"multiAnswer": {
|
||||||
|
"description": "If true, use checkboxes instead of radio buttons when asking the question",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"mappings": {
|
||||||
|
"description": "Allows fixed-tag inputs, shown either as radiobuttons or as checkboxes",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"if": {
|
||||||
|
"description": "If this condition is met, then the text under `then` will be shown.\nIf no value matches, and the user selects this mapping as an option, then these tags will be uploaded to OSM.\n\nFor example: {'if': 'diet:vegetarion=yes', 'then':'A vegetarian option is offered here'}\n\nThis can be an substituting-tag as well, e.g. {'if': 'addr:street:={_calculated_nearby_streetname}', 'then': '{_calculated_nearby_streetname}'}",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"description": "If the condition `if` is met, the text `then` will be rendered.\nIf not known yet, the user will be presented with `then` as an option"
|
||||||
|
},
|
||||||
|
"hideInAnswer": {
|
||||||
|
"description": "In some cases, multiple taggings exist (e.g. a default assumption, or a commonly mapped abbreviation and a fully written variation).\n\nIn the latter case, a correct text should be shown, but only a single, canonical tagging should be selectable by the user.\nIn this case, one of the mappings can be hiden by setting this flag.\n\nTo demonstrate an example making a default assumption:\n\nmappings: [\n {\n if: \"access=\", -- no access tag present, we assume accessible\n then: \"Accessible to the general public\",\n hideInAnswer: true\n },\n {\n if: \"access=yes\",\n then: \"Accessible to the general public\", -- the user selected this, we add that to OSM\n },\n {\n if: \"access=no\",\n then: \"Not accessible to the public\"\n }\n]\n\n\nFor example, for an operator, we have `operator=Agentschap Natuur en Bos`, which is often abbreviated to `operator=ANB`.\nThen, we would add two mappings:\n{\n if: \"operator=Agentschap Natuur en Bos\" -- the non-abbreviated version which should be uploaded\n then: \"Maintained by Agentschap Natuur en Bos\"\n},\n{\n if: \"operator=ANB\", -- we don't want to upload abbreviations\n then: \"Maintained by Agentschap Natuur en Bos\"\n hideInAnswer: true\n}\n\nHide in answer can also be a tagsfilter, e.g. to make sure an option is only shown when appropriate.\nKeep in mind that this is reverse logic: it will be hidden in the answer if the condition is true, it will thus only show in the case of a mismatch\n\ne.g., for toilets: if \"wheelchair=no\", we know there is no wheelchair dedicated room.\nFor the location of the changing table, the option \"in the wheelchair accessible toilet is weird\", so we write:\n\n{\n \"question\": \"Where is the changing table located?\"\n \"mappings\": [\n {\"if\":\"changing_table:location=female\",\"then\":\"In the female restroom\"},\n {\"if\":\"changing_table:location=male\",\"then\":\"In the male restroom\"},\n {\"if\":\"changing_table:location=wheelchair\",\"then\":\"In the wheelchair accessible restroom\", \"hideInAnswer\": \"wheelchair=no\"},\n \n ]\n}\n\nAlso have a look for the meta-tags\n{\n if: \"operator=Agentschap Natuur en Bos\",\n then: \"Maintained by Agentschap Natuur en Bos\",\n hideInAnswer: \"_country!=be\"\n}",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"boolean"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"ifnot": {
|
||||||
|
"description": "Only applicable if 'multiAnswer' is set.\nThis is for situations such as:\n`accepts:coins=no` where one can select all the possible payment methods. However, we want to make explicit that some options _were not_ selected.\nThis can be done with `ifnot`\nNote that we can not explicitly render this negative case to the user, we cannot show `does _not_ accept coins`.\nIf this is important to your usecase, consider using multiple radiobutton-fields without `multiAnswer`",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"addExtraTags": {
|
||||||
|
"description": "If chosen as answer, these tags will be applied as well onto the object.\nNot compatible with multiAnswer",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"if",
|
||||||
|
"then"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
},
|
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
|
||||||
}
|
}
|
|
@ -1,84 +1,84 @@
|
||||||
export default {
|
export default {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"enableImproveAccuracy": {
|
"enableImproveAccuracy": {
|
||||||
"description": "One default reason to move a point is to improve accuracy.\nSet to false to disable this reason",
|
"description": "One default reason to move a point is to improve accuracy.\nSet to false to disable this reason",
|
||||||
"type": "boolean"
|
"type": "boolean"
|
||||||
},
|
|
||||||
"enableRelocation": {
|
|
||||||
"description": "One default reason to move a point is because it has relocated\nSet to false to disable this reason",
|
|
||||||
"type": "boolean"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"or": {
|
"enableRelocation": {
|
||||||
"type": "array",
|
"description": "One default reason to move a point is because it has relocated\nSet to false to disable this reason",
|
||||||
"items": {
|
"type": "boolean"
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"ApplicableUnitJson": {
|
"definitions": {
|
||||||
"type": "object",
|
"AndOrTagConfigJson": {
|
||||||
"properties": {
|
"type": "object",
|
||||||
"canonicalDenomination": {
|
"properties": {
|
||||||
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
"and": {
|
||||||
"type": "string"
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"or": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"canonicalDenominationSingular": {
|
"ApplicableUnitJson": {
|
||||||
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
"type": "object",
|
||||||
"type": "string"
|
"properties": {
|
||||||
},
|
"canonicalDenomination": {
|
||||||
"alternativeDenomination": {
|
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
||||||
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
"type": "string"
|
||||||
"type": "array",
|
},
|
||||||
"items": {
|
"canonicalDenominationSingular": {
|
||||||
"type": "string"
|
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
||||||
}
|
"type": "string"
|
||||||
},
|
},
|
||||||
"human": {
|
"alternativeDenomination": {
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
||||||
},
|
"type": "array",
|
||||||
"humanSingular": {
|
"items": {
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
"type": "string"
|
||||||
},
|
}
|
||||||
"prefix": {
|
},
|
||||||
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
"human": {
|
||||||
"type": "boolean"
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
||||||
},
|
},
|
||||||
"default": {
|
"humanSingular": {
|
||||||
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
||||||
"type": "boolean"
|
},
|
||||||
|
"prefix": {
|
||||||
|
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
||||||
|
"type": "boolean"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"canonicalDenomination"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
"canonicalDenomination"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
|
||||||
}
|
}
|
|
@ -1,295 +1,295 @@
|
||||||
export default {
|
export default {
|
||||||
"description": "The PointRenderingConfig gives all details onto how to render a single point of a feature.\n\nThis can be used if:\n\n- The feature is a point\n- To render something at the centroid of an area, or at the start, end or projected centroid of a way",
|
"description": "The PointRenderingConfig gives all details onto how to render a single point of a feature.\n\nThis can be used if:\n\n- The feature is a point\n- To render something at the centroid of an area, or at the start, end or projected centroid of a way",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"location": {
|
"location": {
|
||||||
"description": "All the locations that this point should be rendered at.\nUsing `location: [\"point\", \"centroid\"] will always render centerpoint",
|
"description": "All the locations that this point should be rendered at.\nUsing `location: [\"point\", \"centroid\"] will always render centerpoint",
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"icon": {
|
|
||||||
"description": "The icon for an element.\nNote that this also doubles as the icon for this layer (rendered with the overpass-tags) ánd the icon in the presets.\n\nThe result of the icon is rendered as follows:\nthe resulting string is interpreted as a _list_ of items, separated by \";\". The bottommost layer is the first layer.\nAs a result, on could use a generic pin, then overlay it with a specific icon.\nTo make things even more practical, one can use all SVG's from the folder \"assets/svg\" and _substitute the color_ in it.\nE.g. to draw a red pin, use \"pin:#f00\", to have a green circle with your icon on top, use `circle:#0f0;<path to my icon.svg>`",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"iconBadges": {
|
|
||||||
"description": "A list of extra badges to show next to the icon as small badge\nThey will be added as a 25% height icon at the bottom right of the icon, with all the badges in a flex layout.\n\nNote: strings are interpreted as icons, so layering and substituting is supported. You can use `circle:white;./my_icon.svg` to add a background circle",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"if": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"then": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"if",
|
|
||||||
"then"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"iconSize": {
|
|
||||||
"description": "A string containing \"width,height\" or \"width,height,anchorpoint\" where anchorpoint is any of 'center', 'top', 'bottom', 'left', 'right', 'bottomleft','topright', ...\nDefault is '40,40,center'",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"rotation": {
|
|
||||||
"description": "The rotation of an icon, useful for e.g. directions.\nUsage: as if it were a css property for 'rotate', thus has to end with 'deg', e.g. `90deg`, `{direction}deg`, `calc(90deg - {camera:direction}deg)``",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"label": {
|
|
||||||
"description": "A HTML-fragment that is shown below the icon, for example:\n<div style=\"background: white; display: block\">{name}</div>\n\nIf the icon is undefined, then the label is shown in the center of the feature.\nNote that, if the wayhandling hides the icon then no label is shown as well.",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/TagRenderingConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"location"
|
|
||||||
],
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"or": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"ApplicableUnitJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"canonicalDenomination": {
|
|
||||||
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"canonicalDenominationSingular": {
|
|
||||||
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"alternativeDenomination": {
|
|
||||||
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"human": {
|
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
|
||||||
},
|
|
||||||
"humanSingular": {
|
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
|
||||||
},
|
|
||||||
"prefix": {
|
|
||||||
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
|
||||||
"type": "boolean"
|
|
||||||
},
|
|
||||||
"default": {
|
|
||||||
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
|
||||||
"type": "boolean"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"canonicalDenomination"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"TagRenderingConfigJson": {
|
|
||||||
"description": "A TagRenderingConfigJson is a single piece of code which converts one ore more tags into a HTML-snippet.\nIf the desired tags are missing and a question is defined, a question will be shown instead.",
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"id": {
|
|
||||||
"description": "The id of the tagrendering, should be an unique string.\nUsed to keep the translations in sync. Only used in the tagRenderings-array of a layerConfig, not requered otherwise.\n\nUse 'questions' to trigger the question box of this group (if a group is defined)",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"group": {
|
|
||||||
"description": "If 'group' is defined on many tagRenderings, these are grouped together when shown. The questions are grouped together as well.\nThe first tagRendering of a group will always be a sticky element.",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"render": {
|
|
||||||
"description": "Renders this value. Note that \"{key}\"-parts are substituted by the corresponding values of the element.\nIf neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value.\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`"
|
|
||||||
},
|
|
||||||
"question": {
|
|
||||||
"description": "If it turns out that this tagRendering doesn't match _any_ value, then we show this question.\nIf undefined, the question is never asked and this tagrendering is read-only"
|
|
||||||
},
|
|
||||||
"condition": {
|
|
||||||
"description": "Only show this question if the object also matches the following tags.\n\nThis is useful to ask a follow-up question. E.g. if there is a diaper table, then ask a follow-up question on diaper tables...",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
}
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"freeform": {
|
"icon": {
|
||||||
"description": "Allow freeform text input from the user",
|
"description": "The icon for an element.\nNote that this also doubles as the icon for this layer (rendered with the overpass-tags) ánd the icon in the presets.\n\nThe result of the icon is rendered as follows:\nthe resulting string is interpreted as a _list_ of items, separated by \";\". The bottommost layer is the first layer.\nAs a result, on could use a generic pin, then overlay it with a specific icon.\nTo make things even more practical, one can use all SVG's from the folder \"assets/svg\" and _substitute the color_ in it.\nE.g. to draw a red pin, use \"pin:#f00\", to have a green circle with your icon on top, use `circle:#0f0;<path to my icon.svg>`",
|
||||||
"type": "object",
|
"anyOf": [
|
||||||
"properties": {
|
{
|
||||||
"key": {
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
"description": "If this key is present, then 'render' is used to display the value.\nIf this is undefined, the rendering is _always_ shown",
|
},
|
||||||
"type": "string"
|
{
|
||||||
},
|
"type": "string"
|
||||||
"type": {
|
}
|
||||||
"description": "The type of the text-field, e.g. 'string', 'nat', 'float', 'date',...\nSee Docs/SpecialInputElements.md and UI/Input/ValidatedTextField.ts for supported values",
|
]
|
||||||
"type": "string"
|
},
|
||||||
},
|
"iconBadges": {
|
||||||
"helperArgs": {
|
"description": "A list of extra badges to show next to the icon as small badge\nThey will be added as a 25% height icon at the bottom right of the icon, with all the badges in a flex layout.\n\nNote: strings are interpreted as icons, so layering and substituting is supported. You can use `circle:white;./my_icon.svg` to add a background circle",
|
||||||
"description": "Extra parameters to initialize the input helper arguments.\nFor semantics, see the 'SpecialInputElements.md'",
|
"type": "array",
|
||||||
"type": "array",
|
"items": {
|
||||||
"items": {}
|
"type": "object",
|
||||||
},
|
"properties": {
|
||||||
"addExtraTags": {
|
"if": {
|
||||||
"description": "If a value is added with the textfield, these extra tag is addded.\nUseful to add a 'fixme=freeform textfield used - to be checked'",
|
"anyOf": [
|
||||||
"type": "array",
|
{
|
||||||
"items": {
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
"type": "string"
|
},
|
||||||
}
|
{
|
||||||
},
|
"type": "string"
|
||||||
"inline": {
|
}
|
||||||
"description": "When set, influences the way a question is asked.\nInstead of showing a full-widht text field, the text field will be shown within the rendering of the question.\n\nThis combines badly with special input elements, as it'll distort the layout.",
|
]
|
||||||
"type": "boolean"
|
},
|
||||||
},
|
"then": {
|
||||||
"default": {
|
"anyOf": [
|
||||||
"description": "default value to enter if no previous tagging is present.\nNormally undefined (aka do not enter anything)",
|
{
|
||||||
"type": "string"
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"if",
|
||||||
|
"then"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"key"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"multiAnswer": {
|
"iconSize": {
|
||||||
"description": "If true, use checkboxes instead of radio buttons when asking the question",
|
"description": "A string containing \"width,height\" or \"width,height,anchorpoint\" where anchorpoint is any of 'center', 'top', 'bottom', 'left', 'right', 'bottomleft','topright', ...\nDefault is '40,40,center'",
|
||||||
"type": "boolean"
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"mappings": {
|
"rotation": {
|
||||||
"description": "Allows fixed-tag inputs, shown either as radiobuttons or as checkboxes",
|
"description": "The rotation of an icon, useful for e.g. directions.\nUsage: as if it were a css property for 'rotate', thus has to end with 'deg', e.g. `90deg`, `{direction}deg`, `calc(90deg - {camera:direction}deg)``",
|
||||||
"type": "array",
|
"anyOf": [
|
||||||
"items": {
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"label": {
|
||||||
|
"description": "A HTML-fragment that is shown below the icon, for example:\n<div style=\"background: white; display: block\">{name}</div>\n\nIf the icon is undefined, then the label is shown in the center of the feature.\nNote that, if the wayhandling hides the icon then no label is shown as well.",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/TagRenderingConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"location"
|
||||||
|
],
|
||||||
|
"definitions": {
|
||||||
|
"AndOrTagConfigJson": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"if": {
|
"and": {
|
||||||
"description": "If this condition is met, then the text under `then` will be shown.\nIf no value matches, and the user selects this mapping as an option, then these tags will be uploaded to OSM.\n\nFor example: {'if': 'diet:vegetarion=yes', 'then':'A vegetarian option is offered here'}\n\nThis can be an substituting-tag as well, e.g. {'if': 'addr:street:={_calculated_nearby_streetname}', 'then': '{_calculated_nearby_streetname}'}",
|
"type": "array",
|
||||||
"anyOf": [
|
"items": {
|
||||||
{
|
"anyOf": [
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
{
|
||||||
},
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
{
|
},
|
||||||
"type": "string"
|
{
|
||||||
}
|
"type": "string"
|
||||||
]
|
}
|
||||||
},
|
]
|
||||||
"then": {
|
}
|
||||||
"description": "If the condition `if` is met, the text `then` will be rendered.\nIf not known yet, the user will be presented with `then` as an option"
|
},
|
||||||
},
|
"or": {
|
||||||
"hideInAnswer": {
|
"type": "array",
|
||||||
"description": "In some cases, multiple taggings exist (e.g. a default assumption, or a commonly mapped abbreviation and a fully written variation).\n\nIn the latter case, a correct text should be shown, but only a single, canonical tagging should be selectable by the user.\nIn this case, one of the mappings can be hiden by setting this flag.\n\nTo demonstrate an example making a default assumption:\n\nmappings: [\n {\n if: \"access=\", -- no access tag present, we assume accessible\n then: \"Accessible to the general public\",\n hideInAnswer: true\n },\n {\n if: \"access=yes\",\n then: \"Accessible to the general public\", -- the user selected this, we add that to OSM\n },\n {\n if: \"access=no\",\n then: \"Not accessible to the public\"\n }\n]\n\n\nFor example, for an operator, we have `operator=Agentschap Natuur en Bos`, which is often abbreviated to `operator=ANB`.\nThen, we would add two mappings:\n{\n if: \"operator=Agentschap Natuur en Bos\" -- the non-abbreviated version which should be uploaded\n then: \"Maintained by Agentschap Natuur en Bos\"\n},\n{\n if: \"operator=ANB\", -- we don't want to upload abbreviations\n then: \"Maintained by Agentschap Natuur en Bos\"\n hideInAnswer: true\n}\n\nHide in answer can also be a tagsfilter, e.g. to make sure an option is only shown when appropriate.\nKeep in mind that this is reverse logic: it will be hidden in the answer if the condition is true, it will thus only show in the case of a mismatch\n\ne.g., for toilets: if \"wheelchair=no\", we know there is no wheelchair dedicated room.\nFor the location of the changing table, the option \"in the wheelchair accessible toilet is weird\", so we write:\n\n{\n \"question\": \"Where is the changing table located?\"\n \"mappings\": [\n {\"if\":\"changing_table:location=female\",\"then\":\"In the female restroom\"},\n {\"if\":\"changing_table:location=male\",\"then\":\"In the male restroom\"},\n {\"if\":\"changing_table:location=wheelchair\",\"then\":\"In the wheelchair accessible restroom\", \"hideInAnswer\": \"wheelchair=no\"},\n \n ]\n}\n\nAlso have a look for the meta-tags\n{\n if: \"operator=Agentschap Natuur en Bos\",\n then: \"Maintained by Agentschap Natuur en Bos\",\n hideInAnswer: \"_country!=be\"\n}",
|
"items": {
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": [
|
"type": "string"
|
||||||
"string",
|
}
|
||||||
"boolean"
|
]
|
||||||
]
|
}
|
||||||
}
|
}
|
||||||
]
|
}
|
||||||
},
|
},
|
||||||
"ifnot": {
|
"ApplicableUnitJson": {
|
||||||
"description": "Only applicable if 'multiAnswer' is set.\nThis is for situations such as:\n`accepts:coins=no` where one can select all the possible payment methods. However, we want to make explicit that some options _were not_ selected.\nThis can be done with `ifnot`\nNote that we can not explicitly render this negative case to the user, we cannot show `does _not_ accept coins`.\nIf this is important to your usecase, consider using multiple radiobutton-fields without `multiAnswer`",
|
"type": "object",
|
||||||
"anyOf": [
|
"properties": {
|
||||||
{
|
"canonicalDenomination": {
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
||||||
},
|
"type": "string"
|
||||||
{
|
},
|
||||||
"type": "string"
|
"canonicalDenominationSingular": {
|
||||||
}
|
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
||||||
]
|
"type": "string"
|
||||||
},
|
},
|
||||||
"addExtraTags": {
|
"alternativeDenomination": {
|
||||||
"description": "If chosen as answer, these tags will be applied as well onto the object.\nNot compatible with multiAnswer",
|
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"human": {
|
||||||
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
||||||
|
},
|
||||||
|
"humanSingular": {
|
||||||
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
||||||
|
},
|
||||||
|
"prefix": {
|
||||||
|
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
"if",
|
"canonicalDenomination"
|
||||||
"then"
|
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
"TagRenderingConfigJson": {
|
||||||
|
"description": "A TagRenderingConfigJson is a single piece of code which converts one ore more tags into a HTML-snippet.\nIf the desired tags are missing and a question is defined, a question will be shown instead.",
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"id": {
|
||||||
|
"description": "The id of the tagrendering, should be an unique string.\nUsed to keep the translations in sync. Only used in the tagRenderings-array of a layerConfig, not requered otherwise.\n\nUse 'questions' to trigger the question box of this group (if a group is defined)",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"group": {
|
||||||
|
"description": "If 'group' is defined on many tagRenderings, these are grouped together when shown. The questions are grouped together as well.\nThe first tagRendering of a group will always be a sticky element.",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"render": {
|
||||||
|
"description": "Renders this value. Note that \"{key}\"-parts are substituted by the corresponding values of the element.\nIf neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value.\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`"
|
||||||
|
},
|
||||||
|
"question": {
|
||||||
|
"description": "If it turns out that this tagRendering doesn't match _any_ value, then we show this question.\nIf undefined, the question is never asked and this tagrendering is read-only"
|
||||||
|
},
|
||||||
|
"condition": {
|
||||||
|
"description": "Only show this question if the object also matches the following tags.\n\nThis is useful to ask a follow-up question. E.g. if there is a diaper table, then ask a follow-up question on diaper tables...",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"freeform": {
|
||||||
|
"description": "Allow freeform text input from the user",
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"key": {
|
||||||
|
"description": "If this key is present, then 'render' is used to display the value.\nIf this is undefined, the rendering is _always_ shown",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"description": "The type of the text-field, e.g. 'string', 'nat', 'float', 'date',...\nSee Docs/SpecialInputElements.md and UI/Input/ValidatedTextField.ts for supported values",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"helperArgs": {
|
||||||
|
"description": "Extra parameters to initialize the input helper arguments.\nFor semantics, see the 'SpecialInputElements.md'",
|
||||||
|
"type": "array",
|
||||||
|
"items": {}
|
||||||
|
},
|
||||||
|
"addExtraTags": {
|
||||||
|
"description": "If a value is added with the textfield, these extra tag is addded.\nUseful to add a 'fixme=freeform textfield used - to be checked'",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"inline": {
|
||||||
|
"description": "When set, influences the way a question is asked.\nInstead of showing a full-widht text field, the text field will be shown within the rendering of the question.\n\nThis combines badly with special input elements, as it'll distort the layout.",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "default value to enter if no previous tagging is present.\nNormally undefined (aka do not enter anything)",
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"key"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"multiAnswer": {
|
||||||
|
"description": "If true, use checkboxes instead of radio buttons when asking the question",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"mappings": {
|
||||||
|
"description": "Allows fixed-tag inputs, shown either as radiobuttons or as checkboxes",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"if": {
|
||||||
|
"description": "If this condition is met, then the text under `then` will be shown.\nIf no value matches, and the user selects this mapping as an option, then these tags will be uploaded to OSM.\n\nFor example: {'if': 'diet:vegetarion=yes', 'then':'A vegetarian option is offered here'}\n\nThis can be an substituting-tag as well, e.g. {'if': 'addr:street:={_calculated_nearby_streetname}', 'then': '{_calculated_nearby_streetname}'}",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"description": "If the condition `if` is met, the text `then` will be rendered.\nIf not known yet, the user will be presented with `then` as an option"
|
||||||
|
},
|
||||||
|
"hideInAnswer": {
|
||||||
|
"description": "In some cases, multiple taggings exist (e.g. a default assumption, or a commonly mapped abbreviation and a fully written variation).\n\nIn the latter case, a correct text should be shown, but only a single, canonical tagging should be selectable by the user.\nIn this case, one of the mappings can be hiden by setting this flag.\n\nTo demonstrate an example making a default assumption:\n\nmappings: [\n {\n if: \"access=\", -- no access tag present, we assume accessible\n then: \"Accessible to the general public\",\n hideInAnswer: true\n },\n {\n if: \"access=yes\",\n then: \"Accessible to the general public\", -- the user selected this, we add that to OSM\n },\n {\n if: \"access=no\",\n then: \"Not accessible to the public\"\n }\n]\n\n\nFor example, for an operator, we have `operator=Agentschap Natuur en Bos`, which is often abbreviated to `operator=ANB`.\nThen, we would add two mappings:\n{\n if: \"operator=Agentschap Natuur en Bos\" -- the non-abbreviated version which should be uploaded\n then: \"Maintained by Agentschap Natuur en Bos\"\n},\n{\n if: \"operator=ANB\", -- we don't want to upload abbreviations\n then: \"Maintained by Agentschap Natuur en Bos\"\n hideInAnswer: true\n}\n\nHide in answer can also be a tagsfilter, e.g. to make sure an option is only shown when appropriate.\nKeep in mind that this is reverse logic: it will be hidden in the answer if the condition is true, it will thus only show in the case of a mismatch\n\ne.g., for toilets: if \"wheelchair=no\", we know there is no wheelchair dedicated room.\nFor the location of the changing table, the option \"in the wheelchair accessible toilet is weird\", so we write:\n\n{\n \"question\": \"Where is the changing table located?\"\n \"mappings\": [\n {\"if\":\"changing_table:location=female\",\"then\":\"In the female restroom\"},\n {\"if\":\"changing_table:location=male\",\"then\":\"In the male restroom\"},\n {\"if\":\"changing_table:location=wheelchair\",\"then\":\"In the wheelchair accessible restroom\", \"hideInAnswer\": \"wheelchair=no\"},\n \n ]\n}\n\nAlso have a look for the meta-tags\n{\n if: \"operator=Agentschap Natuur en Bos\",\n then: \"Maintained by Agentschap Natuur en Bos\",\n hideInAnswer: \"_country!=be\"\n}",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"boolean"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"ifnot": {
|
||||||
|
"description": "Only applicable if 'multiAnswer' is set.\nThis is for situations such as:\n`accepts:coins=no` where one can select all the possible payment methods. However, we want to make explicit that some options _were not_ selected.\nThis can be done with `ifnot`\nNote that we can not explicitly render this negative case to the user, we cannot show `does _not_ accept coins`.\nIf this is important to your usecase, consider using multiple radiobutton-fields without `multiAnswer`",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"addExtraTags": {
|
||||||
|
"description": "If chosen as answer, these tags will be applied as well onto the object.\nNot compatible with multiAnswer",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"if",
|
||||||
|
"then"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
},
|
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
|
||||||
}
|
}
|
|
@ -1,165 +1,165 @@
|
||||||
export default {
|
export default {
|
||||||
"description": "A TagRenderingConfigJson is a single piece of code which converts one ore more tags into a HTML-snippet.\nIf the desired tags are missing and a question is defined, a question will be shown instead.",
|
"description": "A TagRenderingConfigJson is a single piece of code which converts one ore more tags into a HTML-snippet.\nIf the desired tags are missing and a question is defined, a question will be shown instead.",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"id": {
|
"id": {
|
||||||
"description": "The id of the tagrendering, should be an unique string.\nUsed to keep the translations in sync. Only used in the tagRenderings-array of a layerConfig, not requered otherwise.\n\nUse 'questions' to trigger the question box of this group (if a group is defined)",
|
"description": "The id of the tagrendering, should be an unique string.\nUsed to keep the translations in sync. Only used in the tagRenderings-array of a layerConfig, not requered otherwise.\n\nUse 'questions' to trigger the question box of this group (if a group is defined)",
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"group": {
|
|
||||||
"description": "If 'group' is defined on many tagRenderings, these are grouped together when shown. The questions are grouped together as well.\nThe first tagRendering of a group will always be a sticky element.",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"render": {
|
|
||||||
"description": "Renders this value. Note that \"{key}\"-parts are substituted by the corresponding values of the element.\nIf neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value.\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`"
|
|
||||||
},
|
|
||||||
"question": {
|
|
||||||
"description": "If it turns out that this tagRendering doesn't match _any_ value, then we show this question.\nIf undefined, the question is never asked and this tagrendering is read-only"
|
|
||||||
},
|
|
||||||
"condition": {
|
|
||||||
"description": "Only show this question if the object also matches the following tags.\n\nThis is useful to ask a follow-up question. E.g. if there is a diaper table, then ask a follow-up question on diaper tables...",
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"freeform": {
|
|
||||||
"description": "Allow freeform text input from the user",
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"key": {
|
|
||||||
"description": "If this key is present, then 'render' is used to display the value.\nIf this is undefined, the rendering is _always_ shown",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"type": {
|
|
||||||
"description": "The type of the text-field, e.g. 'string', 'nat', 'float', 'date',...\nSee Docs/SpecialInputElements.md and UI/Input/ValidatedTextField.ts for supported values",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
"helperArgs": {
|
|
||||||
"description": "Extra parameters to initialize the input helper arguments.\nFor semantics, see the 'SpecialInputElements.md'",
|
|
||||||
"type": "array",
|
|
||||||
"items": {}
|
|
||||||
},
|
|
||||||
"addExtraTags": {
|
|
||||||
"description": "If a value is added with the textfield, these extra tag is addded.\nUseful to add a 'fixme=freeform textfield used - to be checked'",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"inline": {
|
"group": {
|
||||||
"description": "When set, influences the way a question is asked.\nInstead of showing a full-widht text field, the text field will be shown within the rendering of the question.\n\nThis combines badly with special input elements, as it'll distort the layout.",
|
"description": "If 'group' is defined on many tagRenderings, these are grouped together when shown. The questions are grouped together as well.\nThe first tagRendering of a group will always be a sticky element.",
|
||||||
"type": "boolean"
|
"type": "string"
|
||||||
},
|
},
|
||||||
"default": {
|
"render": {
|
||||||
"description": "default value to enter if no previous tagging is present.\nNormally undefined (aka do not enter anything)",
|
"description": "Renders this value. Note that \"{key}\"-parts are substituted by the corresponding values of the element.\nIf neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value.\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`"
|
||||||
"type": "string"
|
},
|
||||||
}
|
"question": {
|
||||||
},
|
"description": "If it turns out that this tagRendering doesn't match _any_ value, then we show this question.\nIf undefined, the question is never asked and this tagrendering is read-only"
|
||||||
"required": [
|
},
|
||||||
"key"
|
"condition": {
|
||||||
]
|
"description": "Only show this question if the object also matches the following tags.\n\nThis is useful to ask a follow-up question. E.g. if there is a diaper table, then ask a follow-up question on diaper tables...",
|
||||||
},
|
|
||||||
"multiAnswer": {
|
|
||||||
"description": "If true, use checkboxes instead of radio buttons when asking the question",
|
|
||||||
"type": "boolean"
|
|
||||||
},
|
|
||||||
"mappings": {
|
|
||||||
"description": "Allows fixed-tag inputs, shown either as radiobuttons or as checkboxes",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"if": {
|
|
||||||
"description": "If this condition is met, then the text under `then` will be shown.\nIf no value matches, and the user selects this mapping as an option, then these tags will be uploaded to OSM.\n\nFor example: {'if': 'diet:vegetarion=yes', 'then':'A vegetarian option is offered here'}\n\nThis can be an substituting-tag as well, e.g. {'if': 'addr:street:={_calculated_nearby_streetname}', 'then': '{_calculated_nearby_streetname}'}",
|
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"then": {
|
"freeform": {
|
||||||
"description": "If the condition `if` is met, the text `then` will be rendered.\nIf not known yet, the user will be presented with `then` as an option"
|
"description": "Allow freeform text input from the user",
|
||||||
},
|
"type": "object",
|
||||||
"hideInAnswer": {
|
"properties": {
|
||||||
"description": "In some cases, multiple taggings exist (e.g. a default assumption, or a commonly mapped abbreviation and a fully written variation).\n\nIn the latter case, a correct text should be shown, but only a single, canonical tagging should be selectable by the user.\nIn this case, one of the mappings can be hiden by setting this flag.\n\nTo demonstrate an example making a default assumption:\n\nmappings: [\n {\n if: \"access=\", -- no access tag present, we assume accessible\n then: \"Accessible to the general public\",\n hideInAnswer: true\n },\n {\n if: \"access=yes\",\n then: \"Accessible to the general public\", -- the user selected this, we add that to OSM\n },\n {\n if: \"access=no\",\n then: \"Not accessible to the public\"\n }\n]\n\n\nFor example, for an operator, we have `operator=Agentschap Natuur en Bos`, which is often abbreviated to `operator=ANB`.\nThen, we would add two mappings:\n{\n if: \"operator=Agentschap Natuur en Bos\" -- the non-abbreviated version which should be uploaded\n then: \"Maintained by Agentschap Natuur en Bos\"\n},\n{\n if: \"operator=ANB\", -- we don't want to upload abbreviations\n then: \"Maintained by Agentschap Natuur en Bos\"\n hideInAnswer: true\n}\n\nHide in answer can also be a tagsfilter, e.g. to make sure an option is only shown when appropriate.\nKeep in mind that this is reverse logic: it will be hidden in the answer if the condition is true, it will thus only show in the case of a mismatch\n\ne.g., for toilets: if \"wheelchair=no\", we know there is no wheelchair dedicated room.\nFor the location of the changing table, the option \"in the wheelchair accessible toilet is weird\", so we write:\n\n{\n \"question\": \"Where is the changing table located?\"\n \"mappings\": [\n {\"if\":\"changing_table:location=female\",\"then\":\"In the female restroom\"},\n {\"if\":\"changing_table:location=male\",\"then\":\"In the male restroom\"},\n {\"if\":\"changing_table:location=wheelchair\",\"then\":\"In the wheelchair accessible restroom\", \"hideInAnswer\": \"wheelchair=no\"},\n \n ]\n}\n\nAlso have a look for the meta-tags\n{\n if: \"operator=Agentschap Natuur en Bos\",\n then: \"Maintained by Agentschap Natuur en Bos\",\n hideInAnswer: \"_country!=be\"\n}",
|
"key": {
|
||||||
"anyOf": [
|
"description": "If this key is present, then 'render' is used to display the value.\nIf this is undefined, the rendering is _always_ shown",
|
||||||
{
|
"type": "string"
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
},
|
||||||
},
|
"type": {
|
||||||
{
|
"description": "The type of the text-field, e.g. 'string', 'nat', 'float', 'date',...\nSee Docs/SpecialInputElements.md and UI/Input/ValidatedTextField.ts for supported values",
|
||||||
"type": [
|
"type": "string"
|
||||||
"string",
|
},
|
||||||
"boolean"
|
"helperArgs": {
|
||||||
]
|
"description": "Extra parameters to initialize the input helper arguments.\nFor semantics, see the 'SpecialInputElements.md'",
|
||||||
}
|
"type": "array",
|
||||||
|
"items": {}
|
||||||
|
},
|
||||||
|
"addExtraTags": {
|
||||||
|
"description": "If a value is added with the textfield, these extra tag is addded.\nUseful to add a 'fixme=freeform textfield used - to be checked'",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"inline": {
|
||||||
|
"description": "When set, influences the way a question is asked.\nInstead of showing a full-widht text field, the text field will be shown within the rendering of the question.\n\nThis combines badly with special input elements, as it'll distort the layout.",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "default value to enter if no previous tagging is present.\nNormally undefined (aka do not enter anything)",
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"key"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"ifnot": {
|
"multiAnswer": {
|
||||||
"description": "Only applicable if 'multiAnswer' is set.\nThis is for situations such as:\n`accepts:coins=no` where one can select all the possible payment methods. However, we want to make explicit that some options _were not_ selected.\nThis can be done with `ifnot`\nNote that we can not explicitly render this negative case to the user, we cannot show `does _not_ accept coins`.\nIf this is important to your usecase, consider using multiple radiobutton-fields without `multiAnswer`",
|
"description": "If true, use checkboxes instead of radio buttons when asking the question",
|
||||||
"anyOf": [
|
"type": "boolean"
|
||||||
{
|
},
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"mappings": {
|
||||||
},
|
"description": "Allows fixed-tag inputs, shown either as radiobuttons or as checkboxes",
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"addExtraTags": {
|
|
||||||
"description": "If chosen as answer, these tags will be applied as well onto the object.\nNot compatible with multiAnswer",
|
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"if": {
|
||||||
|
"description": "If this condition is met, then the text under `then` will be shown.\nIf no value matches, and the user selects this mapping as an option, then these tags will be uploaded to OSM.\n\nFor example: {'if': 'diet:vegetarion=yes', 'then':'A vegetarian option is offered here'}\n\nThis can be an substituting-tag as well, e.g. {'if': 'addr:street:={_calculated_nearby_streetname}', 'then': '{_calculated_nearby_streetname}'}",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"description": "If the condition `if` is met, the text `then` will be rendered.\nIf not known yet, the user will be presented with `then` as an option"
|
||||||
|
},
|
||||||
|
"hideInAnswer": {
|
||||||
|
"description": "In some cases, multiple taggings exist (e.g. a default assumption, or a commonly mapped abbreviation and a fully written variation).\n\nIn the latter case, a correct text should be shown, but only a single, canonical tagging should be selectable by the user.\nIn this case, one of the mappings can be hiden by setting this flag.\n\nTo demonstrate an example making a default assumption:\n\nmappings: [\n {\n if: \"access=\", -- no access tag present, we assume accessible\n then: \"Accessible to the general public\",\n hideInAnswer: true\n },\n {\n if: \"access=yes\",\n then: \"Accessible to the general public\", -- the user selected this, we add that to OSM\n },\n {\n if: \"access=no\",\n then: \"Not accessible to the public\"\n }\n]\n\n\nFor example, for an operator, we have `operator=Agentschap Natuur en Bos`, which is often abbreviated to `operator=ANB`.\nThen, we would add two mappings:\n{\n if: \"operator=Agentschap Natuur en Bos\" -- the non-abbreviated version which should be uploaded\n then: \"Maintained by Agentschap Natuur en Bos\"\n},\n{\n if: \"operator=ANB\", -- we don't want to upload abbreviations\n then: \"Maintained by Agentschap Natuur en Bos\"\n hideInAnswer: true\n}\n\nHide in answer can also be a tagsfilter, e.g. to make sure an option is only shown when appropriate.\nKeep in mind that this is reverse logic: it will be hidden in the answer if the condition is true, it will thus only show in the case of a mismatch\n\ne.g., for toilets: if \"wheelchair=no\", we know there is no wheelchair dedicated room.\nFor the location of the changing table, the option \"in the wheelchair accessible toilet is weird\", so we write:\n\n{\n \"question\": \"Where is the changing table located?\"\n \"mappings\": [\n {\"if\":\"changing_table:location=female\",\"then\":\"In the female restroom\"},\n {\"if\":\"changing_table:location=male\",\"then\":\"In the male restroom\"},\n {\"if\":\"changing_table:location=wheelchair\",\"then\":\"In the wheelchair accessible restroom\", \"hideInAnswer\": \"wheelchair=no\"},\n \n ]\n}\n\nAlso have a look for the meta-tags\n{\n if: \"operator=Agentschap Natuur en Bos\",\n then: \"Maintained by Agentschap Natuur en Bos\",\n hideInAnswer: \"_country!=be\"\n}",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"boolean"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"ifnot": {
|
||||||
|
"description": "Only applicable if 'multiAnswer' is set.\nThis is for situations such as:\n`accepts:coins=no` where one can select all the possible payment methods. However, we want to make explicit that some options _were not_ selected.\nThis can be done with `ifnot`\nNote that we can not explicitly render this negative case to the user, we cannot show `does _not_ accept coins`.\nIf this is important to your usecase, consider using multiple radiobutton-fields without `multiAnswer`",
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"addExtraTags": {
|
||||||
|
"description": "If chosen as answer, these tags will be applied as well onto the object.\nNot compatible with multiAnswer",
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"if",
|
||||||
|
"then"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"if",
|
|
||||||
"then"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"or": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"definitions": {
|
||||||
},
|
"AndOrTagConfigJson": {
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"and": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"or": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
}
|
}
|
File diff suppressed because it is too large
Load diff
|
@ -1,98 +1,98 @@
|
||||||
export default {
|
export default {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"appliesToKey": {
|
"appliesToKey": {
|
||||||
"description": "Every key from this list will be normalized",
|
"description": "Every key from this list will be normalized",
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"eraseInvalidValues": {
|
|
||||||
"description": "If set, invalid values will be erased in the MC application (but not in OSM of course!)\nBe careful with setting this",
|
|
||||||
"type": "boolean"
|
|
||||||
},
|
|
||||||
"applicableUnits": {
|
|
||||||
"description": "The possible denominations",
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"$ref": "#/definitions/ApplicableUnitJson"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"applicableUnits",
|
|
||||||
"appliesToKey"
|
|
||||||
],
|
|
||||||
"definitions": {
|
|
||||||
"AndOrTagConfigJson": {
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"and": {
|
|
||||||
"type": "array",
|
|
||||||
"items": {
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"or": {
|
"eraseInvalidValues": {
|
||||||
"type": "array",
|
"description": "If set, invalid values will be erased in the MC application (but not in OSM of course!)\nBe careful with setting this",
|
||||||
"items": {
|
"type": "boolean"
|
||||||
"anyOf": [
|
},
|
||||||
{
|
"applicableUnits": {
|
||||||
"$ref": "#/definitions/AndOrTagConfigJson"
|
"description": "The possible denominations",
|
||||||
},
|
"type": "array",
|
||||||
{
|
"items": {
|
||||||
"type": "string"
|
"$ref": "#/definitions/ApplicableUnitJson"
|
||||||
}
|
}
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"ApplicableUnitJson": {
|
"required": [
|
||||||
"type": "object",
|
"applicableUnits",
|
||||||
"properties": {
|
"appliesToKey"
|
||||||
"canonicalDenomination": {
|
],
|
||||||
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
"definitions": {
|
||||||
"type": "string"
|
"AndOrTagConfigJson": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"and": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"or": {
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/definitions/AndOrTagConfigJson"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"canonicalDenominationSingular": {
|
"ApplicableUnitJson": {
|
||||||
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
"type": "object",
|
||||||
"type": "string"
|
"properties": {
|
||||||
},
|
"canonicalDenomination": {
|
||||||
"alternativeDenomination": {
|
"description": "The canonical value which will be added to the text.\ne.g. \"m\" for meters\nIf the user inputs '42', the canonical value will be added and it'll become '42m'",
|
||||||
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
"type": "string"
|
||||||
"type": "array",
|
},
|
||||||
"items": {
|
"canonicalDenominationSingular": {
|
||||||
"type": "string"
|
"description": "The canonical denomination in the case that the unit is precisely '1'",
|
||||||
}
|
"type": "string"
|
||||||
},
|
},
|
||||||
"human": {
|
"alternativeDenomination": {
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
"description": "A list of alternative values which can occur in the OSM database - used for parsing.",
|
||||||
},
|
"type": "array",
|
||||||
"humanSingular": {
|
"items": {
|
||||||
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
"type": "string"
|
||||||
},
|
}
|
||||||
"prefix": {
|
},
|
||||||
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
"human": {
|
||||||
"type": "boolean"
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"meter\",\n \"fr\": \"metre\"\n}"
|
||||||
},
|
},
|
||||||
"default": {
|
"humanSingular": {
|
||||||
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
"description": "The value for humans in the dropdown. This should not use abbreviations and should be translated, e.g.\n{\n \"en\": \"minute\",\n \"nl\": \"minuut\"x²\n}"
|
||||||
"type": "boolean"
|
},
|
||||||
|
"prefix": {
|
||||||
|
"description": "If set, then the canonical value will be prefixed instead, e.g. for '€'\nNote that if all values use 'prefix', the dropdown might move to before the text field",
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"description": "The default interpretation - only one can be set.\nIf none is set, the first unit will be considered the default interpretation of a value without a unit",
|
||||||
|
"type": "boolean"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"canonicalDenomination"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"$schema": "http://json-schema.org/draft-07/schema#"
|
||||||
"canonicalDenomination"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#"
|
|
||||||
}
|
}
|
|
@ -165,7 +165,6 @@ name | default | description
|
||||||
------ | --------- | -------------
|
------ | --------- | -------------
|
||||||
key | opening_hours | The tagkey from which the table is constructed.
|
key | opening_hours | The tagkey from which the table is constructed.
|
||||||
prefix | _empty string_ | Remove this string from the start of the value before parsing. __Note: use `&LPARENs` to
|
prefix | _empty string_ | Remove this string from the start of the value before parsing. __Note: use `&LPARENs` to
|
||||||
|
|
||||||
indicate `(` if needed__
|
indicate `(` if needed__
|
||||||
postfix | _empty string_ | Remove this string from the end of the value before parsing. __Note: use `&RPARENs` to
|
postfix | _empty string_ | Remove this string from the end of the value before parsing. __Note: use `&RPARENs` to
|
||||||
indicate `)` if needed__
|
indicate `)` if needed__
|
||||||
|
@ -493,9 +492,7 @@ tags_to_apply | _undefined_ | A specification of the tags to apply
|
||||||
message | _undefined_ | The text to show to the contributor
|
message | _undefined_ | The text to show to the contributor
|
||||||
image | _undefined_ | An image to show to the contributor on the button
|
image | _undefined_ | An image to show to the contributor on the button
|
||||||
id_of_object_to_apply_this_one | _undefined_ | If specified, applies the the tags onto _
|
id_of_object_to_apply_this_one | _undefined_ | If specified, applies the the tags onto _
|
||||||
|
another_ object. The id will be read from properties[id_of_object_to_apply_this_one] of the selected object. The tags are still calculated based on the tags of the _
|
||||||
another_ object. The id will be read from properties[id_of_object_to_apply_this_one] of the selected object. The tags
|
|
||||||
are still calculated based on the tags of the _
|
|
||||||
selected_ element
|
selected_ element
|
||||||
|
|
||||||
#### Example usage of tag_apply
|
#### Example usage of tag_apply
|
||||||
|
|
102
Docs/TagInfo/mapcomplete_bicycle_rental.json
Normal file
102
Docs/TagInfo/mapcomplete_bicycle_rental.json
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
{
|
||||||
|
"data_format": 1,
|
||||||
|
"project": {
|
||||||
|
"name": "MapComplete Bicycle rental",
|
||||||
|
"description": "A map with biyccle rental stations and bicycle rental shops",
|
||||||
|
"project_url": "https://mapcomplete.osm.be/bicycle_rental",
|
||||||
|
"doc_url": "https://github.com/pietervdvn/MapComplete/tree/master/assets/themes/",
|
||||||
|
"icon_url": "https://mapcomplete.osm.be/assets/themes/bicycle_rental/logo.svg",
|
||||||
|
"contact_name": "Pieter Vander Vennet, ",
|
||||||
|
"contact_email": "pietervdvn@posteo.net"
|
||||||
|
},
|
||||||
|
"tags": [
|
||||||
|
{
|
||||||
|
"key": "amenity",
|
||||||
|
"description": "The MapComplete theme Bicycle rental has a layer Bicycle rental showing features with this tag",
|
||||||
|
"value": "bicycle_rental"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "bicycle_rental",
|
||||||
|
"description": "The MapComplete theme Bicycle rental has a layer Bicycle rental showing features with this tag"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "service:bicycle:rental",
|
||||||
|
"description": "The MapComplete theme Bicycle rental has a layer Bicycle rental showing features with this tag",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "service:bicycle:rental",
|
||||||
|
"description": "Layer 'Bicycle rental' shows service:bicycle:rental=yes&shop=bicycle with a fixed text, namely 'This is a shop which sells or repairs bicycles, but also rents out bicycles' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "shop",
|
||||||
|
"description": "Layer 'Bicycle rental' shows service:bicycle:rental=yes&shop=bicycle with a fixed text, namely 'This is a shop which sells or repairs bicycles, but also rents out bicycles' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "bicycle"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "shop",
|
||||||
|
"description": "Layer 'Bicycle rental' shows shop=bicycle_rental&bicycle_rental=shop with a fixed text, namely 'This is a shop whose main focus is bicycle rental' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "bicycle_rental"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "bicycle_rental",
|
||||||
|
"description": "Layer 'Bicycle rental' shows shop=bicycle_rental&bicycle_rental=shop with a fixed text, namely 'This is a shop whose main focus is bicycle rental' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "shop"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "bicycle_rental",
|
||||||
|
"description": "Layer 'Bicycle rental' shows bicycle_rental=docking_station with a fixed text, namely 'This is an automated docking station, where a bicycle is mechanically locked into a structure' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "docking_station"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "bicycle_rental",
|
||||||
|
"description": "Layer 'Bicycle rental' shows bicycle_rental=key_dispensing_machine with a fixed text, namely 'A machine is present which dispenses and accepts keys, eventually after authentication and/or payment. The bicycles are parked nearby' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "key_dispensing_machine"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "bicycle_rental",
|
||||||
|
"description": "Layer 'Bicycle rental' shows bicycle_rental=dropoff_point with a fixed text, namely 'This is a dropoff point: a designated bicycle parking for this cycle rental' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "dropoff_point"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "website",
|
||||||
|
"description": "Layer 'Bicycle rental' shows and asks freeform values for key 'website' (in the MapComplete.osm.be theme 'Bicycle rental')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "contact:website",
|
||||||
|
"description": "Layer 'Bicycle rental' shows contact:website~^..*$ with a fixed text, namely '<a href='{contact:website}' target='_blank'>{contact:website}</a>' (in the MapComplete.osm.be theme 'Bicycle rental')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "email",
|
||||||
|
"description": "Layer 'Bicycle rental' shows and asks freeform values for key 'email' (in the MapComplete.osm.be theme 'Bicycle rental')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "contact:email",
|
||||||
|
"description": "Layer 'Bicycle rental' shows contact:email~^..*$ with a fixed text, namely '<a href='mailto:{contact:email}' target='_blank'>{contact:email}</a>' (in the MapComplete.osm.be theme 'Bicycle rental')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "phone",
|
||||||
|
"description": "Layer 'Bicycle rental' shows and asks freeform values for key 'phone' (in the MapComplete.osm.be theme 'Bicycle rental')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "contact:phone",
|
||||||
|
"description": "Layer 'Bicycle rental' shows contact:phone~^..*$ with a fixed text, namely '<a href='tel:{contact:phone}'>{contact:phone}</a>' (in the MapComplete.osm.be theme 'Bicycle rental')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "payment:cash",
|
||||||
|
"description": "Layer 'Bicycle rental' shows payment:cash=yes with a fixed text, namely 'Cash is accepted here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "payment:cards",
|
||||||
|
"description": "Layer 'Bicycle rental' shows payment:cards=yes with a fixed text, namely 'Payment cards are accepted here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Bicycle rental')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "id",
|
||||||
|
"description": "The MapComplete theme Bicycle rental has a layer Your track showing features with this tag",
|
||||||
|
"value": "location_track"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -144,10 +144,6 @@
|
||||||
"key": "website",
|
"key": "website",
|
||||||
"description": "Layer 'Bookcases' shows and asks freeform values for key 'website' (in the MapComplete.osm.be theme 'Open Bookcase Map')"
|
"description": "Layer 'Bookcases' shows and asks freeform values for key 'website' (in the MapComplete.osm.be theme 'Open Bookcase Map')"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"key": "id",
|
|
||||||
"description": "The MapComplete theme Open Bookcase Map has a layer Possible bookcases showing features with this tag"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"key": "id",
|
"key": "id",
|
||||||
"description": "The MapComplete theme Open Bookcase Map has a layer Your track showing features with this tag",
|
"description": "The MapComplete theme Open Bookcase Map has a layer Your track showing features with this tag",
|
||||||
|
|
|
@ -136,6 +136,20 @@
|
||||||
"key": "description",
|
"key": "description",
|
||||||
"description": "Layer 'Camper sites' shows and asks freeform values for key 'description' (in the MapComplete.osm.be theme 'Campersites')"
|
"description": "Layer 'Camper sites' shows and asks freeform values for key 'description' (in the MapComplete.osm.be theme 'Campersites')"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "operator",
|
||||||
|
"description": "Layer 'Camper sites' shows and asks freeform values for key 'operator' (in the MapComplete.osm.be theme 'Campersites')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "power_supply",
|
||||||
|
"description": "Layer 'Camper sites' shows power_supply=yes with a fixed text, namely 'This place has a power supply' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Campersites')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "power_supply",
|
||||||
|
"description": "Layer 'Camper sites' shows power_supply=no with a fixed text, namely 'This place does not have power supply' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Campersites')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "amenity",
|
"key": "amenity",
|
||||||
"description": "The MapComplete theme Campersites has a layer Sanitary dump stations showing features with this tag",
|
"description": "The MapComplete theme Campersites has a layer Sanitary dump stations showing features with this tag",
|
||||||
|
@ -225,6 +239,20 @@
|
||||||
"key": "network",
|
"key": "network",
|
||||||
"description": "Layer 'Sanitary dump stations' shows and asks freeform values for key 'network' (in the MapComplete.osm.be theme 'Campersites')"
|
"description": "Layer 'Sanitary dump stations' shows and asks freeform values for key 'network' (in the MapComplete.osm.be theme 'Campersites')"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "operator",
|
||||||
|
"description": "Layer 'Sanitary dump stations' shows and asks freeform values for key 'operator' (in the MapComplete.osm.be theme 'Campersites')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "power_supply",
|
||||||
|
"description": "Layer 'Sanitary dump stations' shows power_supply=yes with a fixed text, namely 'This place has a power supply' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Campersites')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "power_supply",
|
||||||
|
"description": "Layer 'Sanitary dump stations' shows power_supply=no with a fixed text, namely 'This place does not have power supply' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Campersites')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "id",
|
"key": "id",
|
||||||
"description": "The MapComplete theme Campersites has a layer Your track showing features with this tag",
|
"description": "The MapComplete theme Campersites has a layer Your track showing features with this tag",
|
||||||
|
|
|
@ -967,6 +967,16 @@
|
||||||
"description": "Layer 'Charging stations' shows payment:cards=yes with a fixed text, namely 'Payment cards are accepted here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Charging stations')",
|
"description": "Layer 'Charging stations' shows payment:cards=yes with a fixed text, namely 'Payment cards are accepted here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Charging stations')",
|
||||||
"value": "yes"
|
"value": "yes"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "payment:app",
|
||||||
|
"description": "Layer 'Charging stations' shows payment:app=yes with a fixed text, namely 'Payment is done using a dedicated app' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Charging stations')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "payment:membership_card",
|
||||||
|
"description": "Layer 'Charging stations' shows payment:membership_card=yes with a fixed text, namely 'Payment is done using a membership card' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Charging stations')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "authentication:membership_card",
|
"key": "authentication:membership_card",
|
||||||
"description": "Layer 'Charging stations' shows authentication:membership_card=yes with a fixed text, namely 'Authentication by a membership card' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Charging stations')",
|
"description": "Layer 'Charging stations' shows authentication:membership_card=yes with a fixed text, namely 'Authentication by a membership card' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Charging stations')",
|
||||||
|
|
|
@ -60,6 +60,126 @@
|
||||||
"key": "opening_hours",
|
"key": "opening_hours",
|
||||||
"description": "Layer 'Climbing club' shows and asks freeform values for key 'opening_hours' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
"description": "Layer 'Climbing club' shows and asks freeform values for key 'opening_hours' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "url",
|
||||||
|
"description": "Layer 'Climbing club' shows and asks freeform values for key 'url' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing club' shows access=yes with a fixed text, namely 'Publicly accessible to anyone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing club' shows access=permit with a fixed text, namely 'You need a permit to access here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "permit"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing club' shows access=customers with a fixed text, namely 'Only custumers' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "customers"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing club' shows access=members with a fixed text, namely 'Only club members' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "members"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing club' shows access=no with a fixed text, namely 'Not accessible' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access:description",
|
||||||
|
"description": "Layer 'Climbing club' shows values with key 'access:description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:length",
|
||||||
|
"description": "Layer 'Climbing club' shows and asks freeform values for key 'climbing:length' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:min",
|
||||||
|
"description": "Layer 'Climbing club' shows and asks freeform values for key 'climbing:grade:french:min' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:max",
|
||||||
|
"description": "Layer 'Climbing club' shows and asks freeform values for key 'climbing:grade:french:max' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:boulder=yes with a fixed text, namely 'Bouldering is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:boulder=no with a fixed text, namely 'Bouldering is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:boulder=limited with a fixed text, namely 'Bouldering is possible, allthough there are only a few routes' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "limited"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:boulder~^..*$ with a fixed text, namely 'There are {climbing:boulder} boulder routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:toprope=yes with a fixed text, namely 'Toprope climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:toprope=no with a fixed text, namely 'Toprope climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:toprope~^..*$ with a fixed text, namely 'There are {climbing:toprope} toprope routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:sport=yes with a fixed text, namely 'Sport climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:sport=no with a fixed text, namely 'Sport climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:sport~^..*$ with a fixed text, namely 'There are {climbing:sport} sport climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:traditional=yes with a fixed text, namely 'Traditional climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:traditional=no with a fixed text, namely 'Traditional climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:traditional~^..*$ with a fixed text, namely 'There are {climbing:traditional} traditional climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:speed=yes with a fixed text, namely 'There is a speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:speed=no with a fixed text, namely 'There is no speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing club' shows climbing:speed~^..*$ with a fixed text, namely 'There are {climbing:speed} speed climbing walls' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "sport",
|
"key": "sport",
|
||||||
"description": "The MapComplete theme Open Climbing Map has a layer Climbing gyms showing features with this tag",
|
"description": "The MapComplete theme Open Climbing Map has a layer Climbing gyms showing features with this tag",
|
||||||
|
@ -118,6 +238,126 @@
|
||||||
"key": "opening_hours",
|
"key": "opening_hours",
|
||||||
"description": "Layer 'Climbing gyms' shows and asks freeform values for key 'opening_hours' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
"description": "Layer 'Climbing gyms' shows and asks freeform values for key 'opening_hours' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "url",
|
||||||
|
"description": "Layer 'Climbing gyms' shows and asks freeform values for key 'url' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing gyms' shows access=yes with a fixed text, namely 'Publicly accessible to anyone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing gyms' shows access=permit with a fixed text, namely 'You need a permit to access here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "permit"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing gyms' shows access=customers with a fixed text, namely 'Only custumers' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "customers"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing gyms' shows access=members with a fixed text, namely 'Only club members' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "members"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing gyms' shows access=no with a fixed text, namely 'Not accessible' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access:description",
|
||||||
|
"description": "Layer 'Climbing gyms' shows values with key 'access:description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:length",
|
||||||
|
"description": "Layer 'Climbing gyms' shows and asks freeform values for key 'climbing:length' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:min",
|
||||||
|
"description": "Layer 'Climbing gyms' shows and asks freeform values for key 'climbing:grade:french:min' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:max",
|
||||||
|
"description": "Layer 'Climbing gyms' shows and asks freeform values for key 'climbing:grade:french:max' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:boulder=yes with a fixed text, namely 'Bouldering is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:boulder=no with a fixed text, namely 'Bouldering is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:boulder=limited with a fixed text, namely 'Bouldering is possible, allthough there are only a few routes' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "limited"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:boulder~^..*$ with a fixed text, namely 'There are {climbing:boulder} boulder routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:toprope=yes with a fixed text, namely 'Toprope climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:toprope=no with a fixed text, namely 'Toprope climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:toprope~^..*$ with a fixed text, namely 'There are {climbing:toprope} toprope routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:sport=yes with a fixed text, namely 'Sport climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:sport=no with a fixed text, namely 'Sport climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:sport~^..*$ with a fixed text, namely 'There are {climbing:sport} sport climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:traditional=yes with a fixed text, namely 'Traditional climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:traditional=no with a fixed text, namely 'Traditional climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:traditional~^..*$ with a fixed text, namely 'There are {climbing:traditional} traditional climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:speed=yes with a fixed text, namely 'There is a speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:speed=no with a fixed text, namely 'There is no speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing gyms' shows climbing:speed~^..*$ with a fixed text, namely 'There are {climbing:speed} speed climbing walls' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "climbing",
|
"key": "climbing",
|
||||||
"description": "The MapComplete theme Open Climbing Map has a layer Climbing routes showing features with this tag",
|
"description": "The MapComplete theme Open Climbing Map has a layer Climbing routes showing features with this tag",
|
||||||
|
@ -179,6 +419,126 @@
|
||||||
"key": "description",
|
"key": "description",
|
||||||
"description": "Layer 'Climbing routes' shows and asks freeform values for key 'description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
"description": "Layer 'Climbing routes' shows and asks freeform values for key 'description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "url",
|
||||||
|
"description": "Layer 'Climbing routes' shows and asks freeform values for key 'url' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing routes' shows access=yes with a fixed text, namely 'Publicly accessible to anyone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing routes' shows access=permit with a fixed text, namely 'You need a permit to access here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "permit"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing routes' shows access=customers with a fixed text, namely 'Only custumers' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "customers"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing routes' shows access=members with a fixed text, namely 'Only club members' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "members"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing routes' shows access=no with a fixed text, namely 'Not accessible' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access:description",
|
||||||
|
"description": "Layer 'Climbing routes' shows values with key 'access:description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:length",
|
||||||
|
"description": "Layer 'Climbing routes' shows and asks freeform values for key 'climbing:length' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:min",
|
||||||
|
"description": "Layer 'Climbing routes' shows and asks freeform values for key 'climbing:grade:french:min' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:max",
|
||||||
|
"description": "Layer 'Climbing routes' shows and asks freeform values for key 'climbing:grade:french:max' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:boulder=yes with a fixed text, namely 'Bouldering is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:boulder=no with a fixed text, namely 'Bouldering is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:boulder=limited with a fixed text, namely 'Bouldering is possible, allthough there are only a few routes' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "limited"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:boulder~^..*$ with a fixed text, namely 'There are {climbing:boulder} boulder routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:toprope=yes with a fixed text, namely 'Toprope climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:toprope=no with a fixed text, namely 'Toprope climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:toprope~^..*$ with a fixed text, namely 'There are {climbing:toprope} toprope routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:sport=yes with a fixed text, namely 'Sport climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:sport=no with a fixed text, namely 'Sport climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:sport~^..*$ with a fixed text, namely 'There are {climbing:sport} sport climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:traditional=yes with a fixed text, namely 'Traditional climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:traditional=no with a fixed text, namely 'Traditional climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:traditional~^..*$ with a fixed text, namely 'There are {climbing:traditional} traditional climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:speed=yes with a fixed text, namely 'There is a speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:speed=no with a fixed text, namely 'There is no speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing routes' shows climbing:speed~^..*$ with a fixed text, namely 'There are {climbing:speed} speed climbing walls' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "sport",
|
"key": "sport",
|
||||||
"description": "The MapComplete theme Open Climbing Map has a layer Climbing opportunities showing features with this tag",
|
"description": "The MapComplete theme Open Climbing Map has a layer Climbing opportunities showing features with this tag",
|
||||||
|
@ -238,6 +598,126 @@
|
||||||
"description": "Layer 'Climbing opportunities' shows rock=limestone with a fixed text, namely 'Limestone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
"description": "Layer 'Climbing opportunities' shows rock=limestone with a fixed text, namely 'Limestone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
"value": "limestone"
|
"value": "limestone"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "url",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows and asks freeform values for key 'url' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows access=yes with a fixed text, namely 'Publicly accessible to anyone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows access=permit with a fixed text, namely 'You need a permit to access here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "permit"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows access=customers with a fixed text, namely 'Only custumers' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "customers"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows access=members with a fixed text, namely 'Only club members' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "members"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows access=no with a fixed text, namely 'Not accessible' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access:description",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows values with key 'access:description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:length",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows and asks freeform values for key 'climbing:length' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:min",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows and asks freeform values for key 'climbing:grade:french:min' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:max",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows and asks freeform values for key 'climbing:grade:french:max' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:boulder=yes with a fixed text, namely 'Bouldering is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:boulder=no with a fixed text, namely 'Bouldering is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:boulder=limited with a fixed text, namely 'Bouldering is possible, allthough there are only a few routes' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "limited"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:boulder~^..*$ with a fixed text, namely 'There are {climbing:boulder} boulder routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:toprope=yes with a fixed text, namely 'Toprope climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:toprope=no with a fixed text, namely 'Toprope climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:toprope~^..*$ with a fixed text, namely 'There are {climbing:toprope} toprope routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:sport=yes with a fixed text, namely 'Sport climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:sport=no with a fixed text, namely 'Sport climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:sport~^..*$ with a fixed text, namely 'There are {climbing:sport} sport climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:traditional=yes with a fixed text, namely 'Traditional climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:traditional=no with a fixed text, namely 'Traditional climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:traditional~^..*$ with a fixed text, namely 'There are {climbing:traditional} traditional climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:speed=yes with a fixed text, namely 'There is a speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:speed=no with a fixed text, namely 'There is no speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing opportunities' shows climbing:speed~^..*$ with a fixed text, namely 'There are {climbing:speed} speed climbing walls' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "leisure",
|
"key": "leisure",
|
||||||
"description": "The MapComplete theme Open Climbing Map has a layer Climbing opportunities? showing features with this tag",
|
"description": "The MapComplete theme Open Climbing Map has a layer Climbing opportunities? showing features with this tag",
|
||||||
|
@ -283,6 +763,126 @@
|
||||||
"description": "Layer 'Climbing opportunities?' shows climbing=no with a fixed text, namely 'Climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
"description": "Layer 'Climbing opportunities?' shows climbing=no with a fixed text, namely 'Climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
"value": "no"
|
"value": "no"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "url",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows and asks freeform values for key 'url' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows access=yes with a fixed text, namely 'Publicly accessible to anyone' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows access=permit with a fixed text, namely 'You need a permit to access here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "permit"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows access=customers with a fixed text, namely 'Only custumers' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "customers"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows access=members with a fixed text, namely 'Only club members' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "members"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows access=no with a fixed text, namely 'Not accessible' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "access:description",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows values with key 'access:description' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:length",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows and asks freeform values for key 'climbing:length' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:min",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows and asks freeform values for key 'climbing:grade:french:min' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:grade:french:max",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows and asks freeform values for key 'climbing:grade:french:max' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:boulder=yes with a fixed text, namely 'Bouldering is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:boulder=no with a fixed text, namely 'Bouldering is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:boulder=limited with a fixed text, namely 'Bouldering is possible, allthough there are only a few routes' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "limited"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:boulder",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:boulder~^..*$ with a fixed text, namely 'There are {climbing:boulder} boulder routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:toprope=yes with a fixed text, namely 'Toprope climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:toprope=no with a fixed text, namely 'Toprope climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:toprope",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:toprope~^..*$ with a fixed text, namely 'There are {climbing:toprope} toprope routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:sport=yes with a fixed text, namely 'Sport climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:sport=no with a fixed text, namely 'Sport climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:sport",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:sport~^..*$ with a fixed text, namely 'There are {climbing:sport} sport climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:traditional=yes with a fixed text, namely 'Traditional climbing is possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:traditional=no with a fixed text, namely 'Traditional climbing is not possible here' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:traditional",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:traditional~^..*$ with a fixed text, namely 'There are {climbing:traditional} traditional climbing routes' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:speed=yes with a fixed text, namely 'There is a speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:speed=no with a fixed text, namely 'There is no speed climbing wall' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Open Climbing Map')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "climbing:speed",
|
||||||
|
"description": "Layer 'Climbing opportunities?' shows climbing:speed~^..*$ with a fixed text, namely 'There are {climbing:speed} speed climbing walls' (in the MapComplete.osm.be theme 'Open Climbing Map')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "id",
|
"key": "id",
|
||||||
"description": "The MapComplete theme Open Climbing Map has a layer Your track showing features with this tag",
|
"description": "The MapComplete theme Open Climbing Map has a layer Your track showing features with this tag",
|
||||||
|
|
|
@ -31,6 +31,65 @@
|
||||||
"key": "wikipedia",
|
"key": "wikipedia",
|
||||||
"description": "The layer 'Cyclestreets allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
"description": "The layer 'Cyclestreets allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "maxspeed",
|
||||||
|
"description": "Layer 'Cyclestreets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "30"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "overtaking:motor_vehicle",
|
||||||
|
"description": "Layer 'Cyclestreets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows cyclestreet=yes with a fixed text, namely 'This street is a cyclestreet' (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows cyclestreet=yes with a fixed text, namely 'This street is a cyclestreet' (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows proposed:cyclestreet=yes with a fixed text, namely 'This street will become a cyclstreet soon' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows proposed:cyclestreet=yes with a fixed text, namely 'This street will become a cyclstreet soon' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Cyclestreets' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "overtaking:motor_vehicle",
|
||||||
|
"description": "Layer 'Cyclestreets' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key overtaking:motor_vehicle.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet:start_date",
|
||||||
|
"description": "Layer 'Cyclestreets' shows and asks freeform values for key 'cyclestreet:start_date' (in the MapComplete.osm.be theme 'Cyclestreets')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "proposed:cyclestreet",
|
"key": "proposed:cyclestreet",
|
||||||
"description": "The MapComplete theme Cyclestreets has a layer Future cyclestreet showing features with this tag",
|
"description": "The MapComplete theme Cyclestreets has a layer Future cyclestreet showing features with this tag",
|
||||||
|
@ -52,6 +111,65 @@
|
||||||
"key": "wikipedia",
|
"key": "wikipedia",
|
||||||
"description": "The layer 'Future cyclestreet allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
"description": "The layer 'Future cyclestreet allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "maxspeed",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "30"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "overtaking:motor_vehicle",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows cyclestreet=yes with a fixed text, namely 'This street is a cyclestreet' (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows cyclestreet=yes with a fixed text, namely 'This street is a cyclestreet' (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows proposed:cyclestreet=yes with a fixed text, namely 'This street will become a cyclstreet soon' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows proposed:cyclestreet=yes with a fixed text, namely 'This street will become a cyclstreet soon' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "overtaking:motor_vehicle",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key overtaking:motor_vehicle.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet:start_date",
|
||||||
|
"description": "Layer 'Future cyclestreet' shows and asks freeform values for key 'cyclestreet:start_date' (in the MapComplete.osm.be theme 'Cyclestreets')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "highway",
|
"key": "highway",
|
||||||
"description": "The MapComplete theme Cyclestreets has a layer All streets showing features with this tag",
|
"description": "The MapComplete theme Cyclestreets has a layer All streets showing features with this tag",
|
||||||
|
@ -83,6 +201,65 @@
|
||||||
"key": "wikipedia",
|
"key": "wikipedia",
|
||||||
"description": "The layer 'All streets allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
"description": "The layer 'All streets allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "maxspeed",
|
||||||
|
"description": "Layer 'All streets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "30"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "overtaking:motor_vehicle",
|
||||||
|
"description": "Layer 'All streets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "no"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows cyclestreet=yes&maxspeed=30&overtaking:motor_vehicle=no with a fixed text, namely 'This street is a cyclestreet (and has a speed limit of 30 km/h)' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows cyclestreet=yes with a fixed text, namely 'This street is a cyclestreet' (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows cyclestreet=yes with a fixed text, namely 'This street is a cyclestreet' (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows proposed:cyclestreet=yes with a fixed text, namely 'This street will become a cyclstreet soon' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows proposed:cyclestreet=yes with a fixed text, namely 'This street will become a cyclstreet soon' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets')",
|
||||||
|
"value": "yes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "proposed:cyclestreet",
|
||||||
|
"description": "Layer 'All streets' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key proposed:cyclestreet.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "overtaking:motor_vehicle",
|
||||||
|
"description": "Layer 'All streets' shows with a fixed text, namely 'This street is not a cyclestreet' and allows to pick this as a default answer (in the MapComplete.osm.be theme 'Cyclestreets') Picking this answer will delete the key overtaking:motor_vehicle.",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "cyclestreet:start_date",
|
||||||
|
"description": "Layer 'All streets' shows and asks freeform values for key 'cyclestreet:start_date' (in the MapComplete.osm.be theme 'Cyclestreets')"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "id",
|
"key": "id",
|
||||||
"description": "The MapComplete theme Cyclestreets has a layer Your track showing features with this tag",
|
"description": "The MapComplete theme Cyclestreets has a layer Your track showing features with this tag",
|
||||||
|
|
|
@ -50,6 +50,10 @@
|
||||||
"description": "The MapComplete theme Cyclofix - an open map for cyclists has a layer Bike cafe showing features with this tag",
|
"description": "The MapComplete theme Cyclofix - an open map for cyclists has a layer Bike cafe showing features with this tag",
|
||||||
"value": "bicycle"
|
"value": "bicycle"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"key": "service:bicycle:.*",
|
||||||
|
"description": "The MapComplete theme Cyclofix - an open map for cyclists has a layer Bike cafe showing features with this tag"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"key": "image",
|
"key": "image",
|
||||||
"description": "The layer 'Bike cafe allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
"description": "The layer 'Bike cafe allows to upload images and adds them under the 'image'-tag (and image:0, image:1, ... for multiple images). Furhtermore, this layer shows images based on the keys image, wikidata, wikipedia, wikimedia_commons and mapillary"
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
"project_url": "https://mapcomplete.osm.be/postboxes",
|
"project_url": "https://mapcomplete.osm.be/postboxes",
|
||||||
"doc_url": "https://github.com/pietervdvn/MapComplete/tree/master/assets/themes/",
|
"doc_url": "https://github.com/pietervdvn/MapComplete/tree/master/assets/themes/",
|
||||||
"icon_url": "https://mapcomplete.osm.be/assets/themes/postboxes/postbox.svg",
|
"icon_url": "https://mapcomplete.osm.be/assets/themes/postboxes/postbox.svg",
|
||||||
"contact_name": "Pieter Vander Vennet, ",
|
"contact_name": "Pieter Vander Vennet, nicolelaine",
|
||||||
"contact_email": "pietervdvn@posteo.net"
|
"contact_email": "pietervdvn@posteo.net"
|
||||||
},
|
},
|
||||||
"tags": [
|
"tags": [
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "height",
|
"key": "height",
|
||||||
"description": "Layer 'Tree' shows height~^^[0-9.]+$$ with a fixed text, namely 'Height: {height} m' (in the MapComplete.osm.be theme 'Trees')"
|
"description": "Layer 'Tree' shows height~^[0-9.]+$ with a fixed text, namely 'Height: {height} m' (in the MapComplete.osm.be theme 'Trees')"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "leaf_type",
|
"key": "leaf_type",
|
||||||
|
|
1
assets/svg/nfc_card.svg
Normal file
1
assets/svg/nfc_card.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg><path transform="scale(1,-1)" path-name="ampersand" unicode="&" horiz-adv-x="713" d="M618.701 494.586c23.9375 0 43.3418 -19.4033 43.3418 -43.3408v-261.312c0 -23.9375 -19.4033 -43.3428 -43.3408 -43.3428h-220.968c-20.873 0 -38.291 14.7578 -42.4092 34.4072l-106.996 -107c-17.1162 -17.1094 -44.9492 -17.1094 -62.0654 0l-123.433 123.431c-8.55469 8.56152 -12.8311 19.7959 -12.8311 31.0322s4.27637 22.4707 12.8311 31.0322l215.638 215.629c8.29199 8.28613 19.3096 12.8467 31.0322 12.8467c11.7139 0 22.7314 -4.56152 31.0234 -12.8457l14.8281 -14.8281c4.16504 19.5908 21.5498 34.292 42.3809 34.292h220.968zM446.596 306.995c3.77539 3.76855 5.65527 8.71973 5.65527 13.6641c0 4.95117 -1.87988 9.90234 -5.65527 13.6699l-123.433 123.433c-7.53418 7.54297 -19.7959 7.54297 -27.332 0l-215.638 -215.629c-7.55078 -7.53809 -7.55078 -19.8066 0 -27.3408l123.433 -123.433c7.53613 -7.54297 19.8047 -7.54297 27.3408 -0.00878906zM486.077 280.154l16.4277 -16.4297c13.1621 16.0303 20.3193 35.9385 20.3193 56.9414c0 19.8311 -6.46875 38.6279 -18.251 54.1572l-16.4326 -16.4326c7.57227 -11.0322 11.6738 -24.0566 11.6738 -37.7246c0 -14.8447 -4.86426 -28.9111 -13.7373 -40.5117zM518.774 247.455l16.2686 -16.2686c21.7842 24.7969 33.7988 56.1846 33.7988 89.4795c0 32.1475 -11.1299 62.5615 -31.4932 86.9365l-16.3477 -16.3496c16.0625 -19.9697 24.8311 -44.5996 24.8311 -70.5869c0 -27.1514 -9.59473 -52.79 -27.0576 -73.2109zM567.735 198.493c30.4561 33.5215 47.1279 76.5605 47.126 122.172c0 44.4512 -15.877 86.4395 -44.8682 119.582l-16.373 -16.373c24.6719 -28.7627 38.2305 -64.918 38.2305 -103.209c0 -39.4434 -14.4307 -76.5918 -40.5381 -105.749z" /> </svg>
|
After Width: | Height: | Size: 1.6 KiB |
1
assets/svg/payment_card.svg
Normal file
1
assets/svg/payment_card.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 100 100" enable-background="new 0 0 100 100" xml:space="preserve"><g><path fill-rule="evenodd" clip-rule="evenodd" d="M6.64,37.198c-2.187,2.187-2.187,5.727,0,7.913L54.882,93.36 c2.186,2.186,5.736,2.186,7.923,0l1.437-1.437L8.077,35.762L6.64,37.198z"></path><path fill-rule="evenodd" clip-rule="evenodd" d="M93.36,54.878L45.117,6.64c-2.187-2.187-5.727-2.187-7.913,0L12.491,31.348 l56.165,56.16L93.36,62.801C95.547,60.613,95.547,57.064,93.36,54.878z M73.497,74.816L57.558,58.875l15.939-15.939l15.938,15.939 L73.497,74.816z"></path></g></svg>
|
After Width: | Height: | Size: 670 B |
0
assets/themes/bicycle_rental/bicycle_rental.json
Normal file
0
assets/themes/bicycle_rental/bicycle_rental.json
Normal file
Loading…
Reference in a new issue