Have kind of simple situation can't find solution for.
Kendo-UI only implements grid pagination on the bottom. I tried to make it show pager on top, but it becomes unclickable.
I think my clone section is wrong, but don't know how to fix it. Thanks in advance guys.
here is script and part of jsp...
<kendo:grid name="grid" pageable="true" dataBound="onBound">
<kendo:dataSource serverPaging="true" serverSorting="true">
<kendo:dataSource-transport>
<kendo:dataSource-transport-read url="api/items" />
</kendo:dataSource-transport>
<kendo:dataSource-schema data="data" total="total" />
</kendo:dataSource>
<kendo:grid-columns>
<kendo:grid-column title="id" field="itemId"></kendo:grid-column>
</kendo:grid-columns>
</kendo:grid>
<script type="text/javascript">
function onBound() {
var grid = $("#grid");
grid.find(".k-grid-pager")
.clone()
.insertBefore(grid.find(".k-grid-header"))
.addClass("pagerTop").css("border-width", "0 0 1px 0");
}
</script>
Try this, I hope it helps.
function BindTopPager(e) {
var gridView = $('#grid').data('kendoGrid'),
pager = $('#div .k-pager-wrap'),
id = pager.attr('id') + '_top',
$grid = $('#grid'),
topPager;
if (gridView.topPager === null) {
// create top pager div
topPager = $('<div/>', {
'id': id,
'class': 'k-pager-wrap pagerTop'
}).insertBefore($grid.find('.k-grid-header'));
// copy options for bottom pager to top pager
gridView.topPager = new kendo.ui.Pager(topPager, $.extend({}, gridView.options.pageable, { dataSource: gridView.dataSource }));
// cloning the pageable options will use the id from the bottom pager
gridView.options.pagerId = id;
// DataSource change event is not fired, so call this manually
gridView.topPager.refresh();
}
}
var grid = $("#grid").data("kendoGrid");
grid.bind("dataBound", BindTopPager);
grid.dataSource.fetch();
DEMO
I used the above code and made some adjustments to make it work. I made it into a JS method.
function moveNavigationToTopOnGrid(gridSelector) {
var grid = $(gridSelector).data("kendoGrid"),
pager = $(gridSelector + ' .k-pager-wrap'),
id = pager.prop('id') + '_top',
$grid = $(gridSelector);
if (!grid.topPager) {
// create top pager div
topPager = $('<div/>', {
'id': id,
'class': 'k-pager-wrap pagerTop'
}).insertBefore($grid);
// copy options for bottom pager to top pager
grid.topPager = new kendo.ui.Pager(topPager, $.extend({}, grid.options.pageable, { dataSource: grid.dataSource }));
// cloning the pageable options will use the id from the bottom pager
grid.options.pagerId = id;
// DataSource change event is not fired, so call this manually
grid.topPager.refresh();
}
}