| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  | import BaseUIElement from "./BaseUIElement" | 
					
						
							|  |  |  | import Combine from "./Base/Combine" | 
					
						
							|  |  |  | import Title from "./Base/Title" | 
					
						
							|  |  |  | import List from "./Base/List" | 
					
						
							|  |  |  | import Translations from "./i18n/Translations" | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  | import { QueryParameters } from "../Logic/Web/QueryParameters" | 
					
						
							| 
									
										
										
										
											2022-05-18 01:56:09 +02:00
										 |  |  | import FeatureSwitchState from "../Logic/State/FeatureSwitchState" | 
					
						
							|  |  |  | import LayoutConfig from "../Models/ThemeConfig/LayoutConfig" | 
					
						
							| 
									
										
										
										
											2023-08-10 15:37:44 +02:00
										 |  |  | import ThemeViewStateHashActor from "../Logic/Web/ThemeViewStateHashActor" | 
					
						
							| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default class QueryParameterDocumentation { | 
					
						
							|  |  |  |     private static QueryParamDocsIntro = [ | 
					
						
							|  |  |  |         new Title("URL-parameters and URL-hash", 1), | 
					
						
							|  |  |  |         "This document gives an overview of which URL-parameters can be used to influence MapComplete.", | 
					
						
							|  |  |  |         new Title("What is a URL parameter?", 2), | 
					
						
							|  |  |  |         '"URL-parameters are extra parts of the URL used to set the state.', | 
					
						
							| 
									
										
										
										
											2023-08-23 18:33:30 +02:00
										 |  |  |         "For example, if the url is `https://mapcomplete.org/cyclofix?lat=51.0&lon=4.3&z=5&test=true#node/1234`, " + | 
					
						
							| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  |             "the URL-parameters are stated in the part between the `?` and the `#`. There are multiple, all separated by `&`, namely: ", | 
					
						
							|  |  |  |         new List( | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 "The url-parameter `lat` is `51.0` in this instance", | 
					
						
							|  |  |  |                 "The url-parameter `lon` is `4.3` in this instance", | 
					
						
							|  |  |  |                 "The url-parameter `z` is `5` in this instance", | 
					
						
							|  |  |  |                 "The url-parameter `test` is `true` in this instance", | 
					
						
							|  |  |  |             ].map((s) => Translations.W(s)) | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |         "Finally, the URL-hash is the part after the `#`. It is `node/1234` in this case.", | 
					
						
							|  |  |  |     ] | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-14 18:44:24 +02:00
										 |  |  |     public static UrlParamDocs(): Map<string, string> { | 
					
						
							| 
									
										
										
										
											2022-05-18 01:56:09 +02:00
										 |  |  |         const dummyLayout = new LayoutConfig({ | 
					
						
							|  |  |  |             id: ">theme<", | 
					
						
							| 
									
										
										
										
											2022-06-14 18:44:24 +02:00
										 |  |  |             title: { en: "<theme>" }, | 
					
						
							| 
									
										
										
										
											2022-05-18 01:56:09 +02:00
										 |  |  |             description: "A theme to generate docs with", | 
					
						
							|  |  |  |             socialImage: "./assets/SocialImage.png", | 
					
						
							|  |  |  |             startLat: 0, | 
					
						
							|  |  |  |             startLon: 0, | 
					
						
							|  |  |  |             startZoom: 0, | 
					
						
							|  |  |  |             icon: undefined, | 
					
						
							|  |  |  |             layers: [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     name: "<layer>", | 
					
						
							|  |  |  |                     id: "<layer>", | 
					
						
							|  |  |  |                     source: { | 
					
						
							|  |  |  |                         osmTags: "id~*", | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     mapRendering: null, | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         new FeatureSwitchState(dummyLayout) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         QueryParameters.GetQueryParameter( | 
					
						
							|  |  |  |             "layer-<layer-id>", | 
					
						
							|  |  |  |             "true", | 
					
						
							|  |  |  |             "Wether or not the layer with id <layer-id> is shown" | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         return QueryParameters.documentation | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-06-14 18:44:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  |     public static GenerateQueryParameterDocs(): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  |         const docs: (string | BaseUIElement)[] = [ | 
					
						
							|  |  |  |             ...QueryParameterDocumentation.QueryParamDocsIntro, | 
					
						
							| 
									
										
										
										
											2023-08-10 15:37:44 +02:00
										 |  |  |             ...ThemeViewStateHashActor.documentation, | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         ] | 
					
						
							| 
									
										
										
										
											2022-06-14 18:44:24 +02:00
										 |  |  |         this.UrlParamDocs().forEach((value, key) => { | 
					
						
							| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  |             const c = new Combine([ | 
					
						
							|  |  |  |                 new Title(key, 2), | 
					
						
							| 
									
										
										
										
											2022-06-14 18:44:24 +02:00
										 |  |  |                 value, | 
					
						
							| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  |                 QueryParameters.defaults[key] === undefined | 
					
						
							|  |  |  |                     ? "No default value set" | 
					
						
							|  |  |  |                     : `The default value is _${QueryParameters.defaults[key]}_`, | 
					
						
							|  |  |  |             ]) | 
					
						
							|  |  |  |             docs.push(c) | 
					
						
							| 
									
										
										
										
											2022-06-14 18:44:24 +02:00
										 |  |  |         }) | 
					
						
							| 
									
										
										
										
											2021-11-30 22:50:48 +01:00
										 |  |  |         return new Combine(docs).SetClass("flex flex-col") | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |