+/*global Proxmox*/
Ext.define('PMG.ObjectGroup', {
extend: 'Ext.grid.GridPanel',
alias: 'widget.pmgObjectGroup',
if (me.baseurl === undefined) {
me.store.proxy.setUrl(undefined);
me.store.setData([]);
- me.down('#addMenuButton').setDisabled(true);
+ me.setButtonState(me.store, [], false);
} else {
var url = '/api2/json' + me.baseurl + '/objects';
me.store.proxy.setUrl(url);
- me.store.load(function() {
- me.down('#addMenuButton').setDisabled(false);
- });
+ me.store.load();
}
},
}
},
+ setButtonState: function(store, records, success) {
+ var me = this;
+ if (!success || !me.baseurl) {
+ me.down('#addMenuButton').setDisabled(true);
+ return;
+ }
+ me.down('#addMenuButton').setDisabled(false);
+ },
+
initComponent : function() {
var me = this;
}
var editor = PMG.Utils.object_editors[rec.data.otype];
- if (!editor) {
+ if (!editor || editor.uneditable) {
return;
}
menu_items.push({
text: config.subject,
+ iconCls: config.iconCls || 'fa fa-question-circle',
handler: function() {
if (me.baseurl == undefined) {
return;
text: gettext('Edit'),
disabled: true,
selModel: me.selModel,
+ enableFn: function(rec) {
+ var editor = PMG.Utils.object_editors[rec.data.otype];
+ return (editor && !editor.uneditable);
+ },
handler: run_editor
},
- remove_btn
+ remove_btn
]
});
me.callParent();
+ me.mon(me.store, 'load', me.setButtonState, me);
+
if (me.baseurl) {
me.setBaseUrl(me.baseurl); // configure store, load()
}