/* vim: ts=4:sw=4:expandtab * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see . */ (function () { 'use strict'; window.Whisper = window.Whisper || {}; var bg = extension.windows.getBackground(); Whisper.InboxView = Backbone.View.extend({ initialize: function () { this.$gutter = $('#gutter'); this.$contacts = $('#contacts'); this.$fab = this.$el.find('.fab'); this.$back = this.$el.find('.back'); this.newConversationView = new Whisper.NewConversationView(); this.newConversationView.$el.hide().appendTo(this.$gutter); this.conversations = new Whisper.ConversationCollection(); this.inbox = new Whisper.ConversationListView({ el : this.$contacts, collection : this.conversations }); this.$el.addClass('loading'); this.conversations.fetchActive({reset: true}).then(function() { this.$el.removeClass('loading'); }.bind(this)); extension.on('message', function(message) { this.conversations.fetch({id: message.conversationId}).then(function() { this.conversations.get(message.conversationId).fetchMessages(); }.bind(this)); }.bind(this)); window.addEventListener('resize', this.inbox.resize.bind(this.inbox)); }, events: { 'keyup': 'keyup', 'click .back button': 'hideCompose', 'click .fab': 'showCompose', 'open #contacts': 'openConversation', 'open .contacts': 'openConversation', 'open .new-conversation': 'openConversation', 'open .new-contact': 'createConversation', }, openConversation: function(e, data) { bg.openConversation(data.modelId); this.hideCompose(); }, createConversation: function(e, data) { this.newConversationView.new_contact.model.save().then(function() { bg.openConversation(data.modelId); }); this.hideCompose(); }, showCompose: function() { this.$fab.hide(); this.$contacts.hide(); this.newConversationView.reset(); this.newConversationView.$el.show(); this.newConversationView.$input.focus(); this.$back.show(); }, hideCompose: function() { this.newConversationView.$el.hide(); this.$contacts.show(); this.$fab.show(); this.$back.hide(); }, keyup: function(e) { if (e.keyCode === 27) { this.hideCompose(); } } }); })();