From 2f482ecfa8fdbaa5d5eca60cb0e09c9e18034810 Mon Sep 17 00:00:00 2001 From: alexandrusoare Date: Mon, 20 Jan 2025 12:32:24 +0200 Subject: [PATCH] fix(RangeFilterPlugin): fixed range filter --- .../FiltersConfigForm/FiltersConfigForm.tsx | 1 - .../Range/RangeFilterPlugin.test.tsx | 8 ++++++-- .../components/Range/RangeFilterPlugin.tsx | 20 ++++++++++++------- 3 files changed, 19 insertions(+), 10 deletions(-) diff --git a/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/FiltersConfigForm/FiltersConfigForm.tsx b/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/FiltersConfigForm/FiltersConfigForm.tsx index 774a5312bffba..aae734f215dc5 100644 --- a/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/FiltersConfigForm/FiltersConfigForm.tsx +++ b/superset-frontend/src/dashboard/components/nativeFilters/FiltersConfigModal/FiltersConfigForm/FiltersConfigForm.tsx @@ -1249,7 +1249,6 @@ const FiltersConfigForm = ( rules={[ { validator: () => { - console.log(formFilter); if ( formFilter?.defaultDataMask?.filterState?.value !== undefined diff --git a/superset-frontend/src/filters/components/Range/RangeFilterPlugin.test.tsx b/superset-frontend/src/filters/components/Range/RangeFilterPlugin.test.tsx index f70533be7cbbd..550a06e72a581 100644 --- a/superset-frontend/src/filters/components/Range/RangeFilterPlugin.test.tsx +++ b/superset-frontend/src/filters/components/Range/RangeFilterPlugin.test.tsx @@ -135,6 +135,8 @@ describe('RangeFilterPlugin', () => { fireEvent.change(fromInput, { target: { value: 40 } }); + fireEvent.blur(fromInput); + expect(fromInput).toHaveValue('10'); }); @@ -177,7 +179,8 @@ describe('RangeFilterPlugin', () => { value: [20, 100], }, }); - expect(screen.getAllByRole('spinbutton')[0]).toHaveValue('20'); + const input = screen.getByRole('spinbutton'); + expect(input).toHaveValue('20'); }); it('should call setDataMask with correct less than filter', () => { @@ -200,7 +203,8 @@ describe('RangeFilterPlugin', () => { value: [10, 60], }, }); - expect(screen.getAllByRole('spinbutton')[1]).toHaveValue('60'); + const input = screen.getByRole('spinbutton'); + expect(input).toHaveValue('60'); }); it('should call setDataMask with correct exact filter', () => { diff --git a/superset-frontend/src/filters/components/Range/RangeFilterPlugin.tsx b/superset-frontend/src/filters/components/Range/RangeFilterPlugin.tsx index d0f3590d30459..3a05777a56729 100644 --- a/superset-frontend/src/filters/components/Range/RangeFilterPlugin.tsx +++ b/superset-frontend/src/filters/components/Range/RangeFilterPlugin.tsx @@ -94,7 +94,7 @@ export default function RangeFilterPlugin(props: PluginFilterRangeProps) { setFilterActive, filterState, inputRef, - filterBarOrientation, + filterBarOrientation = FilterBarOrientation.Vertical, isOverflowingFilterBar, } = props; const [row] = data; @@ -162,8 +162,13 @@ export default function RangeFilterPlugin(props: PluginFilterRangeProps) { const handleChange = (newValue: number, index: 0 | 1) => { const updatedValue: [number, number] = [...value]; - console.log(newValue); - if (enableSingleExactValue || enableSingleMinValue) { + + if (enableSingleExactValue) { + setValue([newValue, newValue]); + handleAfterChange([newValue, newValue]); + return; + } + if (enableSingleMinValue) { updatedValue[minIndex] = newValue; setValue(updatedValue); handleAfterChange(updatedValue); @@ -194,10 +199,8 @@ export default function RangeFilterPlugin(props: PluginFilterRangeProps) { return; } const filterStateValue = filterState.value ?? minMax; - if (filterStateValue !== minMax) { - setValue(filterStateValue); - handleAfterChange(filterStateValue); - } + setValue(filterStateValue); + handleAfterChange(filterStateValue); }, [ enableSingleMaxValue, enableSingleMinValue, @@ -219,18 +222,21 @@ export default function RangeFilterPlugin(props: PluginFilterRangeProps) { useEffect(() => { if (enableSingleMaxValue) { + setValue([min, minMax[maxIndex]]); handleAfterChange([min, minMax[maxIndex]]); } }, [enableSingleMaxValue]); useEffect(() => { if (enableSingleMinValue) { + setValue([minMax[minIndex], max]); handleAfterChange([minMax[minIndex], max]); } }, [enableSingleMinValue]); useEffect(() => { if (enableSingleExactValue) { + setValue([minMax[minIndex], minMax[minIndex]]); handleAfterChange([minMax[minIndex], minMax[minIndex]]); } }, [enableSingleExactValue]);