Hi,
I am having issues with the autogeneratecolumns feature of igGrid.
I am given the task of making a generic grid which could render the data of a dynamic datasource provided to it at runtime.
I am using Asp.Net MVC. I have a view named Listing.cshtml which will get an action method and cotroller name in its ViewBag and render the grid with datasourceurl set as the ViewBag.ActionMethod & ViewBag,ControllerName supplied to it.
This means that the grid will be displaying dynamic data and its datasource will change dynamically, because GridDataSource action name will be passed as a parameter.
When I set autogeneratecolumns(true) my grid does not render the rows and instead shows a loading circle animation which keeps on loading. I was just checking to see if my grid would render the columns automatically or not, because if I specify the columns explicitly the grid renders fine. When i set autogeneratecolumns to true, the grid does not display data.
Why is that happening? Please guide me i am stuck here. How can I render the grid dynamically without knowing the columns of the datasource through Asp.Net MVC helper.
Also is this achievable that I have a single .cshtml page for my grid and at runtime the page is supplied with the DataSourceUrl, and after reading it from the ViewBag , The grid loads its datasource at runtime. Is this possible? If it is then what would I provide inside the @(Html.Infragistics().Grid<????>() ??
And would the grid render without specifying the @model directive on top of page because the model will change at runtime.
Please help me out here , and if possible please provide a working sample in which the grid datasource is loaded dynamically and its datasource is set to a string which contains the name of [GridDataSourceAction].
Also why my grid is no displaying data when i set autogeneratecolumns to true and renders fine when I explicitly specify the columns.
Any help would be appreciated.
Hello Vasya,
The filtering feature is working now. I had multiple reference of Infragistics in my view(.cshtml files), I had them in my parent view as well as the partial view, which was causing this problem. Now its working fine.
Thanks for your help & cooperation.
Hello zeppelin led,
Everything seems fine with the way Filtering behavior is defined in your code snippet.
In order to investigate this behavior further I will need small isolated ready-to-run sample where this behavior is reproducible. This is going to be highly appreciated and will help me to look deeper into this issue in pursuit of the root cause of the behavior.
Looking forward to hearing from you.
Thanks for the information
I am facing another problem right now. When I first wrote code of the grid in my controller (posted above), there was a row on top of the grid for filtering data , which contained textboxes for searching the grid items, but now for some strange reason that row disappeared, I dont remember doing anything with the filtering feature, I just notcied it is not there anymore, I tried to change the filtering type from remote to local and then back to remote but that too dint help. Other features like pagination are working but the filtering feature mysteriously disappeared. Can you help me in this regard, what could have happened .. I only played around with gridDataSource & gridDataSourceUrl , but I didnt change any filtering property. please help me out here.
Also when I increase the grid page size, the grid container expands , I need a vertical scroller to appear and dont want the grid to expand itself.
Thanks. Please try to answer these questions here if you can because I think these are more or less similar issues regarding the grid features.
Thank you for getting back to me.
When using this approach initially the data source for the igGrid will be loaded from the DataSource property. Afterwards, when requests are made, for example from the remote features being used(such as Filtering, Sorting, Paging) the data source will be loaded from the action set in the DataSourceUrl property.
I hope you find this information helpful.
Please let me know if you have any further questions regarding this matter.
Thanks for the detailed response Vasya. Appreciate your help. Now I understand that this was a dataSource issue but I didnt know how to provide different dataSource at runtime as required.
I wanted to use MVC Helper because of some reasons and not Jquery.
So I tried this method and its working now.
VIEW:
@model Infragistics.Web.Mvc.GridModel
@Html.Partial("_ListingCombo")<br/>@if(ViewBag.entityValue != null){ @Html.Infragistics().Grid(Model)}
CONTROLLER:
[HttpPost] public ActionResult Listing(string entityValue) { ViewBag.entityValue = entityValue; GridModel gridModel = GetGridModel(); return View(gridModel); }
private GridModel GetGridModel() { GridModel gridModel = new GridModel(); gridModel.ID = "MyGrid"; gridModel.AutoGenerateColumns = true; gridModel.AutoGenerateLayouts = true; gridModel.PrimaryKey = "usr_Username"; gridModel.Width = "100%"; gridModel.DataSourceUrl = Url.Action("GetUsers","Users"); //I think this way I can provide these value at runtime to change datasource? gridModel.DataSource = GetUsrs().AsQueryable();// And also invoke another method inplace of GetUsrs at runtime to change datasource dynamically? gridModel.ResponseDataKey="Records"; gridModel.Features.Add(new GridTooltips()); gridModel.Features.Add(new GridFiltering() { Type = OpType.Remote, Inherit = true}); gridModel.Features.Add(new GridSorting() { Type = OpType.Remote, Inherit = true }); gridModel.Features.Add(new GridPaging() { Type = OpType.Remote, Inherit = true, PageSize = 5 ,CurrentPageIndex=0,TotalRecordsCount=20 }); return gridModel; }
What do you suggest, Is this approach right ?