Grid inside ClientDetailTemplate

1 Answer 202 Views
Grid
Gerardo
Top achievements
Rank 1
Iron
Veteran
Iron
Gerardo asked on 05 Jul 2022, 11:03 PM

hello, 
what is the general pattern to include a grid inside another Grid's DetailTemplate? I have a heriarchical collections I need to populate. I don't see other way than declaring a script inside the template's script tag, but that is invalid html.

1 Answer, 1 is accepted

Sort by
0
Momchil
Telerik team
answered on 08 Jul 2022, 08:15 AM

Hello, Gerardo

The general pattern to create a Kendo Grid hierarchy in ASP.NET Core is the following:

1. Create the parent Grid with HtmlHelpers and configure it based on your needs.

2. Add a Kendo Template.

3. Configure the child Grid inside the Kendo Template by using HtmlHelpers. It is important to ensure that the Name() of every child Grid is unique. A good option is to append the unique Model id of parent Grid to the name of the child Grid. For example:

.Name("child_grid_#=ModelId#")

4. Since the child Grid is initialized in a template, it is required to add the ".ToClientTemplate()" option.

5. Specify the name of the template created in Step 2 in the configuration of the parent Grid through the ".ClientDetailTemplateId()" method.

@(Html.Kendo().Grid<ParentGridModel>()
        .Name("grid")
        .ClientDetailTemplateId("template")
        .DataSource(dataSource => dataSource
                ...
                .Model(model => model.Id(p => p.ProductID))
        )
        ...
)

<script id="template" type="text/kendo-tmpl">
        @(Html.Kendo().Grid<ChildGridModel>()
            .Name("grid_#=ProductID#")
            .DataSource(dataSource => dataSource
                .Ajax()
                ...
                .Read(read => read.Action("ReadChildGridData", "ControllerName", new { productID = "#=ProductID#" }))
            )
            ...
            .ToClientTemplate()
        )
</script>

Here is a short demo for your reference: 

https://netcorerepl.telerik.com/cmarYMOB32pCEGCc21

I hope this information helps. Please let me know if I can assist you any further. 

 

Best regards, Momchil Zanev 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/.

Gerardo
Top achievements
Rank 1
Iron
Veteran
Iron
commented on 08 Jul 2022, 01:23 PM | edited

thanks Momchil, 

Is there a way to bind the DetailTemplate to data already avaiable? I mean, to not use

.Read(read => read.Action("ReadChildGridData", "ControllerName", new { productID = "#=ProductID#" }))

and reference it without using an extra request to load the detail. The data is already available in the first "pass". Something like

.Read(read => read.Memory("#=Parent.children#")

 

An alternative quesion is how to declare a template that includes javascript like this:

<script id="template" type="text/kendo-tmpl">
<script type="text/javascript">
</script>
</script>

 

Momchil
Telerik team
commented on 12 Jul 2022, 03:22 PM

Hi Gerardo,

In regards to your first question about loading the data locally in the child grid, I would suggest the following:

1. Configure the parent grid with a DetailTemplate() option. 

@(Html.Kendo().Grid<ParentGridModel>()
	.Name("grid")
	.DataSource(ds => ds
		.Ajax()
                ...
		.Read("GetPeople", "Home")
	)
	...
	.ClientDetailTemplateId("template")
)

2. Disable the server operations of the child grid (ServerOperation(false)).

<script id="template" type="text/kendo-tmpl">
	@(Html.Kendo().Grid<GridHierarchyDemo.Models.Order>()
		.Name("grid_#=EmployeeID#")
                ...
		.DataSource(dataSource => dataSource
			.Ajax()
			.ServerOperation(false)
		)
		.ToClientTemplate()
	)
</script>

 

3. Set a handler for the "DetailInit" event of the parent grid.

@(Html.Kendo().Grid<ParentGridModel>()
	.Name("grid")
	.DataSource(ds => ds
		.Ajax()
		.Read("GetPeople", "Home")
	)
	.ClientDetailTemplateId("template")
	.Events(e => e.DetailInit("onDetailInit"))
)

4. The "DetailInit" event provides the child grid element of the currently expanded master row. By using the "e.detailCell", get a reference of the current child grid. Then use the setDataSource() method to set the DataSource of the child grid with the appropriate data.

<script>
	function onDetailInit(e) {
		var childGridElement = e.detailCell.find(".k-grid"); //select the child grid element

		var dataSource = new kendo.data.DataSource({ //create a new DataSource component
			data: e.data.Orders 
		});
				
		$(childGridElement).data("kendoGrid").setDataSource(dataSource); //set the DataSource
	}
</script>

I am attaching a runnable demo that demonstrates this solution.

 

Regarding your second question on how to include JavaScript inside a Kendo template:

The template allows you to include HTML, JS code, and HtmlHelpers, so declaring a <script> tag inside it is not a valid syntax. If you would like to add JavaScript inside a Kendo template, check out the following documentation:

Templates Overview | Kendo UI Templates | Kendo UI for jQuery (telerik.com)

I hope this answers your questions. I will be glad to assist you further.

 

Regards,
Momchil
Progress Telerik

Love the Telerik and Kendo UI products and believe more people should try them? Invite a fellow developer to become a Progress customer and each of you can get a $50 Amazon gift voucher.

Tags
Grid
Asked by
Gerardo
Top achievements
Rank 1
Iron
Veteran
Iron
Answers by
Momchil
Telerik team
Share this question
or