MapComplete/src/Models/ThemeConfig/Conversion/ValidationUtils.ts

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

79 lines
2.8 KiB
TypeScript
Raw Normal View History

import { TagRenderingConfigJson } from "../Json/TagRenderingConfigJson"
import { Utils } from "../../../Utils"
import SpecialVisualizations from "../../../UI/SpecialVisualizations"
import { RenderingSpecification, SpecialVisualization } from "../../../UI/SpecialVisualization"
2023-10-31 11:49:14 +01:00
import { QuestionableTagRenderingConfigJson } from "../Json/QuestionableTagRenderingConfigJson"
export default class ValidationUtils {
2023-10-31 11:49:14 +01:00
public static getAllSpecialVisualisations(
renderingConfigs: (TagRenderingConfigJson | QuestionableTagRenderingConfigJson)[]
): RenderingSpecification[] {
const visualisations: RenderingSpecification[] = []
if (!Array.isArray(renderingConfigs)) {
throw (
"Could not inspect renderingConfigs, not an array: " +
JSON.stringify(renderingConfigs)
)
}
2023-10-31 11:49:14 +01:00
for (const renderConfig of renderingConfigs) {
visualisations.push(...ValidationUtils.getSpecialVisualisationsWithArgs(renderConfig))
}
return visualisations
}
/**
* Gives all the (function names of) used special visualisations
* @param renderingConfig
*/
public static getSpecialVisualisations(
renderingConfig: TagRenderingConfigJson
): SpecialVisualization[] {
2023-10-31 11:49:14 +01:00
return ValidationUtils.getSpecialVisualisationsWithArgs(renderingConfig).map(
2023-03-31 03:28:11 +02:00
(spec) => spec["func"]
)
}
2023-10-31 11:49:14 +01:00
public static getSpecialVisualisationsWithArgs(
2023-03-31 03:28:11 +02:00
renderingConfig: TagRenderingConfigJson
): RenderingSpecification[] {
2023-10-31 11:49:14 +01:00
if (!renderingConfig) {
return []
}
const cacheName = "__specialVisualisationsWithArgs_cache"
if (renderingConfig[cacheName]) {
return renderingConfig[cacheName]
}
const translations: any[] = Utils.NoNull([
renderingConfig.render,
...(renderingConfig.mappings ?? []).map((m) => m.then),
])
2023-03-31 03:28:11 +02:00
const all: RenderingSpecification[] = []
for (let translation of translations) {
if (typeof translation == "string") {
translation = { "*": translation }
}
for (const key in translation) {
if (!translation.hasOwnProperty(key)) {
continue
}
const template = translation[key]
const parts = SpecialVisualizations.constructSpecification(template)
2023-03-31 03:28:11 +02:00
const specials = parts.filter((p) => typeof p !== "string")
all.push(...specials)
}
}
2023-10-31 11:49:14 +01:00
// _Very_ dirty hack
Object.defineProperty(renderingConfig, cacheName, {
value: all,
enumerable: false,
configurable: true,
writable: true,
})
return all
}
}