Hello,
I'm trying to implement a grid with row virtualization and groups, based on this example : https://demos.telerik.com/aspnet-mvc/grid/server-grouppaging-virtualization . But I see an odd behavior. When I group rows on two columns, then expand the first level group, in my case, there is no filter sent to the server, only group.
Here is the request sent by the grid in my case :
sort: page: 1pageSize: 50group: RAISONSOCIALE-asc~LIBELLERIB-ascfilter: take: 50skip: 0groupPaging: true
And here is the one in the example I use :
sort: page: 1pageSize: 50group: CompanyName-ascfilter: City~eq~'Shady Point'skip: 0take: 50groupPaging: true
Here is the grid :
Html.Kendo().Grid<SomeObject>()    .Name("ForecastListGrid")    .Groupable()    .Columns(columns =>    {        columns.Select().Width(50).HtmlAttributes(new { @class = "checkbox-align" }).HeaderHtmlAttributes(new { @class = "checkbox-align" });        columns.Bound(p => p.RAISONSOCIALE);        columns.Bound(p => p.CODE_FLUX);        columns.Bound(p => p.DATE_O).Width(100).Encoded(false).ClientTemplate("#=kendo.toString(kendo.parseDate(DATE_O,'dd/MM/yyyy'), '" + "dd/MM/yyyy" + "')#");        columns.Bound(p => p.DATE_V).Width(100).Encoded(false).ClientTemplate("#=kendo.toString(kendo.parseDate(DATE_V,'dd/MM/yyyy'), '" + "dd/MM/yyyy" + "')#"); ;        columns.Bound(p => p.NOMBRE);        columns.Bound(p => p.LIBELLE);        columns.Bound(p => p.REFERENCE);    })    .Scrollable(scrollable => scrollable.Virtual(true))    .Height(500)    .DataSource(dataSource => dataSource        .Ajax()        .Events(events =>            events.Error("error_handler")        )        .Model(model =>        {            model.Id(p => p.ID);        })        .GroupPaging(true)        .PageSize(50)        .Read("LoadGrid", "Test")    )
Is there something I'm missing ?
Thanks !
28 Answers, 1 is accepted
Hello Pierrick,
I examined the provided configuration of the Grid and it looks fine to me.
That said, one thing that could cause the behavior is using an older version of the Kendo scripts. Please make sure that all JavaScript files are from the latest version of the components. The CSS files should also have a matching version to avoid any appearance issues.
After referencing the latest scripts and running the application make sure to do a hard refresh in the browser to ensure it requests all resources again.
Regards,
 
Viktor Tachev
 Progress Telerik
    
Our thoughts here at Progress are with those affected by the outbreak.

Thank you for your help. As you pointed out, there was a difference of version between the dll and js files. Now, all is in 2020.2.617.545 version. Unfortunately, it didn't solve the issue.
So, I've done some more tests. In the first place, I used the DataSourceRequest object to create a SQL query in order to fetch precisely the needed data. Then it was transformed to be usable by the Grid.
In my last test, I got rid of that to simplify as much as possible. Here's the result :
public ActionResult LoadGrid([DataSourceRequest]DataSourceRequest request){    List<TRE_ECRITURES_PEntity> data = new TRE_ECRITURES_PService().AllData();    var result = data.ToDataSourceResult(request);    return Json(result);}
First, it retrieves all data, then processed with IEnumerable.ToDataSourceResult(DataSourceRequest) from Kendo.Mvc.Extensions namespace. Lastly, it's converted in json, and sent back to the Grid.
When I run this, at first it works fine. Then I group on one column. Still works. But with a second group, it always throw an exception on the json conversion : System.ArgumentNullException, Value cannot be null. Parameter name : source.
   at System.Linq.Enumerable.OfType[TResult](IEnumerable source)
   at Kendo.Mvc.Infrastructure.Group.InitializeSubgroups()
   at Kendo.Mvc.Infrastructure.Group.get_Subgroups()
Neither of the two columns I'm trying to group are empty or null.
Thanks !
Hi Pierrick,
My name is Tsvetomir and I am covering for my colleague Viktor.
It is great that you have let the DataSource extension method handle the format of the response. I have noticed that all of the needed options in the grid and data source are correctly set.
In our live demo, I have performed various tests and I have not noticed any server-side exceptions or error at all. Could you try replicating the issue with our live demo below?
https://demos.telerik.com/aspnet-mvc/grid/server-grouppaging-virtualization
In order for me to be maximally efficient, I would need to investigate the defect locally. Is it convenient for you to create an example in which the server-side error can be replicated?
Kind regards,
      
Tsvetomir
 Progress Telerik
    

Hello Tsvetomir,
I can confirm that I never had this error in the live demo.
I made you an example. I just created a new "Telerik ASP.Net MVC Application" (version 2020.2.617.545), and made a few changes. I added ExampleModel.cs in the Models folder, changed the GridController.cs and Index.cshtml files. Finally, I added "reduceddata.json" next to the .csproj file.
It is the simplest example I could make, that allow to reproduce the problem. With that, wherever I try to group data on 2 columns, I get the error.
You can find all needed files in the attached archive.
Thank you for your help.
Hi Pierrick,
Thank you for the provided code snippets that are needed to replicate the issue. Indeed, I managed to replicate it and it has already been reported and fixed (it is ready to be tested by the QA team). The fix will be live with any of the next releases.
https://github.com/telerik/kendo-ui-core/issues/5876
Kind regards,
      
Tsvetomir
 Progress Telerik
    

Hi Geetha,
I am happy to inform you that the fix has passed the testing phase and it will be available with the very next release of the Kendo UI library. It is planned for mid-September. At present, there is no workaround that could be used.
Regards,
 
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive , special prizes and more, for FREE?! Register now for DevReach 2.0(20).

