123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370 |
- /**
- * Copyright (c) 2014, Raghu Nayyar <beingminimal@gmail.com>
- * Copyright (c) 2014, Arthur Schiwon <blizzz@owncloud.com>
- * This file is licensed under the Affero General Public License version 3 or later.
- * See the COPYING-README file.
- */
- /* globals escapeHTML, UserList, DeleteHandler */
- var $userGroupList,
- $sortGroupBy;
- var GroupList;
- GroupList = {
- activeGID: '',
- everyoneGID: '_everyone',
- filter: '',
- filterGroups: false,
- addGroup: function (gid, usercount) {
- var $li = $userGroupList.find('.isgroup:last-child').clone();
- $li
- .data('gid', gid)
- .find('.groupname').text(gid);
- GroupList.setUserCount($li, usercount);
- $li.appendTo($userGroupList);
- GroupList.sortGroups();
- return $li;
- },
- setUserCount: function (groupLiElement, usercount) {
- if ($sortGroupBy !== 1) {
- // If we don't sort by group count we don't display them either
- return;
- }
- var $groupLiElement = $(groupLiElement);
- if (usercount === undefined || usercount === 0 || usercount < 0) {
- usercount = '';
- $groupLiElement.data('usercount', 0);
- } else {
- $groupLiElement.data('usercount', usercount);
- }
- $groupLiElement.find('.usercount').text(usercount);
- },
- getUserCount: function ($groupLiElement) {
- return parseInt($groupLiElement.data('usercount'), 10);
- },
- modGroupCount: function(gid, diff) {
- var $li = GroupList.getGroupLI(gid);
- var count = GroupList.getUserCount($li) + diff;
- GroupList.setUserCount($li, count);
- },
- incEveryoneCount: function() {
- GroupList.modGroupCount(GroupList.everyoneGID, 1);
- },
- decEveryoneCount: function() {
- GroupList.modGroupCount(GroupList.everyoneGID, -1);
- },
- incGroupCount: function(gid) {
- GroupList.modGroupCount(gid, 1);
- },
- decGroupCount: function(gid) {
- GroupList.modGroupCount(gid, -1);
- },
- getCurrentGID: function () {
- return GroupList.activeGID;
- },
- sortGroups: function () {
- var lis = $userGroupList.find('.isgroup').get();
- lis.sort(function (a, b) {
- // "Everyone" always at the top
- if ($(a).data('gid') === '_everyone') {
- return -1;
- } else if ($(b).data('gid') === '_everyone') {
- return 1;
- }
- // "admin" always as second
- if ($(a).data('gid') === 'admin') {
- return -1;
- } else if ($(b).data('gid') === 'admin') {
- return 1;
- }
- if ($sortGroupBy === 1) {
- // Sort by user count first
- var $usersGroupA = $(a).data('usercount'),
- $usersGroupB = $(b).data('usercount');
- if ($usersGroupA > 0 && $usersGroupA > $usersGroupB) {
- return -1;
- }
- if ($usersGroupB > 0 && $usersGroupB > $usersGroupA) {
- return 1;
- }
- }
- // Fallback or sort by group name
- 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) {
- $userGroupList.append(items);
- items = [];
- }
- });
- if (items.length > 0) {
- $userGroupList.append(items);
- }
- },
- createGroup: function (groupname) {
- if (OC.PasswordConfirmation.requiresPasswordConfirmation()) {
- OC.PasswordConfirmation.requirePasswordConfirmation(_.bind(this.createGroup, this, groupname));
- return;
- }
- $.post(
- OC.generateUrl('/settings/users/groups'),
- {
- id: groupname
- },
- function (result) {
- if (result.groupname) {
- var addedGroup = result.groupname;
- UserList.availableGroups = $.unique($.merge(UserList.availableGroups, [addedGroup]));
- GroupList.addGroup(result.groupname);
- }
- GroupList.toggleAddGroup();
- }).fail(function(result) {
- OC.Notification.showTemporary(t('settings', 'Error creating group: {message}', {message: result.responseJSON.message}));
- });
- },
- update: function () {
- if (GroupList.updating) {
- return;
- }
- GroupList.updating = true;
- $.get(
- OC.generateUrl('/settings/users/groups'),
- {
- pattern: this.filter,
- filterGroups: this.filterGroups ? 1 : 0,
- sortGroups: $sortGroupBy
- },
- function (result) {
- var lis = [];
- if (result.status === 'success') {
- $.each(result.data, function (i, subset) {
- $.each(subset, function (index, group) {
- if (GroupList.getGroupLI(group.name).length > 0) {
- GroupList.setUserCount(GroupList.getGroupLI(group.name).first(), group.usercount);
- }
- else {
- var $li = GroupList.addGroup(group.name, group.usercount);
- $li.addClass('appear transparent');
- lis.push($li);
- }
- });
- });
- if (result.data.length > 0) {
- GroupList.doSort();
- }
- else {
- GroupList.noMoreEntries = true;
- }
- _.defer(function () {
- $(lis).each(function () {
- this.removeClass('transparent');
- });
- });
- }
- GroupList.updating = false;
- }
- );
- },
- elementBelongsToAddGroup: function (el) {
- return !(el !== $('#newgroup-form').get(0) &&
- $('#newgroup-form').find($(el)).length === 0);
- },
- hasAddGroupNameText: function () {
- var name = $('#newgroupname').val();
- return $.trim(name) !== '';
- },
- showGroup: function (gid) {
- GroupList.activeGID = gid;
- UserList.empty();
- UserList.update(gid);
- $userGroupList.find('li').removeClass('active');
- if (gid !== undefined) {
- //TODO: treat Everyone properly
- GroupList.getGroupLI(gid).addClass('active');
- }
- },
- isAddGroupButtonVisible: function () {
- return $('#newgroup-init').is(":visible");
- },
- toggleAddGroup: function (event) {
- if (GroupList.isAddGroupButtonVisible()) {
- if (event) {
- event.stopPropagation();
- }
- $('#newgroup-form').show();
- $('#newgroup-init').hide();
- $('#newgroupname').focus();
- GroupList.handleAddGroupInput('');
- }
- else {
- $('#newgroup-form').hide();
- $('#newgroup-init').show();
- $('#newgroupname').val('');
- }
- },
- handleAddGroupInput: function (input) {
- if(input.length) {
- $('#newgroup-form input[type="submit"]').attr('disabled', null);
- } else {
- $('#newgroup-form input[type="submit"]').attr('disabled', 'disabled');
- }
- },
- isGroupNameValid: function (groupname) {
- if ($.trim(groupname) === '') {
- OC.Notification.showTemporary(t('settings', 'Error creating group: {message}', {
- message: t('settings', 'A valid group name must be provided')
- }));
- return false;
- }
- return true;
- },
- hide: function (gid) {
- GroupList.getGroupLI(gid).hide();
- },
- show: function (gid) {
- GroupList.getGroupLI(gid).show();
- },
- remove: function (gid) {
- GroupList.getGroupLI(gid).remove();
- },
- empty: function () {
- $userGroupList.find('.isgroup').filter(function(index, item){
- return $(item).data('gid') !== '';
- }).remove();
- },
- initDeleteHandling: function () {
- //set up handler
- var GroupDeleteHandler = new DeleteHandler('/settings/users/groups', 'groupname',
- GroupList.hide, GroupList.remove);
- //configure undo
- OC.Notification.hide();
- var msg = escapeHTML(t('settings', 'deleted {groupName}', {groupName: '%oid'})) + '<span class="undo">' +
- escapeHTML(t('settings', 'undo')) + '</span>';
- GroupDeleteHandler.setNotification(OC.Notification, 'deletegroup', msg,
- GroupList.show);
- //when to mark user for delete
- var deleteAction = function () {
- if (OC.PasswordConfirmation.requiresPasswordConfirmation()) {
- OC.PasswordConfirmation.requirePasswordConfirmation(_.bind(deleteAction, this));
- return;
- }
- // Call function for handling delete/undo
- GroupDeleteHandler.mark(GroupList.getElementGID(this));
- };
- $userGroupList.on('click', '.delete', deleteAction);
- //delete a marked user when leaving the page
- $(window).on('beforeunload', function () {
- GroupDeleteHandler.deleteEntry();
- });
- },
- getGroupLI: function (gid) {
- return $userGroupList.find('li.isgroup').filter(function () {
- return GroupList.getElementGID(this) === gid;
- });
- },
- getElementGID: function (element) {
- return ($(element).closest('li').data('gid') || '').toString();
- },
- getEveryoneCount: function () {
- $.ajax({
- type: "GET",
- dataType: "json",
- url: OC.generateUrl('/settings/users/stats')
- }).success(function (data) {
- $('#everyonegroup').data('usercount', data.totalUsers);
- $('#everyonecount').text(data.totalUsers);
- });
- }
- };
- $(document).ready( function () {
- $userGroupList = $('#usergrouplist');
- GroupList.initDeleteHandling();
- $sortGroupBy = $userGroupList.data('sort-groups');
- if ($sortGroupBy === 1) {
- // Disabled due to performance issues, when we don't need it for sorting
- GroupList.getEveryoneCount();
- }
- // Display or hide of Create Group List Element
- $('#newgroup-form').hide();
- $('#newgroup-init').on('click', function (e) {
- GroupList.toggleAddGroup(e);
- });
- $(document).on('click keydown keyup', function(event) {
- if(!GroupList.isAddGroupButtonVisible() &&
- !GroupList.elementBelongsToAddGroup(event.target) &&
- !GroupList.hasAddGroupNameText()) {
- GroupList.toggleAddGroup();
- }
- // Escape
- if(!GroupList.isAddGroupButtonVisible() && event.keyCode && event.keyCode === 27) {
- GroupList.toggleAddGroup();
- }
- });
- // Responsible for Creating Groups.
- $('#newgroup-form form').submit(function (event) {
- event.preventDefault();
- if(GroupList.isGroupNameValid($('#newgroupname').val())) {
- GroupList.createGroup($('#newgroupname').val());
- }
- });
- // click on group name
- $userGroupList.on('click', '.isgroup', function () {
- GroupList.showGroup(GroupList.getElementGID(this));
- });
- $('#newgroupname').on('input', function(){
- GroupList.handleAddGroupInput(this.value);
- });
- });
|