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!