I have added a search toolbar to my JQuery Kendo grid. I want to use it to search dates as they appear in my grid.
The dates are c# DateTime values fetched from a Controller. I use a template to display the date in the format that I need.
The Search toolbar appears to be searching in the date format before I apply the template formatting.
Eg my date displays as 10/07/2020
but if I search for that string nothing appears.
If I search for: Fri Jul 10 2020 00:00:00 GMT+0800 (W. Australia Standard Time)
, it will return the 10/07/2020
row.
//my grid datasource
var robotDataSource = new kendo.data.DataSource({
transport: {
read: {
url: "@Url.Action("RobotList", "Robot")",
dataType: "json",
type: "POST"
}
},
schema: {
model: {
fields: {
ID: { type: 'number' },
RobotName: { type: 'string' },
CreatedDate: { type: 'date' }
}
},
},
pageSize: 10,
sort: {
field: "ID",
dir: "desc"
}
});
robotDataSource.fetch(function() {
});
//my grid
$("#robotGrid").kendoGrid({
dataSource: robotDataSource,
height: 700,
toolbar: ["search"],
pageable: {
pageSizes: [10, 25, 50, 100]
},
sortable: true,
filterable: true,
columns: [
{
field: "ID",
title: "ID",
filterable: { search: true }
}, {
field: "RobotName",
title: "Name",
width: 160,
}, {
field: "CreatedDate",
title: "Date Created",
width: 160,
template: "#= (CreatedDate == null)? '' : kendo.toString(kendo.parseDate(CreatedDate, 'yyyy-MM-dd'), 'dd/MM/yyyy') #"
filterable: { multi: true, search: true }
}
]
});
Add a string formatted version of Created Date to your datasource and add a parse function like so:
schema: {
model: {
fields: {
ID: { type: 'number' },
RobotName: { type: 'string' },
CreatedDate: { type: 'date' },
CreatedDateFormatted: { type: 'string' }
}
},
parse: function (response) {
for (var i = 0; i < response.length; i++) {
response[i].CreatedDateFormatted = kendo.format("{0:dd/MM/yyyy}", response[i].CreatedDate);
}
return response;
}
},
Then update your grid configuration to indicate which columns to include in the search:
search: {
fields: ["Id", "CreatedDateFormatted"]
},
More information is available here: https://docs.telerik.com/kendo-ui/knowledge-base/grid-filter-columns-by-date-via-search-panel