diff options
author | Adam Young <ayoung@redhat.com> | 2010-10-22 16:23:02 -0400 |
---|---|---|
committer | Adam Young <ayoung@redhat.com> | 2010-10-22 19:51:54 -0400 |
commit | ae76022df5b300bd43af76e879f87b2c3731ec43 (patch) | |
tree | 4a5e41b5b0824cd1aa24ace780db2b80d61cb6c0 /install/static/details.js | |
parent | 9018b601cdf5b1eb124d79ded0baaf8c77ebcae9 (diff) | |
download | freeipa-ae76022df5b300bd43af76e879f87b2c3731ec43.tar.gz freeipa-ae76022df5b300bd43af76e879f87b2c3731ec43.tar.xz freeipa-ae76022df5b300bd43af76e879f87b2c3731ec43.zip |
Multivalue fixes
Strikethrough is now a toggle
undo resets value to blank for new entries.
Diffstat (limited to 'install/static/details.js')
-rw-r--r-- | install/static/details.js | 45 |
1 files changed, 32 insertions, 13 deletions
diff --git a/install/static/details.js b/install/static/details.js index cb4aab111..312ad950f 100644 --- a/install/static/details.js +++ b/install/static/details.js @@ -118,7 +118,7 @@ function ipa_stanza(spec){ var input = $('input', $(this)); if (!input.length) return; - if (input.is('strikethrough')) return; + if (input.is('.strikethrough')) return; var value = $.trim(input.val()); if (!value) value = ''; @@ -299,8 +299,13 @@ function ipa_details_update(container, pkey, on_win, on_fail) var param_info = ipa_get_param_info(obj_name, field.name); if (param_info) { if (param_info['primary_key']) continue; - if (values.length === 1) modlist[field.name] = values[0]; - if (values.length > 1) modlist[field.name] = values; + if (values.length === 1) { + modlist[field.name] = values[0]; + }else if (values.length > 1){ + modlist[field.name] = values; + } else if (param_info['multivalue']){ + modlist[field.name] = []; + } } else { if (values.length) attrs_wo_option[field.name] = values; } @@ -436,9 +441,6 @@ function ipa_create_input(obj_name, attr, value,hint) return input; } -/* HTML template for _ipa_create_remove_link() */ -var _ipa_a_remove_template = - '<a href="jslink" onclick="return (_ipa_remove_on_click(this))" title="A">Remove</a>'; /* creates a Remove link for deleting attribute values */ function _ipa_create_remove_link(attr, param_info) @@ -451,7 +453,12 @@ function _ipa_create_remove_link(attr, param_info) if ((param_info['required']) || (param_info['class'] == 'Password')) return (''); - return (_ipa_a_remove_template.replace('A', attr)); + return $('<a/>',{ + href:"jslink", + click: function (){return (_ipa_remove_on_click(this))}, + title: attr, + text: 'Remove'}); + } @@ -464,7 +471,7 @@ function _ipa_create_text_input(attr, value, param_info) var dd = jobj.parents('dd').slice(0, 1)[0]; dd = dd.previousElementSibling; - while(dd.nodeName === 'dd'){ + while(dd.nodeName.toUpperCase() === 'DD'){ dd = dd.previousElementSibling; index += 1; if (index > 100 ) @@ -500,10 +507,10 @@ function _ipa_create_text_input(attr, value, param_info) index = calculate_dd_index($(this)); var previous_value = entry_attrs[key] || ""; - if (previous_value.length >= index){ - previous_value= previous_value[index]; - }else{ + if (index >= previous_value.length){ previous_value = ''; + }else{ + previous_value= previous_value[index]; } this.previousElementSibling.value = previous_value; @@ -537,7 +544,10 @@ function _ipa_add_on_click(obj) var par = jobj.parent(); var obj_name = jobj.closest('.details-container').attr('title'); - par.prepend(ipa_create_input(obj_name, attr, '')); + var param_info = ipa_get_param_info(obj_name, ''); + var input = _ipa_create_text_input(attr, '', param_info); + + par.prepend(input); jobj.next('input').focus(); jobj.remove(); par.after( ipa_create_other_dd(attr,_ipa_a_add_template.replace('A', attr))); @@ -545,6 +555,9 @@ function _ipa_add_on_click(obj) return (false); } + + + function _ipa_remove_on_click(obj) { var jobj = $(obj); @@ -552,8 +565,14 @@ function _ipa_remove_on_click(obj) var par = jobj.parent(); var input = par.find('input'); - input.addClass('strikethrough'); + if (input.is('.strikethrough')){ + input.removeClass('strikethrough'); + jobj.text("Remove"); + }else{ + input.addClass('strikethrough'); + jobj.text("Undo"); + } return (false); } |