[pve-devel] [PATCH 4/6] add template right-click menu

Alexandre Derumier aderumier at odiso.com
Mon Apr 22 17:56:07 CEST 2013


Signed-off-by: Alexandre Derumier <aderumier at odiso.com>
---
 www/manager/Makefile             |    1 +
 www/manager/qemu/TemplateMenu.js |   81 ++++++++++++++++++++++++++++++++++++++
 www/manager/tree/ResourceTree.js |    6 ++-
 3 files changed, 87 insertions(+), 1 deletion(-)
 create mode 100644 www/manager/qemu/TemplateMenu.js

diff --git a/www/manager/Makefile b/www/manager/Makefile
index 7b46f09..013e762 100644
--- a/www/manager/Makefile
+++ b/www/manager/Makefile
@@ -7,6 +7,7 @@ JSSRC= 				                 	\
 	button/Button.js				\
 	qemu/SendKeyMenu.js				\
 	qemu/CmdMenu.js					\
+	qemu/TemplateMenu.js				\
 	openvz/CmdMenu.js				\
 	VNCConsole.js					\
 	data/TimezoneStore.js				\
diff --git a/www/manager/qemu/TemplateMenu.js b/www/manager/qemu/TemplateMenu.js
new file mode 100644
index 0000000..70ce034
--- /dev/null
+++ b/www/manager/qemu/TemplateMenu.js
@@ -0,0 +1,81 @@
+Ext.define('PVE.qemu.TemplateMenu', {
+    extend: 'Ext.menu.Menu',
+
+    initComponent: function() {
+	var me = this;
+
+	var nodename = me.pveSelNode.data.node;
+	if (!nodename) {
+	    throw "no node name specified";
+	}
+
+	var vmid = me.pveSelNode.data.vmid;
+	if (!vmid) {
+	    throw "no VM ID specified";
+	}
+
+	var vmname = me.pveSelNode.data.name;
+
+	var template = me.pveSelNode.data.template;
+
+	var vm_command = function(cmd, params) {
+	    PVE.Utils.API2Request({
+		params: params,
+		url: '/nodes/' + nodename + '/qemu/' + vmid + "/status/" + cmd,
+		method: 'POST',
+		failure: function(response, opts) {
+		    Ext.Msg.alert('Error', response.htmlStatus);
+		}
+	    });
+	};
+
+	me.title = "VM " + vmid;
+
+	me.items = [
+	    {
+		text: gettext('Migrate'),
+		icon: '/pve2/images/forward.png',
+		handler: function() {
+		    var win = Ext.create('PVE.window.Migrate', {
+			vmtype: 'qemu',
+			nodename: nodename,
+			vmid: vmid
+		    });
+		    win.show();
+		}
+	    },
+	    {
+		text: gettext('Clone To VM'),
+		icon: '/pve2/images/forward.png',
+		handler: function() {
+		    var clonefeature;
+		    //check if linked clone feature is available
+		    var params = { feature: 'clone' };
+
+		    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();
+			}
+		    });
+		}
+	    },
+	];
+
+	me.callParent();
+    }
+});
diff --git a/www/manager/tree/ResourceTree.js b/www/manager/tree/ResourceTree.js
index 8a21330..f46c2c8 100644
--- a/www/manager/tree/ResourceTree.js
+++ b/www/manager/tree/ResourceTree.js
@@ -326,10 +326,14 @@ Ext.define('PVE.tree.ResourceTree', {
 		    //v.select(record);
 		    var menu;
 		    
-		    if (record.data.type === 'qemu') {
+		    if (record.data.type === 'qemu' && !record.data.template) {
 			menu = Ext.create('PVE.qemu.CmdMenu', {
 			    pveSelNode: record
 			});
+		    } else if (record.data.type === 'qemu' && record.data.template) {
+			menu = Ext.create('PVE.qemu.TemplateMenu', {
+			    pveSelNode: record
+			});
 		    } else if (record.data.type === 'openvz') {
 			menu = Ext.create('PVE.openvz.CmdMenu', {
 			    pveSelNode: record
-- 
1.7.10.4




More information about the pve-devel mailing list