Fix read sync on duplicate messages
In the case of a double send (same message encrypted and sent twice due to key conflict bug), we would mark the first instance read twice rather than marking both instances read. Fix by searching for matching messages that have not yet been marked read. // FREEBIE
This commit is contained in:
parent
7ff2d431b2
commit
0f4f00ff4e
2 changed files with 4 additions and 1 deletions
|
@ -253,7 +253,7 @@
|
||||||
var ids = groups.pluck('id');
|
var ids = groups.pluck('id');
|
||||||
ids.push(sender);
|
ids.push(sender);
|
||||||
var message = messages.find(function(message) {
|
var message = messages.find(function(message) {
|
||||||
return (message.get('type') === 'incoming' &&
|
return (message.isIncoming() && message.isUnread() &&
|
||||||
_.contains(ids, message.get('conversationId')));
|
_.contains(ids, message.get('conversationId')));
|
||||||
});
|
});
|
||||||
if (message) {
|
if (message) {
|
||||||
|
|
|
@ -35,6 +35,9 @@
|
||||||
isIncoming: function() {
|
isIncoming: function() {
|
||||||
return this.get('type') === 'incoming';
|
return this.get('type') === 'incoming';
|
||||||
},
|
},
|
||||||
|
isUnread: function() {
|
||||||
|
return !!this.get('unread');
|
||||||
|
},
|
||||||
getDescription: function() {
|
getDescription: function() {
|
||||||
if (this.isGroupUpdate()) {
|
if (this.isGroupUpdate()) {
|
||||||
var group_update = this.get('group_update');
|
var group_update = this.get('group_update');
|
||||||
|
|
Loading…
Reference in a new issue