From 5748ae7ec0ce4e365e855a9261a9ffa4fcef0f57 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tu=C4=9F=C3=A7e=20K=C3=BC=C3=A7=C3=BCko=C4=9Flu?= Date: Mon, 17 Jan 2022 17:10:27 +0300 Subject: [PATCH] Fixed #2001 - Improve resizable structure on DataTable --- src/components/datatable/DataTable.vue | 51 +++++++++----------------- 1 file changed, 18 insertions(+), 33 deletions(-) diff --git a/src/components/datatable/DataTable.vue b/src/components/datatable/DataTable.vue index 4737929e7..ab153f8e6 100755 --- a/src/components/datatable/DataTable.vue +++ b/src/components/datatable/DataTable.vue @@ -1106,15 +1106,7 @@ export default { let nextColumnWidth = nextColumn.offsetWidth - delta; if (newColumnWidth > 15 && nextColumnWidth > 15) { - if (!this.scrollable) { - this.resizeColumnElement.style.width = newColumnWidth + 'px'; - if(nextColumn) { - nextColumn.style.width = nextColumnWidth + 'px'; - } - } - else { - this.resizeTableCells(newColumnWidth, nextColumnWidth); - } + this.resizeTableCells(newColumnWidth, nextColumnWidth); } } else if (this.columnResizeMode === 'expand') { @@ -1122,10 +1114,7 @@ export default { this.$refs.table.style.width = tableWidth; this.$refs.table.style.minWidth = tableWidth; - if (!this.scrollable) - this.resizeColumnElement.style.width = newColumnWidth + 'px'; - else - this.resizeTableCells(newColumnWidth); + this.resizeTableCells(newColumnWidth); } this.$emit('column-resize-end', { @@ -1154,18 +1143,18 @@ export default { this.createStyleElement(); let innerHTML = ''; - widths.forEach((width,index) => { + widths.forEach((width, index) => { let colWidth = index === colIndex ? newColumnWidth : (nextColumnWidth && index === colIndex + 1) ? nextColumnWidth : width; + let style = this.scrollable ? `flex: 1 1 ${colWidth}px !important` : `width: ${colWidth}px !important`; innerHTML += ` - .p-datatable[${this.attributeSelector}] .p-datatable-thead > tr > th:nth-child(${index+1}) { - flex: 0 0 ${colWidth}px !important; - } - - .p-datatable[${this.attributeSelector}] .p-datatable-tbody > tr > td:nth-child(${index+1}) { - flex: 0 0 ${colWidth}px !important; + .p-datatable[${this.attributeSelector}] .p-datatable-thead > tr > th:nth-child(${index + 1}), + .p-datatable[${this.attributeSelector}] .p-datatable-tbody > tr > td:nth-child(${index + 1}), + .p-datatable[${this.attributeSelector}] .p-datatable-tfoot > tr > td:nth-child(${index + 1}) { + ${style} } ` }); + this.styleElement.innerHTML = innerHTML; }, bindColumnResizeEvents() { @@ -1195,7 +1184,7 @@ export default { if (this.documentColumnResizeEndListener) { document.removeEventListener('document', this.documentColumnResizeEndListener); - this.documentColumnResizeEndListener = null; + this.documentColumnResizeEndListener = null; } }, onColumnHeaderMouseDown(e) { @@ -1588,27 +1577,23 @@ export default { this.$el.style.width = this.tableWidthState; } - this.createStyleElement(); + if (ObjectUtils.isNotEmpty(widths)) { + this.createStyleElement(); - if (this.scrollable && widths && widths.length > 0) { let innerHTML = ''; - widths.forEach((width,index) => { + widths.forEach((width, index) => { + let style = this.scrollable ? `flex: 1 1 ${width}px !important` : `width: ${width}px !important`; innerHTML += ` - .p-datatable[${this.attributeSelector}] .p-datatable-thead > tr > th:nth-child(${index+1}) { - flex: 0 0 ${width}px; - } - - .p-datatable[${this.attributeSelector}] .p-datatable-tbody > tr > td:nth-child(${index+1}) { - flex: 0 0 ${width}px; + .p-datatable[${this.attributeSelector}] .p-datatable-thead > tr > th:nth-child(${index + 1}), + .p-datatable[${this.attributeSelector}] .p-datatable-tbody > tr > td:nth-child(${index + 1}), + .p-datatable[${this.attributeSelector}] .p-datatable-tfoot > tr > td:nth-child(${index + 1}) { + ${style} } ` }); this.styleElement.innerHTML = innerHTML; } - else { - DomHandler.find(this.$refs.table, '.p-datatable-thead > tr > th').forEach((header, index) => header.style.width = widths[index] + 'px'); - } } }, onCellEditInit(event) {