aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Kesselberg <mail@danielkesselberg.de>2020-01-24 16:03:39 +0100
committerDaniel Kesselberg <mail@danielkesselberg.de>2020-04-24 18:10:02 +0200
commit16f29d81bfef85e10d4f14720656794bd4224757 (patch)
tree158dd1919921bf635c669e0c8e031187a9610051
parent24e58947d6fba02c3d0ff709213f527411fcec0c (diff)
downloadnextcloud-server-16f29d81bfef85e10d4f14720656794bd4224757.tar.gz
nextcloud-server-16f29d81bfef85e10d4f14720656794bd4224757.zip
Ignore delete groups
Signed-off-by: Daniel Kesselberg <mail@danielkesselberg.de>
-rw-r--r--apps/settings/js/settings.js150
1 files changed, 77 insertions, 73 deletions
diff --git a/apps/settings/js/settings.js b/apps/settings/js/settings.js
index 2c4f9c4c94f..24384ee316b 100644
--- a/apps/settings/js/settings.js
+++ b/apps/settings/js/settings.js
@@ -6,9 +6,9 @@
OC.Settings = OC.Settings || {};
OC.Settings = _.extend(OC.Settings, {
- _cachedGroups: null,
+ _cachedGroups: null,
- /**
+ /**
* Setup selection box for group selection.
*
* Values need to be separated by a pipe "|" character.
@@ -20,77 +20,81 @@ OC.Settings = _.extend(OC.Settings, {
* @param {Array} [options] extra options
* @param {Array} [options.excludeAdmins=false] flag whether to exclude admin groups
*/
- setupGroupsSelect: function($elements, extraOptions, options) {
- var self = this;
- options = options || {};
- if ($elements.length > 0) {
- // Let's load the data and THEN init our select
- $.ajax({
- url: OC.linkToOCS('cloud/groups', 2) + 'details',
- dataType: 'json',
- success: function(data) {
- var results = [];
+ setupGroupsSelect: function($elements, extraOptions, options) {
+ var self = this;
+ options = options || {};
+ if ($elements.length > 0) {
+ // Let's load the data and THEN init our select
+ $.ajax({
+ url: OC.linkToOCS('cloud/groups', 2) + 'details',
+ dataType: 'json',
+ success: function(data) {
+ var results = [];
- if (data.ocs.data.groups && data.ocs.data.groups.length > 0) {
+ if (data.ocs.data.groups && data.ocs.data.groups.length > 0) {
- data.ocs.data.groups.forEach(function(group) {
- if (!options.excludeAdmins || group.id !== 'admin') {
- results.push({ id: group.id, displayname: group.displayname });
- }
- })
+ data.ocs.data.groups.forEach(function(group) {
+ if (!options.excludeAdmins || group.id !== 'admin') {
+ results.push({ id: group.id, displayname: group.displayname });
+ }
+ })
- // note: settings are saved through a "change" event registered
- // on all input fields
- $elements.select2(_.extend({
- placeholder: t('core', 'Groups'),
- allowClear: true,
- multiple: true,
- toggleSelect: true,
- separator: '|',
- data: { results: results, text: 'displayname' },
- initSelection: function(element, callback) {
- var groups = $(element).val();
- var selection;
- if (groups && results.length > 0) {
- selection = _.map((groups || []).split('|').sort(), function(groupId) {
- return {
- id: groupId,
- displayname: results.find(function (group) {
- return group.id === groupId;
- }).displayname
- };
- });
- } else if (groups) {
- selection = _.map((groups || []).split('|').sort(), function(groupId) {
- return {
- id: groupId,
- displayname: groupId
- };
- });
- }
- callback(selection);
- },
- formatResult: function(element) {
- return escapeHTML(element.displayname);
- },
- formatSelection: function(element) {
- return escapeHTML(element.displayname);
- },
- escapeMarkup: function(m) {
- // prevent double markup escape
- return m;
- }
- }, extraOptions || {}));
- } else {
- OC.Notification.show(t('settings', 'Group list is empty'), { type: 'error' });
- console.log(data);
- }
- },
- error: function(data) {
- OC.Notification.show(t('settings', 'Unable to retrieve the group list'), { type: 'error' });
- console.log(data);
- }
- });
- }
- }
-}); \ No newline at end of file
+ // note: settings are saved through a "change" event registered
+ // on all input fields
+ $elements.select2(_.extend({
+ placeholder: t('core', 'Groups'),
+ allowClear: true,
+ multiple: true,
+ toggleSelect: true,
+ separator: '|',
+ data: { results: results, text: 'displayname' },
+ initSelection: function(element, callback) {
+ var groups = $(element).val();
+ var selection;
+ if (groups && results.length > 0) {
+ selection = _.map(_.filter((groups || []).split('|').sort(), function(groupId) {
+ return results.find(function(group) {
+ return group.id === groupId
+ }) !== undefined
+ }), function(groupId) {
+ return {
+ id: groupId,
+ displayname: results.find(function(group) {
+ return group.id === groupId
+ }).displayname
+ }
+ })
+ } else if (groups) {
+ selection = _.map((groups || []).split('|').sort(), function(groupId) {
+ return {
+ id: groupId,
+ displayname: groupId
+ };
+ });
+ }
+ callback(selection);
+ },
+ formatResult: function(element) {
+ return escapeHTML(element.displayname);
+ },
+ formatSelection: function(element) {
+ return escapeHTML(element.displayname);
+ },
+ escapeMarkup: function(m) {
+ // prevent double markup escape
+ return m;
+ }
+ }, extraOptions || {}));
+ } else {
+ OC.Notification.show(t('settings', 'Group list is empty'), { type: 'error' });
+ console.log(data);
+ }
+ },
+ error: function(data) {
+ OC.Notification.show(t('settings', 'Unable to retrieve the group list'), { type: 'error' });
+ console.log(data);
+ }
+ });
+ }
+ }
+});