improve snapshot tree GUI

Add dynamic updates, sort correctly.
This commit is contained in:
Dietmar Maurer 2012-09-13 11:07:03 +02:00
parent 5465dda8e7
commit d0780afcb0
5 changed files with 90 additions and 36 deletions

View File

@ -90,12 +90,6 @@
background-image:url(../images/snapshot.png); background-image:url(../images/snapshot.png);
} }
.x-tree-node-now,
.x-grid-tree-node-expanded .x-tree-node-now
{
background-image:url(../images/now.png);
}
.pve-itype-icon-pool, .pve-itype-icon-pool,
.x-tree-node-pool, .x-tree-node-pool,
.x-grid-tree-pool-expanded .x-tree-node-pool .x-grid-tree-pool-expanded .x-tree-node-pool

View File

@ -20,7 +20,6 @@ GNOME_IMAGES = \
IMAGES = ${GNOME_IMAGES} \ IMAGES = ${GNOME_IMAGES} \
snapshot.png \ snapshot.png \
now.png \
computer-on.png \ computer-on.png \
memory.png \ memory.png \
processor.png \ processor.png \

Binary file not shown.

Before

Width:  |  Height:  |  Size: 948 B

View File

@ -20,10 +20,9 @@ Ext.define('PVE.window.Snapshot', {
success: function(response, options) { success: function(response, options) {
var upid = response.result.data; var upid = response.result.data;
var win = Ext.create('PVE.window.TaskViewer', { // we do not show task viewer for now
upid: upid //var win = Ext.create('PVE.window.TaskViewer', { upid: upid });
}); //win.show();
win.show();
me.close(); me.close();
} }
}); });
@ -81,7 +80,7 @@ Ext.define('PVE.window.Snapshot', {
uncheckedValue: 0, uncheckedValue: 0,
defaultValue: 0, defaultValue: 0,
checked: 1, checked: 1,
fieldLabel: 'Include State' fieldLabel: 'Include RAM'
}); });
} }

View File

