Hi All,
I have a WHDG bound to a WebHierarchicalDataSource with a list of custom entities. The design on the grid is as follows:
<ig:WebHierarchicalDataGrid ID="uxDynamicContentsGrid" runat="server" Width="550px" Height="750px"
AutoGenerateBands="False" AutoGenerateColumns="False" EnableAJAX="false"
DataMember="DCDetails" Key="DCDetails" EnableDataViewState="false"
DataKeyFields="DynamicContentViewId"
GroupingSettings-ShowRemoveButton="False" StyleSetName="Office2007Silver"
GroupingSettings-GroupedRowTextMask="{1}" ShowHeader="False">
<EmptyRowsTemplate>There are no groups/ dynamic content assigned to the selected view.</EmptyRowsTemplate>
<GroupingSettings EnableColumnGrouping="True" GroupAreaVisibility="Hidden" ShowRemoveButton="False">
<RemoveButton AltText="Ungroup Column" />
</GroupingSettings>
<Behaviors>
<ig:Sorting Enabled="false"></ig:Sorting>
<ig:Activation>
</ig:Activation>
<ig:EditingCore AutoCRUD="False">
<ig:CellEditing>
<ColumnSettings>
<ig:EditingColumnSetting ColumnKey="DynamicContentName" ReadOnly="true" />
</ColumnSettings>
</ig:CellEditing>
<ig:RowDeleting />
</Behaviors>
</ig:EditingCore>
The grid is bound on every postback (to resolve certain other issues we have). The loading of the grid is as follows:
uxDynamicContentsGrid.Rows.Clear()
uxDynamicContentsGrid.GroupingSettings.EnableColumnGrouping = DefaultableBoolean.False
uxDynamicContentsGrid.GroupingSettings.GroupedColumns.Clear()
uxDynamicContentsGrid.GroupingSettings.ColumnSettings.Clear()
uxDynamicContentsSource.DataRelations.Clear()
uxDynamicContentsSource.DataViews.Clear()
uxDynamicContentsGrid.DataSource = Nothing
uxDynamicContentsGrid.DataBind()
Dim viewId As Integer = uxViewDropDown.SelectedValue
If viewId > 0 Then
contents = entityManager.GetContentsByEntityIdAndViewId(EntityId, viewId)
Else
contents = entityManager.GetContentsByEntityId(EntityId)
End If
' Specify data views
Dim dv As New Infragistics.Web.UI.DataSourceControls.DataView
dv = New Infragistics.Web.UI.DataSourceControls.DataView
dv.ID = "DCDetails"
dv.DataSource = contents
' Add view to datasource
uxDynamicContentsSource.DataViews.Add(dv)
uxDynamicContentsGrid.GroupingSettings.EnableColumnGrouping = DefaultableBoolean.True
' A calculated property OrderedGroupName has been added which returns GroupOrder_ContentOrder_GroupName
Dim setting As New GridControls.ColumnGroupingSetting
setting.ColumnKey = "OrderedGroupName"
setting.GroupComparer = New GroupNameComparer()
uxDynamicContentsGrid.GroupingSettings.ColumnSettings.Add(setting)
uxDynamicContentsGrid.GroupingSettings.GroupedColumns.Add("OrderedGroupName")
uxDynamicContentsGrid.DataSource = uxDynamicContentsSource
THE ISSUE
1. WE are trying to avoid the binding of the grid on every postback. As per, other forum responses, we tried setting the EnableDAtaViewState property of the grid and binding the datasource only if not postback.
However, we are getting all sorts of errors, two of which are below: Does anyone have a working sample of WHDG with EnableDataViewState="true" ? Is there anything we are missing?
2. When RowUpdate event is fired, it causes additional column to appear and changes the heading of the grid. Does WHDG require the datasource to be bound on row update as well?
Thanks!
Invalid postback or callback argument. Event validation is enabled using <pages enableEventValidation="true"/> in configuration or <%@ Page EnableEventValidation="true" %> in a page. For security purposes, this feature verifies that arguments to postback or callback events originate from the server control that originally rendered them. If the data is valid and expected, use the ClientScriptManager.RegisterForEventValidation method in order to register the postback or callback data for validation. Source : System.Web Help link : ParamName : Data : System.Collections.ListDictionaryInternal TargetSite : Void ValidateEvent(System.String, System.String) Stack Trace : at System.Web.UI.ClientScriptManager.ValidateEvent(String uniqueId, String argument) at System.Web.UI.Control.ValidateEvent(String uniqueID, String eventArgument) at System.Web.UI.WebControls.DropDownList.LoadPostData(String postDataKey, NameValueCollection postCollection) at System.Web.UI.WebControls.DropDownList.System.Web.UI.IPostBackDataHandler.LoadPostData(String postDataKey, NameValueCollection postCollection) at System.Web.UI.Page.ProcessPostData(NameValueCollection postData, Boolean fBeforeLoad) at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
Multiple controls with the same ID 'it3_0' were found. FindControl requires that controls have unique IDs. Source : System.Web Help link : ErrorCode : -2147467259 Data : System.Collections.ListDictionaryInternal TargetSite : Void FillNamedControlsTable(System.Web.UI.Control, System.Web.UI.ControlCollection) Stack Trace : at System.Web.UI.Control.FillNamedControlsTable(Control namingContainer, ControlCollection controls) at System.Web.UI.Control.FillNamedControlsTable(Control namingContainer, ControlCollection controls) at System.Web.UI.Control.EnsureNamedControlsTable() at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Control.FindControl(String id, Int32 pathOffset) at System.Web.UI.Page.FindControl(String id) at System.Web.UI.Page.ProcessPostData(NameValueCollection postData, Boolean fBeforeLoad) at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
Hi Michael,
Thanks for your reply. Hope you can get back to us today.
1. The grid has a InitializeRow events that build the grid template fields etc. and these are also unnecessarily called on every postback.
2. The Row_Updating event also requires the grid to be rebound when EnableDataViewState = true as we are getting the duplicate control id errors.
3. We are not adding any columns in code behind. The only thing we are doing in code behing is switching to group/ ungrouped view of the grid depending on a dropdown list selection.
4. The grid needs to maintain the changes until the 'Save' button is clicked. Currently, each row update raises a server event (to do some checks) which updates viewstate variables and the grid is then rebound to this view state variable. However, users are complaining that this is slow.
5. We have been trying to keep the changes on client side, however when a postback occurs the grid is rebound and the changes are lost.
Hope you can help us solve this issue.
Thanks.
Hi Insula Group Pty Ltd,
Thank you for posting in our forums!
I am glad to hear you were able to resolve the issue with multiple IDs occurring on the page.
If your concern with binding to the WebDataGrid on each postback is with accessing your database each time, one alternative is to store the DataSource in a Session variable and use that on each postback.
Setting EnableDataViewState to true is all that is required. I am unsure of what may cause that error and I will need a little more time to look into this issue.
For the issue where additional columns are appearing, are you dynamically creating columns in code behind elsewhere that you have not posted here?
I will have another update for you by Friday. If you have any further questions or concerns with this, please let me know.
An update, the error with the 'Multiple controls with same ID' is no longer happening. However, the invalid postback or callback argument error is happening after a couple of tree selections i.e. we can select two or three entities in the treeview properly, but after that when a tree selection is made, we start getting the following error for both dropdown list and checkbox controls"
We would appreciate any feedback from the Infragistics team or anyone else who has managed to successfully bind the grid only if not postback and use data view state all other times.
Thanks,