mirror of
https://github.com/ascribe/onion.git
synced 2025-01-12 14:00:24 +01:00
39 lines
1.3 KiB
JavaScript
39 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
import languages from '../constants/languages';
|
|
|
|
import { formatText } from './general_utils';
|
|
|
|
|
|
export function getLang() {
|
|
// this is just for testing, as changing the navigator.language wasn't possible
|
|
// return 'fr';
|
|
return navigator.languages ? navigator.languages[0] :
|
|
(navigator.language || navigator.userLanguage);
|
|
}
|
|
|
|
/**
|
|
* Is used to translate strings to another language. Basically can be used with C's string format method.
|
|
* @param {string} s The string you want to translate
|
|
* @param {array} args An array of arguments (essentially JavaScript's this.arguments) that can be used to substitute digits and other strings
|
|
* @return {string} The formated string
|
|
*/
|
|
export function getLangText(s, ...args) {
|
|
let lang = getLang();
|
|
try {
|
|
if(lang in languages) {
|
|
return formatText(languages[lang][s], args);
|
|
} else {
|
|
// just use the english language
|
|
return formatText(languages['en-US'][s], args);
|
|
}
|
|
} catch(err) {
|
|
//if(!(s in languages[lang])) {
|
|
//console.warn('Language-string is not in constants file. Add: "' + s + '" to the "' + lang + '" language file. Defaulting to keyname');
|
|
return formatText(s, args);
|
|
//} else {
|
|
// console.error(err);
|
|
//}
|
|
}
|
|
}
|