pve-manager/www/manager6/window/Backup.js
Thomas Lamprecht f2e174dacc ui: backup prune: add label for storage prune settings
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2021-06-17 17:44:32 +02:00

289 lines
6.4 KiB
JavaScript

Ext.define('PVE.window.Backup', {
extend: 'Ext.window.Window',
resizable: false,
initComponent: function() {
var me = this;
if (!me.nodename) {
throw "no node name specified";
}
if (!me.vmid) {
throw "no VM ID specified";
}
if (!me.vmtype) {
throw "no VM type specified";
}
let compressionSelector = Ext.create('PVE.form.CompressionSelector', {
name: 'compress',
value: 'zstd',
fieldLabel: gettext('Compression'),
});
let modeSelector = Ext.create('PVE.form.BackupModeSelector', {
fieldLabel: gettext('Mode'),
value: 'snapshot',
name: 'mode',
});
let mailtoField = Ext.create('Ext.form.field.Text', {
fieldLabel: gettext('Send email to'),
name: 'mailto',
emptyText: Proxmox.Utils.noneText,
});
const keepNames = [
['keep-last', gettext('Keep Last')],
['keep-hourly', gettext('Keep Hourly')],
['keep-daily', gettext('Keep Daily')],
['keep-weekly', gettext('Keep Weekly')],
['keep-monthly', gettext('Keep Monthly')],
['keep-yearly', gettext('Keep Yearly')],
];
let pruneSettings = keepNames.map(
name => Ext.create('Ext.form.field.Display', {
name: name[0],
fieldLabel: name[1],
hidden: true,
}),
);
let removeCheckbox = Ext.create('Proxmox.form.Checkbox', {
name: 'remove',
checked: false,
hidden: true,
uncheckedValue: 0,
fieldLabel: gettext('Prune'),
autoEl: {
tag: 'div',
'data-qtip': gettext('Prune older backups afterwards'),
},
handler: function(checkbox, value) {
pruneSettings.forEach(field => field.setHidden(!value));
me.down('label[name="pruneLabel"]').setHidden(!value);
},
});
let initialDefaults = false;
var storagesel = Ext.create('PVE.form.StorageSelector', {
nodename: me.nodename,
name: 'storage',
fieldLabel: gettext('Storage'),
storageContent: 'backup',
allowBlank: false,
listeners: {
change: function(f, v) {
if (!initialDefaults) {
me.setLoading(false);
}
if (v === null || v === undefined || v === '') {
return;
}
let store = f.getStore();
let rec = store.findRecord('storage', v, 0, false, true, true);
if (rec && rec.data && rec.data.type === 'pbs') {
compressionSelector.setValue('zstd');
compressionSelector.setDisabled(true);
} else if (!compressionSelector.getEditable()) {
compressionSelector.setDisabled(false);
}
Proxmox.Utils.API2Request({
url: `/nodes/${me.nodename}/vzdump/defaults`,
method: 'GET',
params: {
storage: v,
},
waitMsgTarget: me,
success: function(response, opts) {
const data = response.result.data;
if (!initialDefaults && data.mailto !== undefined) {
mailtoField.setValue(data.mailto);
}
if (!initialDefaults && data.mode !== undefined) {
modeSelector.setValue(data.mode);
}
initialDefaults = true;
// always update storage dependent properties
if (data['prune-backups'] !== undefined) {
const keepParams = PVE.Parser.parsePropertyString(
data["prune-backups"],
);
if (!keepParams['keep-all']) {
removeCheckbox.setHidden(false);
pruneSettings.forEach(function(field) {
const keep = keepParams[field.name];
if (keep) {
field.setValue(keep);
} else {
field.reset();
}
});
return;
}
}
// no defaults or keep-all=1
removeCheckbox.setHidden(true);
removeCheckbox.setValue(false);
pruneSettings.forEach(field => field.reset());
},
failure: function(response, opts) {
initialDefaults = true;
removeCheckbox.setHidden(true);
removeCheckbox.setValue(false);
pruneSettings.forEach(field => field.reset());
Ext.Msg.alert(gettext('Error'), response.htmlStatus);
},
});
},
},
});
me.formPanel = Ext.create('Proxmox.panel.InputPanel', {
bodyPadding: 10,
border: false,
column1: [
storagesel,
modeSelector,
removeCheckbox,
],
column2: [
compressionSelector,
mailtoField,
],
columnB: [
{
xtype: 'label',
name: 'pruneLabel',
text: gettext('Storage Retention Configuration') + ':',
hidden: true,
},
{
layout: 'hbox',
border: false,
defaults: {
border: false,
layout: 'anchor',
flex: 1,
},
items: [
{
padding: '0 10 0 0',
defaults: {
labelWidth: 110,
},
items: [
pruneSettings[0],
pruneSettings[2],
pruneSettings[4],
],
},
{
padding: '0 0 0 10',
defaults: {
labelWidth: 110,
},
items: [
pruneSettings[1],
pruneSettings[3],
pruneSettings[5],
],
},
],
},
],
});
var submitBtn = Ext.create('Ext.Button', {
text: gettext('Backup'),
handler: function() {
var storage = storagesel.getValue();
let values = me.formPanel.getValues();
var params = {
storage: storage,
vmid: me.vmid,
mode: values.mode,
remove: values.remove,
};
if (values.mailto) {
params.mailto = values.mailto;
}
if (values.compress) {
params.compress = values.compress;
}
Proxmox.Utils.API2Request({
url: '/nodes/' + me.nodename + '/vzdump',
params: params,
method: 'POST',
failure: function(response, opts) {
Ext.Msg.alert('Error', response.htmlStatus);
},
success: function(response, options) {
// close later so we reload the grid
// after the task has completed
me.hide();
var upid = response.result.data;
var win = Ext.create('Proxmox.window.TaskViewer', {
upid: upid,
listeners: {
close: function() {
me.close();
},
},
});
win.show();
},
});
},
});
var helpBtn = Ext.create('Proxmox.button.Help', {
onlineHelp: 'chapter_vzdump',
listenToGlobalEvent: false,
hidden: false,
});
var title = gettext('Backup') + " " +
(me.vmtype === 'lxc' ? "CT" : "VM") +
" " + me.vmid;
Ext.apply(me, {
title: title,
modal: true,
layout: 'auto',
border: false,
items: [me.formPanel],
buttons: [helpBtn, '->', submitBtn],
listeners: {
afterrender: function() {
/// cleared within the storage selector's change listener
me.setLoading(gettext('Please wait...'));
storagesel.setValue(me.storage);
},
},
});
me.callParent();
},
});