define(['jquery', 'views/abstract/itemView', 'underscore', 'views/fileView', 'utils/lazyRequire', 'handlebars', 'peity'], function($, itemView, _, fileView, lazyLoader, HB) { // Renders a single package item return itemView.extend({ tagName: 'li', className: 'package-view', // template: _.template($("#template-package").html()), template: HB.compile($("#template-package").html()), events: { 'click .package-header': 'load', 'click .delete': 'delete', 'click .show-dialog': 'show_dialog' }, modal: null, requireOnce: lazyLoader.once(), initialize: function() { this.model.on('filter:added', this.hide, this); this.model.on('filter:removed', this.show, this); this.model.on('change', this.render, this); this.model.on('remove', this.unrender, this); }, onDestroy: function() { this.model.off('filter:added', this.hide); // TODO }, render: function() { // TODO: on expanding don't re-render this.$el.html(this.template(this.model.toJSON())); var data = [ { label: "Series1", data: 30}, { label: "Series2", data: 90} ]; var pie = this.$('.package-graph'); pie.peity('pie'); this.$('canvas').addClass('pull-right'); if (this.model.isLoaded()) { var ul = $('