Merge pull request #10968 from owncloud/admin-groupsselect2
Use select2 for the groups excluded from sharing in admin page
This commit is contained in:
commit
fed8100177
|
@ -25,8 +25,8 @@ OC_Util::checkAdminUser();
|
||||||
OCP\Util::addScript('files_external', 'settings');
|
OCP\Util::addScript('files_external', 'settings');
|
||||||
OCP\Util::addStyle('files_external', 'settings');
|
OCP\Util::addStyle('files_external', 'settings');
|
||||||
|
|
||||||
OCP\Util::addScript('files_external', '../3rdparty/select2/select2');
|
OCP\Util::addScript('core', 'select2/select2');
|
||||||
OCP\Util::addStyle('files_external', '../3rdparty/select2/select2');
|
OCP\Util::addStyle('core', 'select2/select2');
|
||||||
|
|
||||||
$backends = OC_Mount_Config::getBackends();
|
$backends = OC_Mount_Config::getBackends();
|
||||||
$personal_backends = array();
|
$personal_backends = array();
|
||||||
|
|
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB |
Before Width: | Height: | Size: 613 B After Width: | Height: | Size: 613 B |
Before Width: | Height: | Size: 845 B After Width: | Height: | Size: 845 B |
|
@ -140,6 +140,18 @@ input[type="time"] {
|
||||||
-moz-box-sizing: border-box; box-sizing: border-box;
|
-moz-box-sizing: border-box; box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.select2-choices {
|
||||||
|
border: 1px solid #ddd;
|
||||||
|
border-radius: 3px;
|
||||||
|
color: #333;
|
||||||
|
background-image: none;
|
||||||
|
}
|
||||||
|
.select2-dropdown-open .select2-choices {
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
border: 1px solid #3875d7;
|
||||||
|
}
|
||||||
|
|
||||||
/* correctly align images inside of buttons */
|
/* correctly align images inside of buttons */
|
||||||
input img, button img, .button img {
|
input img, button img, .button img {
|
||||||
vertical-align: text-bottom;
|
vertical-align: text-bottom;
|
||||||
|
|
|
@ -7,10 +7,13 @@
|
||||||
|
|
||||||
OC_Util::checkAdminUser();
|
OC_Util::checkAdminUser();
|
||||||
|
|
||||||
OC_Util::addStyle( "settings", "settings" );
|
OCP\Util::addStyle('settings', 'settings');
|
||||||
|
OCP\Util::addScript('settings', 'settings');
|
||||||
OC_Util::addScript( "settings", "admin" );
|
OC_Util::addScript( "settings", "admin" );
|
||||||
OC_Util::addScript( "settings", "log" );
|
OC_Util::addScript( "settings", "log" );
|
||||||
OC_Util::addScript( 'core', 'multiselect' );
|
OC_Util::addScript( 'core', 'multiselect' );
|
||||||
|
OCP\Util::addScript('core', 'select2/select2');
|
||||||
|
OCP\Util::addStyle('core', 'select2/select2');
|
||||||
OC_App::setActiveNavigationEntry( "admin" );
|
OC_App::setActiveNavigationEntry( "admin" );
|
||||||
|
|
||||||
$tmpl = new OC_Template( 'settings', 'admin', 'user');
|
$tmpl = new OC_Template( 'settings', 'admin', 'user');
|
||||||
|
@ -54,22 +57,9 @@ $tmpl->assign('shareExpireAfterNDays', OC_Appconfig::getValue('core', 'shareapi_
|
||||||
$tmpl->assign('shareEnforceExpireDate', OC_Appconfig::getValue('core', 'shareapi_enforce_expire_date', 'no'));
|
$tmpl->assign('shareEnforceExpireDate', OC_Appconfig::getValue('core', 'shareapi_enforce_expire_date', 'no'));
|
||||||
$excludeGroups = OC_Appconfig::getValue('core', 'shareapi_exclude_groups', 'no') === 'yes' ? true : false;
|
$excludeGroups = OC_Appconfig::getValue('core', 'shareapi_exclude_groups', 'no') === 'yes' ? true : false;
|
||||||
$tmpl->assign('shareExcludeGroups', $excludeGroups);
|
$tmpl->assign('shareExcludeGroups', $excludeGroups);
|
||||||
$allGroups = OC_Group::getGroups();
|
|
||||||
$excludedGroupsList = OC_Appconfig::getValue('core', 'shareapi_exclude_groups_list', '');
|
$excludedGroupsList = OC_Appconfig::getValue('core', 'shareapi_exclude_groups_list', '');
|
||||||
$excludedGroups = $excludedGroupsList !== '' ? explode(',', $excludedGroupsList) : array();
|
$excludedGroupsList = explode(',', $excludedGroupsList); // FIXME: this should be JSON!
|
||||||
$groups = array();
|
$tmpl->assign('shareExcludedGroupsList', implode('|', $excludedGroupsList));
|
||||||
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);
|
|
||||||
|
|
||||||
|
|
||||||
// Check if connected using HTTPS
|
// Check if connected using HTTPS
|
||||||
$tmpl->assign('isConnectedViaHTTPS', OC_Request::serverProtocol() === 'https');
|
$tmpl->assign('isConnectedViaHTTPS', OC_Request::serverProtocol() === 'https');
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
<?php
|
|
||||||
OC_JSON::checkAdminUser();
|
|
||||||
OCP\JSON::callCheck();
|
|
||||||
|
|
||||||
$selectedGroups = isset($_POST["selectedGroups"]) ? json_decode($_POST["selectedGroups"]) : array();
|
|
||||||
$changedGroup = isset($_POST["changedGroup"]) ? $_POST["changedGroup"] : '';
|
|
||||||
|
|
||||||
if ($changedGroup !== '') {
|
|
||||||
if(($key = array_search($changedGroup, $selectedGroups)) !== false) {
|
|
||||||
unset($selectedGroups[$key]);
|
|
||||||
} else {
|
|
||||||
$selectedGroups[] = $changedGroup;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
\OCP\Util::writeLog('core', 'Can not update list of excluded groups from sharing, parameter missing', \OCP\Util::WARN);
|
|
||||||
}
|
|
||||||
|
|
||||||
\OC_Appconfig::setValue('core', 'shareapi_exclude_groups_list', implode(',', $selectedGroups));
|
|
|
@ -24,17 +24,17 @@
|
||||||
OC_Util::checkAdminUser();
|
OC_Util::checkAdminUser();
|
||||||
|
|
||||||
// Load the files we need
|
// Load the files we need
|
||||||
OC_Util::addStyle( "settings", "settings" );
|
OCP\Util::addStyle('settings', 'settings' );
|
||||||
OC_Util::addScript("core", "multiselect");
|
OCP\Util::addScript('settings', 'settings');
|
||||||
|
OCP\Util::addScript('core', 'select2/select2');
|
||||||
|
OCP\Util::addStyle('core', 'select2/select2');
|
||||||
OC_App::setActiveNavigationEntry( "core_apps" );
|
OC_App::setActiveNavigationEntry( "core_apps" );
|
||||||
|
|
||||||
$combinedApps = OC_App::listAllApps();
|
$combinedApps = OC_App::listAllApps();
|
||||||
$groups = \OC_Group::getGroups();
|
|
||||||
|
|
||||||
$tmpl = new OC_Template( "settings", "apps", "user" );
|
$tmpl = new OC_Template( "settings", "apps", "user" );
|
||||||
|
|
||||||
$tmpl->assign('apps', $combinedApps);
|
$tmpl->assign('apps', $combinedApps);
|
||||||
$tmpl->assign('groups', $groups);
|
|
||||||
|
|
||||||
$appid = (isset($_GET['appid'])?strip_tags($_GET['appid']):'');
|
$appid = (isset($_GET['appid'])?strip_tags($_GET['appid']):'');
|
||||||
|
|
||||||
|
|
|
@ -1,42 +1,3 @@
|
||||||
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>');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
var label = null;
|
|
||||||
element.multiSelect({
|
|
||||||
createCallback: addGroup,
|
|
||||||
createText: label,
|
|
||||||
selectedFirst: true,
|
|
||||||
checked: checked,
|
|
||||||
oncheck: checkHandeler,
|
|
||||||
onuncheck: checkHandeler,
|
|
||||||
minWidth: 100
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
$(document).ready(function(){
|
$(document).ready(function(){
|
||||||
var params = OC.Util.History.parseUrlQuery();
|
var params = OC.Util.History.parseUrlQuery();
|
||||||
|
|
||||||
|
@ -57,8 +18,17 @@ $(document).ready(function(){
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$('select#excludedGroups[multiple]').each(function (index, element) {
|
$('#excludedGroups').each(function (index, element) {
|
||||||
SharingGroupList.applyMultipleSelect($(element));
|
OC.Settings.setupGroupsSelect($(element));
|
||||||
|
$(element).change(function(ev) {
|
||||||
|
var groups = ev.val || [];
|
||||||
|
if (groups.length > 0) {
|
||||||
|
groups = ev.val.join(','); // FIXME: make this JSON
|
||||||
|
} else {
|
||||||
|
groups = '';
|
||||||
|
}
|
||||||
|
OC.AppConfig.setValue('core', $(this).attr('name'), groups);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
@ -81,7 +51,7 @@ $(document).ready(function(){
|
||||||
$('#shareAPI p:not(#enable)').toggleClass('hidden', !this.checked);
|
$('#shareAPI p:not(#enable)').toggleClass('hidden', !this.checked);
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#shareAPI input').change(function() {
|
$('#shareAPI input:not(#excludedGroups)').change(function() {
|
||||||
if ($(this).attr('type') === 'checkbox') {
|
if ($(this).attr('type') === 'checkbox') {
|
||||||
if (this.checked) {
|
if (this.checked) {
|
||||||
var value = 'yes';
|
var value = 'yes';
|
||||||
|
|
|
@ -7,6 +7,11 @@
|
||||||
|
|
||||||
OC.Settings = OC.Settings || {};
|
OC.Settings = OC.Settings || {};
|
||||||
OC.Settings.Apps = OC.Settings.Apps || {
|
OC.Settings.Apps = OC.Settings.Apps || {
|
||||||
|
setupGroupsSelect: function() {
|
||||||
|
OC.Settings.setupGroupsSelect($('#group_select'), {
|
||||||
|
placeholder: t('core', 'All')
|
||||||
|
});
|
||||||
|
},
|
||||||
loadApp:function(app) {
|
loadApp:function(app) {
|
||||||
var page = $('#app-content');
|
var page = $('#app-content');
|
||||||
page.find('p.license').show();
|
page.find('p.license').show();
|
||||||
|
@ -112,23 +117,16 @@ OC.Settings.Apps = OC.Settings.Apps || {
|
||||||
page.find(".warning").hide();
|
page.find(".warning").hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
page.find("div.multiselect").parent().remove();
|
|
||||||
if(OC.Settings.Apps.isType(app, 'filesystem') || OC.Settings.Apps.isType(app, 'prelogin') ||
|
if(OC.Settings.Apps.isType(app, 'filesystem') || OC.Settings.Apps.isType(app, 'prelogin') ||
|
||||||
OC.Settings.Apps.isType(app, 'authentication') || OC.Settings.Apps.isType(app, 'logging')) {
|
OC.Settings.Apps.isType(app, 'authentication') || OC.Settings.Apps.isType(app, 'logging')) {
|
||||||
page.find("#groups_enable").hide();
|
page.find("#groups_enable").hide();
|
||||||
page.find("label[for='groups_enable']").hide();
|
page.find("label[for='groups_enable']").hide();
|
||||||
page.find("#groups_enable").attr('checked', null);
|
page.find("#groups_enable").attr('checked', null);
|
||||||
} else {
|
} else {
|
||||||
$('#group_select > option').each(function (i, el) {
|
|
||||||
if (app.groups.length === 0 || app.groups.indexOf(el.value) >= 0) {
|
|
||||||
$(el).attr('selected', 'selected');
|
|
||||||
} else {
|
|
||||||
$(el).attr('selected', null);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (app.active) {
|
if (app.active) {
|
||||||
if (app.groups.length) {
|
if (app.groups.length) {
|
||||||
$('#group_select').multiSelect();
|
OC.Settings.Apps.setupGroupsSelect();
|
||||||
|
$('#group_select').select2('val', app.groups || []);
|
||||||
page.find("#groups_enable").attr('checked','checked');
|
page.find("#groups_enable").attr('checked','checked');
|
||||||
} else {
|
} else {
|
||||||
page.find("#groups_enable").attr('checked', null);
|
page.find("#groups_enable").attr('checked', null);
|
||||||
|
@ -380,9 +378,10 @@ $(document).ready(function(){
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#group_select').change(function() {
|
$('#group_select').change(function(ev) {
|
||||||
var element = $('#app-content input.enable');
|
var element = $('#app-content input.enable');
|
||||||
var groups = $(this).val();
|
// getting an array of values from select2
|
||||||
|
var groups = ev.val || [];
|
||||||
var appid = element.data('appid');
|
var appid = element.data('appid');
|
||||||
if (appid) {
|
if (appid) {
|
||||||
OC.Settings.Apps.enableApp(appid, false, element, groups);
|
OC.Settings.Apps.enableApp(appid, false, element, groups);
|
||||||
|
@ -404,14 +403,14 @@ $(document).ready(function(){
|
||||||
}
|
}
|
||||||
|
|
||||||
$("#groups_enable").change(function() {
|
$("#groups_enable").change(function() {
|
||||||
|
var $select = $('#group_select');
|
||||||
|
$select.val('');
|
||||||
if (this.checked) {
|
if (this.checked) {
|
||||||
$("div.multiselect").parent().remove();
|
OC.Settings.Apps.setupGroupsSelect();
|
||||||
$('#group_select').multiSelect();
|
|
||||||
} else {
|
|
||||||
$('#group_select').hide().val(null);
|
|
||||||
$("div.multiselect").parent().remove();
|
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
$('#group_select').change();
|
$select.select2('destroy');
|
||||||
|
}
|
||||||
|
$select.change();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -0,0 +1,98 @@
|
||||||
|
/**
|
||||||
|
* Copyright (c) 2014, Vincent Petry <pvince81@owncloud.com>
|
||||||
|
* This file is licensed under the Affero General Public License version 3 or later.
|
||||||
|
* See the COPYING-README file.
|
||||||
|
*/
|
||||||
|
OC.Settings = OC.Settings || {};
|
||||||
|
OC.Settings = _.extend(OC.Settings, {
|
||||||
|
|
||||||
|
_cachedGroups: null,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup selection box for group selection.
|
||||||
|
*
|
||||||
|
* Values need to be separated by a pipe "|" character.
|
||||||
|
* (mostly because a comma is more likely to be used
|
||||||
|
* for groups)
|
||||||
|
*
|
||||||
|
* @param $elements jQuery element (hidden input) to setup select2 on
|
||||||
|
* @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
|
||||||
|
$elements.select2(_.extend({
|
||||||
|
placeholder: t('core', 'Groups'),
|
||||||
|
allowClear: true,
|
||||||
|
multiple: true,
|
||||||
|
separator: '|',
|
||||||
|
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
|
||||||
|
};
|
||||||
|
}
|
||||||
|
$.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});
|
||||||
|
});
|
||||||
|
|
||||||
|
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;
|
||||||
|
},
|
||||||
|
initSelection: function(element, callback) {
|
||||||
|
var selection =
|
||||||
|
_.map(($(element).val() || []).split('|').sort(),
|
||||||
|
function(groupName) {
|
||||||
|
return {
|
||||||
|
id: groupName,
|
||||||
|
displayname: groupName
|
||||||
|
};
|
||||||
|
});
|
||||||
|
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 || {}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
|
@ -317,14 +317,7 @@ if ($_['suggestedOverwriteWebroot']) {
|
||||||
<label for="shareapiExcludeGroups"><?php p($l->t('Exclude groups from sharing'));?></label><br/>
|
<label for="shareapiExcludeGroups"><?php p($l->t('Exclude groups from sharing'));?></label><br/>
|
||||||
</p>
|
</p>
|
||||||
<p id="selectExcludedGroups" class="indent <?php if (!$_['shareExcludeGroups'] || $_['shareAPIEnabled'] === 'no') p('hidden'); ?>">
|
<p id="selectExcludedGroups" class="indent <?php if (!$_['shareExcludeGroups'] || $_['shareAPIEnabled'] === 'no') p('hidden'); ?>">
|
||||||
<select
|
<input name="shareapi_exclude_groups_list" type="hidden" id="excludedGroups" value="<?php p($_['shareExcludedGroupsList']) ?>" style="width: 400px"/>
|
||||||
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>
|
|
||||||
<br />
|
<br />
|
||||||
<em><?php p($l->t('These groups will still be able to receive shares, but not to initiate them.')); ?></em>
|
<em><?php p($l->t('These groups will still be able to receive shares, but not to initiate them.')); ?></em>
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -58,11 +58,7 @@
|
||||||
<input class="hidden" type="checkbox" id="groups_enable"/>
|
<input class="hidden" type="checkbox" id="groups_enable"/>
|
||||||
<label class="hidden" for="groups_enable"><?php p($l->t('Enable only for specific groups')); ?></label>
|
<label class="hidden" for="groups_enable"><?php p($l->t('Enable only for specific groups')); ?></label>
|
||||||
<br />
|
<br />
|
||||||
<select class="hidden" id="group_select" multiple="multiple" title="<?php p($l->t('All')); ?>">
|
<input type="hidden" id="group_select" title="<?php p($l->t('All')); ?>" style="width: 200px">
|
||||||
<?php foreach($_['groups'] as $group):?>
|
|
||||||
<option value="<?php p($group);?>"><?php p($group); ?></option>
|
|
||||||
<?php endforeach;?>
|
|
||||||
</select>
|
|
||||||
|
|
||||||
<div class="warning hidden"></div>
|
<div class="warning hidden"></div>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in New Issue