2014-09-01 02:58:36 +02:00
|
|
|
var Whisper = Whisper || {};
|
|
|
|
|
|
|
|
(function () {
|
|
|
|
'use strict';
|
|
|
|
var MessageRecipientInputView = Backbone.View.extend({
|
|
|
|
events: {
|
|
|
|
'change': 'verifyNumber',
|
|
|
|
'focus' : 'removeError'
|
|
|
|
},
|
|
|
|
|
|
|
|
removeError: function() {
|
|
|
|
this.$el.removeClass('error');
|
|
|
|
},
|
|
|
|
|
|
|
|
verifyNumber: function(item) {
|
|
|
|
try {
|
2014-10-12 02:19:16 +02:00
|
|
|
if (libphonenumber.util.verifyNumber(this.$el.val())) {
|
2014-09-01 02:58:36 +02:00
|
|
|
this.removeError();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} catch(ex) { console.log(ex); }
|
|
|
|
this.$el.addClass('error');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Whisper.NewConversationView = Backbone.View.extend({
|
|
|
|
className: 'conversation',
|
|
|
|
initialize: function() {
|
|
|
|
this.template = $('#new-message-form').html();
|
|
|
|
Mustache.parse(this.template);
|
|
|
|
this.render();
|
|
|
|
this.input = this.$el.find('input.number');
|
|
|
|
new MessageRecipientInputView({el: this.input});
|
|
|
|
},
|
|
|
|
|
|
|
|
events: {
|
|
|
|
'submit .send': 'send',
|
|
|
|
'close': 'remove'
|
|
|
|
},
|
|
|
|
|
|
|
|
send: function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
var number = this.input.val();
|
|
|
|
try {
|
2014-10-12 02:19:16 +02:00
|
|
|
if (libphonenumber.util.verifyNumber(number)) {
|
2014-09-01 02:58:36 +02:00
|
|
|
var thread = Whisper.Threads.findOrCreateForRecipient(number);
|
|
|
|
var message_input = this.$el.find('input.send-message');
|
|
|
|
thread.sendMessage(message_input.val());
|
|
|
|
this.remove();
|
2014-09-04 09:21:18 +02:00
|
|
|
thread.trigger('render');
|
2014-09-01 02:58:36 +02:00
|
|
|
}
|
|
|
|
} catch(ex) {}
|
|
|
|
},
|
|
|
|
|
|
|
|
render: function() {
|
|
|
|
this.$el.html(Mustache.render(this.template));
|
|
|
|
Whisper.Layout.setContent(this.$el.show());
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
})();
|