From 1568cf10dcdce613068989f1e610849e65c7fce8 Mon Sep 17 00:00:00 2001
From: Alexandre Fauquette <45398769+alexfauquette@users.noreply.github.com>
Date: Mon, 9 Dec 2024 11:16:56 +0100
Subject: [PATCH 1/5] [charts] Fix scatter dataset with missing data (#15802)
---
.../src/ScatterChart/ScatterChart.test.tsx | 95 ++++++++++++++++++-
.../x-charts/src/ScatterChart/extremums.ts | 7 +-
.../x-charts/src/ScatterChart/formatter.ts | 4 +-
3 files changed, 100 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..f0b6ce301b817 100644
--- a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
+++ b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
@@ -1,5 +1,5 @@
import * as React from 'react';
-import { createRenderer } from '@mui/internal-test-utils/createRenderer';
+import { createRenderer, fireEvent, screen } from '@mui/internal-test-utils/createRenderer';
import { describeConformance } from 'test/utils/describeConformance';
import { ScatterChart } from '@mui/x-charts/ScatterChart';
@@ -38,4 +38,97 @@ describe('', () => {
],
}),
);
+
+ const config = {
+ dataset: [
+ { id: 1, x: 0, y: 10 },
+ { id: 2, x: 10, y: 10 },
+ { id: 3, x: 10, y: 0 },
+ { id: 4, x: 0, y: 0 },
+ { id: 5, x: 5, y: 5 },
+ ],
+ margin: { top: 0, left: 0, bottom: 0, right: 0 },
+ width: 100,
+ height: 100,
+ };
+
+ it('should show the tooltip without errors in default config', function test() {
+ if (isJSDOM) {
+ // svg.createSVGPoint not supported by JSDom /~https://github.com/jsdom/jsdom/issues/300
+ this.skip();
+ }
+ render(
+
+
+
,
+ );
+ const svg = document.querySelector('svg')!;
+ const marks = document.querySelectorAll('circle');
+
+ fireEvent.pointerEnter(marks[0]);
+
+ fireEvent.pointerEnter(svg); // Trigger the tooltip
+ fireEvent.pointerMove(marks[0]); // Only to set the tooltip position
+
+ let cells = document.querySelectorAll('.MuiChartsTooltip-root td');
+ expect([...cells].map((cell) => cell.textContent)).to.deep.equal(['', '', '(0, 10)']);
+
+ fireEvent.pointerEnter(marks[4]);
+ cells = document.querySelectorAll('.MuiChartsTooltip-root td');
+ expect([...cells].map((cell) => cell.textContent)).to.deep.equal(['', '', '(5, 5)']);
+ });
+
+ 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;
From e3dd007748bab057d4051939aaaceb2a198b4fad Mon Sep 17 00:00:00 2001
From: Jose C Quintas Jr
Date: Mon, 9 Dec 2024 12:46:39 +0100
Subject: [PATCH 2/5] Apply suggestions from code review
Signed-off-by: Jose C Quintas Jr
---
packages/x-charts/src/ScatterChart/ScatterChart.test.tsx | 2 ++
1 file changed, 2 insertions(+)
diff --git a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
index f0b6ce301b817..1592fbafd84cd 100644
--- a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
+++ b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
@@ -39,6 +39,8 @@ describe('', () => {
}),
);
+ const isJSDOM = /jsdom/.test(window.navigator.userAgent);
+
const config = {
dataset: [
{ id: 1, x: 0, y: 10 },
From 04f86c2239139d4a4e39fa433fc975db6e454385 Mon Sep 17 00:00:00 2001
From: Jose C Quintas Jr
Date: Mon, 9 Dec 2024 12:55:49 +0100
Subject: [PATCH 3/5] Apply suggestions from code review
Signed-off-by: Jose C Quintas Jr
---
packages/x-charts/src/ScatterChart/ScatterChart.test.tsx | 1 +
1 file changed, 1 insertion(+)
diff --git a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
index 1592fbafd84cd..384b88bad52ca 100644
--- a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
+++ b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
@@ -1,4 +1,5 @@
import * as React from 'react';
+import { expect } from 'chai';
import { createRenderer, fireEvent, screen } from '@mui/internal-test-utils/createRenderer';
import { describeConformance } from 'test/utils/describeConformance';
import { ScatterChart } from '@mui/x-charts/ScatterChart';
From 0432f5963f070baedfa808f8c7c4de5b5e70535d Mon Sep 17 00:00:00 2001
From: Jose C Quintas Jr
Date: Mon, 9 Dec 2024 14:12:32 +0100
Subject: [PATCH 4/5] Apply suggestions from code review
Signed-off-by: Jose C Quintas Jr
---
.../src/ScatterChart/ScatterChart.test.tsx | 34 +------------------
1 file changed, 1 insertion(+), 33 deletions(-)
diff --git a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
index 384b88bad52ca..80c02b2f38630 100644
--- a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
+++ b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
@@ -1,6 +1,6 @@
import * as React from 'react';
import { expect } from 'chai';
-import { createRenderer, fireEvent, screen } from '@mui/internal-test-utils/createRenderer';
+import { createRenderer, screen } from '@mui/internal-test-utils/createRenderer';
import { describeConformance } from 'test/utils/describeConformance';
import { ScatterChart } from '@mui/x-charts/ScatterChart';
@@ -55,38 +55,6 @@ describe('', () => {
height: 100,
};
- it('should show the tooltip without errors in default config', function test() {
- if (isJSDOM) {
- // svg.createSVGPoint not supported by JSDom /~https://github.com/jsdom/jsdom/issues/300
- this.skip();
- }
- render(
-
-
-
,
- );
- const svg = document.querySelector('svg')!;
- const marks = document.querySelectorAll('circle');
-
- fireEvent.pointerEnter(marks[0]);
-
- fireEvent.pointerEnter(svg); // Trigger the tooltip
- fireEvent.pointerMove(marks[0]); // Only to set the tooltip position
-
- let cells = document.querySelectorAll('.MuiChartsTooltip-root td');
- expect([...cells].map((cell) => cell.textContent)).to.deep.equal(['', '', '(0, 10)']);
-
- fireEvent.pointerEnter(marks[4]);
- cells = document.querySelectorAll('.MuiChartsTooltip-root td');
- expect([...cells].map((cell) => cell.textContent)).to.deep.equal(['', '', '(5, 5)']);
- });
-
it('should support dataset with missing values', async function test() {
if (isJSDOM) {
this.skip();
From 16ca69799d920e064b62c5744f20a8e04f8ff64d Mon Sep 17 00:00:00 2001
From: Jose C Quintas Jr
Date: Mon, 9 Dec 2024 17:47:54 +0100
Subject: [PATCH 5/5] Apply suggestions from code review
Signed-off-by: Jose C Quintas Jr
---
.../x-charts/src/ScatterChart/ScatterChart.test.tsx | 13 -------------
1 file changed, 13 deletions(-)
diff --git a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
index 80c02b2f38630..354d06465b4bf 100644
--- a/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
+++ b/packages/x-charts/src/ScatterChart/ScatterChart.test.tsx
@@ -42,19 +42,6 @@ describe('', () => {
const isJSDOM = /jsdom/.test(window.navigator.userAgent);
- const config = {
- dataset: [
- { id: 1, x: 0, y: 10 },
- { id: 2, x: 10, y: 10 },
- { id: 3, x: 10, y: 0 },
- { id: 4, x: 0, y: 0 },
- { id: 5, x: 5, y: 5 },
- ],
- margin: { top: 0, left: 0, bottom: 0, right: 0 },
- width: 100,
- height: 100,
- };
-
it('should support dataset with missing values', async function test() {
if (isJSDOM) {
this.skip();