proxmox-backup/www/form/NamespaceSelector.js
Dominik Csapak b70a12e723 ui: tape/Restore: allow simple namespace mapping
add a default namespace selector (of the current default store)
and a namespace selector per target datastore (for media-sets with
multiple datastores).

to achieve that we have to change the way we handle the mapping field a bit:
* don't use it as field directly (otherwise the value gets stringified),
  but use the 'getValue' method in 'onGetValues'.
* set the defaultStore there, not only that we have one
  (with this we can now easily show it as emptytext for each store)
* add a reference to the widgets to the record so that we can access
  them in the respective change handler (also clean those references up,
  else we have a cyclic reference between record <-> widget)

in onGetValues, if we have multiple datastores, the mapping grid does
all the work for us, otherwise, we have to create the ns mapping
ourselves there.

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2022-05-13 14:09:53 +02:00

94 lines
1.8 KiB
JavaScript

Ext.define('pbs-namespaces', {
extend: 'Ext.data.Model',
fields: [
{
name: 'ns',
},
{
name: 'id', // fake as else the model messes with our value and/or display...
type: 'string',
calculate: data => data.ns === '' ? '/' : data.ns,
},
],
idProperty: 'id',
});
Ext.define('PBS.form.NamespaceSelector', {
extend: 'Ext.form.field.ComboBox',
alias: 'widget.pbsNamespaceSelector',
allowBlank: true,
autoSelect: true,
valueField: 'ns',
displayField: 'ns',
emptyText: gettext('Root'),
editable: true,
anyMatch: true,
forceSelection: true,
matchFieldWidth: false,
listConfig: {
minWidth: 170,
maxWidth: 500,
// below doesn't work :/
//minHeight: 30,
//emptyText: gettext('No namespaces accesible.'),
},
triggers: {
clear: {
cls: 'pmx-clear-trigger',
weight: -1,
hidden: true,
handler: function() {
this.triggers.clear.setVisible(false);
this.setValue('');
},
},
},
listeners: {
change: function(field, value) {
let canClear = value !== '';
field.triggers.clear.setVisible(canClear);
},
},
setDatastore: function(datastore) {
let me = this;
if (datastore ?? false) {
me.datastore = datastore;
me.store.getProxy().setUrl(`/api2/json/admin/datastore/${me.datastore}/namespace`);
if (me.isDisabled()) {
me.setDisabled(false);
}
me.store.load();
me.validate();
} else {
me.datastore = undefined;
me.setDisabled(true);
}
},
initComponent: function() {
let me = this;
if (!me.datastore) {
me.disabled = true;
}
me.store = Ext.create('Ext.data.Store', {
model: 'pbs-namespaces',
autoLoad: !!me.datastore,
proxy: {
type: 'proxmox',
timeout: 30 * 1000,
url: `/api2/json/admin/datastore/${me.datastore}/namespace`,
},
});
me.callParent();
},
});