1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-07-02 01:42:41 +00:00
seahub/static/scripts/app/views/repo-folder-perm-item.js

144 lines
4.6 KiB
JavaScript
Raw Normal View History

2015-04-25 06:28:09 +00:00
define([
'jquery',
'underscore',
'backbone',
'common'
], function($, _, Backbone, Common) {
'use strict';
var FolderPermItemView = Backbone.View.extend({
tagName: 'tr',
template: _.template($('#folder-perm-item-tmpl').html()),
initialize: function(options) {
2017-02-07 08:03:46 +00:00
if (options.item_data.show_folder_path === undefined) {
$.extend(options.item_data, {'show_folder_path': false})
}
2016-08-30 03:15:22 +00:00
this.data = {};
2017-02-07 08:03:46 +00:00
$.extend(this.data, options.item_data);
2015-04-25 06:28:09 +00:00
this.render();
},
render: function () {
2016-08-30 03:15:22 +00:00
this.$el.html(this.template(this.data));
2015-04-25 06:28:09 +00:00
return this;
},
events: {
'mouseenter': 'showPermOpIcons',
'mouseleave': 'hidePermOpIcons',
'click .perm-edit-icon': 'editIconClick',
'change .perm-toggle-select': 'editPerm',
'click .delete-icon': 'deletePerm'
2015-04-25 06:28:09 +00:00
},
showPermOpIcons: function () {
this.$el.find('.op-icon').removeClass('vh');
},
hidePermOpIcons: function () {
this.$el.find('.op-icon').addClass('vh');
},
editIconClick: function (e) {
$(e.currentTarget).closest('td')
.find('.perm').addClass('hide').end()
.find('.perm-toggle-select').removeClass('hide');
2016-04-12 07:53:51 +00:00
return false;
2015-04-25 06:28:09 +00:00
},
editPerm: function (e) {
var _this = this;
var perm = $(e.currentTarget).val();
2016-08-30 03:15:22 +00:00
var data = {
'permission': perm,
'folder_path': this.data.folder_path
2015-04-25 06:28:09 +00:00
};
2016-08-30 03:15:22 +00:00
var for_user = this.data.for_user;
if (for_user) {
2016-08-30 03:15:22 +00:00
$.extend(data, {'user_email': this.data.user_email});
2015-04-25 06:28:09 +00:00
} else {
2016-08-30 03:15:22 +00:00
$.extend(data, {'group_id': this.data.group_id});
2015-04-25 06:28:09 +00:00
}
$.ajax({
url: Common.getUrl({
2016-08-30 03:15:22 +00:00
name: for_user ? 'repo_user_folder_perm' : 'repo_group_folder_perm',
repo_id: this.data.repo_id
2015-04-25 06:28:09 +00:00
}),
2016-08-30 03:15:22 +00:00
type: 'PUT',
2015-04-25 06:28:09 +00:00
dataType: 'json',
cache: false,
beforeSend: Common.prepareCSRFToken,
2016-08-30 03:15:22 +00:00
data: data,
2015-04-25 06:28:09 +00:00
success: function() {
2016-08-30 03:15:22 +00:00
_this.data.permission = perm;
2015-04-25 06:28:09 +00:00
_this.render();
},
error: function(xhr) {
var err;
if (xhr.responseText) {
err = $.parseJSON(xhr.responseText).error;
} else {
err = gettext("Failed. Please check the network.");
}
if (for_user) {
2015-04-25 06:28:09 +00:00
$('#user-folder-perm .error').html(err).removeClass('hide');
} else {
$('#group-folder-perm .error').html(err).removeClass('hide');
}
}
});
},
deletePerm: function () {
var _this = this;
2016-08-30 03:15:22 +00:00
var data = {
'permission': this.data.permission,
'folder_path': this.data.folder_path
2015-04-25 06:28:09 +00:00
};
2016-08-30 03:15:22 +00:00
var for_user = this.data.for_user;
if (for_user) {
2016-08-30 03:15:22 +00:00
$.extend(data, {'user_email': this.data.user_email});
2015-04-25 06:28:09 +00:00
} else {
2016-08-30 03:15:22 +00:00
$.extend(data, {'group_id': this.data.group_id});
2015-04-25 06:28:09 +00:00
}
$.ajax({
url: Common.getUrl({
2016-08-30 03:15:22 +00:00
name: for_user ? 'repo_user_folder_perm' : 'repo_group_folder_perm',
repo_id: this.data.repo_id
2015-04-25 06:28:09 +00:00
}),
2016-08-30 03:15:22 +00:00
type: 'DELETE',
2015-04-25 06:28:09 +00:00
dataType: 'json',
cache: false,
beforeSend: Common.prepareCSRFToken,
2016-08-30 03:15:22 +00:00
data: data,
2015-04-25 06:28:09 +00:00
success: function() {
_this.remove();
},
error: function(xhr) {
var err;
if (xhr.responseText) {
err = $.parseJSON(xhr.responseText).error;
} else {
err = gettext("Failed. Please check the network.");
}
if (for_user) {
2015-04-25 06:28:09 +00:00
$('#user-folder-perm .error').html(err).removeClass('hide');
} else {
$('#group-folder-perm .error').html(err).removeClass('hide');
}
}
});
2016-04-12 07:53:51 +00:00
return false;
2015-04-25 06:28:09 +00:00
}
});
return FolderPermItemView;
});