modxcms/revolution

View on GitHub
manager/assets/modext/widgets/system/modx.grid.manager.log.js

Summary

Maintainability
D
2 days
Test Coverage
/**
 * Loads a grid of Manager Logs.
 *
 * @class MODx.grid.ManagerLog
 * @extends MODx.grid.Grid
 * @param {Object} config An object of options.
 * @xtype modx-grid-manager-log
 */
MODx.grid.ManagerLog = function(config) {
    config = config || {};
    Ext.applyIf(config,{
        title: _('manager_log')
        ,id: 'modx-grid-manager-log'
        ,url: MODx.config.connector_url
        ,baseParams: {
            action: 'system/log/getlist'
        }
        ,fields: ['id','user','username','occurred','action','classKey','item','name','menu']
        ,autosave: false
        ,paging: true
        ,remoteSort: true
        ,columns: [{
            header: _('occurred')
            ,dataIndex: 'occurred'
            ,width: 125
            ,sortable: true
        },{
            header: _('user')
            ,dataIndex: 'username'
            ,width: 125
            ,editable: false
            ,sortable: true
        },{
            header: _('action')
            ,dataIndex: 'action'
            ,width: 125
            ,sortable: true
        },{
            header: _('object')
            ,dataIndex: 'name'
            ,width: 300
            ,renderer: Ext.util.Format.htmlEncode
        }]
        ,tbar: [{
            xtype: 'button'
            ,text: _('filter_clear')
            ,cls: 'primary-button'
            ,scope: this
            ,handler: function() {
                var fp = Ext.getCmp(this.config.formpanel);
                if (fp) {
                    fp.getForm().reset();
                    fp.filter();
                }
            }
        },'->',{
            xtype: 'button'
            ,text: _('mgrlog_clear')
            ,scope: this
            ,handler: function() {
                var fp = Ext.getCmp(this.config.formpanel);
                if (fp) {
                    fp.clearLog();
                }
            }
        }]
    });
    MODx.grid.ManagerLog.superclass.constructor.call(this,config);
};
Ext.extend(MODx.grid.ManagerLog,MODx.grid.Grid);
Ext.reg('modx-grid-manager-log',MODx.grid.ManagerLog);

/**
 * Loads the Manager Log filter panel.
 *
 * @class MODx.panel.ManagerLog
 * @extends MODx.FormPanel
 * @constructor
 * @param {Object} config An object of options.
 * @xtype panel-manager-log
 */
MODx.panel.ManagerLog = function(config) {
    config = config || {};
    Ext.applyIf(config,{
        id: 'modx-panel-manager-log'
        ,cls: 'container'
        ,defaults: { collapsible: false ,autoHeight: true }
        ,items: [{
            html: _('manager_log')
            ,xtype: 'modx-header'
            ,id: 'manager-log-header'
        },MODx.getPageStructure([{
            title: _('mgrlog_query')
            ,layout: 'form'
            ,defaults: { border: false ,msgTarget: 'side' }
            ,items: [{
                html: '<p>'+_('mgrlog_query_msg')+'</p>'
                ,xtype: 'modx-description'
            },{
                xtype: 'panel'
                ,border: false
                ,cls:'main-wrapper'
                ,layout: 'form'
                ,items: [{
                    layout: 'column'
                    ,border: false
                    ,defaults: {
                        layout: 'form'
                        ,labelAlign: 'top'
                        ,anchor: '100%'
                        ,border: false
                    }
                    ,items: [{
                        columnWidth: .5
                        ,items: [{
                            xtype: 'modx-combo-user'
                            ,fieldLabel: _('user')
                            ,name: 'user'
                            ,anchor: '100%'
                            ,listeners: {
                                'select': {fn: this.filter, scope: this}
                            }
                        },{
                            xtype: 'textfield'
                            ,fieldLabel: _('action')
                            ,name: 'actionType'
                            ,anchor: '100%'
                            ,listeners: {
                                'change': {fn: this.filter, scope: this}
                                ,'render': {fn:this._addEnterKeyHandler}
                            }
                        },{
                            xtype: 'textfield'
                            ,fieldLabel: _('class_key')
                            ,name: 'classKey'
                            ,anchor: '100%'
                            ,listeners: {
                                'change': {fn: this.filter, scope: this}
                                ,'render': {fn:this._addEnterKeyHandler}
                            }
                        }]
                    },{
                        columnWidth: .5
                        ,items: [{
                            xtype: 'datefield'
                            ,fieldLabel: _('date_start')
                            ,name: 'dateStart'
                            ,allowBlank: true
                            ,anchor: '100%'
                            ,listeners: {
                                'select': {fn: this.filter, scope: this}
                                ,'render': {fn:this._addEnterKeyHandler}
                            }
                        },{
                            xtype: 'datefield'
                            ,fieldLabel: _('date_end')
                            ,name: 'dateEnd'
                            ,allowBlank: true
                            ,anchor: '100%'
                            ,listeners: {
                                'select': {fn: this.filter, scope: this}
                                ,'render': {fn:this._addEnterKeyHandler}
                            }
                        },{
                            xtype: 'textfield'
                            ,fieldLabel: _('id')
                            ,name: 'item'
                            ,anchor: '100%'
                            ,listeners: {
                                'change': {fn: this.filter, scope: this}
                                ,'render': {fn:this._addEnterKeyHandler}
                            }
                        }]
                    }]
                }]
            },MODx.PanelSpacer,{
                xtype: 'modx-grid-manager-log'
                ,cls:'main-wrapper'
                ,preventRender: true
                ,formpanel: 'modx-panel-manager-log'
            }]
        }])]
    });
    MODx.panel.ManagerLog.superclass.constructor.call(this,config);
};
Ext.extend(MODx.panel.ManagerLog,MODx.FormPanel,{
    filter: function(tf,newValue,oldValue) {
        var p = this.getForm().getValues();
        var g = Ext.getCmp('modx-grid-manager-log');
        p.action = 'system/log/getList';
        g.getStore().baseParams = p;
        g.getStore().load({
            params: p
            ,start: 0
            ,limit: 20
        });
        g.getBottomToolbar().changePage(1);
    }

    ,_addEnterKeyHandler: function() {
        this.getEl().addKeyListener(Ext.EventObject.ENTER,function() {
            this.fireEvent('change');
        },this);
    }

    ,clearLog: function(btn,e) {
        MODx.msg.confirm({
            title: _('warning')
            ,text: _('mgrlog_clear_confirm')
            ,url: MODx.config.connector_url
            ,params: {
                action: 'system/log/truncate'
            }
            ,listeners: {
                'success': {fn:function() {
                    Ext.getCmp('modx-grid-manager-log').refresh();
                },scope:this}
            }
        });
    }
});
Ext.reg('modx-panel-manager-log',MODx.panel.ManagerLog);