Hello,
Could you update your librairies to ASP.NET Core 3.0 GA (instead of 3.0 RC1) because there are some version conflicts when I want to install some nuget packages. For example, If I install the packages Telerik.UI.for.AspNet.Core 2019.3.917 and Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation 3.0.0 in my project, I've get the error :
Error NU1107 - Version conflict detected for Microsoft.CodeAnalysis.Common.
MyProject -> Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation 3.0.0 -> Microsoft.CodeAnalysis.Razor 3.0.0 -> Microsoft.CodeAnalysis.Common (>= 3.3.0)
MyProject -> Telerik.UI.for.AspNet.Core 2019.3.917 -> Microsoft.CodeAnalysis 3.0.0 -> Microsoft.CodeAnalysis.CSharp.Workspaces 3.0.0 -> Microsoft.CodeAnalysis.Common (= 3.0.0)
I have a aspnet core grid that currently has the following code set to select the current row:
.Events( events => events.Change("onRowSelect"))
The function works fine and is written as:
function onRowSelect(e) {
var row = this.dataItem(this.select());
.... do work here
)
The users have added a new requirement that the event must be a doubleclick event and I'm not sure how to proceed. Any help would be appreciated.
Thanks
I have this form:
<div align=
"center"
>
<div>
<button type=
"button"
class
=
"searchButton"
id=
"search"
>Search</button>
</div>
<div
class
=
"col-md-12 row"
>
@(Html.Kendo()
.Grid<ProjectName.DataModels.Models.Customer>()
.Name(
"CustomerGrid"
)
.Columns(columns =>
{
columns.Bound(e => e.CustomerId);
columns.Bound(e => e.SomeCustomerColumn);
})
.Sortable()
.Pageable()
.Scrollable()
.Filterable()
.ClientDetailTemplateId(
"OrderDetails"
)
.HtmlAttributes(
new
{ style =
"height:430px;"
})
.AutoBind(
false
)
// Don't load the data yet because I'll need to supply parameters for the fetch
.DataSource(dataSource => dataSource
.Ajax()
.PageSize(20)
.Read(read => read.Action(
"GetCustomersAsync"
,
"Customer"
))
)
.Events(events => events.DataBound(
"dataBound"
))
)
<script id=
"OrderDetails"
type=
"text/kendo-tmpl"
>
@(Html.Kendo()
.Grid<ProjectName.DataModels.Models.Order>()
.Name(
"OrderDetails_<#= CustomerId #>"
)
.Columns(columns =>
{
columns.Bound(o => o.ProductName);
columns.Bound(o => o.SomeOrderColumn);
})
.DataSource(dataSource => dataSource
.Ajax()
.PageSize(10)
)
.AutoBind(
false
)
.Pageable()
.Sortable()
.ToClientTemplate()
)
</script>
</div>
</div>
<script type=
"text/javascript"
>
function dataBound() {
this
.expandRow(
this
.tbody.find(
"tr.k-master-row"
).first());
}
$(
"#searchButton"
).on(
"click"
, function () {
var startDate = $(
"#startdate"
).data(
"kendoDatePicker"
).value();
var endDate = $(
"#enddate"
).data(
"kendoDatePicker"
).value();
// How to load the customerGrid here by sending over the startDate and endDate? They are set from Kendo Date Pickers.
// How to load the child grid: OrderDetails_123 by using the datasource used by the parent grid?
});
</script>
And a method in the 'Customer' controller:
public
async Task<ActionResult> GetCustomersAsync([DataSourceRequest] DataSourceRequest request, DateTime start, DateTime end)
{
var consolidatedData = GetDataForParentAndChildGrid(start, end);
return
Json(
new
[] { consolidatedData }.ToDataSourceResult(request));
}
private
ConsolidatedDataModel GetDataForParentAndChildGrid(DateTime start, DateTime end)
{
var testData =
new
List<CustomerData>();
// Gets required data with those dates filter and does a lot of mathematical calculations on them
testData.Add(
new
CustomerData
{
CustomerId =
"123"
,
SomeCustomerColumn =
"Blah blah"
,
Orders =
new
List<OrderData>()
{
new
OrderData{
OrderId =
"123ABC"
,
CustomerId =
"123"
,
SomeOrderColumn =
"Blah Blah Blah"
}
}
});
var consolidatedData =
new
ConsolidatedDataModel()
{
Data = testData
};
return
consolidatedData;
}
After I click the "Search" button (which will take into account the start and end date fields to fetch the data), I'd like to update the 'dataSource' for the parent grid and the child grid. As you can see, the data I need for the parent grid already has data that I need for the child grid so I cannot do a new action call to populate the child grid. How do I accomplish this?
Please help.
Thank You!
Hi,
I am able to bind the form to a view model, but I want to add some extra text or image between fields, is it possible?
Thanks,
Wesley
On this page:
https://www.telerik.com/aspnet-core-ui/listbox
There is a See Demo button that references this link:
http://demos.telerik.com/kendo-ui/listbox/index
This link is incorrect as it brings me to the "Kendo UI for JQuery". Instead, I expect it to bring me to the aspnet core demos
https://demos.telerik.com/aspnet-core/listbox/templates
This is quite confusing.
Hi
I am having trouble understanding what some of these options do and having trouble to find documentation about it
@Html.Kendo().Grid<Model>().Name().Columns().DataSource(source => source.Ajax().PageSize(20).Model(m => model.Id(p =>p.Id)).ServerOperation(
false
).Read(read => read.Action(
""
,
""
).Data(
"getId"
)
I don't understand what Model does in Datasource, ServerOperation(false), and .Data("getId").
I also have a endpoint
public
ActionResult GetData([DataSourceRequest] DataSourceRequest,
int
id){
// some stuff }
I understand this is hit by the Action Method in read but I don't understand why most of the DataSourceRquest in empty (for instance page size is 0, when I would think it would be 20).
I am able to get data from the source.Read method as pictured. However, the control doesn't display back the data.
Once I get that working, I need to post changes to the item order. If I have:
Then I move c up one:
How do I capture the position of c and the position of b to update the database using the Order property? I assume I capture the onReorder event.
public partial class Option
{
public int Id { get; set; }
[MaxLength(50)]
public string Name { get; set; }
[MaxLength(128)]
public string Description { get; set; }
public int Order { get; set; }
...
@(Html.Kendo().ListBox()
.DataTextField("Name")
.DataValueField("Id")
.DataSource(source =>
{
source.Read(read =>
{
read.Action("IndexJson", "SessionOptionTemplates").Data("gridGetData");
});
})
.Toolbar(toolbar =>
{
toolbar.Position(ListBoxToolbarPosition.Right);
toolbar.Tools(tools => tools
.MoveUp()
.MoveDown()
.Remove());
})
.Events(events => events
.Remove("onRemove")
.Reorder("onReorder")
))
Thanks in advance for your help, Joel