Merge pull request #63 from onovy/auto-translation

Try to auto-detect user language and translate web.
This commit is contained in:
pointbiz 2014-04-16 20:36:25 -07:00
commit 351a8df3f4
3 changed files with 32 additions and 0 deletions

View file

@ -7488,6 +7488,17 @@ ninja.foreachSerialized = function (collection, whatToDo, onComplete) {
ninja.translator = { ninja.translator = {
currentCulture: "en", currentCulture: "en",
autodetectTranslation: function() {
// window.navigator.language for Firefox / Chrome / Opera Safari
// window.navigator.userLanguage for IE
var language = window.navigator.language || window.navigator.userLanguage;
if (!ninja.translator.translate(language)) {
// Try to remove part after dash, for example cs-CZ -> cs
language = language.substr(0, language.indexOf('-'));
ninja.translator.translate(language);
}
},
translate: function (culture) { translate: function (culture) {
var dict = ninja.translator.translations[culture]; var dict = ninja.translator.translations[culture];
if (dict) { if (dict) {
@ -7507,6 +7518,9 @@ ninja.translator = {
document.getElementById(id).innerHTML = dict[id]; document.getElementById(id).innerHTML = dict[id];
} }
} }
return true;
} else {
return false;
} }
}, },
@ -9900,6 +9914,8 @@ if (ninja.getQueryString()["asyncunittests"] == "true" || ninja.getQueryString()
// change language // change language
if (ninja.getQueryString()["culture"] != undefined) { if (ninja.getQueryString()["culture"] != undefined) {
ninja.translator.translate(ninja.getQueryString()["culture"]); ninja.translator.translate(ninja.getQueryString()["culture"]);
} else {
ninja.translator.autodetectTranslation();
} }
// testnet, check if testnet edition should be activated // testnet, check if testnet edition should be activated
if (ninja.getQueryString()["testnet"] == "true" || ninja.getQueryString()["testnet"] == "1") { if (ninja.getQueryString()["testnet"] == "true" || ninja.getQueryString()["testnet"] == "1") {

View file

@ -10,6 +10,8 @@ if (ninja.getQueryString()["asyncunittests"] == "true" || ninja.getQueryString()
// change language // change language
if (ninja.getQueryString()["culture"] != undefined) { if (ninja.getQueryString()["culture"] != undefined) {
ninja.translator.translate(ninja.getQueryString()["culture"]); ninja.translator.translate(ninja.getQueryString()["culture"]);
} else {
ninja.translator.autodetectTranslation();
} }
// testnet, check if testnet edition should be activated // testnet, check if testnet edition should be activated
if (ninja.getQueryString()["testnet"] == "true" || ninja.getQueryString()["testnet"] == "1") { if (ninja.getQueryString()["testnet"] == "true" || ninja.getQueryString()["testnet"] == "1") {

View file

@ -1,6 +1,17 @@
ninja.translator = { ninja.translator = {
currentCulture: "en", currentCulture: "en",
autodetectTranslation: function() {
// window.navigator.language for Firefox / Chrome / Opera Safari
// window.navigator.userLanguage for IE
var language = window.navigator.language || window.navigator.userLanguage;
if (!ninja.translator.translate(language)) {
// Try to remove part after dash, for example cs-CZ -> cs
language = language.substr(0, language.indexOf('-'));
ninja.translator.translate(language);
}
},
translate: function (culture) { translate: function (culture) {
var dict = ninja.translator.translations[culture]; var dict = ninja.translator.translations[culture];
if (dict) { if (dict) {
@ -20,6 +31,9 @@ ninja.translator = {
document.getElementById(id).innerHTML = dict[id]; document.getElementById(id).innerHTML = dict[id];
} }
} }
return true;
} else {
return false;
} }
}, },