DRY up PushMessageContentProtobuf construction

Messages now know how to protobuf-ify themselves.
This commit is contained in:
lilia 2014-05-18 14:26:55 -07:00
parent 2601c3cc3a
commit 3bd559bbaa
3 changed files with 31 additions and 20 deletions

View File

@ -3,29 +3,38 @@ var Whisper = Whisper || {};
(function () {
'use strict';
var Message = Backbone.Model.extend();
var Message = Backbone.Model.extend({
toProto: function() {
return new PushMessageContentProtobuf({body: this.get('body')});
}
});
Whisper.Messages = new (Backbone.Collection.extend({
localStorage: new Backbone.LocalStorage("Messages"),
model: Message,
comparator: 'timestamp',
addIncomingMessage: function(decrypted) {
Whisper.Messages.add({
var m = Whisper.Messages.add({
person: decrypted.pushMessage.source,
group: decrypted.message.group,
body: decrypted.message.body,
type: 'incoming',
timestamp: decrypted.message.timestamp
}).save();
});
m.save();
return m;
},
addOutgoingMessage: function(messageProto, recipients) {
Whisper.Messages.add({
addOutgoingMessage: function(message, recipients) {
var m = Whisper.Messages.add({
person: recipients[0], // TODO: groups
body: messageProto.body,
body: message,
type: 'outgoing',
timestamp: new Date().getTime()
}).save();
});
m.save();
return m;
}
}))();

View File

@ -51,10 +51,10 @@ textsecure.registerOnLoadFunction(function() {
alert(numberError);
}
}
var messageProto = new PushMessageContentProtobuf();
messageProto.body = $("#popup_send_text").val();
Whisper.Messages.addOutgoingMessage(messageProto, numbers);
textsecure.sendMessage(numbers, messageProto,
var message = Whisper.Messages.addOutgoingMessage(
$("#popup_send_text").val(), numbers
);
textsecure.sendMessage(numbers, message.toProto(),
//TODO: Handle result
function(thing) {console.log(thing);});
});

View File

@ -81,17 +81,19 @@ var Whisper = Whisper || {};
$button.attr("disabled", "disabled");
$button.find('span').text("Sending");
var messageProto = new PushMessageContentProtobuf();
messageProto.body = $input.val();
Whisper.Messages.addOutgoingMessage(messageProto, options.recipients);
var message = Whisper.Messages.addOutgoingMessage(
$input.val(), options.recipients
);
textsecure.sendMessage(options.recipients, messageProto, function(result) {
console.log(result);
$button.removeAttr("disabled");
$button.find('span').text("Send");
$input.val("");
});
textsecure.sendMessage(options.recipients, message.toProto(),
function(result) {
console.log(result);
$button.removeAttr("disabled");
$button.find('span').text("Send");
$input.val("");
}
);
});
},