forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			141 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import Combine from "../UI/Base/Combine";
 | 
						|
import BaseUIElement from "../UI/BaseUIElement";
 | 
						|
import Translations from "../UI/i18n/Translations";
 | 
						|
import {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";
 | 
						|
 | 
						|
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
 | 
						|
            ]
 | 
						|
        ).SetClass("flex flex-col")
 | 
						|
    }
 | 
						|
 | 
						|
    let md = new Combine([Translations.W(html),
 | 
						|
        "\n\nThis document is autogenerated from " + autogenSource.join(", ")
 | 
						|
    ]).AsMarkdown()
 | 
						|
 | 
						|
    md.replace(/\n\n\n+/g, "\n\n");
 | 
						|
 | 
						|
    writeFileSync(filename, md);
 | 
						|
}
 | 
						|
 | 
						|
console.log("Starting documentation generation...")
 | 
						|
AllKnownLayouts.GenOverviewsForSingleLayer((layer, element) => {
 | 
						|
    console.log("Exporting ", layer.id)
 | 
						|
    WriteFile("./Docs/Layers/" + layer.id + ".md", element, [`assets/layers/${layer.id}/${layer.id}.json`])
 | 
						|
 | 
						|
})
 | 
						|
WriteFile("./Docs/SpecialRenderings.md", SpecialVisualizations.HelpMessage(), ["UI/SpecialVisualisations.ts"])
 | 
						|
WriteFile("./Docs/CalculatedTags.md", new Combine([new Title("Metatags", 1),
 | 
						|
        SimpleMetaTaggers.HelpText(), ExtraFunctions.HelpText()]).SetClass("flex-col"),
 | 
						|
    ["SimpleMetaTagger", "ExtraFunction"])
 | 
						|
WriteFile("./Docs/SpecialInputElements.md", ValidatedTextField.HelpText(), ["ValidatedTextField.ts"]);
 | 
						|
WriteFile("./Docs/BuiltinLayers.md", AllKnownLayouts.GenLayerOverviewText(), ["AllKnownLayers.ts"])
 | 
						|
 | 
						|
{
 | 
						|
    // 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
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
const dummyLayout = new LayoutConfig({
 | 
						|
    id: ">theme<",
 | 
						|
    maintainer: "pietervdvn",
 | 
						|
    version: "0",
 | 
						|
    title: {en:"<theme>"},
 | 
						|
    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")
 | 
						|
 | 
						|
WriteFile("./Docs/URL_Parameters.md", QueryParameterDocumentation.GenerateQueryParameterDocs(), ["QueryParameters"])
 | 
						|
 | 
						|
console.log("Generated docs")
 | 
						|
 |