jQWidgets Forums

jQuery UI Widgets Forums Grid 'autoresizecolumn' is not working when grid is grouped

This topic contains 1 reply, has 2 voices, and was last updated by  Peter Stoev 11 years, 8 months ago.

Viewing 2 posts - 1 through 2 (of 2 total)
  • Author

  • aravindtrue
    Member

    Hi,

    I have auto resize column funtionality where the users can toggle the grid’s column look. Now the problem is, when the data are grouped by one or more columns, the auto resize column functionality does not seems to be working.

    I consoled my scripts step by step. I am using ‘cellsrenderer’ for all the columns. When I try to ‘autoresizecolumns’, the cellsrenderer method is called and it passes three arguments (row, datafield, value) to rerender a cell. When the grid is grouped, the ‘row’ value is not proper i.e.

    ->City: London (1)
    Eastern Connection
    -> City: Berlin (3)
    Alferds Futterkiste
    Aan Futterkiste
    Centro Commercial

    Here, City: London (1) is considered as row 0 and City: Berlin (3) is considered as row 2. These are not proper values where the actual value is ‘Eastern Connection’ should be 0 and ‘Alferds Futterkiste’ should be 1.

    Am I doing something wrong?

    Regards,
    Aravind M S


    Peter Stoev
    Keymaster

    Hi,

    That is not the behavior I see with ver. 2.9.3. Here’s a sample:

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <title id='Description'>Basic grouping Grid showing collapsible data groups that can
    be customized via the 'Group By' header menu option or via drag and drop of grid
    column headers.</title>
    <link rel="stylesheet" href="../../jqwidgets/styles/jqx.base.css" type="text/css" />
    <script type="text/javascript" src="../../scripts/jquery-1.10.1.min.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxcore.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxdata.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxbuttons.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxscrollbar.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxmenu.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.grouping.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.selection.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.columnsresize.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.sort.js"></script>
    <script type="text/javascript" src="../../scripts/gettheme.js"></script>
    <script type="text/javascript">
    $(document).ready(function () {
    var theme = getDemoTheme();
    var url = "../sampledata/customers.xml";
    // prepare the data
    var source =
    {
    datatype: "xml",
    datafields: [
    { name: 'CompanyName', map: 'm\\:properties>d\\:CompanyName', type: 'string' },
    { name: 'ContactName', map: 'm\\:properties>d\\:ContactName', type: 'string' },
    { name: 'ContactTitle', map: 'm\\:properties>d\\:ContactTitle', type: 'string' },
    { name: 'City', map: 'm\\:properties>d\\:City', type: 'string' },
    { name: 'PostalCode', map: 'm\\:properties>d\\:PostalCode', type: 'string' },
    { name: 'Country', map: 'm\\:properties>d\\:Country', type: 'string' }
    ],
    root: "entry",
    record: "content",
    id: 'm\\:properties>d\\:CustomerID',
    url: url
    };
    var dataAdapter = new $.jqx.dataAdapter(source);
    // Create jqxGrid
    $("#jqxgrid").jqxGrid(
    {
    width: 600,
    source: dataAdapter,
    groupable: true,
    theme: theme,
    ready: function()
    {
    $("#jqxgrid").jqxGrid('autoresizecolumn', 'CompanyName');
    },
    columns: [
    { text: 'Company Name', cellsrenderer: function(row, datafield, value){
    var r = row;
    },
    datafield: 'CompanyName', width: 250
    },
    { text: 'City', datafield: 'City', width: 120 },
    { text: 'Country', datafield: 'Country' }
    ],
    groups: ['City']
    });
    $("#expand").jqxButton({ theme: theme });
    $("#collapse").jqxButton({ theme: theme });
    $("#expandall").jqxButton({ theme: theme });
    $("#collapseall").jqxButton({ theme: theme });
    // expand group.
    $("#expand").on('click', function () {
    var groupnum = parseInt($("#groupnum").val());
    if (!isNaN(groupnum)) {
    $("#jqxgrid").jqxGrid('expandgroup', groupnum);
    }
    });
    // collapse group.
    $("#collapse").on('click', function () {
    var groupnum = parseInt($("#groupnum").val());
    if (!isNaN(groupnum)) {
    $("#jqxgrid").jqxGrid('collapsegroup', groupnum);
    }
    });
    // expand all groups.
    $("#expandall").on('click', function () {
    $("#jqxgrid").jqxGrid('expandallgroups');
    });
    // collapse all groups.
    $("#collapseall").on('click', function () {
    $("#jqxgrid").jqxGrid('collapseallgroups');
    });
    // trigger expand and collapse events.
    $("#jqxgrid").on('groupexpand', function (event) {
    var args = event.args;
    $("#expandedgroup").text("Group: " + args.group + ", Level: " + args.level);
    });
    $("#jqxgrid").on('groupcollapse', function (event) {
    var args = event.args;
    $("#collapsedgroup").text("Group: " + args.group + ", Level: " + args.level);
    });
    });
    </script>
    </head>
    <body class='default'>
    <div id='jqxWidget' style="font-size: 13px; font-family: Verdana; float: left;">
    <div id="jqxgrid">
    </div>
    <div style="margin-top: 30px;">
    <div style="float: left; margin-left: 20px;">
    <input value="Expand Group" type="button" id='expand' />
    <br />
    <input style="margin-top: 10px;" value="Collapse Group" type="button" id='collapse' />
    <br />
    <span style="margin-top: 10px;">Group:</span>
    <input value="1" id="groupnum" style="margin-top: 10px; width: 20px;" type="text" />
    </div>
    <div style="float: left; margin-left: 20px;">
    <input value="Expand All Groups" type="button" id='expandall' />
    <br />
    <input style="margin-top: 10px; margin-bottom: 10px;" value="Collapse All Groups"
    type="button" id='collapseall' />
    <br />
    </div>
    <div style="float: left; margin-left: 20px;">
    <div style="font-weight: bold;">
    <span>Event Log:</span>
    </div>
    <div style="margin-top: 10px;">
    <span>Expanded Group:</span> <span id="expandedgroup"></span>
    </div>
    <div style="margin-top: 10px;">
    <span>Collapsed Group:</span> <span id="collapsedgroup"></span>
    </div>
    </div>
    </div>
    </div>
    </body>
    </html>

    cellsrenderer is called with the same params when a cell is rendered and when you call “autoresizecolumns”. The Grouping rows are not included in the cellsrenderer.

    Best Regards,
    Peter Stoev

    jQWidgets Team
    http://www.jqwidgets.com/

Viewing 2 posts - 1 through 2 (of 2 total)

You must be logged in to reply to this topic.