From fb1fb60eab9b326f6e36bc1356b7da92723b3bdd Mon Sep 17 00:00:00 2001 From: Mert Sincan Date: Mon, 18 Dec 2023 14:16:35 +0000 Subject: [PATCH] Fixed #4977 - Improve performance of row expansion feature on DataTable (#4978) * DataTable performance improvement (1) * Refactor on DT performance * Refactor * Refactor * Update RowExpansionDoc.vue * Update RowExpansionDoc.vue * Update RowExpansionDoc.vue --- components/lib/datatable/BaseDataTable.vue | 2 +- components/lib/datatable/BodyRow.vue | 575 ++++++++++++++++++ components/lib/datatable/DataTable.vue | 52 +- components/lib/datatable/TableBody.vue | 488 +++------------ .../lib/datatable/style/DataTableStyle.js | 6 +- components/lib/utils/ObjectUtils.js | 12 +- doc/datatable/RowExpansionDoc.vue | 6 +- 7 files changed, 674 insertions(+), 467 deletions(-) create mode 100644 components/lib/datatable/BodyRow.vue diff --git a/components/lib/datatable/BaseDataTable.vue b/components/lib/datatable/BaseDataTable.vue index d307f759b6..ebdee75339 100644 --- a/components/lib/datatable/BaseDataTable.vue +++ b/components/lib/datatable/BaseDataTable.vue @@ -167,7 +167,7 @@ export default { default: false }, expandedRows: { - type: Array, + type: [Array, Object], default: null }, expandedRowIcon: { diff --git a/components/lib/datatable/BodyRow.vue b/components/lib/datatable/BodyRow.vue new file mode 100644 index 0000000000..227413575a --- /dev/null +++ b/components/lib/datatable/BodyRow.vue @@ -0,0 +1,575 @@ + + + diff --git a/components/lib/datatable/DataTable.vue b/components/lib/datatable/DataTable.vue index 96d4f4ef06..e7fd509232 100755 --- a/components/lib/datatable/DataTable.vue +++ b/components/lib/datatable/DataTable.vue @@ -124,7 +124,6 @@ :expandedRowIcon="expandedRowIcon" :collapsedRowIcon="collapsedRowIcon" :expandedRows="expandedRows" - :expandedRowKeys="d_expandedRowKeys" :expandedRowGroups="expandedRowGroups" :editingRows="editingRows" :editingRowKeys="d_editingRowKeys" @@ -181,7 +180,6 @@ :expandedRowIcon="expandedRowIcon" :collapsedRowIcon="collapsedRowIcon" :expandedRows="expandedRows" - :expandedRowKeys="d_expandedRowKeys" :expandedRowGroups="expandedRowGroups" :editingRows="editingRows" :editingRowKeys="d_editingRowKeys" @@ -345,7 +343,6 @@ export default { d_multiSortMeta: this.multiSortMeta ? [...this.multiSortMeta] : [], d_groupRowsSortMeta: null, d_selectionKeys: null, - d_expandedRowKeys: null, d_columnOrder: null, d_editingRowKeys: null, d_editingMeta: {}, @@ -396,11 +393,6 @@ export default { } } }, - expandedRows(newValue) { - if (this.dataKey) { - this.updateExpandedRowKeys(newValue); - } - }, editingRows: { immediate: true, handler(newValue) { @@ -1087,17 +1079,6 @@ export default { this.d_selectionKeys[String(ObjectUtils.resolveFieldData(selection, this.dataKey))] = 1; } }, - updateExpandedRowKeys(expandedRows) { - if (expandedRows && expandedRows.length) { - this.d_expandedRowKeys = {}; - - for (let data of expandedRows) { - this.d_expandedRowKeys[String(ObjectUtils.resolveFieldData(data, this.dataKey))] = 1; - } - } else { - this.d_expandedRowKeys = null; - } - }, updateEditingRowKeys(editingRows) { if (editingRows && editingRows.length) { this.d_editingRowKeys = {}; @@ -1557,31 +1538,22 @@ export default { event.preventDefault(); }, toggleRow(event) { - let rowData = event.data; - let expanded; - let expandedRowIndex; - let _expandedRows = this.expandedRows ? [...this.expandedRows] : []; + const { expanded, ...rest } = event; + const rowData = event.data; + let expandedRows; if (this.dataKey) { - expanded = this.d_expandedRowKeys ? this.d_expandedRowKeys[ObjectUtils.resolveFieldData(rowData, this.dataKey)] !== undefined : false; - } else { - expandedRowIndex = this.findIndex(rowData, this.expandedRows); - expanded = expandedRowIndex > -1; - } + const value = ObjectUtils.resolveFieldData(rowData, this.dataKey); - if (expanded) { - if (expandedRowIndex == null) { - expandedRowIndex = this.findIndex(rowData, this.expandedRows); - } - - _expandedRows.splice(expandedRowIndex, 1); - this.$emit('update:expandedRows', _expandedRows); - this.$emit('row-collapse', event); + expandedRows = this.expandedRows ? { ...this.expandedRows } : {}; + expanded ? (expandedRows[value] = true) : delete expandedRows[value]; } else { - _expandedRows.push(rowData); - this.$emit('update:expandedRows', _expandedRows); - this.$emit('row-expand', event); + expandedRows = this.expandedRows ? [...this.expandedRows] : []; + expanded ? expandedRows.push(rowData) : (expandedRows = expandedRows.filter((d) => !this.equals(rowData, d))); } + + this.$emit('update:expandedRows', expandedRows); + expanded ? this.$emit('row-expand', rest) : this.$emit('row-collapse', rest); }, toggleRowGroup(e) { const event = e.originalEvent; @@ -1655,7 +1627,6 @@ export default { if (this.expandedRows) { state.expandedRows = this.expandedRows; - state.expandedRowKeys = this.d_expandedRowKeys; } if (this.expandedRowGroups) { @@ -1717,7 +1688,6 @@ export default { } if (restoredState.expandedRows) { - this.d_expandedRowKeys = restoredState.expandedRowKeys; this.$emit('update:expandedRows', restoredState.expandedRows); } diff --git a/components/lib/datatable/TableBody.vue b/components/lib/datatable/TableBody.vue index 72383249b0..743290cd30 100755 --- a/components/lib/datatable/TableBody.vue +++ b/components/lib/datatable/TableBody.vue @@ -1,128 +1,78 @@