From 6977d579af893cb8ea68cef85c16f6f4ffbd6e79 Mon Sep 17 00:00:00 2001 From: Andrew Cherniavskii Date: Tue, 3 Dec 2024 12:46:08 +0100 Subject: [PATCH] [DataGrid] Make column autosizing work with flex columns (#15465) --- .../src/tests/columns.DataGridPro.test.tsx | 55 +++++++++---------- .../columnResize/useGridColumnResize.tsx | 1 + 2 files changed, 28 insertions(+), 28 deletions(-) diff --git a/packages/x-data-grid-pro/src/tests/columns.DataGridPro.test.tsx b/packages/x-data-grid-pro/src/tests/columns.DataGridPro.test.tsx index de3639feaffd0..6fadd1a23e5dc 100644 --- a/packages/x-data-grid-pro/src/tests/columns.DataGridPro.test.tsx +++ b/packages/x-data-grid-pro/src/tests/columns.DataGridPro.test.tsx @@ -25,18 +25,9 @@ describe(' - Columns', () => { const baselineProps = { autoHeight: isJSDOM, rows: [ - { - id: 0, - brand: 'Nike', - }, - { - id: 1, - brand: 'Adidas', - }, - { - id: 2, - brand: 'Puma', - }, + { id: 0, brand: 'Nike' }, + { id: 1, brand: 'Adidas' }, + { id: 2, brand: 'Puma' }, ], columns: [{ field: 'brand' }], }; @@ -443,22 +434,10 @@ describe(' - Columns', () => { }); const rows = [ - { - id: 0, - brand: 'Nike', - }, - { - id: 1, - brand: 'Adidas', - }, - { - id: 2, - brand: 'Puma', - }, - { - id: 3, - brand: 'Lululemon Athletica', - }, + { id: 0, brand: 'Nike' }, + { id: 1, brand: 'Adidas' }, + { id: 2, brand: 'Puma' }, + { id: 3, brand: 'Lululemon Athletica' }, ]; const columns = [ { field: 'id', headerName: 'This is the ID column' }, @@ -493,6 +472,26 @@ describe(' - Columns', () => { expect(getWidths()).to.deep.equal([155, 177]); }); + it('should work with flex columns', async () => { + render( + , + ); + const separators = document.querySelectorAll(`.${gridClasses['columnSeparator--resizable']}`); + fireEvent.doubleClick(separators[0]); + await microtasks(); + expect(columns.map((_, i) => getColumnHeaderCell(i).offsetWidth)).to.deep.equal([50, 233]); + + fireEvent.doubleClick(separators[1]); + await microtasks(); + expect(columns.map((_, i) => getColumnHeaderCell(i).offsetWidth)).to.deep.equal([50, 64]); + }); + describe('options', () => { const autosize = async (options: GridAutosizeOptions | undefined, widths: number[]) => { render(); diff --git a/packages/x-data-grid/src/hooks/features/columnResize/useGridColumnResize.tsx b/packages/x-data-grid/src/hooks/features/columnResize/useGridColumnResize.tsx index aa79485f5a4ac..fb778d30871e8 100644 --- a/packages/x-data-grid/src/hooks/features/columnResize/useGridColumnResize.tsx +++ b/packages/x-data-grid/src/hooks/features/columnResize/useGridColumnResize.tsx @@ -726,6 +726,7 @@ export const useGridColumnResize = ( ...column, width: widthByField[column.field], computedWidth: widthByField[column.field], + flex: 0, })); if (options.expand) {