for example, allow starting from contextmenu
only if vm/ct is stopped, etc.

Signed-off-by: Dominik Csapak <d.csa...@proxmox.com>
---
 www/manager6/lxc/CmdMenu.js  | 21 +++++++++++++++++++++
 www/manager6/qemu/CmdMenu.js | 21 +++++++++++++++++++++
 2 files changed, 42 insertions(+)

diff --git a/www/manager6/lxc/CmdMenu.js b/www/manager6/lxc/CmdMenu.js
index 5046269..5f0c428 100644
--- a/www/manager6/lxc/CmdMenu.js
+++ b/www/manager6/lxc/CmdMenu.js
@@ -27,12 +27,29 @@ Ext.define('PVE.lxc.CmdMenu', {
            });
        };
 
+       var running = false;
+       var stopped = true;
+       var suspended = false;
+
+       switch (me.pveSelNode.data.status) {
+           case 'running':
+               running = true;
+               stopped = false;
+               break;
+           case 'paused':
+               stopped = false;
+               suspended = true;
+               break;
+           default: break;
+       }
+
        me.title = 'CT ' + vmid;
 
        me.items = [
            {
                text: gettext('Start'),
                iconCls: 'fa fa-fw fa-play',
+               disabled: running,
                handler: function() {
                    vm_command('start');
                }
@@ -52,6 +69,7 @@ Ext.define('PVE.lxc.CmdMenu', {
            {
                text: gettext('Suspend'),
                iconCls: 'fa fa-fw fa-pause',
+               disabled: stopped || suspended,
                handler: function() {
                    var msg = Ext.String.format(gettext("Do you really want to 
suspend {0}?"), 'CT ' + vmid);
                    Ext.Msg.confirm(gettext('Confirm'), msg, function(btn) {
@@ -66,6 +84,7 @@ Ext.define('PVE.lxc.CmdMenu', {
            {
                text: gettext('Resume'),
                iconCls: 'fa fa-fw fa-play',
+               disabled: !suspended,
                handler: function() {
                    vm_command('resume');
                }
@@ -73,6 +92,7 @@ Ext.define('PVE.lxc.CmdMenu', {
            {
                text: gettext('Shutdown'),
                iconCls: 'fa fa-fw fa-power-off',
+               disabled: stopped || suspended,
                handler: function() {
                    var msg = Ext.String.format(gettext("Do you really want to 
shutdown {0}?"), 'CT ' + vmid);
                    Ext.Msg.confirm(gettext('Confirm'), msg, function(btn) {
@@ -87,6 +107,7 @@ Ext.define('PVE.lxc.CmdMenu', {
            {
                text: gettext('Stop'),
                iconCls: 'fa fa-fw fa-stop',
+               disabled: stopped,
                handler: function() {
                    var msg = Ext.String.format(gettext("Do you really want to 
stop {0}?"), 'CT ' + vmid);
                    Ext.Msg.confirm(gettext('Confirm'), msg, function(btn) {
diff --git a/www/manager6/qemu/CmdMenu.js b/www/manager6/qemu/CmdMenu.js
index a5261c3..79bfe38 100644
--- a/www/manager6/qemu/CmdMenu.js
+++ b/www/manager6/qemu/CmdMenu.js
@@ -27,12 +27,29 @@ Ext.define('PVE.qemu.CmdMenu', {
            });
        };
 
+       var running = false;
+       var stopped = true;
+       var suspended = false;
+
+       switch (me.pveSelNode.data.status) {
+           case 'running':
+               running = true;
+               stopped = false;
+               break;
+           case 'paused':
+               stopped = false;
+               suspended = true;
+               break;
+           default: break;
+       }
+
        me.title = "VM " + vmid;
 
        me.items = [
            {
                text: gettext('Start'),
                iconCls: 'fa fa-fw fa-play',
+               disabled: running,
                handler: function() {
                    vm_command('start');
                }
@@ -52,6 +69,7 @@ Ext.define('PVE.qemu.CmdMenu', {
            {
                text: gettext('Suspend'),
                iconCls: 'fa fa-fw fa-pause',
+               disabled: stopped || suspended,
                handler: function() {
                    var msg = Ext.String.format(gettext("Do you really want to 
suspend {0}?"), 'VM ' + vmid);
                    Ext.Msg.confirm(gettext('Confirm'), msg, function(btn) {
@@ -65,6 +83,7 @@ Ext.define('PVE.qemu.CmdMenu', {
            {
                text: gettext('Resume'),
                iconCls: 'fa fa-fw fa-play',
+               disabled: !suspended,
                handler: function() {
                    vm_command('resume');
                }
@@ -72,6 +91,7 @@ Ext.define('PVE.qemu.CmdMenu', {
            {
                text: gettext('Shutdown'),
                iconCls: 'fa fa-fw fa-power-off',
+               disabled: stopped || suspended,
                handler: function() {
                    var msg = Ext.String.format(gettext("Do you really want to 
shutdown {0}?"), 'VM ' + vmid);
                    Ext.Msg.confirm(gettext('Confirm'), msg, function(btn) {
@@ -86,6 +106,7 @@ Ext.define('PVE.qemu.CmdMenu', {
            {
                text: gettext('Stop'),
                iconCls: 'fa fa-fw fa-stop',
+               disabled: stopped,
                handler: function() {
                    var msg = Ext.String.format(gettext("Do you really want to 
stop {0}?"), 'VM ' + vmid);
                    Ext.Msg.confirm(gettext('Confirm'), msg, function(btn) {
-- 
2.1.4


_______________________________________________
pve-devel mailing list
pve-devel@pve.proxmox.com
http://pve.proxmox.com/cgi-bin/mailman/listinfo/pve-devel

Reply via email to