From cf438de26028301237e33af5fc90ece1c3bcbc91 Mon Sep 17 00:00:00 2001 From: cagataycivici Date: Thu, 30 Jan 2020 12:06:16 +0300 Subject: [PATCH] Fixed #163 - DataTable onPage event fires without sort and filter information --- src/components/datatable/DataTable.vue | 34 ++++++++++++++-------- src/views/datatable/DataTableDoc.vue | 39 +++++++++++++++++++------- 2 files changed, 51 insertions(+), 22 deletions(-) diff --git a/src/components/datatable/DataTable.vue b/src/components/datatable/DataTable.vue index 549e70a74..506c87d40 100644 --- a/src/components/datatable/DataTable.vue +++ b/src/components/datatable/DataTable.vue @@ -451,9 +451,13 @@ export default { this.d_first = event.first; this.d_rows = event.rows; + let pageEvent = this.createLazyLoadEvent(event); + pageEvent.pageCount = event.pageCount; + pageEvent.page = event.page; + this.$emit('update:first', this.d_first); this.$emit('update:rows', this.d_rows); - this.$emit('page', event); + this.$emit('page', pageEvent); }, onColumnHeaderClick(e) { const event = e.originalEvent; @@ -483,12 +487,7 @@ export default { this.$emit('update:sortOrder', this.d_sortOrder); this.$emit('update:multiSortMeta', this.d_multiSortMeta); - this.$emit('sort', { - originalEvent: event, - sortField: this.d_sortField, - sortOrder: this.d_sortOrder, - multiSortMeta: this.d_multiSortMeta - }); + this.$emit('sort', this.createLazyLoadEvent(event)); this.resetPage(); } @@ -608,10 +607,9 @@ export default { filteredValue = data; } - this.$emit('filter', { - filters: this.filters, - filteredValue: filteredValue - }); + let filterEvent = this.createLazyLoadEvent(event); + filterEvent.filterValue = filteredValue; + this.$emit('filter', filterEvent); return filteredValue; }, @@ -1598,7 +1596,19 @@ export default { rows: this.rows * 2 }); }, this.virtualScrollDelay); - } + }, + createLazyLoadEvent(event) { + return { + originalEvent: event, + first: this.d_first, + rows: this.d_rows, + sortField: this.d_sortField, + sortOrder: this.d_sortOrder, + filters: this.filters, + globalFilter: this.filters && this.filters['global'] ? this.filters['global'].value : null, + multiSortMeta: this.d_multiSortMeta + }; + } }, computed: { containerClass() { diff --git a/src/views/datatable/DataTableDoc.vue b/src/views/datatable/DataTableDoc.vue index 4b8a07631..9d9d61a55 100644 --- a/src/views/datatable/DataTableDoc.vue +++ b/src/views/datatable/DataTableDoc.vue @@ -1973,23 +1973,42 @@ export default { event.page: New page number
event.first: Index of first record
event.rows: Number of rows to display in new page
- event.pageCount: Total number of pages + event.pageCount: Total number of pages
+ event.sortField: Field to sort against
+ event.sortOrder: Sort order as integer
+ event.multiSortMeta: MultiSort metadata
+ event.filters: Collection of active filters
+ event.filteredValue: Filtered collection - Callback to invoke on pagination. + Callback to invoke on pagination. Sort and Filter information is also available for lazy loading implementation. sort - event.originalEvent: Browser event.
- event.sortField: Field to sort against.
- event.sortOrder: Sort order as integer.
- event.multiSortMeta: MultiSort metadata. - Callback to invoke on sort. + event.page: New page number
+ event.first: Index of first record
+ event.rows: Number of rows to display in new page
+ event.pageCount: Total number of pages
+ event.sortField: Field to sort against
+ event.sortOrder: Sort order as integer
+ event.multiSortMeta: MultiSort metadata
+ event.filters: Collection of active filters
+ event.filteredValue: Filtered collection + + Callback to invoke on sort. Page and Filter information is also available for lazy loading implementation. filter - event.filters: Collection of active filters.
- event.filteredValue: Filtered collection. - Callback to invoke on filtering. + event.page: New page number
+ event.first: Index of first record
+ event.rows: Number of rows to display in new page
+ event.pageCount: Total number of pages
+ event.sortField: Field to sort against
+ event.sortOrder: Sort order as integer
+ event.multiSortMeta: MultiSort metadata
+ event.filters: Collection of active filters
+ event.filteredValue: Filtered collection + + Callback to invoke on filtering. Page and Sort information is also available for lazy loading implementation. row-click