b70a12e723
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>
94 lines
1.8 KiB
JavaScript
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();
|
|
},
|
|
});
|