mirror of
https://git.proxmox.com/git/pve-manager
synced 2025-08-08 03:02:04 +00:00
ui: add qemu/MultiHDEdit and use it in the wizard
uses the MultiDiskPanel as base and implements the necessary functions/variables this allows now to create a vm also without any disk Signed-off-by: Dominik Csapak <d.csapak@proxmox.com> Tested-by: Lorenz Stechauner <l.stechauner@proxmox.com> Tested-by: Aaron Lauterer <a.lauterer@proxmox.com>
This commit is contained in:
parent
af07d3d3d6
commit
9dbc4dfa88
@ -217,6 +217,7 @@ JSSRC= \
|
|||||||
qemu/MachineEdit.js \
|
qemu/MachineEdit.js \
|
||||||
qemu/MemoryEdit.js \
|
qemu/MemoryEdit.js \
|
||||||
qemu/Monitor.js \
|
qemu/Monitor.js \
|
||||||
|
qemu/MultiHDEdit.js \
|
||||||
qemu/NetworkEdit.js \
|
qemu/NetworkEdit.js \
|
||||||
qemu/OSDefaults.js \
|
qemu/OSDefaults.js \
|
||||||
qemu/OSTypeEdit.js \
|
qemu/OSTypeEdit.js \
|
||||||
|
@ -154,14 +154,11 @@ Ext.define('PVE.qemu.CreateWizard', {
|
|||||||
insideWizard: true,
|
insideWizard: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
xtype: 'pveQemuHDInputPanel',
|
xtype: 'pveMultiHDPanel',
|
||||||
padding: 0,
|
|
||||||
bind: {
|
bind: {
|
||||||
nodename: '{nodename}',
|
nodename: '{nodename}',
|
||||||
},
|
},
|
||||||
title: gettext('Hard Disk'),
|
title: gettext('Disks'),
|
||||||
isCreate: true,
|
|
||||||
insideWizard: true,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
xtype: 'pveQemuProcessorPanel',
|
xtype: 'pveQemuProcessorPanel',
|
||||||
|
@ -107,6 +107,12 @@ Ext.define('PVE.qemu.HDInputPanel', {
|
|||||||
return params;
|
return params;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateVMConfig: function(vmconfig) {
|
||||||
|
var me = this;
|
||||||
|
me.vmconfig = vmconfig;
|
||||||
|
me.bussel?.updateVMConfig(vmconfig);
|
||||||
|
},
|
||||||
|
|
||||||
setVMConfig: function(vmconfig) {
|
setVMConfig: function(vmconfig) {
|
||||||
var me = this;
|
var me = this;
|
||||||
|
|
||||||
@ -183,7 +189,8 @@ Ext.define('PVE.qemu.HDInputPanel', {
|
|||||||
|
|
||||||
if (!me.confid || me.unused) {
|
if (!me.confid || me.unused) {
|
||||||
me.bussel = Ext.create('PVE.form.ControllerSelector', {
|
me.bussel = Ext.create('PVE.form.ControllerSelector', {
|
||||||
vmconfig: me.insideWizard ? { ide2: 'cdrom' } : {},
|
vmconfig: me.vmconfig,
|
||||||
|
selectFree: true,
|
||||||
});
|
});
|
||||||
column1.push(me.bussel);
|
column1.push(me.bussel);
|
||||||
|
|
||||||
|
62
www/manager6/qemu/MultiHDEdit.js
Normal file
62
www/manager6/qemu/MultiHDEdit.js
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
Ext.define('PVE.qemu.MultiHDPanel', {
|
||||||
|
extend: 'PVE.panel.MultiDiskPanel',
|
||||||
|
alias: 'widget.pveMultiHDPanel',
|
||||||
|
|
||||||
|
onlineHelp: 'qm_hard_disk',
|
||||||
|
|
||||||
|
controller: {
|
||||||
|
xclass: 'Ext.app.ViewController',
|
||||||
|
|
||||||
|
// maxCount is the sum of all controller ids - 1 (ide2 is fixed in the wizard)
|
||||||
|
maxCount: Object.values(PVE.Utils.diskControllerMaxIDs)
|
||||||
|
.reduce((previous, current) => previous+current, 0) - 1,
|
||||||
|
|
||||||
|
getNextFreeDisk: function(vmconfig) {
|
||||||
|
let clist = PVE.Utils.sortByPreviousUsage(vmconfig);
|
||||||
|
return PVE.Utils.nextFreeDisk(clist, vmconfig);
|
||||||
|
},
|
||||||
|
|
||||||
|
addPanel: function(itemId, vmconfig, nextFreeDisk) {
|
||||||
|
let me = this;
|
||||||
|
return me.getView().add({
|
||||||
|
vmconfig,
|
||||||
|
border: false,
|
||||||
|
showAdvanced: Ext.state.Manager.getProvider().get('proxmox-advanced-cb'),
|
||||||
|
xtype: 'pveQemuHDInputPanel',
|
||||||
|
bind: {
|
||||||
|
nodename: '{nodename}',
|
||||||
|
},
|
||||||
|
padding: '0 0 0 5',
|
||||||
|
itemId,
|
||||||
|
isCreate: true,
|
||||||
|
insideWizard: true,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
getBaseVMConfig: function() {
|
||||||
|
let me = this;
|
||||||
|
let vm = me.getViewModel();
|
||||||
|
|
||||||
|
return {
|
||||||
|
ide2: 'media=cdrom',
|
||||||
|
scsihw: vm.get('current.scsihw'),
|
||||||
|
ostype: vm.get('current.ostype'),
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
diskSorter: {
|
||||||
|
sorterFn: function(rec1, rec2) {
|
||||||
|
let [, name1, id1] = PVE.Utils.bus_match.exec(rec1.data.name);
|
||||||
|
let [, name2, id2] = PVE.Utils.bus_match.exec(rec2.data.name);
|
||||||
|
|
||||||
|
if (name1 === name2) {
|
||||||
|
return parseInt(id1, 10) - parseInt(id2, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
return name1 < name2 ? -1 : 1;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
deleteDisabled: () => false,
|
||||||
|
},
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user