forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			43 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 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> {
 | |
|     private readonly _inputElement: InputElement<T>
 | |
|     private readonly _renderElement: BaseUIElement
 | |
| 
 | |
|     constructor(
 | |
|         inputElement: InputElement<T>,
 | |
|         translation: Translation,
 | |
|         key: string,
 | |
|         tags: UIEventSource<any>,
 | |
|         state: FeaturePipelineState
 | |
|     ) {
 | |
|         super()
 | |
|         this._inputElement = inputElement
 | |
|         const mapping = new Map<string, BaseUIElement>()
 | |
| 
 | |
|         mapping.set(key, inputElement)
 | |
| 
 | |
|         // Bit of a hack: the SubstitutedTranslation expects a special rendering, but those are formatted '{key()}' instead of '{key}', so we substitute it first
 | |
|         translation = translation.OnEveryLanguage((txt) =>
 | |
|             txt.replace("{" + key + "}", "{" + key + "()}")
 | |
|         )
 | |
|         this._renderElement = new SubstitutedTranslation(translation, tags, state, mapping)
 | |
|     }
 | |
| 
 | |
|     GetValue(): UIEventSource<T> {
 | |
|         return this._inputElement.GetValue()
 | |
|     }
 | |
| 
 | |
|     IsValid(t: T): boolean {
 | |
|         return this._inputElement.IsValid(t)
 | |
|     }
 | |
| 
 | |
|     protected InnerConstructElement(): HTMLElement {
 | |
|         return this._renderElement.ConstructElement()
 | |
|     }
 | |
| }
 |