signal-desktop/js/views/list_view.js

44 lines
1.1 KiB
JavaScript
Raw Normal View History

2020-10-30 20:34:04 +00:00
// Copyright 2014-2020 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
/* global Backbone, Whisper, _ */
// eslint-disable-next-line func-names
(function () {
2018-04-27 21:25:04 +00:00
window.Whisper = window.Whisper || {};
2018-04-27 21:25:04 +00:00
/*
2020-01-08 17:44:54 +00:00
* 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.
*/
2018-04-27 21:25:04 +00:00
Whisper.ListView = Backbone.View.extend({
tagName: 'ul',
itemView: Backbone.View,
initialize(options) {
2018-04-27 21:25:04 +00:00
this.options = options || {};
this.listenTo(this.collection, 'add', this.addOne);
this.listenTo(this.collection, 'reset', this.addAll);
},
addOne(model) {
2018-04-27 21:25:04 +00:00
if (this.itemView) {
const options = _.extend({}, this.options.toInclude, { model });
// eslint-disable-next-line new-cap
const view = new this.itemView(options);
2018-04-27 21:25:04 +00:00
this.$el.append(view.render().el);
this.$el.trigger('add');
}
},
addAll() {
2018-04-27 21:25:04 +00:00
this.$el.html('');
this.collection.each(this.addOne, this);
},
render() {
2018-04-27 21:25:04 +00:00
this.addAll();
return this;
},
});
})();