mirror of
https://git.proxmox.com/git/pve-manager
synced 2025-08-07 22:13:24 +00:00
improve lxc DNS panel
This commit is contained in:
parent
845f6216d6
commit
520893437b
@ -148,49 +148,9 @@ Ext.define('PVE.lxc.CreateWizard', {
|
|||||||
},
|
},
|
||||||
networkpanel,
|
networkpanel,
|
||||||
{
|
{
|
||||||
xtype: 'inputpanel',
|
xtype: 'pveLxcDNSInputPanel',
|
||||||
title: gettext('DNS'),
|
title: gettext('DNS'),
|
||||||
column1: [
|
insideWizard: true
|
||||||
{
|
|
||||||
xtype: 'pvetextfield',
|
|
||||||
name: 'searchdomain',
|
|
||||||
skipEmptyText: true,
|
|
||||||
fieldLabel: gettext('DNS domain'),
|
|
||||||
emptyText: 'use host settings',
|
|
||||||
allowBlank: true,
|
|
||||||
listeners: {
|
|
||||||
change: function(f, value) {
|
|
||||||
if (!me.rendered) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var field = me.down('#dns1');
|
|
||||||
field.setDisabled(!value);
|
|
||||||
field.clearInvalid();
|
|
||||||
field = me.down('#dns2');
|
|
||||||
field.setDisabled(!value);
|
|
||||||
field.clearInvalid();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
xtype: 'pvetextfield',
|
|
||||||
fieldLabel: gettext('DNS server') + " 1",
|
|
||||||
vtype: 'IPAddress',
|
|
||||||
allowBlank: true,
|
|
||||||
disabled: true,
|
|
||||||
name: 'nameserver',
|
|
||||||
itemId: 'dns1'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
xtype: 'pvetextfield',
|
|
||||||
fieldLabel: gettext('DNS server') + " 2",
|
|
||||||
vtype: 'IPAddress',
|
|
||||||
skipEmptyText: true,
|
|
||||||
disabled: true,
|
|
||||||
name: 'nameserver',
|
|
||||||
itemId: 'dns2'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: gettext('Confirm'),
|
title: gettext('Confirm'),
|
||||||
|
@ -1,3 +1,137 @@
|
|||||||
|
Ext.define('PVE.lxc.DNSInputPanel', {
|
||||||
|
extend: 'PVE.panel.InputPanel',
|
||||||
|
alias: 'widget.pveLxcDNSInputPanel',
|
||||||
|
|
||||||
|
insideWizard: false,
|
||||||
|
|
||||||
|
onGetValues: function(values) {
|
||||||
|
var me = this;
|
||||||
|
|
||||||
|
if (!values.searchdomain) {
|
||||||
|
if (me.insideWizard) {
|
||||||
|
return {};
|
||||||
|
} else {
|
||||||
|
return { "delete": "searchdomain,nameserver" };
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var list = [];
|
||||||
|
Ext.Array.each(['dns1', 'dns2', 'dns3'], function(fn) {
|
||||||
|
if (values[fn]) {
|
||||||
|
list.push(values[fn]);
|
||||||
|
}
|
||||||
|
delete values[fn];
|
||||||
|
});
|
||||||
|
|
||||||
|
if (list.length) {
|
||||||
|
values.nameserver = list.join(' ');
|
||||||
|
} else {
|
||||||
|
if (!me.insideWizard) {
|
||||||
|
values['delete'] = 'nameserver';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return values;
|
||||||
|
},
|
||||||
|
|
||||||
|
initComponent : function() {
|
||||||
|
var me = this;
|
||||||
|
|
||||||
|
var items = [
|
||||||
|
{
|
||||||
|
xtype: 'pvetextfield',
|
||||||
|
name: 'searchdomain',
|
||||||
|
skipEmptyText: true,
|
||||||
|
fieldLabel: gettext('DNS domain'),
|
||||||
|
emptyText: gettext('use host settings'),
|
||||||
|
allowBlank: true,
|
||||||
|
listeners: {
|
||||||
|
change: function(f, value) {
|
||||||
|
if (!me.rendered) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var field_ids = ['#dns1', '#dns2', '#dns3'];
|
||||||
|
Ext.Array.each(field_ids, function(fn) {
|
||||||
|
var field = me.down(fn);
|
||||||
|
field.setDisabled(!value);
|
||||||
|
field.clearInvalid();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
xtype: 'pvetextfield',
|
||||||
|
fieldLabel: gettext('DNS server') + " 1",
|
||||||
|
vtype: 'IPAddress',
|
||||||
|
allowBlank: true,
|
||||||
|
disabled: true,
|
||||||
|
name: 'dns1',
|
||||||
|
itemId: 'dns1'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
xtype: 'pvetextfield',
|
||||||
|
fieldLabel: gettext('DNS server') + " 2",
|
||||||
|
vtype: 'IPAddress',
|
||||||
|
skipEmptyText: true,
|
||||||
|
disabled: true,
|
||||||
|
name: 'dns2',
|
||||||
|
itemId: 'dns2'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
xtype: 'pvetextfield',
|
||||||
|
fieldLabel: gettext('DNS server') + " 3",
|
||||||
|
vtype: 'IPAddress',
|
||||||
|
skipEmptyText: true,
|
||||||
|
disabled: true,
|
||||||
|
name: 'dns3',
|
||||||
|
itemId: 'dns3'
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
if (me.insideWizard) {
|
||||||
|
me.column1 = items;
|
||||||
|
} else {
|
||||||
|
me.items = items;
|
||||||
|
}
|
||||||
|
|
||||||
|
me.callParent();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Ext.define('PVE.lxc.DNSEdit', {
|
||||||
|
extend: 'PVE.window.Edit',
|
||||||
|
|
||||||
|
initComponent : function() {
|
||||||
|
var me = this;
|
||||||
|
|
||||||
|
var ipanel = Ext.create('PVE.lxc.DNSInputPanel');
|
||||||
|
|
||||||
|
Ext.apply(me, {
|
||||||
|
subject: gettext('Resources'),
|
||||||
|
items: ipanel
|
||||||
|
});
|
||||||
|
|
||||||
|
me.callParent();
|
||||||
|
|
||||||
|
if (!me.create) {
|
||||||
|
me.load({
|
||||||
|
success: function(response, options) {
|
||||||
|
var values = response.result.data;
|
||||||
|
|
||||||
|
if (values.nameserver) {
|
||||||
|
values.nameserver.replace(/[,;]/, ' ');
|
||||||
|
values.nameserver.replace(/^\s+/, '');
|
||||||
|
var nslist = values.nameserver.split(/\s+/);
|
||||||
|
values.dns1 = nslist[0];
|
||||||
|
values.dns2 = nslist[1];
|
||||||
|
values.dns3 = nslist[2];
|
||||||
|
}
|
||||||
|
|
||||||
|
ipanel.setValues(values);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
/*jslint confusion: true */
|
/*jslint confusion: true */
|
||||||
Ext.define('PVE.lxc.DNS', {
|
Ext.define('PVE.lxc.DNS', {
|
||||||
extend: 'PVE.grid.ObjectGrid',
|
extend: 'PVE.grid.ObjectGrid',
|
||||||
@ -41,30 +175,24 @@ Ext.define('PVE.lxc.DNS', {
|
|||||||
searchdomain: {
|
searchdomain: {
|
||||||
header: gettext('DNS domain'),
|
header: gettext('DNS domain'),
|
||||||
defaultValue: '',
|
defaultValue: '',
|
||||||
editor: caps.vms['VM.Config.Network'] ? {
|
editor: caps.vms['VM.Config.Network'] ? 'PVE.lxc.DNSEdit' : undefined,
|
||||||
xtype: 'pveWindowEdit',
|
renderer: function(value) {
|
||||||
subject: gettext('DNS domain'),
|
if (me.getObjectValue('nameserver') || me.getObjectValue('searchdomain')) {
|
||||||
items: {
|
return value;
|
||||||
xtype: 'pvetextfield',
|
}
|
||||||
name: 'searchdomain',
|
return gettext('use host settings');
|
||||||
fieldLabel: gettext('DNS domain'),
|
|
||||||
allowBlank: false
|
|
||||||
}
|
}
|
||||||
} : undefined
|
|
||||||
},
|
},
|
||||||
nameserver: {
|
nameserver: {
|
||||||
header: gettext('DNS server'),
|
header: gettext('DNS server'),
|
||||||
defaultValue: '',
|
defaultValue: '',
|
||||||
editor: caps.vms['VM.Config.Network'] ? {
|
editor: caps.vms['VM.Config.Network'] ? 'PVE.lxc.DNSEdit' : undefined,
|
||||||
xtype: 'pveWindowEdit',
|
renderer: function(value) {
|
||||||
subject: gettext('DNS server'),
|
if (me.getObjectValue('nameserver') || me.getObjectValue('searchdomain')) {
|
||||||
items: {
|
return value;
|
||||||
xtype: 'pvetextfield',
|
}
|
||||||
name: 'nameserver',
|
return gettext('use host settings');
|
||||||
fieldLabel: gettext('DNS server'),
|
|
||||||
allowBlank: false
|
|
||||||
}
|
}
|
||||||
} : undefined
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -87,14 +215,22 @@ Ext.define('PVE.lxc.DNS', {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var win;
|
||||||
|
if (Ext.isString(rowdef.editor)) {
|
||||||
|
win = Ext.create(rowdef.editor, {
|
||||||
|
pveSelNode: me.pveSelNode,
|
||||||
|
confid: rec.data.key,
|
||||||
|
url: '/api2/extjs/' + baseurl
|
||||||
|
});
|
||||||
|
} else {
|
||||||
var config = Ext.apply({
|
var config = Ext.apply({
|
||||||
pveSelNode: me.pveSelNode,
|
pveSelNode: me.pveSelNode,
|
||||||
confid: rec.data.key,
|
confid: rec.data.key,
|
||||||
url: '/api2/extjs/' + baseurl
|
url: '/api2/extjs/' + baseurl
|
||||||
}, rowdef.editor);
|
}, rowdef.editor);
|
||||||
var win = Ext.createWidget(rowdef.editor.xtype, config);
|
win = Ext.createWidget(rowdef.editor.xtype, config);
|
||||||
win.load();
|
}
|
||||||
|
//win.load();
|
||||||
win.show();
|
win.show();
|
||||||
win.on('destroy', reload);
|
win.on('destroy', reload);
|
||||||
};
|
};
|
||||||
@ -139,4 +275,3 @@ Ext.define('PVE.lxc.DNS', {
|
|||||||
me.on('show', reload);
|
me.on('show', reload);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user