Created
November 22, 2015 08:06
-
-
Save IceCreamYou/f732bfe0d6b5ee42785f to your computer and use it in GitHub Desktop.
Drop-in i18n (internationalization / translation) for HTML / DOM in Chrome extensions / apps.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* Translates HTML in Chrome extensions. | |
* | |
* This works by replacing the content or attributes of a DOM element with a | |
* translated string identified by the element's "data-i18n" attribute. For | |
* example, `<p data-i18n="p_contents,title=p_title" title="hello">world</p>` | |
* will be translated to `<p title="__MSG_p_title__">__MSG_p_contents__</p>` | |
* (assuming `p_title` and `p_contents` are defined keys in a messages.json | |
* file in the extension as described at | |
* https://developer.chrome.com/extensions/i18n). | |
* | |
* Inspired by https://gist.github.com/eligrey/738199 | |
* | |
* MIT Licensed. | |
*/ | |
(function() { | |
window.addEventListener('load', function() { | |
var needsTranslation = document.querySelectorAll("[data-i18n]"), | |
t = chrome.i18n.getMessage; | |
for (var i = 0, l = needsTranslation.length; i < l; i++) { | |
var element = needsTranslation[i], | |
targets = element.split(/\s*,\s*/); | |
for (var j = 0, m = targets.length; j < m; j++) { | |
var parameters = targets[j].split(/\s*=\s*/); | |
if (parameters.length === 1 || parameters[0] === 'textContent') { | |
element.textContent = t(element.dataset.i18n); | |
} | |
else if (parameters[0] === 'innerHTML') { | |
element.innerHTML = t(element.dataset.i18n); | |
} | |
else { | |
element.setAttribute(parameters[0], t(parameters[1])); | |
} | |
} | |
} | |
}); | |
}).call(this); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment