Use momentjs for timestamp localization

Let momentjs handle proper pluralization of relative times. This comes
at the sacrifice of displaying 'minutes' in the conversation list
timestamp rather than 'min'. Note that we don't use moment's fromNow
instance method so as to preserve the rounding logic that matches the
Android client.

// FREEBIE
This commit is contained in:
lilia 2016-08-10 11:33:56 -07:00
parent 78b8fbc836
commit 67c7a06c28
4 changed files with 25 additions and 53 deletions

View file

@ -310,43 +310,15 @@
"description": "Informational text displayed if a sync operation times out."
},
"timestamp_s": {
"description": "Short or abbreviated timestamp for messages sent less than a minute ago. Displayed in the conversation list.",
"description": "Brief timestamp for messages sent less than a minute ago. Displayed in the conversation list and message bubble.",
"message": "now"
},
"timestamp_m": {
"description": "Short or abbreviated timestamp for messages sent a minute ago. Displayed in the conversation list.",
"message": "1 min"
},
"timestamp_mm": {
"description": "Short or abbreviated timestamp for messages sent multiple minutes ago. Displayed in the conversation list.",
"message": "%d min"
"description": "Brief timestamp for messages sent about one minute ago. Displayed in the conversation list and message bubble.",
"message": "1 minute"
},
"timestamp_h": {
"description": "Short or abbreviated timestamp for messages sent about an hour ago. Displayed in the conversation list.",
"description": "Brief timestamp for messages sent about one minute ago. Displayed in the conversation list and message bubble.",
"message": "1 hour"
},
"timestamp_hh": {
"description": "Short or abbreviated timestamp for messages sent multiple hours ago. Displayed in the conversation list.",
"message": "%d hours"
},
"extendedTimestamp_s": {
"description": "Timestamp for messages sent less than a minute ago. Displayed in the message bubble.",
"message": "now"
},
"extendedTimestamp_m": {
"description": "Timestamp for messages sent about a minute ago. Displayed in the message bubble.",
"message": "1 minute ago"
},
"extendedTimestamp_mm": {
"description": "Timestamp for messages sent multiple minutes ago. Displayed in the message bubble.",
"message": "%d minutes ago"
},
"extendedTimestamp_h": {
"description": "Timestamp for messages sent one hour ago. Displayed in the message bubble.",
"message": "1 hour ago"
},
"extendedTimestamp_hh": {
"description": "Timestamp for messages sent multiple hours ago. Displayed in the message bubble.",
"message": "%d hours ago"
}
}

View file

@ -169,9 +169,12 @@
return chrome.i18n.getMessage(message, substitutions);
}
};
i18n.getLocale = function() {
if (window.chrome && chrome.i18n) {
moment.locale(chrome.i18n.getUILanguage());
return chrome.i18n.getUILanguage();
}
return 'en';
};
window.textsecure = window.textsecure || {};
window.textsecure.registration = {

View file

@ -5,6 +5,15 @@
'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));
@ -50,13 +59,13 @@
return timestamp.format(this._format.d);
} else if (timediff.hours() > 1) {
this.delay = moment(timestamp).add(timediff.hours() + 1,'h').diff(moment());
return this.relativeTime(timediff.hours(), 'hh');
return this.relativeTime(timediff.hours(), 'h');
} else if (timediff.hours() === 1) {
this.delay = moment(timestamp).add(timediff.hours() + 1,'h').diff(moment());
return this.relativeTime(timediff.hours(), 'h');
} else if (timediff.minutes() > 1) {
this.delay = moment(timestamp).add(timediff.minutes() + 1,'m').diff(moment());
return this.relativeTime(timediff.minutes(), 'mm');
return this.relativeTime(timediff.minutes(), 'm');
} else if (timediff.minutes() === 1) {
this.delay = moment(timestamp).add(timediff.minutes() + 1,'m').diff(moment());
return this.relativeTime(timediff.minutes(), 'm');
@ -65,16 +74,10 @@
return this.relativeTime(timediff.seconds(), 's');
}
},
relativeTime : function (number, string, isFuture) {
var format = i18n("timestamp_"+string) || this._format[string];
return format.replace(/%d/i, number);
relativeTime : function (number, string) {
return moment.duration(number, string).humanize();
},
_format: {
s: "now",
m: "1 min",
mm: "%d min",
h: "1 hour",
hh: "%d hours",
y: "MMM D, YYYY",
mo: "MMM D",
d: "ddd"
@ -82,15 +85,9 @@
});
Whisper.ExtendedTimestampView = Whisper.TimestampView.extend({
relativeTime : function (number, string, isFuture) {
var format = i18n("extendedTimestamp_"+string) || this._format[string];
return format.replace(/%d/i, number);
return moment.duration(-1 * number, string).humanize(string !== 's');
},
_format: {
s: "now",
m: "%d minute ago",
mm: "%d minutes ago",
h: "%d hour ago",
hh: "%d hours ago",
y: "MMM D, YYYY LT",
mo: "MMM D LT",
d: "ddd LT"

View file

@ -46,7 +46,7 @@ describe('TimestampView', function() {
// check recent timestamps
checkDiff(30, 'now', 'now'); // 30 seconds
checkDiff(40*60, '40 min', '40 minutes ago');
checkDiff(40*60, '40 minutes', '40 minutes ago');
checkDiff(60*60, '1 hour', '1 hour ago');
checkDiff(125*60, '2 hours', '2 hours ago');