/* 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 || {}; // list of conversations, showing user/group and last message sent Whisper.ConversationListItemView = Whisper.View.extend({ tagName: 'div', className: 'contact', template: $('#contact').html(), events: { 'click': 'select' }, initialize: function() { this.listenTo(this.model, 'change', this.render); // auto update this.listenTo(this.model, 'destroy', this.remove); // auto update }, select: function(e) { this.$el.addClass('selected'); this.$el.trigger('select', {modelId: this.model.id}); }, render: function() { this.$el.html( Mustache.render(this.template, { contact_name: this.model.getTitle(), last_message: this.model.get('lastMessage'), last_message_timestamp: moment(this.model.get('timestamp')).format('MMM D'), number: this.model.getNumber() }) ); if (this.model.get('avatar')) { this.$el.find('.avatar').append( new Whisper.AttachmentView({model: this.model.get('avatar')}).render().el ); } else { this.$el.find('.avatar').append( $('').attr('src', '/images/default.png') ); } return this; } }); })();