mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2024-12-23 15:40:01 -06:00
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:
parent
2742001ed0
commit
ead85f2866
@ -42,23 +42,23 @@ var ipa_details_cache = null;
|
||||
function ipa_details_load(pkey, on_win, on_fail,sampleData)
|
||||
{
|
||||
if (!pkey)
|
||||
return;
|
||||
return;
|
||||
|
||||
_ipa_load_on_win_callback = on_win;
|
||||
_ipa_load_on_fail_callback = on_fail;
|
||||
|
||||
ipa_cmd(
|
||||
'show', [pkey], {all: true}, _ipa_load_on_win, _ipa_load_on_fail,
|
||||
_ipa_obj_name, sampleData );
|
||||
'show', [pkey], {all: true}, _ipa_load_on_win, _ipa_load_on_fail,
|
||||
_ipa_obj_name, sampleData );
|
||||
}
|
||||
|
||||
function _ipa_load_on_win(data, text_status, xhr)
|
||||
{
|
||||
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'])
|
||||
return;
|
||||
return;
|
||||
|
||||
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)
|
||||
{
|
||||
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;
|
||||
@ -78,79 +78,80 @@ var _ipa_update_on_fail_callback = null;
|
||||
function ipa_details_update(pkey, on_win, on_fail)
|
||||
{
|
||||
if (!pkey)
|
||||
return;
|
||||
return;
|
||||
|
||||
var modlist = {'all': true, 'setattr': [], 'addattr': []};
|
||||
var attrs_wo_option = {};
|
||||
|
||||
$('.entryattrs input').each(function () {
|
||||
var jobj = $(this);
|
||||
var jobj = $(this);
|
||||
|
||||
var dt = jobj.parent().prevAll('dt').slice(0, 1);
|
||||
if (!dt)
|
||||
return;
|
||||
var dt = jobj.parent().prevAll('dt').slice(0, 1);
|
||||
if (!dt)
|
||||
return;
|
||||
|
||||
var attr = dt.attr('title');
|
||||
if (!attr || attr.indexOf('call_') == 0)
|
||||
return;
|
||||
var attr = dt.attr('title');
|
||||
if (!attr || attr.indexOf('call_') == 0)
|
||||
return;
|
||||
var value = jQuery.trim(jobj.val());
|
||||
|
||||
var param_info = ipa_get_param_info(attr);
|
||||
if (param_info) {
|
||||
modlist[attr] = jobj.val();
|
||||
return;
|
||||
}
|
||||
var param_info = ipa_get_param_info(attr);
|
||||
if (param_info) {
|
||||
modlist[attr] = value;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!attrs_wo_option[attr])
|
||||
attrs_wo_option[attr] = [];
|
||||
attrs_wo_option[attr].push(jobj.val());
|
||||
if (!attrs_wo_option[attr])
|
||||
attrs_wo_option[attr] = [];
|
||||
attrs_wo_option[attr].push(value);
|
||||
});
|
||||
|
||||
$('.entryattrs dt').each(function () {
|
||||
var jobj = $(this);
|
||||
var jobj = $(this);
|
||||
|
||||
var attr = jobj.attr('title');
|
||||
if (!attr)
|
||||
return;
|
||||
var attr = jobj.attr('title');
|
||||
if (!attr)
|
||||
return;
|
||||
|
||||
if (attr.indexOf('call_') == 0) {
|
||||
var func = window[attr.substr(5)];
|
||||
if (func)
|
||||
func(jobj, modlist, IPA_DETAILS_UPDATE);
|
||||
return;
|
||||
}
|
||||
if (attr.indexOf('call_') == 0) {
|
||||
var func = window[attr.substr(5)];
|
||||
if (func)
|
||||
func(jobj, modlist, IPA_DETAILS_UPDATE);
|
||||
return;
|
||||
}
|
||||
|
||||
var param_info = ipa_get_param_info(attr);
|
||||
if (param_info && param_info['primary_key'])
|
||||
return;
|
||||
|
||||
var next = jobj.next('dd');
|
||||
if ((!next.length) || (!next.children('input').length))
|
||||
attrs_wo_option[attr] = [''];
|
||||
var next = jobj.next('dd');
|
||||
if ((!next.length) || (!next.children('input').length))
|
||||
attrs_wo_option[attr] = [''];
|
||||
});
|
||||
|
||||
for (attr in attrs_wo_option) {
|
||||
var values = attrs_wo_option[attr];
|
||||
modlist['setattr'].push(attr + '=' + values[0]);
|
||||
for (var i = 1; i < values.length; ++i)
|
||||
modlist['addattr'].push(attr + '=' + values[i]);
|
||||
var values = attrs_wo_option[attr];
|
||||
modlist['setattr'].push(attr + '=' + values[0]);
|
||||
for (var i = 1; i < values.length; ++i)
|
||||
modlist['addattr'].push(attr + '=' + values[i]);
|
||||
}
|
||||
|
||||
_ipa_update_on_win_callback = on_win;
|
||||
_ipa_update_on_fail_callback = on_fail;
|
||||
|
||||
ipa_cmd(
|
||||
'mod', [pkey], modlist, _ipa_update_on_win, _ipa_update_on_fail,
|
||||
_ipa_obj_name
|
||||
'mod', [pkey], modlist, _ipa_update_on_win, _ipa_update_on_fail,
|
||||
_ipa_obj_name
|
||||
);
|
||||
}
|
||||
|
||||
function _ipa_update_on_win(data, text_status, xhr)
|
||||
{
|
||||
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'])
|
||||
return;
|
||||
return;
|
||||
|
||||
var result = data.result.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)
|
||||
{
|
||||
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)
|
||||
@ -169,10 +170,10 @@ function ipa_details_create(dls, container)
|
||||
container = $('body');
|
||||
|
||||
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"), 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]);
|
||||
}
|
||||
}
|
||||
|
||||
@ -183,7 +184,7 @@ var _ipa_dt_template = '<dt title="T">N:</dt>';
|
||||
function ipa_generate_dl(jobj, id, name, dts)
|
||||
{
|
||||
if (!dts)
|
||||
return;
|
||||
return;
|
||||
|
||||
jobj.after(_ipa_h2_template.replace('I', name));
|
||||
jobj = jobj.next();
|
||||
@ -191,17 +192,17 @@ function ipa_generate_dl(jobj, id, name, dts)
|
||||
jobj = jobj.next();
|
||||
|
||||
for (var i = 0; i < dts.length; ++i) {
|
||||
var label = '';
|
||||
if (dts[i][0].indexOf('call_') != 0) {
|
||||
var param_info = ipa_get_param_info(dts[i][0]);
|
||||
if (param_info)
|
||||
label = param_info['label'];
|
||||
}
|
||||
if ((!label) && (dts[i].length > 1))
|
||||
label = dts[i][1];
|
||||
jobj.append(
|
||||
_ipa_dt_template.replace('T', dts[i][0]).replace('N', label)
|
||||
);
|
||||
var label = '';
|
||||
if (dts[i][0].indexOf('call_') != 0) {
|
||||
var param_info = ipa_get_param_info(dts[i][0]);
|
||||
if (param_info)
|
||||
label = param_info['label'];
|
||||
}
|
||||
if ((!label) && (dts[i].length > 1))
|
||||
label = dts[i][1];
|
||||
jobj.append(
|
||||
_ipa_dt_template.replace('T', dts[i][0]).replace('N', label)
|
||||
);
|
||||
}
|
||||
jobj.after('<hr />');
|
||||
}
|
||||
@ -209,6 +210,7 @@ function ipa_generate_dl(jobj, id, name, dts)
|
||||
/* HTML templates for ipa_details_display() */
|
||||
var _ipa_a_add_template =
|
||||
'<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
|
||||
*
|
||||
@ -232,29 +234,56 @@ function ipa_details_display(entry_attrs)
|
||||
|
||||
/* go through all <dt> tags and pair them with newly created <dd>s */
|
||||
$('.entryattrs dt').each(function () {
|
||||
var jobj = $(this);
|
||||
var jobj = $(this);
|
||||
|
||||
var attr = jobj.attr('title');
|
||||
if (attr.indexOf('call_') == 0) {
|
||||
/* title contains callback instead of attribute name */
|
||||
var func = window[attr.substr(5)];
|
||||
if (func)
|
||||
func(jobj, entry_attrs, IPA_DETAILS_POPULATE);
|
||||
else
|
||||
jobj.after(_ipa_dd_first_template.replace('I', '-'));
|
||||
} else {
|
||||
/* title contains attribute name - default behaviour */
|
||||
var value = entry_attrs[attr];
|
||||
if (value) {
|
||||
ipa_insert_first_dd(jobj, ipa_create_input(attr, value[0]));
|
||||
for (var i = 1; i < value.length; ++i) {
|
||||
jobj = jobj.next();
|
||||
ipa_insert_other_dd(jobj, ipa_create_input(attr, value[i]));
|
||||
}
|
||||
} else {
|
||||
ipa_insert_first_dd(jobj, _ipa_a_add_template.replace('A', attr));
|
||||
}
|
||||
}
|
||||
var attr = jobj.attr('title');
|
||||
if (attr.indexOf('call_') == 0) {
|
||||
/* title contains callback instead of attribute name */
|
||||
var func = window[attr.substr(5)];
|
||||
if (func)
|
||||
func(jobj, entry_attrs, IPA_DETAILS_POPULATE);
|
||||
else
|
||||
jobj.after(_ipa_dd_first_template.replace('I', '-'));
|
||||
} else {
|
||||
/* title contains attribute name - default behaviour */
|
||||
var multivalue = false;
|
||||
var hint_span = '';
|
||||
|
||||
var param_info = ipa_get_param_info(attr);
|
||||
if (param_info) {
|
||||
if (param_info['multivalue'] || param_info['class'] == 'List')
|
||||
multivalue = true;
|
||||
var hint = param_info['hint'];
|
||||
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,
|
||||
'Int': _ipa_create_text_input,
|
||||
'Bool': _ipa_create_text_input,
|
||||
'List': _ipa_create_text_input,
|
||||
};
|
||||
|
||||
/* 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);
|
||||
if (!param_info) {
|
||||
/* no information about the param is available, default to text input */
|
||||
return (
|
||||
_ipa_create_text_input(attr, value, null) +
|
||||
_ipa_create_remove_link(attr, null)
|
||||
);
|
||||
/* no information about the param is available, default to text input */
|
||||
return (_ipa_create_text_input(attr, value, null));
|
||||
}
|
||||
|
||||
/* check if the param value can be modified */
|
||||
if (param_info['primary_key'] || ('no_update' in param_info['flags']))
|
||||
return (value.toString());
|
||||
return (value.toString());
|
||||
|
||||
/* call handler by param class */
|
||||
var handler = _ipa_param_type_2_handler_map[param_info['class']];
|
||||
if (handler) {
|
||||
return (
|
||||
handler(attr, value, param_info) +
|
||||
_ipa_create_remove_link(attr, param_info)
|
||||
);
|
||||
if (param_info['multivalue'] || param_info['class'] == 'List') {
|
||||
return (
|
||||
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 */
|
||||
@ -320,12 +350,12 @@ var _ipa_a_remove_template =
|
||||
function _ipa_create_remove_link(attr, 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
|
||||
* if it is, then we don't want people to be able to remove it */
|
||||
if ((param_info['required']) || (param_info['class'] == 'Password'))
|
||||
return ('');
|
||||
return ('');
|
||||
|
||||
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)
|
||||
{
|
||||
return (
|
||||
_ipa_input_text_template.replace('A', attr).replace(
|
||||
'V', value.toString()
|
||||
)
|
||||
_ipa_input_text_template.replace('A', attr).replace(
|
||||
'V', value.toString()
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
function ipa_details_reset()
|
||||
{
|
||||
if (ipa_details_cache)
|
||||
ipa_details_display(ipa_details_cache);
|
||||
ipa_details_display(ipa_details_cache);
|
||||
}
|
||||
|
||||
/* Event handlers */
|
||||
@ -355,10 +385,14 @@ function ipa_details_reset()
|
||||
function _ipa_add_on_click(obj)
|
||||
{
|
||||
var jobj = $(obj);
|
||||
var attr = jobj.attr('title');
|
||||
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.remove();
|
||||
|
||||
return (false);
|
||||
}
|
||||
|
||||
@ -370,14 +404,16 @@ function _ipa_remove_on_click(obj)
|
||||
|
||||
var next = par.next('dd');
|
||||
if (next.length) {
|
||||
if (par.hasClass('first')) {
|
||||
next.addClass('first');
|
||||
next.removeClass('other');
|
||||
}
|
||||
par.remove();
|
||||
if (par.hasClass('first')) {
|
||||
var hint = par.children('span').detach();
|
||||
next.append(hint);
|
||||
next.addClass('first');
|
||||
next.removeClass('other');
|
||||
}
|
||||
par.remove();
|
||||
} else {
|
||||
par.empty();
|
||||
par.append(_ipa_a_add_template.replace('A', attr));
|
||||
par.empty();
|
||||
par.append(_ipa_a_add_template.replace('A', attr));
|
||||
}
|
||||
|
||||
return (false);
|
||||
@ -388,14 +424,14 @@ function _h2_on_click(obj)
|
||||
var jobj = $(obj);
|
||||
var txt = jobj.text().replace(/^\s*/, '');
|
||||
if (txt.charCodeAt(0) == 8722) {
|
||||
obj.dl = jobj.next().detach();
|
||||
jobj.text('+' + txt.substr(1));
|
||||
obj.dl = jobj.next().detach();
|
||||
jobj.text('+' + txt.substr(1));
|
||||
} else {
|
||||
if (obj.dl)
|
||||
obj.dl.insertAfter(obj);
|
||||
jobj.text(
|
||||
String.fromCharCode(8722) + txt.substr(1)
|
||||
);
|
||||
if (obj.dl)
|
||||
obj.dl.insertAfter(obj);
|
||||
jobj.text(
|
||||
String.fromCharCode(8722) + txt.substr(1)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -182,6 +182,13 @@ div#backtotop {
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
span.attrhint {
|
||||
font-size: 8pt;
|
||||
left: 40em;
|
||||
margin-left: 100px;
|
||||
position: absolute;
|
||||
}
|
||||
|
||||
|
||||
/*Navigation */
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user