From b96138ba56d33fb3b84d992a731d797c2c8492be Mon Sep 17 00:00:00 2001 From: "Endi S. Dewata" Date: Fri, 28 Jan 2011 09:36:25 -0600 Subject: Fixed delegation UI issues This patch fixes several issues in delegation UI: When adding a new delegation, only the first attribute selected was saved. Now all attributes will be saved properly. When loading the details page, the custom widgets did not store the original values properly so is_dirty() did not work correctly. Now this has been fixed except for the memberof attribute because of these issues: - https://fedorahosted.org/freeipa/ticket/869 - https://fedorahosted.org/freeipa/ticket/870 When saving the details page, the attrs were saved as an array which was rejected by the server. Now it is stored as comma- separated list. --- install/ui/aci.js | 53 ++++++++++++++++++++++++----------------------------- 1 file changed, 24 insertions(+), 29 deletions(-) (limited to 'install/ui/aci.js') diff --git a/install/ui/aci.js b/install/ui/aci.js index 742a52c7..92440dfa 100644 --- a/install/ui/aci.js +++ b/install/ui/aci.js @@ -81,35 +81,27 @@ IPA.attribute_table_widget= function (spec){ }; that.save = function(){ - var attrs_boxes = $('table#'+id+" td :checked"); - if (!attrs_boxes.length){ - return []; - } - var retval = ""; - for (var i = 0; i < attrs_boxes.length; i += 1){ - if (i > 0){ - retval += ','; - } - retval += attrs_boxes[i].id.substring("aciattr-".length); + var values = []; + + var attrs_boxes = $('table#'+id+" td :checked"); + + for (var i = 0; i < attrs_boxes.length; i += 1) { + var value = attrs_boxes[i].id.substring("aciattr-".length); + values.push(value); } - return [retval]; + return values; }; - var attrs = []; that.reset =function(){ $('input[type=checkbox]', table).attr('checked',''); - for (var i = 0; i < attrs.length; i+=1){ - $(attrs[i], table).attr('checked','checked'); + for (var i = 0; i < that.values.length; i+=1){ + $('#aciattr-'+that.values[i], table).attr('checked','checked'); } }; that.load = function(record){ - if (!record.attrs) return; - attrs = []; - for (var i = 0; i < record.attrs.length; i+=1){ - attrs.push('#aciattr-' +record.attrs[i]); - } + that.values = record[that.name] || []; that.reset(); }; @@ -122,7 +114,6 @@ IPA.entity_select_widget = function(spec){ var entity = spec.entity || 'group'; function populate_select(value){ - var selected = value; function find_success(result){ $('option', that.entity_select).remove(); var entities = result.result.result; @@ -132,7 +123,7 @@ IPA.entity_select_widget = function(spec){ text:entities[i].cn[0], value:entities[i].cn[0] })); - if (selected === entities[i].cn[0]){ + if (value === entities[i].cn[0]){ option.attr('selected','selected'); } } @@ -180,14 +171,18 @@ IPA.entity_select_widget = function(spec){ }).appendTo(dd); populate_select(); }; - var value = ''; that.reset = function(){ - that.entity_filter.val(value ); - populate_select(value); + that.entity_filter.val(that.values[0]); + populate_select(that.values[0]); }; that.load = function(record){ - value = record[that.name]; + var value = record[that.name]; + if (value instanceof Array) { + that.values = value; + } else { + that.values = value ? [value] : ['']; + } that.reset(); }; @@ -735,13 +730,13 @@ IPA.entity_factories.delegation = function() { custom_input(IPA.entity_select_widget( {name:'group', entity:'group'})). custom_input(IPA.entity_select_widget( - {name:'memberof', entity:'group'})). + {name:'memberof', entity:'group', join: true})). custom_input( IPA.rights_widget({ id:'delegation_rights'})). custom_input( IPA.attribute_table_widget({ - name:'attrs'})))). + name:'attrs', join: true})))). add_dialog(IPA.add_dialog({ name: 'add', title: 'Add Delegation' @@ -750,8 +745,8 @@ IPA.entity_factories.delegation = function() { field(IPA.entity_select_widget({name:'group', entity:'group'})). field(IPA.entity_select_widget({name:'memberof', - entity:'group'})). - field(IPA.attribute_table_widget({ name: 'attrs'}))). + entity:'group', join: true})). + field(IPA.attribute_table_widget({ name: 'attrs', join: true}))). standard_associations(); return that; -- cgit