ui: tape/BackupJobEdit: add second tab with group filters
adds a second tab and adapts the styling to our usual one (border/padding) adds a change listener to the datastore selector to change it on the group filters remaining changes are mostly indentation changes Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
This commit is contained in:
parent
65bd918ac3
commit
705f4b0d95
@ -11,6 +11,8 @@ Ext.define('PBS.TapeManagement.BackupJobEdit', {
|
|||||||
|
|
||||||
fieldDefaults: { labelWidth: 120 },
|
fieldDefaults: { labelWidth: 120 },
|
||||||
|
|
||||||
|
bodyPadding: 0,
|
||||||
|
|
||||||
cbindData: function(initialConfig) {
|
cbindData: function(initialConfig) {
|
||||||
let me = this;
|
let me = this;
|
||||||
|
|
||||||
@ -28,117 +30,140 @@ Ext.define('PBS.TapeManagement.BackupJobEdit', {
|
|||||||
},
|
},
|
||||||
|
|
||||||
items: {
|
items: {
|
||||||
xtype: 'inputpanel',
|
xtype: 'tabpanel',
|
||||||
onGetValues: function(values) {
|
bodyPadding: 10,
|
||||||
let me = this;
|
border: 0,
|
||||||
|
items: [
|
||||||
|
{
|
||||||
|
title: gettext('Options'),
|
||||||
|
xtype: 'inputpanel',
|
||||||
|
onGetValues: function(values) {
|
||||||
|
let me = this;
|
||||||
|
|
||||||
if (values['export-media-set'] && !me.up('pbsTapeBackupJobEdit').isCreate) {
|
if (values['export-media-set'] && !me.up('pbsTapeBackupJobEdit').isCreate) {
|
||||||
Proxmox.Utils.assemble_field_data(values, { "delete": 'eject-media' });
|
Proxmox.Utils.assemble_field_data(values, { "delete": 'eject-media' });
|
||||||
}
|
}
|
||||||
PBS.Utils.delete_if_default(values, 'notify-user');
|
PBS.Utils.delete_if_default(values, 'notify-user');
|
||||||
return values;
|
return values;
|
||||||
},
|
|
||||||
column1: [
|
|
||||||
{
|
|
||||||
xtype: 'pmxDisplayEditField',
|
|
||||||
name: 'id',
|
|
||||||
fieldLabel: gettext('Job ID'),
|
|
||||||
renderer: Ext.htmlEncode,
|
|
||||||
allowBlank: false,
|
|
||||||
cbind: {
|
|
||||||
editable: '{isCreate}',
|
|
||||||
},
|
},
|
||||||
},
|
column1: [
|
||||||
{
|
{
|
||||||
xtype: 'pbsDataStoreSelector',
|
xtype: 'pmxDisplayEditField',
|
||||||
fieldLabel: gettext('Local Datastore'),
|
name: 'id',
|
||||||
name: 'store',
|
fieldLabel: gettext('Job ID'),
|
||||||
},
|
renderer: Ext.htmlEncode,
|
||||||
{
|
allowBlank: false,
|
||||||
xtype: 'pbsMediaPoolSelector',
|
cbind: {
|
||||||
fieldLabel: gettext('Media Pool'),
|
editable: '{isCreate}',
|
||||||
name: 'pool',
|
},
|
||||||
},
|
|
||||||
{
|
|
||||||
xtype: 'pbsDriveSelector',
|
|
||||||
fieldLabel: gettext('Drive'),
|
|
||||||
name: 'drive',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
xtype: 'pmxUserSelector',
|
|
||||||
name: 'notify-user',
|
|
||||||
fieldLabel: gettext('Notify User'),
|
|
||||||
emptyText: 'root@pam',
|
|
||||||
allowBlank: true,
|
|
||||||
value: null,
|
|
||||||
renderer: Ext.String.htmlEncode,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
column2: [
|
|
||||||
{
|
|
||||||
fieldLabel: gettext('Schedule'),
|
|
||||||
xtype: 'pbsCalendarEvent',
|
|
||||||
name: 'schedule',
|
|
||||||
emptyText: gettext('none (disabled)'),
|
|
||||||
cbind: {
|
|
||||||
deleteEmpty: '{!isCreate}',
|
|
||||||
value: '{scheduleValue}',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
fieldLabel: gettext('Export Media-Set'),
|
|
||||||
xtype: 'proxmoxcheckbox',
|
|
||||||
name: 'export-media-set',
|
|
||||||
cbind: {
|
|
||||||
deleteEmpty: '{!isCreate}',
|
|
||||||
},
|
|
||||||
listeners: {
|
|
||||||
change: function(cb, value) {
|
|
||||||
let me = this;
|
|
||||||
let eject = me.up('window').down('proxmoxcheckbox[name=eject-media]');
|
|
||||||
if (value) {
|
|
||||||
eject.setValue(false);
|
|
||||||
}
|
|
||||||
eject.setDisabled(!!value);
|
|
||||||
},
|
},
|
||||||
},
|
{
|
||||||
},
|
xtype: 'pbsDataStoreSelector',
|
||||||
{
|
fieldLabel: gettext('Local Datastore'),
|
||||||
fieldLabel: gettext('Eject Media'),
|
name: 'store',
|
||||||
xtype: 'proxmoxcheckbox',
|
listeners: {
|
||||||
name: 'eject-media',
|
change: function(field, value) {
|
||||||
cbind: {
|
let me = this;
|
||||||
deleteEmpty: '{!isCreate}',
|
me.up('tabpanel').down('pbsGroupFilter').setLocalDatastore(value);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
},
|
||||||
fieldLabel: gettext('Latest Only'),
|
{
|
||||||
xtype: 'proxmoxcheckbox',
|
xtype: 'pbsMediaPoolSelector',
|
||||||
name: 'latest-only',
|
fieldLabel: gettext('Media Pool'),
|
||||||
cbind: {
|
name: 'pool',
|
||||||
deleteEmpty: '{!isCreate}',
|
},
|
||||||
},
|
{
|
||||||
},
|
xtype: 'pbsDriveSelector',
|
||||||
],
|
fieldLabel: gettext('Drive'),
|
||||||
|
name: 'drive',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
xtype: 'pmxUserSelector',
|
||||||
|
name: 'notify-user',
|
||||||
|
fieldLabel: gettext('Notify User'),
|
||||||
|
emptyText: 'root@pam',
|
||||||
|
allowBlank: true,
|
||||||
|
value: null,
|
||||||
|
renderer: Ext.String.htmlEncode,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
columnB: [
|
column2: [
|
||||||
{
|
{
|
||||||
fieldLabel: gettext('Backup Groups'),
|
fieldLabel: gettext('Schedule'),
|
||||||
xtype: 'displayfield',
|
xtype: 'pbsCalendarEvent',
|
||||||
name: 'group-filter',
|
name: 'schedule',
|
||||||
renderer: v => v ? Ext.String.htmlEncode(v) : gettext('All'),
|
emptyText: gettext('none (disabled)'),
|
||||||
cbind: {
|
cbind: {
|
||||||
hidden: '{isCreate}',
|
deleteEmpty: '{!isCreate}',
|
||||||
},
|
value: '{scheduleValue}',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldLabel: gettext('Export Media-Set'),
|
||||||
|
xtype: 'proxmoxcheckbox',
|
||||||
|
name: 'export-media-set',
|
||||||
|
cbind: {
|
||||||
|
deleteEmpty: '{!isCreate}',
|
||||||
|
},
|
||||||
|
listeners: {
|
||||||
|
change: function(cb, value) {
|
||||||
|
let me = this;
|
||||||
|
let eject = me.up('window').down('proxmoxcheckbox[name=eject-media]');
|
||||||
|
if (value) {
|
||||||
|
eject.setValue(false);
|
||||||
|
}
|
||||||
|
eject.setDisabled(!!value);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldLabel: gettext('Eject Media'),
|
||||||
|
xtype: 'proxmoxcheckbox',
|
||||||
|
name: 'eject-media',
|
||||||
|
cbind: {
|
||||||
|
deleteEmpty: '{!isCreate}',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldLabel: gettext('Latest Only'),
|
||||||
|
xtype: 'proxmoxcheckbox',
|
||||||
|
name: 'latest-only',
|
||||||
|
cbind: {
|
||||||
|
deleteEmpty: '{!isCreate}',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
columnB: [
|
||||||
|
{
|
||||||
|
fieldLabel: gettext('Comment'),
|
||||||
|
xtype: 'proxmoxtextfield',
|
||||||
|
name: 'comment',
|
||||||
|
cbind: {
|
||||||
|
deleteEmpty: '{!isCreate}',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldLabel: gettext('Comment'),
|
xtype: 'inputpanel',
|
||||||
xtype: 'proxmoxtextfield',
|
onGetValues: function(values) {
|
||||||
name: 'comment',
|
PBS.Utils.delete_if_default(values, 'group-filter');
|
||||||
cbind: {
|
if (Ext.isArray(values['group-filter']) && values['group-filter'].length === 0) {
|
||||||
deleteEmpty: '{!isCreate}',
|
delete values['group-filter'];
|
||||||
|
values.delete = 'group-filter';
|
||||||
|
}
|
||||||
|
return values;
|
||||||
},
|
},
|
||||||
|
title: gettext('Group Filter'),
|
||||||
|
items: [
|
||||||
|
{
|
||||||
|
xtype: 'pbsGroupFilter',
|
||||||
|
name: 'group-filter',
|
||||||
|
},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
Loading…
Reference in New Issue
Block a user