Recursively fetch messages until we've loaded all unread

FREEBIE
pull/749/head
Scott Nonnenberg 8 years ago
parent 533ec52d0c
commit 30b7bf23db

@ -320,7 +320,7 @@
fetchMessages: function() {
if (!this.id) { return false; }
return this.messageCollection.fetchConversation(this.id);
return this.messageCollection.fetchConversation(this.id, null, this.get('unreadCount'));
},
fetchContacts: function(options) {

@ -524,10 +524,23 @@
}.bind(this));
},
fetchConversation: function(conversationId, limit) {
getLoadedUnreadCount: function() {
return this.models.reduce(function(total, model) {
var count = model.get('unread');
if (count === undefined) {
count = 0;
}
return total + count;
}, 0);
},
fetchConversation: function(conversationId, limit, unreadCount) {
if (typeof limit !== 'number') {
limit = 100;
}
if (typeof unreadCount !== 'number') {
unreadCount = 0;
}
return new Promise(function(resolve) {
var upper;
if (this.length === 0) {
@ -548,6 +561,11 @@
// received_at DESC
};
this.fetch(options).then(resolve);
}.bind(this)).then(function() {
var loadedUnread = this.getLoadedUnreadCount();
if (loadedUnread < unreadCount) {
return this.fetchConversation(conversationId, limit, unreadCount);
}
}.bind(this));
},

Loading…
Cancel
Save