@mui/x-charts 8.0.0-alpha.6 → 8.0.0-alpha.8
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/AnimatedBarElement.js +1 -0
- package/BarChart/BarChart.d.ts +1 -1
- package/BarChart/BarChart.js +26 -8
- package/BarChart/BarLabel/BarLabel.d.ts +1 -479
- package/BarChart/BarLabel/BarLabelPlot.js +1 -1
- package/BarChart/BarLabel/barLabelClasses.d.ts +1 -1
- package/BarChart/BarPlot.js +8 -9
- package/BarChart/extremums.d.ts +3 -3
- package/BarChart/formatter.d.ts +2 -2
- package/BarChart/formatter.js +2 -1
- package/BarChart/getColor.d.ts +1 -1
- package/BarChart/legend.d.ts +1 -1
- package/BarChart/legend.js +1 -0
- package/BarChart/plugin.d.ts +2 -2
- package/BarChart/plugin.js +1 -2
- package/BarChart/useBarChartProps.d.ts +5 -3
- package/BarChart/useBarChartProps.js +16 -3
- package/CHANGELOG.md +242 -1
- package/ChartContainer/ChartContainer.d.ts +6 -2
- package/ChartContainer/ChartContainer.js +13 -7
- package/ChartContainer/useChartContainerProps.d.ts +5 -3
- package/ChartContainer/useChartContainerProps.js +7 -5
- package/ChartsAxis/ChartsAxis.js +5 -3
- package/ChartsGrid/ChartsGrid.js +9 -5
- package/ChartsGrid/ChartsHorizontalGrid.d.ts +2 -2
- package/ChartsGrid/ChartsHorizontalGrid.js +4 -3
- package/ChartsGrid/ChartsVerticalGrid.d.ts +2 -2
- package/ChartsGrid/ChartsVerticalGrid.js +4 -3
- package/ChartsLabel/ChartsLabel.d.ts +2 -3
- package/ChartsLabel/ChartsLabel.js +3 -18
- package/ChartsLabel/ChartsLabelGradient.d.ts +9 -8
- package/ChartsLabel/ChartsLabelGradient.js +28 -26
- package/ChartsLabel/ChartsLabelMark.d.ts +2 -3
- package/ChartsLabel/ChartsLabelMark.js +5 -2
- package/ChartsLabel/index.d.ts +7 -0
- package/ChartsLabel/index.js +6 -0
- package/ChartsLabel/labelClasses.d.ts +0 -1
- package/ChartsLabel/labelGradientClasses.d.ts +5 -4
- package/ChartsLabel/labelGradientClasses.js +3 -2
- package/ChartsLabel/labelMarkClasses.d.ts +3 -2
- package/ChartsLabel/labelMarkClasses.js +3 -2
- package/ChartsLabel/package.json +6 -0
- package/ChartsLegend/ChartsLegend.d.ts +18 -22
- package/ChartsLegend/ChartsLegend.js +100 -109
- package/ChartsLegend/ContinuousColorLegend.d.ts +29 -38
- package/ChartsLegend/ContinuousColorLegend.js +198 -321
- package/ChartsLegend/PiecewiseColorLegend.d.ts +27 -19
- package/ChartsLegend/PiecewiseColorLegend.js +201 -111
- package/ChartsLegend/chartsLegend.types.d.ts +17 -60
- package/ChartsLegend/chartsLegendClasses.d.ts +7 -8
- package/ChartsLegend/chartsLegendClasses.js +16 -2
- package/ChartsLegend/colorLegend.types.d.ts +13 -0
- package/ChartsLegend/continuousColorLegendClasses.d.ts +26 -0
- package/ChartsLegend/continuousColorLegendClasses.js +23 -0
- package/ChartsLegend/direction.d.ts +1 -0
- package/ChartsLegend/index.d.ts +13 -3
- package/ChartsLegend/index.js +9 -3
- package/ChartsLegend/legend.types.d.ts +10 -54
- package/ChartsLegend/legendContext.types.d.ts +55 -0
- package/ChartsLegend/onClickContextBuilder.d.ts +2 -0
- package/ChartsLegend/onClickContextBuilder.js +7 -0
- package/ChartsLegend/piecewiseColorDefaultLabelFormatter.d.ts +2 -0
- package/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +9 -0
- package/ChartsLegend/piecewiseColorLegend.types.d.ts +26 -0
- package/ChartsLegend/piecewiseColorLegendClasses.d.ts +28 -0
- package/ChartsLegend/piecewiseColorLegendClasses.js +23 -0
- package/ChartsLegend/useAxis.d.ts +1 -1
- package/ChartsLegend/useAxis.js +7 -6
- package/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +7 -6
- package/ChartsReferenceLine/ChartsXReferenceLine.d.ts +1 -1
- package/ChartsReferenceLine/ChartsYReferenceLine.d.ts +1 -1
- package/ChartsSurface/ChartsSurface.js +16 -27
- package/ChartsTooltip/ChartsAxisTooltipContent.js +6 -3
- package/ChartsTooltip/ChartsItemTooltipContent.js +6 -3
- package/ChartsTooltip/ChartsTooltipTable.d.ts +0 -6
- package/ChartsTooltip/ChartsTooltipTable.js +0 -20
- package/ChartsTooltip/chartsTooltipClasses.d.ts +1 -1
- package/ChartsTooltip/useAxisTooltip.d.ts +3 -1
- package/ChartsTooltip/useAxisTooltip.js +13 -9
- package/ChartsTooltip/useItemTooltip.d.ts +3 -1
- package/ChartsTooltip/useItemTooltip.js +14 -10
- package/ChartsVoronoiHandler/ChartsVoronoiHandler.js +16 -9
- package/ChartsXAxis/ChartsXAxis.js +11 -8
- package/ChartsYAxis/ChartsYAxis.js +8 -5
- package/Gauge/Gauge.js +5 -1
- package/Gauge/GaugeContainer.d.ts +3 -10
- package/Gauge/GaugeContainer.js +38 -38
- package/LineChart/AnimatedArea.js +2 -1
- package/LineChart/AnimatedLine.js +2 -1
- package/LineChart/AppearingMask.js +2 -1
- package/LineChart/AreaPlot.js +16 -15
- package/LineChart/CircleMarkElement.js +1 -0
- package/LineChart/LineChart.js +29 -11
- package/LineChart/LineHighlightPlot.js +14 -11
- package/LineChart/LinePlot.js +16 -15
- package/LineChart/MarkElement.js +3 -1
- package/LineChart/MarkPlot.js +14 -11
- package/LineChart/extremums.d.ts +3 -3
- package/LineChart/formatter.d.ts +2 -2
- package/LineChart/formatter.js +3 -1
- package/LineChart/getColor.d.ts +1 -1
- package/LineChart/legend.d.ts +1 -1
- package/LineChart/legend.js +1 -0
- package/LineChart/plugin.d.ts +2 -2
- package/LineChart/plugin.js +1 -2
- package/LineChart/useLineChartProps.d.ts +5 -3
- package/LineChart/useLineChartProps.js +15 -2
- package/PieChart/PieArc.js +3 -1
- package/PieChart/PieArcLabel.js +13 -9
- package/PieChart/PieArcLabelPlot.js +3 -2
- package/PieChart/PieArcPlot.js +3 -2
- package/PieChart/PieChart.js +51 -42
- package/PieChart/dataTransform/transition.d.ts +2 -2
- package/PieChart/dataTransform/transition.js +6 -6
- package/PieChart/formatter.d.ts +2 -2
- package/PieChart/formatter.js +4 -1
- package/PieChart/getColor.d.ts +1 -1
- package/PieChart/getPieCoordinates.d.ts +2 -2
- package/PieChart/legend.d.ts +1 -1
- package/PieChart/legend.js +1 -0
- package/PieChart/plugin.d.ts +2 -2
- package/PieChart/plugin.js +1 -2
- package/ScatterChart/Scatter.js +6 -4
- package/ScatterChart/ScatterChart.d.ts +1 -2
- package/ScatterChart/ScatterChart.js +28 -14
- package/ScatterChart/ScatterPlot.js +11 -10
- package/ScatterChart/extremums.d.ts +3 -3
- package/ScatterChart/extremums.js +3 -1
- package/ScatterChart/formatter.d.ts +2 -2
- package/ScatterChart/formatter.js +3 -1
- package/ScatterChart/getColor.d.ts +1 -1
- package/ScatterChart/legend.d.ts +1 -1
- package/ScatterChart/legend.js +1 -0
- package/ScatterChart/plugin.d.ts +2 -2
- package/ScatterChart/plugin.js +1 -2
- package/ScatterChart/useScatterChartProps.d.ts +5 -5
- package/ScatterChart/useScatterChartProps.js +16 -6
- package/SparkLineChart/SparkLineChart.d.ts +2 -2
- package/SparkLineChart/SparkLineChart.js +12 -6
- package/constants/index.d.ts +1 -0
- package/constants/index.js +2 -1
- package/context/ChartDataProvider/ChartDataProvider.d.ts +6 -22
- package/context/ChartDataProvider/ChartDataProvider.js +22 -184
- package/context/ChartDataProvider/useChartDataProviderProps.d.ts +6 -83
- package/context/ChartDataProvider/useChartDataProviderProps.js +33 -47
- package/context/ChartProvider/ChartProvider.d.ts +5 -1
- package/context/ChartProvider/ChartProvider.js +22 -2
- package/context/ChartProvider/ChartProvider.types.d.ts +18 -3
- package/context/InteractionSelectors.d.ts +22 -22
- package/context/PolarProvider/PolarProvider.d.ts +0 -4
- package/context/PolarProvider/PolarProvider.js +59 -47
- package/context/PolarProvider/getAxisExtremum.d.ts +0 -4
- package/context/PolarProvider/getAxisExtremum.js +48 -20
- package/context/PolarProvider/usePolarContext.d.ts +0 -2
- package/context/PolarProvider/usePolarContext.js +9 -8
- package/context/index.d.ts +0 -2
- package/context/index.js +0 -1
- package/hooks/index.d.ts +3 -0
- package/hooks/index.js +4 -1
- package/hooks/useAxis.d.ts +9 -1
- package/hooks/useAxis.js +32 -6
- package/hooks/useAxisEvents.js +12 -8
- package/hooks/useChartGradientId.d.ts +31 -0
- package/hooks/useChartGradientId.js +47 -0
- package/hooks/useColorScale.js +5 -5
- package/hooks/useDrawingArea.d.ts +16 -2
- package/hooks/useDrawingArea.js +5 -20
- package/hooks/useLegend.d.ts +13 -0
- package/{modern/ChartsLegend/utils.js → hooks/useLegend.js} +20 -1
- package/hooks/useSeries.d.ts +11 -6
- package/hooks/useSeries.js +5 -10
- package/hooks/useSvgRef.d.ts +1 -1
- package/hooks/useZAxis.d.ts +3 -2
- package/hooks/useZAxis.js +25 -6
- package/index.d.ts +1 -0
- package/index.js +2 -1
- package/internals/calculateMargins.d.ts +7 -0
- package/internals/calculateMargins.js +25 -0
- package/internals/components/ChartsAxesGradients/ChartsAxesGradients.d.ts +0 -2
- package/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +65 -29
- package/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
- package/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.d.ts +13 -0
- package/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +61 -0
- package/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.d.ts +1 -1
- package/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
- package/internals/components/ChartsWrapper/ChartsWrapper.d.ts +17 -0
- package/internals/components/ChartsWrapper/ChartsWrapper.js +66 -0
- package/internals/components/ChartsWrapper/index.d.ts +1 -0
- package/internals/components/ChartsWrapper/index.js +1 -0
- package/internals/consumeSlots.d.ts +48 -0
- package/internals/consumeSlots.js +101 -0
- package/internals/consumeThemeProps.d.ts +3 -7
- package/internals/consumeThemeProps.js +18 -27
- package/internals/defaultizeColor.d.ts +26 -21
- package/internals/index.d.ts +14 -8
- package/internals/index.js +17 -9
- package/internals/plugins/allPlugins.d.ts +12 -1
- package/internals/plugins/allPlugins.js +5 -2
- package/internals/plugins/corePlugins/corePlugins.d.ts +1 -1
- package/internals/plugins/corePlugins/corePlugins.js +3 -1
- package/internals/plugins/corePlugins/useChartDimensions/index.d.ts +3 -0
- package/internals/plugins/corePlugins/useChartDimensions/index.js +2 -0
- package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.d.ts +3 -0
- package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +175 -0
- package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.d.ts +264 -0
- package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +25 -0
- package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.d.ts +99 -0
- package/internals/plugins/corePlugins/useChartId/index.d.ts +1 -0
- package/internals/plugins/corePlugins/useChartId/index.js +2 -1
- package/internals/plugins/corePlugins/useChartId/useChartId.js +1 -1
- package/internals/plugins/corePlugins/useChartId/useChartId.selectors.d.ts +1 -1
- package/internals/plugins/corePlugins/useChartId/useChartId.types.d.ts +1 -1
- package/internals/plugins/corePlugins/useChartSeries/index.d.ts +3 -0
- package/internals/plugins/corePlugins/useChartSeries/index.js +2 -0
- package/internals/plugins/corePlugins/useChartSeries/processSeries.d.ts +18 -0
- package/{modern/context/SeriesProvider → internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
- package/internals/plugins/corePlugins/useChartSeries/useChartSeries.d.ts +3 -0
- package/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +72 -0
- package/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.d.ts +61 -0
- package/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +4 -0
- package/internals/plugins/corePlugins/useChartSeries/useChartSeries.types.d.ts +51 -0
- package/internals/plugins/corePlugins/useChartSeries/useColorProcessor.d.ts +10 -0
- package/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +21 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.d.ts +29 -0
- package/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
- package/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.d.ts +18 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +61 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.d.ts +39 -0
- package/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +3 -11
- package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.d.ts +6 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +22 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +5 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +4 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.d.ts +4 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +68 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.d.ts +1372 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +87 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.d.ts +76 -0
- package/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.d.ts +18 -0
- package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +11 -11
- package/internals/plugins/featurePlugins/useChartZAxis/index.d.ts +3 -0
- package/internals/plugins/featurePlugins/useChartZAxis/index.js +2 -0
- package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.d.ts +3 -0
- package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +86 -0
- package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.d.ts +45 -0
- package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +3 -0
- package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.d.ts +39 -0
- package/internals/plugins/featurePlugins/useChartZAxis/utils.d.ts +0 -0
- package/internals/plugins/featurePlugins/useChartZAxis/utils.js +0 -0
- package/internals/plugins/models/index.d.ts +1 -0
- package/internals/plugins/models/index.js +2 -1
- package/internals/plugins/models/plugin.d.ts +33 -3
- package/internals/plugins/models/seriesConfig/colorProcessor.types.d.ts +5 -0
- package/internals/plugins/models/seriesConfig/extremumGetter.types.d.ts +22 -0
- package/internals/plugins/models/seriesConfig/index.d.ts +4 -0
- package/internals/plugins/models/seriesConfig/index.js +4 -0
- package/internals/plugins/models/seriesConfig/seriesConfig.types.d.ts +14 -0
- package/internals/plugins/models/seriesConfig/seriesProcessor.types.d.ts +18 -0
- package/internals/store/extractPluginParamsFromProps.d.ts +7 -0
- package/internals/store/extractPluginParamsFromProps.js +28 -0
- package/internals/store/useChartModels.d.ts +7 -0
- package/internals/store/useChartModels.js +64 -0
- package/internals/store/useCharts.d.ts +6 -4
- package/internals/store/useCharts.js +14 -9
- package/internals/store/useCharts.types.d.ts +1 -1
- package/internals/store/useStore.d.ts +5 -1
- package/internals/store/useStore.js +1 -9
- package/models/layout.d.ts +2 -1
- package/models/seriesType/common.d.ts +9 -0
- package/models/seriesType/pie.d.ts +9 -0
- package/modern/BarChart/AnimatedBarElement.js +1 -0
- package/modern/BarChart/BarChart.js +26 -8
- package/modern/BarChart/BarLabel/BarLabelPlot.js +1 -1
- package/modern/BarChart/BarPlot.js +8 -9
- package/modern/BarChart/formatter.js +2 -1
- package/modern/BarChart/legend.js +1 -0
- package/modern/BarChart/plugin.js +1 -2
- package/modern/BarChart/useBarChartProps.js +16 -3
- package/modern/ChartContainer/ChartContainer.js +13 -7
- package/modern/ChartContainer/useChartContainerProps.js +7 -5
- package/modern/ChartsAxis/ChartsAxis.js +5 -3
- package/modern/ChartsGrid/ChartsGrid.js +9 -5
- package/modern/ChartsGrid/ChartsHorizontalGrid.js +4 -3
- package/modern/ChartsGrid/ChartsVerticalGrid.js +4 -3
- package/modern/ChartsLabel/ChartsLabel.js +3 -18
- package/modern/ChartsLabel/ChartsLabelGradient.js +28 -26
- package/modern/ChartsLabel/ChartsLabelMark.js +5 -2
- package/modern/ChartsLabel/index.js +6 -0
- package/modern/ChartsLabel/labelGradientClasses.js +3 -2
- package/modern/ChartsLabel/labelMarkClasses.js +3 -2
- package/modern/ChartsLegend/ChartsLegend.js +100 -109
- package/modern/ChartsLegend/ContinuousColorLegend.js +198 -321
- package/modern/ChartsLegend/PiecewiseColorLegend.js +201 -111
- package/modern/ChartsLegend/chartsLegendClasses.js +16 -2
- package/modern/ChartsLegend/continuousColorLegendClasses.js +23 -0
- package/modern/ChartsLegend/index.js +9 -3
- package/modern/ChartsLegend/onClickContextBuilder.js +7 -0
- package/modern/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +9 -0
- package/modern/ChartsLegend/piecewiseColorLegend.types.js +1 -0
- package/modern/ChartsLegend/piecewiseColorLegendClasses.js +23 -0
- package/modern/ChartsLegend/useAxis.js +7 -6
- package/modern/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +7 -6
- package/modern/ChartsSurface/ChartsSurface.js +16 -27
- package/modern/ChartsTooltip/ChartsAxisTooltipContent.js +6 -3
- package/modern/ChartsTooltip/ChartsItemTooltipContent.js +6 -3
- package/modern/ChartsTooltip/ChartsTooltipTable.js +0 -20
- package/modern/ChartsTooltip/useAxisTooltip.js +13 -9
- package/modern/ChartsTooltip/useItemTooltip.js +14 -10
- package/modern/ChartsVoronoiHandler/ChartsVoronoiHandler.js +16 -9
- package/modern/ChartsXAxis/ChartsXAxis.js +11 -8
- package/modern/ChartsYAxis/ChartsYAxis.js +8 -5
- package/modern/Gauge/Gauge.js +5 -1
- package/modern/Gauge/GaugeContainer.js +38 -38
- package/modern/LineChart/AnimatedArea.js +2 -1
- package/modern/LineChart/AnimatedLine.js +2 -1
- package/modern/LineChart/AppearingMask.js +2 -1
- package/modern/LineChart/AreaPlot.js +16 -15
- package/modern/LineChart/CircleMarkElement.js +1 -0
- package/modern/LineChart/LineChart.js +29 -11
- package/modern/LineChart/LineHighlightPlot.js +14 -11
- package/modern/LineChart/LinePlot.js +16 -15
- package/modern/LineChart/MarkElement.js +3 -1
- package/modern/LineChart/MarkPlot.js +14 -11
- package/modern/LineChart/formatter.js +3 -1
- package/modern/LineChart/legend.js +1 -0
- package/modern/LineChart/plugin.js +1 -2
- package/modern/LineChart/useLineChartProps.js +15 -2
- package/modern/PieChart/PieArc.js +3 -1
- package/modern/PieChart/PieArcLabel.js +13 -9
- package/modern/PieChart/PieArcLabelPlot.js +3 -2
- package/modern/PieChart/PieArcPlot.js +3 -2
- package/modern/PieChart/PieChart.js +51 -42
- package/modern/PieChart/dataTransform/transition.js +6 -6
- package/modern/PieChart/formatter.js +4 -1
- package/modern/PieChart/legend.js +1 -0
- package/modern/PieChart/plugin.js +1 -2
- package/modern/ScatterChart/Scatter.js +6 -4
- package/modern/ScatterChart/ScatterChart.js +28 -14
- package/modern/ScatterChart/ScatterPlot.js +11 -10
- package/modern/ScatterChart/extremums.js +3 -1
- package/modern/ScatterChart/formatter.js +3 -1
- package/modern/ScatterChart/legend.js +1 -0
- package/modern/ScatterChart/plugin.js +1 -2
- package/modern/ScatterChart/useScatterChartProps.js +16 -6
- package/modern/SparkLineChart/SparkLineChart.js +12 -6
- package/modern/constants/index.js +2 -1
- package/modern/context/ChartDataProvider/ChartDataProvider.js +22 -184
- package/modern/context/ChartDataProvider/useChartDataProviderProps.js +33 -47
- package/modern/context/ChartProvider/ChartProvider.js +22 -2
- package/modern/context/PolarProvider/PolarProvider.js +59 -47
- package/modern/context/PolarProvider/getAxisExtremum.js +48 -20
- package/modern/context/PolarProvider/usePolarContext.js +9 -8
- package/modern/context/index.js +0 -1
- package/modern/hooks/index.js +4 -1
- package/modern/hooks/useAxis.js +32 -6
- package/modern/hooks/useAxisEvents.js +12 -8
- package/modern/hooks/useChartGradientId.js +47 -0
- package/modern/hooks/useColorScale.js +5 -5
- package/modern/hooks/useDrawingArea.js +5 -20
- package/{ChartsLegend/utils.js → modern/hooks/useLegend.js} +20 -1
- package/modern/hooks/useSeries.js +5 -10
- package/modern/hooks/useZAxis.js +25 -6
- package/modern/index.js +2 -1
- package/modern/internals/calculateMargins.js +25 -0
- package/modern/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +65 -29
- package/modern/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
- package/modern/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +61 -0
- package/modern/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
- package/modern/internals/components/ChartsWrapper/ChartsWrapper.js +66 -0
- package/modern/internals/components/ChartsWrapper/index.js +1 -0
- package/modern/internals/consumeSlots.js +101 -0
- package/modern/internals/consumeThemeProps.js +18 -27
- package/modern/internals/index.js +17 -9
- package/modern/internals/plugins/allPlugins.js +5 -2
- package/modern/internals/plugins/corePlugins/corePlugins.js +3 -1
- package/modern/internals/plugins/corePlugins/useChartDimensions/index.js +2 -0
- package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +175 -0
- package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +25 -0
- package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js +1 -0
- package/modern/internals/plugins/corePlugins/useChartId/index.js +2 -1
- package/modern/internals/plugins/corePlugins/useChartId/useChartId.js +1 -1
- package/modern/internals/plugins/corePlugins/useChartSeries/index.js +2 -0
- package/{context/SeriesProvider → modern/internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
- package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +72 -0
- package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +4 -0
- package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js +1 -0
- package/modern/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +21 -0
- package/modern/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +61 -0
- package/modern/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +3 -11
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +22 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +4 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +68 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +87 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js +1 -0
- package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js +1 -0
- package/modern/internals/plugins/featurePlugins/useChartZAxis/index.js +2 -0
- package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +86 -0
- package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +3 -0
- package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js +1 -0
- package/modern/internals/plugins/featurePlugins/useChartZAxis/utils.js +0 -0
- package/modern/internals/plugins/models/index.js +2 -1
- package/modern/internals/plugins/models/seriesConfig/colorProcessor.types.js +1 -0
- package/modern/internals/plugins/models/seriesConfig/extremumGetter.types.js +1 -0
- package/modern/internals/plugins/models/seriesConfig/index.js +4 -0
- package/modern/internals/plugins/models/seriesConfig/seriesConfig.types.js +1 -0
- package/modern/internals/plugins/models/seriesConfig/seriesProcessor.types.js +1 -0
- package/modern/internals/store/extractPluginParamsFromProps.js +28 -0
- package/modern/internals/store/useChartModels.js +64 -0
- package/modern/internals/store/useCharts.js +14 -9
- package/modern/internals/store/useStore.js +1 -9
- package/node/BarChart/AnimatedBarElement.js +1 -0
- package/node/BarChart/BarChart.js +26 -8
- package/node/BarChart/BarLabel/BarLabelPlot.js +1 -1
- package/node/BarChart/BarPlot.js +6 -6
- package/node/BarChart/formatter.js +2 -1
- package/node/BarChart/legend.js +1 -0
- package/node/BarChart/plugin.js +1 -2
- package/node/BarChart/useBarChartProps.js +15 -3
- package/node/ChartContainer/ChartContainer.js +13 -7
- package/node/ChartContainer/useChartContainerProps.js +7 -5
- package/node/ChartsAxis/ChartsAxis.js +5 -3
- package/node/ChartsGrid/ChartsGrid.js +9 -5
- package/node/ChartsGrid/ChartsHorizontalGrid.js +4 -3
- package/node/ChartsGrid/ChartsVerticalGrid.js +4 -3
- package/node/ChartsLabel/ChartsLabel.js +3 -18
- package/node/ChartsLabel/ChartsLabelGradient.js +28 -26
- package/node/ChartsLabel/ChartsLabelMark.js +5 -2
- package/node/ChartsLabel/index.js +26 -0
- package/node/ChartsLabel/labelGradientClasses.js +3 -2
- package/node/ChartsLabel/labelMarkClasses.js +3 -2
- package/node/ChartsLegend/ChartsLegend.js +99 -108
- package/node/ChartsLegend/ContinuousColorLegend.js +199 -322
- package/node/ChartsLegend/PiecewiseColorLegend.js +201 -111
- package/node/ChartsLegend/chartsLegendClasses.js +17 -3
- package/node/ChartsLegend/continuousColorLegendClasses.js +31 -0
- package/node/ChartsLegend/index.js +80 -16
- package/node/ChartsLegend/onClickContextBuilder.js +14 -0
- package/node/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +15 -0
- package/node/ChartsLegend/piecewiseColorLegendClasses.js +31 -0
- package/node/ChartsLegend/useAxis.js +6 -4
- package/node/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +6 -5
- package/node/ChartsSurface/ChartsSurface.js +17 -28
- package/node/ChartsTooltip/ChartsAxisTooltipContent.js +5 -2
- package/node/ChartsTooltip/ChartsItemTooltipContent.js +5 -2
- package/node/ChartsTooltip/ChartsTooltipTable.js +1 -21
- package/node/ChartsTooltip/useAxisTooltip.js +11 -7
- package/node/ChartsTooltip/useItemTooltip.js +13 -9
- package/node/ChartsVoronoiHandler/ChartsVoronoiHandler.js +19 -12
- package/node/ChartsXAxis/ChartsXAxis.js +11 -8
- package/node/ChartsYAxis/ChartsYAxis.js +8 -5
- package/node/Gauge/Gauge.js +5 -1
- package/node/Gauge/GaugeContainer.js +38 -38
- package/node/LineChart/AnimatedArea.js +2 -1
- package/node/LineChart/AnimatedLine.js +2 -1
- package/node/LineChart/AppearingMask.js +2 -1
- package/node/LineChart/AreaPlot.js +16 -15
- package/node/LineChart/CircleMarkElement.js +1 -0
- package/node/LineChart/LineChart.js +29 -11
- package/node/LineChart/LineHighlightPlot.js +14 -11
- package/node/LineChart/LinePlot.js +16 -15
- package/node/LineChart/MarkElement.js +3 -1
- package/node/LineChart/MarkPlot.js +14 -11
- package/node/LineChart/formatter.js +3 -1
- package/node/LineChart/legend.js +1 -0
- package/node/LineChart/plugin.js +1 -2
- package/node/LineChart/useLineChartProps.js +14 -2
- package/node/PieChart/PieArc.js +3 -1
- package/node/PieChart/PieArcLabel.js +13 -9
- package/node/PieChart/PieArcLabelPlot.js +2 -1
- package/node/PieChart/PieArcPlot.js +2 -1
- package/node/PieChart/PieChart.js +51 -42
- package/node/PieChart/dataTransform/transition.js +9 -7
- package/node/PieChart/formatter.js +4 -1
- package/node/PieChart/legend.js +1 -0
- package/node/PieChart/plugin.js +1 -2
- package/node/ScatterChart/Scatter.js +6 -4
- package/node/ScatterChart/ScatterChart.js +28 -14
- package/node/ScatterChart/ScatterPlot.js +10 -9
- package/node/ScatterChart/extremums.js +3 -1
- package/node/ScatterChart/formatter.js +3 -1
- package/node/ScatterChart/legend.js +1 -0
- package/node/ScatterChart/plugin.js +1 -2
- package/node/ScatterChart/useScatterChartProps.js +15 -6
- package/node/SparkLineChart/SparkLineChart.js +11 -5
- package/node/constants/index.js +3 -2
- package/node/context/ChartDataProvider/ChartDataProvider.js +22 -184
- package/node/context/ChartDataProvider/useChartDataProviderProps.js +34 -47
- package/node/context/ChartProvider/ChartProvider.js +23 -2
- package/node/context/PolarProvider/PolarProvider.js +59 -51
- package/node/context/PolarProvider/getAxisExtremum.js +49 -27
- package/node/context/PolarProvider/usePolarContext.js +9 -14
- package/node/context/index.js +0 -8
- package/node/hooks/index.js +41 -2
- package/node/hooks/useAxis.js +34 -6
- package/node/hooks/useAxisEvents.js +12 -8
- package/node/hooks/useChartGradientId.js +56 -0
- package/node/hooks/useColorScale.js +4 -4
- package/node/hooks/useDrawingArea.js +5 -21
- package/node/{ChartsLegend/utils.js → hooks/useLegend.js} +19 -1
- package/node/hooks/useSeries.js +5 -9
- package/node/hooks/useZAxis.js +27 -9
- package/node/index.js +12 -1
- package/node/internals/calculateMargins.js +33 -0
- package/node/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +64 -29
- package/node/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
- package/node/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +69 -0
- package/node/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
- package/node/internals/components/ChartsWrapper/ChartsWrapper.js +72 -0
- package/node/internals/components/ChartsWrapper/index.js +16 -0
- package/node/internals/consumeSlots.js +109 -0
- package/node/internals/consumeThemeProps.js +18 -27
- package/node/internals/index.js +134 -62
- package/node/internals/plugins/allPlugins.js +4 -2
- package/node/internals/plugins/corePlugins/corePlugins.js +3 -1
- package/node/internals/plugins/corePlugins/useChartDimensions/index.js +27 -0
- package/node/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +183 -0
- package/node/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +32 -0
- package/node/internals/plugins/corePlugins/useChartId/index.js +16 -1
- package/node/internals/plugins/corePlugins/useChartId/useChartId.js +1 -1
- package/node/internals/plugins/corePlugins/useChartSeries/index.js +27 -0
- package/node/{context/SeriesProvider → internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
- package/node/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +80 -0
- package/node/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +11 -0
- package/node/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +27 -0
- package/node/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
- package/node/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +69 -0
- package/node/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +4 -13
- package/node/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +29 -0
- package/node/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +47 -0
- package/node/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +76 -0
- package/node/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +96 -0
- package/node/internals/plugins/featurePlugins/useChartZAxis/index.js +27 -0
- package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +94 -0
- package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +9 -0
- package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js +5 -0
- package/node/internals/plugins/featurePlugins/useChartZAxis/utils.js +1 -0
- package/node/internals/plugins/models/index.js +11 -0
- package/node/internals/plugins/models/seriesConfig/colorProcessor.types.js +5 -0
- package/node/internals/plugins/models/seriesConfig/extremumGetter.types.js +5 -0
- package/node/internals/plugins/models/seriesConfig/index.js +49 -0
- package/node/internals/plugins/models/seriesConfig/seriesConfig.types.js +5 -0
- package/node/internals/plugins/models/seriesConfig/seriesProcessor.types.js +5 -0
- package/node/internals/store/extractPluginParamsFromProps.js +36 -0
- package/node/internals/store/useChartModels.js +73 -0
- package/node/internals/store/useCharts.js +14 -9
- package/node/internals/store/useStore.js +1 -9
- package/package.json +4 -4
- package/ChartsLegend/ChartsLegendItem.d.ts +0 -26
- package/ChartsLegend/ChartsLegendItem.js +0 -65
- package/ChartsLegend/DefaultChartsLegend.d.ts +0 -25
- package/ChartsLegend/DefaultChartsLegend.js +0 -112
- package/ChartsLegend/LegendPerItem.d.ts +0 -65
- package/ChartsLegend/LegendPerItem.js +0 -129
- package/ChartsLegend/legendItemsPlacement.d.ts +0 -3
- package/ChartsLegend/legendItemsPlacement.js +0 -72
- package/ChartsLegend/utils.d.ts +0 -2
- package/context/CartesianProvider/Cartesian.types.d.ts +0 -59
- package/context/CartesianProvider/CartesianContext.d.ts +0 -4
- package/context/CartesianProvider/CartesianContext.js +0 -13
- package/context/CartesianProvider/CartesianProvider.d.ts +0 -4
- package/context/CartesianProvider/CartesianProvider.js +0 -49
- package/context/CartesianProvider/defaultizeAxis.d.ts +0 -38
- package/context/CartesianProvider/defaultizeAxis.js +0 -13
- package/context/CartesianProvider/getAxisExtremum.d.ts +0 -5
- package/context/CartesianProvider/getAxisExtremum.js +0 -21
- package/context/CartesianProvider/index.d.ts +0 -4
- package/context/CartesianProvider/index.js +0 -4
- package/context/CartesianProvider/useCartesianContext.d.ts +0 -2
- package/context/CartesianProvider/useCartesianContext.js +0 -10
- package/context/ChartDataProvider/useDefaultizeAxis.d.ts +0 -39
- package/context/DrawingAreaProvider/DrawingArea.types.d.ts +0 -51
- package/context/DrawingAreaProvider/DrawingAreaContext.d.ts +0 -3
- package/context/DrawingAreaProvider/DrawingAreaContext.js +0 -15
- package/context/DrawingAreaProvider/DrawingAreaProvider.d.ts +0 -3
- package/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -48
- package/context/DrawingAreaProvider/index.d.ts +0 -3
- package/context/DrawingAreaProvider/index.js +0 -3
- package/context/PluginProvider/ColorProcessor.types.d.ts +0 -8
- package/context/PluginProvider/ExtremumGetter.types.d.ts +0 -25
- package/context/PluginProvider/Plugin.types.d.ts +0 -29
- package/context/PluginProvider/PluginContext.d.ts +0 -4
- package/context/PluginProvider/PluginContext.js +0 -15
- package/context/PluginProvider/PluginProvider.d.ts +0 -4
- package/context/PluginProvider/PluginProvider.js +0 -21
- package/context/PluginProvider/SeriesFormatter.types.d.ts +0 -21
- package/context/PluginProvider/index.d.ts +0 -12
- package/context/PluginProvider/index.js +0 -12
- package/context/PluginProvider/mergePlugins.d.ts +0 -46
- package/context/PluginProvider/mergePlugins.js +0 -40
- package/context/PluginProvider/useColorProcessor.d.ts +0 -4
- package/context/PluginProvider/useColorProcessor.js +0 -17
- package/context/PluginProvider/useRadiusExtremumGetter.d.ts +0 -4
- package/context/PluginProvider/useRadiusExtremumGetter.js +0 -17
- package/context/PluginProvider/useRotationExtremumGetter.d.ts +0 -4
- package/context/PluginProvider/useRotationExtremumGetter.js +0 -17
- package/context/PluginProvider/useSeriesFormatter.d.ts +0 -4
- package/context/PluginProvider/useSeriesFormatter.js +0 -17
- package/context/PluginProvider/useXExtremumGetter.d.ts +0 -4
- package/context/PluginProvider/useXExtremumGetter.js +0 -15
- package/context/PluginProvider/useYExtremumGetter.d.ts +0 -4
- package/context/PluginProvider/useYExtremumGetter.js +0 -15
- package/context/SeriesProvider/Series.types.d.ts +0 -26
- package/context/SeriesProvider/SeriesContext.d.ts +0 -4
- package/context/SeriesProvider/SeriesContext.js +0 -8
- package/context/SeriesProvider/SeriesProvider.d.ts +0 -5
- package/context/SeriesProvider/SeriesProvider.js +0 -33
- package/context/SeriesProvider/index.d.ts +0 -12
- package/context/SeriesProvider/index.js +0 -8
- package/context/SeriesProvider/processSeries.d.ts +0 -18
- package/context/SizeProvider/Size.types.d.ts +0 -30
- package/context/SizeProvider/SizeContext.d.ts +0 -4
- package/context/SizeProvider/SizeContext.js +0 -15
- package/context/SizeProvider/SizeProvider.d.ts +0 -11
- package/context/SizeProvider/SizeProvider.js +0 -26
- package/context/SizeProvider/index.d.ts +0 -4
- package/context/SizeProvider/index.js +0 -4
- package/context/SizeProvider/useChartContainerDimensions.d.ts +0 -9
- package/context/SizeProvider/useChartContainerDimensions.js +0 -108
- package/context/SizeProvider/useSize.d.ts +0 -5
- package/context/SizeProvider/useSize.js +0 -13
- package/context/ZAxisContextProvider.d.ts +0 -33
- package/context/ZAxisContextProvider.js +0 -96
- package/internals/computeAxisValue.d.ts +0 -38
- package/modern/ChartsLegend/ChartsLegendItem.js +0 -65
- package/modern/ChartsLegend/DefaultChartsLegend.js +0 -112
- package/modern/ChartsLegend/LegendPerItem.js +0 -129
- package/modern/ChartsLegend/legendItemsPlacement.js +0 -72
- package/modern/context/CartesianProvider/CartesianContext.js +0 -13
- package/modern/context/CartesianProvider/CartesianProvider.js +0 -49
- package/modern/context/CartesianProvider/defaultizeAxis.js +0 -13
- package/modern/context/CartesianProvider/getAxisExtremum.js +0 -21
- package/modern/context/CartesianProvider/index.js +0 -4
- package/modern/context/CartesianProvider/useCartesianContext.js +0 -10
- package/modern/context/DrawingAreaProvider/DrawingAreaContext.js +0 -15
- package/modern/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -48
- package/modern/context/DrawingAreaProvider/index.js +0 -3
- package/modern/context/PluginProvider/PluginContext.js +0 -15
- package/modern/context/PluginProvider/PluginProvider.js +0 -21
- package/modern/context/PluginProvider/index.js +0 -12
- package/modern/context/PluginProvider/mergePlugins.js +0 -40
- package/modern/context/PluginProvider/useColorProcessor.js +0 -17
- package/modern/context/PluginProvider/useRadiusExtremumGetter.js +0 -17
- package/modern/context/PluginProvider/useRotationExtremumGetter.js +0 -17
- package/modern/context/PluginProvider/useSeriesFormatter.js +0 -17
- package/modern/context/PluginProvider/useXExtremumGetter.js +0 -15
- package/modern/context/PluginProvider/useYExtremumGetter.js +0 -15
- package/modern/context/SeriesProvider/SeriesContext.js +0 -8
- package/modern/context/SeriesProvider/SeriesProvider.js +0 -33
- package/modern/context/SeriesProvider/index.js +0 -8
- package/modern/context/SizeProvider/SizeContext.js +0 -15
- package/modern/context/SizeProvider/SizeProvider.js +0 -26
- package/modern/context/SizeProvider/index.js +0 -4
- package/modern/context/SizeProvider/useChartContainerDimensions.js +0 -108
- package/modern/context/SizeProvider/useSize.js +0 -13
- package/modern/context/ZAxisContextProvider.js +0 -96
- package/node/ChartsLegend/ChartsLegendItem.js +0 -72
- package/node/ChartsLegend/DefaultChartsLegend.js +0 -118
- package/node/ChartsLegend/LegendPerItem.js +0 -137
- package/node/ChartsLegend/legendItemsPlacement.js +0 -79
- package/node/context/CartesianProvider/CartesianContext.js +0 -20
- package/node/context/CartesianProvider/CartesianProvider.js +0 -54
- package/node/context/CartesianProvider/defaultizeAxis.js +0 -21
- package/node/context/CartesianProvider/getAxisExtremum.js +0 -28
- package/node/context/CartesianProvider/index.js +0 -49
- package/node/context/CartesianProvider/useCartesianContext.js +0 -17
- package/node/context/DrawingAreaProvider/DrawingAreaContext.js +0 -21
- package/node/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -55
- package/node/context/DrawingAreaProvider/index.js +0 -38
- package/node/context/PluginProvider/PluginContext.js +0 -22
- package/node/context/PluginProvider/PluginProvider.js +0 -26
- package/node/context/PluginProvider/index.js +0 -137
- package/node/context/PluginProvider/mergePlugins.js +0 -47
- package/node/context/PluginProvider/useColorProcessor.js +0 -23
- package/node/context/PluginProvider/useRadiusExtremumGetter.js +0 -23
- package/node/context/PluginProvider/useRotationExtremumGetter.js +0 -23
- package/node/context/PluginProvider/useSeriesFormatter.js +0 -23
- package/node/context/PluginProvider/useXExtremumGetter.js +0 -22
- package/node/context/PluginProvider/useYExtremumGetter.js +0 -22
- package/node/context/SeriesProvider/SeriesContext.js +0 -15
- package/node/context/SeriesProvider/SeriesProvider.js +0 -38
- package/node/context/SeriesProvider/index.js +0 -49
- package/node/context/SizeProvider/SizeContext.js +0 -22
- package/node/context/SizeProvider/SizeProvider.js +0 -29
- package/node/context/SizeProvider/index.js +0 -49
- package/node/context/SizeProvider/useChartContainerDimensions.js +0 -116
- package/node/context/SizeProvider/useSize.js +0 -20
- package/node/context/ZAxisContextProvider.js +0 -103
- /package/{context/CartesianProvider/Cartesian.types.js → ChartsLegend/colorLegend.types.js} +0 -0
- /package/{context/DrawingAreaProvider/DrawingArea.types.js → ChartsLegend/direction.js} +0 -0
- /package/{context/PluginProvider/ColorProcessor.types.js → ChartsLegend/legendContext.types.js} +0 -0
- /package/{context/PluginProvider/ExtremumGetter.types.js → ChartsLegend/piecewiseColorLegend.types.js} +0 -0
- /package/{context/PluginProvider/Plugin.types.js → internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js} +0 -0
- /package/{context/PluginProvider/SeriesFormatter.types.js → internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js} +0 -0
- /package/{context/SeriesProvider/Series.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js} +0 -0
- /package/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.d.ts +0 -0
- /package/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
- /package/{context/SizeProvider/Size.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js} +0 -0
- /package/{modern/context/CartesianProvider/Cartesian.types.js → internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js} +0 -0
- /package/{modern/context/DrawingAreaProvider/DrawingArea.types.js → internals/plugins/models/seriesConfig/colorProcessor.types.js} +0 -0
- /package/{modern/context/PluginProvider/ColorProcessor.types.js → internals/plugins/models/seriesConfig/extremumGetter.types.js} +0 -0
- /package/{modern/context/PluginProvider/ExtremumGetter.types.js → internals/plugins/models/seriesConfig/seriesConfig.types.js} +0 -0
- /package/{modern/context/PluginProvider/Plugin.types.js → internals/plugins/models/seriesConfig/seriesProcessor.types.js} +0 -0
- /package/modern/{context/PluginProvider/SeriesFormatter.types.js → ChartsLegend/colorLegend.types.js} +0 -0
- /package/modern/{context/SeriesProvider/Series.types.js → ChartsLegend/direction.js} +0 -0
- /package/modern/{context/SizeProvider/Size.types.js → ChartsLegend/legendContext.types.js} +0 -0
- /package/modern/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
- /package/node/{context/CartesianProvider/Cartesian.types.js → ChartsLegend/colorLegend.types.js} +0 -0
- /package/node/{context/DrawingAreaProvider/DrawingArea.types.js → ChartsLegend/direction.js} +0 -0
- /package/node/{context/PluginProvider/ColorProcessor.types.js → ChartsLegend/legendContext.types.js} +0 -0
- /package/node/{context/PluginProvider/ExtremumGetter.types.js → ChartsLegend/piecewiseColorLegend.types.js} +0 -0
- /package/node/{context/PluginProvider/Plugin.types.js → internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js} +0 -0
- /package/node/{context/PluginProvider/SeriesFormatter.types.js → internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js} +0 -0
- /package/node/{context/SeriesProvider/Series.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js} +0 -0
- /package/node/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
- /package/node/{context/SizeProvider/Size.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js} +0 -0
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* A higher order component that consumes a slot from the props and renders the component provided in the slot.
|
|
4
|
+
*
|
|
5
|
+
* This HOC will wrap a single component, and will render the component provided in the slot, if it exists.
|
|
6
|
+
*
|
|
7
|
+
* If you need to render multiple components, you can manually consume the slots from the props and render them in your component instead of using this HOC.
|
|
8
|
+
*
|
|
9
|
+
* In the example below, `MyComponent` will render the component provided in `mySlot` slot, if it exists. Otherwise, it will render the `DefaultComponent`.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
*
|
|
13
|
+
* ```tsx
|
|
14
|
+
* type MyComponentProps = {
|
|
15
|
+
* direction: 'row' | 'column';
|
|
16
|
+
* slots?: {
|
|
17
|
+
* mySlot?: React.JSXElementConstructor<{ direction: 'row' | 'column' }>;
|
|
18
|
+
* }
|
|
19
|
+
* };
|
|
20
|
+
*
|
|
21
|
+
* const MyComponent = consumeSlots(
|
|
22
|
+
* 'MuiMyComponent',
|
|
23
|
+
* 'mySlot',
|
|
24
|
+
* function DefaultComponent(props: MyComponentProps) {
|
|
25
|
+
* return (
|
|
26
|
+
* <div className={props.classes.root}>
|
|
27
|
+
* {props.direction}
|
|
28
|
+
* </div>
|
|
29
|
+
* );
|
|
30
|
+
* }
|
|
31
|
+
* );
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
* @param {string} name The mui component name.
|
|
35
|
+
* @param {string} slotPropName The name of the prop to retrieve the slot from.
|
|
36
|
+
* @param {object} options Options for the HOC.
|
|
37
|
+
* @param {boolean} options.propagateSlots Whether to propagate the slots to the component, this is always false if the slot is provided.
|
|
38
|
+
* @param {Record<string, any>} options.defaultProps A set of defaults for the component, will be deep merged with the props.
|
|
39
|
+
* @param {Array<keyof Props>} options.omitProps An array of props to omit from the component.
|
|
40
|
+
* @param {Function} options.classesResolver A function that returns the classes for the component. It receives the props, after theme props and defaults have been applied. And the theme object as the second argument.
|
|
41
|
+
* @param InComponent The component to render if the slot is not provided.
|
|
42
|
+
*/
|
|
43
|
+
export declare const consumeSlots: <Props extends {}, Ref extends {}, RenderFunction = (props: Props, ref: React.Ref<Ref>) => React.ElementType>(name: string, slotPropName: string, options: {
|
|
44
|
+
propagateSlots?: boolean;
|
|
45
|
+
defaultProps?: Omit<Partial<Props>, "slots" | "slotProps"> | ((props: Props) => Omit<Partial<Props>, "slots" | "slotProps">);
|
|
46
|
+
omitProps?: Array<keyof Props>;
|
|
47
|
+
classesResolver?: (props: Props, theme: any) => Record<string, string>;
|
|
48
|
+
}, InComponent: RenderFunction) => React.ForwardRefExoticComponent<React.PropsWithoutRef<Props> & React.RefAttributes<Ref>>;
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
3
|
+
const _excluded = ["slots", "slotProps"],
|
|
4
|
+
_excluded2 = ["ownerState"];
|
|
5
|
+
import { useTheme, useThemeProps } from '@mui/material/styles';
|
|
6
|
+
import resolveProps from '@mui/utils/resolveProps';
|
|
7
|
+
import useSlotProps from '@mui/utils/useSlotProps';
|
|
8
|
+
import * as React from 'react';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* A higher order component that consumes a slot from the props and renders the component provided in the slot.
|
|
12
|
+
*
|
|
13
|
+
* This HOC will wrap a single component, and will render the component provided in the slot, if it exists.
|
|
14
|
+
*
|
|
15
|
+
* If you need to render multiple components, you can manually consume the slots from the props and render them in your component instead of using this HOC.
|
|
16
|
+
*
|
|
17
|
+
* In the example below, `MyComponent` will render the component provided in `mySlot` slot, if it exists. Otherwise, it will render the `DefaultComponent`.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
*
|
|
21
|
+
* ```tsx
|
|
22
|
+
* type MyComponentProps = {
|
|
23
|
+
* direction: 'row' | 'column';
|
|
24
|
+
* slots?: {
|
|
25
|
+
* mySlot?: React.JSXElementConstructor<{ direction: 'row' | 'column' }>;
|
|
26
|
+
* }
|
|
27
|
+
* };
|
|
28
|
+
*
|
|
29
|
+
* const MyComponent = consumeSlots(
|
|
30
|
+
* 'MuiMyComponent',
|
|
31
|
+
* 'mySlot',
|
|
32
|
+
* function DefaultComponent(props: MyComponentProps) {
|
|
33
|
+
* return (
|
|
34
|
+
* <div className={props.classes.root}>
|
|
35
|
+
* {props.direction}
|
|
36
|
+
* </div>
|
|
37
|
+
* );
|
|
38
|
+
* }
|
|
39
|
+
* );
|
|
40
|
+
* ```
|
|
41
|
+
*
|
|
42
|
+
* @param {string} name The mui component name.
|
|
43
|
+
* @param {string} slotPropName The name of the prop to retrieve the slot from.
|
|
44
|
+
* @param {object} options Options for the HOC.
|
|
45
|
+
* @param {boolean} options.propagateSlots Whether to propagate the slots to the component, this is always false if the slot is provided.
|
|
46
|
+
* @param {Record<string, any>} options.defaultProps A set of defaults for the component, will be deep merged with the props.
|
|
47
|
+
* @param {Array<keyof Props>} options.omitProps An array of props to omit from the component.
|
|
48
|
+
* @param {Function} options.classesResolver A function that returns the classes for the component. It receives the props, after theme props and defaults have been applied. And the theme object as the second argument.
|
|
49
|
+
* @param InComponent The component to render if the slot is not provided.
|
|
50
|
+
*/
|
|
51
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
52
|
+
export const consumeSlots = (name, slotPropName, options, InComponent) => {
|
|
53
|
+
function ConsumeSlotsInternal(props, ref) {
|
|
54
|
+
const themedProps = useThemeProps({
|
|
55
|
+
props,
|
|
56
|
+
// eslint-disable-next-line material-ui/mui-name-matches-component-name
|
|
57
|
+
name
|
|
58
|
+
});
|
|
59
|
+
const defaultProps = typeof options.defaultProps === 'function' ? options.defaultProps(themedProps) : options.defaultProps ?? {};
|
|
60
|
+
const defaultizedProps = resolveProps(defaultProps, themedProps);
|
|
61
|
+
const _ref = defaultizedProps,
|
|
62
|
+
{
|
|
63
|
+
slots,
|
|
64
|
+
slotProps
|
|
65
|
+
} = _ref,
|
|
66
|
+
other = _objectWithoutPropertiesLoose(_ref, _excluded);
|
|
67
|
+
const theme = useTheme();
|
|
68
|
+
const classes = options.classesResolver?.(defaultizedProps, theme);
|
|
69
|
+
|
|
70
|
+
// Can be a function component or a forward ref component.
|
|
71
|
+
const Component = slots?.[slotPropName] ?? InComponent;
|
|
72
|
+
const propagateSlots = options.propagateSlots && !slots?.[slotPropName];
|
|
73
|
+
const _useSlotProps = useSlotProps({
|
|
74
|
+
elementType: Component,
|
|
75
|
+
externalSlotProps: slotProps?.[slotPropName],
|
|
76
|
+
additionalProps: _extends({}, other, {
|
|
77
|
+
classes
|
|
78
|
+
}, propagateSlots && {
|
|
79
|
+
slots,
|
|
80
|
+
slotProps
|
|
81
|
+
}),
|
|
82
|
+
ownerState: {}
|
|
83
|
+
}),
|
|
84
|
+
originalOutProps = _objectWithoutPropertiesLoose(_useSlotProps, _excluded2);
|
|
85
|
+
const outProps = _extends({}, originalOutProps);
|
|
86
|
+
for (const prop of options.omitProps ?? []) {
|
|
87
|
+
delete outProps[prop];
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
// Component can be wrapped in React.forwardRef or just a function that accepts (props, ref).
|
|
91
|
+
// If it is a plain function which accepts two arguments, we need to wrap it in React.forwardRef.
|
|
92
|
+
const OutComponent = Component.length >= 2 ? /*#__PURE__*/React.forwardRef(Component) : Component;
|
|
93
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
94
|
+
OutComponent.displayName = `${name}.slots.${slotPropName}`;
|
|
95
|
+
}
|
|
96
|
+
return /*#__PURE__*/_jsx(OutComponent, _extends({}, outProps, {
|
|
97
|
+
ref: ref
|
|
98
|
+
}));
|
|
99
|
+
}
|
|
100
|
+
return /*#__PURE__*/React.forwardRef(ConsumeSlotsInternal);
|
|
101
|
+
};
|
|
@@ -44,11 +44,7 @@ import * as React from 'react';
|
|
|
44
44
|
* @param {Function} options.classesResolver A function that returns the classes for the component. It receives the props, after theme props and defaults have been applied. And the theme object as the second argument.
|
|
45
45
|
* @param InComponent The component to render if the slot is not provided.
|
|
46
46
|
*/
|
|
47
|
-
export declare const consumeThemeProps: <Props extends {
|
|
48
|
-
|
|
49
|
-
slotProps?: Record<string, any>;
|
|
50
|
-
classes?: Record<string, any>;
|
|
51
|
-
}>(name: string, options: {
|
|
52
|
-
defaultProps?: Omit<Partial<Props>, "slots" | "slotProps"> | ((props: Props) => Omit<Partial<Props>, "slots" | "slotProps">);
|
|
47
|
+
export declare const consumeThemeProps: <Props extends {}, Ref extends {}, RenderFunction = (props: Props, ref: React.Ref<Ref>) => React.ElementType>(name: string, options: {
|
|
48
|
+
defaultProps?: Omit<Partial<Props>, "slots" | "slotProps"> | (<T extends Props>(props: T) => Omit<Partial<T>, "slots" | "slotProps">);
|
|
53
49
|
classesResolver?: (props: Props, theme: any) => Record<string, string>;
|
|
54
|
-
}, InComponent:
|
|
50
|
+
}, InComponent: RenderFunction) => React.ForwardRefExoticComponent<React.PropsWithoutRef<Props> & React.RefAttributes<Ref>>;
|
|
@@ -2,7 +2,6 @@ import _extends from "@babel/runtime/helpers/esm/extends";
|
|
|
2
2
|
import { useTheme, useThemeProps } from '@mui/material/styles';
|
|
3
3
|
import resolveProps from '@mui/utils/resolveProps';
|
|
4
4
|
import * as React from 'react';
|
|
5
|
-
import * as ReactIs from 'react-is';
|
|
6
5
|
|
|
7
6
|
/**
|
|
8
7
|
* A higher order component that consumes and merges the theme `defaultProps` and handles the `classes` and renders the component.
|
|
@@ -50,30 +49,22 @@ import * as ReactIs from 'react-is';
|
|
|
50
49
|
* @param InComponent The component to render if the slot is not provided.
|
|
51
50
|
*/
|
|
52
51
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
53
|
-
export const consumeThemeProps = (name, options, InComponent) => {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
InComponent.displayName = name;
|
|
67
|
-
}
|
|
68
|
-
const OutComponent = ReactIs.isForwardRef(InComponent) ? InComponent :
|
|
69
|
-
/*#__PURE__*/
|
|
70
|
-
// InComponent needs to be a function that accepts `(props, ref)`
|
|
71
|
-
// @ts-expect-error
|
|
72
|
-
React.forwardRef(InComponent);
|
|
73
|
-
return /*#__PURE__*/_jsx(OutComponent, _extends({}, outProps, {
|
|
74
|
-
classes: classes,
|
|
75
|
-
ref: ref
|
|
76
|
-
}));
|
|
52
|
+
export const consumeThemeProps = (name, options, InComponent) => /*#__PURE__*/React.forwardRef(function ConsumeThemeInternal(props, ref) {
|
|
53
|
+
const themedProps = useThemeProps({
|
|
54
|
+
props,
|
|
55
|
+
// eslint-disable-next-line material-ui/mui-name-matches-component-name
|
|
56
|
+
name
|
|
57
|
+
});
|
|
58
|
+
const defaultProps = typeof options.defaultProps === 'function' ? options.defaultProps(themedProps) : options.defaultProps ?? {};
|
|
59
|
+
const outProps = resolveProps(defaultProps, themedProps);
|
|
60
|
+
const theme = useTheme();
|
|
61
|
+
const classes = options.classesResolver?.(outProps, theme);
|
|
62
|
+
const OutComponent = /*#__PURE__*/React.forwardRef(InComponent);
|
|
63
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
64
|
+
OutComponent.displayName = `consumeThemeProps(${name})`;
|
|
77
65
|
}
|
|
78
|
-
return /*#__PURE__*/
|
|
79
|
-
|
|
66
|
+
return /*#__PURE__*/_jsx(OutComponent, _extends({}, outProps, {
|
|
67
|
+
classes: classes,
|
|
68
|
+
ref: ref
|
|
69
|
+
}));
|
|
70
|
+
});
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { AllSeriesType } from '../models/seriesType';
|
|
2
2
|
export declare function defaultizeColor(series: AllSeriesType, seriesIndex: number, colors?: string[]): {
|
|
3
3
|
data: {
|
|
4
|
-
color: string;
|
|
5
4
|
label?: string | ((location: "tooltip" | "legend" | "arc") => string) | undefined;
|
|
5
|
+
color: string;
|
|
6
6
|
value: number;
|
|
7
|
+
labelMarkType?: "line" | "square" | "circle" | undefined;
|
|
7
8
|
id?: import("..").PieItemId | undefined;
|
|
8
9
|
}[];
|
|
9
10
|
type: "pie";
|
|
@@ -43,6 +44,28 @@ export declare function defaultizeColor(series: AllSeriesType, seriesIndex: numb
|
|
|
43
44
|
color?: string;
|
|
44
45
|
valueFormatter?: import(".").SeriesValueFormatter<import("@mui/x-internals/types").MakeOptional<import("..").PieValueType, "id">> | undefined;
|
|
45
46
|
highlightScope?: Partial<import("..").HighlightScope>;
|
|
47
|
+
labelMarkType?: import("..").ChartsLabelMarkProps["type"];
|
|
48
|
+
} | {
|
|
49
|
+
type: "line";
|
|
50
|
+
data?: (number | null)[];
|
|
51
|
+
dataKey?: string;
|
|
52
|
+
stack?: string;
|
|
53
|
+
area?: boolean;
|
|
54
|
+
label?: string | ((location: "tooltip" | "legend") => string);
|
|
55
|
+
curve?: import("..").CurveType;
|
|
56
|
+
showMark?: boolean | ((params: import("..").ShowMarkParams) => boolean);
|
|
57
|
+
disableHighlight?: boolean;
|
|
58
|
+
connectNulls?: boolean;
|
|
59
|
+
stackOffset?: import("..").StackOffsetType;
|
|
60
|
+
baseline?: number | "min" | "max";
|
|
61
|
+
id?: import(".").SeriesId;
|
|
62
|
+
color: string;
|
|
63
|
+
valueFormatter?: import(".").SeriesValueFormatter<number | null> | undefined;
|
|
64
|
+
highlightScope?: Partial<import("..").HighlightScope>;
|
|
65
|
+
labelMarkType?: import("..").ChartsLabelMarkProps["type"];
|
|
66
|
+
xAxisId?: string;
|
|
67
|
+
yAxisId?: string;
|
|
68
|
+
stackOrder?: import("..").StackOrderType;
|
|
46
69
|
} | {
|
|
47
70
|
type: "bar";
|
|
48
71
|
data?: (number | null)[];
|
|
@@ -54,6 +77,7 @@ export declare function defaultizeColor(series: AllSeriesType, seriesIndex: numb
|
|
|
54
77
|
color: string;
|
|
55
78
|
valueFormatter?: import(".").SeriesValueFormatter<number | null> | undefined;
|
|
56
79
|
highlightScope?: Partial<import("..").HighlightScope>;
|
|
80
|
+
labelMarkType?: import("..").ChartsLabelMarkProps["type"];
|
|
57
81
|
xAxisId?: string;
|
|
58
82
|
yAxisId?: string;
|
|
59
83
|
stack?: string;
|
|
@@ -75,26 +99,7 @@ export declare function defaultizeColor(series: AllSeriesType, seriesIndex: numb
|
|
|
75
99
|
color: string;
|
|
76
100
|
valueFormatter?: import(".").SeriesValueFormatter<import("..").ScatterValueType | null> | undefined;
|
|
77
101
|
highlightScope?: Partial<import("..").HighlightScope>;
|
|
102
|
+
labelMarkType?: import("..").ChartsLabelMarkProps["type"];
|
|
78
103
|
xAxisId?: string;
|
|
79
104
|
yAxisId?: string;
|
|
80
|
-
} | {
|
|
81
|
-
type: "line";
|
|
82
|
-
data?: (number | null)[];
|
|
83
|
-
dataKey?: string;
|
|
84
|
-
stack?: string;
|
|
85
|
-
area?: boolean;
|
|
86
|
-
label?: string | ((location: "tooltip" | "legend") => string);
|
|
87
|
-
curve?: import("..").CurveType;
|
|
88
|
-
showMark?: boolean | ((params: import("..").ShowMarkParams) => boolean);
|
|
89
|
-
disableHighlight?: boolean;
|
|
90
|
-
connectNulls?: boolean;
|
|
91
|
-
stackOffset?: import("..").StackOffsetType;
|
|
92
|
-
baseline?: number | "min" | "max";
|
|
93
|
-
id?: import(".").SeriesId;
|
|
94
|
-
color: string;
|
|
95
|
-
valueFormatter?: import(".").SeriesValueFormatter<number | null> | undefined;
|
|
96
|
-
highlightScope?: Partial<import("..").HighlightScope>;
|
|
97
|
-
xAxisId?: string;
|
|
98
|
-
yAxisId?: string;
|
|
99
|
-
stackOrder?: import("..").StackOrderType;
|
|
100
105
|
};
|
package/internals/index.d.ts
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
export * from './components/ChartsAxesGradients';
|
|
2
|
+
export * from './components/ChartsWrapper';
|
|
3
|
+
export * from '../ChartsLabel/ChartsLabelMark';
|
|
2
4
|
export { useSeries } from '../hooks/useSeries';
|
|
3
5
|
export { useInteractionItemProps } from '../hooks/useInteractionItemProps';
|
|
4
6
|
export { useDrawingArea } from '../hooks/useDrawingArea';
|
|
@@ -7,6 +9,16 @@ export { useLineChartProps } from '../LineChart/useLineChartProps';
|
|
|
7
9
|
export { useBarChartProps } from '../BarChart/useBarChartProps';
|
|
8
10
|
export * from '../ChartContainer/useChartContainerProps';
|
|
9
11
|
export * from '../context/ChartDataProvider/useChartDataProviderProps';
|
|
12
|
+
export * from './plugins/corePlugins/useChartId';
|
|
13
|
+
export * from './plugins/corePlugins/useChartSeries';
|
|
14
|
+
export * from './plugins/corePlugins/useChartDimensions';
|
|
15
|
+
export * from './plugins/featurePlugins/useChartZAxis';
|
|
16
|
+
export * from './plugins/featurePlugins/useChartCartesianAxis';
|
|
17
|
+
export * from './plugins/featurePlugins/useChartInteraction';
|
|
18
|
+
export * from './plugins/utils/selectors';
|
|
19
|
+
export * from './store/useCharts';
|
|
20
|
+
export * from './store/useStore';
|
|
21
|
+
export * from './store/useSelector';
|
|
10
22
|
export * from './defaultizeValueFormatter';
|
|
11
23
|
export * from './configInit';
|
|
12
24
|
export * from './getLabel';
|
|
@@ -14,19 +26,13 @@ export * from './getSVGPoint';
|
|
|
14
26
|
export * from './isDefined';
|
|
15
27
|
export { unstable_cleanupDOM } from './domUtils';
|
|
16
28
|
export * from './getScale';
|
|
17
|
-
export * from './computeAxisValue';
|
|
18
|
-
export * from '../context/CartesianProvider';
|
|
19
|
-
export * from '../context/DrawingAreaProvider';
|
|
20
|
-
export * from '../context/SeriesProvider';
|
|
21
|
-
export * from '../context/ZAxisContextProvider';
|
|
22
|
-
export * from '../context/PluginProvider';
|
|
23
29
|
export * from '../context/AnimationProvider';
|
|
24
30
|
export type * from '../context/context.types';
|
|
25
|
-
export { getAxisExtremum } from '
|
|
31
|
+
export { getAxisExtremum } from './plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum';
|
|
26
32
|
export * from '../context/ChartDataProvider';
|
|
27
|
-
export * from '../context/SizeProvider';
|
|
28
33
|
export * from '../context/ChartProvider';
|
|
29
34
|
export * from '../models/seriesType/config';
|
|
30
35
|
export * from '../models/seriesType/common';
|
|
31
36
|
export * from '../models/z-axis';
|
|
32
37
|
export * from '../models/axis';
|
|
38
|
+
export * from './plugins/models';
|
package/internals/index.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
// Components
|
|
2
2
|
export * from "./components/ChartsAxesGradients/index.js";
|
|
3
|
+
export * from "./components/ChartsWrapper/index.js";
|
|
4
|
+
export * from "../ChartsLabel/ChartsLabelMark.js";
|
|
3
5
|
|
|
4
6
|
// hooks
|
|
5
7
|
export { useSeries } from "../hooks/useSeries.js";
|
|
@@ -11,6 +13,18 @@ export { useBarChartProps } from "../BarChart/useBarChartProps.js";
|
|
|
11
13
|
export * from "../ChartContainer/useChartContainerProps.js";
|
|
12
14
|
export * from "../context/ChartDataProvider/useChartDataProviderProps.js";
|
|
13
15
|
|
|
16
|
+
// plugins
|
|
17
|
+
export * from "./plugins/corePlugins/useChartId/index.js";
|
|
18
|
+
export * from "./plugins/corePlugins/useChartSeries/index.js";
|
|
19
|
+
export * from "./plugins/corePlugins/useChartDimensions/index.js";
|
|
20
|
+
export * from "./plugins/featurePlugins/useChartZAxis/index.js";
|
|
21
|
+
export * from "./plugins/featurePlugins/useChartCartesianAxis/index.js";
|
|
22
|
+
export * from "./plugins/featurePlugins/useChartInteraction/index.js";
|
|
23
|
+
export * from "./plugins/utils/selectors.js";
|
|
24
|
+
export * from "./store/useCharts.js";
|
|
25
|
+
export * from "./store/useStore.js";
|
|
26
|
+
export * from "./store/useSelector.js";
|
|
27
|
+
|
|
14
28
|
// utils
|
|
15
29
|
export * from "./defaultizeValueFormatter.js";
|
|
16
30
|
export * from "./configInit.js";
|
|
@@ -19,23 +33,17 @@ export * from "./getSVGPoint.js";
|
|
|
19
33
|
export * from "./isDefined.js";
|
|
20
34
|
export { unstable_cleanupDOM } from "./domUtils.js";
|
|
21
35
|
export * from "./getScale.js";
|
|
22
|
-
export * from "./computeAxisValue.js";
|
|
23
36
|
|
|
24
37
|
// contexts
|
|
25
38
|
|
|
26
|
-
export * from "../context/CartesianProvider/index.js";
|
|
27
|
-
export * from "../context/DrawingAreaProvider/index.js";
|
|
28
|
-
export * from "../context/SeriesProvider/index.js";
|
|
29
|
-
export * from "../context/ZAxisContextProvider.js";
|
|
30
|
-
export * from "../context/PluginProvider/index.js";
|
|
31
39
|
export * from "../context/AnimationProvider/index.js";
|
|
32
|
-
export { getAxisExtremum } from "
|
|
40
|
+
export { getAxisExtremum } from "./plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js";
|
|
33
41
|
export * from "../context/ChartDataProvider/index.js";
|
|
34
|
-
export * from "../context/SizeProvider/index.js";
|
|
35
42
|
export * from "../context/ChartProvider/index.js";
|
|
36
43
|
|
|
37
44
|
// series configuration
|
|
38
45
|
export * from "../models/seriesType/config.js";
|
|
39
46
|
export * from "../models/seriesType/common.js";
|
|
40
47
|
export * from "../models/z-axis.js";
|
|
41
|
-
export * from "../models/axis.js";
|
|
48
|
+
export * from "../models/axis.js";
|
|
49
|
+
export * from "./plugins/models/index.js";
|
|
@@ -1 +1,12 @@
|
|
|
1
|
-
|
|
1
|
+
import { ChartSeriesType } from '../../models/seriesType/config';
|
|
2
|
+
import { UseChartCartesianAxisSignature } from './featurePlugins/useChartCartesianAxis';
|
|
3
|
+
import { UseChartInteractionSignature } from './featurePlugins/useChartInteraction';
|
|
4
|
+
import { UseChartZAxisSignature } from './featurePlugins/useChartZAxis';
|
|
5
|
+
import { ConvertSignaturesIntoPlugins } from './models/helpers';
|
|
6
|
+
export type AllPluginSignatures<TSeries extends ChartSeriesType = ChartSeriesType> = [
|
|
7
|
+
UseChartZAxisSignature,
|
|
8
|
+
UseChartCartesianAxisSignature<TSeries>,
|
|
9
|
+
UseChartInteractionSignature
|
|
10
|
+
];
|
|
11
|
+
export type AllPluginsType<TSeries extends ChartSeriesType = ChartSeriesType> = ConvertSignaturesIntoPlugins<AllPluginSignatures<TSeries>>;
|
|
12
|
+
export declare const ALL_PLUGINS: (import("./models").ChartPlugin<UseChartZAxisSignature> | import("./models").ChartPlugin<UseChartCartesianAxisSignature<keyof import("..").ChartsSeriesConfig>> | import("./models").ChartPlugin<UseChartInteractionSignature>)[];
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
-
// This file should be removed after creating all plugins
|
|
1
|
+
// This file should be removed after creating all plugins in favor of a file per chart type.
|
|
2
|
+
|
|
3
|
+
import { useChartCartesianAxis } from "./featurePlugins/useChartCartesianAxis/index.js";
|
|
2
4
|
import { useChartInteraction } from "./featurePlugins/useChartInteraction/index.js";
|
|
3
|
-
|
|
5
|
+
import { useChartZAxis } from "./featurePlugins/useChartZAxis/index.js";
|
|
6
|
+
export const ALL_PLUGINS = [useChartZAxis, useChartCartesianAxis, useChartInteraction];
|
|
@@ -4,7 +4,7 @@ import { UseChartIdParameters } from './useChartId';
|
|
|
4
4
|
* Internal plugins that create the tools used by the other plugins.
|
|
5
5
|
* These plugins are used by the Charts components.
|
|
6
6
|
*/
|
|
7
|
-
export declare const CHART_CORE_PLUGINS: readonly [import("../models").ChartPlugin<import("./useChartId").UseChartIdSignature>];
|
|
7
|
+
export declare const CHART_CORE_PLUGINS: readonly [import("../models").ChartPlugin<import("./useChartId").UseChartIdSignature>, import("../models").ChartPlugin<import("./useChartDimensions").UseChartDimensionsSignature>, import("../models").ChartPlugin<import("./useChartSeries").UseChartSeriesSignature>];
|
|
8
8
|
export type ChartCorePluginSignatures = ConvertPluginsIntoSignatures<typeof CHART_CORE_PLUGINS>;
|
|
9
9
|
export interface ChartCorePluginParameters extends UseChartIdParameters {
|
|
10
10
|
}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
+
import { useChartDimensions } from "./useChartDimensions/useChartDimensions.js";
|
|
1
2
|
import { useChartId } from "./useChartId/index.js";
|
|
3
|
+
import { useChartSeries } from "./useChartSeries/index.js";
|
|
2
4
|
|
|
3
5
|
/**
|
|
4
6
|
* Internal plugins that create the tools used by the other plugins.
|
|
5
7
|
* These plugins are used by the Charts components.
|
|
6
8
|
*/
|
|
7
|
-
export const CHART_CORE_PLUGINS = [useChartId];
|
|
9
|
+
export const CHART_CORE_PLUGINS = [useChartId, useChartDimensions, useChartSeries];
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
/* eslint-disable react-compiler/react-compiler */
|
|
4
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
5
|
+
import * as React from 'react';
|
|
6
|
+
import useEnhancedEffect from '@mui/utils/useEnhancedEffect';
|
|
7
|
+
import ownerWindow from '@mui/utils/ownerWindow';
|
|
8
|
+
import { DEFAULT_MARGINS } from "../../../../constants/index.js";
|
|
9
|
+
import { selectorChartDimensionsState } from "./useChartDimensions.selectors.js";
|
|
10
|
+
const MAX_COMPUTE_RUN = 10;
|
|
11
|
+
export const useChartDimensions = ({
|
|
12
|
+
params,
|
|
13
|
+
store,
|
|
14
|
+
svgRef
|
|
15
|
+
}) => {
|
|
16
|
+
const hasInSize = params.width !== undefined && params.height !== undefined;
|
|
17
|
+
const stateRef = React.useRef({
|
|
18
|
+
displayError: false,
|
|
19
|
+
initialCompute: true,
|
|
20
|
+
computeRun: 0
|
|
21
|
+
});
|
|
22
|
+
// States only used for the initialization of the size.
|
|
23
|
+
const [innerWidth, setInnerWidth] = React.useState(0);
|
|
24
|
+
const [innerHeight, setInnerHeight] = React.useState(0);
|
|
25
|
+
const computeSize = React.useCallback(() => {
|
|
26
|
+
const mainEl = svgRef?.current;
|
|
27
|
+
if (!mainEl) {
|
|
28
|
+
return {};
|
|
29
|
+
}
|
|
30
|
+
const win = ownerWindow(mainEl);
|
|
31
|
+
const computedStyle = win.getComputedStyle(mainEl);
|
|
32
|
+
const newHeight = Math.floor(parseFloat(computedStyle.height)) || 0;
|
|
33
|
+
const newWidth = Math.floor(parseFloat(computedStyle.width)) || 0;
|
|
34
|
+
store.update(prev => {
|
|
35
|
+
const prevWidth = prev.dimensions.width + prev.dimensions.left + prev.dimensions.right;
|
|
36
|
+
const prevHeight = prev.dimensions.height + prev.dimensions.top + prev.dimensions.bottom;
|
|
37
|
+
if (prevWidth === newWidth && prevHeight === newHeight) {
|
|
38
|
+
return prev;
|
|
39
|
+
}
|
|
40
|
+
return _extends({}, prev, {
|
|
41
|
+
dimensions: _extends({}, prev.dimensions, {
|
|
42
|
+
width: newWidth - prev.dimensions.left - prev.dimensions.right,
|
|
43
|
+
height: newHeight - prev.dimensions.top - prev.dimensions.bottom
|
|
44
|
+
})
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
return {
|
|
48
|
+
height: newHeight,
|
|
49
|
+
width: newWidth
|
|
50
|
+
};
|
|
51
|
+
}, [store, svgRef]);
|
|
52
|
+
store.update(prev => {
|
|
53
|
+
if ((params.width === undefined || prev.dimensions.propsWidth === params.width) && (params.height === undefined || prev.dimensions.propsHeight === params.height)) {
|
|
54
|
+
return prev;
|
|
55
|
+
}
|
|
56
|
+
return _extends({}, prev, {
|
|
57
|
+
dimensions: _extends({}, prev.dimensions, {
|
|
58
|
+
width: params.width === undefined ? prev.dimensions.width : params.width - prev.dimensions.left - prev.dimensions.right,
|
|
59
|
+
height: params.height === undefined ? prev.dimensions.height : params.height - prev.dimensions.top - prev.dimensions.bottom,
|
|
60
|
+
propsWidth: params.width,
|
|
61
|
+
propsHeight: params.height
|
|
62
|
+
})
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
React.useEffect(() => {
|
|
66
|
+
// Ensure the error detection occurs after the first rendering.
|
|
67
|
+
stateRef.current.displayError = true;
|
|
68
|
+
}, []);
|
|
69
|
+
|
|
70
|
+
// This effect is used to compute the size of the container on the initial render.
|
|
71
|
+
// It is not bound to the raf loop to avoid an unwanted "resize" event.
|
|
72
|
+
// https://github.com/mui/mui-x/issues/13477#issuecomment-2336634785
|
|
73
|
+
useEnhancedEffect(() => {
|
|
74
|
+
// computeRun is used to avoid infinite loops.
|
|
75
|
+
if (hasInSize || !stateRef.current.initialCompute || stateRef.current.computeRun > MAX_COMPUTE_RUN) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
const computedSize = computeSize();
|
|
79
|
+
if (computedSize.width !== innerWidth || computedSize.height !== innerHeight) {
|
|
80
|
+
stateRef.current.computeRun += 1;
|
|
81
|
+
if (computedSize.width !== undefined) {
|
|
82
|
+
setInnerWidth(computedSize.width);
|
|
83
|
+
}
|
|
84
|
+
if (computedSize.height !== undefined) {
|
|
85
|
+
setInnerHeight(computedSize.height);
|
|
86
|
+
}
|
|
87
|
+
} else if (stateRef.current.initialCompute) {
|
|
88
|
+
stateRef.current.initialCompute = false;
|
|
89
|
+
}
|
|
90
|
+
}, [innerHeight, innerWidth, computeSize, hasInSize]);
|
|
91
|
+
useEnhancedEffect(() => {
|
|
92
|
+
if (hasInSize) {
|
|
93
|
+
return () => {};
|
|
94
|
+
}
|
|
95
|
+
computeSize();
|
|
96
|
+
const elementToObserve = svgRef.current;
|
|
97
|
+
if (typeof ResizeObserver === 'undefined') {
|
|
98
|
+
return () => {};
|
|
99
|
+
}
|
|
100
|
+
let animationFrame;
|
|
101
|
+
const observer = new ResizeObserver(() => {
|
|
102
|
+
// See https://github.com/mui/mui-x/issues/8733
|
|
103
|
+
animationFrame = requestAnimationFrame(() => {
|
|
104
|
+
computeSize();
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
if (elementToObserve) {
|
|
108
|
+
observer.observe(elementToObserve);
|
|
109
|
+
}
|
|
110
|
+
return () => {
|
|
111
|
+
if (animationFrame) {
|
|
112
|
+
cancelAnimationFrame(animationFrame);
|
|
113
|
+
}
|
|
114
|
+
if (elementToObserve) {
|
|
115
|
+
observer.unobserve(elementToObserve);
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
}, [computeSize, hasInSize, svgRef]);
|
|
119
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
120
|
+
if (stateRef.current.displayError && params.width === undefined && innerWidth === 0) {
|
|
121
|
+
console.error(`MUI X: ChartContainer does not have \`width\` prop, and its container has no \`width\` defined.`);
|
|
122
|
+
stateRef.current.displayError = false;
|
|
123
|
+
}
|
|
124
|
+
if (stateRef.current.displayError && params.height === undefined && innerHeight === 0) {
|
|
125
|
+
console.error(`MUI X: ChartContainer does not have \`height\` prop, and its container has no \`height\` defined.`);
|
|
126
|
+
stateRef.current.displayError = false;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
const isPointInside = React.useCallback(({
|
|
130
|
+
x,
|
|
131
|
+
y
|
|
132
|
+
}, options) => {
|
|
133
|
+
// For element allowed to overflow, wrapping them in <g data-drawing-container /> make them fully part of the drawing area.
|
|
134
|
+
if (options?.targetElement && options?.targetElement.closest('[data-drawing-container]')) {
|
|
135
|
+
return true;
|
|
136
|
+
}
|
|
137
|
+
const drawingArea = selectorChartDimensionsState(store.value);
|
|
138
|
+
const isInsideX = x >= drawingArea.left - 1 && x <= drawingArea.left + drawingArea.width;
|
|
139
|
+
const isInsideY = y >= drawingArea.top - 1 && y <= drawingArea.top + drawingArea.height;
|
|
140
|
+
if (options?.direction === 'x') {
|
|
141
|
+
return isInsideX;
|
|
142
|
+
}
|
|
143
|
+
if (options?.direction === 'y') {
|
|
144
|
+
return isInsideY;
|
|
145
|
+
}
|
|
146
|
+
return isInsideX && isInsideY;
|
|
147
|
+
}, [store.value]);
|
|
148
|
+
return {
|
|
149
|
+
instance: {
|
|
150
|
+
isPointInside
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
};
|
|
154
|
+
useChartDimensions.params = {
|
|
155
|
+
width: true,
|
|
156
|
+
height: true,
|
|
157
|
+
margin: true
|
|
158
|
+
};
|
|
159
|
+
useChartDimensions.getDefaultizedParams = ({
|
|
160
|
+
params
|
|
161
|
+
}) => _extends({}, params, {
|
|
162
|
+
margin: params.margin ? _extends({}, DEFAULT_MARGINS, params.margin) : DEFAULT_MARGINS
|
|
163
|
+
});
|
|
164
|
+
useChartDimensions.getInitialState = ({
|
|
165
|
+
width,
|
|
166
|
+
height,
|
|
167
|
+
margin
|
|
168
|
+
}) => ({
|
|
169
|
+
dimensions: _extends({}, margin, {
|
|
170
|
+
width: (width ?? 0) - margin.left - margin.right,
|
|
171
|
+
height: (height ?? 0) - margin.top - margin.bottom,
|
|
172
|
+
propsWidth: width,
|
|
173
|
+
propsHeight: height
|
|
174
|
+
})
|
|
175
|
+
});
|