Hello Tsvetomir, I recieved an update today for telerik asp.net MVC with relaese notes mentioning the upgrades to the grid(https://www.telerik.com/support/whats-new/aspnet-mvc/release-history/ui-for-asp-net-mvc-r3-2020).
How should i change the code in the controller to resolve the abve mentioned problem? could you please assist us, as this is on a higher priority in our application.
Regards,
Geetha Naidu
Hi Geetha,
No changes are needed in order to have the group virtualization working as expected. All that is needed to be done is to update the Kendo.Mvc.dll - the source for the server-side widget and the version of the client-side resources - CSS and JavaScript.
Can you confirm whether the issue is present after upgrading to 2020 R3 version?
Best regards,
      
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive , special prizes and more, for FREE?! Register now for DevReach 2.0(20).

Hello Tsvetomir, Thank you for replying, yes i did updated my webapplication with 2020.3.915.545 version of Kendp.MVC.dll css and js files, i tried to run the application, but the problem still exist. How to go about this?
Regards,
NAIDU Geetha
Hi Geetha,
I can confirm that with the latest version of the Kendo UI library, I can not replicate the issue. Therefore, grouping by two fields and expanding a group, a server error is not being thrown.
Please find attached an example with the latest version applied.
Is there a chance that you have upgraded the dlls, however, the references from the project to be pointing to the previous version?
Regards,
 
Tsvetomir
 Progress Telerik
    
Virtual Classroom, the free self-paced technical training that gets you up to speed with Telerik and Kendo UI products quickly just got a fresh new look + new and improved content including a brand new Blazor course! Check it out at https://learn.telerik.com/.

Hello Tsvetomir , Thank you for sending use a sample, i did run the sample, it works great.
I have few questions from the above sample, like in the function LoadGrid you are actually retrieving the whole list, is it necessary to do this? in my application i have millions of records. I tried doing it but the expandGrouping is infinite and never displays the result.
The current secnario in our application is bit complicated, the list retirved is a List<dynamic> expandGrouping is infinite and never displays the result.
Can you help me how to resolved these issues?
Regards,
Geetha
Hi Pierrick,
The Kendo UI DataSourceResult object works with IQueryable collections as well. There is no need to request all of the data at once on the server and return only a portion. The example that I provided is for testing purposes only.
For instance, the following demo is not bound directly to a list of items:
https://demos.telerik.com/aspnet-mvc/grid/server-grouppaging-virtualization
Its server-side implementation can be observed in our dedicated repository for data services at:
https://github.com/telerik/kendo-ui-demos-service/tree/master/graphql/graphql-aspnet-core
If there is anything else I can help with, let me know.
Kind regards,
      
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive, special prizes, and more, for FREE?! Register now for DevReach 2.0(20).

Hello Tsvetomir, Thank you, yes the example works, but i my code when i expand a group i get this httpresponse below
{"Data":null,"Total":1,"AggregateResults":null,"Errors":null}
I am unable to figure out why the Data is null when i expand a group. can you help me on this? this is very important task in my project and almost all the pages with grid needs this functionality
Regards,
Geetha
Hi Pierrick,
The actual server grouping functionality depends on several AJAX requests in order to display the correct data item. This is due to the fact that the actual group is regarded as a separate data item even though it is not present in the database.
However, returning no data with the READ requests is not the desired behavior. Nevertheless, I did not manage to replicate the issue locally.
Is it possible for you to share a sample where the described behavior can be observed? For instance, take the sample from one of my previous responses and modify it in order to replicate the defect. I will then investigate it and get back to you with the respective suggestions.
Thank you for your cooperation.
Kind regards,
      
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive, special prizes, and more, for FREE?! Register now for DevReach 2.0(20).

Hello Tsvetomir, thank you for confirmation, below is the exception i get when i try to group the list. I am attaching the project here to test.
Server Error in '/' Application.<br><br> Value cannot be null.<br>Parameter name: source <br> Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.<br><br> Exception Details: System.ArgumentNullException: Value cannot be null.<br>Parameter name: source<br><br>Source Error: <br><br> An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.                      <br>Stack Trace: <br><br>[ArgumentNullException: Value cannot be null.Parameter name: source]   System.Linq.Enumerable.OfType(IEnumerable source) +4957832   Kendo.Mvc.Extensions.DataTableWrapperExtensions.SerializeToDictionary(IEnumerable enumerable, DataTable ownerDataTable) +144   Kendo.Mvc.Extensions.DataTableWrapperExtensions.SerializeGroupItem(DataTable ownerDataTable, IGroup group) +141   Kendo.Mvc.Extensions.<>c__DisplayClass1_0.<SerializeToDictionary>b__0(IGroup group) +8   System.Linq.WhereSelectEnumerableIterator`2.MoveNext() +167   System.Web.Script.Serialization.JavaScriptSerializer.SerializeEnumerable(IEnumerable enumerable, StringBuilder sb, Int32 depth, Hashtable objectsInUse, SerializationFormat serializationFormat) +72   System.Web.Script.Serialization.JavaScriptSerializer.SerializeValueInternal(Object o, StringBuilder sb, Int32 depth, Hashtable objectsInUse, SerializationFormat serializationFormat, MemberInfo currentMember) +1280   System.Web.Script.Serialization.JavaScriptSerializer.SerializeValue(Object o, StringBuilder sb, Int32 depth, Hashtable objectsInUse, SerializationFormat serializationFormat, MemberInfo currentMember) +195   System.Web.Script.Serialization.JavaScriptSerializer.SerializeCustomObject(Object o, StringBuilder sb, Int32 depth, Hashtable objectsInUse, SerializationFormat serializationFormat) +481   System.Web.Script.Serialization.JavaScriptSerializer.SerializeValueInternal(Object o, StringBuilder sb, Int32 depth, Hashtable objectsInUse, SerializationFormat serializationFormat, MemberInfo currentMember) +1325   System.Web.Script.Serialization.JavaScriptSerializer.SerializeValue(Object o, StringBuilder sb, Int32 depth, Hashtable objectsInUse, SerializationFormat serializationFormat, MemberInfo currentMember) +195   System.Web.Script.Serialization.JavaScriptSerializer.Serialize(Object obj, StringBuilder output, SerializationFormat serializationFormat) +29   System.Web.Script.Serialization.JavaScriptSerializer.Serialize(Object obj, SerializationFormat serializationFormat) +64   System.Web.Mvc.JsonResult.ExecuteResult(ControllerContext context) +343   System.Web.Mvc.ControllerActionInvoker.InvokeActionResult(ControllerContext controllerContext, ActionResult actionResult) +13   System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilterRecursive(IList`1 filters, Int32 filterIndex, ResultExecutingContext preContext, ControllerContext controllerContext, ActionResult actionResult) +56   System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilterRecursive(IList`1 filters, Int32 filterIndex, ResultExecutingContext preContext, ControllerContext controllerContext, ActionResult actionResult) +420   System.Web.Mvc.ControllerActionInvoker.InvokeActionResultWithFilters(ControllerContext controllerContext, IList`1 filters, ActionResult actionResult) +52   System.Web.Mvc.Async.<>c__DisplayClass3_6.<BeginInvokeAction>b__4() +198   System.Web.Mvc.Async.<>c__DisplayClass3_1.<BeginInvokeAction>b__1(IAsyncResult asyncResult) +100   System.Web.Mvc.Async.WrappedAsyncResult`1.CallEndDelegate(IAsyncResult asyncResult) +10   System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49   System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeAction(IAsyncResult asyncResult) +27   System.Web.Mvc.<>c.<BeginExecuteCore>b__152_1(IAsyncResult asyncResult, ExecuteCoreState innerState) +11   System.Web.Mvc.Async.WrappedAsyncVoid`1.CallEndDelegate(IAsyncResult asyncResult) +29   System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49   System.Web.Mvc.Controller.EndExecuteCore(IAsyncResult asyncResult) +45   System.Web.Mvc.<>c.<BeginExecute>b__151_2(IAsyncResult asyncResult, Controller controller) +13   System.Web.Mvc.Async.WrappedAsyncVoid`1.CallEndDelegate(IAsyncResult asyncResult) +22   System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49   System.Web.Mvc.Controller.EndExecute(IAsyncResult asyncResult) +26   System.Web.Mvc.Controller.System.Web.Mvc.Async.IAsyncController.EndExecute(IAsyncResult asyncResult) +10   System.Web.Mvc.<>c.<BeginProcessRequest>b__20_1(IAsyncResult asyncResult, ProcessRequestState innerState) +28   System.Web.Mvc.Async.WrappedAsyncVoid`1.CallEndDelegate(IAsyncResult asyncResult) +29   System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49   System.Web.Mvc.MvcHandler.EndProcessRequest(IAsyncResult asyncResult) +28   System.Web.Mvc.MvcHandler.System.Web.IHttpAsyncHandler.EndProcessRequest(IAsyncResult result) +9   System.Web.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +9847873   System.Web.HttpApplication.ExecuteStepImpl(IExecutionStep step) +50   System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +163

