summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2014-09-09 18:00:53 +0200
committerVincent Petry <pvince81@owncloud.com>2014-09-22 10:14:15 +0200
commit996c68aa2eeb8f861413083d51f692853b4d5ca4 (patch)
treed517eab55f36669f46bf945ab18a3148068ebd2a
parent7f030eedde528b48f52cab155e1247b01f78b014 (diff)
downloadnextcloud-server-996c68aa2eeb8f861413083d51f692853b4d5ca4.tar.gz
nextcloud-server-996c68aa2eeb8f861413083d51f692853b4d5ca4.zip
Added select2 on the apps page
Moved setupGroupsSelect() from admin.js to a common settings.js as OC.Settings.setupGoupsSelect(). Now using select2 as well on the apps page.
-rwxr-xr-xsettings/admin.php3
-rw-r--r--settings/apps.php8
-rw-r--r--settings/js/admin.js63
-rw-r--r--settings/js/apps.js35
-rw-r--r--settings/js/settings.js72
-rw-r--r--settings/templates/apps.php6
6 files changed, 99 insertions, 88 deletions
diff --git a/settings/admin.php b/settings/admin.php
index 3b42aa8a5a8..771af7aa720 100755
--- a/settings/admin.php
+++ b/settings/admin.php
@@ -7,7 +7,8 @@
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", "log" );
OC_Util::addScript( 'core', 'multiselect' );
diff --git a/settings/apps.php b/settings/apps.php
index 7573c8b573f..6021574cbb3 100644
--- a/settings/apps.php
+++ b/settings/apps.php
@@ -24,17 +24,17 @@
OC_Util::checkAdminUser();
// Load the files we need
-OC_Util::addStyle( "settings", "settings" );
-OC_Util::addScript("core", "multiselect");
+OCP\Util::addStyle('settings', 'settings' );
+OCP\Util::addScript('settings', 'settings');
+OCP\Util::addScript('core', 'select2/select2');
+OCP\Util::addStyle('core', 'select2/select2');
OC_App::setActiveNavigationEntry( "core_apps" );
$combinedApps = OC_App::listAllApps();
-$groups = \OC_Group::getGroups();
$tmpl = new OC_Template( "settings", "apps", "user" );
$tmpl->assign('apps', $combinedApps);
-$tmpl->assign('groups', $groups);
$appid = (isset($_GET['appid'])?strip_tags($_GET['appid']):'');
diff --git a/settings/js/admin.js b/settings/js/admin.js
index d38c770a28a..943bf78e024 100644
--- a/settings/js/admin.js
+++ b/settings/js/admin.js
@@ -1,64 +1,3 @@
-var SharingGroupList = {
- 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
- }
- }
- },
- 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;
- }
- });
- }
- }
-};
-
$(document).ready(function(){
var params = OC.Util.History.parseUrlQuery();
@@ -80,7 +19,7 @@ $(document).ready(function(){
$('#excludedGroups').each(function (index, element) {
- SharingGroupList.setupGroupsSelect($(element));
+ OC.Settings.setupGroupsSelect($(element));
});
diff --git a/settings/js/apps.js b/settings/js/apps.js
index 877ad78cfe4..aafbdaf958a 100644
--- a/settings/js/apps.js
+++ b/settings/js/apps.js
@@ -7,6 +7,11 @@
OC.Settings = OC.Settings || {};
OC.Settings.Apps = OC.Settings.Apps || {
+ setupGroupsSelect: function() {
+ OC.Settings.setupGroupsSelect($('#group_select'), {
+ placeholder: t('core', 'All')
+ });
+ },
loadApp:function(app) {
var page = $('#app-content');
page.find('p.license').show();
@@ -112,23 +117,16 @@ OC.Settings.Apps = OC.Settings.Apps || {
page.find(".warning").hide();
}
- page.find("div.multiselect").parent().remove();
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')) {
page.find("#groups_enable").hide();
page.find("label[for='groups_enable']").hide();
page.find("#groups_enable").attr('checked', null);
} 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);
- }
- });
+ $('#group_select').val((app.groups || []).join(','));
if (app.active) {
if (app.groups.length) {
- $('#group_select').multiSelect();
+ OC.Settings.Apps.setupGroupsSelect();
page.find("#groups_enable").attr('checked','checked');
} else {
page.find("#groups_enable").attr('checked', null);
@@ -382,6 +380,11 @@ $(document).ready(function(){
$('#group_select').change(function() {
var element = $('#app-content input.enable');
var groups = $(this).val();
+ if (groups && groups !== '') {
+ groups = groups.split(',');
+ } else {
+ groups = [];
+ }
var appid = element.data('appid');
if (appid) {
OC.Settings.Apps.enableApp(appid, false, element, groups);
@@ -403,14 +406,14 @@ $(document).ready(function(){
}
$("#groups_enable").change(function() {
+ var $select = $('#group_select');
+ $select.val('');
if (this.checked) {
- $("div.multiselect").parent().remove();
- $('#group_select').multiSelect();
- } else {
- $('#group_select').hide().val(null);
- $("div.multiselect").parent().remove();
+ OC.Settings.Apps.setupGroupsSelect();
}
-
- $('#group_select').change();
+ else {
+ $select.select2('destroy');
+ }
+ $select.change();
});
});
diff --git a/settings/js/settings.js b/settings/js/settings.js
new file mode 100644
index 00000000000..85e8996ae7f
--- /dev/null
+++ b/settings/js/settings.js
@@ -0,0 +1,72 @@
+/**
+ * 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, {
+ /**
+ * Setup selection box for group selection.
+ * @param $elements jQuery element (hidden input) to setup select2 on
+ * @param [extraOptions] extra options hash to pass to select2
+ */
+ setupGroupsSelect: function($elements, extraOptions) {
+ 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,
+ 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
+ }
+ }
+ },
+ 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;
+ }
+ }, extraOptions || {}));
+ }
+ }
+});
+
diff --git a/settings/templates/apps.php b/settings/templates/apps.php
index 29fda0ed243..5199d3fd7c7 100644
--- a/settings/templates/apps.php
+++ b/settings/templates/apps.php
@@ -58,11 +58,7 @@
<input class="hidden" type="checkbox" id="groups_enable"/>
<label class="hidden" for="groups_enable"><?php p($l->t('Enable only for specific groups')); ?></label>
<br />
- <select class="hidden" id="group_select" multiple="multiple" title="<?php p($l->t('All')); ?>">
- <?php foreach($_['groups'] as $group):?>
- <option value="<?php p($group);?>"><?php p($group); ?></option>
- <?php endforeach;?>
- </select>
+ <input type="hidden" id="group_select" title="<?php p($l->t('All')); ?>" style="width: 200px">
<div class="warning hidden"></div>
</div>