Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
160
Disable paging with a PagerTemplate
posted

Hello,

I created my own PagerTemplate as described here

Because the Grid only groups the shown rows on the page I decided to disable the Paging so the user can see all grouped rows.

Before I created my own PagerTemplate the disable function of the behaviour worked.

Here is the asp code:

<script type="text/javascript">
<!--

function Grid_Paging_PageIndexChanged(sender)
{
var grid = $find('<%=Grid.ClientID%>');
var parentGrid = grid.get_gridView();
var dropdownlist = document.getElementById("ctl00_cphMain_DataControl1_Grid_ctl00_ctl00_DropDownList1");
//var dropdownlist = document.getElementById("<%=Grid.ClientID%>".concat("_ctl00_ctl00_DropDownList1"));

dropdownlist.options[parentGrid.get_behaviors().get_paging().get_pageIndex()].selected = true;
}

function PrevButton_Click()
{
var grid = $find('<%=Grid.ClientID%>');
var parentGrid = grid.get_gridView();
if (parentGrid.get_behaviors().get_paging().get_pageIndex() > 0) {
parentGrid.get_behaviors().get_paging().set_pageIndex(parentGrid.get_behaviors().get_paging().get_pageIndex() - 1);
}
}

function NextButton_Click() {
var grid = $find('<%=Grid.ClientID%>');
var parentGrid = grid.get_gridView();
if (parentGrid.get_behaviors().get_paging().get_pageIndex() < parentGrid.get_behaviors().get_paging().get_pageCount() - 1) {
parentGrid.get_behaviors().get_paging().set_pageIndex(parentGrid.get_behaviors().get_paging().get_pageIndex() + 1);
}
}

function FirstButton_Click() {
var grid = $find('<%=Grid.ClientID%>');
var parentGrid = grid.get_gridView();
parentGrid.get_behaviors().get_paging().set_pageIndex(0);
}

function LastButton_Click() {
var grid = $find('<%=Grid.ClientID%>');
var parentGrid = grid.get_gridView();
parentGrid.get_behaviors().get_paging().set_pageIndex(parentGrid.get_behaviors().get_paging().get_pageCount() - 1);
}

function IndexChanged() {
var grid = $find('<%=Grid.ClientID%>');
var parentGrid = grid.get_gridView();

var dropdownlist = document.getElementById("ctl00_cphMain_DataControl1_Grid_ctl00_ctl00_DropDownList1");
parentGrid.get_behaviors().get_paging().set_pageIndex(dropdownlist.selectedIndex);
}
</script>

<iggrd:WebHierarchicalDataGrid ID="Grid" runat="server" Width="576px" Height="250px" OnLoad="Grid_Load" OnRowSelectionChanged="Grid_RowSelectionChanged"
OnDataFiltered="Grid_DataFiltered" OnColumnSorted="Grid_ColumnSorted" ImageDirectory="" OnInit="Grid_Init"
OnGroupedColumnsChanged="Grid_GroupedColumnsChanged" OnRowIslandDataBinding="Grid_RowIslandDataBinding"
ShowFooter="True" AutoGenerateBands="False" >

<GroupingSettings EnableColumnGrouping="True" GroupAreaVisibility="Visible" InitialRowExpandState="Collapsed" ShowBandInGroupByArea="False" >
</GroupingSettings>

<Behaviors>
<iggrd:Activation>
</iggrd:Activation>
<iggrd:Selection CellClickAction="Row" RowSelectType="Single" CellSelectType="None">
<AutoPostBackFlags RowSelectionChanged="True" />
</iggrd:Selection>
<iggrd:Filtering>
</iggrd:Filtering>
<iggrd:Paging PageSize="30" QuickPages="5" PagerMode="NumericFirstLast">
<PagingClientEvents PageIndexChanged="Grid_Paging_PageIndexChanged" />
<PagerTemplate>
<asp:Button runat="server" ID="FirstButton" Text="<<" OnClientClick="FirstButton_Click(); return false" Height="22px" CssClass=".igg_PageLink" />
<asp:Button runat="server" ID="PrevButton" Text="<" OnClientClick="PrevButton_Click(); return false" Height="22px" CssClass=".igg_PageLink" />
<asp:Button runat="server" ID="NextButton" Text=">" OnClientClick="NextButton_Click(); return false" Height="22px" CssClass=".igg_PageLink" />
<asp:Button runat="server" ID="LastButton" Text=">>" OnClientClick="LastButton_Click(); return false" Height="22px" CssClass=".igg_PageLink" />
<asp:DropDownList ID="DropDownList1" runat="server" Height="26px" OnChange="IndexChanged()" ></asp:DropDownList>
<asp:Label ID="PageCount" runat="server" Text="von 1" Height="22px"></asp:Label>
</PagerTemplate>
</iggrd:Paging>
<iggrd:ColumnMoving>
</iggrd:ColumnMoving>
<iggrd:ColumnResizing>
</iggrd:ColumnResizing>
<iggrd:Sorting>
</iggrd:Sorting>
<iggrd:SummaryRow>
</iggrd:SummaryRow>
</Behaviors>
</iggrd:WebHierarchicalDataGrid>

In the code-behind I have disabled the Paging behaviour in the GroupedColumsChanged event.

protected void Grid_GroupedColumnsChanged(object sender, GroupedColumnsChangedEventArgs e)
{
if (e.GroupedColumns.Count > 0)
{
Grid.Behaviors.Paging.Enabled = false;
}
else
{
Grid.Behaviors.Paging.Enabled = true;
//Grid.Rows[0].Items.FindItemByKey(e.GroupedColumns[0].ColumnKey).Column.Hidden = false;
}
}

Can I disable the paging on the client?

Infragistics Version: 2014 Volume 2.

Parents
  • 16310
    Offline posted

    Hello,

    Thank you for the code shared. I understand you scenario but I am surprised if this worked without the Paging Template. Even if you disable the paging in the GroupedColumnsChaning server side event it does not seem to affect the app as a whole. I believe the behavior should be removed and grid rendered again for this to take effect, but before proceeding please review the attached sample and let me know if this is the behavior you were facing before implementing the template.

    WHDG_Paging.zip
Reply Children