Hi Geetha,
Thank you for the provided code snippets. Indeed, the issue can be replicated when the grid is bound to a DataTable and the GroupPaging option of the data source is used.
With that said, I would need more time to investigate the issue. The moment I have any findings, I will contact you immediately.
Kind regards,
      
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive, special prizes, and more, for FREE?! Register now for DevReach 2.0(20).

Hello Tsvetomir, Thank you for your quick reply, indeed 90% of our aplication pages contains grid in some way or the other, and GroupPaging is enabled for all of them with virtualization. We need your help to resolve this problem as soon as possible. In case can you provide us the Implementation of the QueryableExtensions class?
Regards,
NAIDU Geetha
Hi Geetha,
I have observed the behavior in detail and I can confirm that this is a bug on our side. I have created a feedback portal item and you could track its progress here:
As present, there is no workaround available due to the fact that the implementation in C# has to be modified. However, this would require the precompilation of the Kendo.Mvc.dll.
Kind regards,
      
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive, special prizes, and more, for FREE?! Register now for DevReach 2.0(20).

Hi Tsvetomir, Than you for the reply, i have some other problem with Grid grouping, on grouping all the rows must be expanded, i am using the below code to achieve it.
function onDataBound(e) {<br>    var grid = this;<br>    grid.table.find("tr").each(function () {<br>        var dataItem = grid.dataItem(this);<br>        if (dataItem !== undefined) {<br>            var type = dataItem.Discontinued ? 'success' : 'error';<br>            var text = dataItem.Discontinued ? 'available' : 'not available';<br>        }<br><br>        $(this).find('script').each(function () {<br>            eval($(this).html());<br>        });<br>        kendo.bind($(this), dataItem);<br>   <br>        var groupsToExpand = e.sender.tbody.find(".k-grouping-row:not(Discontinued)");<br>        groupsToExpand.each(function (e) {<br>            grid.expandGroup(this);<br>        });<br>    });<br>}This works correctly for one column grouping when i use,
var groupsToExpand = e.sender.tbody.find(".k-grouping-row");
but for multiple columns grouping, i tried this code
var groupsToExpand = e.sender.tbody.find(".k-grouping-row:not(Discontinued)");
I get javascript errors below. Could you please help me to resolve this issue?
Uncaught RangeError: Maximum call stack size exceeded<br>    at n.fn.init.prepend (jquery-1.12.4.min.js:3)<br>    at n.fn.init.n.fn.<computed> [as prependTo] (jquery-1.12.4.min.js:3)<br>    at Object.progress (kendo.all.js:2473)<br>    at init._progress (kendo.all.js:70120)<br>    at init.expandGroup (kendo.all.js:69734)<br>    at HTMLTableRowElement.<anonymous> (ecritures_financements.js:133)<br>    at Function.each (jquery-1.12.4.min.js:2)<br>    at R.fn.init.each (jquery-1.12.4.min.js:2)<br>    at HTMLTableRowElement.<anonymous> (ecritures_financements.js:128)<br>    at Function.each (jquery-1.12.4.min.js:2)<br>kendo.all.js:238 Uncaught Error: Invalid template:'<tr class="k-master-row" data-uid="#=data.uid#" role='row'><td class="k-group-cell"> </td><td class="k-group-cell"> </td><td class="checkbox-align" aria-describedby='5adbc236-5beb-423c-8858-1aa092c44963' role='gridcell'><input class="k-checkbox" data-role="checkbox" aria-label="Select row" aria-checked="false" type="checkbox"></td><td  aria-describedby='1e6068e6-b179-4efa-b422-c3db1b5300ec' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['Nature'] ? '<span class="k-dirty"></span>' : '' ##var v ={"0":"Placement","1":"Financement"}##var f = v[Nature]#${f != null ? f : ''}</td><td  aria-describedby='e1643122-3bfa-499c-b860-4f25748bee38' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['DenominationSociete'] ? '<span class="k-dirty"></span>' : '' ##:data.DenominationSociete==null?'':data.DenominationSociete#</td><td  aria-describedby='baaaf416-7e13-4e90-a81b-e985fa20a9d5' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['CodeBanque'] ? '<span class="k-dirty"></span>' : '' ##:data.CodeBanque==null?'':data.CodeBanque#</td><td  aria-describedby='2b268417-fba0-4b2d-80d5-678232ee1c81' role='gridcell'><span>#:Type#</span></td><td  aria-describedby='c5644dc4-c40b-4562-b280-2b46fab81b95' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['Libelle'] ? '<span class="k-dirty"></span>' : '' ##:data.Libelle==null?'':data.Libelle#</td><td class="montant-align-right" aria-describedby='b7494e7a-e4eb-434b-a4be-a46f23e6d4f4' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['Montant'] ? '<span class="k-dirty"></span>' : '' ##:kendo.format("{0:n2\}",data.Montant==null?'':data.Montant)#</td><td  aria-describedby='e3d2cb9a-01dd-4622-b2b9-b377c71991d0' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['Devise'] ? '<span class="k-dirty"></span>' : '' ##:data.Devise==null?'':data.Devise#</td><td  aria-describedby='20cf5365-9aaf-4a4a-9443-00919607294a' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['DateDebut'] ? '<span class="k-dirty"></span>' : '' ##=kendo.toString(DateDebut, 'dd/MM/yyyy')#</td><td  aria-describedby='bed0779d-d5eb-4c5e-9d50-7f3587457462' role='gridcell'>#= data && data.dirty && data.dirtyFields && data.dirtyFields['DateFin'] ? '<span class="k-dirty"></span>' : '' ##=kendo.toString(DateFin, 'dd/MM/yyyy')#</td></tr>' Generated code:'var $kendoOutput, $kendoHtmlEncode = kendo.htmlEncode;with(data){$kendoOutput='<tr class="k-master-row" data-uid="'+(data.uid)+'" role=\'row\'><td class="k-group-cell"> </td><td class="k-group-cell"> </td><td class="checkbox-align" aria-describedby=\'5adbc236-5beb-423c-8858-1aa092c44963\' role=\'gridcell\'><input class="k-checkbox" data-role="checkbox" aria-label="Select row" aria-checked="false" type="checkbox"></td><td  aria-describedby=\'1e6068e6-b179-4efa-b422-c3db1b5300ec\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['Nature'] ? '<span class="k-dirty"></span>' : '' )+'';var v ={"0":"Placement","1":"Financement"};$kendoOutput+='';var f = v[Nature];$kendoOutput+=''+($kendoHtmlEncode(f != null ? f : ''))+'</td><td  aria-describedby=\'e1643122-3bfa-499c-b860-4f25748bee38\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['DenominationSociete'] ? '<span class="k-dirty"></span>' : '' )+''+$kendoHtmlEncode(data.DenominationSociete==null?'':data.DenominationSociete)+'</td><td  aria-describedby=\'baaaf416-7e13-4e90-a81b-e985fa20a9d5\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['CodeBanque'] ? '<span class="k-dirty"></span>' : '' )+''+$kendoHtmlEncode(data.CodeBanque==null?'':data.CodeBanque)+'</td><td  aria-describedby=\'2b268417-fba0-4b2d-80d5-678232ee1c81\' role=\'gridcell\'><span>'+$kendoHtmlEncode(Type)+'</span></td><td  aria-describedby=\'c5644dc4-c40b-4562-b280-2b46fab81b95\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['Libelle'] ? '<span class="k-dirty"></span>' : '' )+''+$kendoHtmlEncode(data.Libelle==null?'':data.Libelle)+'</td><td class="montant-align-right" aria-describedby=\'b7494e7a-e4eb-434b-a4be-a46f23e6d4f4\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['Montant'] ? '<span class="k-dirty"></span>' : '' )+''+$kendoHtmlEncode(kendo.format("{0:n2}",data.Montant==null?'':data.Montant))+'</td><td  aria-describedby=\'e3d2cb9a-01dd-4622-b2b9-b377c71991d0\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['Devise'] ? '<span class="k-dirty"></span>' : '' )+''+$kendoHtmlEncode(data.Devise==null?'':data.Devise)+'</td><td  aria-describedby=\'20cf5365-9aaf-4a4a-9443-00919607294a\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['DateDebut'] ? '<span class="k-dirty"></span>' : '' )+''+(kendo.toString(DateDebut, 'dd/MM/yyyy'))+'</td><td  aria-describedby=\'bed0779d-d5eb-4c5e-9d50-7f3587457462\' role=\'gridcell\'>'+( data && data.dirty && data.dirtyFields && data.dirtyFields['DateFin'] ? '<span class="k-dirty"></span>' : '' )+''+(kendo.toString(DateFin, 'dd/MM/yyyy'))+'</td></tr>';}return $kendoOutput;'<br>    at Object.compile (kendo.all.js:238)<br>    at Object.d [as template] (jquery-1.12.4.min.js:2)<br>    at init._tmpl (kendo.all.js:68681)<br>    at init._templates (kendo.all.js:68835)<br>    at init.refresh (kendo.all.js:70201)<br>    at init.d (jquery-1.12.4.min.js:2)<br>    at init.trigger (kendo.all.js:164)<br>    at init._process (kendo.all.js:7941)<br>    at init._processRangeData (kendo.all.js:8820)<br>    at init.range (kendo.all.js:8651)<br>compile @ kendo.all.js:238<br>d @ jquery-1.12.4.min.js:2<br>_tmpl @ kendo.all.js:68681<br>_templates @ kendo.all.js:68835<br>refresh @ kendo.all.js:70201<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115<br>trigger @ kendo.all.js:164<br>refresh @ kendo.all.js:70258<br>d @ jquery-1.12.4.min.js:2<br>trigger @ kendo.all.js:164<br>_process @ kendo.all.js:7941<br>_processRangeData @ kendo.all.js:8820<br>range @ kendo.all.js:8651<br>expandGroup @ kendo.all.js:69735<br>(anonymous) @ ecritures_financements.js:133<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>(anonymous) @ ecritures_financements.js:128<br>each @ jquery-1.12.4.min.js:2<br>each @ jquery-1.12.4.min.js:2<br>onDataBound @ ecritures_financements.js:115
trigger @ kendo.all.js:164
refresh @ kendo.all.js:70258
d @ jquery-1.12.4.min.js:2
trigger @ kendo.all.js:164
_process @ kendo.all.js:7941
_processRangeData @ kendo.all.js:8820
range @ kendo.all.js:8651
expandGroup @ kendo.all.js:69735
(anonymous) @ ecritures_financements.js:133
each @ jquery-1.12.4.min.js:2
each @ jquery-1.12.4.min.js:2
(anonymous) @ ecritures_financements.js:128
each @ jquery-1.12.4.min.js:2
each @ jquery-1.12.4.min.js:2
onDataBound @ ecritures_financements.js:115
trigger @ kendo.all.js:164
refresh @ kendo.all.js:70258
XMLHttpRequest.send (async)
send @ jquery-1.12.4.min.js:4
ajax @ jquery-1.12.4.min.js:4
read @ kendo.all.js:6404
read @ kendo.aspnetmvc.js:257
(anonymous) @ kendo.all.js:8186
_queueRequest @ kendo.all.js:7790
(anonymous) @ kendo.all.js:8184
setTimeout (async)
getGroupItems @ kendo.all.js:8183
_findGroupedRange @ kendo.all.js:8100
_findRange @ kendo.all.js:8711
range @ kendo.all.js:8649
(anonymous) @ kendo.all.js:8252
n.success @ kendo.all.js:6404
i @ jquery-1.12.4.min.js:2
fireWith @ jquery-1.12.4.min.js:2
y @ jquery-1.12.4.min.js:4
c @ jquery-1.12.4.min.js:4
XMLHttpRequest.send (async)
send @ jquery-1.12.4.min.js:4
ajax @ jquery-1.12.4.min.js:4
read @ kendo.all.js:6404
read @ kendo.aspnetmvc.js:257
(anonymous) @ kendo.all.js:8222
_queueRequest @ kendo.all.js:7790
(anonymous) @ kendo.all.js:8220
setTimeout (async)
getGroupSubGroupCount @ kendo.all.js:8219
_findGroupedRange @ kendo.all.js:8088
_findRange @ kendo.all.js:8711
range @ kendo.all.js:8649
(anonymous) @ kendo.all.js:8284
n.success @ kendo.all.js:6404
i @ jquery-1.12.4.min.js:2
fireWith @ jquery-1.12.4.min.js:2
y @ jquery-1.12.4.min.js:4
c @ jquery-1.12.4.min.js:4
XMLHttpRequest.send (async)
send @ jquery-1.12.4.min.js:4
ajax @ jquery-1.12.4.min.js:4
read @ kendo.all.js:6404
read @ kendo.aspnetmvc.js:257
(anonymous) @ kendo.all.js:8186
_queueRequest @ kendo.all.js:7790
(anonymous) @ kendo.all.js:8184
setTimeout (async)
getGroupItems @ kendo.all.js:8183
_findGroupedRange @ kendo.all.js:8100
_findRange @ kendo.all.js:8711
range @ kendo.all.js:8649
(anonymous) @ kendo.all.js:8252
n.success @ kendo.all.js:6404
i @ jquery-1.12.4.min.js:2
fireWith @ jquery-1.12.4.min.js:2
y @ jquery-1.12.4.min.js:4
c @ jquery-1.12.4.min.js:4
XMLHttpRequest.send (async)
send @ jquery-1.12.4.min.js:4
ajax @ jquery-1.12.4.min.js:4
read @ kendo.all.js:6404
read @ kendo.aspnetmvc.js:257
(anonymous) @ kendo.all.js:8222
_queueRequest @ kendo.all.js:7790
(anonymous) @ kendo.all.js:8220
setTimeout (async)
getGroupSubGroupCount @ kendo.all.js:8219
_findGroupedRange @ kendo.all.js:8088
_findRange @ kendo.all.js:8711
range @ kendo.all.js:8649
expandGroup @ kendo.all.js:69735
(anonymous) @ ecritures_financements.js:133
each @ jquery-1.12.4.min.js:2
each @ jquery-1.12.4.min.js:2
(anonymous) @ ecritures_financements.js:128
each @ jquery-1.12.4.min.js:2
each @ jquery-1.12.4.min.js:2
onDataBound @ ecritures_financements.js:115
trigger @ kendo.all.js:164
refresh @ kendo.all.js:70258
d @ jquery-1.12.4.min.js:2
trigger @ kendo.all.js:164
_process @ kendo.all.js:7941
success @ kendo.all.js:7637
success @ kendo.all.js:7528
n.success @ kendo.all.js:6404
i @ jquery-1.12.4.min.js:2
fireWith @ jquery-1.12.4.min.js:2
y @ jquery-1.12.4.min.js:4
c @ jquery-1.12.4.min.js:4
XMLHttpRequest.send (async)
send @ jquery-1.12.4.min.js:4
ajax @ jquery-1.12.4.min.js:4
read @ kendo.all.js:6404
read @ kendo.aspnetmvc.js:257
(anonymous) @ kendo.all.js:7524
_queueRequest @ kendo.all.js:7790
read @ kendo.all.js:7517
query @ kendo.all.js:8034
_query @ kendo.all.js:8397
group @ kendo.all.js:8484
_change @ kendo.all.js:28088
drop @ kendo.all.js:27891
trigger @ kendo.all.js:164
_trigger @ kendo.all.js:26866
_drop @ kendo.all.js:26882
(anonymous) @ kendo.all.js:27138
_withDropTarget @ kendo.all.js:27191
_end @ kendo.all.js:27136
d @ jquery-1.12.4.min.js:2
trigger @ kendo.all.js:164
notify @ kendo.all.js:26312
_trigger @ kendo.all.js:26185
end @ kendo.all.js:26142
_eachTouch @ kendo.all.js:26422
_end @ kendo.all.js:26382
arguments.length.arguments.<computed>.indexOf.t.<computed>.t.<computed>.options.t.<computed> @ kendo.all.js:2875
dispatch @ jquery-1.12.4.min.js:3
r.handle @ jquery-1.12.4.min.js:3
Show 170 more frames

