summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2014-09-09 17:06:50 +0200
committerVincent Petry <pvince81@owncloud.com>2014-09-09 18:03:05 +0200
commitd23621536c23f89785f6beea13cdc53ec2b9392f (patch)
tree29cde309ce00e235f635f90156dd0eb2a5a3341b
parent412da87e6583375f98ef1bdd755c56caab14b8ac (diff)
downloadnextcloud-server-d23621536c23f89785f6beea13cdc53ec2b9392f.tar.gz
nextcloud-server-d23621536c23f89785f6beea13cdc53ec2b9392f.zip
Now using select2 for the groups excluded from sharing
-rwxr-xr-xsettings/admin.php16
-rw-r--r--settings/js/admin.js90
-rw-r--r--settings/templates/admin.php9
3 files changed, 58 insertions, 57 deletions
diff --git a/settings/admin.php b/settings/admin.php
index 65deed6b883..b4064c3345e 100755
--- a/settings/admin.php
+++ b/settings/admin.php
@@ -54,22 +54,8 @@ $tmpl->assign('shareExpireAfterNDays', OC_Appconfig::getValue('core', 'shareapi_
$tmpl->assign('shareEnforceExpireDate', OC_Appconfig::getValue('core', 'shareapi_enforce_expire_date', 'no'));
$excludeGroups = OC_Appconfig::getValue('core', 'shareapi_exclude_groups', 'no') === 'yes' ? true : false;
$tmpl->assign('shareExcludeGroups', $excludeGroups);
-$allGroups = OC_Group::getGroups();
$excludedGroupsList = OC_Appconfig::getValue('core', 'shareapi_exclude_groups_list', '');
-$excludedGroups = $excludedGroupsList !== '' ? explode(',', $excludedGroupsList) : array();
-$groups = array();
-foreach ($allGroups as $group) {
- if (in_array($group, $excludedGroups)) {
- $groups[$group] = array('gid' => $group,
- 'excluded' => true);
- } else {
- $groups[$group] = array('gid' => $group,
- 'excluded' => false);
- }
-}
-ksort($groups);
-$tmpl->assign('groups', $groups);
-
+$tmpl->assign('shareExcludedGroupsList', $excludedGroupsList);
// Check if connected using HTTPS
$tmpl->assign('isConnectedViaHTTPS', OC_Request::serverProtocol() === 'https');
diff --git a/settings/js/admin.js b/settings/js/admin.js
index 56dc1b98716..d38c770a28a 100644
--- a/settings/js/admin.js
+++ b/settings/js/admin.js
@@ -1,38 +1,60 @@
var SharingGroupList = {
- applyMultipleSelect: function(element) {
- var checked = [];
- if ($(element).hasClass('groupsselect')) {
- if (element.data('userGroups')) {
- checked = element.data('userGroups');
- }
- var checkHandeler = function(group) {
- $.post(OC.filePath('settings', 'ajax', 'excludegroups.php'),
- {changedGroup: group, selectedGroups: JSON.stringify(checked)},
- function() {});
- };
-
-
- var addGroup = function(select, group) {
- $(this).each(function(index, element) {
- if ($(element).find('option[value="' + group + '"]').length === 0 &&
- select.data('msid') !== $(element).data('msid')) {
- $(element).append('<option value="' + escapeHTML(group) + '">' +
- escapeHTML(group) + '</option>');
+ setupGroupsSelect: function($elements) {
+ if ($elements.length > 0) {
+ // note: settings are saved through a "change" event registered
+ // on all input fields
+ $elements.select2({
+ placeholder: t('core', 'Groups'),
+ allowClear: true,
+ multiple: true,
+ ajax: {
+ url: OC.generateUrl('/settings/ajax/grouplist'),
+ dataType: 'json',
+ quietMillis: 100,
+ data: function (term) {
+ return {
+ pattern: term, //search term
+ };
+ },
+ results: 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});
+ });
+
+ return {results: results};
+ } else {
+ //FIXME add error handling
+ }
}
- });
- };
-
- var label = null;
- element.multiSelect({
- createCallback: addGroup,
- createText: label,
- selectedFirst: true,
- checked: checked,
- oncheck: checkHandeler,
- onuncheck: checkHandeler,
- minWidth: 100
+ },
+ id: function(element) {
+ return element.id;
+ },
+ initSelection: function(element, callback) {
+ var selection =
+ _.map(($(element).val() || []).split(',').sort(),
+ function(groupName) {
+ return {
+ id: groupName,
+ displayname: groupName
+ };
+ });
+ callback(selection);
+ },
+ formatResult: function (element) {
+ return element.displayname;
+ },
+ formatSelection: function (element) {
+ return element.displayname;
+ }
});
-
}
}
};
@@ -57,8 +79,8 @@ $(document).ready(function(){
}
- $('select#excludedGroups[multiple]').each(function (index, element) {
- SharingGroupList.applyMultipleSelect($(element));
+ $('#excludedGroups').each(function (index, element) {
+ SharingGroupList.setupGroupsSelect($(element));
});
diff --git a/settings/templates/admin.php b/settings/templates/admin.php
index 0e6cb14bcef..9ceebad4ee1 100644
--- a/settings/templates/admin.php
+++ b/settings/templates/admin.php
@@ -317,14 +317,7 @@ if ($_['suggestedOverwriteWebroot']) {
<label for="shareapiExcludeGroups"><?php p($l->t('Exclude groups from sharing'));?></label><br/>
</p>
<p id="selectExcludedGroups" class="indent <?php if (!$_['shareExcludeGroups'] || $_['shareAPIEnabled'] === 'no') p('hidden'); ?>">
- <select
- class="groupsselect"
- id="excludedGroups" data-placeholder="groups"
- title="<?php p($l->t('Groups'))?>" multiple="multiple">
- <?php foreach($_["groups"] as $group): ?>
- <option value="<?php p($group['gid'])?>" <?php if($group['excluded']) { p('selected="selected"'); }?>><?php p($group['gid']);?></option>
- <?php endforeach;?>
- </select>
+ <input name="shareapi_exclude_groups_list" type="hidden" id="excludedGroups" value="<?php p($_['shareExcludedGroupsList']) ?>" style="width: 400px"/>
<br />
<em><?php p($l->t('These groups will still be able to receive shares, but not to initiate them.')); ?></em>
</p>