DataStoreContent.js: show backup groups (instead of snapshots).
This commit is contained in:
parent
5b32852266
commit
507c39c595
|
@ -1,11 +1,21 @@
|
||||||
Ext.define('pbs-data-store-content', {
|
Ext.define('pbs-data-store-content', {
|
||||||
extend: 'Ext.data.Model',
|
extend: 'Ext.data.Model',
|
||||||
fields: [
|
fields: [
|
||||||
'backup-id',
|
|
||||||
'backup-time',
|
|
||||||
'backup-type',
|
'backup-type',
|
||||||
|
'backup-id',
|
||||||
|
{
|
||||||
|
name: 'last-backup',
|
||||||
|
type: 'date',
|
||||||
|
dateFormat: 'timestamp'
|
||||||
|
},
|
||||||
'files',
|
'files',
|
||||||
{ name: 'size', type: 'int', defaultValue: 0 },
|
{ name: 'backup-count', type: 'int' },
|
||||||
|
{
|
||||||
|
name: 'backup-group',
|
||||||
|
calculate: function (data) {
|
||||||
|
return data["backup-type"] + '/' + data["backup-id"];
|
||||||
|
}
|
||||||
|
},
|
||||||
],
|
],
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -13,6 +23,11 @@ Ext.define('PBS.DataStoreContent', {
|
||||||
extend: 'Ext.grid.GridPanel',
|
extend: 'Ext.grid.GridPanel',
|
||||||
alias: 'widget.pbsDataStoreContent',
|
alias: 'widget.pbsDataStoreContent',
|
||||||
|
|
||||||
|
store: {
|
||||||
|
model: 'pbs-data-store-content',
|
||||||
|
sorters: 'backup-group',
|
||||||
|
},
|
||||||
|
|
||||||
controller: {
|
controller: {
|
||||||
xclass: 'Ext.app.ViewController',
|
xclass: 'Ext.app.ViewController',
|
||||||
|
|
||||||
|
@ -30,7 +45,7 @@ Ext.define('PBS.DataStoreContent', {
|
||||||
reload: function() {
|
reload: function() {
|
||||||
var view = this.getView();
|
var view = this.getView();
|
||||||
|
|
||||||
let url = `/api2/json/admin/datastore/${view.datastore}/snapshots`;
|
let url = `/api2/json/admin/datastore/${view.datastore}/groups`;
|
||||||
view.store.setProxy({
|
view.store.setProxy({
|
||||||
type: 'proxmox',
|
type: 'proxmox',
|
||||||
url: url
|
url: url
|
||||||
|
@ -39,45 +54,61 @@ Ext.define('PBS.DataStoreContent', {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
columns: [
|
initComponent: function() {
|
||||||
{
|
var me = this;
|
||||||
header: gettext('Type'),
|
|
||||||
sortable: true,
|
|
||||||
dataIndex: 'backup-type',
|
|
||||||
flex: 1
|
|
||||||
},
|
|
||||||
{
|
|
||||||
header: gettext('ID'),
|
|
||||||
sortable: true,
|
|
||||||
dataIndex: 'backup-id',
|
|
||||||
flex: 1
|
|
||||||
},
|
|
||||||
{
|
|
||||||
header: gettext('Time'),
|
|
||||||
sortable: true,
|
|
||||||
dataIndex: 'backup-time',
|
|
||||||
renderer: Proxmox.Utils.render_timestamp,
|
|
||||||
flex: 1
|
|
||||||
},
|
|
||||||
{
|
|
||||||
header: gettext('Size'),
|
|
||||||
sortable: true,
|
|
||||||
dataIndex: 'size',
|
|
||||||
renderer: Proxmox.Utils.format_size,
|
|
||||||
flex: 1
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
tbar: [
|
var render_backup_type = function(value, metaData, record) {
|
||||||
{
|
var btype = record.data["backup-type"];
|
||||||
text: gettext('Reload'),
|
var cls = '';
|
||||||
iconCls: 'fa fa-refresh',
|
if (btype === 'vm') {
|
||||||
handler: 'reload',
|
cls = 'fa-desktop';
|
||||||
},
|
} else if (btype === 'ct') {
|
||||||
],
|
cls = 'fa-cube';
|
||||||
|
} else if (btype === 'host') {
|
||||||
|
cls = 'fa-building';
|
||||||
|
} else {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
var fa = '<i class="fa fa-fw x-grid-icon-custom ' + cls + '"></i> ';
|
||||||
|
return fa + value;
|
||||||
|
};
|
||||||
|
|
||||||
store: {
|
Ext.apply(me, {
|
||||||
model: 'pbs-data-store-content',
|
columns: [
|
||||||
sorters: 'name',
|
{
|
||||||
|
header: gettext('Backup'),
|
||||||
|
sortable: true,
|
||||||
|
renderer: render_backup_type,
|
||||||
|
dataIndex: 'backup-id',
|
||||||
|
flex: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
xtype: 'datecolumn',
|
||||||
|
header: gettext('Last Backup'),
|
||||||
|
sortable: true,
|
||||||
|
dataIndex: 'last-backup',
|
||||||
|
format: 'Y-m-d H:i:s',
|
||||||
|
flex: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
xtype: 'numbercolumn',
|
||||||
|
format: '0',
|
||||||
|
header: gettext('Nuber of backups'),
|
||||||
|
sortable: true,
|
||||||
|
dataIndex: 'backup-count',
|
||||||
|
flex: 1
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
tbar: [
|
||||||
|
{
|
||||||
|
text: gettext('Reload'),
|
||||||
|
iconCls: 'fa fa-refresh',
|
||||||
|
handler: 'reload',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
me.callParent();
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue