Skip to content

Commit

Permalink
[DataGrid] Make column autosizing work with flex columns (#15465)
Browse files Browse the repository at this point in the history
  • Loading branch information
cherniavskii authored and web-flow committed Dec 3, 2024
1 parent b3b8918 commit 6977d57
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 28 deletions.
55 changes: 27 additions & 28 deletions packages/x-data-grid-pro/src/tests/columns.DataGridPro.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,18 +25,9 @@ describe('<DataGridPro /> - 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' }],
};
Expand Down Expand Up @@ -443,22 +434,10 @@ describe('<DataGridPro /> - 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' },
Expand Down Expand Up @@ -493,6 +472,26 @@ describe('<DataGridPro /> - Columns', () => {
expect(getWidths()).to.deep.equal([155, 177]);
});

it('should work with flex columns', async () => {
render(
<Test
rows={rows}
columns={[
{ field: 'id', flex: 1 },
{ field: 'brand', flex: 2 },
]}
/>,
);
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(<Test rows={rows} columns={columns} />);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -726,6 +726,7 @@ export const useGridColumnResize = (
...column,
width: widthByField[column.field],
computedWidth: widthByField[column.field],
flex: 0,
}));

if (options.expand) {
Expand Down

0 comments on commit 6977d57

Please sign in to comment.