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;' }); var scrollToEnd = function() { var el = textbox.getTargetEl(); var dom = Ext.getDom(el); var clientHeight = dom.clientHeight; // BrowserBug: clientHeight reports 0 in IE9 StrictMode // Instead we are using offsetHeight and hardcoding borders if (Ext.isIE9 && Ext.isStrict) { clientHeight = dom.offsetHeight + 2; } dom.scrollTop = dom.scrollHeight - 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);
} else if (e.getKey() === e.PAGE_UP) {
textbox.scrollBy(0, -0.9*textbox.getHeight(), false);
} else if (e.getKey() === e.PAGE_DOWN) {
textbox.scrollBy(0, 0.9*textbox.getHeight(), false);
}
}
}
}
],
listeners: {
show: function() {
var field = me.query('textfield[name="cmd"]')[0];
field.focus(false, true);
}
}
});
me.callParent();
}
});