@ -2,43 +2,73 @@ Ext.define('PVE.qemu.SnapshotTree', {
extend: 'Ext.tree.Panel', extend: 'Ext.tree.Panel',
alias: ['widget.pveQemuSnapshotTree'], alias: ['widget.pveQemuSnapshotTree'],
reload: function() { load_delay: 3000,
old_digest: 'invalid',
sorterFn: function(rec1, rec2) {
var v1 = rec1.data.snaptime;
var v2 = rec2.data.snaptime;
if (rec1.data.name === 'current') {
return 1;
}
if (rec2.data.name === 'current') {
return -1;
}
console.log("SORT " + v1 + " " + v2);
return (v1 > v2 ? 1 : (v1 < v2 ? -1 : 0));
},
reload: function(repeat) {
var me = this; var me = this;
PVE.Utils.API2Request({ PVE.Utils.API2Request({
url: '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/snapshot', url: '/nodes/' + me.nodename + '/qemu/' + me.vmid + '/snapshot',
waitMsgTarget: me,
method: 'GET', method: 'GET',
failure: function(response, opts) { failure: function(response, opts) {
PVE.Utils.setErrorMask(me, response.htmlStatus); PVE.Utils.setErrorMask(me, response.htmlStatus);
me.load_task.delay(me.load_delay);
}, },
success: function(response, opts) { success: function(response, opts) {
var digest = 'invalid';
var idhash = {}; var idhash = {};
var root = { name: '__root', expanded: true, children: [] }; var root = { name: '__root', expanded: true, children: [] };
Ext.Array.each(response.result.data, function(item) { Ext.Array.each(response.result.data, function(item) {
item.leaf = true; item.leaf = true;
item.children = []; item.children = [];
if (item.name === '__current') { if (item.name === 'current') {
item.iconCls = 'x-tree-node-now'; digest = item.digest + item.running;
if (item.running) {
item.iconCls = 'x-tree-node-computer-running';
} else {
item.iconCls = 'x-tree-node-computer';
}
} else { } else {
item.iconCls = 'x-tree-node-snapshot'; item.iconCls = 'x-tree-node-snapshot';
} }
idhash[item.name] = item; idhash[item.name] = item;
}); });
Ext.Array.each(response.result.data, function(item) { if (digest !== me.old_digest) {
if (item.parent && idhash[item.parent]) { me.old_digest = digest;
var parent_item = idhash[item.parent];
parent_item.children.push(item);
parent_item.leaf = false;
parent_item.expanded = true;
} else {
root.children.push(item);
}
});
me.setRootNode(root); Ext.Array.each(response.result.data, function(item) {
if (item.parent && idhash[item.parent]) {
var parent_item = idhash[item.parent];
parent_item.children.push(item);
parent_item.leaf = false;
parent_item.expanded = true;
} else {
root.children.push(item);
}
});
me.setRootNode(root);
}
me.load_task.delay(me.load_delay);
} }
}); });
}, },
@ -56,12 +86,18 @@ Ext.define('PVE.qemu.SnapshotTree', {
throw "no VM ID specified"; throw "no VM ID specified";
} }
me.load_task = new Ext.util.DelayedTask(me.reload, me);
var sm = Ext.create('Ext.selection.RowModel', {}); var sm = Ext.create('Ext.selection.RowModel', {});
var valid_snapshot = function(record) { var valid_snapshot = function(record) {
return record && record.data && record.data.name && return record && record.data && record.data.name &&
record.data.name !== '__current'; record.data.name !== '__current';
}; };
var valid_snapshot_rollback = function(record) {
return record && record.data && record.data.name &&
record.data.name !== '__current' && !record.data.snapstate;
};
var run_editor = function() { var run_editor = function() {
var rec = sm.getSelection()[0]; var rec = sm.getSelection()[0];
@ -90,7 +126,7 @@ Ext.define('PVE.qemu.SnapshotTree', {
text: gettext('Rollback'), text: gettext('Rollback'),
disabled: true, disabled: true,
selModel: sm, selModel: sm,
enableFn: valid_snapshot, enableFn: valid_snapshot_rollback,
handler: function(btn, event) { handler: function(btn, event) {
var rec = sm.getSelection()[0]; var rec = sm.getSelection()[0];
if (!rec) { if (!rec) {
@ -154,10 +190,11 @@ Ext.define('PVE.qemu.SnapshotTree', {
layout: 'fit', layout: 'fit',
rootVisible: false, rootVisible: false,
animate: false, animate: false,
sortableColumns: false,
selModel: sm, selModel: sm,
tbar: [ snapshotBtn, rollbackBtn, removeBtn, editBtn ], tbar: [ snapshotBtn, rollbackBtn, removeBtn, editBtn ],
fields: [ fields: [
'name', 'description', 'name', 'description', 'snapstate', 'vmstate', 'running',
{ name: 'snaptime', type: 'date', dateFormat: 'timestamp' } { name: 'snaptime', type: 'date', dateFormat: 'timestamp' }
], ],
columns: [ columns: [
@ -167,7 +204,7 @@ Ext.define('PVE.qemu.SnapshotTree', {
dataIndex: 'name', dataIndex: 'name',
width: 200, width: 200,
renderer: function(value, metaData, record) { renderer: function(value, metaData, record) {
if (value === '__current') { if (value === 'current') {
return "NOW"; return "NOW";
} else { } else {
return value; return value;
@ -175,18 +212,37 @@ Ext.define('PVE.qemu.SnapshotTree', {
} }
}, },
{ {
xtype: 'datecolumn', text: gettext('RAM'),
text: gettext('Date'), align: 'center',
resizable: false,
dataIndex: 'vmstate',
width: 50,
renderer: function(value, metaData, record) {
if (record.data.name !== 'current') {
return PVE.Utils.format_boolean(value);
}
}
},
{
text: gettext('Date') + "/" + gettext("State"),
dataIndex: 'snaptime', dataIndex: 'snaptime',
format: 'Y-m-d H:i:s', resizable: false,
width: 120 width: 120,
renderer: function(value, metaData, record) {
if (record.data.snapstate) {
return record.data.snapstate;
}
if (value) {
return Ext.Date.format(value,'Y-m-d H:i:s');
}
}
}, },
{ {
text: gettext('Description'), text: gettext('Description'),
dataIndex: 'description', dataIndex: 'description',
flex: 1, flex: 1,
renderer: function(value, metaData, record) { renderer: function(value, metaData, record) {
if (record.data.name === '__current') { if (record.data.name === 'current') {
return gettext("You are here!"); return gettext("You are here!");
} else { } else {
return value; return value;
@ -197,11 +253,17 @@ Ext.define('PVE.qemu.SnapshotTree', {
columnLines: true, // will work in 4.1? columnLines: true, // will work in 4.1?
listeners: { listeners: {
show: me.reload, show: me.reload,
hide: me.load_task.cancel,
destroy: me.load_task.cancel,
itemdblclick: run_editor itemdblclick: run_editor
} }
}); });
me.callParent(); me.callParent();
me.store.sorters.add(new Ext.util.Sorter({
sorterFn: me.sorterFn
}));
} }
}); });