define(['jquery', 'underscore', 'app', 'views/abstract/modalView', 'hbs!tpl/dialogs/addPluginConfig', 'helpers/pluginIcon', 'select2'], function($, _, App, modalView, template, pluginIcon) { return modalView.extend({ events: { 'click .btn-add': 'add' }, template: template, plugins: null, select: null, initialize: function() { // Inherit parent events this.events = _.extend({}, modalView.prototype.events, this.events); var self = this; $.ajax(App.apiRequest('getAvailablePlugins', null, {success: function(data) { self.plugins = _.sortBy(data, function(item) { return item.name; }); self.render(); }})); }, onRender: function() { // TODO: could be a seperate input type if needed on multiple pages if (this.plugins) this.select = this.$('#pluginSelect').select2({ escapeMarkup: function(m) { return m; }, formatResult: this.format, formatSelection: this.formatSelection, data: {results: this.plugins, text: function(item) { return item.label; }}, id: function(item) { return item.name; } }); }, onShow: function() { }, onHide: function() { }, format: function(data) { var s = '
' + data.label; s += '
' + data.description + '
'; return s; }, formatSelection: function(data) { return ' ' + data.label; }, add: function(e) { e.stopPropagation(); if (this.select) { var plugin = this.select.val(); App.vent.trigger('config:open', plugin); this.hide(); } } }); });