ui: datastore dashboard: use gauge for usage, rework layout a bit

Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
This commit is contained in:
Thomas Lamprecht 2020-11-09 19:26:13 +01:00
parent 625c7bfc0b
commit e1da9ca4bb

View File

@ -9,9 +9,11 @@ Ext.define('PBS.datastore.DataStoreListSummary', {
}, },
bodyPadding: 10, bodyPadding: 10,
controller: {
xclass: 'Ext.app.ViewController',
},
viewModel: { viewModel: {
data: { data: {
usage: "N/A",
full: "N/A", full: "N/A",
history: [], history: [],
}, },
@ -30,8 +32,16 @@ Ext.define('PBS.datastore.DataStoreListSummary', {
setStatus: function(statusData) { setStatus: function(statusData) {
let me = this; let me = this;
let vm = me.getViewModel(); let vm = me.getViewModel();
vm.set('usagetext', PBS.Utils.render_size_usage(statusData.used, statusData.total));
vm.set('usage', statusData.used/statusData.total); let usage = statusData.used/statusData.total;
let usagetext = Ext.String.format(gettext('{0} of {1}'),
Proxmox.Utils.format_size(statusData.used),
Proxmox.Utils.format_size(statusData.total),
);
let usagePanel = me.lookup('usage');
usagePanel.updateValue(usage, usagetext);
let estimate = PBS.Utils.render_estimate(statusData['estimated-full-date']); let estimate = PBS.Utils.render_estimate(statusData['estimated-full-date']);
vm.set('full', estimate); vm.set('full', estimate);
let last = 0; let last = 0;
@ -60,30 +70,23 @@ Ext.define('PBS.datastore.DataStoreListSummary', {
}, },
defaults: { defaults: {
flex: 1,
padding: 5, padding: 5,
}, },
items: [ items: [
{ {
xtype: 'pmxInfoWidget', xtype: 'panel',
iconCls: 'fa fa-fw fa-hdd-o', border: false,
title: gettext('Usage'), flex: 1,
bind: {
data: {
usage: '{usage}',
text: '{usagetext}',
},
},
}, },
{ {
xtype: 'pmxInfoWidget', xtype: 'pmxInfoWidget',
iconCls: 'fa fa-fw fa-line-chart', iconCls: 'fa fa-fw fa-line-chart',
title: gettext('Estimated Full'), title: gettext('Estimated Full'),
width: 230,
printBar: false, printBar: false,
bind: { bind: {
data: { data: {
usage: '0',
text: '{full}', text: '{full}',
}, },
}, },
@ -125,15 +128,57 @@ Ext.define('PBS.datastore.DataStoreListSummary', {
}], }],
}, },
{ {
xtype: 'pbsTaskSummary', xtype: 'container',
border: false, layout: {
header: false, type: 'hbox',
subPanelModal: true, align: 'stretch',
bodyPadding: 0,
minHeight: 0,
cbind: {
datastore: '{datastore}',
}, },
defaults: {
padding: 5,
},
items: [
{
xtype: 'proxmoxGauge',
warningThreshold: 0.8,
criticalThreshold: 0.95,
flex: 1,
reference: 'usage',
},
{
xtype: 'container',
flex: 2,
layout: {
type: 'vbox',
align: 'stretch',
},
defaults: {
padding: 5,
},
items: [
{
xtype: 'label',
text: gettext('Task Summary')
+ ` (${Ext.String.format(gettext('{0} days'), 30)})`,
},
{
xtype: 'pbsTaskSummary',
border: false,
header: false,
subPanelModal: true,
flex: 2,
bodyPadding: 0,
minHeight: 0,
cbind: {
datastore: '{datastore}',
},
},
],
},
],
}, },
], ],
}); });