diff options
author | Morris Jobke <hey@morrisjobke.de> | 2020-05-04 10:02:32 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-04 10:02:32 +0200 |
commit | 6aceb39714a0f776052cb2be5b453eb7ddd44382 (patch) | |
tree | abffe3e0424e1a2018856a87bfca75c59bc0b1c2 | |
parent | afc59665582dbd83c4c25cab21a5b30b79cac676 (diff) | |
parent | 16f29d81bfef85e10d4f14720656794bd4224757 (diff) | |
download | nextcloud-server-6aceb39714a0f776052cb2be5b453eb7ddd44382.tar.gz nextcloud-server-6aceb39714a0f776052cb2be5b453eb7ddd44382.zip |
Merge pull request #19124 from nextcloud/bug/13647/ignore-delete-groups
Exclude groups from sharing: Skip delete groups
-rw-r--r-- | apps/settings/js/settings.js | 150 |
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); + } + }); + } + } +}); |