Make changes to details.js. See commit message.

- Add/Remove links are now only available for multivalue
  attributes (Param.multivalue = true) and attributes with param
  types, that are multivalue by definition (as of now only List).
  Single-value attributes with no value are displayed as empty
  input elements.
- When updating an attribute, leading and trailing spaces are
  stripped
- Context help available in the form of hints, that are extracted
  form Param.hint.
This commit is contained in:
Pavel Zuna 2010-08-25 12:49:30 -04:00 committed by Adam Young
parent 2742001ed0
commit ead85f2866
2 changed files with 155 additions and 112 deletions

View File

@ -42,23 +42,23 @@ var ipa_details_cache = null;
function ipa_details_load(pkey, on_win, on_fail,sampleData) function ipa_details_load(pkey, on_win, on_fail,sampleData)
{ {
if (!pkey) if (!pkey)
return; return;
_ipa_load_on_win_callback = on_win; _ipa_load_on_win_callback = on_win;
_ipa_load_on_fail_callback = on_fail; _ipa_load_on_fail_callback = on_fail;
ipa_cmd( ipa_cmd(
'show', [pkey], {all: true}, _ipa_load_on_win, _ipa_load_on_fail, 'show', [pkey], {all: true}, _ipa_load_on_win, _ipa_load_on_fail,
_ipa_obj_name, sampleData ); _ipa_obj_name, sampleData );
} }
function _ipa_load_on_win(data, text_status, xhr) function _ipa_load_on_win(data, text_status, xhr)
{ {
if (_ipa_load_on_win_callback) if (_ipa_load_on_win_callback)
_ipa_load_on_win_callback(data, text_status, xhr); _ipa_load_on_win_callback(data, text_status, xhr);
if (data['error']) if (data['error'])
return; return;
var result = data.result.result; var result = data.result.result;
@ -69,7 +69,7 @@ function _ipa_load_on_win(data, text_status, xhr)
function _ipa_load_on_fail(xhr, text_status, error_thrown) function _ipa_load_on_fail(xhr, text_status, error_thrown)
{ {
if (_ipa_load_on_fail_callback) if (_ipa_load_on_fail_callback)
_ipa_load_on_fail_callback(xhr, text_status, error_thrown); _ipa_load_on_fail_callback(xhr, text_status, error_thrown);
} }
var _ipa_update_on_win_callback = null; var _ipa_update_on_win_callback = null;
@ -78,79 +78,80 @@ var _ipa_update_on_fail_callback = null;
function ipa_details_update(pkey, on_win, on_fail) function ipa_details_update(pkey, on_win, on_fail)
{ {
if (!pkey) if (!pkey)
return; return;
var modlist = {'all': true, 'setattr': [], 'addattr': []}; var modlist = {'all': true, 'setattr': [], 'addattr': []};
var attrs_wo_option = {}; var attrs_wo_option = {};
$('.entryattrs input').each(function () { $('.entryattrs input').each(function () {
var jobj = $(this); var jobj = $(this);
var dt = jobj.parent().prevAll('dt').slice(0, 1); var dt = jobj.parent().prevAll('dt').slice(0, 1);
if (!dt) if (!dt)
return; return;
var attr = dt.attr('title'); var attr = dt.attr('title');
if (!attr || attr.indexOf('call_') == 0) if (!attr || attr.indexOf('call_') == 0)
return; return;
var value = jQuery.trim(jobj.val());
var param_info = ipa_get_param_info(attr); var param_info = ipa_get_param_info(attr);
if (param_info) { if (param_info) {
modlist[attr] = jobj.val(); modlist[attr] = value;
return; return;
} }
if (!attrs_wo_option[attr]) if (!attrs_wo_option[attr])
attrs_wo_option[attr] = []; attrs_wo_option[attr] = [];
attrs_wo_option[attr].push(jobj.val()); attrs_wo_option[attr].push(value);
}); });
$('.entryattrs dt').each(function () { $('.entryattrs dt').each(function () {
var jobj = $(this); var jobj = $(this);
var attr = jobj.attr('title'); var attr = jobj.attr('title');
if (!attr) if (!attr)
return; return;
if (attr.indexOf('call_') == 0) { if (attr.indexOf('call_') == 0) {
var func = window[attr.substr(5)]; var func = window[attr.substr(5)];
if (func) if (func)
func(jobj, modlist, IPA_DETAILS_UPDATE); func(jobj, modlist, IPA_DETAILS_UPDATE);
return; return;
} }
var param_info = ipa_get_param_info(attr); var param_info = ipa_get_param_info(attr);
if (param_info && param_info['primary_key']) if (param_info && param_info['primary_key'])
return; return;
var next = jobj.next('dd'); var next = jobj.next('dd');
if ((!next.length) || (!next.children('input').length)) if ((!next.length) || (!next.children('input').length))
attrs_wo_option[attr] = ['']; attrs_wo_option[attr] = [''];
}); });
for (attr in attrs_wo_option) { for (attr in attrs_wo_option) {
var values = attrs_wo_option[attr]; var values = attrs_wo_option[attr];
modlist['setattr'].push(attr + '=' + values[0]); modlist['setattr'].push(attr + '=' + values[0]);
for (var i = 1; i < values.length; ++i) for (var i = 1; i < values.length; ++i)
modlist['addattr'].push(attr + '=' + values[i]); modlist['addattr'].push(attr + '=' + values[i]);
} }
_ipa_update_on_win_callback = on_win; _ipa_update_on_win_callback = on_win;
_ipa_update_on_fail_callback = on_fail; _ipa_update_on_fail_callback = on_fail;
ipa_cmd( ipa_cmd(
'mod', [pkey], modlist, _ipa_update_on_win, _ipa_update_on_fail, 'mod', [pkey], modlist, _ipa_update_on_win, _ipa_update_on_fail,
_ipa_obj_name _ipa_obj_name
); );
} }
function _ipa_update_on_win(data, text_status, xhr) function _ipa_update_on_win(data, text_status, xhr)
{ {
if (_ipa_update_on_win_callback) if (_ipa_update_on_win_callback)
_ipa_update_on_win_callback(data, text_status, xhr); _ipa_update_on_win_callback(data, text_status, xhr);
if (data['error']) if (data['error'])
return; return;
var result = data.result.result; var result = data.result.result;
ipa_details_cache = $.extend(true, {}, result); ipa_details_cache = $.extend(true, {}, result);
@ -160,7 +161,7 @@ function _ipa_update_on_win(data, text_status, xhr)
function _ipa_update_on_fail(xhr, text_status, error_thrown) function _ipa_update_on_fail(xhr, text_status, error_thrown)
{ {
if (_ipa_update_on_fail_callback) if (_ipa_update_on_fail_callback)
_ipa_update_on_fail_callback(xhr, text_status, error_thrown); _ipa_update_on_fail_callback(xhr, text_status, error_thrown);
} }
function ipa_details_create(dls, container) function ipa_details_create(dls, container)
@ -169,10 +170,10 @@ function ipa_details_create(dls, container)
container = $('body'); container = $('body');
for (var i = 0; i < dls.length; ++i) { for (var i = 0; i < dls.length; ++i) {
var d = dls[i]; var d = dls[i];
ipa_generate_dl($('#detail-lists hr').last(), d[0], d[1], d[2]); ipa_generate_dl($('#detail-lists hr').last(), d[0], d[1], d[2]);
// ipa_generate_dl($("#detail-lists"), d[0], d[1], d[2]); // ipa_generate_dl($("#detail-lists"), d[0], d[1], d[2]);
} }
} }
@ -183,7 +184,7 @@ var _ipa_dt_template = '<dt title="T">N:</dt>';
function ipa_generate_dl(jobj, id, name, dts) function ipa_generate_dl(jobj, id, name, dts)
{ {
if (!dts) if (!dts)
return; return;
jobj.after(_ipa_h2_template.replace('I', name)); jobj.after(_ipa_h2_template.replace('I', name));
jobj = jobj.next(); jobj = jobj.next();
@ -191,17 +192,17 @@ function ipa_generate_dl(jobj, id, name, dts)
jobj = jobj.next(); jobj = jobj.next();
for (var i = 0; i < dts.length; ++i) { for (var i = 0; i < dts.length; ++i) {
var label = ''; var label = '';
if (dts[i][0].indexOf('call_') != 0) { if (dts[i][0].indexOf('call_') != 0) {
var param_info = ipa_get_param_info(dts[i][0]); var param_info = ipa_get_param_info(dts[i][0]);
if (param_info) if (param_info)
label = param_info['label']; label = param_info['label'];
} }
if ((!label) && (dts[i].length > 1)) if ((!label) && (dts[i].length > 1))
label = dts[i][1]; label = dts[i][1];
jobj.append( jobj.append(
_ipa_dt_template.replace('T', dts[i][0]).replace('N', label) _ipa_dt_template.replace('T', dts[i][0]).replace('N', label)
); );
} }
jobj.after('<hr />'); jobj.after('<hr />');
} }
@ -209,6 +210,7 @@ function ipa_generate_dl(jobj, id, name, dts)
/* HTML templates for ipa_details_display() */ /* HTML templates for ipa_details_display() */
var _ipa_a_add_template = var _ipa_a_add_template =
'<a href="jslink" onclick="return (_ipa_add_on_click(this))" title="A">Add</a>'; '<a href="jslink" onclick="return (_ipa_add_on_click(this))" title="A">Add</a>';
var _ipa_span_doc_template = '<span class="attrhint">Hint: D</span>';
/* populate definition lists with the class 'entryattrs' with entry attributes /* populate definition lists with the class 'entryattrs' with entry attributes
* *
@ -232,29 +234,56 @@ function ipa_details_display(entry_attrs)
/* go through all <dt> tags and pair them with newly created <dd>s */ /* go through all <dt> tags and pair them with newly created <dd>s */
$('.entryattrs dt').each(function () { $('.entryattrs dt').each(function () {
var jobj = $(this); var jobj = $(this);
var attr = jobj.attr('title'); var attr = jobj.attr('title');
if (attr.indexOf('call_') == 0) { if (attr.indexOf('call_') == 0) {
/* title contains callback instead of attribute name */ /* title contains callback instead of attribute name */
var func = window[attr.substr(5)]; var func = window[attr.substr(5)];
if (func) if (func)
func(jobj, entry_attrs, IPA_DETAILS_POPULATE); func(jobj, entry_attrs, IPA_DETAILS_POPULATE);
else else
jobj.after(_ipa_dd_first_template.replace('I', '-')); jobj.after(_ipa_dd_first_template.replace('I', '-'));
} else { } else {
/* title contains attribute name - default behaviour */ /* title contains attribute name - default behaviour */
var value = entry_attrs[attr]; var multivalue = false;
if (value) { var hint_span = '';
ipa_insert_first_dd(jobj, ipa_create_input(attr, value[0]));
for (var i = 1; i < value.length; ++i) { var param_info = ipa_get_param_info(attr);
jobj = jobj.next(); if (param_info) {
ipa_insert_other_dd(jobj, ipa_create_input(attr, value[i])); if (param_info['multivalue'] || param_info['class'] == 'List')
} multivalue = true;
} else { var hint = param_info['hint'];
ipa_insert_first_dd(jobj, _ipa_a_add_template.replace('A', attr)); if (hint)
} hint_span = _ipa_span_hint_template.replace('D', hint);
} }
var value = entry_attrs[attr];
if (value) {
ipa_insert_first_dd(
jobj, ipa_create_input(attr, value[0]) + hint_span
);
for (var i = 1; i < value.length; ++i) {
jobj = jobj.next();
ipa_insert_other_dd(jobj, ipa_create_input(attr, value[i]));
}
if (multivalue) {
ipa_insert_other_dd(
jobj.next(), _ipa_a_add_template.replace('A', attr)
);
}
} else {
if (multivalue) {
ipa_insert_first_dd(
jobj, _ipa_a_add_template.replace('A', attr) + hint_span
);
} else {
ipa_insert_first_dd(
jobj, ipa_create_input(attr, '') + hint_span
);
}
}
}
}); });
} }
@ -278,6 +307,7 @@ var _ipa_param_type_2_handler_map = {
'Str': _ipa_create_text_input, 'Str': _ipa_create_text_input,
'Int': _ipa_create_text_input, 'Int': _ipa_create_text_input,
'Bool': _ipa_create_text_input, 'Bool': _ipa_create_text_input,
'List': _ipa_create_text_input,
}; };
/* create an HTML element for displaying/editing an attribute /* create an HTML element for displaying/editing an attribute
@ -288,24 +318,24 @@ function ipa_create_input(attr, value)
{ {
var param_info = ipa_get_param_info(attr); var param_info = ipa_get_param_info(attr);
if (!param_info) { if (!param_info) {
/* no information about the param is available, default to text input */ /* no information about the param is available, default to text input */
return ( return (_ipa_create_text_input(attr, value, null));
_ipa_create_text_input(attr, value, null) +
_ipa_create_remove_link(attr, null)
);
} }
/* check if the param value can be modified */ /* check if the param value can be modified */
if (param_info['primary_key'] || ('no_update' in param_info['flags'])) if (param_info['primary_key'] || ('no_update' in param_info['flags']))
return (value.toString()); return (value.toString());
/* call handler by param class */ /* call handler by param class */
var handler = _ipa_param_type_2_handler_map[param_info['class']]; var handler = _ipa_param_type_2_handler_map[param_info['class']];
if (handler) { if (handler) {
return ( if (param_info['multivalue'] || param_info['class'] == 'List') {
handler(attr, value, param_info) + return (
_ipa_create_remove_link(attr, param_info) handler(attr, value, param_info) +
); _ipa_create_remove_link(attr, param_info)
);
}
return (handler(attr, value, param_info));
} }
/* no handler for this type? don't allow modification */ /* no handler for this type? don't allow modification */
@ -320,12 +350,12 @@ var _ipa_a_remove_template =
function _ipa_create_remove_link(attr, param_info) function _ipa_create_remove_link(attr, param_info)
{ {
if (!param_info) if (!param_info)
return (_ipa_a_remove_template.replace('A', attr)); return (_ipa_a_remove_template.replace('A', attr));
/* check if the param is required or of the Password type /* check if the param is required or of the Password type
* if it is, then we don't want people to be able to remove it */ * if it is, then we don't want people to be able to remove it */
if ((param_info['required']) || (param_info['class'] == 'Password')) if ((param_info['required']) || (param_info['class'] == 'Password'))
return (''); return ('');
return (_ipa_a_remove_template.replace('A', attr)); return (_ipa_a_remove_template.replace('A', attr));
} }
@ -338,16 +368,16 @@ var _ipa_input_text_template =
function _ipa_create_text_input(attr, value, param_info) function _ipa_create_text_input(attr, value, param_info)
{ {
return ( return (
_ipa_input_text_template.replace('A', attr).replace( _ipa_input_text_template.replace('A', attr).replace(
'V', value.toString() 'V', value.toString()
) )
); );
} }
function ipa_details_reset() function ipa_details_reset()
{ {
if (ipa_details_cache) if (ipa_details_cache)
ipa_details_display(ipa_details_cache); ipa_details_display(ipa_details_cache);
} }
/* Event handlers */ /* Event handlers */
@ -355,10 +385,14 @@ function ipa_details_reset()
function _ipa_add_on_click(obj) function _ipa_add_on_click(obj)
{ {
var jobj = $(obj); var jobj = $(obj);
var attr = jobj.attr('title');
var par = jobj.parent(); var par = jobj.parent();
par.append(ipa_create_input(jobj.attr('title'), ''));
par.prepend(ipa_create_input(attr, ''));
ipa_insert_other_dd(par, _ipa_a_add_template.replace('A', attr));
jobj.next('input').focus(); jobj.next('input').focus();
jobj.remove(); jobj.remove();
return (false); return (false);
} }
@ -370,14 +404,16 @@ function _ipa_remove_on_click(obj)
var next = par.next('dd'); var next = par.next('dd');
if (next.length) { if (next.length) {
if (par.hasClass('first')) { if (par.hasClass('first')) {
next.addClass('first'); var hint = par.children('span').detach();
next.removeClass('other'); next.append(hint);
} next.addClass('first');
par.remove(); next.removeClass('other');
}
par.remove();
} else { } else {
par.empty(); par.empty();
par.append(_ipa_a_add_template.replace('A', attr)); par.append(_ipa_a_add_template.replace('A', attr));
} }
return (false); return (false);
@ -388,14 +424,14 @@ function _h2_on_click(obj)
var jobj = $(obj); var jobj = $(obj);
var txt = jobj.text().replace(/^\s*/, ''); var txt = jobj.text().replace(/^\s*/, '');
if (txt.charCodeAt(0) == 8722) { if (txt.charCodeAt(0) == 8722) {
obj.dl = jobj.next().detach(); obj.dl = jobj.next().detach();
jobj.text('+' + txt.substr(1)); jobj.text('+' + txt.substr(1));
} else { } else {
if (obj.dl) if (obj.dl)
obj.dl.insertAfter(obj); obj.dl.insertAfter(obj);
jobj.text( jobj.text(
String.fromCharCode(8722) + txt.substr(1) String.fromCharCode(8722) + txt.substr(1)
); );
} }
} }

View File

@ -182,6 +182,13 @@ div#backtotop {
text-align: right; text-align: right;
} }
span.attrhint {
font-size: 8pt;
left: 40em;
margin-left: 100px;
position: absolute;
}
/*Navigation */ /*Navigation */