MapComplete/src/UI/QueryParameterDocumentation.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

84 lines
3.2 KiB
TypeScript
Raw Normal View History

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"
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"
import ThemeViewStateHashActor from "../Logic/Web/ThemeViewStateHashActor"
import MarkdownUtils from "../Utils/MarkdownUtils"
2021-11-30 22:50:48 +01:00
export default class QueryParameterDocumentation {
private static QueryParamDocsIntro: string[] = [
"# URL-parameters and URL-hash",
2021-11-30 22:50:48 +01:00
"This document gives an overview of which URL-parameters can be used to influence MapComplete.",
"## What is a URL parameter?",
2021-11-30 22:50:48 +01:00
'"URL-parameters are extra parts of the URL used to set the state.',
"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: ",
2024-07-21 10:52:51 +02:00
MarkdownUtils.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",
]),
2021-11-30 22:50:48 +01:00
"Finally, the URL-hash is the part after the `#`. It is `node/1234` in this case.",
]
2022-01-26 21:40:38 +01:00
public static UrlParamDocs(): Map<string, string> {
const dummyLayout = new LayoutConfig(<any>{
2022-05-18 01:56:09 +02:00
id: "&gt;theme&lt;",
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: "&lt;layer&gt;",
source: {
osmTags: "id~*",
},
2023-09-19 14:04:13 +02:00
lineRendering: [
{
color: "#000000",
width: 5,
},
],
pointRendering: null,
2022-05-18 01:56:09 +02:00
},
],
})
new FeatureSwitchState(dummyLayout)
QueryParameters.GetQueryParameter(
"layer-&lt;layer-id&gt;",
"true",
"Whether the layer with id <layer-id> is shown"
2022-05-18 01:56:09 +02:00
)
return QueryParameters.documentation
}
public static GenerateQueryParameterDocs(): string {
const docs: string[] = [
2022-01-26 21:40:38 +01:00
...QueryParameterDocumentation.QueryParamDocsIntro,
...ThemeViewStateHashActor.documentation,
2022-09-08 21:40:48 +02:00
]
this.UrlParamDocs().forEach((value, key) => {
const c = [
2024-07-21 10:52:51 +02:00
"## " + key,
value,
2021-11-30 22:50:48 +01:00
QueryParameters.defaults[key] === undefined
? "No default value set"
: `The default value is _${QueryParameters.defaults[key]}_`,
].join("\n\n")
2021-11-30 22:50:48 +01:00
docs.push(c)
})
return docs.join("\n\n")
2021-11-30 22:50:48 +01:00
}
}