modxcms/revolution

View on GitHub
manager/assets/modext/widgets/security/modx.panel.groups.roles.js

Summary

Maintainability
C
1 day
Test Coverage
/**
 * @class MODx.panel.GroupsRoles
 * @extends MODx.FormPanel
 * @param {Object} config An object of configuration properties
 * @xtype modx-panel-groups-roles
 */
MODx.panel.GroupsRoles = function(config) {
    config = config || {};
    Ext.applyIf(config,{
        id: 'modx-panel-groups-roles'
        ,cls: 'container'
        ,defaults: { collapsible: false ,autoHeight: true }
        ,forceLayout: true
        ,items: [{
             html: _('user_group_management')
            ,id: 'modx-access-permissions-header'
            ,xtype: 'modx-header'
        },MODx.getPageStructure(this.getPageTabs(config),{
            id: 'modx-access-permissions-tabs'
            ,stateful: true
            ,stateId: 'access-tabpanel'
            ,stateEvents: ['tabchange']
            ,getState:function() {
                return {activeTab:this.items.indexOf(this.getActiveTab())};
            }
        })]
    });
    MODx.panel.GroupsRoles.superclass.constructor.call(this,config);

    var west, usergroupTree = Ext.getCmp('modx-tree-usergroup');

    usergroupTree.on('expandnode', this.fixPanelHeight);
    usergroupTree.on('collapsenode', this.fixPanelHeight);

    usergroupTree.addListener({
        resize : function(cmp) {
            var centre = Ext.getCmp('modx-usergroup-users');
            if (centre.hidden){
                Ext.getCmp('modx-tree-panel-usergroup').layout.west.getSplitBar().el.hide();
            }
        }
    });

    if (MODx.perm.usergroup_user_list == 1) {
        Ext.getCmp('modx-tree-usergroup').on('click', function(node,e){
            this.getUsers(node);
        }, this);
    }

    Ext.getCmp('modx-usergroup-users').store.on('load', this.fixPanelHeight);
};
Ext.extend(MODx.panel.GroupsRoles,MODx.FormPanel,{
    getPageTabs: function(config) {
        var tbs = [];
        if (MODx.perm.usergroup_view == 1) {
            tbs.push({
                title: _('user_groups') + ' & ' + _('users')
                ,autoHeight: true
                ,layout: 'form'
                ,items: [{
                    html: '<p>'+_('user_group_management_msg')+'</p>'
                    ,xtype: 'modx-description'
                },{
                    layout: 'border'
                    ,id: 'modx-tree-panel-usergroup'
                    ,height: 500
                    ,border:false
                    ,defaults: {
                        border:false
                        ,bodyStyle: 'background-color:transparent;'
                    }
                    ,items: [
                        {
                            region:'west'
                            ,cls:'main-wrapper'
                            ,collapseMode: 'mini'
                            ,split: true
                            ,useSplitTips: true
                            ,monitorResize: true
                            ,width: 280
                            ,minWidth: 280
                            ,minSize: 280
                            ,maxSize: 400
                            ,layout: 'fit'
                            ,items: [{
                                xtype: 'modx-tree-usergroup'
                            }]
                        }, {
                            region: 'center'
                            ,id: 'modx-usergroup-users'
                            ,xtype: 'modx-grid-user-group-users'
                            ,hidden: true
                            ,usergroup: '0'
                            ,layout: 'fit'
                            ,cls:'main-wrapper'
                        }
                    ]
                }]
            });
        }
        if (MODx.perm.view_role == 1) {
            tbs.push({
                title: _('roles')
                ,autoHeight: true
                ,layout: 'form'
                ,items: [{
                    html: '<p>'+_('roles_msg')+'</p>'
                    ,xtype: 'modx-description'
                },{
                    xtype: 'modx-grid-role'
                    ,cls:'main-wrapper'
                    ,title: ''
                    ,preventRender: true
                }]
            });
        }
        if (MODx.perm.policy_view == 1) {
            tbs.push({
                title: _('policies')
                ,id: 'modx-panel-access-policies'
                ,autoHeight: true
                ,layout: 'form'
                ,items: [{
                    html: '<p>'+_('policy_management_msg')+'</p>'
                    ,xtype: 'modx-description'
                },{
                    xtype: 'modx-grid-access-policy'
                    ,cls:'main-wrapper'
                }]
            });
        }
        if (MODx.perm.policy_template_view) {
            tbs.push({
                title: _('policy_templates')
                ,id: 'modx-panel-access-policy-templates'
                ,autoHeight: true
                ,layout: 'form'
                ,items: [{
                    html: '<p>'+_('policy_templates.intro_msg')+'</p>'
                    ,xtype: 'modx-description'
                },{
                    xtype: 'modx-grid-access-policy-templates'
                    ,cls:'main-wrapper'
                }]
            });
        }
        return tbs;
    }
    ,getUsers: function(node) {
        var center = Ext.getCmp('modx-usergroup-users');
        center.removeAll();
        var id = node.attributes.id;
        var usergroup = id.replace('n_ug_', '') - 0; // typecasting

        var userGrid = Ext.getCmp('modx-usergroup-users');
        var westPanel = Ext.getCmp('modx-tree-panel-usergroup').layout.west;

        if (usergroup == 0) {
            userGrid.hide();
            westPanel.getSplitBar().el.hide();
        } else {
            userGrid.show();
            westPanel.getSplitBar().el.show();
            userGrid.usergroup = usergroup;
            userGrid.config.usergroup = usergroup;
            userGrid.store.baseParams.usergroup = usergroup;
            userGrid.clearFilter();
        }

    }
    ,fixPanelHeight: function() {
        // fixing border layout's height regarding to tree panel's
        var tree = Ext.getCmp('modx-tree-usergroup');
        var groupUsers = Ext.getCmp('modx-usergroup-users');
        var userGroupPanel = Ext.getCmp('modx-tree-panel-usergroup');

        if (tree.rendered && groupUsers.rendered && userGroupPanel.rendered) {
            var treeEl = tree.getEl();
            var treeH = treeEl.getHeight();
            var cHeight = groupUsers.getHeight(); // .main-wrapper
            var maxH = (treeH > cHeight) ? treeH : cHeight;
            maxH = maxH > 500 ? maxH : 500;
            userGroupPanel.setHeight(maxH);
            Ext.getCmp('modx-content').doLayout();
        }
    }
});
Ext.reg('modx-panel-groups-roles',MODx.panel.GroupsRoles);