Move message and conversation storage to IndexedDB
Getting up and running with IndexedDB was pretty easy, thanks to backbone. The tricky part was making reads and writes asynchronous. In that process I did some refactoring on Whisper.Threads, which has been renamed Conversations for consistency with the view names. This change also adds the unlimitedStorage permission.
This commit is contained in:
parent
5638b20046
commit
ced295a630
24 changed files with 1663 additions and 324 deletions
|
@ -7,7 +7,7 @@ var Whisper = Whisper || {};
|
|||
tagName: 'div',
|
||||
id: 'contacts',
|
||||
itemView: Whisper.ConversationListItemView,
|
||||
collection: Whisper.Threads,
|
||||
collection: Whisper.Conversations,
|
||||
|
||||
events: {
|
||||
'click .contact': 'select',
|
||||
|
|
|
@ -45,11 +45,11 @@ var Whisper = Whisper || {};
|
|||
e.preventDefault();
|
||||
var input = this.$el.find('.send input');
|
||||
var message = input.val();
|
||||
var thread = this.model;
|
||||
var convo = this.model;
|
||||
|
||||
if (message.length > 0 || this.fileInput.hasFiles()) {
|
||||
this.fileInput.getFiles().then(function(attachments) {
|
||||
thread.sendMessage(message, attachments);
|
||||
convo.sendMessage(message, attachments);
|
||||
});
|
||||
input.val("");
|
||||
}
|
||||
|
|
|
@ -13,5 +13,12 @@ var Whisper = Whisper || {};
|
|||
scrollToBottom: function() {
|
||||
this.$el.scrollTop(this.el.scrollHeight);
|
||||
},
|
||||
addAll: function() {
|
||||
this.$el.html('');
|
||||
this.collection.each(function(model) {
|
||||
var view = new this.itemView({model: model});
|
||||
this.$el.prepend(view.render().el);
|
||||
});
|
||||
},
|
||||
});
|
||||
})();
|
||||
|
|
|
@ -25,7 +25,7 @@ var Whisper = Whisper || {};
|
|||
timestamp: moment(this.model.get('timestamp')).fromNow(),
|
||||
attachments: this.model.get('attachments'),
|
||||
bubble_class: this.model.get('type') === 'outgoing' ? 'sent' : 'incoming',
|
||||
sender: this.model.thread().get('type') === 'group' ? this.model.get('person') : ''
|
||||
sender: this.model.get('conversationType') === 'group' ? this.model.get('sender') : ''
|
||||
})
|
||||
);
|
||||
|
||||
|
|
|
@ -67,17 +67,17 @@ var Whisper = Whisper || {};
|
|||
e.preventDefault();
|
||||
var number = this.input.verifyNumber();
|
||||
if (number) {
|
||||
var thread = Whisper.Threads.findOrCreateForRecipient(number);
|
||||
var convo = Whisper.Conversations.findOrCreateForRecipient(number);
|
||||
var message_input = this.$el.find('input.send-message');
|
||||
var message = message_input.val();
|
||||
if (message.length > 0 || this.fileInput.hasFiles()) {
|
||||
this.fileInput.getFiles().then(function(attachments) {
|
||||
thread.sendMessage(message, attachments);
|
||||
convo.sendMessage(message, attachments);
|
||||
});
|
||||
message_input.val("");
|
||||
}
|
||||
this.remove();
|
||||
thread.trigger('render');
|
||||
convo.trigger('render');
|
||||
}
|
||||
},
|
||||
|
||||
|
|
|
@ -37,10 +37,10 @@ var Whisper = Whisper || {};
|
|||
var numbers = this.$el.find('input.numbers').val().split(',');
|
||||
var name = this.$el.find('input.name').val();
|
||||
var view = this;
|
||||
Whisper.Threads.createGroup(numbers, name).then(function(thread){
|
||||
thread.sendMessage(view.$el.find('input.send-message').val());
|
||||
Whisper.Conversations.createGroup(numbers, name).then(function(convo){
|
||||
convo.sendMessage(view.$el.find('input.send-message').val());
|
||||
view.remove();
|
||||
thread.trigger('render');
|
||||
convo.trigger('render');
|
||||
});
|
||||
},
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue