From 0cd7f84a0531099702bffaf19ec44b57619c1bf2 Mon Sep 17 00:00:00 2001 From: lilia Date: Mon, 11 Apr 2016 15:11:20 -0700 Subject: [PATCH] Refactor read state tracking Adds support for handling early arriving read receipts. // FREEBIE --- background.html | 1 + js/background.js | 25 +---------------------- js/models/messages.js | 7 ++++++- js/read_receipts.js | 47 +++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 55 insertions(+), 25 deletions(-) create mode 100644 js/read_receipts.js diff --git a/background.html b/background.html index a715e64e..4fde50b8 100644 --- a/background.html +++ b/background.html @@ -395,6 +395,7 @@ + diff --git a/js/background.js b/js/background.js index 828131de..18d1b2cf 100644 --- a/js/background.js +++ b/js/background.js @@ -245,31 +245,8 @@ function onReadReceipt(ev) { var timestamp = ev.timestamp.toNumber(); var sender = ev.sender; - var messages = new Whisper.MessageCollection(); - var groups = new Whisper.ConversationCollection(); console.log('read receipt ', sender, timestamp); - groups.fetchGroups(sender).then(function() { - messages.fetchSentAt(timestamp).then(function() { - var ids = groups.pluck('id'); - ids.push(sender); - var message = messages.find(function(message) { - return (message.isIncoming() && message.isUnread() && - _.contains(ids, message.get('conversationId'))); - }); - if (message) { - message.markRead().then(function() { - var conversation = ConversationController.get({ - id: message.get('conversationId') - }); - - if (conversation) { - // notify frontend listeners - conversation.trigger('read', message); - } - }); - } - }); - }); + Whisper.ReadReceipts.add({sender: sender, timestamp: timestamp}); } // lazy hack diff --git a/js/models/messages.js b/js/models/messages.js index 6e6b4fe9..2c39b390 100644 --- a/js/models/messages.js +++ b/js/models/messages.js @@ -326,7 +326,12 @@ } attributes.active_at = now; if (type === 'incoming') { - attributes.unreadCount = conversation.get('unreadCount') + 1; + // experimental + if (Whisper.ReadReceipts.forMessage(message)) { + message.unset('unread'); + } else { + attributes.unreadCount = conversation.get('unreadCount') + 1; + } } conversation.set(attributes); diff --git a/js/read_receipts.js b/js/read_receipts.js new file mode 100644 index 00000000..2473aba0 --- /dev/null +++ b/js/read_receipts.js @@ -0,0 +1,47 @@ +/* + * vim: ts=4:sw=4:expandtab + */ +;(function() { + 'use strict'; + window.Whisper = window.Whisper || {}; + Whisper.ReadReceipts = new (Backbone.Collection.extend({ + initialize: function() { + this.on('add', this.onReceipt); + }, + forMessage: function(message) { + var receipt = this.findWhere({ + sender: message.get('source'), + timestamp: message.get('sent_at') + }); + if (receipt) { + console.log('Found early read receipt for message'); + this.remove(receipt); + return receipt; + } + }, + onReceipt: function(receipt) { + var messages = new Whisper.MessageCollection(); + messages.fetchSentAt(receipt.get('timestamp')).then(function() { + var message = messages.find(function(message) { + return (message.isIncoming() && message.isUnread() && + message.get('source') === receipt.get('sender')); + }); + if (message) { + this.remove(receipt); + message.markRead().then(function() { + var conversation = ConversationController.get({ + id: message.get('conversationId') + }); + + if (conversation) { + // notify frontend listeners + conversation.trigger('read', message); + } + }); + } else { + console.log('No message for read receipt'); + } + }.bind(this)); + } + }))(); +})();