This repository has been archived on 2025-12-11. You can view files and clone it, but cannot push or open issues or pull requests.
2025-02-02 10:40:42 +01:00

66 lines
1.5 KiB
JavaScript

var locale = [];
/**
* Similar to the concept of gettext, this function returns the
* localized string for the parsed string. The function supports
* wrapping.
*
* @param {string} args The string we want localized
* @return {string} Returns the localized string
*
*/
function _U() {
var args = arguments;
var string = args[0];
// Was a string specified?
if (!string) {
console.log('locale.js: no string was parsed');
return 'locale.js: no string was parsed';
}
// Has the locale file been set?
if (locale.length === 0) {
console.log('locale.js: no locale has been set');
return 'locale.js: no locale has been set';
}
// Does the translation exist?
if (!locale[string]) {
console.log('locale.js: translation [{0}] does not exist'.format(string));
return 'locale.js: translation [{0}] does not exist'.format(string);
}
// Do we need to format the string?
if (args.length === 1) {
return capitalize(locale[string]);
} else {
return formatString(args);
}
}
function formatString(args) {
var string = capitalize(locale[args[0]]);
for (var i = 1; i < args.length; i++) {
string = string.replace(/%s/, args[i]);
}
return string;
}
function capitalize(string) {
return string[0].toUpperCase() + string.slice(1);
}
// https://stackoverflow.com/a/35359503
String.prototype.format = function () {
var args = arguments;
return this.replace(/{(\d+)}/g, function (match, number) {
return typeof args[number] != 'undefined'
? args[number]
: match
;
});
};