From f92ed2657737bc76ed4b842a98d109f175cdbb60 Mon Sep 17 00:00:00 2001 From: goto-loop <102797966+goto-loop@users.noreply.github.com> Date: Thu, 29 Feb 2024 17:41:23 +0100 Subject: [PATCH] fix(plugin-chart-echarts): calculate Gauge Chart intervals correctly when min value is set (#27285) --- .../src/Gauge/transformProps.ts | 13 ++--- .../test/Gauge/transformProps.test.ts | 54 +++++++++++++++++-- 2 files changed, 58 insertions(+), 9 deletions(-) diff --git a/superset-frontend/plugins/plugin-chart-echarts/src/Gauge/transformProps.ts b/superset-frontend/plugins/plugin-chart-echarts/src/Gauge/transformProps.ts index 269e2a8a18690..09eed22b973c4 100644 --- a/superset-frontend/plugins/plugin-chart-echarts/src/Gauge/transformProps.ts +++ b/superset-frontend/plugins/plugin-chart-echarts/src/Gauge/transformProps.ts @@ -48,11 +48,12 @@ import { getDefaultTooltip } from '../utils/tooltip'; import { Refs } from '../types'; import { getColtypesMapping } from '../utils/series'; -const setIntervalBoundsAndColors = ( +export const getIntervalBoundsAndColors = ( intervals: string, intervalColorIndices: string, colorFn: CategoricalColorScale, - normalizer: number, + min: number, + max: number, ): Array<[number, string]> => { let intervalBoundsNonNormalized; let intervalColorIndicesArray; @@ -65,7 +66,7 @@ const setIntervalBoundsAndColors = ( } const intervalBounds = intervalBoundsNonNormalized.map( - bound => bound / normalizer, + bound => (bound - min) / (max - min), ); const intervalColors = intervalColorIndicesArray.map( ind => colorFn.colors[(ind - 1) % colorFn.colors.length], @@ -221,12 +222,12 @@ export default function transformProps( const axisLabelLength = Math.max( ...axisLabels.map(label => numberFormatter(label).length).concat([1]), ); - const normalizer = max; - const intervalBoundsAndColors = setIntervalBoundsAndColors( + const intervalBoundsAndColors = getIntervalBoundsAndColors( intervals, intervalColorIndices, colorFn, - normalizer, + min, + max, ); const splitLineDistance = axisLineWidth + splitLineLength + OFFSETS.ticksFromLine; diff --git a/superset-frontend/plugins/plugin-chart-echarts/test/Gauge/transformProps.test.ts b/superset-frontend/plugins/plugin-chart-echarts/test/Gauge/transformProps.test.ts index 915a8b9e9dd37..760e3ff93c2b4 100644 --- a/superset-frontend/plugins/plugin-chart-echarts/test/Gauge/transformProps.test.ts +++ b/superset-frontend/plugins/plugin-chart-echarts/test/Gauge/transformProps.test.ts @@ -16,8 +16,15 @@ * specific language governing permissions and limitations * under the License. */ -import { ChartProps, SqlaFormData, supersetTheme } from '@superset-ui/core'; -import transformProps from '../../src/Gauge/transformProps'; +import { + CategoricalColorNamespace, + ChartProps, + SqlaFormData, + supersetTheme, +} from '@superset-ui/core'; +import transformProps, { + getIntervalBoundsAndColors, +} from '../../src/Gauge/transformProps'; import { EchartsGaugeChartProps } from '../../src/Gauge/types'; describe('Echarts Gauge transformProps', () => { @@ -256,8 +263,9 @@ describe('Echarts Gauge transformProps', () => { const formData: SqlaFormData = { ...baseFormData, groupby: ['year', 'platform'], - intervals: '50,100', + intervals: '60,100', intervalColorIndices: '1,2', + minVal: 20, }; const queriesData = [ { @@ -342,3 +350,43 @@ describe('Echarts Gauge transformProps', () => { ); }); }); + +describe('getIntervalBoundsAndColors', () => { + it('should generate correct interval bounds and colors', () => { + const colorFn = CategoricalColorNamespace.getScale( + 'supersetColors' as string, + ); + expect(getIntervalBoundsAndColors('', '', colorFn, 0, 10)).toEqual([]); + expect(getIntervalBoundsAndColors('4, 10', '1, 2', colorFn, 0, 10)).toEqual( + [ + [0.4, '#1f77b4'], + [1, '#ff7f0e'], + ], + ); + expect( + getIntervalBoundsAndColors('4, 8, 10', '9, 8, 7', colorFn, 0, 10), + ).toEqual([ + [0.4, '#bcbd22'], + [0.8, '#7f7f7f'], + [1, '#e377c2'], + ]); + expect(getIntervalBoundsAndColors('4, 10', '1, 2', colorFn, 2, 10)).toEqual( + [ + [0.25, '#1f77b4'], + [1, '#ff7f0e'], + ], + ); + expect( + getIntervalBoundsAndColors('-4, 0', '1, 2', colorFn, -10, 0), + ).toEqual([ + [0.6, '#1f77b4'], + [1, '#ff7f0e'], + ]); + expect( + getIntervalBoundsAndColors('-4, -2', '1, 2', colorFn, -10, -2), + ).toEqual([ + [0.75, '#1f77b4'], + [1, '#ff7f0e'], + ]); + }); +});