mirror of
https://github.com/OneKeyHQ/bip39.git
synced 2026-04-18 16:32:18 +00:00
154 lines
4.6 KiB
JavaScript
154 lines
4.6 KiB
JavaScript
// An extremely basic translation library
|
|
//
|
|
// Example usage:
|
|
//
|
|
// Set some html to be translated. Do this using the 'data-translate' attribute:
|
|
//
|
|
// <div data-translate>Test</div>
|
|
// <div data-translate-html><em>keep em tag</em></div>
|
|
// <input data-translate-placeholder placeholder="Example placeholder">
|
|
// <span data-translate-title title="Example title"></span>
|
|
//
|
|
// Obtain all the phrases to be translated via js debug console:
|
|
//
|
|
// Translate.phrasesAsJson();
|
|
//
|
|
// Use that template to translate the phrases into another language.
|
|
// Leave the key the same. Change the value to the new language.
|
|
//
|
|
// Create a js file to load the new phrases. In this example for Spanish,
|
|
// es.js will contain the following code:
|
|
//
|
|
// Translate.loadForeignPhrases("es", {
|
|
// "Test": "Test in Spanish",
|
|
// "<em>keep em tag</em>": "<em>keep em tag in Spanish</em>",
|
|
// "Example placeholder": "Example placeholder in Spanish"
|
|
// "Example title": "Example title in Spanish"
|
|
// });
|
|
//
|
|
// In your UI put a listener for clicking on the Spanish button:
|
|
//
|
|
// mySpanishButton.addEventListener("click", function() {
|
|
// Translate.setLanguage("es");
|
|
// });
|
|
// myEnglishButton.addEventListener("click", function() {
|
|
// Translate.setLanguage("en");
|
|
// });
|
|
|
|
Translate = new (function() {
|
|
|
|
var defaultLanguage = "en";
|
|
|
|
var allPhrases = {};
|
|
allPhrases[defaultLanguage] = {};
|
|
|
|
// Node types
|
|
|
|
var text = {
|
|
selector: "[data-translate]",
|
|
getKey: function() {
|
|
return this.textContent.trim().replace(/\s+/g, " ");
|
|
},
|
|
setPhrase: function(p) {
|
|
this.textContent = p;
|
|
},
|
|
}
|
|
|
|
var html = {
|
|
selector: "[data-translate-html]",
|
|
getKey: function() {
|
|
return this.innerHTML.trim().replace(/\s+/g, " ");
|
|
},
|
|
setPhrase: function(p) {
|
|
this.innerHTML = p;
|
|
},
|
|
}
|
|
|
|
var placeholder = {
|
|
selector: "[data-translate-placeholder]",
|
|
getKey: function() {
|
|
return this.getAttribute("placeholder").trim().replace(/\s+/g, " ");
|
|
},
|
|
setPhrase: function(p) {
|
|
this.setAttribute("placeholder", p);
|
|
},
|
|
}
|
|
|
|
var title = {
|
|
selector: "[data-translate-title]",
|
|
getKey: function() {
|
|
return this.getAttribute("title").trim().replace(/\s+/g, " ");
|
|
},
|
|
setPhrase: function(p) {
|
|
this.setAttribute("title", p);
|
|
},
|
|
}
|
|
|
|
// Get elements to be translated
|
|
var allEls = getEls(text)
|
|
.concat(getEls(html))
|
|
.concat(getEls(placeholder))
|
|
.concat(getEls(title));
|
|
|
|
// Provides access to phrases from a non-default language.
|
|
// See phrases_en.js for example usage.
|
|
this.loadForeignPhrases = function(language, phrases) {
|
|
allPhrases[language] = phrases;
|
|
}
|
|
|
|
// Displays a different language, eg "en" or "fr"
|
|
this.setLanguage = function(language) {
|
|
for (var i=0; i<allEls.length; i++) {
|
|
var el = allEls[i];
|
|
var key = el.key;
|
|
if (!(language in allPhrases)) {
|
|
console.log(language + " not in allPhrases");
|
|
return;
|
|
}
|
|
if (!(key in allPhrases[language])) {
|
|
console.log(language + " does not contain phrase: " + key);
|
|
return;
|
|
}
|
|
var phrase = allPhrases[language][key];
|
|
el.setPhrase(phrase);
|
|
}
|
|
}
|
|
|
|
// Converts the phrases to a key-pair json file.
|
|
// This is a good way to export phrases for use in translation tools.
|
|
this.phrasesAsJson = function(language) {
|
|
var keys = [];
|
|
for (var i=0; i<allEls.length; i++) {
|
|
var el = allEls[i];
|
|
var key = el.key;
|
|
keys.push(key);
|
|
}
|
|
keys.sort();
|
|
var output = {};
|
|
for (var i=0; i<keys.length; i++) {
|
|
var key = keys[i];
|
|
var translated = "";
|
|
if (language in allPhrases && key in allPhrases[language]) {
|
|
translated = allPhrases[language][key];
|
|
}
|
|
output[key] = translated;
|
|
}
|
|
return JSON.stringify(output, null, 2);
|
|
}
|
|
|
|
function getEls(nodeType) {
|
|
var nodes = document.querySelectorAll(nodeType.selector);
|
|
var els = [];
|
|
for (var i=0; i<nodes.length; i++) {
|
|
var node = nodes[i];
|
|
node.getKey = nodeType.getKey;
|
|
node.setPhrase = nodeType.setPhrase;
|
|
node.key = node.getKey();
|
|
allPhrases[defaultLanguage][node.key] = node.key;
|
|
els.push(node);
|
|
}
|
|
return els;
|
|
}
|
|
|
|
})();
|