/* * vim: ts=4:sw=4:expandtab */ (function () { 'use strict'; window.Whisper = window.Whisper || {}; Whisper.NewConversationView = Whisper.View.extend({ className: 'new-conversation', template: $('#new-conversation').html(), initialize: function(options) { this.render(); this.$group_update = this.$('.group-info-input'); this.$create = this.$('.create'); // Group avatar file input this.appWindow = options.appWindow; this.avatarInput = new Whisper.FileInputView({ el: this.$('.group-avatar'), window: this.appWindow.contentWindow }); this.recipients_view = new Whisper.RecipientsInputView(); this.recipients_view.$el.insertAfter(this.$('.group-info-input')); this.$input = this.$('input.search'); this.listenTo(this.getRecipients(), 'add', this.updateControls); this.listenTo(this.getRecipients(), 'remove', this.updateControls); }, render_attributes: function() { return { avatar: { url: '/images/group_default.png', color: 'gray' } }; }, events: { 'click .create': 'create', 'click .back': 'goBack', 'keyup': 'keyup' }, keyup: function(e) { if (e.keyCode === 27) { this.goBack(); } }, goBack: function() { this.trigger('back'); }, getRecipients: function() { return this.recipients_view.recipients; }, updateControls: function() { if (this.getRecipients().length > 0) { this.$create.show(); } else { this.$create.hide(); } if (this.getRecipients().length > 1) { this.$group_update.slideDown(); } else { this.$group_update.slideUp(); } this.$input.focus(); }, create: function() { var errors = this.recipients_view.$('.error'); if (errors.length) { // TODO: css animation or error notification errors.removeClass('error'); setTimeout(function(){ errors.addClass('error'); }, 300); return; } if (this.getRecipients().length > 1) { this.createGroup(); } else { var id = this.getRecipients().at(0).id; ConversationController.findOrCreatePrivateById(id).then(function(conversation) { conversation.save('active_at', Date.now()); this.trigger('open', { conversation: conversation }); }.bind(this)); } }, createGroup: function() { var name = this.$('.group-info-input .name').val(); if (!name.trim().length) { return; } return this.avatarInput.getThumbnail().then(function(avatarFile) { var members = this.getRecipients().pluck('id'); members.push(textsecure.storage.user.getNumber()); textsecure.storage.groups.createNewGroup(members).then(function(group) { return group.id; }).then(function(groupId) { var attributes = { id: groupId, groupId: groupId, type: 'group', name: name, avatar: avatarFile, members: members, active_at: Date.now() }; var group = ConversationController.create(attributes); group.save().then(function() { this.trigger('open', { conversation: group }); }.bind(this)); var now = Date.now(); var message = group.messageCollection.add({ conversationId : group.id, type : 'outgoing', sent_at : now, received_at : now, group_update : { name: group.get('name'), avatar: group.get('avatar'), joined: group.get('members') } }); message.save(); textsecure.messaging.updateGroup( group.id, group.get('name'), group.get('avatar'), group.get('members') ).catch(function(errors) { message.save({errors: errors.map(function(e){return e.error;})}); }).then(function() { message.save({sent: true}); }); }.bind(this)); }.bind(this)); }, reset: function() { this.delegateEvents(); this.avatarInput.delegateEvents(); this.$create.hide(); this.$('.group-info-input .name').val(''); this.$group_update.hide(); this.recipients_view.reset(); }, }); })();