define([ 'jquery', 'underscore', 'backbone', 'common' ], function($, _, Backbone, Common) { 'use strict'; var OrganizationRepoView = Backbone.View.extend({ tagName: 'tr', template: _.template($('#organization-repo-tmpl').html()), initialize: function() { }, render: function() { var obj = this.model.toJSON(); var icon_size = Common.isHiDPI() ? 96 : 24; var icon_url = this.model.getIconUrl(icon_size); _.extend(obj, { 'icon_url': icon_url, 'icon_title': this.model.getIconTitle() }); this.$el.html(this.template(obj)); return this; }, events: { 'mouseenter': 'highlight', 'mouseleave': 'rmHighlight', 'click .cancel-share': 'removeShare' }, highlight: function() { this.$el.addClass('hl').find('.op-icon').removeClass('vh'); }, rmHighlight: function() { this.$el.removeClass('hl').find('.op-icon').addClass('vh'); }, removeShare: function() { var el = this.$el; var lib_name = this.model.get('name'); $.ajax({ url: Common.getUrl({ name: 'ajax_unset_inner_pub_repo', repo_id: this.model.get('id') }), type: 'POST', data: { 'permission': this.model.get('permission') }, beforeSend: Common.prepareCSRFToken, dataType: 'json', success: function () { el.remove(); var msg = gettext('Successfully unshared {placeholder}').replace('{placeholder}', '' + Common.HTMLescape(lib_name) + ''); Common.feedback(msg, 'success', Common.SUCCESS_TIMOUT); }, error: function(xhr) { Common.ajaxErrorHandler(xhr); } }); } }); return OrganizationRepoView; });