forked from MapComplete/MapComplete
108 lines
4.2 KiB
TypeScript
108 lines
4.2 KiB
TypeScript
import * as questions from "../assets/tagRenderings/questions.json";
|
|
import * as icons from "../assets/tagRenderings/icons.json";
|
|
import {Utils} from "../Utils";
|
|
import TagRenderingConfig from "../Models/ThemeConfig/TagRenderingConfig";
|
|
import {TagRenderingConfigJson} from "../Models/ThemeConfig/Json/TagRenderingConfigJson";
|
|
import BaseUIElement from "../UI/BaseUIElement";
|
|
import Combine from "../UI/Base/Combine";
|
|
import Title from "../UI/Base/Title";
|
|
import {FixedUiElement} from "../UI/Base/FixedUiElement";
|
|
import List from "../UI/Base/List";
|
|
|
|
export default class SharedTagRenderings {
|
|
|
|
public static SharedTagRendering: Map<string, TagRenderingConfig> = SharedTagRenderings.generatedSharedFields();
|
|
public static SharedTagRenderingJson: Map<string, TagRenderingConfigJson> = SharedTagRenderings.generatedSharedFieldsJsons();
|
|
public static SharedIcons: Map<string, TagRenderingConfig> = SharedTagRenderings.generatedSharedFields(true);
|
|
|
|
private static generatedSharedFields(iconsOnly = false): Map<string, TagRenderingConfig> {
|
|
const configJsons = SharedTagRenderings.generatedSharedFieldsJsons(iconsOnly)
|
|
const d = new Map<string, TagRenderingConfig>()
|
|
for (const key of Array.from(configJsons.keys())) {
|
|
try {
|
|
d.set(key, new TagRenderingConfig(configJsons.get(key), `SharedTagRenderings.${key}`))
|
|
} catch (e) {
|
|
if (!Utils.runningFromConsole) {
|
|
console.error("BUG: could not parse", key, " from questions.json or icons.json - this error happened during the build step of the SharedTagRenderings", e)
|
|
|
|
}
|
|
}
|
|
}
|
|
return d
|
|
}
|
|
|
|
private static generatedSharedFieldsJsons(iconsOnly = false): Map<string, TagRenderingConfigJson> {
|
|
const dict = new Map<string, TagRenderingConfigJson>();
|
|
|
|
if (!iconsOnly) {
|
|
for (const key in questions) {
|
|
if (key === "id") {
|
|
continue
|
|
}
|
|
dict.set(key, <TagRenderingConfigJson>questions[key])
|
|
}
|
|
}
|
|
for (const key in icons) {
|
|
if (key === "id") {
|
|
continue
|
|
}
|
|
dict.set(key, <TagRenderingConfigJson>icons[key])
|
|
}
|
|
|
|
dict.forEach((value, key) => {
|
|
if (key === "id") {
|
|
return
|
|
}
|
|
value.id = value.id ?? key;
|
|
if(value["builtin"] !== undefined){
|
|
if(value["override"] == undefined){
|
|
throw "HUH? Why whould you want to reuse a builtin if one doesn't override? In questions.json/"+key
|
|
}
|
|
if(typeof value["builtin"] !== "string"){
|
|
return;
|
|
}
|
|
// This is a really funny situation: we extend another tagRendering!
|
|
const parent = Utils.Clone(dict.get(value["builtin"]))
|
|
delete parent.id
|
|
Utils.Merge(value["override"], parent)
|
|
delete value["builtin"]
|
|
delete value["override"]
|
|
for (const pkey in parent) {
|
|
value[pkey] = parent[pkey]
|
|
}
|
|
}
|
|
})
|
|
|
|
|
|
return dict;
|
|
}
|
|
|
|
|
|
public static HelpText(): BaseUIElement {
|
|
return new Combine([
|
|
new Combine([
|
|
|
|
new Title("Builtin questions",1),
|
|
|
|
"The following items can be easily reused in your layers"
|
|
]).SetClass("flex flex-col"),
|
|
|
|
... Array.from( SharedTagRenderings.SharedTagRendering.keys()).map(key => {
|
|
const tr = SharedTagRenderings.SharedTagRendering.get(key)
|
|
let mappings: BaseUIElement = undefined
|
|
if(tr.mappings?.length > 0){
|
|
mappings = new List(tr.mappings.map(m => m.then.textFor("en")))
|
|
}
|
|
return new Combine([
|
|
new Title(key),
|
|
tr.render?.textFor("en"),
|
|
tr.question?.textFor("en") ?? new FixedUiElement("Read-only tagrendering").SetClass("font-bold"),
|
|
mappings
|
|
]).SetClass("flex flex-col")
|
|
|
|
})
|
|
|
|
]).SetClass("flex flex-col")
|
|
}
|
|
|
|
}
|