signal-desktop/js/views/new_message_button.js
lilia c034ac8267 Refactor components for the main content section
Each conversation views now manages its own separate elements
rather than all binding to a shared #conversation element, and
similarly for message composition ui.

Also includes the beginnings of group creation UI (not working yet),
featuring bootstrap-tagsinput field for entering group recipients
2014-08-25 18:54:55 -07:00

120 lines
3.2 KiB
JavaScript

var Whisper = Whisper || {};
(function () {
'use strict';
Whisper.GroupRecipientsInputView = Backbone.View.extend({
initialize: function() {
this.$el.tagsinput({ tagClass: this.tagClass });
},
tagClass: function(item) {
try {
if (textsecure.utils.verifyNumber(item)) {
return;
}
} catch(ex) {}
return 'error';
}
});
Whisper.NewGroupView = Backbone.View.extend({
initialize: function() {
this.template = $('#new-group-form').html();
Mustache.parse(this.template);
this.render();
new Whisper.GroupRecipientsInputView({el: this.$el.find('input.numbers')}).$el.appendTo(this.$el);
},
events: {
'submit #send': 'send'
},
send: function(e) {
var numbers = this.$el.find('input.numbers').val().split(',');
var name = this.$el.find('input.name').val();
var thread = Whisper.Threads.createGroup(numbers, name);
thread.sendMessage(input.val());
// close this, select the new thread
},
render: function() {
this.$el.prepend($(Mustache.render(this.template)));
return this;
}
});
Whisper.MessageRecipientInputView = Backbone.View.extend({
events: {
'change': 'verifyNumber',
'focus' : 'removeError'
},
removeError: function() {
this.$el.removeClass('error');
},
verifyNumber: function(item) {
try {
if (textsecure.utils.verifyNumber(this.$el.val())) {
this.removeError();
return;
}
} catch(ex) { console.log(ex); }
this.$el.addClass('error');
}
});
Whisper.NewConversationView = Backbone.View.extend({
initialize: function() {
this.template = $('#new-message-form').html();
Mustache.parse(this.template);
this.input = this.$el.find('input.number');
new Whisper.MessageRecipientInputView({el: this.input});
},
events: {
'submit #send': 'send',
'close': 'undelegateEvents'
},
send: function(e) {
e.preventDefault();
var number = this.input.val();
if (textsecure.utils.verifyNumber(number)) {
var thread = Whisper.Threads.findOrCreateForRecipient(number);
var send_input = this.$el.find('#send input');
thread.sendMessage(send_input.val());
send_input.val('');
this.$el.find('form.message').remove();
this.$el.trigger('close');
new Whisper.ConversationView({model: thread});
}
},
render: function() {
this.$el.html(Mustache.render(this.template));
return this;
}
});
Whisper.Header = Backbone.View.extend({
events: {
'click #new-message': 'new_message',
'click #new-group': 'new_group'
},
new_message: function(e) {
e.preventDefault();
$('.conversation').hide().trigger('close'); // detach any existing conversation views
this.view = new Whisper.NewConversationView().render().$el.insertAfter($('#gutter'));
//todo: less new
},
new_group: function(e) {
e.preventDefault();
$('.conversation').trigger('close'); // detach any existing conversation views
new Whisper.NewGroupView({ el: $('.conversation') });
}
});
})();