From 497912c32f441988269b27cefd396c3eaaa015cb Mon Sep 17 00:00:00 2001 From: Rajat Date: Thu, 28 Nov 2024 00:31:15 +0530 Subject: [PATCH] [DataGridPro] Fix header filtering with `boolean` column type (#15528) --- .../headerFiltering/GridHeaderFilterCell.tsx | 4 +- .../src/tests/filtering.DataGridPro.test.tsx | 69 +++++++++++++++++++ .../src/tests/filtering.DataGrid.test.tsx | 1 + 3 files changed, 72 insertions(+), 2 deletions(-) diff --git a/packages/x-data-grid-pro/src/components/headerFiltering/GridHeaderFilterCell.tsx b/packages/x-data-grid-pro/src/components/headerFiltering/GridHeaderFilterCell.tsx index 6c19ae5f9b372..bd8aca4630ed1 100644 --- a/packages/x-data-grid-pro/src/components/headerFiltering/GridHeaderFilterCell.tsx +++ b/packages/x-data-grid-pro/src/components/headerFiltering/GridHeaderFilterCell.tsx @@ -167,7 +167,7 @@ const GridHeaderFilterCell = React.forwardRef { - if (item.value && !updatedItem.value) { + if (item.value && updatedItem.value === undefined) { apiRef.current.deleteFilterItem(updatedItem); return; } @@ -314,7 +314,7 @@ const GridHeaderFilterCell = React.forwardRef - Filter', () => { ); }).not.toErrorDev(); }); + + it('should work correctly with boolean column type', () => { + const getRows = (item: Omit) => { + const { unmount } = render( + { + const value = params.value as boolean | null | undefined; + + if (value === null) { + return 'null'; + } + + if (value === undefined) { + return 'undefined'; + } + + return value.toString(); + }, + }, + ]} + headerFilters + />, + ); + const values = getColumnValues(0); + unmount(); + return values; + }; + const ALL_ROWS = ['undefined', 'null', 'true', 'false']; + const TRUTHY_ROWS = ['true']; + const FALSY_ROWS = ['undefined', 'null', 'false']; + + expect(getRows({ operator: 'is', value: 'true' })).to.deep.equal(TRUTHY_ROWS); + expect(getRows({ operator: 'is', value: true })).to.deep.equal(TRUTHY_ROWS); + + expect(getRows({ operator: 'is', value: 'false' })).to.deep.equal(FALSY_ROWS); + expect(getRows({ operator: 'is', value: false })).to.deep.equal(FALSY_ROWS); + + expect(getRows({ operator: 'is', value: '' })).to.deep.equal(ALL_ROWS); + expect(getRows({ operator: 'is', value: undefined })).to.deep.equal(ALL_ROWS); + expect(getRows({ operator: 'is', value: null })).to.deep.equal(ALL_ROWS); + expect(getRows({ operator: 'is', value: 'test' })).to.deep.equal(ALL_ROWS); // Ignores invalid values + }); }); describe('Read-only filters', () => { diff --git a/packages/x-data-grid/src/tests/filtering.DataGrid.test.tsx b/packages/x-data-grid/src/tests/filtering.DataGrid.test.tsx index 6aff1383998ac..5e333fd3765bb 100644 --- a/packages/x-data-grid/src/tests/filtering.DataGrid.test.tsx +++ b/packages/x-data-grid/src/tests/filtering.DataGrid.test.tsx @@ -1127,6 +1127,7 @@ describe(' - Filter', () => { expect(getRows({ operator: 'is', value: '' })).to.deep.equal(ALL_ROWS); expect(getRows({ operator: 'is', value: undefined })).to.deep.equal(ALL_ROWS); + expect(getRows({ operator: 'is', value: null })).to.deep.equal(ALL_ROWS); expect(getRows({ operator: 'is', value: 'test' })).to.deep.equal(ALL_ROWS); // Ignores invalid values }); });