forked from MapComplete/MapComplete
		
	Chore: housekeeping
This commit is contained in:
		
							parent
							
								
									18e3e6f806
								
							
						
					
					
						commit
						a3a7e74f56
					
				
					 94 changed files with 1273 additions and 1080 deletions
				
			
		|  | @ -42,6 +42,7 @@ Available languages: | ||||||
|   - eu |   - eu | ||||||
|   - pl |   - pl | ||||||
|   - it |   - it | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/advertising/advertising.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/advertising/advertising.json) | This document is autogenerated from [assets/themes/advertising/advertising.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/advertising/advertising.json) | ||||||
|  |  | ||||||
|  | @ -48,6 +48,7 @@ Available languages: | ||||||
|   - eu |   - eu | ||||||
|   - it |   - it | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/atm/atm.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/atm/atm.json) | This document is autogenerated from [assets/themes/atm/atm.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/atm/atm.json) | ||||||
|  |  | ||||||
|  | @ -34,6 +34,7 @@ Available languages: | ||||||
|   - ca |   - ca | ||||||
|   - fr |   - fr | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/bicycle_parkings/bicycle_parkings.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/bicycle_parkings/bicycle_parkings.json) | This document is autogenerated from [assets/themes/bicycle_parkings/bicycle_parkings.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/bicycle_parkings/bicycle_parkings.json) | ||||||
|  |  | ||||||
|  | @ -46,6 +46,7 @@ Available languages: | ||||||
|   - eu |   - eu | ||||||
|   - it |   - it | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/blind_osm/blind_osm.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/blind_osm/blind_osm.json) | This document is autogenerated from [assets/themes/blind_osm/blind_osm.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/blind_osm/blind_osm.json) | ||||||
|  |  | ||||||
|  | @ -46,6 +46,7 @@ Available languages: | ||||||
|   - cs |   - cs | ||||||
|   - eu |   - eu | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/bookcases/bookcases.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/bookcases/bookcases.json) | This document is autogenerated from [assets/themes/bookcases/bookcases.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/bookcases/bookcases.json) | ||||||
|  |  | ||||||
|  | @ -39,6 +39,7 @@ Available languages: | ||||||
|   - fr |   - fr | ||||||
|   - eu |   - eu | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/clock/clock.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/clock/clock.json) | This document is autogenerated from [assets/themes/clock/clock.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/clock/clock.json) | ||||||
|  |  | ||||||
|  | @ -36,6 +36,7 @@ Available languages: | ||||||
|   - de |   - de | ||||||
|   - es |   - es | ||||||
|   - ca |   - ca | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/disaster_response/disaster_response.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/disaster_response/disaster_response.json) | This document is autogenerated from [assets/themes/disaster_response/disaster_response.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/disaster_response/disaster_response.json) | ||||||
|  |  | ||||||
|  | @ -34,6 +34,7 @@ Available languages: | ||||||
|   - cs |   - cs | ||||||
|   - ca |   - ca | ||||||
|   - es |   - es | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/icecream/icecream.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/icecream/icecream.json) | This document is autogenerated from [assets/themes/icecream/icecream.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/icecream/icecream.json) | ||||||
|  |  | ||||||
|  | @ -31,6 +31,7 @@ Available languages: | ||||||
| 
 | 
 | ||||||
|   - en |   - en | ||||||
|   - de |   - de | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/lighthouses/lighthouses.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/lighthouses/lighthouses.json) | This document is autogenerated from [assets/themes/lighthouses/lighthouses.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/lighthouses/lighthouses.json) | ||||||
|  |  | ||||||
|  | @ -31,6 +31,7 @@ Available languages: | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   - en |   - en | ||||||
|  |   - da | ||||||
|   - de |   - de | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -38,6 +38,7 @@ Available languages: | ||||||
|   - de |   - de | ||||||
|   - fr |   - fr | ||||||
|   - nl |   - nl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/memorials/memorials.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/memorials/memorials.json) | This document is autogenerated from [assets/themes/memorials/memorials.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/memorials/memorials.json) | ||||||
|  |  | ||||||
|  | @ -44,6 +44,7 @@ Available languages: | ||||||
|   - es |   - es | ||||||
|   - cs |   - cs | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/openwindpowermap/openwindpowermap.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/openwindpowermap/openwindpowermap.json) | This document is autogenerated from [assets/themes/openwindpowermap/openwindpowermap.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/openwindpowermap/openwindpowermap.json) | ||||||
|  |  | ||||||
|  | @ -42,6 +42,8 @@ Available languages: | ||||||
|   - en |   - en | ||||||
|   - de |   - de | ||||||
|   - es |   - es | ||||||
|  |   - da | ||||||
|  |   - fr | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/ski/ski.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/ski/ski.json) | This document is autogenerated from [assets/themes/ski/ski.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/ski/ski.json) | ||||||
|  |  | ||||||
|  | @ -61,6 +61,7 @@ Available languages: | ||||||
|   - cs |   - cs | ||||||
|   - zh_Hant |   - zh_Hant | ||||||
|   - pl |   - pl | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/stations/stations.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/stations/stations.json) | This document is autogenerated from [assets/themes/stations/stations.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/stations/stations.json) | ||||||
|  |  | ||||||
|  | @ -42,6 +42,7 @@ Available languages: | ||||||
|   - es |   - es | ||||||
|   - pl |   - pl | ||||||
|   - zh_Hant |   - zh_Hant | ||||||
|  |   - da | ||||||
|   |   | ||||||
| 
 | 
 | ||||||
| This document is autogenerated from [assets/themes/vending_machine/vending_machine.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/vending_machine/vending_machine.json) | This document is autogenerated from [assets/themes/vending_machine/vending_machine.json](https://github.com/pietervdvn/MapComplete/blob/develop/assets/themes/vending_machine/vending_machine.json) | ||||||
|  |  | ||||||
|  | @ -134,7 +134,7 @@ This documentation is defined in the source code at [Locale.ts](/src/UI/i18n/Loc | ||||||
| 
 | 
 | ||||||
|  If true, 'dryrun' mode is activated and a fake user account is loaded |  If true, 'dryrun' mode is activated and a fake user account is loaded | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L33) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L37) | ||||||
| 
 | 
 | ||||||
|  The default value is _false_ |  The default value is _false_ | ||||||
| 
 | 
 | ||||||
|  | @ -145,7 +145,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/Enables logging in and thus disables editing all together. This effectively puts MapComplete into read-only mode. |  Disables/Enables logging in and thus disables editing all together. This effectively puts MapComplete into read-only mode. | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L74) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L100) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -156,7 +156,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the search bar |  Disables/Enables the search bar | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L89) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L115) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -165,9 +165,9 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
|  fs-background  |  fs-background  | ||||||
| --------------- | --------------- | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the background layer control |  Disables/Enables the background layer control where a user can enable e.g. aerial imagery | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L94) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L120) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -176,9 +176,9 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
|  fs-filter  |  fs-filter  | ||||||
| ----------- | ----------- | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the filter view |  Disables/Enables the filter view where a user can enable/disable MapComplete-layers or filter for certain properties | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L100) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L126) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -189,7 +189,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/enables the help menu or welcome message |  Disables/enables the help menu or welcome message | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L106) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L132) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -200,7 +200,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/enables the button to get in touch with the community |  Disables/enables the button to get in touch with the community | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L111) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L137) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -211,7 +211,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the extraLink button. By default, if in iframe mode and the welcome message is hidden, a popout button to the full mapcomplete instance is shown instead (unless disabled with this switch or another extraLink button is enabled) |  Disables/Enables the extraLink button. By default, if in iframe mode and the welcome message is hidden, a popout button to the full mapcomplete instance is shown instead (unless disabled with this switch or another extraLink button is enabled) | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L116) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L142) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -222,7 +222,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the various links which go back to the index page with the theme overview |  Disables/Enables the various links which go back to the index page with the theme overview | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L121) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L147) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -233,7 +233,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the 'Share-screen'-tab in the welcome message |  Disables/Enables the 'Share-screen'-tab in the welcome message | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L126) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L152) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -244,7 +244,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Disables/Enables the geolocation button |  Disables/Enables the geolocation button | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L131) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L157) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -255,7 +255,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Always show all questions |  Always show all questions | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L136) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L162) | ||||||
| 
 | 
 | ||||||
|  The default value is _false_ |  The default value is _false_ | ||||||
| 
 | 
 | ||||||
|  | @ -266,7 +266,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Enable the export as GeoJSON and CSV button |  Enable the export as GeoJSON and CSV button | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L142) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L168) | ||||||
| 
 | 
 | ||||||
|  The default value is _true_ |  The default value is _true_ | ||||||
| 
 | 
 | ||||||
|  | @ -277,7 +277,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  If true, 'dryrun' mode is activated. The app will behave as normal, except that changes to OSM will be printed onto the console instead of actually uploaded to osm.org |  If true, 'dryrun' mode is activated. The app will behave as normal, except that changes to OSM will be printed onto the console instead of actually uploaded to osm.org | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L156) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L182) | ||||||
| 
 | 
 | ||||||
|  The default value is _false_ |  The default value is _false_ | ||||||
| 
 | 
 | ||||||
|  | @ -288,7 +288,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  If true, shows some extra debugging help such as all the available tags on every object |  If true, shows some extra debugging help such as all the available tags on every object | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L162) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L188) | ||||||
| 
 | 
 | ||||||
|  The default value is _false_ |  The default value is _false_ | ||||||
| 
 | 
 | ||||||
|  | @ -299,7 +299,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  If true, the location distance indication will not be written to the changeset and other privacy enhancing measures might be taken. |  If true, the location distance indication will not be written to the changeset and other privacy enhancing measures might be taken. | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L168) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L194) | ||||||
| 
 | 
 | ||||||
|  The default value is _false_ |  The default value is _false_ | ||||||
| 
 | 
 | ||||||
|  | @ -310,7 +310,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Point mapcomplete to a different overpass-instance. Example: https://overpass-api.de/api/interpreter |  Point mapcomplete to a different overpass-instance. Example: https://overpass-api.de/api/interpreter | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L174) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L200) | ||||||
| 
 | 
 | ||||||
|  The default value is _https://overpass-api.de/api/interpreter,https://overpass.kumi.systems/api/interpreter,https://overpass.openstreetmap.ru/cgi/interpreter_ |  The default value is _https://overpass-api.de/api/interpreter,https://overpass.kumi.systems/api/interpreter,https://overpass.openstreetmap.ru/cgi/interpreter_ | ||||||
| 
 | 
 | ||||||
|  | @ -321,7 +321,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Set a different timeout (in seconds) for queries in overpass |  Set a different timeout (in seconds) for queries in overpass | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L185) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L211) | ||||||
| 
 | 
 | ||||||
|  The default value is _30_ |  The default value is _30_ | ||||||
| 
 | 
 | ||||||
|  | @ -332,7 +332,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|   point to switch between OSM-api and overpass |   point to switch between OSM-api and overpass | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L193) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L219) | ||||||
| 
 | 
 | ||||||
|  The default value is _16_ |  The default value is _16_ | ||||||
| 
 | 
 | ||||||
|  | @ -343,7 +343,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  Tilesize when the OSM-API is used to fetch data within a BBOX |  Tilesize when the OSM-API is used to fetch data within a BBOX | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L201) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L227) | ||||||
| 
 | 
 | ||||||
|  The default value is _17_ |  The default value is _17_ | ||||||
| 
 | 
 | ||||||
