Hello,
I am developing a wizard very similar to the one you provide in this demo: https://demos.telerik.com/aspnet-core/wizard/index . I wonder if you could help me to find out how to send the model back to the controller after clicking on done. Do you have to send the data with ajax or can you send the model back to the controller? Sorry if this question is too obvious, I am just starting.
Kind Regards,
Pablo
Hello,
I am developing a ASP.NET core Telerik Wizard prototype, each step is a form. The issue is that I have a submit button for the form and next button for the wizard so the user has to click on submit and then on next to continue. I would like to submit the form when the user clicks on the next button. Is it possible? If I cannot submit the form with the next button I will have to bin the prototype.
Kind Regards.
Good morning,
I'm new to Telerik and doing a POC evaluation using the Aspnet Core Grid control to see if it will work for our situation. I've worked through most issues along the way, but I'm unable to get aggregates to work on the grid so far and I'm hoping it's something simple I'm missing and not a limitation of aggregates within a nested grid hierarchy.
Here is the scenario:
I am trying to do a simple count of items in the nested grid and place them using the .ClientGroupHeaderColumnTemplate. I'm also adding the .Aggregates to the DataSource call. When I do so, I am unable to access the grid and get the following javascript error: "Uncaught ReferenceError: count is not defined"
I believe I have followed all the demos/examples/threads that I've found online correctly, but the difference is that this grid is nested within 2 other grids. I have also tried several of the other ClientTemplates (footer, header, etc...) with the same result. Thanks in advance for any help you can give and let me know if you need additional information.
Here is the code I'm calling for this grid:
<script id="agents" type="text/kendo-tmpl">
@(Html.Kendo().Grid<TLCAgentSchedulerT.Models.AgentViewModel>
()
.Name("agent_#=SubPodId#")
.Columns(columns =>
{
columns.Bound(o => o.AgentName).Width(50);
columns.Bound(o => o.Block1).Width(4)
.ClientGroupHeaderColumnTemplate("Sum: #= count#")
.ClientTemplate(@"<div class='agentStatus' style='background-image: url(" + @Url.Content("~/images/\\#:data.Block1\\#.png") + ");'></div>").ClientHeaderTemplate("<span data-toggle='tooltip' data-placement='top' title='6:00 AM EST'>B1</span>");
columns.Bound(o => o.Block2).Width(4).ClientTemplate(@"<div class='agentStatus' style='background-image: url(" + @Url.Content("~/images/\\#:data.Block2\\#.png") + ");'></div>").ClientHeaderTemplate("<span data-toggle='tooltip' data-placement='top' title='6:00 AM EST'>B2</span>");
columns.Bound(o => o.Block3).Width(4).ClientTemplate(@"<div class='agentStatus' style='background-image: url(" + @Url.Content("~/images/\\#:data.Block3\\#.png") + ");'></div>").ClientHeaderTemplate("<span data-toggle='tooltip' data-placement='top' title='6:00 AM EST'>B3</span>");
columns.Bound(o => o.Block4).Width(4).ClientTemplate(@"<div class='agentStatus' style='background-image: url(" + @Url.Content("~/images/\\#:data.Block4\\#.png") + ");'></div>").ClientHeaderTemplate("<span data-toggle='tooltip' data-placement='top' title='6:00 AM EST'>B4</span>");
//Add Additional Blocks
columns.Command(command =>
{
command.Edit().Text("Edit Agent");
}).Width(25);
})
.DataSource(dataSource => dataSource
.Ajax()
//.Read(read => read.Action("EditAgent", "Grid"))
.Update(update => update.Action("EditAgent", "Grid"))
.Events(events => events.Error("error_handler"))
.Aggregates(aggregates =>
{
aggregates.Add(p => p.Block1).Count();
})
.Group(groups => groups.Add(p=> p.Block1))
.PageSize(5)
.Read(read => read.Action("GetAgents", "Grid", new { subPodId = "#=SubPodId#" }))
)
//.ToolBar(toolbar => toolbar.Create()) //Adds 'Add New Record' button to toolbar
.Editable(editable => editable.Mode(GridEditMode.PopUp))
.Scrollable()
//.Sortable()
.ToClientTemplate()
)
</script>

