Hi,
I am new to using KendoUI and am sorry if this has been answered before but I cannot seem to find an answer that works for me. I have a search button and a grid on the page. I am taking to d.3 in the backend (a DMS system) using library calls. The user enters s/he search query in the field and I call the Read method in my Controller to get the data from d.3. What is happening is that I am getting the data back in the request but the grid is not updating.
Here is my MVC code:
@(Html.Kendo()
.Grid(Model)
.Name("grid")
.DataSource(dataSource => dataSource
.Ajax()
.ServerOperation(false)
.Read(r => r.Action("Read", "Search"))
)
.Filterable(f => f.Mode(GridFilterMode.Row))
.Columns(columns =>
{
{
columns.Bound(c => c.DocumentType)
.Filterable(false)
.Width("150px")
.Title(@Localizer["SearchTableHeaderDocumentType"]);
columns.Bound(c => c.DocumentTypeLong)
.Filterable(true)
.Title(@Localizer["SearchTableHeaderDocumentTitle"])
.Filterable(ftb => ftb.Cell(cell => cell.Operator("contains").SuggestionOperator(FilterType.Contains)));
})
)
I have a button on the page that does the submit using the following code:
var search = $("#search-field").val();
if (!search) return;
if (search.trim() === "") return;
var dataSource = $("#grid").data("kendoGrid").dataSource;
var parameters = {
searchFor: search
}
// call the search passing the parameters -> searchFor is the parameter name on the SearchController/Read method
dataSource.read(parameters);
This calls my Read method in the SearchController.cs. The Search method creates the data that is supposed to be passed back to the Grid:
// setup your result for KendoUI
DataSourceResult result = model.Entries.ToDataSourceResult(request);
// return
return Json(result);
I also see the data structure in the response if I check the event after the RequestEnd:
.Events(events => events.RequestEnd("onRequestEnd"))
or if I check the response in Chrome - this is what I get:
+0Object {DocumentId: "GD00000016", DocumentType: "D3CHG", DocumentTypeLong: "D.3 :: Fehler/Request", …}Object
+1Object {DocumentId: "GD00000148", DocumentType: "DEPSU", DocumentTypeLong: "Abteilung :: Leitung", …}Object
+2Object {DocumentId: "GD00000149", DocumentType: "DEPSU", DocumentTypeLong: "Abteilung :: Leitung", …}Object
+3Object {DocumentId: "GD00000150", DocumentType: "DEPSU", DocumentTypeLong: "Abteilung :: Leitung", …}Object
+4Object {DocumentId: "GD00000266", DocumentType: "IDOCU", DocumentTypeLong: "Infrastruktur :: Handbuch", …}Object
+5Object {DocumentId: "GD00000267", DocumentType: "IDOCU", DocumentTypeLong: "Infrastruktur :: Handbuch", …}Object
+6Object {DocumentId: "GD00000268", DocumentType: "IDOCU", DocumentTypeLong: "Infrastruktur :: Handbuch", …}Object
+7Object {DocumentId: "GD00000269", DocumentType: "CKNOW", DocumentTypeLong: "Global :: Wissen", …}Object
+8Object {DocumentId: "GD00000277", DocumentType: "IDOCU", DocumentTypeLong: "Infrastruktur :: Handbuch", …}Object
very odd.
Maybe this helps: If I return dummy data from the Index method (I am currently returning an empty list => return View(new List<SearchEntryModel>());) before using the Read method from the grid everything magically works (except that the number of entries is limited to the return from the Index method).
Sorry about the weird explanation but I don't know how to better explain it.
Thank you in advance
Martin

c.Bound(g => g.LastUpdated).Format("{0:MM/dd/yyyy hh:mm tt}")
Hi
I have based the following code on Grid / Custom command
https://demos.telerik.com/aspnet-mvc/grid/custom-command
@(Html.Kendo().Grid<MyProject.Models.Profiles>(). Name("MyTable"). Columns(columns => { columns.Command(command => { command.Custom("Edit Details").Click("EditDetails"); }).Width(120); }) .HtmlAttributes(new { style = "height: 600px" }) .BindTo(Model) .Scrollable() .Groupable() .Sortable() .Filterable())<script> function EditDetails(e) { e.preventDefault(); }</script>When I run the code I get the following error in the Developer Console(Edge & Chrome)
Uncaught ReferenceError: EditDetails is not defined
I have been unable to find the problem, any suggestions?
Is there a way that i can call a controller method without going through javascript?
Thanks
Hello,
I have this autocomplete in my view :
@(Html.Kendo().AutoComplete() .Name("description.EmplacementEquipementAutreSpecifier") .DataTextField("EmplacementEquipementAutreSpecifier") .Filter("contains") .MinLength(3) .HtmlAttributes(new { style = "width:100%;", @class = "form-control" }) .DataSource(source => { source .Read(read => { read.Action("GetEmplacementEquipementAutreSpecifier", "Description"); }) .ServerFiltering(false); }) .Value(Model.description.EmplacementEquipementAutreSpecifier) .Events(e => e.Filtering("OnChangeNoEmplacementEquipement").Close("OnChangeNoEmplacementEquipement")))And need to apply a Bootstrap style (class="form-control"). See result in attachment.
When I remove some style I can see the reason of the missing bottom blue border. The input box seem a bit lower compare to the thing that make the blue border.
Any suggestion to correct this issue? Css probably.
Hello,
I have a ui grid with code to hide the destroy button if only one record left in the grid:
...
columns.Command(command => { command.Destroy().Visible("isLastRecordEmail").Text("Remove"); }).Width(200);
...
function isLastRecordEmail(e) {
return $('\#GridEmails').data('kendoGrid').dataSource.data().length > 1;
}
But if I click the Add button then a new records appears and destroy button will appear for last record to allow to delete the very last record.
My question is, how to hide the destroy button in this case?
I did try to add code:
function isLastRecordEmail(e) {
if ($('\#GridEmails').EditIndexes.Count > 0) return false;
but EditIndexes is undefined.
Could you please help?
Thanks!
CostCenterController:
public ActionResult CostCenters_Read([DataSourceRequest] DataSourceRequest request) { return Json(ccService.Read().ToDataSourceResult(request)); } [AcceptVerbs(HttpVerbs.Post)]
public ActionResult CostCenters_Create([DataSourceRequest] DataSourceRequest request, CostCenterViewModel cc) { if (cc != null && ModelState.IsValid) { ccService.Create(cc); } //return Json(cc, JsonRequestBehavior.AllowGet); return Json(new[] { cc }.ToDataSourceResult(request, ModelState)); } [AcceptVerbs(HttpVerbs.Post)]
public ActionResult CostCenters_Update([DataSourceRequest] DataSourceRequest request, CostCenterViewModel cc) { if (cc != null && ModelState.IsValid) { ccService.Update(cc); } return Json(new[] { cc }.ToDataSourceResult(request, ModelState)); }
Index.cshtml:
@(Html.Kendo().Grid<Main.Models.Quality.CostCenterViewModel>()
.Name("CostCenter")
.Columns(columns =>
{columns.Bound(c => c.CostCenterID);
columns.Bound(c => c.CC).Width(140);
columns.Bound(c => c.Rate).Width(140);
columns.Bound(c => c.Date).Width(100);
columns.Command(command => command.Destroy()).Width(110);
})
.ToolBar(toolbar => toolbar.Create())
.Editable(editable => editable.Mode(GridEditMode.PopUp))
.Pageable()
.Sortable()
.Scrollable()
.HtmlAttributes(new { style = "height:550px;" })
.DataSource(dataSource => dataSource
.Ajax()
.PageSize(20)
.Events(events => events.Error("error_handler"))
.Model(model => model.Id(c => c.CostCenterID)) .Create(update => update.Action("CostCenters_Create", "CostCenter")) .Read(read => read.Action("CostCenters_Read", "CostCenter")) .Update(update => update.Action("CostCenters_Update", "CostCenter")) .Destroy(update => update.Action("CostCenters_Destroy", "CostCenter"))
))
<script type="text/javascript">
function error_handler(e) {
if (e.errors) {
var message = "Errors:\n";
$.each(e.errors, function (key, value) {
if ('errors' in value) {
$.each(value.errors, function () {
message += this + "\n";
});
}
});
alert(message); }
}
</script>
I set CostCenterServer, the code is similar as ProductService.
It show up as normal, but when I Click "New Record", It popped up error with "This request has been blocked because sensitive information could be disclosed to third party web sites when this is used in a GET request. To allow GET requests, set JsonRequestBehavior to AllowGet."
In Controller, i tried to replace return Json(cc, JsonRequestBehavior.AllowGet); with return Json(new[] { cc }.ToDataSourceResult(request, ModelState)); but no lucky??

Hello,
What is the best practice to use Kendo UI grid with "long run" server side data source? I have a web page with two tabs. The grid in on second page. The data downloaded on login process and average time is about 20-30 seconds, that's not good. If I create remote data source then opening the second tab is taking 20 seconds to display the grid content.If I choose the first tab and then return the second tab then the grid takes 20 seconds again.
The amount of records in the data source is 0-5. The problem is that SQL code has to check too many things (and controller accessing another web site) and cannot be optimized.
Should I go with web workers? In this case the data could be downloaded when the first tab is displaying. Or might be exist another solution? Or something already in grid functionality that I have missed? What is the best practice for such case?
Thanks!