proxmox-backup/www/dashboard/DataStoreStatistics.js
Thomas Lamprecht 8af1fa5477 ui: use base 10 (SI) for all storage related displays
matches what we do for (most) of such things in PVE since 7.0 there
and also what the disk management gui shows, further disks are sold
with SI units for their advertised capacity, so its more fitting
there too.

Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2022-05-17 10:21:26 +02:00

161 lines
3.2 KiB
JavaScript

Ext.define('pbs-datastore-statistics', {
extend: 'Ext.data.Model',
fields: [
'store',
'total',
'used',
'avail',
'estimated-full-date',
'error',
{
name: 'history',
convert: function(values) {
if (!values) {
return [];
}
let last = null;
return values.map(v => {
if (v !== undefined && v !== null) {
last = v;
}
return last;
});
},
},
{
name: 'usage',
calculate: function(data) {
let used = data.used || 0;
let total = data.total || 0;
if (total > 0) {
return used/total;
} else {
return -1;
}
},
},
],
proxy: {
type: 'proxmox',
url: "/api2/json/status/datastore-usage",
},
idProperty: 'store',
});
Ext.define('PBS.DatastoreStatistics', {
extend: 'Ext.grid.Panel',
alias: 'widget.pbsDatastoresStatistics',
title: gettext('Datastore Usage'),
disableSelection: true,
emptyText: gettext('No Data'),
controller: {
xclass: 'Ext.app.ViewController',
init: function(view) {
Proxmox.Utils.monStoreErrors(view, view.getStore().rstore);
},
},
columns: [
{
text: gettext('Name'),
dataIndex: 'store',
sortable: true,
renderer: (value, metaData, record, rowIndex, colIndex, store) => {
let err = record.get('error');
if (err) {
metaData.tdAttr = `data-qtip="${Ext.htmlEncode(err)}"`;
metaData.tdCls = 'proxmox-invalid-row';
return `${value || ''} <i class="fa fa-fw critical fa-exclamation-circle"></i>`;
}
return value;
},
},
{
text: gettext('Size'),
dataIndex: 'total',
sortable: true,
width: 90,
renderer: v => v === undefined || v < 0 ? '-' : Proxmox.Utils.format_size(v, true),
},
{
text: gettext('Used'),
dataIndex: 'used',
sortable: true,
width: 90,
renderer: v => v === undefined || v < 0 ? '-' : Proxmox.Utils.format_size(v, true),
},
{
text: gettext('Available'),
dataIndex: 'avail',
sortable: true,
width: 90,
renderer: v => v === undefined || v < 0 ? '-' : Proxmox.Utils.format_size(v, true),
},
{
text: gettext('Usage %'),
dataIndex: 'usage',
sortable: true,
xtype: 'widgetcolumn',
widget: {
xtype: 'progressbarwidget',
bind: '{record.usage}',
textTpl: [
'<tpl if="value &gt;= 0">',
'{value:number("0.00")*100}%',
'<tpl else>',
Proxmox.Utils.unknownText,
'</tpl>',
],
},
},
{
text: gettext('Estimated Full'),
dataIndex: 'estimated-full-date',
sortable: true,
renderer: PBS.Utils.render_estimate,
flex: 1,
minWidth: 130,
maxWidth: 200,
},
{
text: gettext("History (last Month)"),
width: 100,
xtype: 'widgetcolumn',
dataIndex: 'history',
flex: 1,
widget: {
xtype: 'sparklineline',
bind: '{record.history}',
spotRadius: 0,
fillColor: '#ddd',
lineColor: '#555',
lineWidth: 0,
chartRangeMin: 0,
chartRangeMax: 1,
tipTpl: '{y:number("0.00")*100}%',
},
},
],
store: {
type: 'diff',
autoDestroy: true,
autoDestroyRstore: true,
sorters: 'store',
rstore: {
type: 'update',
storeid: 'pbs-datastore-statistics',
model: 'pbs-datastore-statistics',
autoStart: true,
interval: 30000,
},
},
});