From 19379998a3c71e68ddcf1477a378e6f87505e45a Mon Sep 17 00:00:00 2001 From: Cagatay Civici Date: Wed, 20 Jan 2021 12:37:50 +0300 Subject: [PATCH] Fixed #850 - state-save and state-restore events for Table --- src/components/datatable/DataTable.vue | 6 ++++- src/views/datatable/DataTableDoc.vue | 36 ++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 1 deletion(-) diff --git a/src/components/datatable/DataTable.vue b/src/components/datatable/DataTable.vue index b66e7ad40..663e80d59 100755 --- a/src/components/datatable/DataTable.vue +++ b/src/components/datatable/DataTable.vue @@ -143,7 +143,7 @@ export default { emits: ['update:first', 'update:rows', 'page', 'update:sortField', 'update:sortOrder', 'update:multiSortMeta', 'sort', 'filter', 'row-click', 'update:selection', 'row-select', 'row-unselect', 'update:contextMenuSelection', 'row-contextmenu', 'row-unselect-all', 'row-select-all', 'column-resize-end', 'column-reorder', 'row-reorder', 'update:expandedRows', 'row-collapse', 'row-expand', - 'update:expandedRowGroups', 'rowgroup-collapse', 'rowgroup-expand', 'update:filters', 'virtual-scroll', + 'update:expandedRowGroups', 'rowgroup-collapse', 'rowgroup-expand', 'update:filters', 'virtual-scroll', 'state-restore', 'state-save', 'cell-edit-init', 'cell-edit-complete', 'cell-edit-cancel', 'update:editingRows', 'row-edit-init', 'row-edit-save', 'row-edit-cancel'], props: { value: { @@ -1488,6 +1488,8 @@ export default { if (Object.keys(state).length) { storage.setItem(this.stateKey, JSON.stringify(state)); } + + this.$emit('state-save', state); }, restoreState() { const storage = this.getStorage(); @@ -1536,6 +1538,8 @@ export default { this.d_selectionKeys = restoredState.d_selectionKeys; this.$emit('update:selection', restoredState.selection); } + + this.$emit('state-restore', restoredState); } }, saveColumnWidths(state) { diff --git a/src/views/datatable/DataTableDoc.vue b/src/views/datatable/DataTableDoc.vue index fd252c3d7..87d0a7b73 100755 --- a/src/views/datatable/DataTableDoc.vue +++ b/src/views/datatable/DataTableDoc.vue @@ -2345,6 +2345,42 @@ export default { event.rows: Rows per page. Callback to invoke during virtual scrolling. + + state-save + event.first: Index of first record
+ event.rows: Number of rows to display in new page
+ event.sortField: Field to sort against
+ event.sortOrder: Sort order as integer
+ event.multiSortMeta: MultiSort metadata
+ event.filters: Collection of active filters
+ event.columWidths: Comma separated list of column widths
+ event.columnOrder: Order of the columns
+ event.expandedRows: Instances of rows in expanded state
+ event.expandedRowKeys: Keys of rows in expanded state
+ event.expandedRowGroups: Instances of row groups in expanded state
+ event.selection: Selected rows
+ event.selectionKeys: Keys of selected rows
+ + Invoked when a stateful table saves the state. + + + state-restore + event.first: Index of first record
+ event.rows: Number of rows to display in new page
+ event.sortField: Field to sort against
+ event.sortOrder: Sort order as integer
+ event.multiSortMeta: MultiSort metadata
+ event.filters: Collection of active filters
+ event.columWidths: Comma separated list of column widths
+ event.columnOrder: Order of the columns
+ event.expandedRows: Instances of rows in expanded state
+ event.expandedRowKeys: Keys of rows in expanded state
+ event.expandedRowGroups: Instances of row groups in expanded state
+ event.selection: Selected rows
+ event.selectionKeys: Keys of selected rows
+ + Invoked when a stateful table restores the state. +