2022-09-08 21:40:48 +02:00
|
|
|
import { DropDown } from "./Input/DropDown"
|
|
|
|
import Locale from "./i18n/Locale"
|
|
|
|
import BaseUIElement from "./BaseUIElement"
|
2023-02-08 01:14:21 +01:00
|
|
|
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"
|
2023-03-09 17:11:44 +01:00
|
|
|
import LanguageUtils from "../Utils/LanguageUtils"
|
2023-06-06 00:03:50 +02:00
|
|
|
import {UIEventSource} from "../Logic/UIEventSource";
|
2020-11-05 13:34:48 +01:00
|
|
|
|
2022-07-03 00:30:11 +02:00
|
|
|
export default class LanguagePicker extends Toggle {
|
2023-06-06 00:03:50 +02:00
|
|
|
constructor(languages: string[], assignTo: UIEventSource<string>) {
|
2022-09-27 18:48:02 +02:00
|
|
|
console.log("Constructing a language pîcker for languages", languages)
|
2021-11-30 21:29:17 +01:00
|
|
|
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 {
|
2023-06-06 00:03:50 +02:00
|
|
|
const normalPicker = LanguagePicker.dropdownFor(languages, assignTo ?? Locale.language)
|
|
|
|
const fullPicker = new Lazy(() => LanguagePicker.dropdownFor(allLanguages, assignTo ?? Locale.language))
|
2022-09-27 18:48:02 +02:00
|
|
|
super(fullPicker, normalPicker, Locale.showLinkToWeblate)
|
2023-03-09 17:11:44 +01:00
|
|
|
const allLanguages: string[] = LanguageUtils.usedLanguagesSorted
|
2020-11-05 13:34:48 +01:00
|
|
|
}
|
2022-04-03 03:00:45 +02:00
|
|
|
}
|
2022-07-03 00:30:11 +02:00
|
|
|
|
2023-06-06 00:03:50 +02:00
|
|
|
private static dropdownFor(languages: string[], assignTo: UIEventSource<string>): BaseUIElement {
|
2022-09-08 21:40:48 +02:00
|
|
|
return new DropDown(
|
2023-06-06 00:03:50 +02:00
|
|
|
undefined,
|
2022-09-08 21:40:48 +02:00
|
|
|
languages
|
|
|
|
.filter((lang) => lang !== "_context")
|
|
|
|
.map((lang) => {
|
|
|
|
return { value: lang, shown: LanguagePicker.hybrid(lang) }
|
|
|
|
}),
|
2023-06-06 00:03:50 +02:00
|
|
|
assignTo
|
2022-09-08 21:40:48 +02:00
|
|
|
)
|
2020-11-05 13:34:48 +01:00
|
|
|
}
|
|
|
|
|
2022-02-24 02:33:20 +01:00
|
|
|
private static hybrid(lang: string): Translation {
|
|
|
|
const nativeText = native[lang] ?? lang
|
|
|
|
const translation = {}
|
2023-02-08 01:14:21 +01:00
|
|
|
const trans = language_translations[lang]
|
2022-07-03 00:30:11 +02:00
|
|
|
if (trans === undefined) {
|
2022-09-08 21:40:48 +02:00
|
|
|
return new Translation({ "*": nativeText })
|
2022-02-24 02:33:20 +01:00
|
|
|
}
|
|
|
|
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
|
|
|
|
}
|
2023-02-08 01:14:21 +01:00
|
|
|
const translationInKey = language_translations[lang][key]
|
2022-07-03 00:30:11 +02:00
|
|
|
if (nativeText.toLowerCase() === translationInKey.toLowerCase()) {
|
2022-02-24 02:33:20 +01:00
|
|
|
translation[key] = nativeText
|
2022-07-03 00:30:11 +02:00
|
|
|
} else {
|
|
|
|
translation[key] = nativeText + " (" + translationInKey + ")"
|
2022-02-24 02:33:20 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return new Translation(translation)
|
2022-07-03 00:30:11 +02:00
|
|
|
}
|
2022-09-08 21:40:48 +02:00
|
|
|
}
|