forked from MapComplete/MapComplete
		
	Review of many feature switches and iframe context; fix OH-vis when ranges are not given
This commit is contained in:
		
							parent
							
								
									ecfa7d3d1d
								
							
						
					
					
						commit
						afea9adacb
					
				
					 21 changed files with 157 additions and 88 deletions
				
			
		|  | @ -6,22 +6,26 @@ import { UIEventSource } from "../UIEventSource" | |||
| import { QueryParameters } from "../Web/QueryParameters" | ||||
| import Constants from "../../Models/Constants" | ||||
| import { Utils } from "../../Utils" | ||||
| import { Query } from "pg" | ||||
| 
 | ||||
| class FeatureSwitchUtils { | ||||
|     /** Helper function to initialize feature switches | ||||
|      * | ||||
|      */ | ||||
|     static initSwitch(key: string, deflt: boolean, documentation: string): UIEventSource<boolean> { | ||||
|         const defaultValue = deflt | ||||
|         const queryParam = QueryParameters.GetQueryParameter( | ||||
|             key, | ||||
|             "" + defaultValue, | ||||
|             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
 | ||||
|         return queryParam.sync( | ||||
|             (str) => (str === undefined ? defaultValue : str !== "false"), | ||||
|             [], | ||||
|             (b) => (b == defaultValue ? undefined : "" + b) | ||||
|             (b) => (b == defaultValue ? undefined : "" + b), | ||||
|         ) | ||||
|     } | ||||
| } | ||||
|  | @ -33,7 +37,7 @@ export class OsmConnectionFeatureSwitches { | |||
|         this.featureSwitchFakeUser = QueryParameters.GetBooleanQueryParameter( | ||||
|             "fake-user", | ||||
|             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", | ||||
|         ) | ||||
|     } | ||||
| } | ||||
|  | @ -69,19 +73,41 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | |||
|         super() | ||||
|         this.layoutToUse = layoutToUse | ||||
| 
 | ||||
|         // Helper function to initialize feature switches
 | ||||
| 
 | ||||
|         const legacyRewrite: Record<string, string | string[]> = { | ||||
|             "fs-userbadge": "fs-enable-login", | ||||
|             "fs-layers": ["fs-filter", "fs-background"], | ||||
| 
 | ||||
|         } | ||||
| 
 | ||||
|         for (const key in legacyRewrite) { | ||||
|             let intoList = legacyRewrite[key] | ||||
|             if (!QueryParameters.wasInitialized(key)) { | ||||
|                 continue | ||||
|             } | ||||
|             if (typeof intoList === "string") { | ||||
|                 intoList = [intoList] | ||||
|             } | ||||
|             for (const into of intoList) { | ||||
|                 if (!QueryParameters.wasInitialized(into)) { | ||||
|                     const v = QueryParameters.GetQueryParameter(key, "", "").data | ||||
|                     console.log("Adding url param due to legacy:", key, "-->", into, "(", v + ")") | ||||
|                     QueryParameters.GetQueryParameter(into, "", "").setData(v) | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         this.featureSwitchEnableLogin = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-enable-login", | ||||
|             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")) { | ||||
|                 // userbadge is the legacy name for 'enable-login'
 | ||||
|                 this.featureSwitchEnableLogin.setData( | ||||
|                     QueryParameters.GetBooleanQueryParameter("fs-userbadge", undefined, "Legacy") | ||||
|                         .data | ||||
|                         .data, | ||||
|                 ) | ||||
|             } | ||||
|         } | ||||
|  | @ -89,60 +115,60 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | |||
|         this.featureSwitchSearch = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-search", | ||||
|             layoutToUse?.enableSearch ?? true, | ||||
|             "Disables/Enables the search bar" | ||||
|             "Disables/Enables the search bar", | ||||
|         ) | ||||
|         this.featureSwitchBackgroundSelection = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-background", | ||||
|             layoutToUse?.enableBackgroundLayerSelection ?? true, | ||||
|             "Disables/Enables the background layer control" | ||||
|             "Disables/Enables the background layer control where a user can enable e.g. aerial imagery", | ||||
|         ) | ||||
| 
 | ||||
