@mui/x-charts 8.0.0-beta.1 → 8.0.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BarChart/useBarChartProps.d.ts +2 -1
- package/BarChart/useBarChartProps.js +20 -13
- package/CHANGELOG.md +94 -0
- package/ChartsAxisHighlight/ChartsXAxisHighlight.js +8 -8
- package/ChartsAxisHighlight/ChartsYAxisHighlight.js +8 -8
- package/ChartsOverlay/ChartsLoadingOverlay.js +1 -1
- package/ChartsOverlay/ChartsNoDataOverlay.js +1 -1
- package/ChartsTooltip/ChartsTooltipContainer.js +2 -1
- package/ChartsTooltip/useAxisTooltip.js +2 -2
- package/LineChart/CircleMarkElement.js +2 -2
- package/LineChart/LineHighlightPlot.js +2 -2
- package/LineChart/MarkElement.js +2 -2
- package/LineChart/useLineChartProps.d.ts +2 -1
- package/LineChart/useLineChartProps.js +7 -4
- package/RadarChart/RadarAxisHighlight/useRadarAxisHighlight.js +9 -5
- package/RadarChart/RadarGrid/RadarGrid.d.ts +1 -1
- package/RadarChart/RadarGrid/RadarGrid.js +5 -1
- package/RadarChart/RadarGrid/useRadarGridData.d.ts +1 -1
- package/RadarChart/RadarGrid/useRadarGridData.js +3 -0
- package/RadarChart/RadarSeriesPlot/useRadarSeriesData.js +2 -2
- package/ScatterChart/useScatterChartProps.d.ts +2 -1
- package/ScatterChart/useScatterChartProps.js +6 -3
- package/esm/BarChart/useBarChartProps.d.ts +2 -1
- package/esm/BarChart/useBarChartProps.js +19 -13
- package/esm/ChartsAxisHighlight/ChartsXAxisHighlight.js +8 -8
- package/esm/ChartsAxisHighlight/ChartsYAxisHighlight.js +8 -8
- package/esm/ChartsOverlay/ChartsLoadingOverlay.js +1 -1
- package/esm/ChartsOverlay/ChartsNoDataOverlay.js +1 -1
- package/esm/ChartsTooltip/ChartsTooltipContainer.js +2 -1
- package/esm/ChartsTooltip/useAxisTooltip.js +1 -1
- package/esm/LineChart/CircleMarkElement.js +1 -1
- package/esm/LineChart/LineHighlightPlot.js +1 -1
- package/esm/LineChart/MarkElement.js +1 -1
- package/esm/LineChart/useLineChartProps.d.ts +2 -1
- package/esm/LineChart/useLineChartProps.js +6 -4
- package/esm/RadarChart/RadarAxisHighlight/useRadarAxisHighlight.js +9 -5
- package/esm/RadarChart/RadarGrid/RadarGrid.d.ts +1 -1
- package/esm/RadarChart/RadarGrid/RadarGrid.js +5 -1
- package/esm/RadarChart/RadarGrid/useRadarGridData.d.ts +1 -1
- package/esm/RadarChart/RadarGrid/useRadarGridData.js +3 -0
- package/esm/RadarChart/RadarSeriesPlot/useRadarSeriesData.js +2 -2
- package/esm/ScatterChart/useScatterChartProps.d.ts +2 -1
- package/esm/ScatterChart/useScatterChartProps.js +5 -3
- package/esm/hooks/useAxis.d.ts +5 -5
- package/esm/hooks/useScale.d.ts +2 -2
- package/esm/hooks/useScale.js +2 -2
- package/esm/index.js +1 -1
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.d.ts +8 -6
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.js +28 -22
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +1 -0
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +1 -0
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +9 -42
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.d.ts +1 -0
- package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.js +41 -0
- package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +7 -20
- package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +36 -242
- package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js +4 -10
- package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +9 -15
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.d.ts +12 -0
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.js +8 -0
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.d.ts +6 -4
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.js +18 -13
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarAxis.js +16 -32
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.d.ts +3669 -0
- package/esm/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.js +22 -0
- package/hooks/useAxis.d.ts +5 -5
- package/hooks/useScale.d.ts +2 -2
- package/hooks/useScale.js +2 -2
- package/index.js +1 -1
- package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.d.ts +8 -6
- package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.js +29 -22
- package/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +1 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +12 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +7 -40
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.d.ts +1 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.js +47 -0
- package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +7 -20
- package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +36 -242
- package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js +5 -11
- package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +9 -15
- package/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.d.ts +12 -0
- package/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.js +17 -0
- package/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.d.ts +6 -4
- package/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.js +19 -13
- package/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarAxis.js +16 -32
- package/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.d.ts +3669 -0
- package/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.js +28 -0
- package/modern/BarChart/useBarChartProps.d.ts +2 -1
- package/modern/BarChart/useBarChartProps.js +19 -13
- package/modern/ChartsAxisHighlight/ChartsXAxisHighlight.js +8 -8
- package/modern/ChartsAxisHighlight/ChartsYAxisHighlight.js +8 -8
- package/modern/ChartsOverlay/ChartsLoadingOverlay.js +1 -1
- package/modern/ChartsOverlay/ChartsNoDataOverlay.js +1 -1
- package/modern/ChartsTooltip/ChartsTooltipContainer.js +2 -1
- package/modern/ChartsTooltip/useAxisTooltip.js +1 -1
- package/modern/LineChart/CircleMarkElement.js +1 -1
- package/modern/LineChart/LineHighlightPlot.js +1 -1
- package/modern/LineChart/MarkElement.js +1 -1
- package/modern/LineChart/useLineChartProps.d.ts +2 -1
- package/modern/LineChart/useLineChartProps.js +6 -4
- package/modern/RadarChart/RadarAxisHighlight/useRadarAxisHighlight.js +9 -5
- package/modern/RadarChart/RadarGrid/RadarGrid.d.ts +1 -1
- package/modern/RadarChart/RadarGrid/RadarGrid.js +5 -1
- package/modern/RadarChart/RadarGrid/useRadarGridData.d.ts +1 -1
- package/modern/RadarChart/RadarGrid/useRadarGridData.js +3 -0
- package/modern/RadarChart/RadarSeriesPlot/useRadarSeriesData.js +2 -2
- package/modern/ScatterChart/useScatterChartProps.d.ts +2 -1
- package/modern/ScatterChart/useScatterChartProps.js +5 -3
- package/modern/hooks/useAxis.d.ts +5 -5
- package/modern/hooks/useScale.d.ts +2 -2
- package/modern/hooks/useScale.js +2 -2
- package/modern/index.js +1 -1
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.d.ts +8 -6
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.js +28 -22
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +1 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +1 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +9 -42
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.d.ts +1 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.js +41 -0
- package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +7 -20
- package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +36 -242
- package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js +4 -10
- package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +9 -15
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.d.ts +12 -0
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.js +8 -0
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.d.ts +6 -4
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.js +18 -13
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarAxis.js +16 -32
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.d.ts +3669 -0
- package/modern/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.js +22 -0
- package/package.json +2 -2
- package/tsconfig.build.tsbuildinfo +1 -1
|
@@ -3,9 +3,9 @@ import { clampAngleRad } from "../../../clampAngle.js";
|
|
|
3
3
|
|
|
4
4
|
/**
|
|
5
5
|
* For a pointer coordinate, this function returns the value and dataIndex associated.
|
|
6
|
-
* Returns `
|
|
6
|
+
* Returns `-1` if the coordinate does not match a value.
|
|
7
7
|
*/
|
|
8
|
-
export function
|
|
8
|
+
export function getAxisIndex(axisConfig, pointerValue) {
|
|
9
9
|
const {
|
|
10
10
|
scale,
|
|
11
11
|
data: axisData,
|
|
@@ -14,20 +14,25 @@ export function getAxisValue(axisConfig, pointerValue) {
|
|
|
14
14
|
if (!isBandScale(scale)) {
|
|
15
15
|
throw new Error('MUI X: getAxisValue is not implemented for polare continuous axes.');
|
|
16
16
|
}
|
|
17
|
+
if (!axisData) {
|
|
18
|
+
return -1;
|
|
19
|
+
}
|
|
17
20
|
const angleGap = clampAngleRad(pointerValue - Math.min(...scale.range()));
|
|
18
21
|
const dataIndex = scale.bandwidth() === 0 ? Math.floor((angleGap + scale.step() / 2) / scale.step()) % axisData.length : Math.floor(angleGap / scale.step());
|
|
19
22
|
if (dataIndex < 0 || dataIndex >= axisData.length) {
|
|
20
|
-
return
|
|
23
|
+
return -1;
|
|
21
24
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
25
|
+
return reverse ? axisData.length - 1 - dataIndex : dataIndex;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* For a pointer coordinate, this function returns the value and dataIndex associated.
|
|
30
|
+
* Returns `null` if the coordinate is outside of values.
|
|
31
|
+
*/
|
|
32
|
+
export function getAxisValue(axisConfig, pointerValue) {
|
|
33
|
+
const dataIndex = getAxisIndex(axisConfig, pointerValue);
|
|
34
|
+
if (dataIndex < 0) {
|
|
35
|
+
return null;
|
|
28
36
|
}
|
|
29
|
-
return
|
|
30
|
-
index: dataIndex,
|
|
31
|
-
value: axisData[dataIndex]
|
|
32
|
-
};
|
|
37
|
+
return axisConfig.data?.[dataIndex];
|
|
33
38
|
}
|
|
@@ -6,10 +6,10 @@ import { warnOnce } from '@mui/x-internals/warning';
|
|
|
6
6
|
import { useSelector } from "../../../store/useSelector.js";
|
|
7
7
|
import { selectorChartDrawingArea } from "../../corePlugins/useChartDimensions/useChartDimensions.selectors.js";
|
|
8
8
|
import { defaultizeAxis } from "./defaultizeAxis.js";
|
|
9
|
-
import { getAxisValue } from "./getAxisValue.js";
|
|
10
9
|
import { selectorChartsInteractionIsInitialized } from "../useChartInteraction/index.js";
|
|
11
10
|
import { selectorChartPolarCenter, selectorChartRadiusAxis, selectorChartRotationAxis } from "./useChartPolarAxis.selectors.js";
|
|
12
11
|
import { getSVGPoint } from "../../../getSVGPoint.js";
|
|
12
|
+
import { generatePolar2svg, generateSvg2polar, generateSvg2rotation } from "./coordinateTransformation.js";
|
|
13
13
|
export const useChartPolarAxis = ({
|
|
14
14
|
params,
|
|
15
15
|
store,
|
|
@@ -56,14 +56,18 @@ export const useChartPolarAxis = ({
|
|
|
56
56
|
})
|
|
57
57
|
}));
|
|
58
58
|
}, [seriesConfig, drawingArea, rotationAxis, radiusAxis, dataset, store]);
|
|
59
|
-
const svg2rotation = React.
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
}, [center.cx, center.cy]);
|
|
59
|
+
const svg2rotation = React.useMemo(() => generateSvg2rotation({
|
|
60
|
+
cx: center.cx,
|
|
61
|
+
cy: center.cy
|
|
62
|
+
}), [center.cx, center.cy]);
|
|
63
|
+
const svg2polar = React.useMemo(() => generateSvg2polar({
|
|
64
|
+
cx: center.cx,
|
|
65
|
+
cy: center.cy
|
|
66
|
+
}), [center.cx, center.cy]);
|
|
67
|
+
const polar2svg = React.useMemo(() => generatePolar2svg({
|
|
68
|
+
cx: center.cx,
|
|
69
|
+
cy: center.cy
|
|
70
|
+
}), [center.cx, center.cy]);
|
|
67
71
|
const usedRotationAxisId = rotationAxisIds[0];
|
|
68
72
|
const usedRadiusAxisId = radiusAxisIds[0];
|
|
69
73
|
|
|
@@ -97,15 +101,7 @@ export const useChartPolarAxis = ({
|
|
|
97
101
|
targetElement: event.target
|
|
98
102
|
})) {
|
|
99
103
|
if (mousePosition.current.isInChart) {
|
|
100
|
-
|
|
101
|
-
interaction: {
|
|
102
|
-
item: null,
|
|
103
|
-
axis: {
|
|
104
|
-
x: null,
|
|
105
|
-
y: null
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}));
|
|
104
|
+
instance?.cleanInteraction();
|
|
109
105
|
mousePosition.current.isInChart = false;
|
|
110
106
|
}
|
|
111
107
|
return;
|
|
@@ -116,25 +112,13 @@ export const useChartPolarAxis = ({
|
|
|
116
112
|
const maxRadius = radiusAxisWithScale[usedRadiusAxisId].scale.range()[1];
|
|
117
113
|
if (radiusSquare > maxRadius ** 2) {
|
|
118
114
|
if (mousePosition.current.isInChart) {
|
|
119
|
-
|
|
120
|
-
interaction: {
|
|
121
|
-
item: null,
|
|
122
|
-
axis: {
|
|
123
|
-
x: null,
|
|
124
|
-
y: null
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
}));
|
|
115
|
+
instance?.cleanInteraction();
|
|
128
116
|
mousePosition.current.isInChart = false;
|
|
129
117
|
}
|
|
130
118
|
return;
|
|
131
119
|
}
|
|
132
120
|
mousePosition.current.isInChart = true;
|
|
133
|
-
|
|
134
|
-
instance.setAxisInteraction?.({
|
|
135
|
-
x: getAxisValue(rotationAxisWithScale[usedRotationAxisId], angle),
|
|
136
|
-
y: null
|
|
137
|
-
});
|
|
121
|
+
instance.setPointerCoordinate?.(svgPoint);
|
|
138
122
|
};
|
|
139
123
|
const handleDown = event => {
|
|
140
124
|
const target = event.currentTarget;
|