From 9a4e11db0e3546f4132de810db8001d7ec44919b Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Mon, 9 Dec 2024 20:16:49 +0100 Subject: [PATCH] [charts] Fix scatter dataset with missing data (@alexfauquette) (#15804) Signed-off-by: Jose C Quintas Jr Co-authored-by: Alexandre Fauquette <45398769+alexfauquette@users.noreply.github.com> Co-authored-by: Jose C Quintas Jr --- .../src/ScatterChart/ScatterChart.test.tsx | 53 ++++++++++++++++++- .../x-charts/src/ScatterChart/extremums.ts | 7 +-- .../x-charts/src/ScatterChart/formatter.ts | 4 +- 3 files changed, 58 insertions(+), 6 deletions(-) diff --git a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx index 6a0810ce8dd3e..354d06465b4bf 100644 --- a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx +++ b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx @@ -1,5 +1,6 @@ import * as React from 'react'; -import { createRenderer } from '@mui/internal-test-utils/createRenderer'; +import { expect } from 'chai'; +import { createRenderer, screen } from '@mui/internal-test-utils/createRenderer'; import { describeConformance } from 'test/utils/describeConformance'; import { ScatterChart } from '@mui/x-charts/ScatterChart'; @@ -38,4 +39,54 @@ describe('', () => { ], }), ); + + const isJSDOM = /jsdom/.test(window.navigator.userAgent); + + it('should support dataset with missing values', async function test() { + if (isJSDOM) { + this.skip(); + } + + // x from 500 to 600 + // y from 100 to 200 + const dataset = [ + { + version: 'data-0', + a1: 500, + a2: 100, + }, + { + version: 'data-1', + a1: 600, + a2: 200, + }, + { + version: 'data-2', + // Item with missing x-values + // a1: 500, + a2: 200, + }, + { + version: 'data-2', + // Item with missing y-values + a1: 500, + // a2: 200, + }, + ]; + + render( + , + ); + + const labelX = await screen.findByText('100'); + expect(labelX).toBeVisible(); + + const labelY = await screen.findByText('600'); + expect(labelY).toBeVisible(); + }); }); diff --git a/packages/x-charts/src/ScatterChart/extremums.ts b/packages/x-charts/src/ScatterChart/extremums.ts index 806295a1997ff..3e739e90eb42b 100644 --- a/packages/x-charts/src/ScatterChart/extremums.ts +++ b/packages/x-charts/src/ScatterChart/extremums.ts @@ -6,9 +6,10 @@ import { const mergeMinMax = ( acc: ExtremumGetterResult, val: ExtremumGetterResult, -): ExtremumGetterResult => { - return [Math.min(acc[0], val[0]), Math.max(acc[1], val[1])]; -}; +): ExtremumGetterResult => [ + val[0] === null ? acc[0] : Math.min(acc[0], val[0]), + val[1] === null ? acc[1] : Math.max(acc[1], val[1]), +]; export const getExtremumX: ExtremumGetter<'scatter'> = (params) => { const { series, axis, isDefaultAxis, getFilters } = params; diff --git a/packages/x-charts/src/ScatterChart/formatter.ts b/packages/x-charts/src/ScatterChart/formatter.ts index 60c024f88c2e4..fa55ee74a6b94 100644 --- a/packages/x-charts/src/ScatterChart/formatter.ts +++ b/packages/x-charts/src/ScatterChart/formatter.ts @@ -23,8 +23,8 @@ const formatter: SeriesFormatter<'scatter'> = ({ series, seriesOrder }, dataset) ? (seriesData.data ?? []) : (dataset?.map((d) => { return { - x: d[datasetKeys.x], - y: d[datasetKeys.y], + x: d[datasetKeys.x] ?? null, + y: d[datasetKeys.y] ?? null, z: datasetKeys.z && d[datasetKeys.z], id: d[datasetKeys.id], } as ScatterValueType;