gui: preview prune selection
This commit is contained in:
parent
dda7015497
commit
d16122cd87
@ -1,8 +1,76 @@
|
|||||||
|
Ext.define('pbs-prune-list', {
|
||||||
|
extend: 'Ext.data.Model',
|
||||||
|
fields: [
|
||||||
|
'backup-type',
|
||||||
|
'backup-id',
|
||||||
|
{
|
||||||
|
name: 'backup-time',
|
||||||
|
type: 'date',
|
||||||
|
dateFormat: 'timestamp'
|
||||||
|
},
|
||||||
|
]
|
||||||
|
});
|
||||||
|
|
||||||
Ext.define('PBS.DataStorePruneInputPanel', {
|
Ext.define('PBS.DataStorePruneInputPanel', {
|
||||||
extend: 'Proxmox.panel.InputPanel',
|
extend: 'Proxmox.panel.InputPanel',
|
||||||
alias: 'widget.pbsDataStorePruneInputPanel',
|
alias: 'widget.pbsDataStorePruneInputPanel',
|
||||||
|
mixins: ['Proxmox.Mixin.CBind'],
|
||||||
|
|
||||||
items: [
|
onGetValues: function(values) {
|
||||||
|
var me = this;
|
||||||
|
|
||||||
|
values["backup-type"] = me.backup_type;
|
||||||
|
values["backup-id"] = me.backup_id;
|
||||||
|
return values;
|
||||||
|
},
|
||||||
|
|
||||||
|
controller: {
|
||||||
|
xclass: 'Ext.app.ViewController',
|
||||||
|
|
||||||
|
init: function(view) {
|
||||||
|
if (!view.url) {
|
||||||
|
throw "no url specified";
|
||||||
|
}
|
||||||
|
if (!view.backup_type) {
|
||||||
|
throw "no backup_type specified";
|
||||||
|
}
|
||||||
|
if (!view.backup_id) {
|
||||||
|
throw "no backup_id specified";
|
||||||
|
}
|
||||||
|
|
||||||
|
this.reload(); // initial load
|
||||||
|
},
|
||||||
|
|
||||||
|
reload: function() {
|
||||||
|
var view = this.getView();
|
||||||
|
|
||||||
|
let params = view.getValues();
|
||||||
|
params["dry-run"] = true;
|
||||||
|
|
||||||
|
Proxmox.Utils.API2Request({
|
||||||
|
url: view.url,
|
||||||
|
method: "POST",
|
||||||
|
params: params,
|
||||||
|
callback: function() {
|
||||||
|
console.log("DONE");
|
||||||
|
},
|
||||||
|
failure: function (response, opts) {
|
||||||
|
Ext.Msg.alert(gettext('Error'), response.htmlStatus);
|
||||||
|
},
|
||||||
|
success: function(response, options) {
|
||||||
|
var data = response.result.data;
|
||||||
|
console.log(data);
|
||||||
|
view.prune_store.setData(data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
control: {
|
||||||
|
field: { change: 'reload' }
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
column1: [
|
||||||
{
|
{
|
||||||
xtype: 'proxmoxintegerfield',
|
xtype: 'proxmoxintegerfield',
|
||||||
name: 'keep-last',
|
name: 'keep-last',
|
||||||
@ -45,14 +113,47 @@ Ext.define('PBS.DataStorePruneInputPanel', {
|
|||||||
fieldLabel: gettext('keep-yearly'),
|
fieldLabel: gettext('keep-yearly'),
|
||||||
minValue: 1,
|
minValue: 1,
|
||||||
}
|
}
|
||||||
// fixme: howto handle dry-run?
|
],
|
||||||
//{
|
|
||||||
// xtype: 'proxmoxcheckbox',
|
|
||||||
// name: 'dry-run',
|
|
||||||
// fieldLabel: gettext('dry-run'),
|
|
||||||
//}
|
|
||||||
],
|
|
||||||
|
|
||||||
|
|
||||||
|
initComponent : function() {
|
||||||
|
var me = this;
|
||||||
|
|
||||||
|
me.prune_store = Ext.create('Ext.data.Store', {
|
||||||
|
model: 'pbs-prune-list',
|
||||||
|
sorters: { property: 'backup-time', direction: 'DESC' }
|
||||||
|
});
|
||||||
|
|
||||||
|
me.column2 = [
|
||||||
|
{
|
||||||
|
xtype: 'grid',
|
||||||
|
height: 200,
|
||||||
|
store: me.prune_store,
|
||||||
|
columns: [
|
||||||
|
{
|
||||||
|
header: gettext('Backup Time'),
|
||||||
|
sortable: true,
|
||||||
|
dataIndex: 'backup-time',
|
||||||
|
renderer: function(value, metaData, record) {
|
||||||
|
let text = Ext.Date.format(value, 'Y-m-d H:i:s');
|
||||||
|
if (record.data.keep) {
|
||||||
|
return text;
|
||||||
|
} else {
|
||||||
|
return '<div style="text-decoration: line-through;">'+ text +'</div>';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
flex: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "keep",
|
||||||
|
dataIndex: 'keep'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
me.callParent();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
Ext.define('PBS.DataStorePrune', {
|
Ext.define('PBS.DataStorePrune', {
|
||||||
@ -81,11 +182,9 @@ Ext.define('PBS.DataStorePrune', {
|
|||||||
title: "Prune Datastore '" + me.datastore + "'",
|
title: "Prune Datastore '" + me.datastore + "'",
|
||||||
items: [{
|
items: [{
|
||||||
xtype: 'pbsDataStorePruneInputPanel',
|
xtype: 'pbsDataStorePruneInputPanel',
|
||||||
onGetValues: function(values) {
|
url: '/api2/extjs/admin/datastore/' + me.datastore + "/prune",
|
||||||
values["backup-type"] = me.backup_type;
|
backup_type: me.backup_type,
|
||||||
values["backup-id"] = me.backup_id;
|
backup_id: me.backup_id
|
||||||
return values;
|
|
||||||
}
|
|
||||||
}]
|
}]
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user