DRY up PushMessageContentProtobuf construction
Messages now know how to protobuf-ify themselves.
This commit is contained in:
parent
2601c3cc3a
commit
3bd559bbaa
3 changed files with 31 additions and 20 deletions
|
@ -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;
|
||||
}
|
||||
}))();
|
||||
|
||||
|
|
|
@ -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);});
|
||||
});
|
||||
|
|
|
@ -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) {
|
||||
textsecure.sendMessage(options.recipients, message.toProto(),
|
||||
function(result) {
|
||||
console.log(result);
|
||||
$button.removeAttr("disabled");
|
||||
$button.find('span').text("Send");
|
||||
$input.val("");
|
||||
});
|
||||
}
|
||||
);
|
||||
});
|
||||
},
|
||||
|
||||
|
|
Loading…
Reference in a new issue