2014-02-19 07:44:18 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2014, Raghu Nayyar <beingminimal@gmail.com>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
var GroupList = {
|
2014-02-25 14:22:20 +00:00
|
|
|
addGroup: function(gid) {
|
|
|
|
var li = $('li[data-gid]').last().clone();
|
|
|
|
var ul = $('li[data-gid]').first().parent();
|
|
|
|
li.attr('data-gid', gid);
|
|
|
|
li.attr('data-usercount', 0);
|
|
|
|
li.find('a span').first().text(gid);
|
|
|
|
li.find('span[class=usercount]').first().text('');
|
|
|
|
|
|
|
|
$(li).appendTo(ul);
|
|
|
|
|
|
|
|
GroupList.sortGroups(0);
|
|
|
|
},
|
|
|
|
|
|
|
|
sortGroups: function(usercount) {
|
|
|
|
var lis = $('li[data-gid]').filterAttr('data-usercount', usercount.toString()).get();
|
|
|
|
var ul = $(lis).first().parent();
|
|
|
|
|
|
|
|
lis.sort(function(a, b) {
|
|
|
|
return UserList.alphanum($(a).find('a span').text(), $(b).find('a span').text());
|
|
|
|
});
|
|
|
|
|
|
|
|
var items = [];
|
|
|
|
$.each(lis, function(index, li) {
|
|
|
|
items.push(li);
|
|
|
|
if(items.length === 100) {
|
|
|
|
$(ul).append(items);
|
|
|
|
items = [];
|
|
|
|
}
|
|
|
|
});
|
|
|
|
if(items.length > 0) {
|
|
|
|
$(ul).append(items);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
createGroup: function(groupname) {
|
|
|
|
$.post(
|
|
|
|
OC.filePath('settings', 'ajax', 'creategroup.php'),
|
|
|
|
{
|
|
|
|
groupname : groupname
|
|
|
|
},
|
|
|
|
function (result) {
|
|
|
|
if (result.status !== 'success') {
|
|
|
|
OC.dialogs.alert(result.data.message,
|
|
|
|
t('settings', 'Error creating group'));
|
|
|
|
} else {
|
|
|
|
if (result.data.groupname) {
|
|
|
|
var addedGroups = result.data.groupname;
|
|
|
|
UserList.availableGroups = $.unique($.merge(UserList.availableGroups, addedGroups));
|
|
|
|
GroupList.addGroup(result.data.groupname);
|
|
|
|
}
|
|
|
|
GroupList.toggleAddGroup();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
},
|
2014-02-19 07:44:18 +00:00
|
|
|
|
|
|
|
delete_group: function (gid) {
|
|
|
|
if(GroupList.deleteGid !=='undefined') {
|
|
|
|
GroupList.finishDelete(null);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Set the undo flag
|
|
|
|
GroupList.deleteCanceled = false;
|
|
|
|
|
|
|
|
//Provide an option to undo
|
|
|
|
$('#notification').data('deletegroup', true);
|
|
|
|
OC.Notification.showHtml(t('settings', 'deleted') + ' ' + escapeHTML(gid) + '<span class="undo">' + t('settings', 'undo') + '</span>');
|
|
|
|
},
|
|
|
|
|
2014-02-25 14:41:03 +00:00
|
|
|
elementBelongsToAddGroup: function(el) {
|
|
|
|
return !(el !== $('#newgroup-form').get(0)
|
|
|
|
&& $('#newgroup-form').find($(el)).length === 0);
|
|
|
|
},
|
|
|
|
|
2014-02-25 15:11:20 +00:00
|
|
|
hasAddGroupNameText: function() {
|
|
|
|
name = $('#newgroupname').val();
|
|
|
|
if($.trim(name) === '') {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
2014-02-19 10:40:07 +00:00
|
|
|
showGroup: function (gid) {
|
|
|
|
UserList.empty();
|
|
|
|
UserList.update(gid);
|
2014-02-20 18:11:52 +00:00
|
|
|
$('#app-navigation li').removeClass('active');
|
|
|
|
if(gid !== undefined) {
|
|
|
|
//TODO: treat Everyone properly
|
|
|
|
$('#app-navigation li').filterAttr('data-gid', gid).addClass('active');
|
|
|
|
}
|
2014-02-19 10:40:07 +00:00
|
|
|
},
|
|
|
|
|
2014-02-25 14:41:03 +00:00
|
|
|
isAddGroupButtonVisible: function() {
|
|
|
|
return $('#newgroup-init').is(":visible");
|
|
|
|
},
|
|
|
|
|
2014-02-25 13:26:35 +00:00
|
|
|
toggleAddGroup: function(event) {
|
2014-02-25 14:41:03 +00:00
|
|
|
if(GroupList.isAddGroupButtonVisible()) {
|
2014-02-25 13:26:35 +00:00
|
|
|
event.stopPropagation();
|
|
|
|
$('#newgroup-form').show();
|
|
|
|
$('#newgroup-init').hide();
|
|
|
|
$('#newgroupname').focus();
|
|
|
|
} else {
|
|
|
|
$('#newgroup-form').hide();
|
|
|
|
$('#newgroup-init').show();
|
|
|
|
$('#newgroupname').val('');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2014-02-25 14:22:20 +00:00
|
|
|
isGroupNameValid: function(groupname) {
|
|
|
|
if ($.trim(groupname) === '') {
|
|
|
|
OC.dialogs.alert(
|
|
|
|
t('settings', 'A valid groupname must be provided'),
|
|
|
|
t('settings', 'Error creating group'));
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
2014-02-19 07:44:18 +00:00
|
|
|
finishDelete: function (ready) {
|
|
|
|
if (!GroupList.deleteCanceled && GroupList.deleteGid) {
|
|
|
|
$.ajax({
|
|
|
|
type: 'POST',
|
|
|
|
url: OC.filePath('settings', 'ajax', 'removegroup.php'),
|
|
|
|
async: false,
|
|
|
|
data: { groupname: GroupList.deleteGid },
|
|
|
|
success: function (result) {
|
|
|
|
if (result.status === 'success') {
|
|
|
|
// Remove undo option, & remove user from table
|
|
|
|
OC.Notification.hide();
|
|
|
|
$('li').filterAttr('data-gid', GroupList.deleteGid).remove();
|
|
|
|
GroupList.deleteCanceled = true;
|
|
|
|
if (ready) {
|
|
|
|
ready();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
OC.dialogs.alert(result.data.message, t('settings', 'Unable to remove group'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
$(document).ready( function () {
|
|
|
|
$('ul').on('click', 'span.utils>a', function (event) {
|
|
|
|
var li = $(this).parent().parent();
|
|
|
|
var gid = $(li).attr('data-gid');
|
|
|
|
$(li).hide();
|
|
|
|
// Call function for handling delete/undo on Groups
|
|
|
|
GroupList.delete_group(gid);
|
|
|
|
});
|
2014-02-25 10:09:01 +00:00
|
|
|
|
|
|
|
// Display or hide of Create Group List Element
|
|
|
|
$('#newgroup-form').hide();
|
|
|
|
$('#newgroup-init').on('click', function (e) {
|
2014-02-25 13:26:35 +00:00
|
|
|
GroupList.toggleAddGroup(e);
|
2014-02-25 10:09:01 +00:00
|
|
|
});
|
|
|
|
|
2014-02-25 14:41:03 +00:00
|
|
|
$(document).on('click keydown keyup', function(event) {
|
|
|
|
if(!GroupList.isAddGroupButtonVisible()
|
2014-02-25 15:11:20 +00:00
|
|
|
&& !GroupList.elementBelongsToAddGroup(event.target)
|
|
|
|
&& !GroupList.hasAddGroupNameText()) {
|
2014-02-25 14:41:03 +00:00
|
|
|
GroupList.toggleAddGroup();
|
|
|
|
}
|
|
|
|
// Escape
|
|
|
|
if(!GroupList.isAddGroupButtonVisible() && event.keyCode && event.keyCode === 27) {
|
|
|
|
GroupList.toggleAddGroup();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-02-25 10:09:01 +00:00
|
|
|
// Responsible for Creating Groups.
|
|
|
|
$('#newgroup-form form').submit(function (event) {
|
2014-02-19 07:44:18 +00:00
|
|
|
event.preventDefault();
|
2014-02-25 14:22:20 +00:00
|
|
|
if(GroupList.isGroupNameValid($('#newgroupname').val())) {
|
|
|
|
GroupList.createGroup($('#newgroupname').val());
|
2014-02-19 07:44:18 +00:00
|
|
|
}
|
|
|
|
});
|
2014-02-25 13:05:48 +00:00
|
|
|
|
|
|
|
// click on group name
|
|
|
|
// FIXME: also triggered when clicking on "remove"
|
|
|
|
$('ul').on('click', 'li[data-gid]', function (event) {
|
|
|
|
var li = $(this);
|
|
|
|
var gid = $(li).attr('data-gid');
|
|
|
|
// Call function for handling delete/undo on Groups
|
|
|
|
GroupList.showGroup(gid);
|
|
|
|
});
|
|
|
|
|
2014-02-19 07:44:18 +00:00
|
|
|
// Implements Groupname editing.
|
2014-02-22 21:28:44 +00:00
|
|
|
$('#app-navigation').on('click', 'img.rename', function (event) {
|
2014-02-19 07:44:18 +00:00
|
|
|
event.stopPropagation();
|
|
|
|
var img = $(this);
|
|
|
|
var gid = img.parent().parent().attr('data-gid');
|
|
|
|
var groupname = escapeHTML(img.parent().parent().attr('data-gid'));
|
|
|
|
var input = $('<input type="text" value="' + groupname + '">');
|
|
|
|
img.css('display', 'none');
|
2014-02-22 21:28:44 +00:00
|
|
|
img.parent().children('span').replaceWith(input);
|
2014-02-19 07:44:18 +00:00
|
|
|
input.focus();
|
|
|
|
input.keypress(function (event) {
|
|
|
|
if (event.keyCode === 13) {
|
|
|
|
if ($(this).val().length > 0) {
|
|
|
|
$.post(
|
|
|
|
OC.filePath('settings', 'ajax', 'changegroupname.php'),
|
|
|
|
{ groupname: gid,
|
|
|
|
groupname: $(this).val()
|
|
|
|
}
|
|
|
|
);
|
|
|
|
input.blur();
|
|
|
|
} else {
|
|
|
|
input.blur();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
input.blur(function () {
|
|
|
|
var input = $(this), groupname = input.val();
|
|
|
|
input.closest('li').attr('data-gid', groupname);
|
2014-02-22 21:28:44 +00:00
|
|
|
input.replaceWith('<span>' + escapeHTML(groupname) + '</span>');
|
2014-02-19 07:44:18 +00:00
|
|
|
img.css('display', '');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-02-19 09:10:49 +00:00
|
|
|
// Implements Quota Settings Toggle.
|
|
|
|
$('#app-navigation').find('.settings-button').on('click', function (e) {
|
2014-02-26 20:31:50 +00:00
|
|
|
$('.settings-button').addClass('opened');
|
|
|
|
var settings = $('#app-settings');
|
2014-02-19 09:10:49 +00:00
|
|
|
e.stopPropagation();
|
2014-02-26 20:31:50 +00:00
|
|
|
settings.animate({height: "100px"});
|
|
|
|
$('#app-settings-content').css('display', 'block');
|
|
|
|
$(document).click(function (e) {
|
|
|
|
if (!settings.is(e.target) && settings.has(e.target).length === 0) {
|
|
|
|
settings.animate({height: "45px"});
|
|
|
|
}
|
|
|
|
});
|
2014-02-19 09:10:49 +00:00
|
|
|
});
|
2014-02-19 07:44:18 +00:00
|
|
|
});
|