mirror of
https://git.proxmox.com/git/pve-manager
synced 2025-08-07 02:23:23 +00:00
improve snapshot tree GUI
Add dynamic updates, sort correctly.
This commit is contained in:
parent
5465dda8e7
commit
d0780afcb0
@ -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
|
||||||
|
@ -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 |
@ -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'
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user