Hi Geetha,
I have tested out the described scenario with a column that is of type DateTime and it appears that the grouping works as expected. Is it possible for you to modify the sample attached to one of my previous responses and replicate the issue there? In order to attach the project, delete the "obj", "bin" and "packages" folders of the project.
As per the error that is observed with expanding the rows, it is expected due to the fact that each expansion triggers the DataBound event. In turn, the logic of the DataBound expands the next and the unexpected behavior is observed.
It is important to point out that the group paging's main idea is to load the records on demand. If you would like to not load them on demand, switch to the normal grouping functionality.
Kind regards,
      
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive, special prizes, and more, for FREE?! Register now for DevReach 2.0(20).

Hi Pierrick,
I have investigated the sample and there are so many requests sent due to the fact that the dates from the client are sent with the current time zone applied whereas the values on the server-side have no time zone applied. In this case, you should unify the hours section, or keep the dates always in UTC format:
As per expanding all groups of the grid, you could try the following approach:
<script type="text/javascript">
    function onDataBound(e) {
        var groupsToExpand = e.sender.tbody.find(".k-grouping-row");
            $(groupsToExpand).each(function (ev) {
                var row = this;
                setTimeout(function () {
                    e.sender.expandGroup($(row));
                })
            });
    }
</script>
Regards,
 
Tsvetomir
 Progress Telerik
    
Five days of Blazor, Angular, React, and Xamarin experts live-coding on twitch.tv/CodeItLive, special prizes, and more, for FREE?! Register now for DevReach 2.0(20).

Hello Tsvetomir, thank you for your help. I updated my application with the new version of the Telerik dll , which was released on 21st.
Can you tell me if the grouping of datatable or list of dynamic ?
Regards,
NAIDU Geetha

