mapcomplete/scripts/generateDocs.ts

84 lines
2.8 KiB
TypeScript
Raw Normal View History

import {Utils} from "../Utils";
import SpecialVisualizations from "../UI/SpecialVisualizations";
import SimpleMetaTagger from "../Logic/SimpleMetaTagger";
2021-03-24 02:01:04 +01:00
import Combine from "../UI/Base/Combine";
import {ExtraFunction} from "../Logic/ExtraFunction";
import ValidatedTextField from "../UI/Input/ValidatedTextField";
import BaseUIElement from "../UI/BaseUIElement";
import Translations from "../UI/i18n/Translations";
import {writeFileSync} from "fs";
import {QueryParameters} from "../Logic/Web/QueryParameters";
import LayoutConfig from "../Models/ThemeConfig/LayoutConfig";
2021-10-28 03:21:17 +02:00
import Minimap from "../UI/Base/Minimap";
import FeatureSwitchState from "../Logic/State/FeatureSwitchState";
2021-11-08 02:36:01 +01:00
import {AllKnownLayouts} from "../Customizations/AllKnownLayouts";
2021-11-30 22:50:48 +01:00
import TableOfContents from "../UI/Base/TableOfContents";
import Title from "../UI/Base/Title";
import QueryParameterDocumentation from "../UI/QueryParameterDocumentation";
2021-11-07 16:34:51 +01:00
Utils.runningFromConsole = true;
2021-06-16 21:23:03 +02:00
2021-11-30 22:50:48 +01:00
function WriteFile(filename, html: BaseUIElement, autogenSource: string[]): void {
if (html instanceof Combine) {
const toc = new TableOfContents(html);
const els = html.getElements();
html = new Combine(
[els.shift(),
toc,
...els
]
)
}
2021-06-16 17:09:32 +02:00
writeFileSync(filename, new Combine([Translations.W(html),
2021-11-08 02:36:01 +01:00
"\n\nThis document is autogenerated from " + autogenSource.join(", ")
2021-06-16 17:09:32 +02:00
]).AsMarkdown());
}
WriteFile("./Docs/SpecialRenderings.md", SpecialVisualizations.HelpMessage(), ["UI/SpecialVisualisations.ts"])
2021-11-30 22:50:48 +01:00
WriteFile("./Docs/CalculatedTags.md", new Combine([new Title("Metatags", 1), SimpleMetaTagger.HelpText(), ExtraFunction.HelpText()]).SetClass("flex-col"),
["SimpleMetaTagger", "ExtraFunction"])
WriteFile("./Docs/SpecialInputElements.md", ValidatedTextField.HelpText(), ["ValidatedTextField.ts"]);
2021-11-08 02:36:01 +01:00
WriteFile("./Docs/BuiltinLayers.md", AllKnownLayouts.GenLayerOverviewText(), ["AllKnownLayers.ts"])
2021-10-28 03:21:17 +02:00
Minimap.createMiniMap = _ => {
console.log("Not creating a minimap, it is disabled");
return undefined
}
2021-03-22 01:06:24 +01:00
2021-10-28 03:21:17 +02:00
const dummyLayout = new LayoutConfig({
language: ["en"],
id: "<theme>",
maintainer: "pietervdvn",
version: "0",
title: "<theme>",
description: "A theme to generate docs with",
startLat: 0,
startLon: 0,
startZoom: 0,
icon: undefined,
layers: [
{
name: "<layer>",
id: "<layer>",
source: {
osmTags: "id~*"
2021-10-28 03:21:17 +02:00
},
2021-11-30 22:50:48 +01:00
mapRendering: null,
}
]
2021-10-28 03:21:17 +02:00
})
new FeatureSwitchState(dummyLayout)
QueryParameters.GetQueryParameter("layer-<layer-id>", "true", "Wether or not the layer with id <layer-id> is shown")
2021-11-30 22:50:48 +01:00
WriteFile("./Docs/URL_Parameters.md", QueryParameterDocumentation.GenerateQueryParameterDocs(), ["QueryParameters"])
2021-03-22 01:06:24 +01:00
console.log("Generated docs")