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:
parent
78b8fbc836
commit
67c7a06c28
4 changed files with 25 additions and 53 deletions
|
@ -310,43 +310,15 @@
|
||||||
"description": "Informational text displayed if a sync operation times out."
|
"description": "Informational text displayed if a sync operation times out."
|
||||||
},
|
},
|
||||||
"timestamp_s": {
|
"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"
|
"message": "now"
|
||||||
},
|
},
|
||||||
"timestamp_m": {
|
"timestamp_m": {
|
||||||
"description": "Short or abbreviated timestamp for messages sent a minute 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 min"
|
"message": "1 minute"
|
||||||
},
|
|
||||||
"timestamp_mm": {
|
|
||||||
"description": "Short or abbreviated timestamp for messages sent multiple minutes ago. Displayed in the conversation list.",
|
|
||||||
"message": "%d min"
|
|
||||||
},
|
},
|
||||||
"timestamp_h": {
|
"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"
|
"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"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -169,9 +169,12 @@
|
||||||
return chrome.i18n.getMessage(message, substitutions);
|
return chrome.i18n.getMessage(message, substitutions);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
if (window.chrome && chrome.i18n) {
|
i18n.getLocale = function() {
|
||||||
moment.locale(chrome.i18n.getUILanguage());
|
if (window.chrome && chrome.i18n) {
|
||||||
}
|
return chrome.i18n.getUILanguage();
|
||||||
|
}
|
||||||
|
return 'en';
|
||||||
|
};
|
||||||
|
|
||||||
window.textsecure = window.textsecure || {};
|
window.textsecure = window.textsecure || {};
|
||||||
window.textsecure.registration = {
|
window.textsecure.registration = {
|
||||||
|
|
|
@ -5,6 +5,15 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
window.Whisper = window.Whisper || {};
|
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({
|
Whisper.TimestampView = Whisper.View.extend({
|
||||||
initialize: function(options) {
|
initialize: function(options) {
|
||||||
extension.windows.onClosed(this.clearTimeout.bind(this));
|
extension.windows.onClosed(this.clearTimeout.bind(this));
|
||||||
|
@ -50,13 +59,13 @@
|
||||||
return timestamp.format(this._format.d);
|
return timestamp.format(this._format.d);
|
||||||
} else if (timediff.hours() > 1) {
|
} else if (timediff.hours() > 1) {
|
||||||
this.delay = moment(timestamp).add(timediff.hours() + 1,'h').diff(moment());
|
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) {
|
} else if (timediff.hours() === 1) {
|
||||||
this.delay = moment(timestamp).add(timediff.hours() + 1,'h').diff(moment());
|
this.delay = moment(timestamp).add(timediff.hours() + 1,'h').diff(moment());
|
||||||
return this.relativeTime(timediff.hours(), 'h');
|
return this.relativeTime(timediff.hours(), 'h');
|
||||||
} else if (timediff.minutes() > 1) {
|
} else if (timediff.minutes() > 1) {
|
||||||
this.delay = moment(timestamp).add(timediff.minutes() + 1,'m').diff(moment());
|
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) {
|
} else if (timediff.minutes() === 1) {
|
||||||
this.delay = moment(timestamp).add(timediff.minutes() + 1,'m').diff(moment());
|
this.delay = moment(timestamp).add(timediff.minutes() + 1,'m').diff(moment());
|
||||||
return this.relativeTime(timediff.minutes(), 'm');
|
return this.relativeTime(timediff.minutes(), 'm');
|
||||||
|
@ -65,16 +74,10 @@
|
||||||
return this.relativeTime(timediff.seconds(), 's');
|
return this.relativeTime(timediff.seconds(), 's');
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
relativeTime : function (number, string, isFuture) {
|
relativeTime : function (number, string) {
|
||||||
var format = i18n("timestamp_"+string) || this._format[string];
|
return moment.duration(number, string).humanize();
|
||||||
return format.replace(/%d/i, number);
|
|
||||||
},
|
},
|
||||||
_format: {
|
_format: {
|
||||||
s: "now",
|
|
||||||
m: "1 min",
|
|
||||||
mm: "%d min",
|
|
||||||
h: "1 hour",
|
|
||||||
hh: "%d hours",
|
|
||||||
y: "MMM D, YYYY",
|
y: "MMM D, YYYY",
|
||||||
mo: "MMM D",
|
mo: "MMM D",
|
||||||
d: "ddd"
|
d: "ddd"
|
||||||
|
@ -82,15 +85,9 @@
|
||||||
});
|
});
|
||||||
Whisper.ExtendedTimestampView = Whisper.TimestampView.extend({
|
Whisper.ExtendedTimestampView = Whisper.TimestampView.extend({
|
||||||
relativeTime : function (number, string, isFuture) {
|
relativeTime : function (number, string, isFuture) {
|
||||||
var format = i18n("extendedTimestamp_"+string) || this._format[string];
|
return moment.duration(-1 * number, string).humanize(string !== 's');
|
||||||
return format.replace(/%d/i, number);
|
|
||||||
},
|
},
|
||||||
_format: {
|
_format: {
|
||||||
s: "now",
|
|
||||||
m: "%d minute ago",
|
|
||||||
mm: "%d minutes ago",
|
|
||||||
h: "%d hour ago",
|
|
||||||
hh: "%d hours ago",
|
|
||||||
y: "MMM D, YYYY LT",
|
y: "MMM D, YYYY LT",
|
||||||
mo: "MMM D LT",
|
mo: "MMM D LT",
|
||||||
d: "ddd LT"
|
d: "ddd LT"
|
||||||
|
|
|
@ -46,7 +46,7 @@ describe('TimestampView', function() {
|
||||||
|
|
||||||
// check recent timestamps
|
// check recent timestamps
|
||||||
checkDiff(30, 'now', 'now'); // 30 seconds
|
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(60*60, '1 hour', '1 hour ago');
|
||||||
checkDiff(125*60, '2 hours', '2 hours ago');
|
checkDiff(125*60, '2 hours', '2 hours ago');
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue