/* 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 || {}; /* * Generic list view that watches a given collection, wraps its members in * a given child view and adds the child view elements to its own element. */ Whisper.ListView = Backbone.View.extend({ tagName: 'ul', itemView: Backbone.View, initialize: function(options) { this.listenTo(this.collection, 'add', this.addOne); this.listenTo(this.collection, 'reset', this.addAll); if (options.window) { var $window = this.$(options.window); $window.scroll(this.onScroll.bind(this)); $window.resize(this.onResize.bind(this)); } }, onResize: function(e) { this.resizing = true; clearTimeout(this.resizeTimer); resizeTimer = setTimeout(function() { resizing = false; }, 500); this.$el.scrollTop(this.scrollPercent * this.$el.height()); }, onScroll: function(e) { if (!this.resizing) { this.scrollTop = this.$el.scrollTop(); this.scrollPercent = this.scrollTop / this.$el.height(); } }, addOne: function(model) { if (this.itemView) { var view = new this.itemView({model: model}); this.$el.append(view.render().el); this.$el.trigger('add'); } }, addAll: function() { this.$el.html(''); this.collection.each(this.addOne, this); }, render: function() { this.addAll(); return this; } }); })();