Ext.define('PVE.dc.AuthView', { extend: 'Ext.grid.GridPanel', alias: ['widget.pveAuthView'], initComponent : function() { var me = this; var store = new Ext.data.Store({ model: 'pve-domains', sorters: { property: 'realm', order: 'DESC' } }); var reload = function() { store.load(); }; var sm = Ext.create('Ext.selection.RowModel', {}); var run_editor = function() { var rec = sm.getSelection()[0]; if (!rec) { return; } var win = Ext.create('PVE.dc.AuthEdit',{ realm: rec.data.realm, authType: rec.data.type }); win.on('destroy', reload); win.show(); }; var edit_btn = new PVE.button.Button({ text: gettext('Edit'), disabled: true, selModel: sm, handler: run_editor }); var remove_btn = new PVE.button.Button({ text: gettext('Remove'), disabled: true, selModel: sm, confirmMsg: function (rec) { return Ext.String.format(gettext('Are you sure you want to remove entry {0}'), "'" + rec.data.realm + "'"); }, enableFn: function(rec) { return !(rec.data.type === 'pve' || rec.data.type === 'pam'); }, handler: function(btn, event, rec) { var realm = rec.data.realm; PVE.Utils.API2Request({ url: '/access/domains/' + realm, method: 'DELETE', waitMsgTarget: me, callback: function() { reload(); }, failure: function (response, opts) { Ext.Msg.alert(gettext('Error'), response.htmlStatus); } }); } }); var tbar = [ { text: gettext('Add'), menu: new Ext.menu.Menu({ items: [ { text: gettext('Active Directory Server'), handler: function() { var win = Ext.create('PVE.dc.AuthEdit', { authType: 'ad' }); win.on('destroy', reload); win.show(); } }, { text: gettext('LDAP Server'), handler: function() { var win = Ext.create('PVE.dc.AuthEdit',{ authType: 'ldap' }); win.on('destroy', reload); win.show(); } } ] }) }, edit_btn, remove_btn ]; Ext.apply(me, { store: store, selModel: sm, stateful: false, tbar: tbar, viewConfig: { trackOver: false }, columns: [ { header: gettext('Realm'), width: 100, sortable: true, dataIndex: 'realm' }, { header: gettext('Type'), width: 100, sortable: true, dataIndex: 'type' }, { header: gettext('TFA'), width: 100, sortable: true, dataIndex: 'tfa' }, { id: 'comment', header: gettext('Comment'), sortable: false, dataIndex: 'comment', flex: 1 } ], listeners: { activate: reload, itemdblclick: run_editor } }); me.callParent(); } });