summaryrefslogtreecommitdiff
path: root/web-ui/app
diff options
context:
space:
mode:
Diffstat (limited to 'web-ui/app')
-rw-r--r--web-ui/app/js/helpers/monitored_ajax.js2
-rw-r--r--web-ui/app/js/helpers/view_helper.js2
-rw-r--r--web-ui/app/js/mail_view/ui/forward_box.js2
-rw-r--r--web-ui/app/js/mail_view/ui/reply_box.js2
-rw-r--r--web-ui/app/js/mail_view/ui/send_button.js4
-rw-r--r--web-ui/app/js/main.js5
-rw-r--r--web-ui/app/js/mixins/with_mail_edit_base.js2
-rw-r--r--web-ui/app/js/page/default.js56
-rw-r--r--web-ui/app/js/services/delete_service.js8
-rw-r--r--web-ui/app/js/services/mail_service.js18
-rw-r--r--web-ui/app/js/services/recover_service.js2
-rw-r--r--web-ui/app/js/tags/ui/tag.js2
-rw-r--r--web-ui/app/js/views/i18n.js46
-rw-r--r--web-ui/app/locales/de_DE/translation.json2
-rw-r--r--web-ui/app/locales/es_ES/translation.json2
-rw-r--r--web-ui/app/locales/pt_BR/translation.json1
-rw-r--r--web-ui/app/locales/sv_SE/translation.json1
17 files changed, 99 insertions, 58 deletions
diff --git a/web-ui/app/js/helpers/monitored_ajax.js b/web-ui/app/js/helpers/monitored_ajax.js
index 061806fc..bbf85c45 100644
--- a/web-ui/app/js/helpers/monitored_ajax.js
+++ b/web-ui/app/js/helpers/monitored_ajax.js
@@ -49,7 +49,7 @@ define(['page/events', 'views/i18n', 'helpers/browser'], function (events, i18n,
if (!config.skipErrorMessage) {
var msg = (xmlhttprequest.responseJSON && xmlhttprequest.responseJSON.message) ||
messages[textstatus] || messages.error;
- on.trigger(document, events.ui.userAlerts.displayMessage, {message: i18n(msg), class: 'error'});
+ on.trigger(document, events.ui.userAlerts.displayMessage, {message: i18n.t(msg), class: 'error'});
}
if (xmlhttprequest.status === 302) {
diff --git a/web-ui/app/js/helpers/view_helper.js b/web-ui/app/js/helpers/view_helper.js
index f8152ff7..c12e6aaf 100644
--- a/web-ui/app/js/helpers/view_helper.js
+++ b/web-ui/app/js/helpers/view_helper.js
@@ -72,7 +72,7 @@ define(
}
function prependFrom(mail) {
- return i18n(
+ return i18n.t(
'On __date__, <__from__> wrote:\n',
{'date': new Date(mail.header.date).toString(), 'from': mail.header.from}
);
diff --git a/web-ui/app/js/mail_view/ui/forward_box.js b/web-ui/app/js/mail_view/ui/forward_box.js
index f767915c..970fad7f 100644
--- a/web-ui/app/js/mail_view/ui/forward_box.js
+++ b/web-ui/app/js/mail_view/ui/forward_box.js
@@ -31,7 +31,7 @@ define(
return defineComponent(forwardBox, withHideAndShow, withComposeInline);
function forwardBox() {
- var fwd = function(v) { return i18n('fwd') + ': ' + v; };
+ var fwd = function(v) { return i18n.t('fwd') + v; };
this.fetchTargetMail = function (ev) {
this.trigger(document, events.mail.want, { mail: this.attr.ident, caller: this });
diff --git a/web-ui/app/js/mail_view/ui/reply_box.js b/web-ui/app/js/mail_view/ui/reply_box.js
index ba306d7f..fdc9dd0f 100644
--- a/web-ui/app/js/mail_view/ui/reply_box.js
+++ b/web-ui/app/js/mail_view/ui/reply_box.js
@@ -46,7 +46,7 @@ define(
}
};
- var re = function(v) { return i18n('re') + v; };
+ var re = function(v) { return i18n.t('re') + v; };
this.setupReplyBox = function() {
var recipients, body;
diff --git a/web-ui/app/js/mail_view/ui/send_button.js b/web-ui/app/js/mail_view/ui/send_button.js
index c4cf86dc..581a244a 100644
--- a/web-ui/app/js/mail_view/ui/send_button.js
+++ b/web-ui/app/js/mail_view/ui/send_button.js
@@ -89,7 +89,7 @@ define([
}.bind(this)));
this.disableButton();
- this.$node.text(viewHelper.i18n('sending-mail'));
+ this.$node.text(viewHelper.i18n.t('sending-mail'));
this.attr.sendingInProgress = true;
@@ -99,7 +99,7 @@ define([
this.resetButton = function () {
this.attr.sendingInProgress = false;
this.attr.uploading = false;
- this.$node.html(viewHelper.i18n('send-button'));
+ this.$node.html(viewHelper.i18n.t('send-button'));
this.enableButton();
};
diff --git a/web-ui/app/js/main.js b/web-ui/app/js/main.js
index e093e790..b8836a6b 100644
--- a/web-ui/app/js/main.js
+++ b/web-ui/app/js/main.js
@@ -38,7 +38,9 @@ requirejs.config({
'search': 'js/search',
'foundation': 'js/foundation',
'features': 'js/features/features',
- 'i18next': 'bower_components/i18next/i18next.amd',
+ 'i18next': 'bower_components/i18next/i18next',
+ 'i18nextXHRBackend': 'bower_components/i18next-xhr-backend/i18nextXHRBackend',
+ 'i18nextBrowserLanguageDetector': 'bower_components/i18next-browser-languagedetector/i18nextBrowserLanguageDetector',
'quoted-printable': 'bower_components/quoted-printable',
'utf8': 'bower_components/utf8',
'user_settings': 'js/user_settings'
@@ -68,6 +70,7 @@ require(
function(compose, registry, advice, withLogging, debug, events, initializeDefault, _monkeyPatched) {
'use strict';
+
window.Pixelated = window.Pixelated || {};
window.Pixelated.events = events;
diff --git a/web-ui/app/js/mixins/with_mail_edit_base.js b/web-ui/app/js/mixins/with_mail_edit_base.js
index 41de162c..a60cce03 100644
--- a/web-ui/app/js/mixins/with_mail_edit_base.js
+++ b/web-ui/app/js/mixins/with_mail_edit_base.js
@@ -147,7 +147,7 @@ define(
} else {
this.trigger(
events.ui.userAlerts.displayMessage,
- {message: i18n('One or more of the recipients are not valid emails')}
+ {message: i18n.t('One or more of the recipients are not valid emails')}
);
this.trigger(events.mail.send_failed);
}
diff --git a/web-ui/app/js/page/default.js b/web-ui/app/js/page/default.js
index 965fb577..ecaedfd8 100644
--- a/web-ui/app/js/page/default.js
+++ b/web-ui/app/js/page/default.js
@@ -97,46 +97,48 @@ define(
'use strict';
function initialize(path) {
viewI18n.init(path + '/assets/');
- paneContractExpand.attachTo(document);
+ viewI18n.loaded(function() {
+ paneContractExpand.attachTo(document);
- userAlerts.attachTo('#user-alerts');
+ userAlerts.attachTo('#user-alerts');
- mailList.attachTo('#mail-list');
- mailListActions.attachTo('#list-actions');
+ mailList.attachTo('#mail-list');
+ mailListActions.attachTo('#list-actions');
- searchTrigger.attachTo('#search-trigger');
- resultsHighlighter.attachTo(document);
+ searchTrigger.attachTo('#search-trigger');
+ resultsHighlighter.attachTo(document);
- mailSender.attachTo(document);
+ mailSender.attachTo(document);
- mailService.attachTo(document);
- deleteService.attachTo(document);
- recoverService.attachTo(document);
+ mailService.attachTo(document);
+ deleteService.attachTo(document);
+ recoverService.attachTo(document);
- tags.attachTo(document);
- tagList.attachTo('#tag-list');
+ tags.attachTo(document);
+ tagList.attachTo('#tag-list');
- router.attachTo(document);
+ router.attachTo(document);
- rightPaneDispatcher.attachTo(document);
- middlePaneDispatcher.attachTo(document);
- leftPaneDispatcher.attachTo(document);
+ rightPaneDispatcher.attachTo(document);
+ middlePaneDispatcher.attachTo(document);
+ leftPaneDispatcher.attachTo(document);
- offCanvas.attachTo(document);
- userSettings.attachTo(document);
- userSettingsIcon.attachTo('#user-settings-icon');
- logout.attachTo('#logout');
- logoutShortcut.attachTo('#logout-shortcut');
- version.attachTo('.version');
+ offCanvas.attachTo(document);
+ userSettings.attachTo(document);
+ userSettingsIcon.attachTo('#user-settings-icon');
+ logout.attachTo('#logout');
+ logoutShortcut.attachTo('#logout-shortcut');
+ version.attachTo('.version');
- feedback.attachTo('#feedback');
- feedbackSender.attachTo(document);
+ feedback.attachTo('#feedback');
+ feedbackSender.attachTo(document);
- unreadCountTitle.attachTo(document);
+ unreadCountTitle.attachTo(document);
- pixLogo.attachTo(document);
+ pixLogo.attachTo(document);
- $.ajaxSetup({headers: {'X-XSRF-TOKEN': browser.getCookie('XSRF-TOKEN')}});
+ $.ajaxSetup({headers: {'X-XSRF-TOKEN': browser.getCookie('XSRF-TOKEN')}});
+ });
}
return initialize;
diff --git a/web-ui/app/js/services/delete_service.js b/web-ui/app/js/services/delete_service.js
index 4097ea7e..0dfc1bdb 100644
--- a/web-ui/app/js/services/delete_service.js
+++ b/web-ui/app/js/services/delete_service.js
@@ -22,14 +22,14 @@ define(['flight/lib/component', 'page/events', 'views/i18n'], function (defineCo
this.successDeleteMessageFor = function(mail) {
return mail.isInTrash() ?
- i18n('delete-single') :
- i18n('trash-single');
+ i18n.t('delete-single') :
+ i18n.t('trash-single');
};
this.successDeleteManyMessageFor = function(mail) {
return mail.isInTrash() ?
- i18n('delete-bulk') :
- i18n('trash-bulk');
+ i18n.t('delete-bulk') :
+ i18n.t('trash-bulk');
};
this.deleteEmail = function (event, data) {
diff --git a/web-ui/app/js/services/mail_service.js b/web-ui/app/js/services/mail_service.js
index 412451cb..529a43b8 100644
--- a/web-ui/app/js/services/mail_service.js
+++ b/web-ui/app/js/services/mail_service.js
@@ -60,9 +60,9 @@ define(
};
var failure = function (resp) {
- var msg = i18n('Could not update mail tags');
+ var msg = i18n.t('Could not update mail tags');
if (resp.status === 403) {
- msg = i18n('Invalid tag name');
+ msg = i18n.t('Invalid tag name');
}
this.trigger(document, events.ui.userAlerts.displayMessage, { message: msg });
};
@@ -128,7 +128,7 @@ define(
var mails = dataToRecover.mails || [dataToRecover.mail];
this.refreshMails();
- this.trigger(document, events.ui.userAlerts.displayMessage, { message: i18n(dataToRecover.successMessage)});
+ this.trigger(document, events.ui.userAlerts.displayMessage, { message: i18n.t(dataToRecover.successMessage)});
this.trigger(document, events.ui.mails.uncheckAll);
}, this);
};
@@ -136,7 +136,7 @@ define(
this.triggerArchived = function (dataToArchive) {
return _.bind(function (response) {
this.refreshMails();
- this.trigger(document, events.ui.userAlerts.displayMessage, { message: i18n(response.successMessage)});
+ this.trigger(document, events.ui.userAlerts.displayMessage, { message: i18n.t(response.successMessage)});
this.trigger(document, events.ui.mails.uncheckAll);
}, this);
};
@@ -151,14 +151,14 @@ define(
contentType: 'application/json; charset=utf-8',
data: JSON.stringify({idents: mailIdents})
}).done(this.triggerArchived(dataToArchive))
- .fail(this.errorMessage(i18n('Could not archive emails')));
+ .fail(this.errorMessage(i18n.t('Could not archive emails')));
};
this.deleteMail = function (ev, data) {
monitoredAjax(this, '/mail/' + data.mail.ident,
{type: 'DELETE'})
.done(this.triggerDeleted(data))
- .fail(this.errorMessage(i18n('Could not delete email')));
+ .fail(this.errorMessage(i18n.t('Could not delete email')));
};
this.deleteManyMails = function (ev, data) {
@@ -173,7 +173,7 @@ define(
contentType: 'application/json; charset=utf-8',
data: JSON.stringify({idents: mailIdents})
}).done(this.triggerDeleted(dataToDelete))
- .fail(this.errorMessage(i18n('Could not delete emails')));
+ .fail(this.errorMessage(i18n.t('Could not delete emails')));
};
this.recoverManyMails = function (ev, data) {
@@ -188,7 +188,7 @@ define(
contentType: 'application/json; charset=utf-8',
data: JSON.stringify({idents: mailIdents})
}).done(this.triggerRecovered(dataToRecover))
- .fail(this.errorMessage(i18n('Could not move emails to inbox')));
+ .fail(this.errorMessage(i18n.t('Could not move emails to inbox')));
};
function compileQuery(data) {
@@ -246,7 +246,7 @@ define(
this.trigger(document, events.mails.available, _.merge({tag: this.attr.currentTag, forSearch: this.attr.lastQuery }, this.parseMails(data)));
}.bind(this))
.fail(function () {
- this.trigger(document, events.ui.userAlerts.displayMessage, { message: i18n('Could not fetch messages'), class: 'error' });
+ this.trigger(document, events.ui.userAlerts.displayMessage, { message: i18n.t('Could not fetch messages'), class: 'error' });
}.bind(this));
};
diff --git a/web-ui/app/js/services/recover_service.js b/web-ui/app/js/services/recover_service.js
index 62fcf1f9..d7d9cdc9 100644
--- a/web-ui/app/js/services/recover_service.js
+++ b/web-ui/app/js/services/recover_service.js
@@ -25,7 +25,7 @@ define(['flight/lib/component', 'page/events', 'views/i18n'], function (defineCo
this.trigger(document, events.mail.recoverMany, {
mails: emails,
- successMessage: i18n('Your messages were moved to inbox!')
+ successMessage: i18n.t('Your messages were moved to inbox!')
});
};
diff --git a/web-ui/app/js/tags/ui/tag.js b/web-ui/app/js/tags/ui/tag.js
index ba6dfe61..37814cfc 100644
--- a/web-ui/app/js/tags/ui/tag.js
+++ b/web-ui/app/js/tags/ui/tag.js
@@ -78,7 +78,7 @@ define(
this.viewFor = function (tag, template, currentTag) {
return template({
- tagName: tag.default ? i18n('tags.' + tag.name) : tag.name,
+ tagName: tag.default ? i18n.t('tags.' + tag.name) : tag.name,
ident: this.hashIdent(tag.ident),
count: this.badgeType(tag) === 'total' ? tag.counts.total : (tag.counts.total - tag.counts.read),
displayBadge: this.displayBadge(tag),
diff --git a/web-ui/app/js/views/i18n.js b/web-ui/app/js/views/i18n.js
index 6a39ee89..f843b845 100644
--- a/web-ui/app/js/views/i18n.js
+++ b/web-ui/app/js/views/i18n.js
@@ -14,15 +14,49 @@
* You should have received a copy of the GNU Affero General Public License
* along with Pixelated. If not, see <http://www.gnu.org/licenses/>.
*/
-define(['i18next'], function(i18n) {
+define(['i18next',
+ 'i18nextXHRBackend',
+ 'i18nextBrowserLanguageDetector'],
+function(i18n, i18n_backend, I18n_detector) {
'use strict';
- var self = i18n.t;
+ var detector = new I18n_detector();
+ var detect = detector.detect.bind(detector);
- self.init = function(path) {
- i18n.init({detectLngQS: 'lang', fallbackLng: 'en_US', lowerCaseLng: true, getAsync: false, resGetPath: path + 'locales/__lng__/__ns__.json'});
- Handlebars.registerHelper('t', self.bind(self));
+ detector.detect = function(detectionOrder) {
+ var result = detect(detectionOrder);
+ return result.replace('-', '_');
};
- return self;
+ function t(i18n_key) {
+ var result = i18n.t(i18n_key);
+ var safe_string = new Handlebars.SafeString(result);
+ return safe_string.string;
+ }
+
+ function loaded(callback) {
+ i18n.on('loaded', function(loaded) {
+ callback();
+ });
+ }
+
+ function init(path) {
+ i18n
+ .use(i18n_backend)
+ .use(detector)
+ .init({
+ fallbackLng: 'en_US',
+ backend: {
+ loadPath: path + 'locales/{{lng}}/{{ns}}.json'
+ }
+ });
+ // Handlebars.registerHelper('t', self.bind(self));
+ Handlebars.registerHelper('t', t);
+ }
+
+ return {
+ t: t,
+ init: init,
+ loaded: loaded
+ };
});
diff --git a/web-ui/app/locales/de_DE/translation.json b/web-ui/app/locales/de_DE/translation.json
index 357187b0..c625790c 100644
--- a/web-ui/app/locales/de_DE/translation.json
+++ b/web-ui/app/locales/de_DE/translation.json
@@ -1,7 +1,7 @@
{
"compose": "Compose",
"re": "Re: ",
- "Fwd: ": "Fwd: ",
+ "fwd": "Fwd: ",
"Your message was moved to trash!": "Your message was moved to trash!",
"Your message was archived": "Your message was archived",
"Your message was permanently deleted!": "Your message was permanently deleted!",
diff --git a/web-ui/app/locales/es_ES/translation.json b/web-ui/app/locales/es_ES/translation.json
index 357187b0..c625790c 100644
--- a/web-ui/app/locales/es_ES/translation.json
+++ b/web-ui/app/locales/es_ES/translation.json
@@ -1,7 +1,7 @@
{
"compose": "Compose",
"re": "Re: ",
- "Fwd: ": "Fwd: ",
+ "fwd": "Fwd: ",
"Your message was moved to trash!": "Your message was moved to trash!",
"Your message was archived": "Your message was archived",
"Your message was permanently deleted!": "Your message was permanently deleted!",
diff --git a/web-ui/app/locales/pt_BR/translation.json b/web-ui/app/locales/pt_BR/translation.json
index d20b02b3..80da4a93 100644
--- a/web-ui/app/locales/pt_BR/translation.json
+++ b/web-ui/app/locales/pt_BR/translation.json
@@ -2,6 +2,7 @@
"compose": "Escrever",
"re": "Res: ",
"fwd": "Enc",
+ "Your message was moved to trash!": "Sua mensagem foi movida para a lixeira!",
"Your message was archived": "Sua mensagem foi arquivada!",
"Saved as draft.": "Mensagem salva como rascunho.",
"One or more of the recipients are not valid emails": "Email de um ou mais destinatários é inválido",
diff --git a/web-ui/app/locales/sv_SE/translation.json b/web-ui/app/locales/sv_SE/translation.json
index aa7035f3..416665f2 100644
--- a/web-ui/app/locales/sv_SE/translation.json
+++ b/web-ui/app/locales/sv_SE/translation.json
@@ -2,6 +2,7 @@
"compose": "Skriv nytt",
"re": "Sv: ",
"fwd": "VB",
+ "Your message was moved to trash!": "Ditt meddelande har flyttats till papperskorgen!",
"Your message was archived": "Ditt meddelande har arkiverats!",
"Saved as draft.": "Sparat som utkast.",
"One or more of the recipients are not valid emails": "En eller flera mottagare är inte giltiga epost-adresser",