forked from MapComplete/MapComplete
134 lines
5.4 KiB
TypeScript
134 lines
5.4 KiB
TypeScript
import Combine from "../UI/Base/Combine";
|
|
import BaseUIElement from "../UI/BaseUIElement";
|
|
import Translations from "../UI/i18n/Translations";
|
|
import {existsSync, mkdir, mkdirSync, writeFileSync} from "fs";
|
|
import {AllKnownLayouts} from "../Customizations/AllKnownLayouts";
|
|
import TableOfContents from "../UI/Base/TableOfContents";
|
|
import SimpleMetaTaggers, {SimpleMetaTagger} from "../Logic/SimpleMetaTagger";
|
|
import ValidatedTextField from "../UI/Input/ValidatedTextField";
|
|
import LayoutConfig from "../Models/ThemeConfig/LayoutConfig";
|
|
import SpecialVisualizations from "../UI/SpecialVisualizations";
|
|
import FeatureSwitchState from "../Logic/State/FeatureSwitchState";
|
|
import {ExtraFunctions} from "../Logic/ExtraFunctions";
|
|
import Title from "../UI/Base/Title";
|
|
import Minimap from "../UI/Base/Minimap";
|
|
import {QueryParameters} from "../Logic/Web/QueryParameters";
|
|
import QueryParameterDocumentation from "../UI/QueryParameterDocumentation";
|
|
import ScriptUtils from "./ScriptUtils";
|
|
import List from "../UI/Base/List";
|
|
import SharedTagRenderings from "../Customizations/SharedTagRenderings";
|
|
|
|
function WriteFile(filename, html: BaseUIElement, autogenSource: string[], options?: {
|
|
noTableOfContents: boolean
|
|
}): void {
|
|
|
|
|
|
for (const source of autogenSource) {
|
|
if(source.indexOf("*") > 0){
|
|
continue
|
|
}
|
|
if(!existsSync(source)){
|
|
throw "While creating a documentation file and checking that the generation sources are properly linked: source file "+source+" was not found. Typo?"
|
|
}
|
|
}
|
|
|
|
if (html instanceof Combine && !(options?.noTableOfContents)) {
|
|
const toc = new TableOfContents(html);
|
|
const els = html.getElements();
|
|
html = new Combine(
|
|
[els.shift(),
|
|
toc,
|
|
...els
|
|
]
|
|
).SetClass("flex flex-col")
|
|
}
|
|
|
|
let md = new Combine([Translations.W(html),
|
|
"\n\nThis document is autogenerated from " + autogenSource.map(file => `[${file}](https://github.com/pietervdvn/MapComplete/blob/develop/${file})`).join(", ")
|
|
]).AsMarkdown()
|
|
|
|
md.replace(/\n\n\n+/g, "\n\n");
|
|
|
|
writeFileSync(filename, md);
|
|
}
|
|
|
|
console.log("Starting documentation generation...")
|
|
AllKnownLayouts.GenOverviewsForSingleLayer((layer, element, inlineSource) => {
|
|
console.log("Exporting ", layer.id)
|
|
if(!existsSync("./Docs/Layers")){
|
|
mkdirSync("./Docs/Layers")
|
|
}
|
|
let source: string = `assets/layers/${layer.id}/${layer.id}.json`
|
|
if(inlineSource !== undefined){
|
|
source = `assets/themes/${inlineSource}/${inlineSource}.json`
|
|
}
|
|
WriteFile("./Docs/Layers/" + layer.id + ".md", element, [source], {noTableOfContents: true})
|
|
|
|
})
|
|
WriteFile("./Docs/SpecialRenderings.md", SpecialVisualizations.HelpMessage(), ["UI/SpecialVisualizations.ts"])
|
|
WriteFile("./Docs/CalculatedTags.md", new Combine([new Title("Metatags", 1),
|
|
SimpleMetaTaggers.HelpText(), ExtraFunctions.HelpText()]).SetClass("flex-col"),
|
|
["Logic/SimpleMetaTagger.ts", "Logic/ExtraFunctions.ts"])
|
|
WriteFile("./Docs/SpecialInputElements.md", ValidatedTextField.HelpText(), ["UI/Input/ValidatedTextField.ts"]);
|
|
WriteFile("./Docs/BuiltinLayers.md", AllKnownLayouts.GenLayerOverviewText(), ["Customizations/AllKnownLayouts.ts"])
|
|
WriteFile("./Docs/BuiltinQuestions.md", SharedTagRenderings.HelpText(), ["Customizations/SharedTagRenderings.ts","assets/tagRenderings/questions.json"])
|
|
|
|
{
|
|
// Generate the builtinIndex which shows interlayer dependencies
|
|
var layers = ScriptUtils.getLayerFiles().map(f => f.parsed)
|
|
var builtinsPerLayer= new Map<string, string[]>();
|
|
var layersUsingBuiltin = new Map<string /* Builtin */, string[]>();
|
|
for (const layer of layers) {
|
|
if(layer.tagRenderings === undefined){
|
|
continue
|
|
}
|
|
const usedBuiltins : string[] = []
|
|
for (const tagRendering of layer.tagRenderings) {
|
|
if(typeof tagRendering === "string"){
|
|
usedBuiltins.push(tagRendering)
|
|
continue
|
|
}
|
|
if(tagRendering["builtin"] !== undefined){
|
|
const builtins = tagRendering["builtin"]
|
|
if(typeof builtins === "string"){
|
|
usedBuiltins.push(builtins)
|
|
}else{
|
|
usedBuiltins.push(...builtins)
|
|
}
|
|
}
|
|
}
|
|
for (const usedBuiltin of usedBuiltins) {
|
|
var using = layersUsingBuiltin.get(usedBuiltin)
|
|
if(using === undefined){
|
|
layersUsingBuiltin.set(usedBuiltin, [layer.id])
|
|
}else{
|
|
using.push(layer.id)
|
|
}
|
|
}
|
|
|
|
builtinsPerLayer.set(layer.id, usedBuiltins)
|
|
}
|
|
|
|
const docs = new Combine([
|
|
new Title("Index of builtin TagRendering" ,1),
|
|
new Title("Existing builtin tagrenderings", 2),
|
|
... Array.from(layersUsingBuiltin.entries()).map(([builtin, usedByLayers]) =>
|
|
new Combine([
|
|
new Title(builtin),
|
|
new List(usedByLayers)
|
|
]).SetClass("flex flex-col")
|
|
)
|
|
]).SetClass("flex flex-col")
|
|
WriteFile("./Docs/BuiltinIndex.md", docs, ["assets/layers/*.json"])
|
|
}
|
|
|
|
Minimap.createMiniMap = _ => {
|
|
console.log("Not creating a minimap, it is disabled");
|
|
return undefined
|
|
}
|
|
|
|
|
|
WriteFile("./Docs/URL_Parameters.md", QueryParameterDocumentation.GenerateQueryParameterDocs(), ["Logic/Web/QueryParameters.ts", "UI/QueryParameterDocumentation.ts"])
|
|
|
|
console.log("Generated docs")
|
|
|