mapcomplete/UI/Popup/TagRenderingAnswer.ts

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

79 lines
2.9 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { UIEventSource } from "../../Logic/UIEventSource"
import { Utils } from "../../Utils"
import BaseUIElement from "../BaseUIElement"
import { VariableUiElement } from "../Base/VariableUIElement"
import { SubstitutedTranslation } from "../SubstitutedTranslation"
import TagRenderingConfig from "../../Models/ThemeConfig/TagRenderingConfig"
import Combine from "../Base/Combine"
import Img from "../Base/Img"
2020-10-27 01:01:34 +01:00
/***
* Displays the correct value for a known tagrendering
*/
2021-06-14 02:39:23 +02:00
export default class TagRenderingAnswer extends VariableUiElement {
2022-09-08 21:40:48 +02:00
constructor(
tagsSource: UIEventSource<any>,
configuration: TagRenderingConfig,
state: any,
contentClasses: string = "",
contentStyle: string = "",
options?: {
2022-01-26 21:40:38 +01:00
specialViz: Map<string, BaseUIElement>
2022-09-08 21:40:48 +02:00
}
) {
if (configuration === undefined) {
2020-11-17 02:22:48 +01:00
throw "Trying to generate a tagRenderingAnswer without configuration..."
}
2021-11-08 14:18:45 +01:00
if (tagsSource === undefined) {
throw "Trying to generate a tagRenderingAnswer without tagSource..."
}
2022-09-08 21:40:48 +02:00
super(
tagsSource
.map((tags) => {
if (tags === undefined) {
return undefined
}
2021-07-16 02:13:41 +02:00
2022-09-08 21:40:48 +02:00
if (configuration.condition) {
if (!configuration.condition.matchesProperties(tags)) {
return undefined
}
}
2021-07-16 02:13:41 +02:00
2022-09-08 21:40:48 +02:00
const trs = Utils.NoNull(configuration.GetRenderValues(tags))
if (trs.length === 0) {
return undefined
}
2021-07-16 02:13:41 +02:00
2022-09-08 21:40:48 +02:00
const valuesToRender: BaseUIElement[] = trs.map((tr) => {
const text = new SubstitutedTranslation(
tr.then,
tagsSource,
state,
options?.specialViz
)
if (tr.icon === undefined) {
return text
}
return new Combine([
new Img(tr.icon).SetClass("mapping-icon-" + (tr.iconClass ?? "small")),
text,
]).SetClass("flex items-center")
})
if (valuesToRender.length === 1) {
return valuesToRender[0]
} else if (valuesToRender.length > 1) {
return new Combine(valuesToRender).SetClass("flex flex-col")
}
return undefined
})
.map((element: BaseUIElement) =>
element?.SetClass(contentClasses)?.SetStyle(contentStyle)
)
)
2021-07-16 02:13:41 +02:00
this.SetClass("flex items-center flex-row text-lg link-underline")
2022-09-08 21:40:48 +02:00
this.SetStyle("word-wrap: anywhere;")
2020-10-27 01:01:34 +01:00
}
2022-09-08 21:40:48 +02:00
}