add monitor GUI
This commit is contained in:
parent
e0a6a27469
commit
f5c5dcfa90
@ -75,6 +75,7 @@ JSSRC= \
|
||||
node/Config.js \
|
||||
qemu/StatusView.js \
|
||||
qemu/Migrate.js \
|
||||
qemu/Monitor.js \
|
||||
qemu/Summary.js \
|
||||
qemu/OSTypeEdit.js \
|
||||
qemu/ProcessorEdit.js \
|
||||
|
@ -37,6 +37,11 @@ Ext.define('PVE.qemu.Config', {
|
||||
itemId: 'options',
|
||||
xtype: 'PVE.qemu.Options'
|
||||
},
|
||||
{
|
||||
title: 'Monitor',
|
||||
itemId: 'monitor',
|
||||
xtype: 'pveQemuMonitor'
|
||||
},
|
||||
/*
|
||||
{
|
||||
xtype: 'pveKVMConsole',
|
||||
|
111
www/manager/qemu/Monitor.js
Normal file
111
www/manager/qemu/Monitor.js
Normal file
@ -0,0 +1,111 @@
|
||||
Ext.define('PVE.qemu.Monitor', {
|
||||
extend: 'Ext.panel.Panel',
|
||||
|
||||
alias: 'widget.pveQemuMonitor',
|
||||
|
||||
maxLines: 500,
|
||||
|
||||
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 lines = [];
|
||||
|
||||
var textbox = Ext.createWidget('panel', {
|
||||
region: 'center',
|
||||
xtype: 'panel',
|
||||
autoScroll: true,
|
||||
border: true,
|
||||
margins: '5 5 5 5',
|
||||
bodyStyle: 'font-family: monospace;white-space: pre;'
|
||||
});
|
||||
|
||||
var scrollToEnd = function() {
|
||||
var el = textbox.getTargetEl();
|
||||
var dom = Ext.getDom(el);
|
||||
dom.scrollTop = dom.scrollHeight - dom.clientHeight;
|
||||
}
|
||||
|
||||
var refresh = function() {
|
||||
textbox.update(lines.join('\n'));
|
||||
scrollToEnd();
|
||||
};
|
||||
|
||||
var addLine = function(line) {
|
||||
lines.push(line);
|
||||
if (lines.length > me.maxLines) {
|
||||
lines.shift();
|
||||
}
|
||||
};
|
||||
|
||||
var executeCmd = function(cmd) {
|
||||
addLine("# " + Ext.htmlEncode(cmd));
|
||||
refresh();
|
||||
PVE.Utils.API2Request({
|
||||
params: { command: cmd },
|
||||
url: '/nodes/' + nodename + '/qemu/' + vmid + "/monitor",
|
||||
method: 'POST',
|
||||
waitMsgTarget: me,
|
||||
success: function(response, opts) {
|
||||
var res = response.result.data;
|
||||
Ext.Array.each(res.split('\n'), function(line) {
|
||||
addLine(Ext.htmlEncode(line));
|
||||
});
|
||||
refresh();
|
||||
},
|
||||
failure: function(response, opts) {
|
||||
Ext.Msg.alert('Error', response.htmlStatus);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
Ext.apply(me, {
|
||||
layout: { type: 'border' },
|
||||
border: false,
|
||||
items: [
|
||||
textbox,
|
||||
{
|
||||
region: 'south',
|
||||
margins:'0 5 5 5',
|
||||
border: false,
|
||||
xtype: 'textfield',
|
||||
name: 'cmd',
|
||||
value: '',
|
||||
fieldStyle: 'font-family: monospace;',
|
||||
allowBlank: true,
|
||||
listeners: {
|
||||
afterrender: function(f) {
|
||||
f.focus(false);
|
||||
addLine("Type 'help' for help.");
|
||||
refresh();
|
||||
},
|
||||
specialkey: function(f, e) {
|
||||
if (e.getKey() === e.ENTER) {
|
||||
var cmd = f.getValue();
|
||||
f.setValue('');
|
||||
executeCmd(cmd);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
],
|
||||
listeners: {
|
||||
show: function() {
|
||||
var field = me.query('textfield[name="cmd"]')[0];
|
||||
field.focus(false, true);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
me.callParent();
|
||||
}
|
||||
});
|
Loading…
x
Reference in New Issue
Block a user