Merge pull request #4153 from frissdiegurke/patch-2

Fix undefined S within translator
v1.18.x
Julian Lam 9 years ago
commit 9a7ec01e15

@ -2,15 +2,18 @@
"use strict"; "use strict";
/* globals RELATIVE_PATH, config, define */ /* globals RELATIVE_PATH, config, define */
var S; var S = null;
var stringDefer = null;
// export the class if we are in a Node-like system. // export the class if we are in a Node-like system.
if (typeof module === 'object' && module.exports === translator) { if (typeof module === 'object' && module.exports === translator) {
exports = module.exports = translator; exports = module.exports = translator;
S = require('string'); S = require('string');
} else { } else {
stringDefer = $.Deferred();
require(['string'], function(stringLib) { require(['string'], function(stringLib) {
S = stringLib; S = stringLib;
stringDefer.resolve(S);
}); });
} }
@ -161,6 +164,12 @@
if (!count) { if (!count) {
return callback(text); return callback(text);
} }
if (S === null) { // browser environment and S not yet initialized
// we need to wait for async require call
stringDefer.then(function () { translateKeys(keys, text, language, callback); });
return;
}
var data = {text: text}; var data = {text: text};
keys.forEach(function(key) { keys.forEach(function(key) {

Loading…
Cancel
Save