Update style of i18n, pull it in via preload instead of .html

This commit is contained in:
Scott Nonnenberg 2018-03-23 18:37:32 -07:00
parent 1ad2b080c8
commit f86a6ef752
No known key found for this signature in database
GPG Key ID: 5F82280C35134661
7 changed files with 47 additions and 40 deletions

View File

@ -19,6 +19,7 @@ test/views/*.js
!js/backup.js
!js/database.js
!js/logging.js
!js/i18n.js
!js/models/conversations.js
!js/views/attachment_view.js
!js/views/conversation_search_view.js

View File

@ -909,7 +909,6 @@
<script type='text/javascript' src='js/expire.js'></script>
<script type='text/javascript' src='js/conversation_controller.js'></script>
<script type='text/javascript' src='js/emoji_util.js'></script>
<script type='text/javascript' src='js/i18n.js'></script>
<script type='text/javascript' src='js/views/whisper_view.js'></script>
<script type='text/javascript' src='js/views/last_seen_indicator_view.js'></script>

View File

@ -1,29 +1,34 @@
/*
* vim: ts=4:sw=4:expandtab
*/
;(function() {
'use strict';
/* eslint-env node */
// preload.js loads this, pulling it from main.js (where it was loaded from disk)
var messages = window.config.localeMessages;
var locale = window.config.locale;
exports.setup = (locale, messages) => {
if (!locale) {
throw new Error('i18n: locale parameter is required');
}
if (!messages) {
throw new Error('i18n: messages parameter is required');
}
window.i18n = function (message, substitutions) {
if (!messages[message]) {
return;
}
var s = messages[message].message;
if (substitutions instanceof Array) {
substitutions.forEach(function(sub) {
s = s.replace(/\$.+?\$/, sub);
});
} else if (substitutions) {
s = s.replace(/\$.+?\$/, substitutions);
}
return s;
};
function getMessage(key, substitutions) {
const entry = messages[key];
if (!entry) {
console.error(`i18n: Attempted to get translation for nonexistent key '${key}'`);
return '';
}
i18n.getLocale = function() {
return locale;
};
})();
const { message } = entry;
if (substitutions instanceof Array) {
return substitutions.reduce(
(result, substitution) => result.replace(/\$.+?\$/, substitution),
message
);
} else if (substitutions) {
return message.replace(/\$.+?\$/, substitutions);
}
return message;
}
getMessage.getLocale = () => locale;
return getMessage;
};

View File

@ -5,15 +5,6 @@
'use strict';
window.Whisper = window.Whisper || {};
moment.updateLocale(i18n.getLocale(), {
relativeTime : {
s: i18n('timestamp_s') || 'now',
m: i18n('timestamp_m') || '1 minute',
h: i18n('timestamp_h') || '1 hour'
}
});
moment.locale(i18n.getLocale());
Whisper.TimestampView = Whisper.View.extend({
initialize: function(options) {
extension.windows.onClosed(this.clearTimeout.bind(this));

View File

@ -110,6 +110,19 @@ window.nodeNotifier = require('node-notifier');
window.ProxyAgent = require('proxy-agent');
window.moment = require('moment');
const { setup } = require('./js/i18n');
const { locale, localeMessages } = window.config;
window.i18n = setup(locale, localeMessages);
window.moment.updateLocale(locale, {
relativeTime: {
s: window.i18n('timestamp_s'),
m: window.i18n('timestamp_m'),
h: window.i18n('timestamp_h'),
},
});
window.moment.locale(locale);
// ES2015+ modules
const attachmentsPath = Attachments.getPath(app.getPath('userData'));
const deleteAttachmentData = Attachments.createDeleter(attachmentsPath);

View File

@ -1,7 +1,7 @@
describe('i18n', function() {
describe('i18n', function() {
it('returns undefined for unknown string', function() {
assert.strictEqual(i18n('random'), undefined);
it('returns empty string for unknown string', function() {
assert.strictEqual(i18n('random'), '');
});
it('returns message for given string', function() {
assert.equal(i18n('reportIssue'), 'Report an issue');

View File

@ -562,8 +562,6 @@
<script type="text/javascript" src="../js/reliable_trigger.js" data-cover></script>
<script type="text/javascript" src="test.js"></script>
<script type='text/javascript' src='../js/i18n.js'></script>
<script type='text/javascript' src='../js/registration.js' data-cover></script>
<script type="text/javascript" src="../js/expire.js" data-cover></script>
<script type="text/javascript" src="../js/chromium.js" data-cover></script>