forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			99 lines
		
	
	
		
			No EOL
		
	
	
		
			3.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			No EOL
		
	
	
		
			3.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {InputElement} from "./InputElement";
 | |
| import {UIEventSource} from "../../Logic/UIEventSource";
 | |
| import {TextField} from "./TextField";
 | |
| 
 | |
| export default class MultiLingualTextFields extends InputElement<any> {
 | |
|     private _fields: Map<string, TextField> = new Map<string, TextField>();
 | |
|     private readonly _value: UIEventSource<any>;
 | |
|     public readonly IsSelected: UIEventSource<boolean> = new UIEventSource<boolean>(false);
 | |
|     constructor(languages: UIEventSource<string[]>,
 | |
|                 textArea: boolean = false,
 | |
|                 value: UIEventSource<Map<string, UIEventSource<string>>> = undefined) {
 | |
|         super(undefined);
 | |
|         this._value = value ?? new UIEventSource({});
 | |
|         this._value.addCallbackAndRun(latestData => {
 | |
|             if (typeof (latestData) === "string") {
 | |
|                 console.warn("Refusing string for multilingual input", latestData);
 | |
|                 self._value.setData({});
 | |
|             }
 | |
|         })
 | |
|         
 | |
|         const self = this;
 | |
| 
 | |
|         function setup(languages: string[]) {
 | |
|             if (languages === undefined) {
 | |
|                 return;
 | |
|             }
 | |
|             const newFields = new Map<string, TextField>();
 | |
|             for (const language of languages) {
 | |
|                 if (language.length != 2) {
 | |
|                     continue;
 | |
|                 }
 | |
|                 
 | |
|                 let oldField = self._fields.get(language);
 | |
|                 if (oldField === undefined) {
 | |
|                     oldField = new TextField({textArea: textArea});
 | |
|                     oldField.GetValue().addCallback(str => {
 | |
|                         self._value.data[language] = str;
 | |
|                         self._value.ping();
 | |
|                     });
 | |
|                     oldField.GetValue().setData(self._value.data[language]);
 | |
|                     
 | |
|                     oldField.IsSelected.addCallback(() => {
 | |
|                         let selected = false;
 | |
|                         self._fields.forEach(value => {selected = selected || value.IsSelected.data});
 | |
|                         self.IsSelected.setData(selected);
 | |
|                     })
 | |
|                     
 | |
|                 }
 | |
|                 newFields.set(language, oldField);
 | |
|             }
 | |
|             self._fields = newFields;
 | |
|             self.Update();
 | |
| 
 | |
|           
 | |
|         }
 | |
| 
 | |
|         setup(languages.data);
 | |
|         languages.addCallback(setup);
 | |
| 
 | |
| 
 | |
|         function load(latest: any){
 | |
|             if(latest === undefined){
 | |
|                 return;
 | |
|             }
 | |
|             for (const lang in latest) {
 | |
|                 self._fields.get(lang)?.GetValue().setData(latest[lang]);
 | |
|             }
 | |
|         }
 | |
|         this._value.addCallback(load);
 | |
|         load(this._value.data);
 | |
|     }
 | |
| 
 | |
|     protected InnerUpdate(htmlElement: HTMLElement) {
 | |
|         super.InnerUpdate(htmlElement);
 | |
|         this._fields.forEach(value => value.Update());
 | |
|     }
 | |
| 
 | |
|     GetValue(): UIEventSource<Map<string, UIEventSource<string>>> {
 | |
|         return this._value;
 | |
|     }
 | |
| 
 | |
|     InnerRender(): string {
 | |
|         let html = "";
 | |
|         this._fields.forEach((field, lang) => {
 | |
|             html += `<tr><td>${lang}</td><td>${field.Render()}</td></tr>`
 | |
|         })
 | |
|         if(html === ""){
 | |
|             return "Please define one or more languages"
 | |
|         }
 | |
|         
 | |
|         return `<table>${html}</table>`;
 | |
|     }
 | |
| 
 | |
| 
 | |
|     IsValid(t: any): boolean {
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
| } |