MapComplete/UI/Input/InputElementWrapper.ts

44 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { InputElement } from "./InputElement"
import { UIEventSource } from "../../Logic/UIEventSource"
import BaseUIElement from "../BaseUIElement"
import { Translation } from "../i18n/Translation"
import { SubstitutedTranslation } from "../SubstitutedTranslation"
import FeaturePipelineState from "../../Logic/State/FeaturePipelineState"
export default class InputElementWrapper<T> extends InputElement<T> {
2022-09-08 21:40:48 +02:00
private readonly _inputElement: InputElement<T>
private readonly _renderElement: BaseUIElement
2022-09-08 21:40:48 +02:00
constructor(
inputElement: InputElement<T>,
translation: Translation,
key: string,
tags: UIEventSource<any>,
state: FeaturePipelineState
) {
super()
2022-09-08 21:40:48 +02:00
this._inputElement = inputElement
const mapping = new Map<string, BaseUIElement>()
mapping.set(key, inputElement)
2022-01-12 02:31:51 +01:00
// Bit of a hack: the SubstitutedTranslation expects a special rendering, but those are formatted '{key()}' instead of '{key}', so we substitute it first
2022-09-08 21:40:48 +02:00
translation = translation.OnEveryLanguage((txt) =>
txt.replace("{" + key + "}", "{" + key + "()}")
)
this._renderElement = new SubstitutedTranslation(translation, tags, state, mapping)
}
GetValue(): UIEventSource<T> {
2022-09-08 21:40:48 +02:00
return this._inputElement.GetValue()
}
IsValid(t: T): boolean {
2022-09-08 21:40:48 +02:00
return this._inputElement.IsValid(t)
}
protected InnerConstructElement(): HTMLElement {
2022-09-08 21:40:48 +02:00
return this._renderElement.ConstructElement()
}
2022-09-08 21:40:48 +02:00
}