116 lines
3.9 KiB
TypeScript
116 lines
3.9 KiB
TypeScript
import {FixedUiElement} from "../Base/FixedUiElement";
|
|
import {Translation} from "./Translation";
|
|
import BaseUIElement from "../BaseUIElement";
|
|
import * as known_languages from "../../assets/generated/used_languages.json"
|
|
import CompiledTranslations from "../../assets/generated/CompiledTranslations";
|
|
|
|
export default class Translations {
|
|
|
|
static t = CompiledTranslations.t;
|
|
private static knownLanguages = new Set(known_languages.languages)
|
|
constructor() {
|
|
throw "Translations is static. If you want to intitialize a new translation, use the singular form"
|
|
}
|
|
|
|
public static W(s: string | BaseUIElement): BaseUIElement {
|
|
if (typeof (s) === "string") {
|
|
return new FixedUiElement(s);
|
|
}
|
|
if (typeof s === "number") {
|
|
return new FixedUiElement("" + s)
|
|
}
|
|
return s;
|
|
}
|
|
|
|
static T(t: string | any, context = undefined): Translation {
|
|
if (t === undefined || t === null) {
|
|
return undefined;
|
|
}
|
|
if (typeof t === "number") {
|
|
t = "" + t
|
|
}
|
|
if (typeof t === "string") {
|
|
return new Translation({"*": t}, context);
|
|
}
|
|
if (t.render !== undefined) {
|
|
const msg = "Creating a translation, but this object contains a 'render'-field. Use the translation directly"
|
|
console.error(msg, t);
|
|
throw msg
|
|
}
|
|
if (t instanceof Translation) {
|
|
return t;
|
|
}
|
|
return new Translation(t, context);
|
|
}
|
|
|
|
/**
|
|
* 'Wrap Translation': given an object containing translations OR a string, returns a translation object
|
|
*
|
|
* const json: any = {"en": "English", "nl": "Nederlands"};
|
|
* const translation = Translations.WT(new Translation(json));
|
|
* translation.textFor("en") // => "English"
|
|
* translation.textFor("nl") // => "Nederlands"
|
|
*/
|
|
public static WT(s: string | Translation): Translation {
|
|
if (s === undefined || s === null) {
|
|
return undefined;
|
|
}
|
|
if (typeof (s) === "string") {
|
|
return new Translation({'*': s});
|
|
}
|
|
if (s instanceof Translation) {
|
|
return s.Clone() /* MUST CLONE HERE! */;
|
|
}
|
|
console.error("Trying to Translation.WT, but got ", s)
|
|
throw "??? Not a valid translation"
|
|
}
|
|
|
|
public static CountTranslations() {
|
|
const queue: any = [Translations.t];
|
|
const tr: Translation[] = [];
|
|
while (queue.length > 0) {
|
|
const item = queue.pop();
|
|
if (item instanceof Translation || item.translations !== undefined) {
|
|
tr.push(item);
|
|
} else if (typeof (item) === "string") {
|
|
console.warn("Got single string in translationgs file: ", item);
|
|
} else {
|
|
for (const t in item) {
|
|
const x = item[t];
|
|
queue.push(x)
|
|
}
|
|
}
|
|
}
|
|
|
|
const langaugeCounts = {};
|
|
for (const translation of tr) {
|
|
for (const language in translation.translations) {
|
|
if (langaugeCounts[language] === undefined) {
|
|
langaugeCounts[language] = 1
|
|
} else {
|
|
langaugeCounts[language]++;
|
|
}
|
|
}
|
|
}
|
|
for (const language in langaugeCounts) {
|
|
console.log("Total translations in ", language, langaugeCounts[language], "/", tr.length)
|
|
}
|
|
|
|
}
|
|
|
|
static isProbablyATranslation(transl: any) {
|
|
if(typeof transl !== "object"){
|
|
return false;
|
|
}
|
|
if(Object.keys(transl).length == 0){
|
|
// No translations found; not a translation
|
|
return false
|
|
}
|
|
// is a weird key found?
|
|
if(Object.keys(transl).some(key => !this.knownLanguages.has(key))){
|
|
return false
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|