Hello,
I use Nuget AspNet.Core (2020.1.406) but "Html.Kendo().TileLayout()" is not found...
Thanks
Nathan
Do you have sample code that would allow me to upload a spreadsheet and read it, looping through each row and column using built-in functions/procedures from Telerik UI for ASP.NET?
I see you have samles in: http://demos.telerik.com/aspnet-core/spreadsheet/index. None of them though show how to upload the file and read the file using Telerik UI for ASP.net. Please advise
Hello,
The generation of the identifier in TagHelpers is different from HtmlHelpers. The dot is not replaced by underscore :
<input asp-for="SubModel.Name" /> generates SubModel_Name@Html.Kendo().AutoCompleteFor(m => m.SubModel.Name) generates SubModel_Name<kendo-autocomplete for="SubModel.Name"></kendo-autocomplete> generates SubModel.Name
Is there an option to replace dot with underscore in TagHelpers ?
Cordially,
Stephane.
Hi everyone,
I have a page with two grids on the page and each grid has grouping. I want to collapse the groups in both grids and also allow the user to click on the labels to expand and collapse the groups. I am using version 2020.2.513
So what is happening is that grid 1 is collapsing as expected, but grid 2 is not collapsing at all. What do I have wrong?
My code is below:
Grid 1
@(Html.Kendo().Grid<VwFormSubmissionMenuListActive>() .Name("ActiveForms") .Groupable() .Columns(columns => { columns.Bound(p => p.FormSubmissionId).Hidden(true); columns.Bound(p => p.FormName).Title("Form Name").Width(200).Hidden(true); columns.Bound(p => p.SubjectName).Title("Subject").Width(200).MinScreenWidth(800); columns.Group(group => group .Title("Form Agreement") .Columns(info => { info.Bound(x => x.AgreementRequired).Title("Required").Width(75); info.Bound(x => x.AgreementStatusDescription).Title("Status").Width(75); }) ); columns.Bound(p => p.AgreementStatusId).Hidden(true); }) .ToolBar(toolbar => { toolbar.Search(); }) .HtmlAttributes(new { style = "height:650px;" }) .Navigatable() .Selectable(selectable => selectable.Mode(GridSelectionMode.Single)) .Sortable() .Groupable(true) .Events(events => events.DataBound("collapseGroupRows_Forms")) .Events(ev => ev.Change("onChange")) .Scrollable() .DataSource(dataSource => dataSource .Ajax() .ServerOperation(false) .GroupPaging(true) .Events(events => events.Error("error_handler")) .Model(model => model.Id(p => p.FormSubmissionId)) .Read("vwFormSubmissionMenuList_Active", "Grid", new { StudentId = -1 }) .Group(x => { x.Add(y => y.FormName); }) ))
Grid 2
@(Html.Kendo().Grid<VwSubjectChange>() .Name("SubjectChange") .Groupable() .Columns(columns => { columns.Bound(p => p.SubjectChangeId).Hidden(true); columns.Bound(p => p.Timetable).Title("Timetable").Width(200).Hidden(true); columns.Bound(p => p.Surname).Title("Surname").Width(100); columns.Bound(p => p.Preferred).Title("Preferred").Width(100).MinScreenWidth(800); columns.Bound(p => p.Yearlevel).Title("Current Year").Width(50); columns.Bound(p => p.Studentnumber).Title("Student Id").Width(50); }) .ToolBar(toolbar => { toolbar.Search(); }) .HtmlAttributes(new { style = "height:650px;" }) .Navigatable() .Selectable(selectable => selectable.Mode(GridSelectionMode.Single)) .Sortable() .Groupable(true) .Events(events => events.DataBound("collapseGroupRows_SubjectChange")) .Scrollable() .DataSource(dataSource => dataSource .Ajax() .ServerOperation(false) .GroupPaging(true) .Events(events => events.Error("error_handler")) .Model(model => model.Id(p => p.SubjectChangeId)) .Read("VwSubjectChange", "Grid", new { username = @User.Identity.Name }) .Group(x => { x.Add(y => y.Timetable); x.Add(y => y.CurrentStatus); }) ))
Javascript code:
function collapseGroupRows_SubjectChange() { var grid = $("#SubjectChange").data("kendoGrid"); $(".k-grouping-row").each(function (e) { var expanded = $(this).find(".k-i-collapse").length > 0; if (expanded) { grid.collapseGroup(this); } else { grid.expandGroup(this); } //grid.collapseGroup(this); }); $(".k-grouping-row").click(function () { var expanded = $(this).find(".k-i-collapse").length > 0; if (expanded) { grid.collapseGroup(this); } else { grid.expandGroup(this); } });}function collapseGroupRows_Forms() { var grid = $("#ActiveForms").data("kendoGrid"); $(".k-grouping-row").each(function (e) { var expanded = $(this).find(".k-i-collapse").length > 0; if (expanded) { grid.collapseGroup(this); } else { grid.expandGroup(this); } }); $(".k-grouping-row").click(function () { var expanded = $(this).find(".k-i-collapse").length > 0; if (expanded) { grid.collapseGroup(this); } else { grid.expandGroup(this); } });}
I want to send the token and additional data on my update call.
Something like the below, is this possible? Do i even need the token for an intranet app? If not, how do I get rid of it?
Javascript
function additionalInfo() { return { token: kendo.antiForgeryTokens(), whatChanged: 2 } }
PageModel
public JsonResult OnPostUpdate([DataSourceRequest] DataSourceRequest request, OCHODisplayReply reply, int whatChanged) { if (reply != null && ModelState.IsValid) { /... }}
Grid method
.Update(u => u.Url("/Index/?handler=Update").Data("additionalInfo")
How do I include and populate a ComboBox inside a Grid template? I have it list my Templates successfully as defined. But, I need a ComboBox that lists the Template's Items. The data is served up from the Model.
Then, on selection of the items in the ComboBox, I need to store the Item index to a local array/list (because we don't know how many templates there are) for consumption on a button press.
Template:
public partial class SessionOptionTemplate{ public int Id { get; set; } [MaxLength(50)] public string Name { get; set; } [MaxLength(128)] public string Description { get; set; } public int Order { get; set; } public DateTime AddTimestamp { get; set; } = DateTime.UtcNow; public DateTime? DeactivateTimestamp { get; set; } public ICollection<SessionOptionItem> SessionOptionItems { get; set; } = new HashSet<SessionOptionItem>();}Items:
public partial class SessionOptionItem{ [Key] public int Id { get; set; } public int SessionOptionTemplateId { get; set; } [MaxLength(50)] public string Name { get; set; } [MaxLength(128)] public string Description { get; set; } public DateTime AddTimestamp { get; set; } = DateTime.UtcNow; public DateTime? DeactivateTimestamp { get; set; }}
Grid:
@(Html.Kendo().Grid((IEnumerable<SessionOptionTemplate>)Model.SessionOptionTemplates) .Name("template-grid") .HtmlAttributes(new { @class = "GridNoHeader" }) .Columns(columns => { columns.Template(" ").Title("Name").Width(200); }) .ClientRowTemplate(@" <div style='margin-bottom: 10px;'> <input class='select' type='checkbox' #=IsSelected ? " + @"checked='checked' " + @" : '' # /> <span class='name'>#: Name #</span><br /> <span class='desc'>#: Description #</span> </div>") .DataSource(dataSource => dataSource .Ajax() .PageSize(20) .ServerOperation(false)) )