summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2014-09-11 11:12:44 +0200
committerVincent Petry <pvince81@owncloud.com>2014-09-22 10:14:25 +0200
commitc16c680e3218cde36ddb7cc46508c92d35241a8e (patch)
tree48bc07e808e50cb75b852dc5aa8860c2a8768404
parent13cee302f7faee5b5576b192d0fcbab609a8635e (diff)
downloadnextcloud-server-c16c680e3218cde36ddb7cc46508c92d35241a8e.tar.gz
nextcloud-server-c16c680e3218cde36ddb7cc46508c92d35241a8e.zip
Add select2 cache for complete group list
To avoid making a server request every time the dropdown opens, the whole list of groups are cached (from the last request): Whenever the user types in a search term it will still send server requests.
-rw-r--r--settings/js/settings.js62
1 files changed, 39 insertions, 23 deletions
diff --git a/settings/js/settings.js b/settings/js/settings.js
index 6e44c473185..13c56a8f53a 100644
--- a/settings/js/settings.js
+++ b/settings/js/settings.js
@@ -5,6 +5,9 @@
*/
OC.Settings = OC.Settings || {};
OC.Settings = _.extend(OC.Settings, {
+
+ _cachedGroups: null,
+
/**
* Setup selection box for group selection.
*
@@ -16,6 +19,7 @@ OC.Settings = _.extend(OC.Settings, {
* @param [extraOptions] extra options hash to pass to select2
*/
setupGroupsSelect: function($elements, extraOptions) {
+ var self = this;
if ($elements.length > 0) {
// note: settings are saved through a "change" event registered
// on all input fields
@@ -24,33 +28,45 @@ OC.Settings = _.extend(OC.Settings, {
allowClear: true,
multiple: true,
separator: '|',
- ajax: {
- url: OC.generateUrl('/settings/ajax/grouplist'),
- dataType: 'json',
- quietMillis: 100,
- data: function (term) {
- return {
- pattern: term, //search term
+ query: _.debounce(function(query) {
+ var queryData = {};
+ if (self._cachedGroups && query.term === '') {
+ query.callback({results: self._cachedGroups});
+ return;
+ }
+ if (query.term !== '') {
+ queryData = {
+ pattern: query.term,
+ filterGroups: 1
};
- },
- results: function (data) {
- if (data.status === "success") {
- var results = [];
+ }
+ $.ajax({
+ url: OC.generateUrl('/settings/ajax/grouplist'),
+ data: queryData,
+ dataType: 'json',
+ success: function(data) {
+ if (data.status === "success") {
+ var results = [];
- // add groups
- $.each(data.data.adminGroups, function(i, group) {
- results.push({id:group.id, displayname:group.name});
- });
- $.each(data.data.groups, function(i, group) {
- results.push({id:group.id, displayname:group.name});
- });
+ // add groups
+ $.each(data.data.adminGroups, function(i, group) {
+ results.push({id:group.id, displayname:group.name});
+ });
+ $.each(data.data.groups, function(i, group) {
+ results.push({id:group.id, displayname:group.name});
+ });
- return {results: results};
- } else {
- //FIXME add error handling
+ if (query.term === '') {
+ // cache full list
+ self._cachedGroups = results;
+ }
+ query.callback({results: results});
+ } else {
+ //FIXME add error handling
+ }
}
- }
- },
+ });
+ }, 100, true),
id: function(element) {
return element.id;
},