summaryrefslogtreecommitdiffstats
path: root/install/static/sudorule.js
diff options
context:
space:
mode:
authorEndi S. Dewata <edewata@redhat.com>2011-01-11 09:51:09 +0700
committerAdam Young <ayoung@redhat.com>2011-01-11 21:33:35 -0500
commit409b6efa5f0d4149fb26513dd25259b9d0026840 (patch)
tree78eeb4cfc0c138ae4547656130554804e19511b8 /install/static/sudorule.js
parente79406a0f956dc827beb176d9a25d8b983f1fd23 (diff)
downloadfreeipa-409b6efa5f0d4149fb26513dd25259b9d0026840.tar.gz
freeipa-409b6efa5f0d4149fb26513dd25259b9d0026840.tar.xz
freeipa-409b6efa5f0d4149fb26513dd25259b9d0026840.zip
Support for enabling/disabling table widget.
The table widget now can be enabled/disabled. When disabled, the checkboxes and links/buttons are grayed out and non functional. The radio buttons in HBAC and SUDO details page have been modified to enable/disable the corresponding tables.
Diffstat (limited to 'install/static/sudorule.js')
-rwxr-xr-xinstall/static/sudorule.js92
1 files changed, 90 insertions, 2 deletions
diff --git a/install/static/sudorule.js b/install/static/sudorule.js
index 04fe277e4..865abe383 100755
--- a/install/static/sudorule.js
+++ b/install/static/sudorule.js
@@ -633,6 +633,38 @@ function ipa_sudorule_details_command_section(spec){
field.create(table_span);
};
+ that.setup = function(container) {
+
+ that.section_setup(container);
+
+ function update_tables(value) {
+
+ var enabled = '' == value;
+
+ var field = that.get_field('memberallowcmd_sudocmd');
+ field.set_enabled(enabled);
+
+ field = that.get_field('memberallowcmd_sudocmdgroup');
+ field.set_enabled(enabled);
+ }
+
+ var cmdcategory = that.get_field('cmdcategory');
+ cmdcategory.reset = function() {
+ cmdcategory.widget_reset();
+ var values = cmdcategory.save();
+ if (values.length == 0) return;
+ var value = values[0];
+ update_tables(value);
+ };
+
+ var inputs = $('input[name=cmdcategory]', container);
+ inputs.change(function() {
+ var input = $(this);
+ var value = input.val();
+ update_tables(value);
+ });
+ };
+
return that;
}
@@ -769,6 +801,62 @@ function ipa_sudorule_details_runas_section(spec){
field.create(table_span);
};
+ that.setup = function(container) {
+
+ that.section_setup(container);
+
+ function user_update_tables(value) {
+
+ var enabled = '' == value;
+
+ var field = that.get_field('ipasudorunas_user');
+ field.set_enabled(enabled);
+
+ field = that.get_field('ipasudorunas_group');
+ field.set_enabled(enabled);
+ }
+
+ var user_category = that.get_field('ipasudorunasusercategory');
+ user_category.reset = function() {
+ user_category.widget_reset();
+ var values = user_category.save();
+ if (values.length == 0) return;
+ var value = values[0];
+ user_update_tables(value);
+ };
+
+ var user_inputs = $('input[name=ipasudorunasusercategory]', container);
+ user_inputs.change(function() {
+ var input = $(this);
+ var value = input.val();
+ user_update_tables(value);
+ });
+
+ function group_update_tables(value) {
+
+ var enabled = '' == value;
+
+ var field = that.get_field('ipasudorunasgroup_group');
+ field.set_enabled(enabled);
+ }
+
+ var group_category = that.get_field('ipasudorunasgroupcategory');
+ group_category.reset = function() {
+ group_category.widget_reset();
+ var values = group_category.save();
+ if (values.length == 0) return;
+ var value = values[0];
+ group_update_tables(value);
+ };
+
+ var group_inputs = $('input[name=ipasudorunasgroupcategory]', container);
+ group_inputs.change(function() {
+ var input = $(this);
+ var value = input.val();
+ group_update_tables(value);
+ });
+ };
+
return that;
}
@@ -985,7 +1073,7 @@ function ipa_sudorule_command_table_widget(spec) {
var command;
- if (that.category && that.category.save() == 'all') {
+ if (that.category) {
command = ipa_command({
'method': that.entity_name+'_mod',
'args': [pkey],
@@ -993,7 +1081,7 @@ function ipa_sudorule_command_table_widget(spec) {
'on_success': function() {
var record = {};
record[that.category.name] = [''];
- that.category.load(['']);
+ that.category.load(record);
}
});
command.set_option(that.category.name, '');