mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-02-25 18:55:28 -06:00
Fixed DNS zone adder dialog.
The DNS zone adder dialog has been modified to use radio buttons to select whether to enter a zone name or a reverse zone IP network. Ticket #1575
This commit is contained in:
@@ -259,6 +259,7 @@ IPA.dialog = function(spec) {
|
||||
that.dialog_create = that.create;
|
||||
that.dialog_open = that.open;
|
||||
that.dialog_close = that.close;
|
||||
that.dialog_save = that.save;
|
||||
|
||||
var fields = spec.fields || [];
|
||||
for (var i=0; i<fields.length; i++) {
|
||||
|
@@ -88,16 +88,21 @@ IPA.entity_factories.dnszone = function() {
|
||||
width: 500,
|
||||
height: 300,
|
||||
fields: [
|
||||
'idnsname',
|
||||
{
|
||||
factory: IPA.checkbox_widget,
|
||||
name: 'name_from_ip',
|
||||
name: 'idnsname',
|
||||
optional: true,
|
||||
undo: false
|
||||
},
|
||||
'name_from_ip',
|
||||
'idnssoamname',
|
||||
'idnssoarname',
|
||||
{
|
||||
factory: IPA.force_dnszone_add_checkbox_widget
|
||||
name: 'idnssoarname',
|
||||
optional: true,
|
||||
undo: false
|
||||
},
|
||||
{
|
||||
factory: IPA.force_dnszone_add_checkbox_widget,
|
||||
name: 'force'
|
||||
}
|
||||
]
|
||||
}).
|
||||
@@ -110,36 +115,180 @@ IPA.dnszone_adder_dialog = function(spec) {
|
||||
|
||||
var that = IPA.add_dialog(spec);
|
||||
|
||||
that.create = function() {
|
||||
|
||||
that.container.addClass('dnszone-adder-dialog');
|
||||
|
||||
var table = $('<table/>').appendTo(that.container);
|
||||
|
||||
var field = that.get_field('idnsname');
|
||||
|
||||
var tr = $('<tr/>').appendTo(table);
|
||||
|
||||
var td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
var label = $('<label/>', {
|
||||
'for': 'dnszone-adder-dialog-idnsname-radio'
|
||||
}).appendTo(td);
|
||||
|
||||
that.idnsname_radio = $('<input/>', {
|
||||
type: 'radio',
|
||||
id: 'dnszone-adder-dialog-idnsname-radio',
|
||||
name: 'type',
|
||||
value: 'idnsname'
|
||||
}).appendTo(label);
|
||||
|
||||
label.append(field.label+':');
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
var span = $('<span/>', {
|
||||
name: field.name
|
||||
}).appendTo(td);
|
||||
|
||||
field.create(span);
|
||||
|
||||
var idnsname_input = $('input', span);
|
||||
|
||||
field = that.get_field('name_from_ip');
|
||||
|
||||
tr = $('<tr/>').appendTo(table);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
label = $('<label/>', {
|
||||
'for': 'dnszone-adder-dialog-name_from_ip-radio'
|
||||
}).appendTo(td);
|
||||
|
||||
var name_from_ip_radio = $('<input/>', {
|
||||
type: 'radio',
|
||||
id: 'dnszone-adder-dialog-name_from_ip-radio',
|
||||
name: 'type',
|
||||
value: 'name_from_ip'
|
||||
}).appendTo(label);
|
||||
|
||||
label.append(field.label+':');
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
span = $('<span/>', {
|
||||
name: field.name
|
||||
}).appendTo(td);
|
||||
|
||||
field.create(span);
|
||||
|
||||
var name_from_ip_input = $('input', span);
|
||||
|
||||
that.idnsname_radio.click(function() {
|
||||
idnsname_input.attr('disabled', false);
|
||||
name_from_ip_input.attr('disabled', true);
|
||||
});
|
||||
|
||||
name_from_ip_radio.click(function() {
|
||||
idnsname_input.attr('disabled', true);
|
||||
name_from_ip_input.attr('disabled', false);
|
||||
});
|
||||
|
||||
idnsname_input.focus(function() {
|
||||
that.idnsname_radio.attr('checked', true);
|
||||
});
|
||||
|
||||
name_from_ip_input.focus(function() {
|
||||
name_from_ip_radio.attr('checked', true);
|
||||
});
|
||||
|
||||
that.idnsname_radio.click();
|
||||
|
||||
tr = $('<tr/>').appendTo(table);
|
||||
|
||||
td = $('<td/>', {
|
||||
colspan: 2,
|
||||
html: ' '
|
||||
}).appendTo(tr);
|
||||
|
||||
field = that.get_field('idnssoamname');
|
||||
|
||||
tr = $('<tr/>').appendTo(table);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
label = $('<label/>', {
|
||||
text: field.label+':'
|
||||
}).appendTo(td);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
span = $('<span/>', {
|
||||
name: field.name
|
||||
}).appendTo(td);
|
||||
|
||||
field.create(span);
|
||||
|
||||
field = that.get_field('idnssoarname');
|
||||
|
||||
tr = $('<tr/>').appendTo(table);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
label = $('<label/>', {
|
||||
text: field.label+':'
|
||||
}).appendTo(td);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
span = $('<span/>', {
|
||||
name: field.name
|
||||
}).appendTo(td);
|
||||
|
||||
field.create(span);
|
||||
|
||||
field = that.get_field('force');
|
||||
|
||||
tr = $('<tr/>').appendTo(table);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
label = $('<label/>', {
|
||||
text: field.label+':'
|
||||
}).appendTo(td);
|
||||
|
||||
td = $('<td/>', {
|
||||
title: field.label
|
||||
}).appendTo(tr);
|
||||
|
||||
span = $('<span/>', {
|
||||
name: field.name
|
||||
}).appendTo(td);
|
||||
|
||||
field.create(span);
|
||||
};
|
||||
|
||||
that.save = function(record) {
|
||||
|
||||
var idnsname;
|
||||
var name_from_ip;
|
||||
that.dialog_save(record);
|
||||
|
||||
var fields = that.fields.values;
|
||||
for (var i=0; i<fields.length; i++) {
|
||||
var field = fields[i];
|
||||
|
||||
if (field.name == 'idnsname') {
|
||||
|
||||
idnsname = field.save()[0];
|
||||
|
||||
} else if (field.name == 'name_from_ip') {
|
||||
|
||||
name_from_ip = field.save()[0];
|
||||
if (name_from_ip) {
|
||||
record.name_from_ip = idnsname;
|
||||
if (that.idnsname_radio.is(':checked')) {
|
||||
delete record.name_from_ip;
|
||||
} else {
|
||||
record.idnsname = idnsname;
|
||||
}
|
||||
|
||||
} else if (field.name == 'idnssoarname') {
|
||||
|
||||
field.optional = name_from_ip;
|
||||
|
||||
} else {
|
||||
var values = field.save();
|
||||
record[field.name] = values.join(',');
|
||||
}
|
||||
delete record.idnsname;
|
||||
}
|
||||
};
|
||||
|
||||
@@ -388,7 +537,7 @@ IPA.dnsrecord_host_link_widget = function(spec){
|
||||
IPA.dns_record_types = function() {
|
||||
var attrs = IPA.metadata.objects.dnsrecord.default_attributes;
|
||||
var record_types = [];
|
||||
for (var i =0; i < attrs.length; i+=1){
|
||||
for (var i=0; i<attrs.length; i++) {
|
||||
var attr = attrs[i];
|
||||
var index = attr.search('record$');
|
||||
if (index > -1) {
|
||||
@@ -410,8 +559,7 @@ IPA.dnsrecord_type_widget = function (spec){
|
||||
};
|
||||
|
||||
IPA.force_dnszone_add_checkbox_widget = function(spec) {
|
||||
var param_info = IPA.get_method_option('dnszone_add', 'force');
|
||||
spec.name = 'force';
|
||||
var param_info = IPA.get_method_option('dnszone_add', spec.name);
|
||||
spec.label = param_info.label;
|
||||
spec.tooltip = param_info.doc;
|
||||
spec.undo = false;
|
||||
|
Reference in New Issue
Block a user