|         this.featureSwitchFilter = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-filter", | ||||
|             layoutToUse?.enableLayers ?? true, | ||||
|             "Disables/Enables the filter view" | ||||
|             "Disables/Enables the filter view where a user can enable/disable MapComplete-layers or filter for certain properties", | ||||
|         ) | ||||
| 
 | ||||
|         this.featureSwitchWelcomeMessage = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-welcome-message", | ||||
|             true, | ||||
|             "Disables/enables the help menu or welcome message" | ||||
|             "Disables/enables the help menu or welcome message", | ||||
|         ) | ||||
|         this.featureSwitchCommunityIndex = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-community-index", | ||||
|             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( | ||||
|             "fs-iframe-popout", | ||||
|             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( | ||||
|             "fs-homepage-link", | ||||
|             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( | ||||
|             "fs-share-screen", | ||||
|             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( | ||||
|             "fs-geolocation", | ||||
|             layoutToUse?.enableGeolocation ?? true, | ||||
|             "Disables/Enables the geolocation button" | ||||
|             "Disables/Enables the geolocation button", | ||||
|         ) | ||||
|         this.featureSwitchShowAllQuestions = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-all-questions", | ||||
|             layoutToUse?.enableShowAllQuestions ?? false, | ||||
|             "Always show all questions" | ||||
|             "Always show all questions", | ||||
|         ) | ||||
| 
 | ||||
|         this.featureSwitchEnableExport = FeatureSwitchUtils.initSwitch( | ||||
|             "fs-export", | ||||
|             layoutToUse?.enableExportButton ?? true, | ||||
|             "Enable the export as GeoJSON and CSV button" | ||||
|             "Enable the export as GeoJSON and CSV button", | ||||
|         ) | ||||
| 
 | ||||
|         let testingDefaultValue = false | ||||
|  | @ -156,59 +182,59 @@ export default class FeatureSwitchState extends OsmConnectionFeatureSwitches { | |||
|         this.featureSwitchIsTesting = QueryParameters.GetBooleanQueryParameter( | ||||
|             "test", | ||||
|             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( | ||||
|             "debug", | ||||
|             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( | ||||
|             "moreprivacy", | ||||
|             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( | ||||
|             "overpassUrl", | ||||
|             (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( | ||||
|             (param) => param?.split(","), | ||||
|             [], | ||||
|             (urls) => urls?.join(",") | ||||
|             (urls) => urls?.join(","), | ||||
|         ) | ||||
| 
 | ||||
|         this.overpassTimeout = UIEventSource.asInt( | ||||
|             QueryParameters.GetQueryParameter( | ||||
|                 "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( | ||||
|             QueryParameters.GetQueryParameter( | ||||
|                 "overpassMaxZoom", | ||||
|                 "" + layoutToUse?.overpassMaxZoom, | ||||
|                 " point to switch between OSM-api and overpass" | ||||
|             ) | ||||
|                 " point to switch between OSM-api and overpass", | ||||
|             ), | ||||
|         ) | ||||
| 
 | ||||
|         this.osmApiTileSize = UIEventSource.asInt( | ||||
|             QueryParameters.GetQueryParameter( | ||||
|                 "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( | ||||
|             "background", | ||||
|             layoutToUse?.defaultBackgroundId, | ||||
|             "The id of the background layer to start with" | ||||
|             "The id of the background layer to start with", | ||||
|         ) | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -297,6 +297,7 @@ export default class UserRelatedState { | |||
|             _applicationOpened: new Date().toISOString(), | ||||
|             _supports_sharing: | ||||
|                 typeof window === "undefined" ? "no" : window.navigator.share ? "yes" : "no", | ||||
|             _iframe: Utils.isIframe ? "yes" : "no" | ||||
|         }) | ||||
| 
 | ||||
|         for (const key in Constants.userJourney) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue