| Index: chrome/content/ui/i18n.js |
| =================================================================== |
| --- a/chrome/content/ui/i18n.js |
| +++ b/chrome/content/ui/i18n.js |
| @@ -15,90 +15,19 @@ |
| * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
| */ |
| -var i18n; |
| - |
| -if (typeof ext != "undefined") |
| - i18n = ext.i18n; |
| -else if (typeof chrome != "undefined") |
| - // TODO: This check only exist for backwards compatibility, while the Safari |
| - // port isn't merged into the adblockpluschrome repo. So this branch should |
| - // be removed when the Safari port was merged. |
| - i18n = chrome.i18n; |
| -else |
| -{ |
| - // Using Firefox' approach on i18n instead |
| - |
| - // Randomize URI to work around bug 719376 |
| - var pageName = location.pathname.replace(/.*\//, '').replace(/\..*?$/, ''); |
| - var stringBundle = Services.strings.createBundle("chrome://adblockplus/locale/" + pageName + |
| - ".properties?" + Math.random()); |
| - |
| - function getI18nMessage(key) |
| - { |
| - return { |
| - "message": stringBundle.GetStringFromName(key) |
| - }; |
| - } |
| - |
| - i18n = (function() |
| - { |
| - function getText(message, args) |
| - { |
| - var text = message.message; |
| - var placeholders = message.placeholders; |
| - |
| - if (!args || !placeholders) |
| - return text; |
| - |
| - for (var key in placeholders) |
| - { |
| - var content = placeholders[key].content; |
| - if (!content) |
| - continue; |
| - |
| - var index = parseInt(content.slice(1), 10); |
| - if (isNaN(index)) |
| - continue; |
| - |
| - var replacement = args[index - 1]; |
| - if (typeof replacement === "undefined") |
| - continue; |
| - |
| - text = text.split("$" + key + "$").join(replacement); |
| - } |
| - return text; |
| - } |
| - |
| - return { |
| - getMessage: function(key, args) |
| - { |
| - try{ |
| - var message = getI18nMessage(key); |
| - return getText(message, args); |
| - } |
| - catch(e) |
| - { |
| - Cu.reportError(e); |
| - return "Missing translation: " + key; |
| - } |
| - } |
| - }; |
| - })(); |
| -} |
| - |
| // Inserts i18n strings into matching elements. Any inner HTML already in the element is |
| // parsed as JSON and used as parameters to substitute into placeholders in the i18n |
| // message. |
| -i18n.setElementText = function(element, stringName, arguments) |
| +ext.i18n.setElementText = function(element, stringName, arguments) |
| { |
| function processString(str, element) |
| { |
| - var match = /^(.*?)<(a|strong)>(.*?)<\/\2>(.*)$/.exec(str); |
| + let match = /^(.*?)<(a|strong)>(.*?)<\/\2>(.*)$/.exec(str); |
| if (match) |
| { |
| processString(match[1], element); |
| - var e = document.createElement(match[2]); |
| + let e = document.createElement(match[2]); |
| processString(match[3], e); |
| element.appendChild(e); |
| @@ -110,36 +39,36 @@ |
| while (element.lastChild) |
| element.removeChild(element.lastChild); |
| - processString(i18n.getMessage(stringName, arguments), element); |
| + processString(ext.i18n.getMessage(stringName, arguments), element); |
| } |
| // Loads i18n strings |
| function loadI18nStrings() |
| { |
| - var nodes = document.querySelectorAll("[class^='i18n_']"); |
| - for(var i = 0; i < nodes.length; i++) |
| + let nodes = document.querySelectorAll("[class^='i18n_']"); |
| + for(let i = 0; i < nodes.length; i++) |
| { |
| - var node = nodes[i]; |
| - var arguments = JSON.parse("[" + node.textContent + "]"); |
| + let node = nodes[i]; |
| + let arguments = JSON.parse("[" + node.textContent + "]"); |
| if (arguments.length == 0) |
| arguments = null; |
| - var className = node.className; |
| + let className = node.className; |
| if (className instanceof SVGAnimatedString) |
| className = className.animVal; |
| - var stringName = className.split(/\s/)[0].substring(5); |
| + let stringName = className.split(/\s/)[0].substring(5); |
| - i18n.setElementText(node, stringName, arguments); |
| + ext.i18n.setElementText(node, stringName, arguments); |
| } |
| } |
| // Provides a more readable string of the current date and time |
| function i18n_timeDateStrings(when) |
| { |
| - var d = new Date(when); |
| - var timeString = d.toLocaleTimeString(); |
| + let d = new Date(when); |
| + let timeString = d.toLocaleTimeString(); |
| - var now = new Date(); |
| + let now = new Date(); |
| if (d.toDateString() == now.toDateString()) |
| return [timeString]; |
| else |