MapComplete/UI/LanguagePicker.ts

58 lines
2.3 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { DropDown } from "./Input/DropDown"
import Locale from "./i18n/Locale"
import BaseUIElement from "./BaseUIElement"
import native from "../assets/language_native.json"
import language_translations from "../assets/language_translations.json"
2022-09-08 21:40:48 +02:00
import { Translation } from "./i18n/Translation"
import Lazy from "./Base/Lazy"
import Toggle from "./Input/Toggle"
import LanguageUtils from "../Utils/LanguageUtils"
import {UIEventSource} from "../Logic/UIEventSource";
export default class LanguagePicker extends Toggle {
constructor(languages: string[], assignTo: UIEventSource<string>) {
console.log("Constructing a language pîcker for languages", languages)
if (languages === undefined || languages.length <= 1) {
2022-09-08 21:40:48 +02:00
super(undefined, undefined, undefined)
2022-10-27 01:50:01 +02:00
} else {
const normalPicker = LanguagePicker.dropdownFor(languages, assignTo ?? Locale.language)
const fullPicker = new Lazy(() => LanguagePicker.dropdownFor(allLanguages, assignTo ?? Locale.language))
super(fullPicker, normalPicker, Locale.showLinkToWeblate)
const allLanguages: string[] = LanguageUtils.usedLanguagesSorted
}
}
private static dropdownFor(languages: string[], assignTo: UIEventSource<string>): BaseUIElement {
2022-09-08 21:40:48 +02:00
return new DropDown(
undefined,
2022-09-08 21:40:48 +02:00
languages
.filter((lang) => lang !== "_context")
.map((lang) => {
return { value: lang, shown: LanguagePicker.hybrid(lang) }
}),
assignTo
2022-09-08 21:40:48 +02:00
)
}
private static hybrid(lang: string): Translation {
const nativeText = native[lang] ?? lang
const translation = {}
const trans = language_translations[lang]
if (trans === undefined) {
2022-09-08 21:40:48 +02:00
return new Translation({ "*": nativeText })
}
for (const key in trans) {
2022-11-02 13:47:34 +01:00
if (key.startsWith("_")) {
2022-10-29 03:02:42 +02:00
continue
}
const translationInKey = language_translations[lang][key]
if (nativeText.toLowerCase() === translationInKey.toLowerCase()) {
translation[key] = nativeText
} else {
translation[key] = nativeText + " (" + translationInKey + ")"
}
}
return new Translation(translation)
}
2022-09-08 21:40:48 +02:00
}