|  | @ -354,7 +354,7 @@ This documentation is defined in the source code at [FeatureSwitchState.ts](/src | ||||||
| 
 | 
 | ||||||
|  The id of the background layer to start with |  The id of the background layer to start with | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L208) | This documentation is defined in the source code at [FeatureSwitchState.ts](/src/Logic/State/FeatureSwitchState.ts#L234) | ||||||
| 
 | 
 | ||||||
|  No default value set |  No default value set | ||||||
| 
 | 
 | ||||||
|  | @ -398,7 +398,7 @@ This documentation is defined in the source code at [InitialMapPositioning.ts](/ | ||||||
| 
 | 
 | ||||||
|  Used to complete the login |  Used to complete the login | ||||||
| 
 | 
 | ||||||
| This documentation is defined in the source code at [ThemeViewState.ts](/src/Models/ThemeViewState.ts#L175) | This documentation is defined in the source code at [ThemeViewState.ts](/src/Models/ThemeViewState.ts#L168) | ||||||
| 
 | 
 | ||||||
|  No default value set |  No default value set | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -130,7 +130,7 @@ | ||||||
| {{service_item | {{service_item | ||||||
| |name= [https://mapcomplete.org/atm atm] | |name= [https://mapcomplete.org/atm atm] | ||||||
| |region= Worldwide | |region= Worldwide | ||||||
| |lang= {{#language:en|en}}, {{#language:de|en}}, {{#language:fr|en}}, {{#language:nl|en}}, {{#language:ca|en}}, {{#language:cs|en}}, {{#language:nb_NO|en}}, {{#language:es|en}}, {{#language:id|en}}, {{#language:zh_Hant|en}}, {{#language:eu|en}}, {{#language:it|en}}, {{#language:pl|en}} | |lang= {{#language:en|en}}, {{#language:de|en}}, {{#language:fr|en}}, {{#language:nl|en}}, {{#language:ca|en}}, {{#language:cs|en}}, {{#language:nb_NO|en}}, {{#language:es|en}}, {{#language:id|en}}, {{#language:zh_Hant|en}}, {{#language:eu|en}}, {{#language:it|en}}, {{#language:pl|en}}, {{#language:da|en}} | ||||||
| |descr= A MapComplete theme: This map shows ATMs to withdraw or deposit money | |descr= A MapComplete theme: This map shows ATMs to withdraw or deposit money | ||||||
| |material= {{yes|[https://mapcomplete.org/ Yes]}} | |material= {{yes|[https://mapcomplete.org/ Yes]}} | ||||||
| |image= MapComplete_Screenshot.png | |image= MapComplete_Screenshot.png | ||||||
|  | @ -220,7 +220,7 @@ | ||||||
| {{service_item | {{service_item | ||||||
| |name= [https://mapcomplete.org/clock clock] | |name= [https://mapcomplete.org/clock clock] | ||||||
| |region= Worldwide | |region= Worldwide | ||||||
| |lang= {{#language:en|en}}, {{#language:nl|en}}, {{#language:ca|en}}, {{#language:de|en}}, {{#language:es|en}}, {{#language:cs|en}}, {{#language:fr|en}}, {{#language:pl|en}} | |lang= {{#language:en|en}}, {{#language:nl|en}}, {{#language:ca|en}}, {{#language:de|en}}, {{#language:es|en}}, {{#language:cs|en}}, {{#language:fr|en}}, {{#language:pl|en}}, {{#language:da|en}} | ||||||
| |descr= A MapComplete theme: Map showing all public clocks | |descr= A MapComplete theme: Map showing all public clocks | ||||||
| |material= {{yes|[https://mapcomplete.org/ Yes]}} | |material= {{yes|[https://mapcomplete.org/ Yes]}} | ||||||
| |image= MapComplete_Screenshot.png | |image= MapComplete_Screenshot.png | ||||||
|  |  | ||||||
|  | @ -367,7 +367,7 @@ | ||||||
|             "nl": "Dit is een <b>nachtclub</b> met dansvloer, DJ met bijhorende lichteffecten en bar waar men (alcoholische) dranken kan nuttigen", |             "nl": "Dit is een <b>nachtclub</b> met dansvloer, DJ met bijhorende lichteffecten en bar waar men (alcoholische) dranken kan nuttigen", | ||||||
|             "de": "Dies ist ein <b>Club</b> oder eine Disco mit Fokus auf Tanzen, Musik von einem DJ mit begleitender Lichtshow und einer Bar, an der man (alkoholische) Getränke bekommt", |             "de": "Dies ist ein <b>Club</b> oder eine Disco mit Fokus auf Tanzen, Musik von einem DJ mit begleitender Lichtshow und einer Bar, an der man (alkoholische) Getränke bekommt", | ||||||
|             "es": "Este es un <b>club nocturno</b> o discoteca centrado en bailar, música de un DJ con un espectáculo de luces que la acompaña y un bar donde conseguir bebidas (alcohólicas)", |             "es": "Este es un <b>club nocturno</b> o discoteca centrado en bailar, música de un DJ con un espectáculo de luces que la acompaña y un bar donde conseguir bebidas (alcohólicas)", | ||||||
|             "fr": "C'est une <b>boîte de nuit</b> ou discothèque orientée danse, la musique d'un DJ avec un spectacle de lumière et un bar pour prendre des boissons (alcoolisées)", |             "fr": "Une <b>boîte de nuit</b> ou discothèque orientée danse, la musique d'un DJ avec un spectacle de lumière et un bar pour prendre des boissons (alcoolisées)", | ||||||
|             "da": "Dette er en <b>natklub</b> eller diskotek med fokus på dans, musik af en DJ med tilhørende lysshow og en bar, hvor man kan købe (alkoholiske) drikkevarer", |             "da": "Dette er en <b>natklub</b> eller diskotek med fokus på dans, musik af en DJ med tilhørende lysshow og en bar, hvor man kan købe (alkoholiske) drikkevarer", | ||||||
|             "ca": "Açò és un <b>club nocturn</b> o discoteca centrat en ballar, música d'un DJ acompanyat d'un espectacle de llums i una barra on obtindre begudes (alcohòliques)", |             "ca": "Açò és un <b>club nocturn</b> o discoteca centrat en ballar, música d'un DJ acompanyat d'un espectacle de llums i una barra on obtindre begudes (alcohòliques)", | ||||||
|             "cs": "Jedná se o <b>noční klub</b> nebo diskotéku se zaměřením na tanec, hudbu DJ s doprovodnou světelnou show a bar, kde si můžete dát (alkoholické) nápoje" |             "cs": "Jedná se o <b>noční klub</b> nebo diskotéku se zaměřením na tanec, hudbu DJ s doprovodnou světelnou show a bar, kde si můžete dát (alkoholické) nápoje" | ||||||
|  |  | ||||||
|  | @ -6,7 +6,8 @@ | ||||||
|     "de": "Objekte mit Namensherkunft", |     "de": "Objekte mit Namensherkunft", | ||||||
|     "fr": "A une étymologie", |     "fr": "A une étymologie", | ||||||
|     "ca": "Té etimologia", |     "ca": "Té etimologia", | ||||||
|     "cs": "Má etymologii" |     "cs": "Má etymologii", | ||||||
|  |     "da": "Har etymologi" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "All objects which have an etymology known", |     "en": "All objects which have an etymology known", | ||||||
|  | @ -15,7 +16,8 @@ | ||||||
|     "hu": "Minden olyan objektum, amelynél ismert a nevének az eredete", |     "hu": "Minden olyan objektum, amelynél ismert a nevének az eredete", | ||||||
|     "fr": "Tous les objets dont l’étymologie est connue", |     "fr": "Tous les objets dont l’étymologie est connue", | ||||||
|     "ca": "Tots els objectes que tenen una etimologia coneguda", |     "ca": "Tots els objectes que tenen una etimologia coneguda", | ||||||
|     "cs": "Všechny objekty, které mají známou etymologii" |     "cs": "Všechny objekty, které mají známou etymologii", | ||||||
|  |     "da": "Alle objekter med kendt etymologi" | ||||||
|   }, |   }, | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": { |     "osmTags": { | ||||||
|  | @ -113,7 +115,8 @@ | ||||||
|         "nl": "Wat is het Wikidata-item van hetgeen dit object is naar vernoemd?", |         "nl": "Wat is het Wikidata-item van hetgeen dit object is naar vernoemd?", | ||||||
|         "de": "Was ist das Wikidata-Element, nach dem dieses Objekt benannt ist?", |         "de": "Was ist das Wikidata-Element, nach dem dieses Objekt benannt ist?", | ||||||
|         "fr": "Quel est l'Item Wikidata auquel l'objet fait référence ?", |         "fr": "Quel est l'Item Wikidata auquel l'objet fait référence ?", | ||||||
|         "cs": "Po jaké položce Wikidat je tento objekt pojmenován?" |         "cs": "Po jaké položce Wikidat je tento objekt pojmenován?", | ||||||
|  |         "da": "Hvilket Wikidata-emne er dette objekt opkaldt efter?" | ||||||
|       }, |       }, | ||||||
|       "freeform": { |       "freeform": { | ||||||
|         "key": "name:etymology:wikidata", |         "key": "name:etymology:wikidata", | ||||||
|  | @ -248,7 +251,8 @@ | ||||||
|         "de": "<h3>Wikipedia Artikel zur Namensherkunft</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", |         "de": "<h3>Wikipedia Artikel zur Namensherkunft</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", | ||||||
|         "fr": "<h3>Article Wikipedia de la référence au nom</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", |         "fr": "<h3>Article Wikipedia de la référence au nom</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", | ||||||
|         "ca": "<h3> Article de la Viquipèdia del nom donant</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", |         "ca": "<h3> Article de la Viquipèdia del nom donant</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", | ||||||
|         "cs": "<h3>Článek autora jména na Wikipedii</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}" |         "cs": "<h3>Článek autora jména na Wikipedii</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}", | ||||||
|  |         "da": "<h3>Wikipedia-artikel om navnets ophav</h3>{wikipedia(name:etymology:wikidata):max-height:20rem}" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -270,7 +274,8 @@ | ||||||
|         "de": "Wonach ist dieses Objekt benannt?", |         "de": "Wonach ist dieses Objekt benannt?", | ||||||
|         "fr": "En référence à quoi cet objet est-il nommé ?", |         "fr": "En référence à quoi cet objet est-il nommé ?", | ||||||
|         "pl": "Po czym nazwany jest ten obiekt?", |         "pl": "Po czym nazwany jest ten obiekt?", | ||||||
|         "cs": "Po čem je tento objekt pojmenován?" |         "cs": "Po čem je tento objekt pojmenován?", | ||||||
|  |         "da": "Hvad er dette objekt opkaldt efter?" | ||||||
|       }, |       }, | ||||||
|       "render": { |       "render": { | ||||||
|         "en": "Named after {name:etymology}", |         "en": "Named after {name:etymology}", | ||||||
|  | @ -322,7 +327,8 @@ | ||||||
|         "de": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Bild eines Straßenschildes hinzufügen)}", |         "de": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Bild eines Straßenschildes hinzufügen)}", | ||||||
|         "fr": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Ajouter une photo de la plaque de rue)}", |         "fr": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Ajouter une photo de la plaque de rue)}", | ||||||
|         "ca": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Afegeix una imatge de la placa amb el nom del carrer)}", |         "ca": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Afegeix una imatge de la placa amb el nom del carrer)}", | ||||||
|         "cs": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Add image of a street name sign)}" |         "cs": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Add image of a street name sign)}", | ||||||
|  |         "da": "{image_carousel(image:streetsign)}<br/>{image_upload(image:streetsign, Tilføj foto af gadenavneskilt)}" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -339,7 +345,8 @@ | ||||||
|         "de": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Automatische Datenübernahme auf alle Segmente mit demselben Namen, true)}", |         "de": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Automatische Datenübernahme auf alle Segmente mit demselben Namen, true)}", | ||||||
|         "fr": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Appliquer automatiquement aux segments avec le même nom, true)}", |         "fr": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Appliquer automatiquement aux segments avec le même nom, true)}", | ||||||
|         "ca": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etimology, aplicació automàtica de dades a tots els segments amb el mateix nom, vertader)}", |         "ca": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etimology, aplicació automàtica de dades a tots els segments amb el mateix nom, vertader)}", | ||||||
|         "cs": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Auto-applying data on all segments with the same name, true)}" |         "cs": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Auto-applying data on all segments with the same name, true)}", | ||||||
|  |         "da": "{multi_apply(_same_name_ids, name:etymology:wikidata;name:etymology, Tilføjer automatisk til alle segmenter med samme navn, true)}" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -352,7 +359,8 @@ | ||||||
|         "fr": "Un article Wikipédia à propos de cette <b>rue</b> existe :<br/>{wikipedia():max-height:25rem}", |         "fr": "Un article Wikipédia à propos de cette <b>rue</b> existe :<br/>{wikipedia():max-height:25rem}", | ||||||
|         "pl": "Istnieje artykuł Wikipedii na temat tej <b>ulicy</b>:<br/>{wikipedia():max-height:25rem}", |         "pl": "Istnieje artykuł Wikipedii na temat tej <b>ulicy</b>:<br/>{wikipedia():max-height:25rem}", | ||||||
|         "ca": "Existeix un article de la Viquipèdia sobre aquest <b>carrer</b>:<br/>{wikipedia():max-height:25rem}", |         "ca": "Existeix un article de la Viquipèdia sobre aquest <b>carrer</b>:<br/>{wikipedia():max-height:25rem}", | ||||||
|         "cs": "Článek na Wikipedii o této <b>ulici</b> existuje:<br/>{wikipedia():max-height:25rem}" |         "cs": "Článek na Wikipedii o této <b>ulici</b> existuje:<br/>{wikipedia():max-height:25rem}", | ||||||
|  |         "da": "Der findes en Wikipedia-artikel om denne <b>gade</b>:<br/>{wikipedia():max-height:25rem}" | ||||||
|       }, |       }, | ||||||
|       "condition": "wikidata~*" |       "condition": "wikidata~*" | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -288,7 +288,8 @@ | ||||||
|             "en": "Open on openstreetmap.org", |             "en": "Open on openstreetmap.org", | ||||||
|             "nl": "Bekijk op openstreetmap.org", |             "nl": "Bekijk op openstreetmap.org", | ||||||
|             "de": "Auf openstreetmap.org öffnen", |             "de": "Auf openstreetmap.org öffnen", | ||||||
|             "pl": "Otwórz na openstreetmap.org" |             "pl": "Otwórz na openstreetmap.org", | ||||||
|  |             "da": "Åbn på openstreetmap.org" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|  | @ -310,7 +311,8 @@ | ||||||
|                 "en": "Open on openstreetmap.org", |                 "en": "Open on openstreetmap.org", | ||||||
|                 "nl": "Bekijk op openstreetmap.org", |                 "nl": "Bekijk op openstreetmap.org", | ||||||
|                 "de": "Auf openstreetmap.org öffnen", |                 "de": "Auf openstreetmap.org öffnen", | ||||||
|                 "pl": "Otwórz na openstreetmap.org" |                 "pl": "Otwórz na openstreetmap.org", | ||||||
|  |                 "da": "Åbn på openstreetmap.org" | ||||||
|               } |               } | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|  |  | ||||||
|  | @ -55,7 +55,8 @@ | ||||||
|       "ariaLabel": { |       "ariaLabel": { | ||||||
|         "en": "See on OpenStreetMap.org", |         "en": "See on OpenStreetMap.org", | ||||||
|         "nl": "Bekijk op OpenStreetMap.org", |         "nl": "Bekijk op OpenStreetMap.org", | ||||||
|         "de": "Auf OpenStreetMap.org ansehen" |         "de": "Auf OpenStreetMap.org ansehen", | ||||||
|  |         "da": "Se på OpenStreetMap.org" | ||||||
|       }, |       }, | ||||||
|       "render": "<a href='https://openstreetmap.org/note/{id}' target='_blank'><img src='./assets/svg/osm-logo-us.svg'></a>" |       "render": "<a href='https://openstreetmap.org/note/{id}' target='_blank'><img src='./assets/svg/osm-logo-us.svg'></a>" | ||||||
|     } |     } | ||||||
|  | @ -251,7 +252,8 @@ | ||||||
|             "de": "Zuletzt bearbeitet von {search}", |             "de": "Zuletzt bearbeitet von {search}", | ||||||
|             "es": "Editada por última vez por el contributor {search}", |             "es": "Editada por última vez por el contributor {search}", | ||||||
|             "ca": "Editat per última vega pel contribuïdor {search}", |             "ca": "Editat per última vega pel contribuïdor {search}", | ||||||
|             "cs": "Naposledy upravil přispěvatel {search}" |             "cs": "Naposledy upravil přispěvatel {search}", | ||||||
|  |             "da": "Senest redigeret af bidragsyder {search}" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  |  | ||||||
|  | @ -277,7 +277,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "The surface is tartan - a synthetic, springy surface typically seen on athletic pistes", |             "en": "The surface is tartan - a synthetic, springy surface typically seen on athletic pistes", | ||||||
|             "nl": "De ondergrond bestaat uit Tartan - een synthetisch, elastisch en poreus materiaal dat je ook vindt op atletiekpistes", |             "nl": "De ondergrond bestaat uit Tartan - een synthetisch, elastisch en poreus materiaal dat je ook vindt op atletiekpistes", | ||||||
|             "de": "Der Belag ist aus Tartan - ein synthetischer, federnder Belag, der typischerweise auf Sportbahnen zu finden ist" |             "de": "Der Belag ist aus Tartan - ein synthetischer, federnder Belag, der typischerweise auf Sportbahnen zu finden ist", | ||||||
|  |             "fr": "La surface est en tartan - un revêtement synthétique typiquement utilisé sur les pistes d'athlétisme" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -285,7 +286,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "The surface is made from rubber, such as rubber tiles, rubber mulch or a big rubber area", |             "en": "The surface is made from rubber, such as rubber tiles, rubber mulch or a big rubber area", | ||||||
|             "nl": "De ondergrond bestaat uit rubber, zoals rubberen tegels, rubber snippers of een groot rubberen oppervlak", |             "nl": "De ondergrond bestaat uit rubber, zoals rubberen tegels, rubber snippers of een groot rubberen oppervlak", | ||||||
|             "de": "Die Oberfläche besteht aus Gummi, z. B. aus Gummifliesen, Gummimulch oder einer großen Gummifläche" |             "de": "Die Oberfläche besteht aus Gummi, z. B. aus Gummifliesen, Gummimulch oder einer großen Gummifläche", | ||||||
|  |             "fr": "La surface est en caoutchouc, comme des dalles de caoutchouc, des copeaux de caoutchouc ou une grande surface en caoutchouc" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ], |       ], | ||||||
|  |  | ||||||
|  | @ -2691,7 +2691,8 @@ | ||||||
|           "en": "Scan this code to open this location on another device", |           "en": "Scan this code to open this location on another device", | ||||||
|           "nl": "Scan deze code om deze locatie op een ander apparaat te zien", |           "nl": "Scan deze code om deze locatie op een ander apparaat te zien", | ||||||
|           "de": "Scannen Sie den Code, um diesen Ort auf einem anderen Gerät zu öffnen", |           "de": "Scannen Sie den Code, um diesen Ort auf einem anderen Gerät zu öffnen", | ||||||
|           "sl": "Skenirajte to kodo, da odprete ta kraj na drugi napravi" |           "sl": "Skenirajte to kodo, da odprete ta kraj na drugi napravi", | ||||||
|  |           "da": "Skan denne kode for at åbne dette sted på en anden enhed" | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  | @ -2724,7 +2725,8 @@ | ||||||
|             "nl": "Laatst gewijzigd op {_last_edit:timestamp} door {_last_edit:contributor} ", |             "nl": "Laatst gewijzigd op {_last_edit:timestamp} door {_last_edit:contributor} ", | ||||||
|             "de": "Zuletzt bearbeitet am {_last_edit:timestamp} von {_last_edit:contributor}", |             "de": "Zuletzt bearbeitet am {_last_edit:timestamp} von {_last_edit:contributor}", | ||||||
|             "ca": "Darrera edició el {_last_edit:timestamp} per {_last_edit:contributor}", |             "ca": "Darrera edició el {_last_edit:timestamp} per {_last_edit:contributor}", | ||||||
|             "cs": "Naposledy upravil {_last_edit:timestamp} {_last_edit:contributor}" |             "cs": "Naposledy upravil {_last_edit:timestamp} {_last_edit:contributor}", | ||||||
|  |             "da": "Senest redigeret {_last_edit:timestamp} af {_last_edit:contributor}" | ||||||
|           }, |           }, | ||||||
|           "class": "subtle font-small" |           "class": "subtle font-small" | ||||||
|         } |         } | ||||||
|  | @ -2746,7 +2748,8 @@ | ||||||
|           "type": "if_nothing_known", |           "type": "if_nothing_known", | ||||||
|           "text": { |           "text": { | ||||||
|             "en": "Nothing is known about this place. Help by filling out the questions", |             "en": "Nothing is known about this place. Help by filling out the questions", | ||||||
|             "nl": "Er is nog niets geweten. Help mee door de vragen te beantwoorden" |             "nl": "Er is nog niets geweten. Help mee door de vragen te beantwoorden", | ||||||
|  |             "de": "Über diesen Ort ist nichts bekannt. Hilf mit, indem du die Fragen ausfüllst" | ||||||
|           }, |           }, | ||||||
|           "cssClasses": "subtle m-4 italic flex items-center justify-center" |           "cssClasses": "subtle m-4 italic flex items-center justify-center" | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -2,11 +2,13 @@ | ||||||
|   "id": "ski_piste", |   "id": "ski_piste", | ||||||
|   "name": { |   "name": { | ||||||
|     "en": "Ski and snowboard pistes", |     "en": "Ski and snowboard pistes", | ||||||
|     "de": "Ski- und Snowboardpisten" |     "de": "Ski- und Snowboardpisten", | ||||||
|  |     "fr": "Pistes de ski et de snowboard" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Ski and snowboard pistes", |     "en": "Ski and snowboard pistes", | ||||||
|     "de": "Ski- und Snowboardpisten" |     "de": "Ski- und Snowboardpisten", | ||||||
|  |     "fr": "Pistes de ski et de snowboard" | ||||||
|   }, |   }, | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": { |     "osmTags": { | ||||||
|  | @ -25,7 +27,8 @@ | ||||||
|   "title": { |   "title": { | ||||||
|     "render": { |     "render": { | ||||||
|       "en": "Ski piste {name}", |       "en": "Ski piste {name}", | ||||||
|       "de": "Skipiste {name}" |       "de": "Skipiste {name}", | ||||||
|  |       "fr": "Piste de ski {name}" | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "pointRendering": [ |   "pointRendering": [ | ||||||
|  | @ -80,7 +83,8 @@ | ||||||
|     { |     { | ||||||
|       "question": { |       "question": { | ||||||
|         "en": "What is the difficulty of this piste?", |         "en": "What is the difficulty of this piste?", | ||||||
|         "de": "Was ist der Schwierigkeitsgrad der Piste?" |         "de": "Was ist der Schwierigkeitsgrad der Piste?", | ||||||
|  |         "fr": "Quelle est la difficulté de cette piste ?" | ||||||
|       }, |       }, | ||||||
|       "id": "piste_difficulty", |       "id": "piste_difficulty", | ||||||
|       "condition": "piste:type!=connection", |       "condition": "piste:type!=connection", | ||||||
|  | @ -89,42 +93,48 @@ | ||||||
|           "if": "piste:difficulty=novice", |           "if": "piste:difficulty=novice", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Novice (green)", |             "en": "Novice (green)", | ||||||
|             "de": "Anfänger (grün)" |             "de": "Anfänger (grün)", | ||||||
|  |             "fr": "Débutant (vert)" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "piste:difficulty=easy", |           "if": "piste:difficulty=easy", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Easy (blue)", |             "en": "Easy (blue)", | ||||||
|             "de": "Einfach (blau)" |             "de": "Einfach (blau)", | ||||||
|  |             "fr": "Facile (bleu)" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "piste:difficulty=intermediate", |           "if": "piste:difficulty=intermediate", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Intermediate (red)", |             "en": "Intermediate (red)", | ||||||
|             "de": "Mittel (rot)" |             "de": "Mittel (rot)", | ||||||
|  |             "fr": "Intermédiaire (rouge)" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "piste:difficulty=advanced", |           "if": "piste:difficulty=advanced", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Advanced (black)", |             "en": "Advanced (black)", | ||||||
|             "de": "Fortgeschritten (schwarz)" |             "de": "Fortgeschritten (schwarz)", | ||||||
|  |             "fr": "Avancé (noir)" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "piste:difficulty=expert", |           "if": "piste:difficulty=expert", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Expert (orange/double black)", |             "en": "Expert (orange/double black)", | ||||||
|             "de": "Experte (orange/doppel schwarz)" |             "de": "Experte (orange/doppel schwarz)", | ||||||
|  |             "fr": "Expert (orange/double noir)" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "piste:difficulty=freeride", |           "if": "piste:difficulty=freeride", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Freeride", |             "en": "Freeride", | ||||||
|             "de": "Freeride" |             "de": "Freeride", | ||||||
|  |             "fr": "Hors piste" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  | @ -133,7 +143,8 @@ | ||||||
|       "id": "length", |       "id": "length", | ||||||
|       "render": { |       "render": { | ||||||
|         "en": "This part of the ski piste is {_length:km} kilometer long", |         "en": "This part of the ski piste is {_length:km} kilometer long", | ||||||
|         "de": "Dieser Teil der Skipiste hat eine Länge von {_length:km} km" |         "de": "Dieser Teil der Skipiste hat eine Länge von {_length:km} km", | ||||||
|  |         "fr": "Ce tronçon de piste de ski mesure {_length:km} kilomètres de long" | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|  | @ -3,13 +3,15 @@ | ||||||
|   "name": { |   "name": { | ||||||
|     "en": "Paths, carfree and slow roads", |     "en": "Paths, carfree and slow roads", | ||||||
|     "nl": "Paadjes, trage wegen en autoluwe straten", |     "nl": "Paadjes, trage wegen en autoluwe straten", | ||||||
|     "de": "Pfade, autofreie und geschwindigkeitsreduzierte Straßen" |     "de": "Pfade, autofreie und geschwindigkeitsreduzierte Straßen", | ||||||
|  |     "fr": "Chemins, routes non carrossables et routes à vitesse réduite" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "All carfree roads", |     "en": "All carfree roads", | ||||||
|     "nl": "Alle verkeersvrije wegen", |     "nl": "Alle verkeersvrije wegen", | ||||||
|     "de": "Alle autofreien Straßen", |     "de": "Alle autofreien Straßen", | ||||||
|     "ca": "Totes les carreteres sense cotxe" |     "ca": "Totes les carreteres sense cotxe", | ||||||
|  |     "fr": "Toutes les routes non carrossables" | ||||||
|   }, |   }, | ||||||
|   "source": { |   "source": { | ||||||
|     "osmTags": { |     "osmTags": { | ||||||
|  | @ -115,7 +117,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "This is a living street", |             "en": "This is a living street", | ||||||
|             "nl": "<div> Dit is een woonerf: <ul><li>Voetgangers mogen hier de volledige breedte van de straat gebruiken</li><li>Gemotoriseerd verkeer mag maximaal <b>20km/h</b> rijden</li></ul></div>", |             "nl": "<div> Dit is een woonerf: <ul><li>Voetgangers mogen hier de volledige breedte van de straat gebruiken</li><li>Gemotoriseerd verkeer mag maximaal <b>20km/h</b> rijden</li></ul></div>", | ||||||
|             "de": "Dies ist eine Wohnstraße" |             "de": "Dies ist eine Wohnstraße", | ||||||
|  |             "fr": "C'est une zone de rencontre" | ||||||
|           }, |           }, | ||||||
|           "icon": { |           "icon": { | ||||||
|             "path": "./assets/layers/slow_roads/woonerf.svg", |             "path": "./assets/layers/slow_roads/woonerf.svg", | ||||||
|  | @ -135,7 +138,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "This is a footway", |             "en": "This is a footway", | ||||||
|             "nl": "Dit is een voetpaadje", |             "nl": "Dit is een voetpaadje", | ||||||
|             "de": "Dies ist ein Fußweg" |             "de": "Dies ist ein Fußweg", | ||||||
|  |             "fr": "C'est un chemin piéton" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -143,7 +147,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "This is a small path", |             "en": "This is a small path", | ||||||
|             "nl": "Dit is een wegeltje of bospad", |             "nl": "Dit is een wegeltje of bospad", | ||||||
|             "de": "Dies ist ein schmaler Pfad" |             "de": "Dies ist ein schmaler Pfad", | ||||||
|  |             "fr": "C'est un petit sentier" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -151,7 +156,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "This is a bridleway", |             "en": "This is a bridleway", | ||||||
|             "nl": "Dit is een ruiterswegel", |             "nl": "Dit is een ruiterswegel", | ||||||
|             "de": "Dies ist ein Reitweg" |             "de": "Dies ist ein Reitweg", | ||||||
|  |             "fr": "C'est une voie équestre" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -307,7 +313,8 @@ | ||||||
|       "question": { |       "question": { | ||||||
|         "en": "Is this road lit at night?", |         "en": "Is this road lit at night?", | ||||||
|         "nl": "Is deze weg 's nachts verlicht?", |         "nl": "Is deze weg 's nachts verlicht?", | ||||||
|         "de": "Ist diese Straße nachts beleuchtet?" |         "de": "Ist diese Straße nachts beleuchtet?", | ||||||
|  |         "fr": "Cette route est-elle éclairée la nuit ?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|  |  | ||||||
|  | @ -177,7 +177,7 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Public access", |             "en": "Public access", | ||||||
|             "de": "Der Zugang ist öffentlich", |             "de": "Der Zugang ist öffentlich", | ||||||
|             "fr": "Accès publique", |             "fr": "Accès public", | ||||||
|             "nl": "Publiek toegankelijk", |             "nl": "Publiek toegankelijk", | ||||||
|             "it": "Accesso pubblico", |             "it": "Accesso pubblico", | ||||||
|             "ru": "Свободный доступ", |             "ru": "Свободный доступ", | ||||||
|  | @ -603,7 +603,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Free menstrual products are available to all visitors of these toilets", |             "en": "Free menstrual products are available to all visitors of these toilets", | ||||||
|             "nl": "Er zijn gratis menstruatieprocten beschikbaar voor alle bezoekers van deze toiletten", |             "nl": "Er zijn gratis menstruatieprocten beschikbaar voor alle bezoekers van deze toiletten", | ||||||
|             "de": "Für alle Besucher dieser Toiletten stehen kostenlose Menstruationsprodukte zur Verfügung" |             "de": "Für alle Besucher dieser Toiletten stehen kostenlose Menstruationsprodukte zur Verfügung", | ||||||
|  |             "fr": "Protections menstruelles gratuites disponibles dans ces toilettes, pour tout le monde" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -611,7 +612,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Free menstrual products are available to some visitors of these toilets", |             "en": "Free menstrual products are available to some visitors of these toilets", | ||||||
|             "nl": "De gratis menstruatieproducten zijn enkel beschikbaar in een deel van de toiletten", |             "nl": "De gratis menstruatieproducten zijn enkel beschikbaar in een deel van de toiletten", | ||||||
|             "de": "Für einige Besucher dieser Toiletten gibt es kostenlose Menstruationsprodukte" |             "de": "Für einige Besucher dieser Toiletten gibt es kostenlose Menstruationsprodukte", | ||||||
|  |             "fr": "Protections menstruelles gratuites disponibles dans ces toilettes, réservées à certains visiteurs" | ||||||
|           }, |           }, | ||||||
|           "hideInAnswer": "gender_segregated=yes" |           "hideInAnswer": "gender_segregated=yes" | ||||||
|         }, |         }, | ||||||
|  | @ -621,7 +623,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "No free menstrual products are available here", |             "en": "No free menstrual products are available here", | ||||||
|             "nl": "Er zijn geen gratis menstruatieproducten beschikbaar", |             "nl": "Er zijn geen gratis menstruatieproducten beschikbaar", | ||||||
|             "de": "Hier gibt es keine kostenlosen Menstruationsprodukte" |             "de": "Hier gibt es keine kostenlosen Menstruationsprodukte", | ||||||
|  |             "fr": "Pas protection menstruelle disponible ici" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  |  | ||||||
|  | @ -53,7 +53,8 @@ | ||||||
|             "de": "Die Sprache wurde über einen URL-Parameter gesetzt und kann nicht vom Benutzer eingestellt werden.", |             "de": "Die Sprache wurde über einen URL-Parameter gesetzt und kann nicht vom Benutzer eingestellt werden.", | ||||||
|             "ca": "L'idioma es va establir mitjançant un paràmetre d'URL i l'usuari no pot definir-lo.", |             "ca": "L'idioma es va establir mitjançant un paràmetre d'URL i l'usuari no pot definir-lo.", | ||||||
|             "cs": "Jazyk byl nastaven pomocí parametru URL a uživatel jej nemůže nastavit.²", |             "cs": "Jazyk byl nastaven pomocí parametru URL a uživatel jej nemůže nastavit.²", | ||||||
|             "nl": "De taal werd ingesteld via een URL-parameter en kan niet manueel ingesteld worden." |             "nl": "De taal werd ingesteld via een URL-parameter en kan niet manueel ingesteld worden.", | ||||||
|  |             "da": "Sproget er angivet vha. en URL-parameter og kan ikke angives af brugeren." | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  | @ -72,7 +73,8 @@ | ||||||
|                 "nl": "Ga naar je inbox", |                 "nl": "Ga naar je inbox", | ||||||
|                 "de": "Deinen Posteingang öffnen", |                 "de": "Deinen Posteingang öffnen", | ||||||
|                 "ca": "Obre la teva safata d'entrada", |                 "ca": "Obre la teva safata d'entrada", | ||||||
|                 "cs": "Otevřít schránku" |                 "cs": "Otevřít schránku", | ||||||
|  |                 "da": "Åbn din indbakke" | ||||||
|               } |               } | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|  | @ -87,7 +89,8 @@ | ||||||
|                 "de": "<b class='alert'>Sie haben {_unreadMessages} Nachrichten</b><br/>Posteingang öffnen", |                 "de": "<b class='alert'>Sie haben {_unreadMessages} Nachrichten</b><br/>Posteingang öffnen", | ||||||
|                 "ca": "<b class='alert'>Tens {_unreadMessages} missatges </b><br/>Obri la safata d'entrada", |                 "ca": "<b class='alert'>Tens {_unreadMessages} missatges </b><br/>Obri la safata d'entrada", | ||||||
|                 "cs": "<b class='alert'>Máte {_unreadMessages}</b><br/>Otevřít schránku", |                 "cs": "<b class='alert'>Máte {_unreadMessages}</b><br/>Otevřít schránku", | ||||||
|                 "nl": "<b class='alert'>Je hebt {_unreadMessages} ongelezen berichten</b><br/>Ga naar je inbox" |                 "nl": "<b class='alert'>Je hebt {_unreadMessages} ongelezen berichten</b><br/>Ga naar je inbox", | ||||||
|  |                 "da": "<b class='alert'>Du har {_unreadMessages} beskeder</b><br/>Åbn din indbakke" | ||||||
|               }, |               }, | ||||||
|               "href": "{_backend}/messages/inbox" |               "href": "{_backend}/messages/inbox" | ||||||
|             } |             } | ||||||
|  | @ -105,7 +108,8 @@ | ||||||
|             "de": "Öffne Deine Einstellungen auf OpenStreetMap.org", |             "de": "Öffne Deine Einstellungen auf OpenStreetMap.org", | ||||||
|             "ca": "Obriu la vostra configuració a OpenStreetMap.org", |             "ca": "Obriu la vostra configuració a OpenStreetMap.org", | ||||||
|             "cs": "Otevřít vaše nastavení na OpenStreetMap.org", |             "cs": "Otevřít vaše nastavení na OpenStreetMap.org", | ||||||
|             "nl": "Open je instellingen op OpenStreetMap.org" |             "nl": "Open je instellingen op OpenStreetMap.org", | ||||||
|  |             "da": "Åbn dine indstillinger på OpenStreetMap.org" | ||||||
|           }, |           }, | ||||||
|           "href": "{_backend}/account/edit" |           "href": "{_backend}/account/edit" | ||||||
|         } |         } | ||||||
|  | @ -122,7 +126,8 @@ | ||||||
|       "question": { |       "question": { | ||||||
|         "en": "What accessibility features should be applied?", |         "en": "What accessibility features should be applied?", | ||||||
|         "nl": "Wanneer moet de toegankelijkheidsmode ingeschakeld worden?", |         "nl": "Wanneer moet de toegankelijkheidsmode ingeschakeld worden?", | ||||||
|         "de": "Welche Barrierefrei-Funktionen sollen angewendet werden?" |         "de": "Welche Barrierefrei-Funktionen sollen angewendet werden?", | ||||||
|  |         "da": "Hvilke tilgængelighedsfunktioner skal anvendes?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|  | @ -132,7 +137,8 @@ | ||||||
|             "en": "Enable accessibility features when arrow keys are used to navigate the map", |             "en": "Enable accessibility features when arrow keys are used to navigate the map", | ||||||
|             "ca": "Activar les funcions d'accessibilitat quan s'utilitzen les tecles de fletxa per navegar pel mapa", |             "ca": "Activar les funcions d'accessibilitat quan s'utilitzen les tecles de fletxa per navegar pel mapa", | ||||||
|             "nl": "Schakel toegankelijkheidsmode aan wanneer op de pijltjestoetsen wordt geduwd om de kaart te bewegen", |             "nl": "Schakel toegankelijkheidsmode aan wanneer op de pijltjestoetsen wordt geduwd om de kaart te bewegen", | ||||||
|             "de": "Barrierefrei-Modus aktivieren, wenn Pfeiltasten zum Navigieren in der Karte verwendet werden" |             "de": "Barrierefrei-Modus aktivieren, wenn Pfeiltasten zum Navigieren in der Karte verwendet werden", | ||||||
|  |             "da": "Aktiver tilgængelighedsfunktioner, når piletaster anvendes til at navigere i kortet" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -141,7 +147,8 @@ | ||||||
|             "en": "Always enable accessibility features", |             "en": "Always enable accessibility features", | ||||||
|             "ca": "Sempre habilita les característiques d'accessibilitat", |             "ca": "Sempre habilita les característiques d'accessibilitat", | ||||||
|             "nl": "Schakel de toegankelijkheidsmode altijd aan", |             "nl": "Schakel de toegankelijkheidsmode altijd aan", | ||||||
|             "de": "Barrierefrei-Modus immer aktivieren" |             "de": "Barrierefrei-Modus immer aktivieren", | ||||||
|  |             "da": "Aktiver altid tilgængelighedsfunktioner" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -149,7 +156,8 @@ | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Never enable accessibility features", |             "en": "Never enable accessibility features", | ||||||
|             "nl": "Gebruik geen toegankelijkheidsmode", |             "nl": "Gebruik geen toegankelijkheidsmode", | ||||||
|             "de": "Barrierefrei-Modus niemals aktivieren" |             "de": "Barrierefrei-Modus niemals aktivieren", | ||||||
|  |             "da": "Aktiver aldrig tilgængelighedsfunktioner" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  | @ -168,7 +176,8 @@ | ||||||
|         "ca": "Aquest mapa temàtic té un conjunt de capes de fons predefinides. La configuració predeterminada del tema no s'aplica", |         "ca": "Aquest mapa temàtic té un conjunt de capes de fons predefinides. La configuració predeterminada del tema no s'aplica", | ||||||
|         "de": "Diese thematische Karte hat einen vordefinierten Hintergrund. Ihr Standardhintergrund wird nicht angewendet", |         "de": "Diese thematische Karte hat einen vordefinierten Hintergrund. Ihr Standardhintergrund wird nicht angewendet", | ||||||
|         "cs": "Tato tematická mapa má předdefinovanou sadu podkladových vrstev. Vaše výchozí nastavení tématu se nepoužije", |         "cs": "Tato tematická mapa má předdefinovanou sadu podkladových vrstev. Vaše výchozí nastavení tématu se nepoužije", | ||||||
|         "nl": "Deze kaart heeft een achtegrondlaag instgesteld. Je instellingen worden niet gebruikt" |         "nl": "Deze kaart heeft een achtegrondlaag instgesteld. Je instellingen worden niet gebruikt", | ||||||
|  |         "da": "Dette temakort har angivet et foruddefineret baggrundslag. Dine standardindstillinger benyttes ikke" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -179,7 +188,8 @@ | ||||||
|         "de": "Welche Hintergrundebene soll als Standard verwendet werden?", |         "de": "Welche Hintergrundebene soll als Standard verwendet werden?", | ||||||
|         "cs": "Jaká vrstva pozadí by se měla zobrazovat ve výchozím nastavení?", |         "cs": "Jaká vrstva pozadí by se měla zobrazovat ve výchozím nastavení?", | ||||||
|         "nl": "Welke achtergrondlaag moet altijd gebruikt worden?", |         "nl": "Welke achtergrondlaag moet altijd gebruikt worden?", | ||||||
|         "fr": "Quel fond souhaitez-vous utiliser par défaut ?" |         "fr": "Quel fond souhaitez-vous utiliser par défaut ?", | ||||||
|  |         "da": "Hvilket baggrundslag skal vises som standard?" | ||||||
|       }, |       }, | ||||||
|       "condition": "_theme:backgroundLayer=", |       "condition": "_theme:backgroundLayer=", | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|  | @ -192,7 +202,8 @@ | ||||||
|             "de": "Standardhintergrund verwenden", |             "de": "Standardhintergrund verwenden", | ||||||
|             "cs": "Použití výchozí vrstvu pozadí", |             "cs": "Použití výchozí vrstvu pozadí", | ||||||
|             "nl": "Gebruik de standaard achtergrondlaag", |             "nl": "Gebruik de standaard achtergrondlaag", | ||||||
|             "fr": "Utiliser le fond par défaut" |             "fr": "Utiliser le fond par défaut", | ||||||
|  |             "da": "Vis standardbaggrundslaget" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -203,7 +214,8 @@ | ||||||
|             "de": "OpenStreetMap-carto als Standardhintergrund verwenden", |             "de": "OpenStreetMap-carto als Standardhintergrund verwenden", | ||||||
|             "cs": "Použít OpenStreetMap-carto jako výchozí vrstvu", |             "cs": "Použít OpenStreetMap-carto jako výchozí vrstvu", | ||||||
|             "nl": "Gebruik OpenStreetMap-carto altijd als achtergrondlaag", |             "nl": "Gebruik OpenStreetMap-carto altijd als achtergrondlaag", | ||||||
|             "fr": "Utiliser le fond OpenStreetMap-carto par défaut" |             "fr": "Utiliser le fond OpenStreetMap-carto par défaut", | ||||||
|  |             "da": "Brug OpenStreetMap-carto som standardlag" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -214,7 +226,8 @@ | ||||||
|             "de": "Satellitenbilder als Standardhintergrund verwenden", |             "de": "Satellitenbilder als Standardhintergrund verwenden", | ||||||
|             "cs": "Použít letecké snímky jako výchozí pozadí", |             "cs": "Použít letecké snímky jako výchozí pozadí", | ||||||
|             "nl": "Gebruik luchtfoto's als standaard achtergrondlaag", |             "nl": "Gebruik luchtfoto's als standaard achtergrondlaag", | ||||||
|             "fr": "Utiliser le fond imagerie aérienne par défaut" |             "fr": "Utiliser le fond imagerie aérienne par défaut", | ||||||
|  |             "da": "Brug luftfoto som standardbaggrund" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -225,7 +238,8 @@ | ||||||
|             "de": "Eine eigene Karte als Standardhintergrund verwenden", |             "de": "Eine eigene Karte als Standardhintergrund verwenden", | ||||||
|             "cs": "Použití mapy, která není založena na mapě openstreetmap, jako výchozího pozadí", |             "cs": "Použití mapy, která není založena na mapě openstreetmap, jako výchozího pozadí", | ||||||
|             "nl": "Gebruik altijd een kaart di niet op OpenStreetMap gebaseerd is als achtergrond", |             "nl": "Gebruik altijd een kaart di niet op OpenStreetMap gebaseerd is als achtergrond", | ||||||
|             "fr": "Utiliser un fond non basé sur OpenStreetMap par défaut" |             "fr": "Utiliser un fond non basé sur OpenStreetMap par défaut", | ||||||
|  |             "da": "Brug et ikke-OpenSreetMap-baseret kort som standardbaggrund" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -236,7 +250,8 @@ | ||||||
|             "de": "Aktuelle Hintergrundebene (<span class='code'>{__current_background}</span>) als Standardhintergrund verwenden", |             "de": "Aktuelle Hintergrundebene (<span class='code'>{__current_background}</span>) als Standardhintergrund verwenden", | ||||||
|             "cs": "Použít aktuální vrstvu pozadí (<span class='code'>{__current_background}</span>) jako výchozí pozadí", |             "cs": "Použít aktuální vrstvu pozadí (<span class='code'>{__current_background}</span>) jako výchozí pozadí", | ||||||
|             "nl": "Gebruik altijd <span class='code'>{__current_background}</span> als achtergrondlaag. Dit is de huidige achtergrond.", |             "nl": "Gebruik altijd <span class='code'>{__current_background}</span> als achtergrondlaag. Dit is de huidige achtergrond.", | ||||||
|             "fr": "Utiliser le fond actuel (<span class='code'>{__current_background}</span>) par défaut" |             "fr": "Utiliser le fond actuel (<span class='code'>{__current_background}</span>) par défaut", | ||||||
|  |             "da": "Brug det nuværende baggrundslag (<span class='code'>{__current_background}</span>) som standardbaggrund" | ||||||
|           }, |           }, | ||||||
|           "hideInAnswer": { |           "hideInAnswer": { | ||||||
|             "or": [ |             "or": [ | ||||||
|  | @ -254,7 +269,8 @@ | ||||||
|             "de": "Hintergrundebene <span class='code'>{mapcomplete-preferred-background-layer}</span> als Standardhintergrund verwenden", |             "de": "Hintergrundebene <span class='code'>{mapcomplete-preferred-background-layer}</span> als Standardhintergrund verwenden", | ||||||
|             "cs": "Použít vrstvu pozadí <span class='code'>{mapcomplete-preferred-background-layer}</span> jako výchozí pozadí", |             "cs": "Použít vrstvu pozadí <span class='code'>{mapcomplete-preferred-background-layer}</span> jako výchozí pozadí", | ||||||
|             "nl": "Gebruik <span class='code'>{mapcomplete-preferred-background-layer}</span> altijd als achtergrondlaag", |             "nl": "Gebruik <span class='code'>{mapcomplete-preferred-background-layer}</span> altijd als achtergrondlaag", | ||||||
|             "fr": "Utiliser le fond (<span class='code'>{mapcomplete-preferred-background-layer}</span>)par défaut" |             "fr": "Utiliser le fond (<span class='code'>{mapcomplete-preferred-background-layer}</span>)par défaut", | ||||||
|  |             "da": "Brug baggrundslaget <span class='code'>{mapcomplete-preferred-background-layer}</span> som standardbaggrund" | ||||||
|           }, |           }, | ||||||
|           "hideInAnswer": true |           "hideInAnswer": true | ||||||
|         } |         } | ||||||
|  | @ -269,7 +285,8 @@ | ||||||
|         "nl": "Met welke licentie wil je je afbeeldingen toevoegen?", |         "nl": "Met welke licentie wil je je afbeeldingen toevoegen?", | ||||||
|         "ca": "Sota quina llicència vols publicar les teves fotos?", |         "ca": "Sota quina llicència vols publicar les teves fotos?", | ||||||
|         "pt": "Sob que licença você deseja publicar suas fotos?", |         "pt": "Sob que licença você deseja publicar suas fotos?", | ||||||
|         "cs": "Pod jakou licencí chcete své fotografie zveřejnit?" |         "cs": "Pod jakou licencí chcete své fotografie zveřejnit?", | ||||||
|  |         "da": "Under hvilken licens vil du frigive dine billeder?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|  | @ -402,7 +419,8 @@ | ||||||
|         "pt": "As perguntas para campos de dados desconhecidos devem aparecer uma a uma ou juntas?", |         "pt": "As perguntas para campos de dados desconhecidos devem aparecer uma a uma ou juntas?", | ||||||
|         "ca": "Les preguntes amb camps de dades desconeguts haurien d'aparèixer una per una o juntes?", |         "ca": "Les preguntes amb camps de dades desconeguts haurien d'aparèixer una per una o juntes?", | ||||||
|         "nl": "Moeten onbeantwoorde vragen om beurt of allemaal samen getoond worden?", |         "nl": "Moeten onbeantwoorde vragen om beurt of allemaal samen getoond worden?", | ||||||
|         "cs": "Mají se otázky pro neznámá datová pole zobrazovat jednotlivě, nebo společně?" |         "cs": "Mají se otázky pro neznámá datová pole zobrazovat jednotlivě, nebo společně?", | ||||||
|  |         "da": "Skal spørgsmål for ukendte oplysninger vises ét ad gangen eller alle på én gang?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|  | @ -414,7 +432,8 @@ | ||||||
|             "fr": "Afficher toutes les question en même temps dans l'infobox", |             "fr": "Afficher toutes les question en même temps dans l'infobox", | ||||||
|             "pt": "Mostrar todas as perguntas na caixa de informações juntas", |             "pt": "Mostrar todas as perguntas na caixa de informações juntas", | ||||||
|             "nl": "Toon alle onbeantwoorde vragen", |             "nl": "Toon alle onbeantwoorde vragen", | ||||||
|             "cs": "Zobrazit všechny otázky v infoboxu dohromady" |             "cs": "Zobrazit všechny otázky v infoboxu dohromady", | ||||||
|  |             "da": "Vis alle spørgsmål i infoboksen på én gang" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|  | @ -426,7 +445,8 @@ | ||||||
|             "fr": "Afficher les questions une à une", |             "fr": "Afficher les questions une à une", | ||||||
|             "pt": "Mostrar perguntas uma a uma", |             "pt": "Mostrar perguntas uma a uma", | ||||||
|             "nl": "Toon de vragen één per één", |             "nl": "Toon de vragen één per één", | ||||||
|             "cs": "Zobrazit otázky jednu po druhé" |             "cs": "Zobrazit otázky jednu po druhé", | ||||||
|  |             "da": "Vis spørgsmål ét ad gangen" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  | @ -469,37 +489,43 @@ | ||||||
|     { |     { | ||||||
|       "id": "add-new-feature", |       "id": "add-new-feature", | ||||||
|       "question": { |       "question": { | ||||||
|         "en": "How should the menu to add a new feature be opened?" |         "en": "How should the menu to add a new feature be opened?", | ||||||
|  |         "de": "Wie soll das Menü zum Hinzufügen eines neuen Objekts geöffnet werden?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|           "if": "mapcomplete-preferences-add-new-mode=button", |           "if": "mapcomplete-preferences-add-new-mode=button", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "Adding a new feature is done with the button at the bottom left. Clicking the map does nothing" |             "en": "Adding a new feature is done with the button at the bottom left. Clicking the map does nothing", | ||||||
|  |             "de": "Das Hinzufügen eines neuen Objekts erfolgt über die Schaltfläche unten links. Ein Klick auf die Karte bewirkt nichts" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "mapcomplete-preferences-add-new-mode=click", |           "if": "mapcomplete-preferences-add-new-mode=click", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "When clicking or tapping the map, a marker pops up where a new feature is added" |             "en": "When clicking or tapping the map, a marker pops up where a new feature is added", | ||||||
|  |             "de": "Wenn Sie auf die Karte klicken oder tippen, wird eine Markierung eingeblendet, an der ein neues Objekt hinzugefügt wird" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "mapcomplete-preferences-add-new-mode=click_right", |           "if": "mapcomplete-preferences-add-new-mode=click_right", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "When right-clicking or long-pressing the map, a marker pops up where a new feature can be added" |             "en": "When right-clicking or long-pressing the map, a marker pops up where a new feature can be added", | ||||||
|  |             "de": "Beim Rechtsklick oder einem langen Druck auf die Karte erscheint eine Markierung, mit der ein neues Objekt hinzugefügt werden kann" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "mapcomplete-preferences-add-new-mode=button_click", |           "if": "mapcomplete-preferences-add-new-mode=button_click", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "When clicking or tapping the map, a marker pops up where a new feature can be added. Additionally, a button at the bottom left is shown" |             "en": "When clicking or tapping the map, a marker pops up where a new feature can be added. Additionally, a button at the bottom left is shown", | ||||||
|  |             "de": "Beim Klicken oder Tippen auf die Karte wird eine Markierung eingeblendet, an der ein neues Objekt hinzugefügt werden kann. Zusätzlich wird unten links eine Schaltfläche angezeigt" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|           "if": "mapcomplete-preferences-add-new-mode=button_click_right", |           "if": "mapcomplete-preferences-add-new-mode=button_click_right", | ||||||
|           "then": { |           "then": { | ||||||
|             "en": "When right-clicking or long-pressing the map, a marker pops up where a new feature can be added. Additionally, a button at the bottom left is shown" |             "en": "When right-clicking or long-pressing the map, a marker pops up where a new feature can be added. Additionally, a button at the bottom left is shown", | ||||||
|  |             "de": "Beim Rechtsklick oder einem langen Druck auf die Karte erscheint eine Markierung, an der ein neues Objekt hinzugefügt werden kann. Zusätzlich wird unten links eine Schaltfläche angezeigt" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  | @ -511,7 +537,8 @@ | ||||||
|         "de": "Soll Norden immer oben sein?", |         "de": "Soll Norden immer oben sein?", | ||||||
|         "ca": "El nord hauria d'estar sempre amunt?", |         "ca": "El nord hauria d'estar sempre amunt?", | ||||||
|         "cs": "Měl by být sever vždy nahoře?", |         "cs": "Měl by být sever vždy nahoře?", | ||||||
|         "nl": "Moet het noorden altijd naar boven getoond worden?" |         "nl": "Moet het noorden altijd naar boven getoond worden?", | ||||||
|  |         "da": "Skal nord altid pege opad?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|  | @ -536,7 +563,8 @@ | ||||||
|             "fr": "Toujours garder le nord en haut", |             "fr": "Toujours garder le nord en haut", | ||||||
|             "ca": "Mantingueu sempre el nord apuntant cap amunt", |             "ca": "Mantingueu sempre el nord apuntant cap amunt", | ||||||
|             "cs": "Sever vždy směřujte nahoru", |             "cs": "Sever vždy směřujte nahoru", | ||||||
|             "nl": "Hou het noorden altijd naar boven" |             "nl": "Hou het noorden altijd naar boven", | ||||||
|  |             "da": "Nord peger altid opad" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       ] |       ] | ||||||
|  | @ -623,13 +651,15 @@ | ||||||
|           "text": { |           "text": { | ||||||
|             "en": "Import a mangrove private key from backup", |             "en": "Import a mangrove private key from backup", | ||||||
|             "nl": "Herstel een Mangrove Private sleutel van backup", |             "nl": "Herstel een Mangrove Private sleutel van backup", | ||||||
|             "de": "Privaten Mangrove-Schlüssel aus Backup importieren" |             "de": "Privaten Mangrove-Schlüssel aus Backup importieren", | ||||||
|  |             "da": "Indlæs en privat Mangrove-nøgle fra backup" | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "after": { |         "after": { | ||||||
|           "en": "Uploading a private key erases your current private key. If you made reviews with it, download your current private key first", |           "en": "Uploading a private key erases your current private key. If you made reviews with it, download your current private key first", | ||||||
|           "de": "Wenn du einen privaten Schlüssel hochlädst, wird dein aktueller privater Schlüssel gelöscht. Wenn du damit Rezensionen geschrieben hast, lade zuerst deinen aktuellen privaten Schlüssel hoch", |           "de": "Wenn du einen privaten Schlüssel hochlädst, wird dein aktueller privater Schlüssel gelöscht. Wenn du damit Rezensionen geschrieben hast, lade zuerst deinen aktuellen privaten Schlüssel hoch", | ||||||
|           "nl": "Een private sleutel uploaden overschrijft je huidige private sleutel. Indien je beoordelingen maakte met je huidige private sleutel, download deze dan eerst" |           "nl": "Een private sleutel uploaden overschrijft je huidige private sleutel. Indien je beoordelingen maakte met je huidige private sleutel, download deze dan eerst", | ||||||
|  |           "da": "Når du uploader en privat nøgle, slettes din nuværende private nøgle. Hvis du har brugt den til at lave anmeldelser, kan du downloade din private nøgle først" | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  | @ -652,7 +682,8 @@ | ||||||
|         "ca": "Vols ajudar a traduir MapComplete?", |         "ca": "Vols ajudar a traduir MapComplete?", | ||||||
|         "fr": "Voulez-vous aider à traduire MapComplete ?", |         "fr": "Voulez-vous aider à traduire MapComplete ?", | ||||||
|         "pt": "Quer ajudar na tradução do MapComplete?", |         "pt": "Quer ajudar na tradução do MapComplete?", | ||||||
|         "nl": "Wil je MapComplete helpen vertalen?" |         "nl": "Wil je MapComplete helpen vertalen?", | ||||||
|  |         "da": "Vil du hjælpe med at oversætte MapComplete?" | ||||||
|       }, |       }, | ||||||
|       "mappings": [ |       "mappings": [ | ||||||
|         { |         { | ||||||
|  | @ -862,7 +893,8 @@ | ||||||
|             "de": "Sie haben Code zu MapComplete mit {_code_contributions} Commits beigetragen! Das ist großartig!", |             "de": "Sie haben Code zu MapComplete mit {_code_contributions} Commits beigetragen! Das ist großartig!", | ||||||
|             "nl": "Je hebt mee geprogrammeerd aan MapComplete met {_code_contributions} commits! Das supercool van je! Bedankt hiervoor!", |             "nl": "Je hebt mee geprogrammeerd aan MapComplete met {_code_contributions} commits! Das supercool van je! Bedankt hiervoor!", | ||||||
|             "ca": "Heu aportat codi a MapComplete amb {_code_contributions} commits! Això és increïble!", |             "ca": "Heu aportat codi a MapComplete amb {_code_contributions} commits! Això és increïble!", | ||||||
|             "cs": "Přispěli jste do MapComplete kódem s {_code_contributions} revizemi! To je úžasné!" |             "cs": "Přispěli jste do MapComplete kódem s {_code_contributions} revizemi! To je úžasné!", | ||||||
|  |             "da": "Du har bidraget kode til MapComplete med {_code_contributions} commits! Det er fantastisk!" | ||||||
|           }, |           }, | ||||||
|           "icon": "party", |           "icon": "party", | ||||||
|           "hideInAnswer": true |           "hideInAnswer": true | ||||||
|  |  | ||||||
|  | @ -11,7 +11,8 @@ | ||||||
|     "zh_Hant": "廣告物件", |     "zh_Hant": "廣告物件", | ||||||
|     "eu": "Publizitatea", |     "eu": "Publizitatea", | ||||||
|     "pl": "Reklamy", |     "pl": "Reklamy", | ||||||
|     "it": "Pubblicità" |     "it": "Pubblicità", | ||||||
|  |     "da": "Reklamer" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "ca": "Alguna vegada t'has preguntat quanta publictat hi ha als nostres carrers i carreteres? Amb aquest mapa podràs trobar i afegir informació de tots els elements publictaris que t'hi trobes pel carrer", |     "ca": "Alguna vegada t'has preguntat quanta publictat hi ha als nostres carrers i carreteres? Amb aquest mapa podràs trobar i afegir informació de tots els elements publictaris que t'hi trobes pel carrer", | ||||||
|  |  | ||||||
|  | @ -20,7 +20,7 @@ | ||||||
|     "sl": "Defibrilatorji", |     "sl": "Defibrilatorji", | ||||||
|     "zh_Hans": "Open AED Map", |     "zh_Hans": "Open AED Map", | ||||||
|     "fil": "Open AED Map", |     "fil": "Open AED Map", | ||||||
|     "da": "Åben AED Kort", |     "da": "Hjertestartere", | ||||||
|     "cs": "Defibrilátory", |     "cs": "Defibrilátory", | ||||||
|     "zgh": "ⴽⵛⵎ ⵖⵔ ⵜⴽⴰⵕⴹⴰ ⵏ AED", |     "zgh": "ⴽⵛⵎ ⵖⵔ ⵜⴽⴰⵕⴹⴰ ⵏ AED", | ||||||
|     "eu": "Desfibriladoreak" |     "eu": "Desfibriladoreak" | ||||||
|  |  | ||||||
|  | @ -17,7 +17,7 @@ | ||||||
|     "ca": "Obra d'art", |     "ca": "Obra d'art", | ||||||
|     "zh_Hans": "Open Artwork Map", |     "zh_Hans": "Open Artwork Map", | ||||||
|     "fil": "Open Artwork Map", |     "fil": "Open Artwork Map", | ||||||
|     "da": "Åbn illustrationskort", |     "da": "Kunstværker", | ||||||
|     "cs": "Umělecká díla", |     "cs": "Umělecká díla", | ||||||
|     "pa_PK": "آزاد کلاکاری نقشہ", |     "pa_PK": "آزاد کلاکاری نقشہ", | ||||||
|     "zgh": "ⵕⵥⵎ ⵜⴰⴽⴰⵕⴹⴰ ⵏ ⵜⵡⵓⵔⵉ ⵜⴰⵏⴰⵥⵓⵕⵜ", |     "zgh": "ⵕⵥⵎ ⵜⴰⴽⴰⵕⴹⴰ ⵏ ⵜⵡⵓⵔⵉ ⵜⴰⵏⴰⵥⵓⵕⵜ", | ||||||
|  |  | ||||||
|  | @ -14,7 +14,8 @@ | ||||||
|     "zh_Hant": "自動櫃員機", |     "zh_Hant": "自動櫃員機", | ||||||
|     "eu": "Kutxazain automatikoa", |     "eu": "Kutxazain automatikoa", | ||||||
|     "it": "Sportelli bancomat", |     "it": "Sportelli bancomat", | ||||||
|     "pl": "Bankomaty" |     "pl": "Bankomaty", | ||||||
|  |     "da": "Hæveautomater" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "This map shows ATMs to withdraw or deposit money", |     "en": "This map shows ATMs to withdraw or deposit money", | ||||||
|  | @ -29,7 +30,8 @@ | ||||||
|     "zh_Hant": "此地圖顯示了提款或存款的 ATM", |     "zh_Hant": "此地圖顯示了提款或存款的 ATM", | ||||||
|     "eu": "Mapa honek dirua atera edo sartzeko kutxazain automatikoak erakusten ditu", |     "eu": "Mapa honek dirua atera edo sartzeko kutxazain automatikoak erakusten ditu", | ||||||
|     "it": "Questa mappa mostra gli sportelli Bancomat per ritirare o depositare del denaro", |     "it": "Questa mappa mostra gli sportelli Bancomat per ritirare o depositare del denaro", | ||||||
|     "pl": "Ta mapa pokazuje bankomaty, w których można wypłacać lub wpłacać pieniądze" |     "pl": "Ta mapa pokazuje bankomaty, w których można wypłacać lub wpłacać pieniądze", | ||||||
|  |     "da": "Dette kort viser hæveautomater, hvor du kan hæve og indsætte kontanter" | ||||||
|   }, |   }, | ||||||
|   "icon": "./assets/themes/atm/logo.svg", |   "icon": "./assets/themes/atm/logo.svg", | ||||||
|   "layers": [ |   "layers": [ | ||||||
|  | @ -96,7 +98,8 @@ | ||||||
|                   "eu": "Inportatu kutxazain automatiko hau", |                   "eu": "Inportatu kutxazain automatiko hau", | ||||||
|                   "it": "Importa questo sportello bancomat", |                   "it": "Importa questo sportello bancomat", | ||||||
|                   "pl": "Importuj ten bankomat", |                   "pl": "Importuj ten bankomat", | ||||||
|                   "cs": "Importovat tento bankomat" |                   "cs": "Importovat tento bankomat", | ||||||
|  |                   "da": "Importer denne hæveautomat" | ||||||
|                 }, |                 }, | ||||||
|                 "icon": "./assets/svg/addSmall.svg" |                 "icon": "./assets/svg/addSmall.svg" | ||||||
|               } |               } | ||||||
|  | @ -112,7 +115,8 @@ | ||||||
|               "ca": "OpenStreetMap sap sobre <a href='#{_closest_osm_poi}'>un caixer automàtic que està a {_closest_osm_poi_distance} de distància.</a> ", |               "ca": "OpenStreetMap sap sobre <a href='#{_closest_osm_poi}'>un caixer automàtic que està a {_closest_osm_poi_distance} de distància.</a> ", | ||||||
|               "cs": "OpenStreetMap ví o <a href='#{_closest_osm_poi}'> bankomatu, který je {_closest_osm_poi_distance} metr daleko.</a> ", |               "cs": "OpenStreetMap ví o <a href='#{_closest_osm_poi}'> bankomatu, který je {_closest_osm_poi_distance} metr daleko.</a> ", | ||||||
|               "pl": "OpenStreetMap wie o <a href='#{_closest_osm_poi}'>bankomacie oddalonym o {_closest_osm_poi_distance} metry.</a> ", |               "pl": "OpenStreetMap wie o <a href='#{_closest_osm_poi}'>bankomacie oddalonym o {_closest_osm_poi_distance} metry.</a> ", | ||||||
|               "nl": "OpenStreetMap kent <a href='#{_closest_osm_poi}'>een geldautomaat die {_closest_osm_poi_distance} meter weg is</a> " |               "nl": "OpenStreetMap kent <a href='#{_closest_osm_poi}'>een geldautomaat die {_closest_osm_poi_distance} meter weg is</a> ", | ||||||
|  |               "da": "OpenStreetMap kender <a href='#{_closest_osm_poi}'>en hæveautomatet, som ligger {_closest_osm_poi_distance} meter væk.</a> " | ||||||
|             } |             } | ||||||
|           }, |           }, | ||||||
|           { |           { | ||||||
|  | @ -132,7 +136,8 @@ | ||||||
|                   "eu": "Gehitu iradokitako etiketa guztiak hurbilen dagoen kutxazainari", |                   "eu": "Gehitu iradokitako etiketa guztiak hurbilen dagoen kutxazainari", | ||||||
|                   "pl": "Dodaj wszystkie sugerowane znaczniki do najbliższego bankomatu", |                   "pl": "Dodaj wszystkie sugerowane znaczniki do najbliższego bankomatu", | ||||||
|                   "cs": "Přidání všech navrhovaných značek do nejbližšího bankomatu", |                   "cs": "Přidání všech navrhovaných značek do nejbližšího bankomatu", | ||||||
|                   "nl": "Voeg alle gesuggereerde tags toe aan de dichtstbijzijnde geldautomaat" |                   "nl": "Voeg alle gesuggereerde tags toe aan de dichtstbijzijnde geldautomaat", | ||||||
|  |                   "da": "Tilføj alle foreslåede tags til den nærmeste hæveautomat" | ||||||
|                 }, |                 }, | ||||||
|                 "image": "./assets/svg/addSmall.svg", |                 "image": "./assets/svg/addSmall.svg", | ||||||
|                 "maproulette_id": "mr_taskId" |                 "maproulette_id": "mr_taskId" | ||||||
|  |  | ||||||
|  | @ -5,7 +5,8 @@ | ||||||
|     "de": "Fahrradabstellplätze", |     "de": "Fahrradabstellplätze", | ||||||
|     "ca": "Aparcament de bicicletes", |     "ca": "Aparcament de bicicletes", | ||||||
|     "fr": "Stationnement vélo", |     "fr": "Stationnement vélo", | ||||||
|     "pl": "Parkingi dla rowerów" |     "pl": "Parkingi dla rowerów", | ||||||
|  |     "da": "Cykelparkering" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "A map showing all types of bicycle parkings", |     "en": "A map showing all types of bicycle parkings", | ||||||
|  |  | ||||||
|  | @ -12,7 +12,8 @@ | ||||||
|     "es": "OSM para ciegos", |     "es": "OSM para ciegos", | ||||||
|     "eu": "OSM itsuentzat", |     "eu": "OSM itsuentzat", | ||||||
|     "it": "OSM per i non vedenti", |     "it": "OSM per i non vedenti", | ||||||
|     "pl": "OSM dla niewidomych" |     "pl": "OSM dla niewidomych", | ||||||
|  |     "da": "OSM for blinde" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Help to map features relevant for the blind", |     "en": "Help to map features relevant for the blind", | ||||||
|  |  | ||||||
|  | @ -17,7 +17,8 @@ | ||||||
|     "pa_PK": "آزاد کتاب نقشہ", |     "pa_PK": "آزاد کتاب نقشہ", | ||||||
|     "cs": "Veřejné knihovničky", |     "cs": "Veřejné knihovničky", | ||||||
|     "eu": "Apalategi publikoak", |     "eu": "Apalategi publikoak", | ||||||
|     "pl": "Publiczne regały na książki" |     "pl": "Publiczne regały na książki", | ||||||
|  |     "da": "Bogbytteskabe" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "A public bookcase is a small streetside cabinet, box, old phone booth or some other objects where books are stored. Everyone can place or take a book. This map aims to collect all these bookcases.", |     "en": "A public bookcase is a small streetside cabinet, box, old phone booth or some other objects where books are stored. Everyone can place or take a book. This map aims to collect all these bookcases.", | ||||||
|  | @ -30,7 +31,7 @@ | ||||||
|     "it": "Una libreria pubblica è una piccola cabina a lato della strada, un locale, una vecchia cabina telefonica o qualche altro luogo in cui sono tenuti libri. Chiunque può lasciare o prendere libri. Scopo della mappa è individuarle. Se scopri nuove librerie nelle vicinanze, puoi facilmente aggiungerle con un account OpenStreetMap.", |     "it": "Una libreria pubblica è una piccola cabina a lato della strada, un locale, una vecchia cabina telefonica o qualche altro luogo in cui sono tenuti libri. Chiunque può lasciare o prendere libri. Scopo della mappa è individuarle. Se scopri nuove librerie nelle vicinanze, puoi facilmente aggiungerle con un account OpenStreetMap.", | ||||||
|     "hu": "A nyilvános könyvespolc egy kis utcai szekrény, doboz, régi telefonfülke vagy más tárgy, ahol könyveket tárolnak. Bárki tehet rá vagy vihet el róla könyvet. Ez a térkép ezeket a könyvespolcokat kívánja összegyűjteni. Ha felfedezett egy új könyvespolcot a közelben, akkor egy ingyenes OpenStreetMap-fiókkal gyorsan fel is rajzolhatja a térképre.", |     "hu": "A nyilvános könyvespolc egy kis utcai szekrény, doboz, régi telefonfülke vagy más tárgy, ahol könyveket tárolnak. Bárki tehet rá vagy vihet el róla könyvet. Ez a térkép ezeket a könyvespolcokat kívánja összegyűjteni. Ha felfedezett egy új könyvespolcot a közelben, akkor egy ingyenes OpenStreetMap-fiókkal gyorsan fel is rajzolhatja a térképre.", | ||||||
|     "es": "Una librería pública es un pequeño armario en la calle, una caja, una vieja cabina telefónica o algún otro objeto donde se guardan libros. Todo el mundo puede colocar o coger un libro. Este mapa pretende recoger todas estas librerías.", |     "es": "Una librería pública es un pequeño armario en la calle, una caja, una vieja cabina telefónica o algún otro objeto donde se guardan libros. Todo el mundo puede colocar o coger un libro. Este mapa pretende recoger todas estas librerías.", | ||||||
|     "da": "Et offentligt bogskab er et lille skab, en kasse, en gammel telefonboks eller andre steder, hvor bøger opbevares. Alle kan lægge eller tage en bog. Dette kort har til formål at samle alle disse bogskabe. Du kan opdage nye bogkasser i nærheden og med en gratis OpenStreetMap-konto hurtigt tilføje dine yndlingsbogkasser.", |     "da": "Et bogbytteskab er et lille skab, en kasse, en gammel telefonboks eller andre steder, hvor bøger opbevares. Enhver kan lægge eller tage en bog. Dette kort har til formål at samle alle disse bogbytteskabe.", | ||||||
|     "ca": "Una llibreria pública és un xicotet armari al carrer, una caixa, una vella cabina telefònica o algun altre objecte on es guarden llibres. Tothom pot col·locar o agafar un llibre. Aquest mapa pretén recollir totes aquestes llibreries.", |     "ca": "Una llibreria pública és un xicotet armari al carrer, una caixa, una vella cabina telefònica o algun altre objecte on es guarden llibres. Tothom pot col·locar o agafar un llibre. Aquest mapa pretén recollir totes aquestes llibreries.", | ||||||
|     "cs": "Veřejná knihovna je malá pouliční skříňka, krabice, stará telefonní budka nebo jiný předmět, ve kterém jsou uloženy knihy. Kdokoliv do ní může umístit, nebo si z ní vzít knihu. Cílem této mapy je shromáždit všechny tyto knihovny.", |     "cs": "Veřejná knihovna je malá pouliční skříňka, krabice, stará telefonní budka nebo jiný předmět, ve kterém jsou uloženy knihy. Kdokoliv do ní může umístit, nebo si z ní vzít knihu. Cílem této mapy je shromáždit všechny tyto knihovny.", | ||||||
|     "eu": "Kale-liburutegi publiko bat kale-armairu txiki bat da, kaxa, telefono-kabina zaharra edo liburuak gordetzeko beste objektu batzuk. Guztiek jar edo har dezakete liburu bat. Koaderno horiek guztiak biltzea da mapa honen helburua.", |     "eu": "Kale-liburutegi publiko bat kale-armairu txiki bat da, kaxa, telefono-kabina zaharra edo liburuak gordetzeko beste objektu batzuk. Guztiek jar edo har dezakete liburu bat. Koaderno horiek guztiak biltzea da mapa honen helburua.", | ||||||
|  |  | ||||||
|  | @ -348,7 +348,8 @@ | ||||||
|               "es": "¿Esta tienda de reparación de zapatos repara zapatos de escalada?", |               "es": "¿Esta tienda de reparación de zapatos repara zapatos de escalada?", | ||||||
|               "ca": "Aquesta botiga de reparació de calçat repara sabates d'escalada?", |               "ca": "Aquesta botiga de reparació de calçat repara sabates d'escalada?", | ||||||
|               "cs": "Opravuje tato opravna obuvy horolezecké boty?", |               "cs": "Opravuje tato opravna obuvy horolezecké boty?", | ||||||
|               "pl": "Czy ten warsztat szewski naprawia buty wspinaczkowe?" |               "pl": "Czy ten warsztat szewski naprawia buty wspinaczkowe?", | ||||||
|  |               "da": "Reparerer denne butik klatresko?" | ||||||
|             }, |             }, | ||||||
|             "mappings": [ |             "mappings": [ | ||||||
|               { |               { | ||||||
|  | @ -360,7 +361,8 @@ | ||||||
|                   "es": "Esta tienda repara zapatos de escalada", |                   "es": "Esta tienda repara zapatos de escalada", | ||||||
|                   "ca": "Aquesta botiga repara sabates d'escalada", |                   "ca": "Aquesta botiga repara sabates d'escalada", | ||||||
|                   "cs": "Tento obchod opravuje lezeckou obuv", |                   "cs": "Tento obchod opravuje lezeckou obuv", | ||||||
|                   "pl": "Ten warsztat naprawia buty wspinaczkowe" |                   "pl": "Ten warsztat naprawia buty wspinaczkowe", | ||||||
|  |                   "da": "Denne butik reparerer klatresko" | ||||||
|                 } |                 } | ||||||
|               }, |               }, | ||||||
|               { |               { | ||||||
|  | @ -372,7 +374,8 @@ | ||||||
|                   "es": "Esta tienda no repara zapatos de escalada", |                   "es": "Esta tienda no repara zapatos de escalada", | ||||||
|                   "ca": "Aquesta botiga no repara sabates d'escalada", |                   "ca": "Aquesta botiga no repara sabates d'escalada", | ||||||
|                   "cs": "Tento obchod neopravuje lezeckou obuv", |                   "cs": "Tento obchod neopravuje lezeckou obuv", | ||||||
|                   "pl": "Ten warsztat nie naprawia butów wspinaczkowych" |                   "pl": "Ten warsztat nie naprawia butów wspinaczkowych", | ||||||
|  |                   "da": "Denne butik reparerer ikke klatresko" | ||||||
|                 } |                 } | ||||||
|               } |               } | ||||||
|             ] |             ] | ||||||
|  | @ -404,7 +407,8 @@ | ||||||
|               "es": "¿Esta tienda de reparación de zapatos también repara zapatos de escalada?", |               "es": "¿Esta tienda de reparación de zapatos también repara zapatos de escalada?", | ||||||
|               "ca": "Aquesta botiga de reparació de calçat també repara sabates d'escalada?", |               "ca": "Aquesta botiga de reparació de calçat també repara sabates d'escalada?", | ||||||
|               "cs": "Opravuje tato opravna obuvy také lezeckou obuv?", |               "cs": "Opravuje tato opravna obuvy také lezeckou obuv?", | ||||||
|               "pl": "Czy ten warsztat obuwniczy naprawia również buty wspinaczkowe?" |               "pl": "Czy ten warsztat obuwniczy naprawia również buty wspinaczkowe?", | ||||||
|  |               "da": "Reparerer denne skomager klatresko?" | ||||||
|             }, |             }, | ||||||
|             "mappings": [ |             "mappings": [ | ||||||
|               { |               { | ||||||
|  | @ -416,7 +420,8 @@ | ||||||
|                   "es": "Esta tienda repara zapatos de escalada", |                   "es": "Esta tienda repara zapatos de escalada", | ||||||
|                   "ca": "Aquesta botiga repara sabates d'escalada", |                   "ca": "Aquesta botiga repara sabates d'escalada", | ||||||
|                   "cs": "Tento obchod opravuje lezeckou obuv", |                   "cs": "Tento obchod opravuje lezeckou obuv", | ||||||
|                   "pl": "Ten warsztat naprawia buty wspinaczkowe" |                   "pl": "Ten warsztat naprawia buty wspinaczkowe", | ||||||
|  |                   "da": "Denne butik reparerer klatresko" | ||||||
|                 } |                 } | ||||||
|               }, |               }, | ||||||
|               { |               { | ||||||
|  | @ -428,7 +433,8 @@ | ||||||
|                   "es": "Esta tienda no repara zapatos de escalada", |                   "es": "Esta tienda no repara zapatos de escalada", | ||||||
|                   "ca": "Aquesta botiga no repara sabates d'escalada", |                   "ca": "Aquesta botiga no repara sabates d'escalada", | ||||||
|                   "cs": "Tento obchod neopravuje lezeckou obuv", |                   "cs": "Tento obchod neopravuje lezeckou obuv", | ||||||
|                   "pl": "Ten warsztat nie naprawia butów wspinaczkowych" |                   "pl": "Ten warsztat nie naprawia butów wspinaczkowych", | ||||||
|  |                   "da": "Denne butik reparerer ikke klatresko" | ||||||
|                 } |                 } | ||||||
|               } |               } | ||||||
|             ] |             ] | ||||||
|  | @ -446,7 +452,8 @@ | ||||||
|               "es": "una tienda de reparación de zapatos", |               "es": "una tienda de reparación de zapatos", | ||||||
|               "ca": "una botiga de reparació de calçat", |               "ca": "una botiga de reparació de calçat", | ||||||
|               "cs": "opravna bot", |               "cs": "opravna bot", | ||||||
|               "pl": "warsztat szewski" |               "pl": "warsztat szewski", | ||||||
|  |               "da": "en skomager" | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|         ] |         ] | ||||||
|  |  | ||||||
|  | @ -9,7 +9,8 @@ | ||||||
|     "cs": "Hodiny", |     "cs": "Hodiny", | ||||||
|     "fr": "Horloges", |     "fr": "Horloges", | ||||||
|     "eu": "Erlojuak", |     "eu": "Erlojuak", | ||||||
|     "pl": "Zegary" |     "pl": "Zegary", | ||||||
|  |     "da": "Ure" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Map showing all public clocks", |     "en": "Map showing all public clocks", | ||||||
|  | @ -19,7 +20,8 @@ | ||||||
|     "es": "Mapa con todos los relojes públicos", |     "es": "Mapa con todos los relojes públicos", | ||||||
|     "cs": "Mapa zobrazující veřejné hodiny", |     "cs": "Mapa zobrazující veřejné hodiny", | ||||||
|     "fr": "Carte affichant toutes les horloges publiques", |     "fr": "Carte affichant toutes les horloges publiques", | ||||||
|     "pl": "Mapa pokazująca wszystkie zegary publiczne" |     "pl": "Mapa pokazująca wszystkie zegary publiczne", | ||||||
|  |     "da": "Kort over alle ure i det offentlige rum" | ||||||
|   }, |   }, | ||||||
|   "icon": "./assets/layers/clock/clock.svg", |   "icon": "./assets/layers/clock/clock.svg", | ||||||
|   "layers": [ |   "layers": [ | ||||||
|  |  | ||||||
|  | @ -229,7 +229,8 @@ | ||||||
|               "de": "z.B. 1", |               "de": "z.B. 1", | ||||||
|               "cs": "e.g. 1", |               "cs": "e.g. 1", | ||||||
|               "es": "Por ejemplo, 1", |               "es": "Por ejemplo, 1", | ||||||
|               "pl": "np. 1" |               "pl": "np. 1", | ||||||
|  |               "da": "fx 1" | ||||||
|             } |             } | ||||||
|           }, |           }, | ||||||
|           "render": { |           "render": { | ||||||
|  | @ -298,7 +299,8 @@ | ||||||
|               "de": "z.B. 3", |               "de": "z.B. 3", | ||||||
|               "cs": "e.g. 3", |               "cs": "e.g. 3", | ||||||
|               "es": "Por ejemplo, 3", |               "es": "Por ejemplo, 3", | ||||||
|               "pl": "np. 3" |               "pl": "np. 3", | ||||||
|  |               "da": "fx 3" | ||||||
|             } |             } | ||||||
|           }, |           }, | ||||||
|           "id": "node-expected_rcn_route_relations" |           "id": "node-expected_rcn_route_relations" | ||||||
|  |  | ||||||
|  | @ -624,7 +624,8 @@ | ||||||
|               "ca": "Residents permesos", |               "ca": "Residents permesos", | ||||||
|               "es": "Residentes autorizados", |               "es": "Residentes autorizados", | ||||||
|               "cs": "Přístup povolen obyvatelům", |               "cs": "Přístup povolen obyvatelům", | ||||||
|               "pl": "Mieszkańcy dopuszczeni" |               "pl": "Mieszkańcy dopuszczeni", | ||||||
|  |               "da": "Beboere tilladt" | ||||||
|             }, |             }, | ||||||
|             "icon": { |             "icon": { | ||||||
|               "path": "./assets/themes/cyclestreets/Zeichen_244_1020-30.svg", |               "path": "./assets/themes/cyclestreets/Zeichen_244_1020-30.svg", | ||||||
|  | @ -647,7 +648,8 @@ | ||||||
|               "cs": "Vjezd motorových vozidel povolen", |               "cs": "Vjezd motorových vozidel povolen", | ||||||
|               "ca": "Vehicles a motor permesos", |               "ca": "Vehicles a motor permesos", | ||||||
|               "es": "Vehículos a motor permitidos", |               "es": "Vehículos a motor permitidos", | ||||||
|               "pl": "Pojazdy silnikowe dozwolone" |               "pl": "Pojazdy silnikowe dozwolone", | ||||||
|  |               "da": "Motorkøretøjer tilladt" | ||||||
|             }, |             }, | ||||||
|             "icon": { |             "icon": { | ||||||
|               "path": "./assets/themes/cyclestreets/Zeichen_244_KFZ_frei.svg", |               "path": "./assets/themes/cyclestreets/Zeichen_244_KFZ_frei.svg", | ||||||
|  | @ -671,7 +673,8 @@ | ||||||
|               "cs": "Vjezd motocyklů povolen", |               "cs": "Vjezd motocyklů povolen", | ||||||
|               "ca": "Motos permeses", |               "ca": "Motos permeses", | ||||||
|               "es": "Motocicletas permitidas", |               "es": "Motocicletas permitidas", | ||||||
|               "pl": "Motocykle dozwolone" |               "pl": "Motocykle dozwolone", | ||||||
|  |               "da": "Motorcykler tilladt" | ||||||
|             }, |             }, | ||||||
|             "icon": { |             "icon": { | ||||||
|               "path": "./assets/themes/cyclestreets/Zeichen_244_1022-12.svg", |               "path": "./assets/themes/cyclestreets/Zeichen_244_1022-12.svg", | ||||||
|  | @ -696,7 +699,8 @@ | ||||||
|               "nb_NO": "Biler tillatt", |               "nb_NO": "Biler tillatt", | ||||||
|               "ca": "Cotxes permesos", |               "ca": "Cotxes permesos", | ||||||
|               "es": "Coches permitidos", |               "es": "Coches permitidos", | ||||||
|               "pl": "Samochody dozwolone" |               "pl": "Samochody dozwolone", | ||||||
|  |               "da": "Biler tilladt" | ||||||
|             }, |             }, | ||||||
|             "icon": { |             "icon": { | ||||||
|               "path": "./assets/themes/cyclestreets/Zeichen_244_1024-10.svg", |               "path": "./assets/themes/cyclestreets/Zeichen_244_1024-10.svg", | ||||||
|  |  | ||||||
|  | @ -5,7 +5,8 @@ | ||||||
|     "it": "Risposta ai disastri", |     "it": "Risposta ai disastri", | ||||||
|     "de": "Katastrophenschutz", |     "de": "Katastrophenschutz", | ||||||
|     "es": "Respuesta ante desastres", |     "es": "Respuesta ante desastres", | ||||||
|     "ca": "Resposta davant de desastres" |     "ca": "Resposta davant de desastres", | ||||||
|  |     "da": "Beredskab" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "This map contains elements meant for disaster preparedness and response.", |     "en": "This map contains elements meant for disaster preparedness and response.", | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ | ||||||
|     "hu": "Etimológiai térkép", |     "hu": "Etimológiai térkép", | ||||||
|     "fr": "Étymologie - d'où les rues tirent leur nom ?", |     "fr": "Étymologie - d'où les rues tirent leur nom ?", | ||||||
|     "ca": "Etimologia: com rep el nom un carrer?", |     "ca": "Etimologia: com rep el nom un carrer?", | ||||||
|     "da": "Åbn oprindelseskort", |     "da": "Etymology - hvad er et sted opkaldt efter?", | ||||||
|     "nb_NO": "Åpent etymologikart", |     "nb_NO": "Åpent etymologikart", | ||||||
|     "cs": "Etymologie - podle čeho se ulice jmenuje?", |     "cs": "Etymologie - podle čeho se ulice jmenuje?", | ||||||
|     "es": "Etimología - a qué se debe el nombre de una calle?", |     "es": "Etimología - a qué se debe el nombre de una calle?", | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ | ||||||
|     "fr": "Carte des friteries", |     "fr": "Carte des friteries", | ||||||
|     "de": "Pommesbuden", |     "de": "Pommesbuden", | ||||||
|     "ca": "Botigues de patates", |     "ca": "Botigues de patates", | ||||||
|     "da": "Pommes frites butik", |     "da": "Pomfritbutikker", | ||||||
|     "pa_PK": "فرائیاں دیاں دکاناں", |     "pa_PK": "فرائیاں دیاں دکاناں", | ||||||
|     "cs": "Obchody s hranolky", |     "cs": "Obchody s hranolky", | ||||||
|     "es": "Tiendas de patatas fritas", |     "es": "Tiendas de patatas fritas", | ||||||
|  | @ -37,7 +37,7 @@ | ||||||
|           "it": "Friggitoria", |           "it": "Friggitoria", | ||||||
|           "hu": "Sültkrumplievő-hely", |           "hu": "Sültkrumplievő-hely", | ||||||
|           "ca": "Botigues de patates", |           "ca": "Botigues de patates", | ||||||
|           "da": "Pommes frites butik", |           "da": "Pomfritbutik", | ||||||
|           "pa_PK": "فرائیاں دی دکان", |           "pa_PK": "فرائیاں دی دکان", | ||||||
|           "cs": "Obchod s hranolky", |           "cs": "Obchod s hranolky", | ||||||
|           "es": "Tienda de patatas fritas", |           "es": "Tienda de patatas fritas", | ||||||
|  |  | ||||||
|  | @ -5,7 +5,8 @@ | ||||||
|     "de": "Eiscreme", |     "de": "Eiscreme", | ||||||
|     "cs": "Zmrzlina", |     "cs": "Zmrzlina", | ||||||
|     "ca": "Gelat", |     "ca": "Gelat", | ||||||
|     "es": "Helado" |     "es": "Helado", | ||||||
|  |     "da": "Is" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "A map showing ice cream parlors and ice cream vending machines", |     "en": "A map showing ice cream parlors and ice cream vending machines", | ||||||
|  |  | ||||||
|  | @ -2,7 +2,8 @@ | ||||||
|   "id": "lighthouses", |   "id": "lighthouses", | ||||||
|   "title": { |   "title": { | ||||||
|     "en": "Lighthouses", |     "en": "Lighthouses", | ||||||
|     "de": "Leuchttürme" |     "de": "Leuchttürme", | ||||||
|  |     "da": "Fyrtårne" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Lighthouses are tall buildings with a light on top to guide marine traffic.", |     "en": "Lighthouses are tall buildings with a light on top to guide marine traffic.", | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ | ||||||
|     "ca": "Velocitat", |     "ca": "Velocitat", | ||||||
|     "de": "Höchstgeschwindigkeit", |     "de": "Höchstgeschwindigkeit", | ||||||
|     "fr": "Vitesse maximale", |     "fr": "Vitesse maximale", | ||||||
|     "da": "Højeste hastighed", |     "da": "Fartgrænser", | ||||||
|     "nl": "Maximale snelheden", |     "nl": "Maximale snelheden", | ||||||
|     "pa_PK": "حد رفتار", |     "pa_PK": "حد رفتار", | ||||||
|     "cs": "Maximální rychlost", |     "cs": "Maximální rychlost", | ||||||
|  |  | ||||||
|  | @ -4,7 +4,8 @@ | ||||||
|     "en": "Memorials", |     "en": "Memorials", | ||||||
|     "de": "Denkmäler", |     "de": "Denkmäler", | ||||||
|     "fr": "Mémoriaux", |     "fr": "Mémoriaux", | ||||||
|     "nl": "Gedenktekens en graven" |     "nl": "Gedenktekens en graven", | ||||||
|  |     "da": "Mindesmærker" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Memorials are physical objects permantently placed in the public space to remember a person or event. They can be a wide range of objects, such as statues, plaques, paintings, military objects (such as tanks), ...", |     "en": "Memorials are physical objects permantently placed in the public space to remember a person or event. They can be a wide range of objects, such as statues, plaques, paintings, military objects (such as tanks), ...", | ||||||
|  |  | ||||||
|  | @ -279,7 +279,8 @@ | ||||||
|           "cs": "Parkovací místa pro osoby se zdravotním postižením", |           "cs": "Parkovací místa pro osoby se zdravotním postižením", | ||||||
|           "es": "Plazas de aparcamiento para discapacitados", |           "es": "Plazas de aparcamiento para discapacitados", | ||||||
|           "ca": "Places d'aparcament per a minusvàlids", |           "ca": "Places d'aparcament per a minusvàlids", | ||||||
|           "pl": "Miejsca parkingowe dla niepełnosprawnych" |           "pl": "Miejsca parkingowe dla niepełnosprawnych", | ||||||
|  |           "da": "Handikapparkeringspladser" | ||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|       "hideTagRenderingsWithLabels": [ |       "hideTagRenderingsWithLabels": [ | ||||||
|  |  | ||||||
|  | @ -111,7 +111,8 @@ | ||||||
|             "title": { |             "title": { | ||||||
|               "en": "a condom vending machine", |               "en": "a condom vending machine", | ||||||
|               "de": "ein Kondomautomat", |               "de": "ein Kondomautomat", | ||||||
|               "es": "una máquina de venta de condones" |               "es": "una máquina de venta de condones", | ||||||
|  |               "da": "en kondomautomat" | ||||||
|             }, |             }, | ||||||
|             "tags": [ |             "tags": [ | ||||||
|               "amenity=vending_machine", |               "amenity=vending_machine", | ||||||
|  |  | ||||||
|  | @ -15,7 +15,8 @@ | ||||||
|     "pa_PK": "اوپنونڈپاورمیپ", |     "pa_PK": "اوپنونڈپاورمیپ", | ||||||
|     "es": "Generadores de energía eólica", |     "es": "Generadores de energía eólica", | ||||||
|     "cs": "Větrné elektrárny", |     "cs": "Větrné elektrárny", | ||||||
|     "pl": "Generatory wiatrowe" |     "pl": "Generatory wiatrowe", | ||||||
|  |     "da": "Vindmøller" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "A map for showing and editing wind turbines.", |     "en": "A map for showing and editing wind turbines.", | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ | ||||||
|   "id": "pets", |   "id": "pets", | ||||||
|   "title": { |   "title": { | ||||||
|     "en": "Veterinarians, dog parks and other pet-amenities", |     "en": "Veterinarians, dog parks and other pet-amenities", | ||||||
|     "da": "hundesteder", |     "da": "Dyrlæger, hundeparker og andre faciliteter for kæledyr", | ||||||
|     "de": "Tierärzte, Hundeparks und andere Einrichtungen für Haustiere", |     "de": "Tierärzte, Hundeparks und andere Einrichtungen für Haustiere", | ||||||
|     "nl": "Dierenartsen, hondenloopzones en andere huisdiervriendelijke plaatsen", |     "nl": "Dierenartsen, hondenloopzones en andere huisdiervriendelijke plaatsen", | ||||||
|     "fr": "Vétérinaires, parcs à chiens et autres endroits pour chiens", |     "fr": "Vétérinaires, parcs à chiens et autres endroits pour chiens", | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ | ||||||
|     "hu": "Posta- és postaládatérkép", |     "hu": "Posta- és postaládatérkép", | ||||||
|     "nl": "Brievenbussen en postkantoren", |     "nl": "Brievenbussen en postkantoren", | ||||||
|     "fr": "Carte des bureaux de poste et boîtes à lettres", |     "fr": "Carte des bureaux de poste et boîtes à lettres", | ||||||
|     "da": "Postkasse- og Posthus-Kort", |     "da": "Postkasser og posthuse", | ||||||
|     "ca": "Mapa de bústies i oficines de correus", |     "ca": "Mapa de bústies i oficines de correus", | ||||||
|     "es": "Mapa de Buzones y Oficinas de Correos", |     "es": "Mapa de Buzones y Oficinas de Correos", | ||||||
|     "cs": "Mapa poštovních schránek a pošt", |     "cs": "Mapa poštovních schránek a pošt", | ||||||
|  |  | ||||||
|  | @ -4,7 +4,7 @@ | ||||||
|     "en": "Rainbow pedestrian crossings", |     "en": "Rainbow pedestrian crossings", | ||||||
|     "de": "Regenbogen-Fußgängerübergänge", |     "de": "Regenbogen-Fußgängerübergänge", | ||||||
|     "fr": "Passages piétons arc-en-ciel", |     "fr": "Passages piétons arc-en-ciel", | ||||||
|     "da": "Regnbue fodgængerfelter", |     "da": "Regnbuemalede fodgængerfelter", | ||||||
|     "nl": "Regenboogzebrapaden", |     "nl": "Regenboogzebrapaden", | ||||||
|     "ru": "Радужные пешеходные переходы", |     "ru": "Радужные пешеходные переходы", | ||||||
|     "ca": "Pasos de vianants amb l'arc de Sant Martí", |     "ca": "Pasos de vianants amb l'arc de Sant Martí", | ||||||
|  |  | ||||||
|  | @ -12,7 +12,7 @@ | ||||||
|     "hu": "Bolttérkép", |     "hu": "Bolttérkép", | ||||||
|     "nl": "Winkels", |     "nl": "Winkels", | ||||||
|     "ca": "Botigues", |     "ca": "Botigues", | ||||||
|     "da": "Åbn butikskort", |     "da": "Butikker", | ||||||
|     "es": "Tiendas", |     "es": "Tiendas", | ||||||
|     "cs": "Obchody", |     "cs": "Obchody", | ||||||
|     "eu": "Denda", |     "eu": "Denda", | ||||||
|  |  | ||||||
|  | @ -3,7 +3,9 @@ | ||||||
|   "title": { |   "title": { | ||||||
|     "en": "Ski pistes and aerialways", |     "en": "Ski pistes and aerialways", | ||||||
|     "de": "Skipisten und Seilbahnen", |     "de": "Skipisten und Seilbahnen", | ||||||
|     "es": "Pistas de esquí y vías aéreas" |     "es": "Pistas de esquí y vías aéreas", | ||||||
|  |     "da": "Skiløjper og skilifte", | ||||||
|  |     "fr": "Pistes de ski et remontées mécaniques" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Everything you need to go skiing", |     "en": "Everything you need to go skiing", | ||||||
|  |  | ||||||
|  | @ -10,7 +10,8 @@ | ||||||
|     "es": "Estaciones de tren", |     "es": "Estaciones de tren", | ||||||
|     "cs": "Vlaková nádraží", |     "cs": "Vlaková nádraží", | ||||||
|     "zh_Hant": "火車站", |     "zh_Hant": "火車站", | ||||||
|     "pl": "Stacje Kolejowe" |     "pl": "Stacje Kolejowe", | ||||||
|  |     "da": "Togstationer" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "View, edit and add details to a train station", |     "en": "View, edit and add details to a train station", | ||||||
|  | @ -72,7 +73,8 @@ | ||||||
|         "cs": "Vlaková nádraží", |         "cs": "Vlaková nádraží", | ||||||
|         "it": "Stazioni ferroviarie", |         "it": "Stazioni ferroviarie", | ||||||
|         "pl": "Stacje Kolejowe", |         "pl": "Stacje Kolejowe", | ||||||
|         "zh_Hant": "火車站" |         "zh_Hant": "火車站", | ||||||
|  |         "da": "Togstationer" | ||||||
|       }, |       }, | ||||||
|       "description": { |       "description": { | ||||||
|         "en": "Layer showing train stations", |         "en": "Layer showing train stations", | ||||||
|  | @ -294,7 +296,8 @@ | ||||||
|         "es": "Tableros de salidas", |         "es": "Tableros de salidas", | ||||||
|         "cs": "Odjezdové tabule", |         "cs": "Odjezdové tabule", | ||||||
|         "pl": "Tablice odjazdów", |         "pl": "Tablice odjazdów", | ||||||
|         "zh_Hant": "出發板" |         "zh_Hant": "出發板", | ||||||
|  |         "da": "Afgangstavler" | ||||||
|       }, |       }, | ||||||
|       "description": { |       "description": { | ||||||
|         "en": "Displays showing the trains that will leave from this station", |         "en": "Displays showing the trains that will leave from this station", | ||||||
|  | @ -316,7 +319,8 @@ | ||||||
|           "es": "Tablero de salidas", |           "es": "Tablero de salidas", | ||||||
|           "cs": "Odjezdová tabule", |           "cs": "Odjezdová tabule", | ||||||
|           "zh_Hant": "時刻表", |           "zh_Hant": "時刻表", | ||||||
|           "pl": "Tablica odjazdów" |           "pl": "Tablica odjazdów", | ||||||
|  |           "da": "Afgangstavle" | ||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|       "minzoom": 18, |       "minzoom": 18, | ||||||
|  | @ -342,7 +346,8 @@ | ||||||
|             "es": "¿Qué tipo de tablero de salidas es éste?", |             "es": "¿Qué tipo de tablero de salidas es éste?", | ||||||
|             "cs": "Co je to za odjezdovou tabuli?", |             "cs": "Co je to za odjezdovou tabuli?", | ||||||
|             "zh_Hant": "這是那種類型的時刻表?", |             "zh_Hant": "這是那種類型的時刻表?", | ||||||
|             "pl": "Co to za tablica odjazdów?" |             "pl": "Co to za tablica odjazdów?", | ||||||
|  |             "da": "Hvilken type afgangstavle er dette?" | ||||||
|           }, |           }, | ||||||
|           "mappings": [ |           "mappings": [ | ||||||
|             { |             { | ||||||
|  | @ -417,7 +422,8 @@ | ||||||
|             "es": "un tablero de salidas", |             "es": "un tablero de salidas", | ||||||
|             "cs": "odjezdová tabule", |             "cs": "odjezdová tabule", | ||||||
|             "zh_Hant": "時刻表", |             "zh_Hant": "時刻表", | ||||||
|             "pl": "tablica odjazdów" |             "pl": "tablica odjazdów", | ||||||
|  |             "da": "en afgangstavle" | ||||||
|           }, |           }, | ||||||
|           "description": { |           "description": { | ||||||
|             "en": "Add a board showing departures, either electronic or paper", |             "en": "Add a board showing departures, either electronic or paper", | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ | ||||||
|     "nb_NO": "Åpent toalettkart", |     "nb_NO": "Åpent toalettkart", | ||||||
|     "hu": "WC-térkép", |     "hu": "WC-térkép", | ||||||
|     "ca": "Lavabos públics", |     "ca": "Lavabos públics", | ||||||
|     "da": "Åbn toiletkort", |     "da": "Offentlige toiletter", | ||||||
|     "es": "Baños públicos", |     "es": "Baños públicos", | ||||||
|     "cs": "Veřejné toalety" |     "cs": "Veřejné toalety" | ||||||
|   }, |   }, | ||||||
|  |  | ||||||
|  | @ -9,7 +9,8 @@ | ||||||
|     "cs": "Prodejní automaty", |     "cs": "Prodejní automaty", | ||||||
|     "es": "Máquinas expendedoras", |     "es": "Máquinas expendedoras", | ||||||
|     "pl": "Automaty sprzedające", |     "pl": "Automaty sprzedające", | ||||||
|     "zh_Hant": "自動販賣機" |     "zh_Hant": "自動販賣機", | ||||||
|  |     "da": "Salgsautomater" | ||||||
|   }, |   }, | ||||||
|   "description": { |   "description": { | ||||||
|     "en": "Find vending machines for everything", |     "en": "Find vending machines for everything", | ||||||
|  |  | ||||||
|  | @ -23,7 +23,7 @@ | ||||||
|     "fr": "Carte des poubelles et infrastructures de recyclage.", |     "fr": "Carte des poubelles et infrastructures de recyclage.", | ||||||
|     "it": "Mappa dei cestini per i rifiuti e i centri di raccolta e riciclo rifiuti.", |     "it": "Mappa dei cestini per i rifiuti e i centri di raccolta e riciclo rifiuti.", | ||||||
|     "ca": "Mapa que mostra papereres i infraestructures de reciclatge.", |     "ca": "Mapa que mostra papereres i infraestructures de reciclatge.", | ||||||
|     "da": "Kort over affaldskurve og genbrugsanlæg.", |     "da": "Kort over skraldespande og genbrugsanlæg.", | ||||||
|     "es": "Mapa que muestra las papeleras y las instalaciones de reciclaje.", |     "es": "Mapa que muestra las papeleras y las instalaciones de reciclaje.", | ||||||
|     "cs": "Mapa zobrazující koše na odpadky a recyklační zařízení.", |     "cs": "Mapa zobrazující koše na odpadky a recyklační zařízení.", | ||||||
|     "zh_Hant": "顯示垃圾筒與回收設施的地圖。", |     "zh_Hant": "顯示垃圾筒與回收設施的地圖。", | ||||||
|  |  | ||||||
|  | @ -11,7 +11,7 @@ | ||||||
|     "ca": "Papepera", |     "ca": "Papepera", | ||||||
|     "fr": "Poubelles", |     "fr": "Poubelles", | ||||||
|     "nb_NO": "Søppelkurv", |     "nb_NO": "Søppelkurv", | ||||||
|     "da": "Affaldskurv", |     "da": "Skraldespande", | ||||||
|     "pa_PK": "کوڑے دی ٹوکری", |     "pa_PK": "کوڑے دی ٹوکری", | ||||||
|     "es": "Papeleras", |     "es": "Papeleras", | ||||||
|     "cs": "Odpadkový koš", |     "cs": "Odpadkový koš", | ||||||
|  | @ -25,7 +25,7 @@ | ||||||
|     "zh_Hant": "在這份地圖當中,你可以找到你附近的垃圾筒。如果地圖有遺漏垃圾筒,你可以自己加上去", |     "zh_Hant": "在這份地圖當中,你可以找到你附近的垃圾筒。如果地圖有遺漏垃圾筒,你可以自己加上去", | ||||||
|     "hu": "Ezen a térképen megtalálhatod a közeledben lévő szemeteskosarakat. Ha hiányzik egy kuka a térképről, te is felrajzolhatod", |     "hu": "Ezen a térképen megtalálhatod a közeledben lévő szemeteskosarakat. Ha hiányzik egy kuka a térképről, te is felrajzolhatod", | ||||||
|     "fr": "Retrouvez les poubelles près de vous. Si une poubelle est manquante, vous pouvez l’ajouter vous même", |     "fr": "Retrouvez les poubelles près de vous. Si une poubelle est manquante, vous pouvez l’ajouter vous même", | ||||||
|     "da": "På dette kort finder du affaldskurve i nærheden af dig. Hvis der mangler en affaldskurv på dette kort, kan du selv tilføje den", |     "da": "På dette kort finder du skraldespande i nærheden af dig. Hvis der mangler en skraldespand på dette kort, kan du selv tilføje den", | ||||||
|     "ca": "A aquest mapa trobaràs les papereres a prop teua. Si falta una paperera al mapa pots afegir-la tu mateix", |     "ca": "A aquest mapa trobaràs les papereres a prop teua. Si falta una paperera al mapa pots afegir-la tu mateix", | ||||||
|     "es": "En este mapa, encontrará las papeleras cercanas a usted. Si falta una papelera en el mapa, puede añadirla usted mismo", |     "es": "En este mapa, encontrará las papeleras cercanas a usted. Si falta una papelera en el mapa, puede añadirla usted mismo", | ||||||
|     "cs": "Na této mapě najdete koše na odpadky ve vašem okolí. Pokud na této mapě odpadkový koš chybí, můžete jej přidat sami", |     "cs": "Na této mapě najdete koše na odpadky ve vašem okolí. Pokud na této mapě odpadkový koš chybí, můžete jej přidat sami", | ||||||
|  | @ -40,7 +40,7 @@ | ||||||
|     "hu": "Szemeteskosarakat ábrázoló térkép", |     "hu": "Szemeteskosarakat ábrázoló térkép", | ||||||
|     "fr": "Une carte des poubelles", |     "fr": "Une carte des poubelles", | ||||||
|     "nb_NO": "Oversikt over søppelkurver", |     "nb_NO": "Oversikt over søppelkurver", | ||||||
|     "da": "Et kort med affaldskurve", |     "da": "Et kort over skraldespande", | ||||||
|     "ca": "Un mapa amb papereres", |     "ca": "Un mapa amb papereres", | ||||||
|     "es": "Un mapa con papeleras", |     "es": "Un mapa con papeleras", | ||||||
|     "cs": "Mapa odpadkových košů", |     "cs": "Mapa odpadkových košů", | ||||||
|  |  | ||||||
|  | @ -94,12 +94,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "Vægmaleri" |                         "then": "Vægmaleri" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "Azulejo (spansk dekorativt flisebeklædning)" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "flisebeklædning" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "Maleri" |                         "then": "Maleri" | ||||||
|                     }, |                     }, | ||||||
|  | @ -123,6 +117,12 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "Relief" |                         "then": "Relief" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "Azulejo (spansk dekorativt flisebeklædning)" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "flisebeklædning" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "Hvilken slags kunstværk er det?", |                 "question": "Hvilken slags kunstværk er det?", | ||||||
|  | @ -2873,4 +2873,4 @@ | ||||||
|             "render": "vindmølle" |             "render": "vindmølle" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -35,23 +35,6 @@ | ||||||
|             "1": { |             "1": { | ||||||
|                 "title": "un panneau à affiches scellé au sol" |                 "title": "un panneau à affiches scellé au sol" | ||||||
|             }, |             }, | ||||||
|             "10": { |  | ||||||
|                 "description": "Une pièce de textile imperméable avec un message imprimé, ancrée de façon permanente sur un mur.", |  | ||||||
|                 "title": "une bâche" |  | ||||||
|             }, |  | ||||||
|             "11": { |  | ||||||
|                 "title": "un totem" |  | ||||||
|             }, |  | ||||||
|             "12": { |  | ||||||
|                 "description": "Désigne une enseigne publicitaire, une enseigne néon, les logos ou des indications d'entrées", |  | ||||||
|                 "title": "une enseigne" |  | ||||||
|             }, |  | ||||||
|             "13": { |  | ||||||
|                 "title": "une sculpture" |  | ||||||
|             }, |  | ||||||
|             "14": { |  | ||||||
|                 "title": "une peinture murale" |  | ||||||
|             }, |  | ||||||
|             "2": { |             "2": { | ||||||
|                 "title": "un panneau à affiches monté sur un mur" |                 "title": "un panneau à affiches monté sur un mur" | ||||||
|             }, |             }, | ||||||
|  | @ -77,6 +60,23 @@ | ||||||
|             }, |             }, | ||||||
|             "9": { |             "9": { | ||||||
|                 "title": "un écran fixé sur un abri de transport" |                 "title": "un écran fixé sur un abri de transport" | ||||||
|  |             }, | ||||||
|  |             "10": { | ||||||
|  |                 "description": "Une pièce de textile imperméable avec un message imprimé, ancrée de façon permanente sur un mur.", | ||||||
|  |                 "title": "une bâche" | ||||||
|  |             }, | ||||||
|  |             "11": { | ||||||
|  |                 "title": "un totem" | ||||||
|  |             }, | ||||||
|  |             "12": { | ||||||
|  |                 "description": "Désigne une enseigne publicitaire, une enseigne néon, les logos ou des indications d'entrées", | ||||||
|  |                 "title": "une enseigne" | ||||||
|  |             }, | ||||||
|  |             "13": { | ||||||
|  |                 "title": "une sculpture" | ||||||
|  |             }, | ||||||
|  |             "14": { | ||||||
|  |                 "title": "une peinture murale" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "tagRenderings": { |         "tagRenderings": { | ||||||
|  | @ -168,9 +168,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "C'est un petit panneau" |                         "then": "C'est un petit panneau" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "C'est une peinture murale" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "C'est une colonne" |                         "then": "C'est une colonne" | ||||||
|                     }, |                     }, | ||||||
|  | @ -194,6 +191,9 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "C'est un totem" |                         "then": "C'est un totem" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "C'est une peinture murale" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "De quel type de dispositif publicitaire s'agit-il ?", |                 "question": "De quel type de dispositif publicitaire s'agit-il ?", | ||||||
|  | @ -205,9 +205,6 @@ | ||||||
|                 "1": { |                 "1": { | ||||||
|                     "then": "Petit panneau" |                     "then": "Petit panneau" | ||||||
|                 }, |                 }, | ||||||
|                 "10": { |  | ||||||
|                     "then": "Peinture murale" |  | ||||||
|                 }, |  | ||||||
|                 "3": { |                 "3": { | ||||||
|                     "then": "Colonne" |                     "then": "Colonne" | ||||||
|                 }, |                 }, | ||||||
|  | @ -228,6 +225,9 @@ | ||||||
|                 }, |                 }, | ||||||
|                 "9": { |                 "9": { | ||||||
|                     "then": "Totem" |                     "then": "Totem" | ||||||
|  |                 }, | ||||||
|  |                 "10": { | ||||||
|  |                     "then": "Peinture murale" | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -328,15 +328,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "Peinture murale" |                         "then": "Peinture murale" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "Azulejo (faïence latine)" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "Carrelage" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "then": "Sculpture sur bois" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "Peinture" |                         "then": "Peinture" | ||||||
|                     }, |                     }, | ||||||
|  | @ -360,6 +351,15 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "Relief" |                         "then": "Relief" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "Azulejo (faïence latine)" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "Carrelage" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "then": "Sculpture sur bois" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "Quel est le type de cette œuvre d'art ?", |                 "question": "Quel est le type de cette œuvre d'art ?", | ||||||
|  | @ -2451,15 +2451,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "Cette piste cyclable est goudronée" |                         "then": "Cette piste cyclable est goudronée" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "Cette piste cyclable est faite en graviers fins" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "Cette piste cyclable est en cailloux" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "then": "Cette piste cyclable est faite en sol brut" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "Cette piste cyclable est asphaltée" |                         "then": "Cette piste cyclable est asphaltée" | ||||||
|                     }, |                     }, | ||||||
|  | @ -2483,6 +2474,15 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "Cette piste cyclable est faite en graviers" |                         "then": "Cette piste cyclable est faite en graviers" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "Cette piste cyclable est faite en graviers fins" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "Cette piste cyclable est en cailloux" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "then": "Cette piste cyclable est faite en sol brut" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "De quoi est faite la surface de la piste cyclable ?", |                 "question": "De quoi est faite la surface de la piste cyclable ?", | ||||||
|  | @ -2531,15 +2531,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "Cette piste cyclable est pavée" |                         "then": "Cette piste cyclable est pavée" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "Cette piste cyclable est faite en graviers fins" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "Cette piste cyclable est en cailloux" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "then": "Cette piste cyclable est faite en sol brut" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "Cette piste cyclable est asphaltée" |                         "then": "Cette piste cyclable est asphaltée" | ||||||
|                     }, |                     }, | ||||||
|  | @ -2563,6 +2554,15 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "Cette piste cyclable est faite en graviers" |                         "then": "Cette piste cyclable est faite en graviers" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "Cette piste cyclable est faite en graviers fins" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "Cette piste cyclable est en cailloux" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "then": "Cette piste cyclable est faite en sol brut" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "De quel materiel est faite cette rue ?", |                 "question": "De quel materiel est faite cette rue ?", | ||||||
|  | @ -3412,21 +3412,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "C'est une friterie" |                         "then": "C'est une friterie" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "Des plats chinois sont servis ici" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "Des plats grecs sont servis ici" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "then": "Des plats indiens sont servis ici" |  | ||||||
|                     }, |  | ||||||
|                     "13": { |  | ||||||
|                         "then": "Des plats turcs sont servis ici" |  | ||||||
|                     }, |  | ||||||
|                     "14": { |  | ||||||
|                         "then": "Des plats thaïlandais sont servis ici" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "Restaurant Italien" |                         "then": "Restaurant Italien" | ||||||
|                     }, |                     }, | ||||||
|  | @ -3450,6 +3435,21 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "Des plats français sont servis ici" |                         "then": "Des plats français sont servis ici" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "Des plats chinois sont servis ici" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "Des plats grecs sont servis ici" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "then": "Des plats indiens sont servis ici" | ||||||
|  |                     }, | ||||||
|  |                     "13": { | ||||||
|  |                         "then": "Des plats turcs sont servis ici" | ||||||
|  |                     }, | ||||||
|  |                     "14": { | ||||||
|  |                         "then": "Des plats thaïlandais sont servis ici" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "Quelle type de nourriture est servie ici ?", |                 "question": "Quelle type de nourriture est servie ici ?", | ||||||
|  | @ -3843,11 +3843,11 @@ | ||||||
|             }, |             }, | ||||||
|             "room-type": { |             "room-type": { | ||||||
|                 "mappings": { |                 "mappings": { | ||||||
|                     "14": { |  | ||||||
|                         "then": "C'est un bureau" |  | ||||||
|                     }, |  | ||||||
|                     "4": { |                     "4": { | ||||||
|                         "then": "C'est une salle de classe" |                         "then": "C'est une salle de classe" | ||||||
|  |                     }, | ||||||
|  |                     "14": { | ||||||
|  |                         "then": "C'est un bureau" | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | @ -4128,18 +4128,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "C'est une plaque" |                         "then": "C'est une plaque" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "C'est une croix" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "C'est une plaque bleue (spécifique aux pays anglo-saxons)" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "then": "C'est un char historique, placé de manière permanente dans l'espace public comme mémorial" |  | ||||||
|                     }, |  | ||||||
|                     "13": { |  | ||||||
|                         "then": "C'est un arbre du souvenir" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "C'est un banc commémoratif" |                         "then": "C'est un banc commémoratif" | ||||||
|                     }, |                     }, | ||||||
|  | @ -4163,6 +4151,18 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "C'est un obélisque" |                         "then": "C'est un obélisque" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "C'est une croix" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "C'est une plaque bleue (spécifique aux pays anglo-saxons)" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "then": "C'est un char historique, placé de manière permanente dans l'espace public comme mémorial" | ||||||
|  |                     }, | ||||||
|  |                     "13": { | ||||||
|  |                         "then": "C'est un arbre du souvenir" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "C'est un mémorial de guerre", |                 "question": "C'est un mémorial de guerre", | ||||||
|  | @ -5254,6 +5254,30 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "question": "Recyclage de piles et batteries domestiques" |                         "question": "Recyclage de piles et batteries domestiques" | ||||||
|                     }, |                     }, | ||||||
|  |                     "2": { | ||||||
|  |                         "question": "Recyclage d'emballage de boissons" | ||||||
|  |                     }, | ||||||
|  |                     "3": { | ||||||
|  |                         "question": "Recyclage de boites de conserve et de canettes" | ||||||
|  |                     }, | ||||||
|  |                     "4": { | ||||||
|  |                         "question": "Recyclage de vêtements" | ||||||
|  |                     }, | ||||||
|  |                     "5": { | ||||||
|  |                         "question": "Recyclage des huiles de friture" | ||||||
|  |                     }, | ||||||
|  |                     "6": { | ||||||
|  |                         "question": "Recyclage des huiles de moteur" | ||||||
|  |                     }, | ||||||
|  |                     "7": { | ||||||
|  |                         "question": "Recyclage des lampes fluorescentes" | ||||||
|  |                     }, | ||||||
|  |                     "8": { | ||||||
|  |                         "question": "Recyclage des déchets verts" | ||||||
|  |                     }, | ||||||
|  |                     "9": { | ||||||
|  |                         "question": "Recyclage des bouteilles en verre et des bocaux" | ||||||
|  |                     }, | ||||||
|                     "10": { |                     "10": { | ||||||
|                         "question": "Recyclage de tout type de verre" |                         "question": "Recyclage de tout type de verre" | ||||||
|                     }, |                     }, | ||||||
|  | @ -5284,35 +5308,11 @@ | ||||||
|                     "19": { |                     "19": { | ||||||
|                         "question": "Recyclage des autres déchets" |                         "question": "Recyclage des autres déchets" | ||||||
|                     }, |                     }, | ||||||
|                     "2": { |  | ||||||
|                         "question": "Recyclage d'emballage de boissons" |  | ||||||
|                     }, |  | ||||||
|                     "20": { |                     "20": { | ||||||
|                         "question": "Recyclage des cartouches d'imprimante" |                         "question": "Recyclage des cartouches d'imprimante" | ||||||
|                     }, |                     }, | ||||||
|                     "21": { |                     "21": { | ||||||
|                         "question": "Recyclage des vélos" |                         "question": "Recyclage des vélos" | ||||||
|                     }, |  | ||||||
|                     "3": { |  | ||||||
|                         "question": "Recyclage de boites de conserve et de canettes" |  | ||||||
|                     }, |  | ||||||
|                     "4": { |  | ||||||
|                         "question": "Recyclage de vêtements" |  | ||||||
|                     }, |  | ||||||
|                     "5": { |  | ||||||
|                         "question": "Recyclage des huiles de friture" |  | ||||||
|                     }, |  | ||||||
|                     "6": { |  | ||||||
|                         "question": "Recyclage des huiles de moteur" |  | ||||||
|                     }, |  | ||||||
|                     "7": { |  | ||||||
|                         "question": "Recyclage des lampes fluorescentes" |  | ||||||
|                     }, |  | ||||||
|                     "8": { |  | ||||||
|                         "question": "Recyclage des déchets verts" |  | ||||||
|                     }, |  | ||||||
|                     "9": { |  | ||||||
|                         "question": "Recyclage des bouteilles en verre et des bocaux" |  | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             }, |             }, | ||||||
|  | @ -5375,6 +5375,30 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "Les briques alimentaires en carton peuvent être recyclées ici" |                         "then": "Les briques alimentaires en carton peuvent être recyclées ici" | ||||||
|                     }, |                     }, | ||||||
|  |                     "2": { | ||||||
|  |                         "then": "Les boites de conserve et canettes peuvent être recyclées ici" | ||||||
|  |                     }, | ||||||
|  |                     "3": { | ||||||
|  |                         "then": "Les vêtements peuvent être recyclés ici" | ||||||
|  |                     }, | ||||||
|  |                     "4": { | ||||||
|  |                         "then": "Les huiles de friture peuvent être recyclées ici" | ||||||
|  |                     }, | ||||||
|  |                     "5": { | ||||||
|  |                         "then": "Les huiles de moteur peuvent être recyclées ici" | ||||||
|  |                     }, | ||||||
|  |                     "6": { | ||||||
|  |                         "then": "Les lampes fluorescentes peuvent être recyclées ici" | ||||||
|  |                     }, | ||||||
|  |                     "7": { | ||||||
|  |                         "then": "Les déchets verts peuvent être recyclés ici" | ||||||
|  |                     }, | ||||||
|  |                     "8": { | ||||||
|  |                         "then": "Les déchets organiques peuvent être recyclés ici" | ||||||
|  |                     }, | ||||||
|  |                     "9": { | ||||||
|  |                         "then": "Les bouteilles en verre et bocaux peuvent être recyclés ici" | ||||||
|  |                     }, | ||||||
|                     "10": { |                     "10": { | ||||||
|                         "then": "Tout type de verre peut être recyclé ici" |                         "then": "Tout type de verre peut être recyclé ici" | ||||||
|                     }, |                     }, | ||||||
|  | @ -5402,9 +5426,6 @@ | ||||||
|                     "19": { |                     "19": { | ||||||
|                         "then": "La ferraille peut être recyclée ici" |                         "then": "La ferraille peut être recyclée ici" | ||||||
|                     }, |                     }, | ||||||
|                     "2": { |  | ||||||
|                         "then": "Les boites de conserve et canettes peuvent être recyclées ici" |  | ||||||
|                     }, |  | ||||||
|                     "20": { |                     "20": { | ||||||
|                         "then": "Les chaussures peuvent être recyclées ici" |                         "then": "Les chaussures peuvent être recyclées ici" | ||||||
|                     }, |                     }, | ||||||
|  | @ -5422,27 +5443,6 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "25": { |                     "25": { | ||||||
|                         "then": "Les vélos peuvent être recyclés ici" |                         "then": "Les vélos peuvent être recyclés ici" | ||||||
|                     }, |  | ||||||
|                     "3": { |  | ||||||
|                         "then": "Les vêtements peuvent être recyclés ici" |  | ||||||
|                     }, |  | ||||||
|                     "4": { |  | ||||||
|                         "then": "Les huiles de friture peuvent être recyclées ici" |  | ||||||
|                     }, |  | ||||||
|                     "5": { |  | ||||||
|                         "then": "Les huiles de moteur peuvent être recyclées ici" |  | ||||||
|                     }, |  | ||||||
|                     "6": { |  | ||||||
|                         "then": "Les lampes fluorescentes peuvent être recyclées ici" |  | ||||||
|                     }, |  | ||||||
|                     "7": { |  | ||||||
|                         "then": "Les déchets verts peuvent être recyclés ici" |  | ||||||
|                     }, |  | ||||||
|                     "8": { |  | ||||||
|                         "then": "Les déchets organiques peuvent être recyclés ici" |  | ||||||
|                     }, |  | ||||||
|                     "9": { |  | ||||||
|                         "then": "Les bouteilles en verre et bocaux peuvent être recyclés ici" |  | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "Que peut-on recycler ici ?" |                 "question": "Que peut-on recycler ici ?" | ||||||
|  | @ -6891,27 +6891,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "question": "Vente de boissons" |                         "question": "Vente de boissons" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "question": "Vente de lait" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "question": "Vente de pain" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "question": "Vente d'œufs" |  | ||||||
|                     }, |  | ||||||
|                     "13": { |  | ||||||
|                         "question": "Vente de fromage" |  | ||||||
|                     }, |  | ||||||
|                     "14": { |  | ||||||
|                         "question": "Vente de miel" |  | ||||||
|                     }, |  | ||||||
|                     "15": { |  | ||||||
|                         "question": "Vente de pommes de terre" |  | ||||||
|                     }, |  | ||||||
|                     "19": { |  | ||||||
|                         "question": "Vente de fleurs" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "question": "Ventre de confiseries" |                         "question": "Ventre de confiseries" | ||||||
|                     }, |                     }, | ||||||
|  | @ -6935,6 +6914,27 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "question": "Vente de chambres à air pour vélo" |                         "question": "Vente de chambres à air pour vélo" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "question": "Vente de lait" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "question": "Vente de pain" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "question": "Vente d'œufs" | ||||||
|  |                     }, | ||||||
|  |                     "13": { | ||||||
|  |                         "question": "Vente de fromage" | ||||||
|  |                     }, | ||||||
|  |                     "14": { | ||||||
|  |                         "question": "Vente de miel" | ||||||
|  |                     }, | ||||||
|  |                     "15": { | ||||||
|  |                         "question": "Vente de pommes de terre" | ||||||
|  |                     }, | ||||||
|  |                     "19": { | ||||||
|  |                         "question": "Vente de fleurs" | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | @ -6992,24 +6992,6 @@ | ||||||
|                     "1": { |                     "1": { | ||||||
|                         "then": "Vent des confiseries" |                         "then": "Vent des confiseries" | ||||||
|                     }, |                     }, | ||||||
|                     "10": { |  | ||||||
|                         "then": "Vent du pain" |  | ||||||
|                     }, |  | ||||||
|                     "11": { |  | ||||||
|                         "then": "Vent des œufs" |  | ||||||
|                     }, |  | ||||||
|                     "12": { |  | ||||||
|                         "then": "Vent du fromage" |  | ||||||
|                     }, |  | ||||||
|                     "13": { |  | ||||||
|                         "then": "Vent du miel" |  | ||||||
|                     }, |  | ||||||
|                     "14": { |  | ||||||
|                         "then": "Vent des pommes de terre" |  | ||||||
|                     }, |  | ||||||
|                     "18": { |  | ||||||
|                         "then": "Vent des fleurs" |  | ||||||
|                     }, |  | ||||||
|                     "2": { |                     "2": { | ||||||
|                         "then": "Vent de la nourriture" |                         "then": "Vent de la nourriture" | ||||||
|                     }, |                     }, | ||||||
|  | @ -7033,6 +7015,24 @@ | ||||||
|                     }, |                     }, | ||||||
|                     "9": { |                     "9": { | ||||||
|                         "then": "Vent du lait" |                         "then": "Vent du lait" | ||||||
|  |                     }, | ||||||
|  |                     "10": { | ||||||
|  |                         "then": "Vent du pain" | ||||||
|  |                     }, | ||||||
|  |                     "11": { | ||||||
|  |                         "then": "Vent des œufs" | ||||||
|  |                     }, | ||||||
|  |                     "12": { | ||||||
|  |                         "then": "Vent du fromage" | ||||||
|  |                     }, | ||||||
|  |                     "13": { | ||||||
|  |                         "then": "Vent du miel" | ||||||
|  |                     }, | ||||||
|  |                     "14": { | ||||||
|  |                         "then": "Vent des pommes de terre" | ||||||
|  |                     }, | ||||||
|  |                     "18": { | ||||||
|  |                         "then": "Vent des fleurs" | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "question": "Que vent ce distributeur ?", |                 "question": "Que vent ce distributeur ?", | ||||||
|  | @ -7235,4 +7235,4 @@ | ||||||
|             "render": "éolienne" |             "render": "éolienne" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -820,33 +820,6 @@ | ||||||
|     "onwheels": { |     "onwheels": { | ||||||
|         "description": "På dette kort vises steder, der er offentligt tilgængelige for kørestolsbrugere, og de kan nemt tilføjes", |         "description": "På dette kort vises steder, der er offentligt tilgængelige for kørestolsbrugere, og de kan nemt tilføjes", | ||||||
|         "layers": { |         "layers": { | ||||||
|             "19": { |  | ||||||
|                 "override": { |  | ||||||
|                     "=title": { |  | ||||||
|                         "render": "Statistikker" |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "20": { |  | ||||||
|                 "override": { |  | ||||||
|                     "+tagRenderings": { |  | ||||||
|                         "0": { |  | ||||||
|                             "render": { |  | ||||||
|                                 "special": { |  | ||||||
|                                     "text": "Importere" |  | ||||||
|                                 } |  | ||||||
|                             } |  | ||||||
|                         }, |  | ||||||
|                         "1": { |  | ||||||
|                             "render": { |  | ||||||
|                                 "special": { |  | ||||||
|                                     "message": "Tilføj alle de foreslåede tags" |  | ||||||
|                                 } |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "4": { |             "4": { | ||||||
|                 "override": { |                 "override": { | ||||||
|                     "filter": { |                     "filter": { | ||||||
|  | @ -889,6 +862,33 @@ | ||||||
|                 "override": { |                 "override": { | ||||||
|                     "name": "Handikapparkeringspladser" |                     "name": "Handikapparkeringspladser" | ||||||
|                 } |                 } | ||||||
|  |             }, | ||||||
|  |             "19": { | ||||||
|  |                 "override": { | ||||||
|  |                     "=title": { | ||||||
|  |                         "render": "Statistikker" | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "20": { | ||||||
|  |                 "override": { | ||||||
|  |                     "+tagRenderings": { | ||||||
|  |                         "0": { | ||||||
|  |                             "render": { | ||||||
|  |                                 "special": { | ||||||
|  |                                     "text": "Importere" | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         }, | ||||||
|  |                         "1": { | ||||||
|  |                             "render": { | ||||||
|  |                                 "special": { | ||||||
|  |                                     "message": "Tilføj alle de foreslåede tags" | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|  | @ -1041,6 +1041,9 @@ | ||||||
|     }, |     }, | ||||||
|     "stations": { |     "stations": { | ||||||
|         "layers": { |         "layers": { | ||||||
|  |             "3": { | ||||||
|  |                 "name": "Togstationer" | ||||||
|  |             }, | ||||||
|             "16": { |             "16": { | ||||||
|                 "name": "Afgangstavler", |                 "name": "Afgangstavler", | ||||||
|                 "presets": { |                 "presets": { | ||||||
|  | @ -1056,9 +1059,6 @@ | ||||||
|                 "title": { |                 "title": { | ||||||
|                     "render": "Afgangstavle" |                     "render": "Afgangstavle" | ||||||
|                 } |                 } | ||||||
|             }, |  | ||||||
|             "3": { |  | ||||||
|                 "name": "Togstationer" |  | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "title": "Togstationer" |         "title": "Togstationer" | ||||||
|  | @ -1153,4 +1153,4 @@ | ||||||
|         "shortDescription": "Et kort over skraldespande", |         "shortDescription": "Et kort over skraldespande", | ||||||
|         "title": "Skraldespande" |         "title": "Skraldespande" | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -868,33 +868,6 @@ | ||||||
|     "onwheels": { |     "onwheels": { | ||||||
|         "description": "Sur cette carte nous pouvons voir et ajouter les différents endroits publiques accessibles aux chaises roulantes", |         "description": "Sur cette carte nous pouvons voir et ajouter les différents endroits publiques accessibles aux chaises roulantes", | ||||||
|         "layers": { |         "layers": { | ||||||
|             "19": { |  | ||||||
|                 "override": { |  | ||||||
|                     "=title": { |  | ||||||
|                         "render": "Statistiques" |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "20": { |  | ||||||
|                 "override": { |  | ||||||
|                     "+tagRenderings": { |  | ||||||
|                         "0": { |  | ||||||
|                             "render": { |  | ||||||
|                                 "special": { |  | ||||||
|                                     "text": "Importation" |  | ||||||
|                                 } |  | ||||||
|                             } |  | ||||||
|                         }, |  | ||||||
|                         "1": { |  | ||||||
|                             "render": { |  | ||||||
|                                 "special": { |  | ||||||
|                                     "message": "Ajouter tous les attributs suggérés" |  | ||||||
|                                 } |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "4": { |             "4": { | ||||||
|                 "override": { |                 "override": { | ||||||
|                     "filter": { |                     "filter": { | ||||||
|  | @ -937,6 +910,33 @@ | ||||||
|                 "override": { |                 "override": { | ||||||
|                     "name": "Places de stationnement pour personnes handicapées" |                     "name": "Places de stationnement pour personnes handicapées" | ||||||
|                 } |                 } | ||||||
|  |             }, | ||||||
|  |             "19": { | ||||||
|  |                 "override": { | ||||||
|  |                     "=title": { | ||||||
|  |                         "render": "Statistiques" | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "20": { | ||||||
|  |                 "override": { | ||||||
|  |                     "+tagRenderings": { | ||||||
|  |                         "0": { | ||||||
|  |                             "render": { | ||||||
|  |                                 "special": { | ||||||
|  |                                     "text": "Importation" | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         }, | ||||||
|  |                         "1": { | ||||||
|  |                             "render": { | ||||||
|  |                                 "special": { | ||||||
|  |                                     "message": "Ajouter tous les attributs suggérés" | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "title": "OnWheels" |         "title": "OnWheels" | ||||||
|  | @ -1100,6 +1100,10 @@ | ||||||
|     "stations": { |     "stations": { | ||||||
|         "description": "Voir, modifier et ajouter des détails à une gare ferroviaire", |         "description": "Voir, modifier et ajouter des détails à une gare ferroviaire", | ||||||
|         "layers": { |         "layers": { | ||||||
|  |             "3": { | ||||||
|  |                 "description": "Couche montrant les gares", | ||||||
|  |                 "name": "Gares ferroviaires" | ||||||
|  |             }, | ||||||
|             "16": { |             "16": { | ||||||
|                 "description": "Panneau affichant les trains au départ depuis cette gare", |                 "description": "Panneau affichant les trains au départ depuis cette gare", | ||||||
|                 "name": "Panneaux des départs", |                 "name": "Panneaux des départs", | ||||||
|  | @ -1131,10 +1135,6 @@ | ||||||
|                 "title": { |                 "title": { | ||||||
|                     "render": "Tableau des départs" |                     "render": "Tableau des départs" | ||||||
|                 } |                 } | ||||||
|             }, |  | ||||||
|             "3": { |  | ||||||
|                 "description": "Couche montrant les gares", |  | ||||||
|                 "name": "Gares ferroviaires" |  | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "title": "Gares ferroviaires" |         "title": "Gares ferroviaires" | ||||||
|  | @ -1256,4 +1256,4 @@ | ||||||
|         "shortDescription": "Une carte des poubelles", |         "shortDescription": "Une carte des poubelles", | ||||||
|         "title": "Poubelles" |         "title": "Poubelles" | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -4,24 +4,25 @@ export interface Handler { | ||||||
|     mustMatch: string | RegExp |     mustMatch: string | RegExp | ||||||
|     mimetype: string |     mimetype: string | ||||||
|     addHeaders?: Record<string, string> |     addHeaders?: Record<string, string> | ||||||
|     handle: (path: string, queryParams: URLSearchParams, req: http.IncomingMessage) => Promise<string> |     handle: ( | ||||||
| 
 |         path: string, | ||||||
|  |         queryParams: URLSearchParams, | ||||||
|  |         req: http.IncomingMessage | ||||||
|  |     ) => Promise<string> | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| class ServerUtils { | class ServerUtils { | ||||||
| 
 |  | ||||||
|     public static getBody(req: http.IncomingMessage): Promise<string> { |     public static getBody(req: http.IncomingMessage): Promise<string> { | ||||||
|         return new Promise<string>((resolve) => { |         return new Promise<string>((resolve) => { | ||||||
|             let body = ''; |             let body = "" | ||||||
|             req.on('data', (chunk) => { |             req.on("data", (chunk) => { | ||||||
|                 body += chunk; |                 body += chunk | ||||||
|             }); |             }) | ||||||
|             req.on('end', () => { |             req.on("end", () => { | ||||||
|                 resolve(body) |                 resolve(body) | ||||||
|             }); |             }) | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export class Server { | export class Server { | ||||||
|  |  | ||||||
|  | @ -17,25 +17,34 @@ class ServerErrorReport extends Script { | ||||||
|             console.log("Created this directory") |             console.log("Created this directory") | ||||||
|         } |         } | ||||||
|         let errorReport = 0 |         let errorReport = 0 | ||||||
|         new Server(2348, {}, |         new Server(2348, {}, [ | ||||||
|             [<Handler>{ |             <Handler>{ | ||||||
|                 mustMatch: "report", |                 mustMatch: "report", | ||||||
|                 mimetype: "application/json", |                 mimetype: "application/json", | ||||||
|                 handle: async (_, queryParams, req, body) => { |                 handle: async (_, queryParams, req, body) => { | ||||||
|                     if (!body) { |                     if (!body) { | ||||||
|                         throw "{\"error\": \"No body; use a post request\"}" |                         throw '{"error": "No body; use a post request"}' | ||||||
|                     } |                     } | ||||||
|                     console.log(body) |                     console.log(body) | ||||||
|                     const ip = <string>req.headers["x-forwarded-for"] |                     const ip = <string>req.headers["x-forwarded-for"] | ||||||
|                     const d = new Date() |                     const d = new Date() | ||||||
|                     const date = d.toISOString() |                     const date = d.toISOString() | ||||||
|                     const file = logDirectory + "/" + d.getUTCFullYear() + "_" + d.getUTCMonth() + "_" + d.getUTCDay() + ".lines.json" |                     const file = | ||||||
|                     try{ |                         logDirectory + | ||||||
|  |                         "/" + | ||||||
|  |                         d.getUTCFullYear() + | ||||||
|  |                         "_" + | ||||||
|  |                         d.getUTCMonth() + | ||||||
|  |                         "_" + | ||||||
|  |                         d.getUTCDay() + | ||||||
|  |                         ".lines.json" | ||||||
|  |                     try { | ||||||
|                         body = JSON.parse(body) |                         body = JSON.parse(body) | ||||||
|                     }catch (e) { |                     } catch (e) { | ||||||
|                         // could not parse, we'll save it as is
 |                         // could not parse, we'll save it as is
 | ||||||
|                     } |                     } | ||||||
|                     const contents = "\n"+JSON.stringify({ ip, index: errorReport, date, message: body }) |                     const contents = | ||||||
|  |                         "\n" + JSON.stringify({ ip, index: errorReport, date, message: body }) | ||||||
|                     if (!existsSync(file)) { |                     if (!existsSync(file)) { | ||||||
|                         writeFileSync(file, contents) |                         writeFileSync(file, contents) | ||||||
|                     } else { |                     } else { | ||||||
|  | @ -44,8 +53,8 @@ class ServerErrorReport extends Script { | ||||||
|                     errorReport++ |                     errorReport++ | ||||||
|                     return `{"status":"ok", "nr": ${errorReport}}` |                     return `{"status":"ok", "nr": ${errorReport}}` | ||||||
|                 }, |                 }, | ||||||
| 
 |             }, | ||||||
|             }]) |         ]) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -174,7 +174,7 @@ export default class DetermineLayout { | ||||||
|                 layerConfig.pointRendering |                 layerConfig.pointRendering | ||||||
|                     .flatMap((pr) => pr.marker) |                     .flatMap((pr) => pr.marker) | ||||||
|                     .map((iconSpec) => { |                     .map((iconSpec) => { | ||||||
|                         if(!iconSpec){ |                         if (!iconSpec) { | ||||||
|                             return undefined |                             return undefined | ||||||
|                         } |                         } | ||||||
|                         const icon = new TagRenderingConfig(<TagRenderingConfigJson>iconSpec.icon) |                         const icon = new TagRenderingConfig(<TagRenderingConfigJson>iconSpec.icon) | ||||||
|  | @ -192,7 +192,7 @@ export default class DetermineLayout { | ||||||
|                     }) |                     }) | ||||||
|             ).join(";") |             ).join(";") | ||||||
| 
 | 
 | ||||||
|             if(!icon){ |             if (!icon) { | ||||||
|                 icon = "./assets/svg/bug.svg" |                 icon = "./assets/svg/bug.svg" | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -72,7 +72,7 @@ export class LastClickFeatureSource implements FeatureSource { | ||||||
|             first_preset: this.renderings[0], |             first_preset: this.renderings[0], | ||||||
|             mouse_button: mode ?? "none", |             mouse_button: mode ?? "none", | ||||||
|             _usermode: this._usermode?.data, |             _usermode: this._usermode?.data, | ||||||
|             _addNewEnabled: (this._enabledAddMorePoints?.data ?? true) ? "yes" : "no" |             _addNewEnabled: this._enabledAddMorePoints?.data ?? true ? "yes" : "no", | ||||||
|         } |         } | ||||||
|         this.i++ |         this.i++ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -118,7 +118,7 @@ export default class MetaTagging { | ||||||
|         } |         } | ||||||
|         const state = this.state |         const state = this.state | ||||||
|         const layer = state.layout.getMatchingLayer(feature.properties) |         const layer = state.layout.getMatchingLayer(feature.properties) | ||||||
|         if(!layer){ |         if (!layer) { | ||||||
|             return |             return | ||||||
|         } |         } | ||||||
|         // Force update if the tags of the element changed
 |         // Force update if the tags of the element changed
 | ||||||
|  |  | ||||||
|  | @ -55,7 +55,7 @@ export class Changes { | ||||||
|             featureSwitches?: FeatureSwitchState |             featureSwitches?: FeatureSwitchState | ||||||
|         }, |         }, | ||||||
|         leftRightSensitive: boolean = false, |         leftRightSensitive: boolean = false, | ||||||
|         reportError?: (string: string | Error) => void, |         reportError?: (string: string | Error) => void | ||||||
|     ) { |     ) { | ||||||
|         this._leftRightSensitive = leftRightSensitive |         this._leftRightSensitive = leftRightSensitive | ||||||
|         // We keep track of all changes just as well
 |         // We keep track of all changes just as well
 | ||||||
|  | @ -70,7 +70,7 @@ export class Changes { | ||||||
|             state.osmConnection, |             state.osmConnection, | ||||||
|             state.featurePropertiesStore, |             state.featurePropertiesStore, | ||||||
|             this, |             this, | ||||||
|             e => this._reportError(e) |             (e) => this._reportError(e) | ||||||
|         ) |         ) | ||||||
|         this.historicalUserLocations = state.historicalUserLocations |         this.historicalUserLocations = state.historicalUserLocations | ||||||
| 
 | 
 | ||||||
|  | @ -523,9 +523,13 @@ export class Changes { | ||||||
|                     const osmObj = await downloader.DownloadObjectAsync(id, 0) |                     const osmObj = await downloader.DownloadObjectAsync(id, 0) | ||||||
|                     return { id, osmObj } |                     return { id, osmObj } | ||||||
|                 } catch (e) { |                 } catch (e) { | ||||||
|                     this._reportError( "Could not download OSM-object"+ |                     this._reportError( | ||||||
|                         id+ |                         "Could not download OSM-object" + | ||||||
|                         " dropping it from the changes (" + e + ")") |                             id + | ||||||
|  |                             " dropping it from the changes (" + | ||||||
|  |                             e + | ||||||
|  |                             ")" | ||||||
|  |                     ) | ||||||
|                     console.error( |                     console.error( | ||||||
|                         "Could not download OSM-object", |                         "Could not download OSM-object", | ||||||
|                         id, |                         id, | ||||||
|  |  | ||||||
|  | @ -26,7 +26,7 @@ export class ChangesetHandler { | ||||||
|      * @private |      * @private | ||||||
|      */ |      */ | ||||||
|     private readonly _remappings = new Map<string, string>() |     private readonly _remappings = new Map<string, string>() | ||||||
|     private readonly _reportError: (e: (string | Error)) => void |     private readonly _reportError: (e: string | Error) => void | ||||||
| 
 | 
 | ||||||
|     constructor( |     constructor( | ||||||
|         dryRun: Store<boolean>, |         dryRun: Store<boolean>, | ||||||
|  | @ -151,10 +151,10 @@ export class ChangesetHandler { | ||||||
|                     await this.UpdateTags(csId, extraMetaTags) |                     await this.UpdateTags(csId, extraMetaTags) | ||||||
|                 } |                 } | ||||||
|             } catch (e) { |             } catch (e) { | ||||||
|                 if(this._reportError){ |                 if (this._reportError) { | ||||||
|                     this._reportError(e) |                     this._reportError(e) | ||||||
|                 } |                 } | ||||||
|                 console.warn("Could not open/upload changeset due to ", e,"trying t") |                 console.warn("Could not open/upload changeset due to ", e, "trying t") | ||||||
|                 openChangeset.setData(undefined) |                 openChangeset.setData(undefined) | ||||||
| 
 | 
 | ||||||
|                 throw e |                 throw e | ||||||
|  | @ -186,7 +186,7 @@ export class ChangesetHandler { | ||||||
|                 ) |                 ) | ||||||
|                 await this.UpdateTags(csId, rewrittenTags) |                 await this.UpdateTags(csId, rewrittenTags) | ||||||
|             } catch (e) { |             } catch (e) { | ||||||
|                 if(this._reportError){ |                 if (this._reportError) { | ||||||
|                     this._reportError(e) |                     this._reportError(e) | ||||||
|                 } |                 } | ||||||
|                 console.warn("Could not upload, changeset is probably closed: ", e) |                 console.warn("Could not upload, changeset is probably closed: ", e) | ||||||
|  |  | ||||||
|  | @ -18,14 +18,14 @@ class FeatureSwitchUtils { | ||||||
|             key, |             key, | ||||||
|             "" + defaultValue, |             "" + defaultValue, | ||||||
|             documentation, |             documentation, | ||||||
|             { stackOffset: -1 }, |             { stackOffset: -1 } | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         // It takes the current layout, extracts the default value for this query parameter. A query parameter event source is then retrieved and flattened
 |         // It takes the current layout, extracts the default value for this query parameter. A query parameter event source is then retrieved and flattened
 | ||||||
|         return queryParam.sync( |         return queryParam.sync( | ||||||
|             (str) => (str === undefined ? defaultValue : str !== "false"), |             (str) => (str === undefined ? defaultValue : str !== "false"), | ||||||
|             [], |             [], | ||||||
|             (b) => (b == defaultValue ? undefined : "" + b), |             (b) => (b == defaultValue ? undefined : "" + b) | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -37,7 +37,7 @@ export class OsmConnectionFeatureSwitches { | ||||||
|         this.featureSwitchFakeUser = QueryParameters.GetBooleanQueryParameter( |         this.featureSwitchFakeUser = QueryParameters.GetBooleanQueryParameter( | ||||||
|             "fake-user", |             "fake-user", | ||||||
|             false, |             false, | ||||||
|             "If true, 'dryrun' mode is activated and a fake user account is loaded", |             "If true, 'dryrun' mode is activated and a fake user account is loaded" | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -73,11 +73,9 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | ||||||
|         super() |         super() | ||||||
|         this.layoutToUse = layoutToUse |         this.layoutToUse = layoutToUse | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         const legacyRewrite: Record<string, string | string[]> = { |         const legacyRewrite: Record<string, string | string[]> = { | ||||||
|             "fs-userbadge": "fs-enable-login", |             "fs-userbadge": "fs-enable-login", | ||||||
|             "fs-layers": ["fs-filter", "fs-background"], |             "fs-layers": ["fs-filter", "fs-background"], | ||||||
| 
 |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         for (const key in legacyRewrite) { |         for (const key in legacyRewrite) { | ||||||
|  | @ -100,14 +98,14 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | ||||||
|         this.featureSwitchEnableLogin = FeatureSwitchUtils.initSwitch( |         this.featureSwitchEnableLogin = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-enable-login", |             "fs-enable-login", | ||||||
|             layoutToUse?.enableUserBadge ?? true, |             layoutToUse?.enableUserBadge ?? true, | ||||||
|             "Disables/Enables logging in and thus disables editing all together. This effectively puts MapComplete into read-only mode.", |             "Disables/Enables logging in and thus disables editing all together. This effectively puts MapComplete into read-only mode." | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if (QueryParameters.wasInitialized("fs-userbadge")) { |             if (QueryParameters.wasInitialized("fs-userbadge")) { | ||||||
|                 // userbadge is the legacy name for 'enable-login'
 |                 // userbadge is the legacy name for 'enable-login'
 | ||||||
|                 this.featureSwitchEnableLogin.setData( |                 this.featureSwitchEnableLogin.setData( | ||||||
|                     QueryParameters.GetBooleanQueryParameter("fs-userbadge", undefined, "Legacy") |                     QueryParameters.GetBooleanQueryParameter("fs-userbadge", undefined, "Legacy") | ||||||
|                         .data, |                         .data | ||||||
|                 ) |                 ) | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -115,60 +113,60 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | ||||||
|         this.featureSwitchSearch = FeatureSwitchUtils.initSwitch( |         this.featureSwitchSearch = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-search", |             "fs-search", | ||||||
|             layoutToUse?.enableSearch ?? true, |             layoutToUse?.enableSearch ?? true, | ||||||
|             "Disables/Enables the search bar", |             "Disables/Enables the search bar" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchBackgroundSelection = FeatureSwitchUtils.initSwitch( |         this.featureSwitchBackgroundSelection = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-background", |             "fs-background", | ||||||
|             layoutToUse?.enableBackgroundLayerSelection ?? true, |             layoutToUse?.enableBackgroundLayerSelection ?? true, | ||||||
|             "Disables/Enables the background layer control where a user can enable e.g. aerial imagery", |             "Disables/Enables the background layer control where a user can enable e.g. aerial imagery" | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.featureSwitchFilter = FeatureSwitchUtils.initSwitch( |         this.featureSwitchFilter = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-filter", |             "fs-filter", | ||||||
|             layoutToUse?.enableLayers ?? true, |             layoutToUse?.enableLayers ?? true, | ||||||
|             "Disables/Enables the filter view where a user can enable/disable MapComplete-layers or filter for certain properties", |             "Disables/Enables the filter view where a user can enable/disable MapComplete-layers or filter for certain properties" | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.featureSwitchWelcomeMessage = FeatureSwitchUtils.initSwitch( |         this.featureSwitchWelcomeMessage = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-welcome-message", |             "fs-welcome-message", | ||||||
|             true, |             true, | ||||||
|             "Disables/enables the help menu or welcome message", |             "Disables/enables the help menu or welcome message" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchCommunityIndex = FeatureSwitchUtils.initSwitch( |         this.featureSwitchCommunityIndex = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-community-index", |             "fs-community-index", | ||||||
|             this.featureSwitchEnableLogin.data, |             this.featureSwitchEnableLogin.data, | ||||||
|             "Disables/enables the button to get in touch with the community", |             "Disables/enables the button to get in touch with the community" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchExtraLinkEnabled = FeatureSwitchUtils.initSwitch( |         this.featureSwitchExtraLinkEnabled = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-iframe-popout", |             "fs-iframe-popout", | ||||||
|             true, |             true, | ||||||
|             "Disables/Enables the extraLink button. By default, if in iframe mode and the welcome message is hidden, a popout button to the full mapcomplete instance is shown instead (unless disabled with this switch or another extraLink button is enabled)", |             "Disables/Enables the extraLink button. By default, if in iframe mode and the welcome message is hidden, a popout button to the full mapcomplete instance is shown instead (unless disabled with this switch or another extraLink button is enabled)" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchBackToThemeOverview = FeatureSwitchUtils.initSwitch( |         this.featureSwitchBackToThemeOverview = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-homepage-link", |             "fs-homepage-link", | ||||||
|             layoutToUse?.enableMoreQuests ?? true, |             layoutToUse?.enableMoreQuests ?? true, | ||||||
|             "Disables/Enables the various links which go back to the index page with the theme overview", |             "Disables/Enables the various links which go back to the index page with the theme overview" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchShareScreen = FeatureSwitchUtils.initSwitch( |         this.featureSwitchShareScreen = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-share-screen", |             "fs-share-screen", | ||||||
|             layoutToUse?.enableShareScreen ?? true, |             layoutToUse?.enableShareScreen ?? true, | ||||||
|             "Disables/Enables the 'Share-screen'-tab in the welcome message", |             "Disables/Enables the 'Share-screen'-tab in the welcome message" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchGeolocation = FeatureSwitchUtils.initSwitch( |         this.featureSwitchGeolocation = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-geolocation", |             "fs-geolocation", | ||||||
|             layoutToUse?.enableGeolocation ?? true, |             layoutToUse?.enableGeolocation ?? true, | ||||||
|             "Disables/Enables the geolocation button", |             "Disables/Enables the geolocation button" | ||||||
|         ) |         ) | ||||||
|         this.featureSwitchShowAllQuestions = FeatureSwitchUtils.initSwitch( |         this.featureSwitchShowAllQuestions = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-all-questions", |             "fs-all-questions", | ||||||
|             layoutToUse?.enableShowAllQuestions ?? false, |             layoutToUse?.enableShowAllQuestions ?? false, | ||||||
|             "Always show all questions", |             "Always show all questions" | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.featureSwitchEnableExport = FeatureSwitchUtils.initSwitch( |         this.featureSwitchEnableExport = FeatureSwitchUtils.initSwitch( | ||||||
|             "fs-export", |             "fs-export", | ||||||
|             layoutToUse?.enableExportButton ?? true, |             layoutToUse?.enableExportButton ?? true, | ||||||
|             "Enable the export as GeoJSON and CSV button", |             "Enable the export as GeoJSON and CSV button" | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         let testingDefaultValue = false |         let testingDefaultValue = false | ||||||
|  | @ -182,59 +180,59 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | ||||||
|         this.featureSwitchIsTesting = QueryParameters.GetBooleanQueryParameter( |         this.featureSwitchIsTesting = QueryParameters.GetBooleanQueryParameter( | ||||||
|             "test", |             "test", | ||||||
|             testingDefaultValue, |             testingDefaultValue, | ||||||
|             "If true, 'dryrun' mode is activated. The app will behave as normal, except that changes to OSM will be printed onto the console instead of actually uploaded to osm.org", |             "If true, 'dryrun' mode is activated. The app will behave as normal, except that changes to OSM will be printed onto the console instead of actually uploaded to osm.org" | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.featureSwitchIsDebugging = QueryParameters.GetBooleanQueryParameter( |         this.featureSwitchIsDebugging = QueryParameters.GetBooleanQueryParameter( | ||||||
|             "debug", |             "debug", | ||||||
|             false, |             false, | ||||||
|             "If true, shows some extra debugging help such as all the available tags on every object", |             "If true, shows some extra debugging help such as all the available tags on every object" | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.featureSwitchMorePrivacy = QueryParameters.GetBooleanQueryParameter( |         this.featureSwitchMorePrivacy = QueryParameters.GetBooleanQueryParameter( | ||||||
|             "moreprivacy", |             "moreprivacy", | ||||||
|             layoutToUse.enableMorePrivacy, |             layoutToUse.enableMorePrivacy, | ||||||
|             "If true, the location distance indication will not be written to the changeset and other privacy enhancing measures might be taken.", |             "If true, the location distance indication will not be written to the changeset and other privacy enhancing measures might be taken." | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.overpassUrl = QueryParameters.GetQueryParameter( |         this.overpassUrl = QueryParameters.GetQueryParameter( | ||||||
|             "overpassUrl", |             "overpassUrl", | ||||||
|             (layoutToUse?.overpassUrl ?? Constants.defaultOverpassUrls).join(","), |             (layoutToUse?.overpassUrl ?? Constants.defaultOverpassUrls).join(","), | ||||||
|             "Point mapcomplete to a different overpass-instance. Example: https://overpass-api.de/api/interpreter", |             "Point mapcomplete to a different overpass-instance. Example: https://overpass-api.de/api/interpreter" | ||||||
|         ).sync( |         ).sync( | ||||||
|             (param) => param?.split(","), |             (param) => param?.split(","), | ||||||
|             [], |             [], | ||||||
|             (urls) => urls?.join(","), |             (urls) => urls?.join(",") | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.overpassTimeout = UIEventSource.asInt( |         this.overpassTimeout = UIEventSource.asInt( | ||||||
|             QueryParameters.GetQueryParameter( |             QueryParameters.GetQueryParameter( | ||||||
|                 "overpassTimeout", |                 "overpassTimeout", | ||||||
|                 "" + layoutToUse?.overpassTimeout, |                 "" + layoutToUse?.overpassTimeout, | ||||||
|                 "Set a different timeout (in seconds) for queries in overpass", |                 "Set a different timeout (in seconds) for queries in overpass" | ||||||
|             ), |             ) | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.overpassMaxZoom = UIEventSource.asFloat( |         this.overpassMaxZoom = UIEventSource.asFloat( | ||||||
|             QueryParameters.GetQueryParameter( |             QueryParameters.GetQueryParameter( | ||||||
|                 "overpassMaxZoom", |                 "overpassMaxZoom", | ||||||
|                 "" + layoutToUse?.overpassMaxZoom, |                 "" + layoutToUse?.overpassMaxZoom, | ||||||
|                 " point to switch between OSM-api and overpass", |                 " point to switch between OSM-api and overpass" | ||||||
|             ), |             ) | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.osmApiTileSize = UIEventSource.asInt( |         this.osmApiTileSize = UIEventSource.asInt( | ||||||
|             QueryParameters.GetQueryParameter( |             QueryParameters.GetQueryParameter( | ||||||
|                 "osmApiTileSize", |                 "osmApiTileSize", | ||||||
|                 "" + layoutToUse?.osmApiTileSize, |                 "" + layoutToUse?.osmApiTileSize, | ||||||
|                 "Tilesize when the OSM-API is used to fetch data within a BBOX", |                 "Tilesize when the OSM-API is used to fetch data within a BBOX" | ||||||
|             ), |             ) | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.backgroundLayerId = QueryParameters.GetQueryParameter( |         this.backgroundLayerId = QueryParameters.GetQueryParameter( | ||||||
|             "background", |             "background", | ||||||
|             layoutToUse?.defaultBackgroundId, |             layoutToUse?.defaultBackgroundId, | ||||||
|             "The id of the background layer to start with", |             "The id of the background layer to start with" | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -62,7 +62,9 @@ export default class UserRelatedState { | ||||||
|         "gps_location_retention" |         "gps_location_retention" | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     public readonly addNewFeatureMode = new UIEventSource<"button" | "button_click_right" | "button_click" | "click" | "click_right">("button_click_right") |     public readonly addNewFeatureMode = new UIEventSource< | ||||||
|  |         "button" | "button_click_right" | "button_click" | "click" | "click_right" | ||||||
|  |     >("button_click_right") | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Preferences as tags exposes many preferences and state properties as record. |      * Preferences as tags exposes many preferences and state properties as record. | ||||||
|  | @ -134,7 +136,7 @@ export default class UserRelatedState { | ||||||
|             "preferences-add-new-mode", |             "preferences-add-new-mode", | ||||||
|             "button_click_right", |             "button_click_right", | ||||||
|             { |             { | ||||||
|                 documentation: "How adding a new feature is done" |                 documentation: "How adding a new feature is done", | ||||||
|             } |             } | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|  | @ -297,7 +299,7 @@ export default class UserRelatedState { | ||||||
|             _applicationOpened: new Date().toISOString(), |             _applicationOpened: new Date().toISOString(), | ||||||
|             _supports_sharing: |             _supports_sharing: | ||||||
|                 typeof window === "undefined" ? "no" : window.navigator.share ? "yes" : "no", |                 typeof window === "undefined" ? "no" : window.navigator.share ? "yes" : "no", | ||||||
|             _iframe: Utils.isIframe ? "yes" : "no" |             _iframe: Utils.isIframe ? "yes" : "no", | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         for (const key in Constants.userJourney) { |         for (const key in Constants.userJourney) { | ||||||
|  |  | ||||||
|  | @ -1,14 +1,42 @@ | ||||||
| import { Utils } from "../../Utils" | import { Utils } from "../../Utils" | ||||||
| /** This code is autogenerated - do not edit. Edit ./assets/layers/usersettings/usersettings.json instead */ | /** This code is autogenerated - do not edit. Edit ./assets/layers/usersettings/usersettings.json instead */ | ||||||
| export class ThemeMetaTagging { | export class ThemeMetaTagging { | ||||||
|    public static readonly themeName = "usersettings" |     public static readonly themeName = "usersettings" | ||||||
| 
 | 
 | ||||||
|    public metaTaggging_for_usersettings(feat: {properties: Record<string, string>}) { |     public metaTaggging_for_usersettings(feat: { properties: Record<string, string> }) { | ||||||
|       Utils.AddLazyProperty(feat.properties, '_mastodon_candidate_md', () => feat.properties._description.match(/\[[^\]]*\]\((.*(mastodon|en.osm.town).*)\).*/)?.at(1) )  |         Utils.AddLazyProperty(feat.properties, "_mastodon_candidate_md", () => | ||||||
|       Utils.AddLazyProperty(feat.properties, '_d', () => feat.properties._description?.replace(/</g,'<')?.replace(/>/g,'>') ?? '' )  |             feat.properties._description | ||||||
|       Utils.AddLazyProperty(feat.properties, '_mastodon_candidate_a', () => (feat => {const e = document.createElement('div');e.innerHTML = feat.properties._d;return Array.from(e.getElementsByTagName("a")).filter(a => a.href.match(/mastodon|en.osm.town/) !== null)[0]?.href   }) (feat)  )  |                 .match(/\[[^\]]*\]\((.*(mastodon|en.osm.town).*)\).*/) | ||||||
|       Utils.AddLazyProperty(feat.properties, '_mastodon_link', () => (feat => {const e = document.createElement('div');e.innerHTML = feat.properties._d;return Array.from(e.getElementsByTagName("a")).filter(a => a.getAttribute("rel")?.indexOf('me') >= 0)[0]?.href})(feat)  )  |                 ?.at(1) | ||||||
|       Utils.AddLazyProperty(feat.properties, '_mastodon_candidate', () => feat.properties._mastodon_candidate_md ?? feat.properties._mastodon_candidate_a )  |         ) | ||||||
|       feat.properties['__current_backgroun'] = 'initial_value' |         Utils.AddLazyProperty( | ||||||
|    } |             feat.properties, | ||||||
| } |             "_d", | ||||||
|  |             () => feat.properties._description?.replace(/</g, "<")?.replace(/>/g, ">") ?? "" | ||||||
|  |         ) | ||||||
|  |         Utils.AddLazyProperty(feat.properties, "_mastodon_candidate_a", () => | ||||||
|  |             ((feat) => { | ||||||
|  |                 const e = document.createElement("div") | ||||||
|  |                 e.innerHTML = feat.properties._d | ||||||
|  |                 return Array.from(e.getElementsByTagName("a")).filter( | ||||||
|  |                     (a) => a.href.match(/mastodon|en.osm.town/) !== null | ||||||
|  |                 )[0]?.href | ||||||
|  |             })(feat) | ||||||
|  |         ) | ||||||
|  |         Utils.AddLazyProperty(feat.properties, "_mastodon_link", () => | ||||||
|  |             ((feat) => { | ||||||
|  |                 const e = document.createElement("div") | ||||||
|  |                 e.innerHTML = feat.properties._d | ||||||
|  |                 return Array.from(e.getElementsByTagName("a")).filter( | ||||||
|  |                     (a) => a.getAttribute("rel")?.indexOf("me") >= 0 | ||||||
|  |                 )[0]?.href | ||||||
|  |             })(feat) | ||||||
|  |         ) | ||||||
|  |         Utils.AddLazyProperty( | ||||||
|  |             feat.properties, | ||||||
|  |             "_mastodon_candidate", | ||||||
|  |             () => feat.properties._mastodon_candidate_md ?? feat.properties._mastodon_candidate_a | ||||||
|  |         ) | ||||||
|  |         feat.properties["__current_backgroun"] = "initial_value" | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -2,7 +2,11 @@ import LayoutConfig from "./ThemeConfig/LayoutConfig" | ||||||
| import { SpecialVisualizationState } from "../UI/SpecialVisualization" | import { SpecialVisualizationState } from "../UI/SpecialVisualization" | ||||||
| import { Changes } from "../Logic/Osm/Changes" | import { Changes } from "../Logic/Osm/Changes" | ||||||
| import { Store, UIEventSource } from "../Logic/UIEventSource" | import { Store, UIEventSource } from "../Logic/UIEventSource" | ||||||
| import { FeatureSource, IndexedFeatureSource, WritableFeatureSource } from "../Logic/FeatureSource/FeatureSource" | import { | ||||||
|  |     FeatureSource, | ||||||
|  |     IndexedFeatureSource, | ||||||
|  |     WritableFeatureSource, | ||||||
|  | } from "../Logic/FeatureSource/FeatureSource" | ||||||
| import { OsmConnection } from "../Logic/Osm/OsmConnection" | import { OsmConnection } from "../Logic/Osm/OsmConnection" | ||||||
| import { ExportableMap, MapProperties } from "./MapProperties" | import { ExportableMap, MapProperties } from "./MapProperties" | ||||||
| import LayerState from "../Logic/State/LayerState" | import LayerState from "../Logic/State/LayerState" | ||||||
|  | @ -46,7 +50,9 @@ import BackgroundLayerResetter from "../Logic/Actors/BackgroundLayerResetter" | ||||||
| import SaveFeatureSourceToLocalStorage from "../Logic/FeatureSource/Actors/SaveFeatureSourceToLocalStorage" | import SaveFeatureSourceToLocalStorage from "../Logic/FeatureSource/Actors/SaveFeatureSourceToLocalStorage" | ||||||
| import BBoxFeatureSource from "../Logic/FeatureSource/Sources/TouchesBboxFeatureSource" | import BBoxFeatureSource from "../Logic/FeatureSource/Sources/TouchesBboxFeatureSource" | ||||||
| import ThemeViewStateHashActor from "../Logic/Web/ThemeViewStateHashActor" | import ThemeViewStateHashActor from "../Logic/Web/ThemeViewStateHashActor" | ||||||
| import NoElementsInViewDetector, { FeatureViewState } from "../Logic/Actors/NoElementsInViewDetector" | import NoElementsInViewDetector, { | ||||||
|  |     FeatureViewState, | ||||||
|  | } from "../Logic/Actors/NoElementsInViewDetector" | ||||||
| import FilteredLayer from "./FilteredLayer" | import FilteredLayer from "./FilteredLayer" | ||||||
| import { PreferredRasterLayerSelector } from "../Logic/Actors/PreferredRasterLayerSelector" | import { PreferredRasterLayerSelector } from "../Logic/Actors/PreferredRasterLayerSelector" | ||||||
| import { ImageUploadManager } from "../Logic/ImageProviders/ImageUploadManager" | import { ImageUploadManager } from "../Logic/ImageProviders/ImageUploadManager" | ||||||
|  | @ -152,7 +158,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|         this.featureSwitches = new FeatureSwitchState(layout) |         this.featureSwitches = new FeatureSwitchState(layout) | ||||||
|         this.guistate = new MenuState( |         this.guistate = new MenuState( | ||||||
|             this.featureSwitches.featureSwitchWelcomeMessage.data, |             this.featureSwitches.featureSwitchWelcomeMessage.data, | ||||||
|             layout.id, |             layout.id | ||||||
|         ) |         ) | ||||||
|         this.map = new UIEventSource<MlMap>(undefined) |         this.map = new UIEventSource<MlMap>(undefined) | ||||||
|         const geolocationState = new GeoLocationState() |         const geolocationState = new GeoLocationState() | ||||||
|  | @ -168,14 +174,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             oauth_token: QueryParameters.GetQueryParameter( |             oauth_token: QueryParameters.GetQueryParameter( | ||||||
|                 "oauth_token", |                 "oauth_token", | ||||||
|                 undefined, |                 undefined, | ||||||
|                 "Used to complete the login", |                 "Used to complete the login" | ||||||
|             ), |             ), | ||||||
|         }) |         }) | ||||||
|         this.userRelatedState = new UserRelatedState( |         this.userRelatedState = new UserRelatedState( | ||||||
|             this.osmConnection, |             this.osmConnection, | ||||||
|             layout, |             layout, | ||||||
|             this.featureSwitches, |             this.featureSwitches, | ||||||
|             this.mapProperties, |             this.mapProperties | ||||||
|         ) |         ) | ||||||
|         this.userRelatedState.fixateNorth.addCallbackAndRunD((fixated) => { |         this.userRelatedState.fixateNorth.addCallbackAndRunD((fixated) => { | ||||||
|             this.mapProperties.allowRotating.setData(fixated !== "yes") |             this.mapProperties.allowRotating.setData(fixated !== "yes") | ||||||
|  | @ -186,13 +192,13 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             geolocationState, |             geolocationState, | ||||||
|             this.selectedElement, |             this.selectedElement, | ||||||
|             this.mapProperties, |             this.mapProperties, | ||||||
|             this.userRelatedState.gpsLocationHistoryRetentionTime, |             this.userRelatedState.gpsLocationHistoryRetentionTime | ||||||
|         ) |         ) | ||||||
|         this.geolocationControl = new GeolocationControlState(this.geolocation, this.mapProperties) |         this.geolocationControl = new GeolocationControlState(this.geolocation, this.mapProperties) | ||||||
| 
 | 
 | ||||||
|         this.availableLayers = AvailableRasterLayers.layersAvailableAt( |         this.availableLayers = AvailableRasterLayers.layersAvailableAt( | ||||||
|             this.mapProperties.location, |             this.mapProperties.location, | ||||||
|             this.osmConnection.isLoggedIn, |             this.osmConnection.isLoggedIn | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         const self = this |         const self = this | ||||||
|  | @ -204,7 +210,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                 const isDisplayed = QueryParameters.GetBooleanQueryParameter( |                 const isDisplayed = QueryParameters.GetBooleanQueryParameter( | ||||||
|                     "overlay-" + rasterInfo.id, |                     "overlay-" + rasterInfo.id, | ||||||
|                     rasterInfo.defaultState ?? true, |                     rasterInfo.defaultState ?? true, | ||||||
|                     "Wether or not overlayer layer " + rasterInfo.id + " is shown", |                     "Wether or not overlayer layer " + rasterInfo.id + " is shown" | ||||||
|                 ) |                 ) | ||||||
|                 const state = { isDisplayed } |                 const state = { isDisplayed } | ||||||
|                 overlayLayerStates.set(rasterInfo.id, state) |                 overlayLayerStates.set(rasterInfo.id, state) | ||||||
|  | @ -229,7 +235,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                 this.osmConnection.Backend(), |                 this.osmConnection.Backend(), | ||||||
|                 (id) => self.layerState.filteredLayers.get(id).isDisplayed, |                 (id) => self.layerState.filteredLayers.get(id).isDisplayed, | ||||||
|                 mvtAvailableLayers, |                 mvtAvailableLayers, | ||||||
|                 this.fullNodeDatabase, |                 this.fullNodeDatabase | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             let currentViewIndex = 0 |             let currentViewIndex = 0 | ||||||
|  | @ -247,7 +253,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                             id: "current_view_" + currentViewIndex, |                             id: "current_view_" + currentViewIndex, | ||||||
|                         }), |                         }), | ||||||
|                     ] |                     ] | ||||||
|                 }), |                 }) | ||||||
|             ) |             ) | ||||||
|             this.featuresInView = new BBoxFeatureSource(layoutSource, this.mapProperties.bounds) |             this.featuresInView = new BBoxFeatureSource(layoutSource, this.mapProperties.bounds) | ||||||
| 
 | 
 | ||||||
|  | @ -265,19 +271,19 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                     featureSwitches: this.featureSwitches, |                     featureSwitches: this.featureSwitches, | ||||||
|                 }, |                 }, | ||||||
|                 layout?.isLeftRightSensitive() ?? false, |                 layout?.isLeftRightSensitive() ?? false, | ||||||
|                 e => this.reportError(e), |                 (e) => this.reportError(e) | ||||||
|             ) |             ) | ||||||
|             this.historicalUserLocations = this.geolocation.historicalUserLocations |             this.historicalUserLocations = this.geolocation.historicalUserLocations | ||||||
|             this.newFeatures = new NewGeometryFromChangesFeatureSource( |             this.newFeatures = new NewGeometryFromChangesFeatureSource( | ||||||
|                 this.changes, |                 this.changes, | ||||||
|                 layoutSource, |                 layoutSource, | ||||||
|                 this.featureProperties, |                 this.featureProperties | ||||||
|             ) |             ) | ||||||
|             layoutSource.addSource(this.newFeatures) |             layoutSource.addSource(this.newFeatures) | ||||||
| 
 | 
 | ||||||
|             const perLayer = new PerLayerFeatureSourceSplitter( |             const perLayer = new PerLayerFeatureSourceSplitter( | ||||||
|                 Array.from(this.layerState.filteredLayers.values()).filter( |                 Array.from(this.layerState.filteredLayers.values()).filter( | ||||||
|                     (l) => l.layerDef?.source !== null, |                     (l) => l.layerDef?.source !== null | ||||||
|                 ), |                 ), | ||||||
|                 new ChangeGeometryApplicator(this.indexedFeatures, this.changes), |                 new ChangeGeometryApplicator(this.indexedFeatures, this.changes), | ||||||
|                 { |                 { | ||||||
|  | @ -288,10 +294,10 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                             "Got ", |                             "Got ", | ||||||
|                             features.length, |                             features.length, | ||||||
|                             "leftover features, such as", |                             "leftover features, such as", | ||||||
|                             features[0].properties, |                             features[0].properties | ||||||
|                         ) |                         ) | ||||||
|                     }, |                     }, | ||||||
|                 }, |                 } | ||||||
|             ) |             ) | ||||||
|             this.perLayer = perLayer.perLayer |             this.perLayer = perLayer.perLayer | ||||||
|         } |         } | ||||||
|  | @ -336,7 +342,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
| 
 | 
 | ||||||
|         this.osmObjectDownloader = new OsmObjectDownloader( |         this.osmObjectDownloader = new OsmObjectDownloader( | ||||||
|             this.osmConnection.Backend(), |             this.osmConnection.Backend(), | ||||||
|             this.changes, |             this.changes | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         this.perLayerFiltered = this.showNormalDataOn(this.map) |         this.perLayerFiltered = this.showNormalDataOn(this.map) | ||||||
|  | @ -347,7 +353,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                 currentZoom: this.mapProperties.zoom, |                 currentZoom: this.mapProperties.zoom, | ||||||
|                 layerState: this.layerState, |                 layerState: this.layerState, | ||||||
|                 bounds: this.visualFeedbackViewportBounds, |                 bounds: this.visualFeedbackViewportBounds, | ||||||
|             }, |             } | ||||||
|         ) |         ) | ||||||
|         this.hasDataInView = new NoElementsInViewDetector(this).hasFeatureInView |         this.hasDataInView = new NoElementsInViewDetector(this).hasFeatureInView | ||||||
|         this.imageUploadManager = new ImageUploadManager( |         this.imageUploadManager = new ImageUploadManager( | ||||||
|  | @ -355,7 +361,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             Imgur.singleton, |             Imgur.singleton, | ||||||
|             this.featureProperties, |             this.featureProperties, | ||||||
|             this.osmConnection, |             this.osmConnection, | ||||||
|             this.changes, |             this.changes | ||||||
|         ) |         ) | ||||||
|         this.favourites = new FavouritesFeatureSource(this) |         this.favourites = new FavouritesFeatureSource(this) | ||||||
| 
 | 
 | ||||||
|  | @ -398,7 +404,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                 LayoutSource.fromCacheZoomLevel, |                 LayoutSource.fromCacheZoomLevel, | ||||||
|                 fs, |                 fs, | ||||||
|                 this.featureProperties, |                 this.featureProperties, | ||||||
|                 fs.layer.layerDef.maxAgeOfCache, |                 fs.layer.layerDef.maxAgeOfCache | ||||||
|             ) |             ) | ||||||
|             toLocalStorage.set(layerId, storage) |             toLocalStorage.set(layerId, storage) | ||||||
|         }) |         }) | ||||||
|  | @ -411,7 +417,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             const doShowLayer = this.mapProperties.zoom.map( |             const doShowLayer = this.mapProperties.zoom.map( | ||||||
|                 (z) => |                 (z) => | ||||||
|                     (fs.layer.isDisplayed?.data ?? true) && z >= (fs.layer.layerDef?.minzoom ?? 0), |                     (fs.layer.isDisplayed?.data ?? true) && z >= (fs.layer.layerDef?.minzoom ?? 0), | ||||||
|                 [fs.layer.isDisplayed], |                 [fs.layer.isDisplayed] | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             if (!doShowLayer.data && this.featureSwitches.featureSwitchFilter.data === false) { |             if (!doShowLayer.data && this.featureSwitches.featureSwitchFilter.data === false) { | ||||||
|  | @ -428,7 +434,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                 fs.layer, |                 fs.layer, | ||||||
|                 fs, |                 fs, | ||||||
|                 (id) => this.featureProperties.getStore(id), |                 (id) => this.featureProperties.getStore(id), | ||||||
|                 this.layerState.globalFilters, |                 this.layerState.globalFilters | ||||||
|             ) |             ) | ||||||
|             filteringFeatureSource.set(layerName, filtered) |             filteringFeatureSource.set(layerName, filtered) | ||||||
| 
 | 
 | ||||||
|  | @ -569,7 +575,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                     return |                     return | ||||||
|                 } |                 } | ||||||
|                 this.selectClosestAtCenter(0) |                 this.selectClosestAtCenter(0) | ||||||
|             }, |             } | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         for (let i = 1; i < 9; i++) { |         for (let i = 1; i < 9; i++) { | ||||||
|  | @ -587,7 +593,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                     onUp: true, |                     onUp: true, | ||||||
|                 }, |                 }, | ||||||
|                 doc, |                 doc, | ||||||
|                 () => this.selectClosestAtCenter(i - 1), |                 () => this.selectClosestAtCenter(i - 1) | ||||||
|             ) |             ) | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -604,7 +610,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                     if (this.featureSwitches.featureSwitchBackgroundSelection.data) { |                     if (this.featureSwitches.featureSwitchBackgroundSelection.data) { | ||||||
|                         this.guistate.backgroundLayerSelectionIsOpened.setData(true) |                         this.guistate.backgroundLayerSelectionIsOpened.setData(true) | ||||||
|                     } |                     } | ||||||
|                 }, |                 } | ||||||
|             ) |             ) | ||||||
|             Hotkeys.RegisterHotkey( |             Hotkeys.RegisterHotkey( | ||||||
|                 { |                 { | ||||||
|  | @ -616,14 +622,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                     if (this.featureSwitches.featureSwitchFilter.data) { |                     if (this.featureSwitches.featureSwitchFilter.data) { | ||||||
|                         this.guistate.openFilterView() |                         this.guistate.openFilterView() | ||||||
|                     } |                     } | ||||||
|                 }, |                 } | ||||||
|             ) |             ) | ||||||
|             Hotkeys.RegisterHotkey( |             Hotkeys.RegisterHotkey( | ||||||
|                 { shift: "O" }, |                 { shift: "O" }, | ||||||
|                 Translations.t.hotkeyDocumentation.selectMapnik, |                 Translations.t.hotkeyDocumentation.selectMapnik, | ||||||
|                 () => { |                 () => { | ||||||
|                     this.mapProperties.rasterLayer.setData(AvailableRasterLayers.osmCarto) |                     this.mapProperties.rasterLayer.setData(AvailableRasterLayers.osmCarto) | ||||||
|                 }, |                 } | ||||||
|             ) |             ) | ||||||
|             const setLayerCategory = (category: EliCategory) => { |             const setLayerCategory = (category: EliCategory) => { | ||||||
|                 const available = this.availableLayers.data |                 const available = this.availableLayers.data | ||||||
|  | @ -631,7 +637,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                 const best = RasterLayerUtils.SelectBestLayerAccordingTo( |                 const best = RasterLayerUtils.SelectBestLayerAccordingTo( | ||||||
|                     available, |                     available, | ||||||
|                     category, |                     category, | ||||||
|                     current.data, |                     current.data | ||||||
|                 ) |                 ) | ||||||
|                 console.log("Best layer for category", category, "is", best.properties.id) |                 console.log("Best layer for category", category, "is", best.properties.id) | ||||||
|                 current.setData(best) |                 current.setData(best) | ||||||
|  | @ -640,26 +646,26 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             Hotkeys.RegisterHotkey( |             Hotkeys.RegisterHotkey( | ||||||
|                 { nomod: "O" }, |                 { nomod: "O" }, | ||||||
|                 Translations.t.hotkeyDocumentation.selectOsmbasedmap, |                 Translations.t.hotkeyDocumentation.selectOsmbasedmap, | ||||||
|                 () => setLayerCategory("osmbasedmap"), |                 () => setLayerCategory("osmbasedmap") | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             Hotkeys.RegisterHotkey( |             Hotkeys.RegisterHotkey( | ||||||
|                 { nomod: "M" }, |                 { nomod: "M" }, | ||||||
|                 Translations.t.hotkeyDocumentation.selectMap, |                 Translations.t.hotkeyDocumentation.selectMap, | ||||||
|                 () => setLayerCategory("map"), |                 () => setLayerCategory("map") | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             Hotkeys.RegisterHotkey( |             Hotkeys.RegisterHotkey( | ||||||
|                 { nomod: "P" }, |                 { nomod: "P" }, | ||||||
|                 Translations.t.hotkeyDocumentation.selectAerial, |                 Translations.t.hotkeyDocumentation.selectAerial, | ||||||
|                 () => setLayerCategory("photo"), |                 () => setLayerCategory("photo") | ||||||
|             ) |             ) | ||||||
|             Hotkeys.RegisterHotkey( |             Hotkeys.RegisterHotkey( | ||||||
|                 { nomod: "L" }, |                 { nomod: "L" }, | ||||||
|                 Translations.t.hotkeyDocumentation.geolocate, |                 Translations.t.hotkeyDocumentation.geolocate, | ||||||
|                 () => { |                 () => { | ||||||
|                     this.geolocationControl.handleClick() |                     this.geolocationControl.handleClick() | ||||||
|                 }, |                 } | ||||||
|             ) |             ) | ||||||
|             return true |             return true | ||||||
|         }) |         }) | ||||||
|  | @ -671,7 +677,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             Translations.t.hotkeyDocumentation.translationMode, |             Translations.t.hotkeyDocumentation.translationMode, | ||||||
|             () => { |             () => { | ||||||
|                 Locale.showLinkToWeblate.setData(!Locale.showLinkToWeblate.data) |                 Locale.showLinkToWeblate.setData(!Locale.showLinkToWeblate.data) | ||||||
|             }, |             } | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -682,7 +688,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|         const normalLayers = this.layout.layers.filter( |         const normalLayers = this.layout.layers.filter( | ||||||
|             (l) => |             (l) => | ||||||
|                 Constants.priviliged_layers.indexOf(<any>l.id) < 0 && |                 Constants.priviliged_layers.indexOf(<any>l.id) < 0 && | ||||||
|                 !l.id.startsWith("note_import"), |                 !l.id.startsWith("note_import") | ||||||
|         ) |         ) | ||||||
|         const maxzoom = Math.min(...normalLayers.map((l) => l.minzoom)) |         const maxzoom = Math.min(...normalLayers.map((l) => l.minzoom)) | ||||||
| 
 | 
 | ||||||
|  | @ -690,7 +696,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             (l) => |             (l) => | ||||||
|                 Constants.priviliged_layers.indexOf(<any>l.id) < 0 && |                 Constants.priviliged_layers.indexOf(<any>l.id) < 0 && | ||||||
|                 l.source.geojsonSource === undefined && |                 l.source.geojsonSource === undefined && | ||||||
|                 l.doCount, |                 l.doCount | ||||||
|         ) |         ) | ||||||
|         const summaryTileSource = new SummaryTileSource( |         const summaryTileSource = new SummaryTileSource( | ||||||
|             Constants.SummaryServer, |             Constants.SummaryServer, | ||||||
|  | @ -699,7 +705,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             this.mapProperties, |             this.mapProperties, | ||||||
|             { |             { | ||||||
|                 isActive: this.mapProperties.zoom.map((z) => z <= maxzoom), |                 isActive: this.mapProperties.zoom.map((z) => z <= maxzoom), | ||||||
|             }, |             } | ||||||
|         ) |         ) | ||||||
|         return new SummaryTileSourceRewriter(summaryTileSource, this.layerState.filteredLayers) |         return new SummaryTileSourceRewriter(summaryTileSource, this.layerState.filteredLayers) | ||||||
|     } |     } | ||||||
|  | @ -719,12 +725,12 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             gps_location_history: this.geolocation.historicalUserLocations, |             gps_location_history: this.geolocation.historicalUserLocations, | ||||||
|             gps_track: this.geolocation.historicalUserLocationsTrack, |             gps_track: this.geolocation.historicalUserLocationsTrack, | ||||||
|             selected_element: new StaticFeatureSource( |             selected_element: new StaticFeatureSource( | ||||||
|                 this.selectedElement.map((f) => (f === undefined ? empty : [f])), |                 this.selectedElement.map((f) => (f === undefined ? empty : [f])) | ||||||
|             ), |             ), | ||||||
|             range: new StaticFeatureSource( |             range: new StaticFeatureSource( | ||||||
|                 this.mapProperties.maxbounds.map((bbox) => |                 this.mapProperties.maxbounds.map((bbox) => | ||||||
|                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "range" })], |                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "range" })] | ||||||
|                 ), |                 ) | ||||||
|             ), |             ), | ||||||
|             current_view: this.currentView, |             current_view: this.currentView, | ||||||
|             favourite: this.favourites, |             favourite: this.favourites, | ||||||
|  | @ -739,7 +745,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             ShowDataLayer.showRange( |             ShowDataLayer.showRange( | ||||||
|                 this.map, |                 this.map, | ||||||
|                 new StaticFeatureSource([bbox.asGeoJson({ id: "range" })]), |                 new StaticFeatureSource([bbox.asGeoJson({ id: "range" })]), | ||||||
|                 this.featureSwitches.featureSwitchIsTesting, |                 this.featureSwitches.featureSwitchIsTesting | ||||||
|             ) |             ) | ||||||
|         } |         } | ||||||
|         const currentViewLayer = this.layout.layers.find((l) => l.id === "current_view") |         const currentViewLayer = this.layout.layers.find((l) => l.id === "current_view") | ||||||
|  | @ -753,7 +759,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|                     currentViewLayer, |                     currentViewLayer, | ||||||
|                     this.layout, |                     this.layout, | ||||||
|                     this.osmObjectDownloader, |                     this.osmObjectDownloader, | ||||||
|                     this.featureProperties, |                     this.featureProperties | ||||||
|                 ) |                 ) | ||||||
|             }) |             }) | ||||||
|         } |         } | ||||||
|  | @ -797,20 +803,20 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
| 
 | 
 | ||||||
|         const lastClickLayerConfig = new LayerConfig( |         const lastClickLayerConfig = new LayerConfig( | ||||||
|             <LayerConfigJson>last_click_layerconfig, |             <LayerConfigJson>last_click_layerconfig, | ||||||
|             "last_click", |             "last_click" | ||||||
|         ) |         ) | ||||||
|         const lastClickFiltered = |         const lastClickFiltered = | ||||||
|             lastClickLayerConfig.isShown === undefined |             lastClickLayerConfig.isShown === undefined | ||||||
|                 ? specialLayers.last_click |                 ? specialLayers.last_click | ||||||
|                 : specialLayers.last_click.features.mapD((fs) => |                 : specialLayers.last_click.features.mapD((fs) => | ||||||
|                     fs.filter((f) => { |                       fs.filter((f) => { | ||||||
|                         const matches = lastClickLayerConfig.isShown.matchesProperties( |                           const matches = lastClickLayerConfig.isShown.matchesProperties( | ||||||
|                             f.properties, |                               f.properties | ||||||
|                         ) |                           ) | ||||||
|                         console.log("LastClick ", f, "matches", matches) |                           console.log("LastClick ", f, "matches", matches) | ||||||
|                         return matches |                           return matches | ||||||
|                     }), |                       }) | ||||||
|                 ) |                   ) | ||||||
|         new ShowDataLayer(this.map, { |         new ShowDataLayer(this.map, { | ||||||
|             features: new StaticFeatureSource(lastClickFiltered), |             features: new StaticFeatureSource(lastClickFiltered), | ||||||
|             layer: lastClickLayerConfig, |             layer: lastClickLayerConfig, | ||||||
|  | @ -855,7 +861,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|             this.mapProperties.rasterLayer, |             this.mapProperties.rasterLayer, | ||||||
|             this.availableLayers, |             this.availableLayers, | ||||||
|             this.featureSwitches.backgroundLayerId, |             this.featureSwitches.backgroundLayerId, | ||||||
|             this.userRelatedState.preferredBackgroundLayer, |             this.userRelatedState.preferredBackgroundLayer | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -865,14 +871,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public async reportError(message: string | Error) { |     public async reportError(message: string | Error) { | ||||||
|         console.log(">>> Reporting error to",Constants.ErrorReportServer, message) |         console.log(">>> Reporting error to", Constants.ErrorReportServer, message) | ||||||
|         let stacktrace: string = new Error().stack |         let stacktrace: string = new Error().stack | ||||||
| 
 | 
 | ||||||
|         await fetch(Constants.ErrorReportServer, { |         await fetch(Constants.ErrorReportServer, { | ||||||
|             method: "POST", |             method: "POST", | ||||||
|             body: JSON.stringify({ |             body: JSON.stringify({ | ||||||
|                 stacktrace, |                 stacktrace, | ||||||
|                 message: ""+message, |                 message: "" + message, | ||||||
|                 layout: this.layout.id, |                 layout: this.layout.id, | ||||||
|                 version: Constants.vNumber, |                 version: Constants.vNumber, | ||||||
|                 language: this.userRelatedState.language.data, |                 language: this.userRelatedState.language.data, | ||||||
|  |  | ||||||
|  | @ -149,14 +149,13 @@ | ||||||
|     </LoginToggle> |     </LoginToggle> | ||||||
| 
 | 
 | ||||||
|     <a |     <a | ||||||
|       class="flex button" |       class="button flex" | ||||||
|       href={window.location.protocol + "//" + window.location.host + "/studio.html"} |       href={window.location.protocol + "//" + window.location.host + "/studio.html"} | ||||||
|     > |     > | ||||||
|       <Pencil class="mr-2 h-6 w-6" /> |       <Pencil class="mr-2 h-6 w-6" /> | ||||||
|       <Tr t={Translations.t.general.morescreen.createYourOwnTheme} /> |       <Tr t={Translations.t.general.morescreen.createYourOwnTheme} /> | ||||||
|     </a> |     </a> | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     <h3 id="about"> |     <h3 id="about"> | ||||||
|       <Tr t={Translations.t.index.about} /> |       <Tr t={Translations.t.index.about} /> | ||||||
|     </h3> |     </h3> | ||||||
|  | @ -173,8 +172,8 @@ | ||||||
|       </a> |       </a> | ||||||
| 
 | 
 | ||||||
|       <a class="flex" href={Utils.OsmChaLinkFor(7)} target="_blank"> |       <a class="flex" href={Utils.OsmChaLinkFor(7)} target="_blank"> | ||||||
|         <ArrowTrendingUp class="mr-2 h-6 w-6"/> |         <ArrowTrendingUp class="mr-2 h-6 w-6" /> | ||||||
|         <Tr t={Translations.t.general.attribution.openOsmchaLastWeek}/> |         <Tr t={Translations.t.general.attribution.openOsmchaLastWeek} /> | ||||||
|       </a> |       </a> | ||||||
| 
 | 
 | ||||||
|       <a class="flex" href="https://en.osm.town/@MapComplete" target="_blank"> |       <a class="flex" href="https://en.osm.town/@MapComplete" target="_blank"> | ||||||
|  |  | ||||||
|  | @ -41,14 +41,14 @@ | ||||||
|     </slot> |     </slot> | ||||||
|   {:else if !silentFail && $loadingStatus === "error"} |   {:else if !silentFail && $loadingStatus === "error"} | ||||||
|     <slot name="error"> |     <slot name="error"> | ||||||
|       <div class="alert flex items-center flex-col"> |       <div class="alert flex flex-col items-center"> | ||||||
|       <div class="max-w-64 flex items-center "> |         <div class="max-w-64 flex items-center"> | ||||||
|         <Invalid class="m-2 h-8 w-8 shrink-0" /> |           <Invalid class="m-2 h-8 w-8 shrink-0" /> | ||||||
|         <Tr t={offlineModes[$apiState] ?? t.loginFailedUnreachableMode} /> |           <Tr t={offlineModes[$apiState] ?? t.loginFailedUnreachableMode} /> | ||||||
|       </div> |         </div> | ||||||
|         <button class="h-fit" on:click={() => state.osmConnection.AttemptLogin()}> |         <button class="h-fit" on:click={() => state.osmConnection.AttemptLogin()}> | ||||||
|           <ArrowPath class="w-6 h-6"/> |           <ArrowPath class="h-6 w-6" /> | ||||||
|           <Tr t={t.retry}/> |           <Tr t={t.retry} /> | ||||||
|         </button> |         </button> | ||||||
|       </div> |       </div> | ||||||
|     </slot> |     </slot> | ||||||
|  |  | ||||||
|  | @ -40,9 +40,9 @@ export default class CopyrightPanel extends Combine { | ||||||
|         const t = Translations.t.general.attribution |         const t = Translations.t.general.attribution | ||||||
|         const layoutToUse = state.layout |         const layoutToUse = state.layout | ||||||
| 
 | 
 | ||||||
|         const iconAttributions: BaseUIElement[] = Utils.Dedup(layoutToUse |         const iconAttributions: BaseUIElement[] = Utils.Dedup(layoutToUse.getUsedImages()).map( | ||||||
|             .getUsedImages()) |             CopyrightPanel.IconAttribution | ||||||
|             .map(CopyrightPanel.IconAttribution) |         ) | ||||||
| 
 | 
 | ||||||
|         let maintainer: BaseUIElement = undefined |         let maintainer: BaseUIElement = undefined | ||||||
|         if (layoutToUse.credits !== undefined && layoutToUse.credits !== "") { |         if (layoutToUse.credits !== undefined && layoutToUse.credits !== "") { | ||||||
|  |  | ||||||
|  | @ -151,10 +151,10 @@ | ||||||
|   </div> |   </div> | ||||||
| 
 | 
 | ||||||
|   {#if Utils.isIframe} |   {#if Utils.isIframe} | ||||||
|     <div  class="flex justify-end link-underline"> |     <div class="link-underline flex justify-end"> | ||||||
|     <a href="https://mapcomplete.org" target="_blank"> |       <a href="https://mapcomplete.org" target="_blank"> | ||||||
|       <Tr t={Translations.t.general.poweredByMapComplete}/> |         <Tr t={Translations.t.general.poweredByMapComplete} /> | ||||||
|     </a> |       </a> | ||||||
|     </div> |     </div> | ||||||
|   {:else} |   {:else} | ||||||
|     <If condition={state.featureSwitches.featureSwitchBackToThemeOverview}> |     <If condition={state.featureSwitches.featureSwitchBackToThemeOverview}> | ||||||
|  |  | ||||||
|  | @ -42,7 +42,7 @@ | ||||||
|   let knownImages = comparisonState.bindD((ct) => ct.knownImages) |   let knownImages = comparisonState.bindD((ct) => ct.knownImages) | ||||||
|   let propertyKeysExternal = comparisonState.mapD((ct) => ct.propertyKeysExternal) |   let propertyKeysExternal = comparisonState.mapD((ct) => ct.propertyKeysExternal) | ||||||
|   let hasDifferencesAtStart = comparisonState.mapD((ct) => ct.hasDifferencesAtStart) |   let hasDifferencesAtStart = comparisonState.mapD((ct) => ct.hasDifferencesAtStart) | ||||||
|   let enableLogin=  state.featureSwitches.featureSwitchEnableLogin |   let enableLogin = state.featureSwitches.featureSwitchEnableLogin | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| {#if !$sourceUrl || !$enableLogin} | {#if !$sourceUrl || !$enableLogin} | ||||||
|  |  | ||||||
|  | @ -29,10 +29,10 @@ | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| {#if enableLogin.data} | {#if enableLogin.data} | ||||||
| <AccordionSingle> |   <AccordionSingle> | ||||||
|   <span slot="header" class="p-2 text-base"> |     <span slot="header" class="p-2 text-base"> | ||||||
|     <Tr t={t.seeNearby} /> |       <Tr t={t.seeNearby} /> | ||||||
|   </span> |     </span> | ||||||
|   <NearbyImages {tags} {state} {lon} {lat} {feature} {linkable} {layer} /> |     <NearbyImages {tags} {state} {lon} {lat} {feature} {linkable} {layer} /> | ||||||
| </AccordionSingle> |   </AccordionSingle> | ||||||
|   {/if} | {/if} | ||||||
|  |  | ||||||
|  | @ -58,7 +58,7 @@ | ||||||
|   <LoginButton clss="small w-full" osmConnection={state.osmConnection} slot="not-logged-in"> |   <LoginButton clss="small w-full" osmConnection={state.osmConnection} slot="not-logged-in"> | ||||||
|     <Tr t={Translations.t.image.pleaseLogin} /> |     <Tr t={Translations.t.image.pleaseLogin} /> | ||||||
|   </LoginButton> |   </LoginButton> | ||||||
|   <div class="flex flex-col my-4"> |   <div class="my-4 flex flex-col"> | ||||||
|     <UploadingImageCounter {state} {tags} /> |     <UploadingImageCounter {state} {tags} /> | ||||||
|     {#each $errors as error} |     {#each $errors as error} | ||||||
|       <Tr t={error} cls="alert" /> |       <Tr t={error} cls="alert" /> | ||||||
|  |  | ||||||
|  | @ -934,7 +934,7 @@ export class ToTextualDescription { | ||||||
|         ranges: OpeningRange[][] |         ranges: OpeningRange[][] | ||||||
|     ): Translation | undefined { |     ): Translation | undefined { | ||||||
|         const t = Translations.t.general.opening_hours |         const t = Translations.t.general.opening_hours | ||||||
|         if(!ranges){ |         if (!ranges) { | ||||||
|             return undefined |             return undefined | ||||||
|         } |         } | ||||||
|         if (!ranges?.some((r) => r.length > 0)) { |         if (!ranges?.some((r) => r.length > 0)) { | ||||||
|  |  | ||||||
|  | @ -79,7 +79,7 @@ export default class OpeningHoursVisualization extends Toggle { | ||||||
|             // The normal case: we have items for the coming days
 |             // The normal case: we have items for the coming days
 | ||||||
|             return OpeningHoursVisualization.ConstructVizTable(oh, ranges, lastMonday) |             return OpeningHoursVisualization.ConstructVizTable(oh, ranges, lastMonday) | ||||||
|         } |         } | ||||||
|          // The special case that range is completely empty
 |         // The special case that range is completely empty
 | ||||||
|         return OpeningHoursVisualization.ShowSpecialCase(oh) |         return OpeningHoursVisualization.ShowSpecialCase(oh) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -303,6 +303,8 @@ export default class OpeningHoursVisualization extends Toggle { | ||||||
|             opensAtDate.getHours(), |             opensAtDate.getHours(), | ||||||
|             opensAtDate.getMinutes() |             opensAtDate.getMinutes() | ||||||
|         )}` |         )}` | ||||||
|         return Translations.t.general.opening_hours.closed_until.Subs({ date: opensAtDate.toLocaleString() }) |         return Translations.t.general.opening_hours.closed_until.Subs({ | ||||||
|  |             date: opensAtDate.toLocaleString(), | ||||||
|  |         }) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -64,7 +64,9 @@ export class CloseNoteButton implements SpecialVisualization { | ||||||
|             zoomButton: string |             zoomButton: string | ||||||
|         } = <any>Utils.ParseVisArgs(this.args, args) |         } = <any>Utils.ParseVisArgs(this.args, args) | ||||||
| 
 | 
 | ||||||
|         let icon: BaseUIElement = new SvelteUIElement(Icon, {icon: params.icon ?? "checkmark.svg"}) |         let icon: BaseUIElement = new SvelteUIElement(Icon, { | ||||||
|  |             icon: params.icon ?? "checkmark.svg", | ||||||
|  |         }) | ||||||
|         let textToShow = t.closeNote |         let textToShow = t.closeNote | ||||||
|         if ((params.text ?? "") !== "") { |         if ((params.text ?? "") !== "") { | ||||||
|             textToShow = Translations.T(args[0]) |             textToShow = Translations.T(args[0]) | ||||||
|  |  | ||||||
|  | @ -110,7 +110,10 @@ | ||||||
|         </SubtleButton> |         </SubtleButton> | ||||||
|       </div> |       </div> | ||||||
|     {:else} |     {:else} | ||||||
|       <form class="low-interaction rounded-sm p-2 flex flex-col" on:submit|preventDefault={uploadNote}> |       <form | ||||||
|  |         class="low-interaction flex flex-col rounded-sm p-2" | ||||||
|  |         on:submit|preventDefault={uploadNote} | ||||||
|  |       > | ||||||
|         <label class="neutral-label"> |         <label class="neutral-label"> | ||||||
|           <Tr t={Translations.t.notes.createNoteIntro} /> |           <Tr t={Translations.t.notes.createNoteIntro} /> | ||||||
|           <div class="w-full p-1"> |           <div class="w-full p-1"> | ||||||
|  |  | ||||||
|  | @ -49,7 +49,7 @@ export default class NoteCommentElement extends Combine { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const userinfo = Stores.FromPromise( |         const userinfo = Stores.FromPromise( | ||||||
|             Utils.downloadJsonCached<{user: { img: { href: string } }}>( |             Utils.downloadJsonCached<{ user: { img: { href: string } } }>( | ||||||
|                 "https://api.openstreetmap.org/api/0.6/user/" + comment.uid, |                 "https://api.openstreetmap.org/api/0.6/user/" + comment.uid, | ||||||
|                 24 * 60 * 60 * 1000 |                 24 * 60 * 60 * 1000 | ||||||
|             ) |             ) | ||||||
|  | @ -122,7 +122,7 @@ export default class NoteCommentElement extends Combine { | ||||||
|     public static addCommentTo( |     public static addCommentTo( | ||||||
|         txt: string, |         txt: string, | ||||||
|         tags: UIEventSource<any>, |         tags: UIEventSource<any>, | ||||||
|         state: { osmConnection: {userDetails: Store<{ name: string, uid: number }>} } |         state: { osmConnection: { userDetails: Store<{ name: string; uid: number }> } } | ||||||
|     ) { |     ) { | ||||||
|         const comments: any[] = JSON.parse(tags.data["comments"]) |         const comments: any[] = JSON.parse(tags.data["comments"]) | ||||||
|         const username = state.osmConnection.userDetails.data.name |         const username = state.osmConnection.userDetails.data.name | ||||||
|  |  | ||||||
|  | @ -111,93 +111,97 @@ | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| {#if $loginEnabled} | {#if $loginEnabled} | ||||||
| <div |   <div | ||||||
|   bind:this={questionboxElem} |     bind:this={questionboxElem} | ||||||
|   aria-live="polite" |     aria-live="polite" | ||||||
|   class="marker-questionbox-root" |     class="marker-questionbox-root" | ||||||
|   class:hidden={$questionsToAsk.length === 0 && skipped === 0 && answered === 0} |     class:hidden={$questionsToAsk.length === 0 && skipped === 0 && answered === 0} | ||||||
| > |   > | ||||||
|   {#if $allQuestionsToAsk.length === 0} |     {#if $allQuestionsToAsk.length === 0} | ||||||
|     {#if skipped + answered > 0} |       {#if skipped + answered > 0} | ||||||
|       <div class="thanks"> |         <div class="thanks"> | ||||||
|         <Tr t={Translations.t.general.questionBox.done} /> |           <Tr t={Translations.t.general.questionBox.done} /> | ||||||
|       </div> |  | ||||||
|       {#if answered === 0} |  | ||||||
|         {#if skipped === 1} |  | ||||||
|           <Tr t={Translations.t.general.questionBox.skippedOne} /> |  | ||||||
|         {:else} |  | ||||||
|           <Tr t={Translations.t.general.questionBox.skippedMultiple.Subs({ skipped })} /> |  | ||||||
|         {/if} |  | ||||||
|       {:else if answered === 1} |  | ||||||
|         {#if skipped === 0} |  | ||||||
|           <Tr t={Translations.t.general.questionBox.answeredOne} /> |  | ||||||
|         {:else if skipped === 1} |  | ||||||
|           <Tr t={Translations.t.general.questionBox.answeredOneSkippedOne} /> |  | ||||||
|         {:else} |  | ||||||
|           <Tr t={Translations.t.general.questionBox.answeredOneSkippedMultiple.Subs({ skipped })} /> |  | ||||||
|         {/if} |  | ||||||
|       {:else if skipped === 0} |  | ||||||
|         <Tr t={Translations.t.general.questionBox.answeredMultiple.Subs({ answered })} /> |  | ||||||
|       {:else if skipped === 1} |  | ||||||
|         <Tr t={Translations.t.general.questionBox.answeredMultipleSkippedOne.Subs({ answered })} /> |  | ||||||
|       {:else} |  | ||||||
|         <Tr |  | ||||||
|           t={Translations.t.general.questionBox.answeredMultipleSkippedMultiple.Subs({ |  | ||||||
|             answered, |  | ||||||
|             skipped, |  | ||||||
|           })} |  | ||||||
|         /> |  | ||||||
|       {/if} |  | ||||||
| 
 |  | ||||||
|       {#if skipped > 0} |  | ||||||
|         <button |  | ||||||
|           class="w-full" |  | ||||||
|           on:click={() => { |  | ||||||
|             skippedQuestions.setData(new Set()) |  | ||||||
|             skipped = 0 |  | ||||||
|           }} |  | ||||||
|         > |  | ||||||
|           <Tr t={Translations.t.general.questionBox.reactivate} /> |  | ||||||
|         </button> |  | ||||||
|       {/if} |  | ||||||
|     {/if} |  | ||||||
|   {:else} |  | ||||||
|     <div> |  | ||||||
|       {#if $showAllQuestionsAtOnce} |  | ||||||
|         <div class="flex flex-col gap-y-1"> |  | ||||||
|           {#each $allQuestionsToAsk as question (question.id)} |  | ||||||
|             <TagRenderingQuestionDynamic |  | ||||||
|               config={question} |  | ||||||
|               {tags} |  | ||||||
|               {selectedElement} |  | ||||||
|               {state} |  | ||||||
|               {layer} |  | ||||||
|             /> |  | ||||||
|           {/each} |  | ||||||
|         </div> |         </div> | ||||||
|       {:else if $firstQuestion !== undefined} |         {#if answered === 0} | ||||||
|         <TagRenderingQuestionDynamic |           {#if skipped === 1} | ||||||
|           config={$firstQuestion} |             <Tr t={Translations.t.general.questionBox.skippedOne} /> | ||||||
|           {layer} |           {:else} | ||||||
|           {selectedElement} |             <Tr t={Translations.t.general.questionBox.skippedMultiple.Subs({ skipped })} /> | ||||||
|           {state} |           {/if} | ||||||
|           {tags} |         {:else if answered === 1} | ||||||
|           on:saved={() => { |           {#if skipped === 0} | ||||||
|             skip($firstQuestion, true) |             <Tr t={Translations.t.general.questionBox.answeredOne} /> | ||||||
|           }} |           {:else if skipped === 1} | ||||||
|         > |             <Tr t={Translations.t.general.questionBox.answeredOneSkippedOne} /> | ||||||
|  |           {:else} | ||||||
|  |             <Tr | ||||||
|  |               t={Translations.t.general.questionBox.answeredOneSkippedMultiple.Subs({ skipped })} | ||||||
|  |             /> | ||||||
|  |           {/if} | ||||||
|  |         {:else if skipped === 0} | ||||||
|  |           <Tr t={Translations.t.general.questionBox.answeredMultiple.Subs({ answered })} /> | ||||||
|  |         {:else if skipped === 1} | ||||||
|  |           <Tr | ||||||
|  |             t={Translations.t.general.questionBox.answeredMultipleSkippedOne.Subs({ answered })} | ||||||
|  |           /> | ||||||
|  |         {:else} | ||||||
|  |           <Tr | ||||||
|  |             t={Translations.t.general.questionBox.answeredMultipleSkippedMultiple.Subs({ | ||||||
|  |               answered, | ||||||
|  |               skipped, | ||||||
|  |             })} | ||||||
|  |           /> | ||||||
|  |         {/if} | ||||||
|  | 
 | ||||||
|  |         {#if skipped > 0} | ||||||
|           <button |           <button | ||||||
|             class="secondary" |             class="w-full" | ||||||
|             on:click={() => { |             on:click={() => { | ||||||
|               skip($firstQuestion) |               skippedQuestions.setData(new Set()) | ||||||
|  |               skipped = 0 | ||||||
|             }} |             }} | ||||||
|             slot="cancel" |  | ||||||
|           > |           > | ||||||
|             <Tr t={Translations.t.general.skip} /> |             <Tr t={Translations.t.general.questionBox.reactivate} /> | ||||||
|           </button> |           </button> | ||||||
|         </TagRenderingQuestionDynamic> |         {/if} | ||||||
|       {/if} |       {/if} | ||||||
|     </div> |     {:else} | ||||||
|   {/if} |       <div> | ||||||
| </div> |         {#if $showAllQuestionsAtOnce} | ||||||
|   {/if} |           <div class="flex flex-col gap-y-1"> | ||||||
|  |             {#each $allQuestionsToAsk as question (question.id)} | ||||||
|  |               <TagRenderingQuestionDynamic | ||||||
|  |                 config={question} | ||||||
|  |                 {tags} | ||||||
|  |                 {selectedElement} | ||||||
|  |                 {state} | ||||||
|  |                 {layer} | ||||||
|  |               /> | ||||||
|  |             {/each} | ||||||
|  |           </div> | ||||||
|  |         {:else if $firstQuestion !== undefined} | ||||||
|  |           <TagRenderingQuestionDynamic | ||||||
|  |             config={$firstQuestion} | ||||||
|  |             {layer} | ||||||
|  |             {selectedElement} | ||||||
|  |             {state} | ||||||
|  |             {tags} | ||||||
|  |             on:saved={() => { | ||||||
|  |               skip($firstQuestion, true) | ||||||
|  |             }} | ||||||
|  |           > | ||||||
|  |             <button | ||||||
|  |               class="secondary" | ||||||
|  |               on:click={() => { | ||||||
|  |                 skip($firstQuestion) | ||||||
|  |               }} | ||||||
|  |               slot="cancel" | ||||||
|  |             > | ||||||
|  |               <Tr t={Translations.t.general.skip} /> | ||||||
|  |             </button> | ||||||
|  |           </TagRenderingQuestionDynamic> | ||||||
|  |         {/if} | ||||||
|  |       </div> | ||||||
|  |     {/if} | ||||||
|  |   </div> | ||||||
|  | {/if} | ||||||
|  |  | ||||||
|  | @ -28,7 +28,7 @@ | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| {#if config !== undefined && (config?.condition === undefined || config.condition.matchesProperties($tags))} | {#if config !== undefined && (config?.condition === undefined || config.condition.matchesProperties($tags))} | ||||||
|   <div {id} class={twMerge("link-underline flex w-full h-full flex-col", extraClasses)}> |   <div {id} class={twMerge("link-underline flex h-full w-full flex-col", extraClasses)}> | ||||||
|     {#if $trs.length === 1} |     {#if $trs.length === 1} | ||||||
|       <TagRenderingMapping |       <TagRenderingMapping | ||||||
|         mapping={$trs[0]} |         mapping={$trs[0]} | ||||||
|  |  | ||||||
|  | @ -106,8 +106,16 @@ | ||||||
|       </TagRenderingQuestion> |       </TagRenderingQuestion> | ||||||
|     {:else} |     {:else} | ||||||
|       <div class="low-interaction flex items-center justify-between overflow-hidden rounded pl-2"> |       <div class="low-interaction flex items-center justify-between overflow-hidden rounded pl-2"> | ||||||
|         <TagRenderingAnswer id={answerId} {config} {tags} {selectedElement} {state} {layer} extraClasses="my-2"/> |         <TagRenderingAnswer | ||||||
|         {#if (!editingEnabled || $editingEnabled)} |           id={answerId} | ||||||
|  |           {config} | ||||||
|  |           {tags} | ||||||
|  |           {selectedElement} | ||||||
|  |           {state} | ||||||
|  |           {layer} | ||||||
|  |           extraClasses="my-2" | ||||||
|  |         /> | ||||||
|  |         {#if !editingEnabled || $editingEnabled} | ||||||
|           <EditButton |           <EditButton | ||||||
|             arialabel={config.editButtonAriaLabel} |             arialabel={config.editButtonAriaLabel} | ||||||
|             ariaLabelledBy={answerId} |             ariaLabelledBy={answerId} | ||||||
|  |  | ||||||
|  | @ -1,5 +1,4 @@ | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <main > | <main /> | ||||||
| </main> |  | ||||||
|  |  | ||||||
|  | @ -124,11 +124,11 @@ | ||||||
|   state.mapProperties.installCustomKeyboardHandler(viewport) |   state.mapProperties.installCustomKeyboardHandler(viewport) | ||||||
|   let canZoomIn = mapproperties.maxzoom.map( |   let canZoomIn = mapproperties.maxzoom.map( | ||||||
|     (mz) => mapproperties.zoom.data < mz, |     (mz) => mapproperties.zoom.data < mz, | ||||||
|     [mapproperties.zoom], |     [mapproperties.zoom] | ||||||
|   ) |   ) | ||||||
|   let canZoomOut = mapproperties.minzoom.map( |   let canZoomOut = mapproperties.minzoom.map( | ||||||
|     (mz) => mapproperties.zoom.data > mz, |     (mz) => mapproperties.zoom.data > mz, | ||||||
|     [mapproperties.zoom], |     [mapproperties.zoom] | ||||||
|   ) |   ) | ||||||
| 
 | 
 | ||||||
|   function updateViewport() { |   function updateViewport() { | ||||||
|  | @ -165,7 +165,7 @@ | ||||||
|   onDestroy( |   onDestroy( | ||||||
|     rasterLayer.addCallbackAndRunD((l) => { |     rasterLayer.addCallbackAndRunD((l) => { | ||||||
|       rasterLayerName = l.properties.name |       rasterLayerName = l.properties.name | ||||||
|     }), |     }) | ||||||
|   ) |   ) | ||||||
|   let previewedImage = state.previewedImage |   let previewedImage = state.previewedImage | ||||||
| 
 | 
 | ||||||
|  | @ -196,7 +196,7 @@ | ||||||
|   let openMapButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>(undefined) |   let openMapButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>(undefined) | ||||||
|   let openMenuButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>(undefined) |   let openMenuButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>(undefined) | ||||||
|   let openCurrentViewLayerButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>( |   let openCurrentViewLayerButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>( | ||||||
|     undefined, |     undefined | ||||||
|   ) |   ) | ||||||
|   let _openNewElementButton: HTMLButtonElement |   let _openNewElementButton: HTMLButtonElement | ||||||
|   let openNewElementButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>(undefined) |   let openNewElementButton: UIEventSource<HTMLElement> = new UIEventSource<HTMLElement>(undefined) | ||||||
|  | @ -572,7 +572,6 @@ | ||||||
|         <div class="link-underline links-w-full m-2 flex flex-col gap-y-1" slot="content0"> |         <div class="link-underline links-w-full m-2 flex flex-col gap-y-1" slot="content0"> | ||||||
|           <Tr t={Translations.t.general.aboutMapComplete.intro} /> |           <Tr t={Translations.t.general.aboutMapComplete.intro} /> | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|           <a class="flex" href={Utils.HomepageLink()}> |           <a class="flex" href={Utils.HomepageLink()}> | ||||||
|             <Add class="h-6 w-6" /> |             <Add class="h-6 w-6" /> | ||||||
|             {#if Utils.isIframe} |             {#if Utils.isIframe} | ||||||
|  |  | ||||||
|  | @ -146,7 +146,6 @@ In the case that MapComplete is pointed to the testing grounds, the edit will be | ||||||
| 
 | 
 | ||||||
|     public static readonly isIframe = !Utils.runningFromConsole && window !== window.top |     public static readonly isIframe = !Utils.runningFromConsole && window !== window.top | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     public static initDomPurify() { |     public static initDomPurify() { | ||||||
|         if (Utils.runningFromConsole) { |         if (Utils.runningFromConsole) { | ||||||
|             return |             return | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| { | { | ||||||
|   "contributors": [ |   "contributors": [ | ||||||
|     { |     { | ||||||
|       "commits": 7596, |       "commits": 7612, | ||||||
|       "contributor": "Pieter Vander Vennet" |       "contributor": "Pieter Vander Vennet" | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ | ||||||
|       "contributor": "Pieter Vander Vennet" |       "contributor": "Pieter Vander Vennet" | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "commits": 347, |       "commits": 351, | ||||||
|       "contributor": "kjon" |       "contributor": "kjon" | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -21,7 +21,7 @@ | ||||||
|       "contributor": "Robin van der Linde" |       "contributor": "Robin van der Linde" | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "commits": 67, |       "commits": 69, | ||||||
|       "contributor": "mcliquid" |       "contributor": "mcliquid" | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|  | @ -112,6 +112,10 @@ | ||||||
|       "commits": 13, |       "commits": 13, | ||||||
|       "contributor": "Joost" |       "contributor": "Joost" | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |       "commits": 12, | ||||||
|  |       "contributor": "Patchanka64" | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|       "commits": 12, |       "commits": 12, | ||||||
|       "contributor": "Ettore Atalan" |       "contributor": "Ettore Atalan" | ||||||
|  | @ -152,10 +156,6 @@ | ||||||
|       "commits": 10, |       "commits": 10, | ||||||
|       "contributor": "Irina" |       "contributor": "Irina" | ||||||
|     }, |     }, | ||||||
|     { |  | ||||||
|       "commits": 9, |  | ||||||
|       "contributor": "Patchanka64" |  | ||||||
|     }, |  | ||||||
|     { |     { | ||||||
|       "commits": 9, |       "commits": 9, | ||||||
|       "contributor": "Manuel Tassi" |       "contributor": "Manuel Tassi" | ||||||
|  | @ -256,6 +256,10 @@ | ||||||
|       "commits": 6, |       "commits": 6, | ||||||
|       "contributor": "lvgx" |       "contributor": "lvgx" | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |       "commits": 5, | ||||||
|  |       "contributor": "Christian Schmidt" | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|       "commits": 5, |       "commits": 5, | ||||||
|       "contributor": "Emory Shaw" |       "contributor": "Emory Shaw" | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue