548c8e69cf
Three locations were changed: 1. a group update, which lists a set of contacts 2. the contact name in the left pane 3. the conversation title Three new components were added to window.Signal.Components to support these scenarios, respectively: 1. Emojify 2. ContactName 3. ConversationTitle Note that there are a number of other places in the app that should be emojified, but never have been before. Essentially any place that a contact name might be shown. A non-exhaustive list: - Show group members - Show safety number - Verified change notification - Disappearing timer change notification - Contact verification notification - Quote contact name
130 lines
3.5 KiB
JavaScript
130 lines
3.5 KiB
JavaScript
(function() {
|
|
'use strict';
|
|
window.Whisper = window.Whisper || {};
|
|
|
|
// list of conversations, showing user/group and last message sent
|
|
Whisper.ConversationListItemView = Whisper.View.extend({
|
|
tagName: 'div',
|
|
className: function() {
|
|
return 'conversation-list-item contact ' + this.model.cid;
|
|
},
|
|
templateName: 'conversation-preview',
|
|
events: {
|
|
click: 'select',
|
|
},
|
|
initialize: function() {
|
|
// auto update
|
|
this.listenTo(
|
|
this.model,
|
|
'change',
|
|
_.debounce(this.render.bind(this), 1000)
|
|
);
|
|
this.listenTo(this.model, 'destroy', this.remove); // auto update
|
|
this.listenTo(this.model, 'opened', this.markSelected); // auto update
|
|
|
|
var updateLastMessage = _.debounce(
|
|
this.model.updateLastMessage.bind(this.model),
|
|
1000
|
|
);
|
|
this.listenTo(
|
|
this.model.messageCollection,
|
|
'add remove',
|
|
updateLastMessage
|
|
);
|
|
this.listenTo(this.model, 'newmessage', updateLastMessage);
|
|
|
|
extension.windows.onClosed(
|
|
function() {
|
|
this.stopListening();
|
|
}.bind(this)
|
|
);
|
|
this.timeStampView = new Whisper.TimestampView({ brief: true });
|
|
this.model.updateLastMessage();
|
|
},
|
|
|
|
markSelected: function() {
|
|
this.$el
|
|
.addClass('selected')
|
|
.siblings('.selected')
|
|
.removeClass('selected');
|
|
},
|
|
|
|
select: function(e) {
|
|
this.markSelected();
|
|
this.$el.trigger('select', this.model);
|
|
},
|
|
|
|
remove() {
|
|
if (this.nameView) {
|
|
this.nameView.remove();
|
|
this.nameView = null;
|
|
}
|
|
if (this.bodyView) {
|
|
this.bodyView.remove();
|
|
this.bodyView = null;
|
|
}
|
|
Backbone.View.prototype.remove.call(this);
|
|
},
|
|
|
|
render: function() {
|
|
const lastMessage = this.model.get('lastMessage');
|
|
|
|
this.$el.html(
|
|
Mustache.render(
|
|
_.result(this, 'template', ''),
|
|
{
|
|
last_message: Boolean(lastMessage),
|
|
last_message_timestamp: this.model.get('timestamp'),
|
|
number: this.model.getNumber(),
|
|
avatar: this.model.getAvatar(),
|
|
unreadCount: this.model.get('unreadCount'),
|
|
},
|
|
this.render_partials()
|
|
)
|
|
);
|
|
this.timeStampView.setElement(this.$('.last-timestamp'));
|
|
this.timeStampView.update();
|
|
|
|
if (this.nameView) {
|
|
this.nameView.remove();
|
|
this.nameView = null;
|
|
}
|
|
this.nameView = new Whisper.ReactWrapperView({
|
|
className: 'name-wrapper',
|
|
Component: window.Signal.Components.ContactName,
|
|
props: {
|
|
phoneNumber: this.model.getNumber(),
|
|
name: this.model.getName(),
|
|
profileName: this.model.getProfileName(),
|
|
},
|
|
});
|
|
this.$('.name').append(this.nameView.el);
|
|
|
|
if (lastMessage) {
|
|
if (this.bodyView) {
|
|
this.bodyView.remove();
|
|
this.bodyView = null;
|
|
}
|
|
this.bodyView = new Whisper.ReactWrapperView({
|
|
className: 'body-wrapper',
|
|
Component: window.Signal.Components.MessageBody,
|
|
props: {
|
|
text: lastMessage,
|
|
disableJumbomoji: true,
|
|
disableLinks: true,
|
|
},
|
|
});
|
|
this.$('.last-message').append(this.bodyView.el);
|
|
}
|
|
|
|
var unread = this.model.get('unreadCount');
|
|
if (unread > 0) {
|
|
this.$el.addClass('unread');
|
|
} else {
|
|
this.$el.removeClass('unread');
|
|
}
|
|
|
|
return this;
|
|
},
|
|
});
|
|
})();
|