Commit 085f9d9b authored by Dietmar Maurer's avatar Dietmar Maurer

clone GUI: add pool, simplify code

parent 07c85089
...@@ -3,31 +3,31 @@ Ext.define('PVE.window.Clone', { ...@@ -3,31 +3,31 @@ Ext.define('PVE.window.Clone', {
resizable: false, resizable: false,
isTemplate: false,
create_clone: function(snapname, name, newvmid, clonemode, storage, format, diskarray) { create_clone: function(values) {
var me = this; var me = this;
var params = { newid: newvmid }; var params = { newid: values.newvmid };
if (snapname && snapname !== 'current') { if (values.snapname && values.snapname !== 'current') {
params.snapname = snapname; params.snapname = values.snapname;
} }
if (name) { if (values.name) {
params.name = name; params.name = values.name;
} }
if (clonemode === 'full') { if (values.clonemode === 'copy') {
params.full = 1; params.full = 1;
if (storage) { if (values.storage) {
params.storage = storage; params.storage = values.storage;
if (format) { if (values.diskformat) {
params.format = format; params.format = values.diskformat;
} }
} }
} }
PVE.Utils.API2Request({ PVE.Utils.API2Request({
params: params, params: params,
url: '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/clone', url: '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/clone',
...@@ -43,28 +43,36 @@ Ext.define('PVE.window.Clone', { ...@@ -43,28 +43,36 @@ Ext.define('PVE.window.Clone', {
}, },
compute_sel1: function(clonefeature, istemplate, snapname) { verifyFeature: function() {
var me = this; var me = this;
var list = [];
list.push(['full', 'Full Clone']); var snapname = me.snapshotSel.getValue();
var clonemode = me.kv1.getValue();
if((clonefeature && istemplate === 1 && snapname === 'current') || (clonefeature && !istemplate && snapname !== 'current')){ var params = { feature: clonemode };
list.push(['linked', 'Linked Clone']); if (snapname !== 'current') {
params.snapname = snapname;
} }
me.kv1.store.loadData(list);
if((clonefeature && istemplate === 1 && snapname === 'current') || (clonefeature && !istemplate && snapname !== 'current')){ PVE.Utils.API2Request({
me.kv1.setValue('linked'); waitMsgTarget: me,
}else{ url: '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/feature',
me.kv1.setValue('full'); params: params,
} method: 'GET',
failure: function(response, opts) {
me.submitBtn.setDisabled(false);
Ext.Msg.alert('Error', response.htmlStatus);
},
success: function(response, options) {
me.submitBtn.setDisabled(response.result.data !== 1);
}
});
}, },
initComponent : function() { initComponent : function() {
/*jslint confusion: true */
var me = this; var me = this;
var diskarray = [];
if (!me.nodename) { if (!me.nodename) {
throw "no node name specified"; throw "no node name specified";
} }
...@@ -73,49 +81,58 @@ Ext.define('PVE.window.Clone', { ...@@ -73,49 +81,58 @@ Ext.define('PVE.window.Clone', {
throw "no VM ID specified"; throw "no VM ID specified";
} }
me.snapshotsel = Ext.create('PVE.form.SnapshotSelector', { if (!me.snapname) {
name: 'snapname', me.snapname = 'current';
fieldLabel: 'Snapshot', }
nodename: me.nodename,
vmid: me.vmid, var col1 = [];
disabled: false, var col2 = [];
hidden: me.istemplate ? true : false,
allowBlank: false, var modelist = [['copy', 'Full Clone']];
value : me.snapname, if (me.isTemplate) {
listeners: { modelist.push(['clone', 'Linked Clone']);
change: function(f, value) { }
var clonefeature; me.kv1 = Ext.create('PVE.form.KVComboBox', {
var snapname = value; fieldLabel: 'Clone Mode',
//check if linked clone feature is available name: 'clonemode',
var params = { feature: 'clone' }; allowBlank: false,
if (value !== 'current') { value: me.isTemplate ? 'clone' : 'copy',
params.snapname = snapname; data: modelist
} });
PVE.Utils.API2Request({ me.mon(me.kv1, 'change', function(t, value) {
waitMsgTarget: me, if (value === 'copy') {
url: '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/feature', me.hdstoragesel.setDisabled(false);
params: params, me.formatsel.setDisabled(false);
method: 'GET', } else {
success: function(response, options) { me.hdstoragesel.setDisabled(true);
var res = response.result.data; me.formatsel.setDisabled(true);
}
if (res === 1) { me.verifyFeature();
clonefeature = 1; });
}
me.compute_sel1(clonefeature, me.istemplate, snapname); col1.push(me.kv1);
}
}); me.snapshotSel = Ext.create('PVE.form.SnapshotSelector', {
} name: 'snapname',
fieldLabel: 'Snapshot',
nodename: me.nodename,
vmid: me.vmid,
hidden: me.isTemplate ? true : false,
disabled: false,
allowBlank: false,
value : me.snapname,
listeners: {
change: function(f, value) {
me.verifyFeature();
} }
}
}); });
var items = []; col1.push(me.snapshotSel);
items.push(me.snapshotsel); col1.push(
items.push(
{ {
xtype: 'pveVMIDSelector', xtype: 'pveVMIDSelector',
name: 'newvmid', name: 'newvmid',
...@@ -132,7 +149,7 @@ Ext.define('PVE.window.Clone', { ...@@ -132,7 +149,7 @@ Ext.define('PVE.window.Clone', {
); );
me.hdstoragesel = Ext.create('PVE.form.StorageSelector', { me.hdstoragesel = Ext.create('PVE.form.StorageSelector', {
name: 'hdstorage', name: 'storage',
nodename: me.nodename, nodename: me.nodename,
fieldLabel: 'Target Storage', fieldLabel: 'Target Storage',
storageContent: 'images', storageContent: 'images',
...@@ -171,103 +188,71 @@ Ext.define('PVE.window.Clone', { ...@@ -171,103 +188,71 @@ Ext.define('PVE.window.Clone', {
allowBlank: false allowBlank: false
}); });
me.kv1 = Ext.create('PVE.form.KVComboBox', { col2.push({
fieldLabel: 'Clone Mode', xtype: 'pvePoolSelector',
name: 'clonemode', fieldLabel: gettext('Resource Pool'),
allowBlank: false, name: 'pool',
data: [] value: '',
}); allowBlank: true
});
me.mon(me.kv1, 'change', function(t, value) {
if (value === 'full') {
me.hdstoragesel.setDisabled(false);
}else{
me.hdstoragesel.setDisabled(true);
me.formatsel.setDisabled(true);
}
});
items.push(me.kv1); col2.push(me.hdstoragesel);
items.push(me.hdstoragesel); col2.push(me.formatsel);
items.push(me.formatsel);
me.formPanel = Ext.create('Ext.form.Panel', { me.formPanel = Ext.create('Ext.form.Panel', {
bodyPadding: 10, bodyPadding: 10,
border: false, border: false,
layout: 'column',
defaultType: 'container',
columns: 2,
fieldDefaults: { fieldDefaults: {
labelWidth: 100, labelWidth: 100,
anchor: '100%' anchor: '100%'
}, },
items: items items: [
{
columnWidth: 0.5,
padding: '0 10 0 0',
layout: 'anchor',
items: col1
},
{
columnWidth: 0.5,
padding: '0 0 0 10',
layout: 'anchor',
items: col2
}
]
}); });
var form = me.formPanel.getForm(); var form = me.formPanel.getForm();
var submitBtn; var titletext = me.isTemplate ? "Template" : "VM";
var titletext = me.istemplate ? "Template" : "VM";
me.title = "Clone " + titletext + " " + me.vmid; me.title = "Clone " + titletext + " " + me.vmid;
submitBtn = Ext.create('Ext.Button', {
me.submitBtn = Ext.create('Ext.Button', {
text: gettext('Clone'), text: gettext('Clone'),
disabled: true,
handler: function() { handler: function() {
if (form.isValid()) { if (form.isValid()) {
var values = form.getValues(); var values = form.getValues();
me.create_clone(values.snapname, values.name, values.newvmid, values.clonemode, values.hdstorage, values.diskformat, diskarray); me.create_clone(values);
} }
} }
}); });
Ext.apply(me, { Ext.apply(me, {
modal: true, modal: true,
width: 350, width: 600,
height: 250, height: 250,
border: false, border: false,
layout: 'fit', layout: 'fit',
buttons: [ submitBtn ], buttons: [ me.submitBtn ],
items: [ me.formPanel ] items: [ me.formPanel ]
}); });
me.callParent(); me.callParent();
if (!me.snapname) { me.verifyFeature();
return;
}
me.compute_sel1(me.clonefeature, me.istemplate, me.snapname);
var url;
if (me.snapsname) {
url = '/nodes/' + me.nodename + '/qemu/' + me.vmid + "/snapshot/" + me.snapname + '/config';
} else {
url = '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/config';
}
PVE.Utils.API2Request({
url: url,
waitMsgTarget: me,
method: 'GET',
failure: function(response, opts) {
Ext.Msg.alert('Error', response.htmlStatus);
me.close();
},
success: function(response, options) {
var data = response.result.data;
Ext.Object.each(data, function(key, value) {
var drive = PVE.Parser.parseQemuDrive(key, value);
if (drive) {
var match = drive.file.match(/^([^:]+):/);
if (match) {
diskarray.push(key);
}
}
});
}
});
} }
}); });
...@@ -82,7 +82,6 @@ Ext.define('PVE.qemu.CmdMenu', { ...@@ -82,7 +82,6 @@ Ext.define('PVE.qemu.CmdMenu', {
icon: '/pve2/images/forward.png', icon: '/pve2/images/forward.png',
handler: function() { handler: function() {
var win = Ext.create('PVE.window.Clone', { var win = Ext.create('PVE.window.Clone', {
snapname: 'current',
nodename: nodename, nodename: nodename,
vmid: vmid vmid: vmid
}); });
...@@ -90,7 +89,7 @@ Ext.define('PVE.qemu.CmdMenu', { ...@@ -90,7 +89,7 @@ Ext.define('PVE.qemu.CmdMenu', {
} }
}, },
{ {
text: gettext('Convert To Template'), text: gettext('Convert to template'),
icon: '/pve2/images/forward.png', icon: '/pve2/images/forward.png',
handler: function() { handler: function() {
var msg = Ext.String.format(gettext("Do you really want convert VM {0} to template (You'll can use the VM anymore)?"), vmid); var msg = Ext.String.format(gettext("Do you really want convert VM {0} to template (You'll can use the VM anymore)?"), vmid);
......
...@@ -48,30 +48,12 @@ Ext.define('PVE.qemu.TemplateMenu', { ...@@ -48,30 +48,12 @@ Ext.define('PVE.qemu.TemplateMenu', {
text: gettext('Clone'), text: gettext('Clone'),
icon: '/pve2/images/forward.png', icon: '/pve2/images/forward.png',
handler: function() { handler: function() {
var clonefeature; var win = Ext.create('PVE.window.Clone', {
//check if linked clone feature is available nodename: nodename,
var params = { feature: 'clone' }; vmid: vmid,
isTemplate: template
PVE.Utils.API2Request({
waitMsgTarget: me,
url: '/nodes/' + nodename + '/qemu/' + vmid + '/feature',
params: params,
method: 'GET',
success: function(response, options) {
var res = response.result.data;
if (res === 1) {
clonefeature = 1;
}
var win = Ext.create('PVE.window.Clone', {
snapname: 'current',
nodename: nodename,
vmid: vmid,
istemplate: template,
clonefeature: clonefeature
});
win.show();
}
}); });
win.show();
} }
} }
]; ];
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment