@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.
Files changed (716) hide show
  1. package/BarChart/AnimatedBarElement.js +1 -0
  2. package/BarChart/BarChart.d.ts +1 -1
  3. package/BarChart/BarChart.js +26 -8
  4. package/BarChart/BarLabel/BarLabel.d.ts +1 -479
  5. package/BarChart/BarLabel/BarLabelPlot.js +1 -1
  6. package/BarChart/BarLabel/barLabelClasses.d.ts +1 -1
  7. package/BarChart/BarPlot.js +8 -9
  8. package/BarChart/extremums.d.ts +3 -3
  9. package/BarChart/formatter.d.ts +2 -2
  10. package/BarChart/formatter.js +2 -1
  11. package/BarChart/getColor.d.ts +1 -1
  12. package/BarChart/legend.d.ts +1 -1
  13. package/BarChart/legend.js +1 -0
  14. package/BarChart/plugin.d.ts +2 -2
  15. package/BarChart/plugin.js +1 -2
  16. package/BarChart/useBarChartProps.d.ts +5 -3
  17. package/BarChart/useBarChartProps.js +16 -3
  18. package/CHANGELOG.md +242 -1
  19. package/ChartContainer/ChartContainer.d.ts +6 -2
  20. package/ChartContainer/ChartContainer.js +13 -7
  21. package/ChartContainer/useChartContainerProps.d.ts +5 -3
  22. package/ChartContainer/useChartContainerProps.js +7 -5
  23. package/ChartsAxis/ChartsAxis.js +5 -3
  24. package/ChartsGrid/ChartsGrid.js +9 -5
  25. package/ChartsGrid/ChartsHorizontalGrid.d.ts +2 -2
  26. package/ChartsGrid/ChartsHorizontalGrid.js +4 -3
  27. package/ChartsGrid/ChartsVerticalGrid.d.ts +2 -2
  28. package/ChartsGrid/ChartsVerticalGrid.js +4 -3
  29. package/ChartsLabel/ChartsLabel.d.ts +2 -3
  30. package/ChartsLabel/ChartsLabel.js +3 -18
  31. package/ChartsLabel/ChartsLabelGradient.d.ts +9 -8
  32. package/ChartsLabel/ChartsLabelGradient.js +28 -26
  33. package/ChartsLabel/ChartsLabelMark.d.ts +2 -3
  34. package/ChartsLabel/ChartsLabelMark.js +5 -2
  35. package/ChartsLabel/index.d.ts +7 -0
  36. package/ChartsLabel/index.js +6 -0
  37. package/ChartsLabel/labelClasses.d.ts +0 -1
  38. package/ChartsLabel/labelGradientClasses.d.ts +5 -4
  39. package/ChartsLabel/labelGradientClasses.js +3 -2
  40. package/ChartsLabel/labelMarkClasses.d.ts +3 -2
  41. package/ChartsLabel/labelMarkClasses.js +3 -2
  42. package/ChartsLabel/package.json +6 -0
  43. package/ChartsLegend/ChartsLegend.d.ts +18 -22
  44. package/ChartsLegend/ChartsLegend.js +100 -109
  45. package/ChartsLegend/ContinuousColorLegend.d.ts +29 -38
  46. package/ChartsLegend/ContinuousColorLegend.js +198 -321
  47. package/ChartsLegend/PiecewiseColorLegend.d.ts +27 -19
  48. package/ChartsLegend/PiecewiseColorLegend.js +201 -111
  49. package/ChartsLegend/chartsLegend.types.d.ts +17 -60
  50. package/ChartsLegend/chartsLegendClasses.d.ts +7 -8
  51. package/ChartsLegend/chartsLegendClasses.js +16 -2
  52. package/ChartsLegend/colorLegend.types.d.ts +13 -0
  53. package/ChartsLegend/continuousColorLegendClasses.d.ts +26 -0
  54. package/ChartsLegend/continuousColorLegendClasses.js +23 -0
  55. package/ChartsLegend/direction.d.ts +1 -0
  56. package/ChartsLegend/index.d.ts +13 -3
  57. package/ChartsLegend/index.js +9 -3
  58. package/ChartsLegend/legend.types.d.ts +10 -54
  59. package/ChartsLegend/legendContext.types.d.ts +55 -0
  60. package/ChartsLegend/onClickContextBuilder.d.ts +2 -0
  61. package/ChartsLegend/onClickContextBuilder.js +7 -0
  62. package/ChartsLegend/piecewiseColorDefaultLabelFormatter.d.ts +2 -0
  63. package/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +9 -0
  64. package/ChartsLegend/piecewiseColorLegend.types.d.ts +26 -0
  65. package/ChartsLegend/piecewiseColorLegendClasses.d.ts +28 -0
  66. package/ChartsLegend/piecewiseColorLegendClasses.js +23 -0
  67. package/ChartsLegend/useAxis.d.ts +1 -1
  68. package/ChartsLegend/useAxis.js +7 -6
  69. package/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +7 -6
  70. package/ChartsReferenceLine/ChartsXReferenceLine.d.ts +1 -1
  71. package/ChartsReferenceLine/ChartsYReferenceLine.d.ts +1 -1
  72. package/ChartsSurface/ChartsSurface.js +16 -27
  73. package/ChartsTooltip/ChartsAxisTooltipContent.js +6 -3
  74. package/ChartsTooltip/ChartsItemTooltipContent.js +6 -3
  75. package/ChartsTooltip/ChartsTooltipTable.d.ts +0 -6
  76. package/ChartsTooltip/ChartsTooltipTable.js +0 -20
  77. package/ChartsTooltip/chartsTooltipClasses.d.ts +1 -1
  78. package/ChartsTooltip/useAxisTooltip.d.ts +3 -1
  79. package/ChartsTooltip/useAxisTooltip.js +13 -9
  80. package/ChartsTooltip/useItemTooltip.d.ts +3 -1
  81. package/ChartsTooltip/useItemTooltip.js +14 -10
  82. package/ChartsVoronoiHandler/ChartsVoronoiHandler.js +16 -9
  83. package/ChartsXAxis/ChartsXAxis.js +11 -8
  84. package/ChartsYAxis/ChartsYAxis.js +8 -5
  85. package/Gauge/Gauge.js +5 -1
  86. package/Gauge/GaugeContainer.d.ts +3 -10
  87. package/Gauge/GaugeContainer.js +38 -38
  88. package/LineChart/AnimatedArea.js +2 -1
  89. package/LineChart/AnimatedLine.js +2 -1
  90. package/LineChart/AppearingMask.js +2 -1
  91. package/LineChart/AreaPlot.js +16 -15
  92. package/LineChart/CircleMarkElement.js +1 -0
  93. package/LineChart/LineChart.js +29 -11
  94. package/LineChart/LineHighlightPlot.js +14 -11
  95. package/LineChart/LinePlot.js +16 -15
  96. package/LineChart/MarkElement.js +3 -1
  97. package/LineChart/MarkPlot.js +14 -11
  98. package/LineChart/extremums.d.ts +3 -3
  99. package/LineChart/formatter.d.ts +2 -2
  100. package/LineChart/formatter.js +3 -1
  101. package/LineChart/getColor.d.ts +1 -1
  102. package/LineChart/legend.d.ts +1 -1
  103. package/LineChart/legend.js +1 -0
  104. package/LineChart/plugin.d.ts +2 -2
  105. package/LineChart/plugin.js +1 -2
  106. package/LineChart/useLineChartProps.d.ts +5 -3
  107. package/LineChart/useLineChartProps.js +15 -2
  108. package/PieChart/PieArc.js +3 -1
  109. package/PieChart/PieArcLabel.js +13 -9
  110. package/PieChart/PieArcLabelPlot.js +3 -2
  111. package/PieChart/PieArcPlot.js +3 -2
  112. package/PieChart/PieChart.js +51 -42
  113. package/PieChart/dataTransform/transition.d.ts +2 -2
  114. package/PieChart/dataTransform/transition.js +6 -6
  115. package/PieChart/formatter.d.ts +2 -2
  116. package/PieChart/formatter.js +4 -1
  117. package/PieChart/getColor.d.ts +1 -1
  118. package/PieChart/getPieCoordinates.d.ts +2 -2
  119. package/PieChart/legend.d.ts +1 -1
  120. package/PieChart/legend.js +1 -0
  121. package/PieChart/plugin.d.ts +2 -2
  122. package/PieChart/plugin.js +1 -2
  123. package/ScatterChart/Scatter.js +6 -4
  124. package/ScatterChart/ScatterChart.d.ts +1 -2
  125. package/ScatterChart/ScatterChart.js +28 -14
  126. package/ScatterChart/ScatterPlot.js +11 -10
  127. package/ScatterChart/extremums.d.ts +3 -3
  128. package/ScatterChart/extremums.js +3 -1
  129. package/ScatterChart/formatter.d.ts +2 -2
  130. package/ScatterChart/formatter.js +3 -1
  131. package/ScatterChart/getColor.d.ts +1 -1
  132. package/ScatterChart/legend.d.ts +1 -1
  133. package/ScatterChart/legend.js +1 -0
  134. package/ScatterChart/plugin.d.ts +2 -2
  135. package/ScatterChart/plugin.js +1 -2
  136. package/ScatterChart/useScatterChartProps.d.ts +5 -5
  137. package/ScatterChart/useScatterChartProps.js +16 -6
  138. package/SparkLineChart/SparkLineChart.d.ts +2 -2
  139. package/SparkLineChart/SparkLineChart.js +12 -6
  140. package/constants/index.d.ts +1 -0
  141. package/constants/index.js +2 -1
  142. package/context/ChartDataProvider/ChartDataProvider.d.ts +6 -22
  143. package/context/ChartDataProvider/ChartDataProvider.js +22 -184
  144. package/context/ChartDataProvider/useChartDataProviderProps.d.ts +6 -83
  145. package/context/ChartDataProvider/useChartDataProviderProps.js +33 -47
  146. package/context/ChartProvider/ChartProvider.d.ts +5 -1
  147. package/context/ChartProvider/ChartProvider.js +22 -2
  148. package/context/ChartProvider/ChartProvider.types.d.ts +18 -3
  149. package/context/InteractionSelectors.d.ts +22 -22
  150. package/context/PolarProvider/PolarProvider.d.ts +0 -4
  151. package/context/PolarProvider/PolarProvider.js +59 -47
  152. package/context/PolarProvider/getAxisExtremum.d.ts +0 -4
  153. package/context/PolarProvider/getAxisExtremum.js +48 -20
  154. package/context/PolarProvider/usePolarContext.d.ts +0 -2
  155. package/context/PolarProvider/usePolarContext.js +9 -8
  156. package/context/index.d.ts +0 -2
  157. package/context/index.js +0 -1
  158. package/hooks/index.d.ts +3 -0
  159. package/hooks/index.js +4 -1
  160. package/hooks/useAxis.d.ts +9 -1
  161. package/hooks/useAxis.js +32 -6
  162. package/hooks/useAxisEvents.js +12 -8
  163. package/hooks/useChartGradientId.d.ts +31 -0
  164. package/hooks/useChartGradientId.js +47 -0
  165. package/hooks/useColorScale.js +5 -5
  166. package/hooks/useDrawingArea.d.ts +16 -2
  167. package/hooks/useDrawingArea.js +5 -20
  168. package/hooks/useLegend.d.ts +13 -0
  169. package/{modern/ChartsLegend/utils.js → hooks/useLegend.js} +20 -1
  170. package/hooks/useSeries.d.ts +11 -6
  171. package/hooks/useSeries.js +5 -10
  172. package/hooks/useSvgRef.d.ts +1 -1
  173. package/hooks/useZAxis.d.ts +3 -2
  174. package/hooks/useZAxis.js +25 -6
  175. package/index.d.ts +1 -0
  176. package/index.js +2 -1
  177. package/internals/calculateMargins.d.ts +7 -0
  178. package/internals/calculateMargins.js +25 -0
  179. package/internals/components/ChartsAxesGradients/ChartsAxesGradients.d.ts +0 -2
  180. package/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +65 -29
  181. package/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
  182. package/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.d.ts +13 -0
  183. package/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +61 -0
  184. package/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.d.ts +1 -1
  185. package/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
  186. package/internals/components/ChartsWrapper/ChartsWrapper.d.ts +17 -0
  187. package/internals/components/ChartsWrapper/ChartsWrapper.js +66 -0
  188. package/internals/components/ChartsWrapper/index.d.ts +1 -0
  189. package/internals/components/ChartsWrapper/index.js +1 -0
  190. package/internals/consumeSlots.d.ts +48 -0
  191. package/internals/consumeSlots.js +101 -0
  192. package/internals/consumeThemeProps.d.ts +3 -7
  193. package/internals/consumeThemeProps.js +18 -27
  194. package/internals/defaultizeColor.d.ts +26 -21
  195. package/internals/index.d.ts +14 -8
  196. package/internals/index.js +17 -9
  197. package/internals/plugins/allPlugins.d.ts +12 -1
  198. package/internals/plugins/allPlugins.js +5 -2
  199. package/internals/plugins/corePlugins/corePlugins.d.ts +1 -1
  200. package/internals/plugins/corePlugins/corePlugins.js +3 -1
  201. package/internals/plugins/corePlugins/useChartDimensions/index.d.ts +3 -0
  202. package/internals/plugins/corePlugins/useChartDimensions/index.js +2 -0
  203. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.d.ts +3 -0
  204. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +175 -0
  205. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.d.ts +264 -0
  206. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +25 -0
  207. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.d.ts +99 -0
  208. package/internals/plugins/corePlugins/useChartId/index.d.ts +1 -0
  209. package/internals/plugins/corePlugins/useChartId/index.js +2 -1
  210. package/internals/plugins/corePlugins/useChartId/useChartId.js +1 -1
  211. package/internals/plugins/corePlugins/useChartId/useChartId.selectors.d.ts +1 -1
  212. package/internals/plugins/corePlugins/useChartId/useChartId.types.d.ts +1 -1
  213. package/internals/plugins/corePlugins/useChartSeries/index.d.ts +3 -0
  214. package/internals/plugins/corePlugins/useChartSeries/index.js +2 -0
  215. package/internals/plugins/corePlugins/useChartSeries/processSeries.d.ts +18 -0
  216. package/{modern/context/SeriesProvider → internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
  217. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.d.ts +3 -0
  218. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +72 -0
  219. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.d.ts +61 -0
  220. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +4 -0
  221. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.types.d.ts +51 -0
  222. package/internals/plugins/corePlugins/useChartSeries/useColorProcessor.d.ts +10 -0
  223. package/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +21 -0
  224. package/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.d.ts +29 -0
  225. package/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
  226. package/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.d.ts +18 -0
  227. package/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +61 -0
  228. package/internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.d.ts +39 -0
  229. package/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +3 -11
  230. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.d.ts +6 -0
  231. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +22 -0
  232. package/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +5 -0
  233. package/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +4 -0
  234. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.d.ts +4 -0
  235. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +68 -0
  236. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.d.ts +1372 -0
  237. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +87 -0
  238. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.d.ts +76 -0
  239. package/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.d.ts +18 -0
  240. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +11 -11
  241. package/internals/plugins/featurePlugins/useChartZAxis/index.d.ts +3 -0
  242. package/internals/plugins/featurePlugins/useChartZAxis/index.js +2 -0
  243. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.d.ts +3 -0
  244. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +86 -0
  245. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.d.ts +45 -0
  246. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +3 -0
  247. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.d.ts +39 -0
  248. package/internals/plugins/featurePlugins/useChartZAxis/utils.d.ts +0 -0
  249. package/internals/plugins/featurePlugins/useChartZAxis/utils.js +0 -0
  250. package/internals/plugins/models/index.d.ts +1 -0
  251. package/internals/plugins/models/index.js +2 -1
  252. package/internals/plugins/models/plugin.d.ts +33 -3
  253. package/internals/plugins/models/seriesConfig/colorProcessor.types.d.ts +5 -0
  254. package/internals/plugins/models/seriesConfig/extremumGetter.types.d.ts +22 -0
  255. package/internals/plugins/models/seriesConfig/index.d.ts +4 -0
  256. package/internals/plugins/models/seriesConfig/index.js +4 -0
  257. package/internals/plugins/models/seriesConfig/seriesConfig.types.d.ts +14 -0
  258. package/internals/plugins/models/seriesConfig/seriesProcessor.types.d.ts +18 -0
  259. package/internals/store/extractPluginParamsFromProps.d.ts +7 -0
  260. package/internals/store/extractPluginParamsFromProps.js +28 -0
  261. package/internals/store/useChartModels.d.ts +7 -0
  262. package/internals/store/useChartModels.js +64 -0
  263. package/internals/store/useCharts.d.ts +6 -4
  264. package/internals/store/useCharts.js +14 -9
  265. package/internals/store/useCharts.types.d.ts +1 -1
  266. package/internals/store/useStore.d.ts +5 -1
  267. package/internals/store/useStore.js +1 -9
  268. package/models/layout.d.ts +2 -1
  269. package/models/seriesType/common.d.ts +9 -0
  270. package/models/seriesType/pie.d.ts +9 -0
  271. package/modern/BarChart/AnimatedBarElement.js +1 -0
  272. package/modern/BarChart/BarChart.js +26 -8
  273. package/modern/BarChart/BarLabel/BarLabelPlot.js +1 -1
  274. package/modern/BarChart/BarPlot.js +8 -9
  275. package/modern/BarChart/formatter.js +2 -1
  276. package/modern/BarChart/legend.js +1 -0
  277. package/modern/BarChart/plugin.js +1 -2
  278. package/modern/BarChart/useBarChartProps.js +16 -3
  279. package/modern/ChartContainer/ChartContainer.js +13 -7
  280. package/modern/ChartContainer/useChartContainerProps.js +7 -5
  281. package/modern/ChartsAxis/ChartsAxis.js +5 -3
  282. package/modern/ChartsGrid/ChartsGrid.js +9 -5
  283. package/modern/ChartsGrid/ChartsHorizontalGrid.js +4 -3
  284. package/modern/ChartsGrid/ChartsVerticalGrid.js +4 -3
  285. package/modern/ChartsLabel/ChartsLabel.js +3 -18
  286. package/modern/ChartsLabel/ChartsLabelGradient.js +28 -26
  287. package/modern/ChartsLabel/ChartsLabelMark.js +5 -2
  288. package/modern/ChartsLabel/index.js +6 -0
  289. package/modern/ChartsLabel/labelGradientClasses.js +3 -2
  290. package/modern/ChartsLabel/labelMarkClasses.js +3 -2
  291. package/modern/ChartsLegend/ChartsLegend.js +100 -109
  292. package/modern/ChartsLegend/ContinuousColorLegend.js +198 -321
  293. package/modern/ChartsLegend/PiecewiseColorLegend.js +201 -111
  294. package/modern/ChartsLegend/chartsLegendClasses.js +16 -2
  295. package/modern/ChartsLegend/continuousColorLegendClasses.js +23 -0
  296. package/modern/ChartsLegend/index.js +9 -3
  297. package/modern/ChartsLegend/onClickContextBuilder.js +7 -0
  298. package/modern/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +9 -0
  299. package/modern/ChartsLegend/piecewiseColorLegend.types.js +1 -0
  300. package/modern/ChartsLegend/piecewiseColorLegendClasses.js +23 -0
  301. package/modern/ChartsLegend/useAxis.js +7 -6
  302. package/modern/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +7 -6
  303. package/modern/ChartsSurface/ChartsSurface.js +16 -27
  304. package/modern/ChartsTooltip/ChartsAxisTooltipContent.js +6 -3
  305. package/modern/ChartsTooltip/ChartsItemTooltipContent.js +6 -3
  306. package/modern/ChartsTooltip/ChartsTooltipTable.js +0 -20
  307. package/modern/ChartsTooltip/useAxisTooltip.js +13 -9
  308. package/modern/ChartsTooltip/useItemTooltip.js +14 -10
  309. package/modern/ChartsVoronoiHandler/ChartsVoronoiHandler.js +16 -9
  310. package/modern/ChartsXAxis/ChartsXAxis.js +11 -8
  311. package/modern/ChartsYAxis/ChartsYAxis.js +8 -5
  312. package/modern/Gauge/Gauge.js +5 -1
  313. package/modern/Gauge/GaugeContainer.js +38 -38
  314. package/modern/LineChart/AnimatedArea.js +2 -1
  315. package/modern/LineChart/AnimatedLine.js +2 -1
  316. package/modern/LineChart/AppearingMask.js +2 -1
  317. package/modern/LineChart/AreaPlot.js +16 -15
  318. package/modern/LineChart/CircleMarkElement.js +1 -0
  319. package/modern/LineChart/LineChart.js +29 -11
  320. package/modern/LineChart/LineHighlightPlot.js +14 -11
  321. package/modern/LineChart/LinePlot.js +16 -15
  322. package/modern/LineChart/MarkElement.js +3 -1
  323. package/modern/LineChart/MarkPlot.js +14 -11
  324. package/modern/LineChart/formatter.js +3 -1
  325. package/modern/LineChart/legend.js +1 -0
  326. package/modern/LineChart/plugin.js +1 -2
  327. package/modern/LineChart/useLineChartProps.js +15 -2
  328. package/modern/PieChart/PieArc.js +3 -1
  329. package/modern/PieChart/PieArcLabel.js +13 -9
  330. package/modern/PieChart/PieArcLabelPlot.js +3 -2
  331. package/modern/PieChart/PieArcPlot.js +3 -2
  332. package/modern/PieChart/PieChart.js +51 -42
  333. package/modern/PieChart/dataTransform/transition.js +6 -6
  334. package/modern/PieChart/formatter.js +4 -1
  335. package/modern/PieChart/legend.js +1 -0
  336. package/modern/PieChart/plugin.js +1 -2
  337. package/modern/ScatterChart/Scatter.js +6 -4
  338. package/modern/ScatterChart/ScatterChart.js +28 -14
  339. package/modern/ScatterChart/ScatterPlot.js +11 -10
  340. package/modern/ScatterChart/extremums.js +3 -1
  341. package/modern/ScatterChart/formatter.js +3 -1
  342. package/modern/ScatterChart/legend.js +1 -0
  343. package/modern/ScatterChart/plugin.js +1 -2
  344. package/modern/ScatterChart/useScatterChartProps.js +16 -6
  345. package/modern/SparkLineChart/SparkLineChart.js +12 -6
  346. package/modern/constants/index.js +2 -1
  347. package/modern/context/ChartDataProvider/ChartDataProvider.js +22 -184
  348. package/modern/context/ChartDataProvider/useChartDataProviderProps.js +33 -47
  349. package/modern/context/ChartProvider/ChartProvider.js +22 -2
  350. package/modern/context/PolarProvider/PolarProvider.js +59 -47
  351. package/modern/context/PolarProvider/getAxisExtremum.js +48 -20
  352. package/modern/context/PolarProvider/usePolarContext.js +9 -8
  353. package/modern/context/index.js +0 -1
  354. package/modern/hooks/index.js +4 -1
  355. package/modern/hooks/useAxis.js +32 -6
  356. package/modern/hooks/useAxisEvents.js +12 -8
  357. package/modern/hooks/useChartGradientId.js +47 -0
  358. package/modern/hooks/useColorScale.js +5 -5
  359. package/modern/hooks/useDrawingArea.js +5 -20
  360. package/{ChartsLegend/utils.js → modern/hooks/useLegend.js} +20 -1
  361. package/modern/hooks/useSeries.js +5 -10
  362. package/modern/hooks/useZAxis.js +25 -6
  363. package/modern/index.js +2 -1
  364. package/modern/internals/calculateMargins.js +25 -0
  365. package/modern/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +65 -29
  366. package/modern/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
  367. package/modern/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +61 -0
  368. package/modern/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
  369. package/modern/internals/components/ChartsWrapper/ChartsWrapper.js +66 -0
  370. package/modern/internals/components/ChartsWrapper/index.js +1 -0
  371. package/modern/internals/consumeSlots.js +101 -0
  372. package/modern/internals/consumeThemeProps.js +18 -27
  373. package/modern/internals/index.js +17 -9
  374. package/modern/internals/plugins/allPlugins.js +5 -2
  375. package/modern/internals/plugins/corePlugins/corePlugins.js +3 -1
  376. package/modern/internals/plugins/corePlugins/useChartDimensions/index.js +2 -0
  377. package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +175 -0
  378. package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +25 -0
  379. package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js +1 -0
  380. package/modern/internals/plugins/corePlugins/useChartId/index.js +2 -1
  381. package/modern/internals/plugins/corePlugins/useChartId/useChartId.js +1 -1
  382. package/modern/internals/plugins/corePlugins/useChartSeries/index.js +2 -0
  383. package/{context/SeriesProvider → modern/internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
  384. package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +72 -0
  385. package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +4 -0
  386. package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js +1 -0
  387. package/modern/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +21 -0
  388. package/modern/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
  389. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +61 -0
  390. package/modern/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +3 -11
  391. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +22 -0
  392. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +4 -0
  393. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +68 -0
  394. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +87 -0
  395. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js +1 -0
  396. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js +1 -0
  397. package/modern/internals/plugins/featurePlugins/useChartZAxis/index.js +2 -0
  398. package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +86 -0
  399. package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +3 -0
  400. package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js +1 -0
  401. package/modern/internals/plugins/featurePlugins/useChartZAxis/utils.js +0 -0
  402. package/modern/internals/plugins/models/index.js +2 -1
  403. package/modern/internals/plugins/models/seriesConfig/colorProcessor.types.js +1 -0
  404. package/modern/internals/plugins/models/seriesConfig/extremumGetter.types.js +1 -0
  405. package/modern/internals/plugins/models/seriesConfig/index.js +4 -0
  406. package/modern/internals/plugins/models/seriesConfig/seriesConfig.types.js +1 -0
  407. package/modern/internals/plugins/models/seriesConfig/seriesProcessor.types.js +1 -0
  408. package/modern/internals/store/extractPluginParamsFromProps.js +28 -0
  409. package/modern/internals/store/useChartModels.js +64 -0
  410. package/modern/internals/store/useCharts.js +14 -9
  411. package/modern/internals/store/useStore.js +1 -9
  412. package/node/BarChart/AnimatedBarElement.js +1 -0
  413. package/node/BarChart/BarChart.js +26 -8
  414. package/node/BarChart/BarLabel/BarLabelPlot.js +1 -1
  415. package/node/BarChart/BarPlot.js +6 -6
  416. package/node/BarChart/formatter.js +2 -1
  417. package/node/BarChart/legend.js +1 -0
  418. package/node/BarChart/plugin.js +1 -2
  419. package/node/BarChart/useBarChartProps.js +15 -3
  420. package/node/ChartContainer/ChartContainer.js +13 -7
  421. package/node/ChartContainer/useChartContainerProps.js +7 -5
  422. package/node/ChartsAxis/ChartsAxis.js +5 -3
  423. package/node/ChartsGrid/ChartsGrid.js +9 -5
  424. package/node/ChartsGrid/ChartsHorizontalGrid.js +4 -3
  425. package/node/ChartsGrid/ChartsVerticalGrid.js +4 -3
  426. package/node/ChartsLabel/ChartsLabel.js +3 -18
  427. package/node/ChartsLabel/ChartsLabelGradient.js +28 -26
  428. package/node/ChartsLabel/ChartsLabelMark.js +5 -2
  429. package/node/ChartsLabel/index.js +26 -0
  430. package/node/ChartsLabel/labelGradientClasses.js +3 -2
  431. package/node/ChartsLabel/labelMarkClasses.js +3 -2
  432. package/node/ChartsLegend/ChartsLegend.js +99 -108
  433. package/node/ChartsLegend/ContinuousColorLegend.js +199 -322
  434. package/node/ChartsLegend/PiecewiseColorLegend.js +201 -111
  435. package/node/ChartsLegend/chartsLegendClasses.js +17 -3
  436. package/node/ChartsLegend/continuousColorLegendClasses.js +31 -0
  437. package/node/ChartsLegend/index.js +80 -16
  438. package/node/ChartsLegend/onClickContextBuilder.js +14 -0
  439. package/node/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +15 -0
  440. package/node/ChartsLegend/piecewiseColorLegendClasses.js +31 -0
  441. package/node/ChartsLegend/useAxis.js +6 -4
  442. package/node/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +6 -5
  443. package/node/ChartsSurface/ChartsSurface.js +17 -28
  444. package/node/ChartsTooltip/ChartsAxisTooltipContent.js +5 -2
  445. package/node/ChartsTooltip/ChartsItemTooltipContent.js +5 -2
  446. package/node/ChartsTooltip/ChartsTooltipTable.js +1 -21
  447. package/node/ChartsTooltip/useAxisTooltip.js +11 -7
  448. package/node/ChartsTooltip/useItemTooltip.js +13 -9
  449. package/node/ChartsVoronoiHandler/ChartsVoronoiHandler.js +19 -12
  450. package/node/ChartsXAxis/ChartsXAxis.js +11 -8
  451. package/node/ChartsYAxis/ChartsYAxis.js +8 -5
  452. package/node/Gauge/Gauge.js +5 -1
  453. package/node/Gauge/GaugeContainer.js +38 -38
  454. package/node/LineChart/AnimatedArea.js +2 -1
  455. package/node/LineChart/AnimatedLine.js +2 -1
  456. package/node/LineChart/AppearingMask.js +2 -1
  457. package/node/LineChart/AreaPlot.js +16 -15
  458. package/node/LineChart/CircleMarkElement.js +1 -0
  459. package/node/LineChart/LineChart.js +29 -11
  460. package/node/LineChart/LineHighlightPlot.js +14 -11
  461. package/node/LineChart/LinePlot.js +16 -15
  462. package/node/LineChart/MarkElement.js +3 -1
  463. package/node/LineChart/MarkPlot.js +14 -11
  464. package/node/LineChart/formatter.js +3 -1
  465. package/node/LineChart/legend.js +1 -0
  466. package/node/LineChart/plugin.js +1 -2
  467. package/node/LineChart/useLineChartProps.js +14 -2
  468. package/node/PieChart/PieArc.js +3 -1
  469. package/node/PieChart/PieArcLabel.js +13 -9
  470. package/node/PieChart/PieArcLabelPlot.js +2 -1
  471. package/node/PieChart/PieArcPlot.js +2 -1
  472. package/node/PieChart/PieChart.js +51 -42
  473. package/node/PieChart/dataTransform/transition.js +9 -7
  474. package/node/PieChart/formatter.js +4 -1
  475. package/node/PieChart/legend.js +1 -0
  476. package/node/PieChart/plugin.js +1 -2
  477. package/node/ScatterChart/Scatter.js +6 -4
  478. package/node/ScatterChart/ScatterChart.js +28 -14
  479. package/node/ScatterChart/ScatterPlot.js +10 -9
  480. package/node/ScatterChart/extremums.js +3 -1
  481. package/node/ScatterChart/formatter.js +3 -1
  482. package/node/ScatterChart/legend.js +1 -0
  483. package/node/ScatterChart/plugin.js +1 -2
  484. package/node/ScatterChart/useScatterChartProps.js +15 -6
  485. package/node/SparkLineChart/SparkLineChart.js +11 -5
  486. package/node/constants/index.js +3 -2
  487. package/node/context/ChartDataProvider/ChartDataProvider.js +22 -184
  488. package/node/context/ChartDataProvider/useChartDataProviderProps.js +34 -47
  489. package/node/context/ChartProvider/ChartProvider.js +23 -2
  490. package/node/context/PolarProvider/PolarProvider.js +59 -51
  491. package/node/context/PolarProvider/getAxisExtremum.js +49 -27
  492. package/node/context/PolarProvider/usePolarContext.js +9 -14
  493. package/node/context/index.js +0 -8
  494. package/node/hooks/index.js +41 -2
  495. package/node/hooks/useAxis.js +34 -6
  496. package/node/hooks/useAxisEvents.js +12 -8
  497. package/node/hooks/useChartGradientId.js +56 -0
  498. package/node/hooks/useColorScale.js +4 -4
  499. package/node/hooks/useDrawingArea.js +5 -21
  500. package/node/{ChartsLegend/utils.js → hooks/useLegend.js} +19 -1
  501. package/node/hooks/useSeries.js +5 -9
  502. package/node/hooks/useZAxis.js +27 -9
  503. package/node/index.js +12 -1
  504. package/node/internals/calculateMargins.js +33 -0
  505. package/node/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +64 -29
  506. package/node/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
  507. package/node/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +69 -0
  508. package/node/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
  509. package/node/internals/components/ChartsWrapper/ChartsWrapper.js +72 -0
  510. package/node/internals/components/ChartsWrapper/index.js +16 -0
  511. package/node/internals/consumeSlots.js +109 -0
  512. package/node/internals/consumeThemeProps.js +18 -27
  513. package/node/internals/index.js +134 -62
  514. package/node/internals/plugins/allPlugins.js +4 -2
  515. package/node/internals/plugins/corePlugins/corePlugins.js +3 -1
  516. package/node/internals/plugins/corePlugins/useChartDimensions/index.js +27 -0
  517. package/node/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +183 -0
  518. package/node/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +32 -0
  519. package/node/internals/plugins/corePlugins/useChartId/index.js +16 -1
  520. package/node/internals/plugins/corePlugins/useChartId/useChartId.js +1 -1
  521. package/node/internals/plugins/corePlugins/useChartSeries/index.js +27 -0
  522. package/node/{context/SeriesProvider → internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
  523. package/node/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +80 -0
  524. package/node/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +11 -0
  525. package/node/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +27 -0
  526. package/node/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
  527. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +69 -0
  528. package/node/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +4 -13
  529. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +29 -0
  530. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +47 -0
  531. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +76 -0
  532. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +96 -0
  533. package/node/internals/plugins/featurePlugins/useChartZAxis/index.js +27 -0
  534. package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +94 -0
  535. package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +9 -0
  536. package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js +5 -0
  537. package/node/internals/plugins/featurePlugins/useChartZAxis/utils.js +1 -0
  538. package/node/internals/plugins/models/index.js +11 -0
  539. package/node/internals/plugins/models/seriesConfig/colorProcessor.types.js +5 -0
  540. package/node/internals/plugins/models/seriesConfig/extremumGetter.types.js +5 -0
  541. package/node/internals/plugins/models/seriesConfig/index.js +49 -0
  542. package/node/internals/plugins/models/seriesConfig/seriesConfig.types.js +5 -0
  543. package/node/internals/plugins/models/seriesConfig/seriesProcessor.types.js +5 -0
  544. package/node/internals/store/extractPluginParamsFromProps.js +36 -0
  545. package/node/internals/store/useChartModels.js +73 -0
  546. package/node/internals/store/useCharts.js +14 -9
  547. package/node/internals/store/useStore.js +1 -9
  548. package/package.json +4 -4
  549. package/ChartsLegend/ChartsLegendItem.d.ts +0 -26
  550. package/ChartsLegend/ChartsLegendItem.js +0 -65
  551. package/ChartsLegend/DefaultChartsLegend.d.ts +0 -25
  552. package/ChartsLegend/DefaultChartsLegend.js +0 -112
  553. package/ChartsLegend/LegendPerItem.d.ts +0 -65
  554. package/ChartsLegend/LegendPerItem.js +0 -129
  555. package/ChartsLegend/legendItemsPlacement.d.ts +0 -3
  556. package/ChartsLegend/legendItemsPlacement.js +0 -72
  557. package/ChartsLegend/utils.d.ts +0 -2
  558. package/context/CartesianProvider/Cartesian.types.d.ts +0 -59
  559. package/context/CartesianProvider/CartesianContext.d.ts +0 -4
  560. package/context/CartesianProvider/CartesianContext.js +0 -13
  561. package/context/CartesianProvider/CartesianProvider.d.ts +0 -4
  562. package/context/CartesianProvider/CartesianProvider.js +0 -49
  563. package/context/CartesianProvider/defaultizeAxis.d.ts +0 -38
  564. package/context/CartesianProvider/defaultizeAxis.js +0 -13
  565. package/context/CartesianProvider/getAxisExtremum.d.ts +0 -5
  566. package/context/CartesianProvider/getAxisExtremum.js +0 -21
  567. package/context/CartesianProvider/index.d.ts +0 -4
  568. package/context/CartesianProvider/index.js +0 -4
  569. package/context/CartesianProvider/useCartesianContext.d.ts +0 -2
  570. package/context/CartesianProvider/useCartesianContext.js +0 -10
  571. package/context/ChartDataProvider/useDefaultizeAxis.d.ts +0 -39
  572. package/context/DrawingAreaProvider/DrawingArea.types.d.ts +0 -51
  573. package/context/DrawingAreaProvider/DrawingAreaContext.d.ts +0 -3
  574. package/context/DrawingAreaProvider/DrawingAreaContext.js +0 -15
  575. package/context/DrawingAreaProvider/DrawingAreaProvider.d.ts +0 -3
  576. package/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -48
  577. package/context/DrawingAreaProvider/index.d.ts +0 -3
  578. package/context/DrawingAreaProvider/index.js +0 -3
  579. package/context/PluginProvider/ColorProcessor.types.d.ts +0 -8
  580. package/context/PluginProvider/ExtremumGetter.types.d.ts +0 -25
  581. package/context/PluginProvider/Plugin.types.d.ts +0 -29
  582. package/context/PluginProvider/PluginContext.d.ts +0 -4
  583. package/context/PluginProvider/PluginContext.js +0 -15
  584. package/context/PluginProvider/PluginProvider.d.ts +0 -4
  585. package/context/PluginProvider/PluginProvider.js +0 -21
  586. package/context/PluginProvider/SeriesFormatter.types.d.ts +0 -21
  587. package/context/PluginProvider/index.d.ts +0 -12
  588. package/context/PluginProvider/index.js +0 -12
  589. package/context/PluginProvider/mergePlugins.d.ts +0 -46
  590. package/context/PluginProvider/mergePlugins.js +0 -40
  591. package/context/PluginProvider/useColorProcessor.d.ts +0 -4
  592. package/context/PluginProvider/useColorProcessor.js +0 -17
  593. package/context/PluginProvider/useRadiusExtremumGetter.d.ts +0 -4
  594. package/context/PluginProvider/useRadiusExtremumGetter.js +0 -17
  595. package/context/PluginProvider/useRotationExtremumGetter.d.ts +0 -4
  596. package/context/PluginProvider/useRotationExtremumGetter.js +0 -17
  597. package/context/PluginProvider/useSeriesFormatter.d.ts +0 -4
  598. package/context/PluginProvider/useSeriesFormatter.js +0 -17
  599. package/context/PluginProvider/useXExtremumGetter.d.ts +0 -4
  600. package/context/PluginProvider/useXExtremumGetter.js +0 -15
  601. package/context/PluginProvider/useYExtremumGetter.d.ts +0 -4
  602. package/context/PluginProvider/useYExtremumGetter.js +0 -15
  603. package/context/SeriesProvider/Series.types.d.ts +0 -26
  604. package/context/SeriesProvider/SeriesContext.d.ts +0 -4
  605. package/context/SeriesProvider/SeriesContext.js +0 -8
  606. package/context/SeriesProvider/SeriesProvider.d.ts +0 -5
  607. package/context/SeriesProvider/SeriesProvider.js +0 -33
  608. package/context/SeriesProvider/index.d.ts +0 -12
  609. package/context/SeriesProvider/index.js +0 -8
  610. package/context/SeriesProvider/processSeries.d.ts +0 -18
  611. package/context/SizeProvider/Size.types.d.ts +0 -30
  612. package/context/SizeProvider/SizeContext.d.ts +0 -4
  613. package/context/SizeProvider/SizeContext.js +0 -15
  614. package/context/SizeProvider/SizeProvider.d.ts +0 -11
  615. package/context/SizeProvider/SizeProvider.js +0 -26
  616. package/context/SizeProvider/index.d.ts +0 -4
  617. package/context/SizeProvider/index.js +0 -4
  618. package/context/SizeProvider/useChartContainerDimensions.d.ts +0 -9
  619. package/context/SizeProvider/useChartContainerDimensions.js +0 -108
  620. package/context/SizeProvider/useSize.d.ts +0 -5
  621. package/context/SizeProvider/useSize.js +0 -13
  622. package/context/ZAxisContextProvider.d.ts +0 -33
  623. package/context/ZAxisContextProvider.js +0 -96
  624. package/internals/computeAxisValue.d.ts +0 -38
  625. package/modern/ChartsLegend/ChartsLegendItem.js +0 -65
  626. package/modern/ChartsLegend/DefaultChartsLegend.js +0 -112
  627. package/modern/ChartsLegend/LegendPerItem.js +0 -129
  628. package/modern/ChartsLegend/legendItemsPlacement.js +0 -72
  629. package/modern/context/CartesianProvider/CartesianContext.js +0 -13
  630. package/modern/context/CartesianProvider/CartesianProvider.js +0 -49
  631. package/modern/context/CartesianProvider/defaultizeAxis.js +0 -13
  632. package/modern/context/CartesianProvider/getAxisExtremum.js +0 -21
  633. package/modern/context/CartesianProvider/index.js +0 -4
  634. package/modern/context/CartesianProvider/useCartesianContext.js +0 -10
  635. package/modern/context/DrawingAreaProvider/DrawingAreaContext.js +0 -15
  636. package/modern/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -48
  637. package/modern/context/DrawingAreaProvider/index.js +0 -3
  638. package/modern/context/PluginProvider/PluginContext.js +0 -15
  639. package/modern/context/PluginProvider/PluginProvider.js +0 -21
  640. package/modern/context/PluginProvider/index.js +0 -12
  641. package/modern/context/PluginProvider/mergePlugins.js +0 -40
  642. package/modern/context/PluginProvider/useColorProcessor.js +0 -17
  643. package/modern/context/PluginProvider/useRadiusExtremumGetter.js +0 -17
  644. package/modern/context/PluginProvider/useRotationExtremumGetter.js +0 -17
  645. package/modern/context/PluginProvider/useSeriesFormatter.js +0 -17
  646. package/modern/context/PluginProvider/useXExtremumGetter.js +0 -15
  647. package/modern/context/PluginProvider/useYExtremumGetter.js +0 -15
  648. package/modern/context/SeriesProvider/SeriesContext.js +0 -8
  649. package/modern/context/SeriesProvider/SeriesProvider.js +0 -33
  650. package/modern/context/SeriesProvider/index.js +0 -8
  651. package/modern/context/SizeProvider/SizeContext.js +0 -15
  652. package/modern/context/SizeProvider/SizeProvider.js +0 -26
  653. package/modern/context/SizeProvider/index.js +0 -4
  654. package/modern/context/SizeProvider/useChartContainerDimensions.js +0 -108
  655. package/modern/context/SizeProvider/useSize.js +0 -13
  656. package/modern/context/ZAxisContextProvider.js +0 -96
  657. package/node/ChartsLegend/ChartsLegendItem.js +0 -72
  658. package/node/ChartsLegend/DefaultChartsLegend.js +0 -118
  659. package/node/ChartsLegend/LegendPerItem.js +0 -137
  660. package/node/ChartsLegend/legendItemsPlacement.js +0 -79
  661. package/node/context/CartesianProvider/CartesianContext.js +0 -20
  662. package/node/context/CartesianProvider/CartesianProvider.js +0 -54
  663. package/node/context/CartesianProvider/defaultizeAxis.js +0 -21
  664. package/node/context/CartesianProvider/getAxisExtremum.js +0 -28
  665. package/node/context/CartesianProvider/index.js +0 -49
  666. package/node/context/CartesianProvider/useCartesianContext.js +0 -17
  667. package/node/context/DrawingAreaProvider/DrawingAreaContext.js +0 -21
  668. package/node/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -55
  669. package/node/context/DrawingAreaProvider/index.js +0 -38
  670. package/node/context/PluginProvider/PluginContext.js +0 -22
  671. package/node/context/PluginProvider/PluginProvider.js +0 -26
  672. package/node/context/PluginProvider/index.js +0 -137
  673. package/node/context/PluginProvider/mergePlugins.js +0 -47
  674. package/node/context/PluginProvider/useColorProcessor.js +0 -23
  675. package/node/context/PluginProvider/useRadiusExtremumGetter.js +0 -23
  676. package/node/context/PluginProvider/useRotationExtremumGetter.js +0 -23
  677. package/node/context/PluginProvider/useSeriesFormatter.js +0 -23
  678. package/node/context/PluginProvider/useXExtremumGetter.js +0 -22
  679. package/node/context/PluginProvider/useYExtremumGetter.js +0 -22
  680. package/node/context/SeriesProvider/SeriesContext.js +0 -15
  681. package/node/context/SeriesProvider/SeriesProvider.js +0 -38
  682. package/node/context/SeriesProvider/index.js +0 -49
  683. package/node/context/SizeProvider/SizeContext.js +0 -22
  684. package/node/context/SizeProvider/SizeProvider.js +0 -29
  685. package/node/context/SizeProvider/index.js +0 -49
  686. package/node/context/SizeProvider/useChartContainerDimensions.js +0 -116
  687. package/node/context/SizeProvider/useSize.js +0 -20
  688. package/node/context/ZAxisContextProvider.js +0 -103
  689. /package/{context/CartesianProvider/Cartesian.types.js → ChartsLegend/colorLegend.types.js} +0 -0
  690. /package/{context/DrawingAreaProvider/DrawingArea.types.js → ChartsLegend/direction.js} +0 -0
  691. /package/{context/PluginProvider/ColorProcessor.types.js → ChartsLegend/legendContext.types.js} +0 -0
  692. /package/{context/PluginProvider/ExtremumGetter.types.js → ChartsLegend/piecewiseColorLegend.types.js} +0 -0
  693. /package/{context/PluginProvider/Plugin.types.js → internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js} +0 -0
  694. /package/{context/PluginProvider/SeriesFormatter.types.js → internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js} +0 -0
  695. /package/{context/SeriesProvider/Series.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js} +0 -0
  696. /package/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.d.ts +0 -0
  697. /package/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
  698. /package/{context/SizeProvider/Size.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js} +0 -0
  699. /package/{modern/context/CartesianProvider/Cartesian.types.js → internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js} +0 -0
  700. /package/{modern/context/DrawingAreaProvider/DrawingArea.types.js → internals/plugins/models/seriesConfig/colorProcessor.types.js} +0 -0
  701. /package/{modern/context/PluginProvider/ColorProcessor.types.js → internals/plugins/models/seriesConfig/extremumGetter.types.js} +0 -0
  702. /package/{modern/context/PluginProvider/ExtremumGetter.types.js → internals/plugins/models/seriesConfig/seriesConfig.types.js} +0 -0
  703. /package/{modern/context/PluginProvider/Plugin.types.js → internals/plugins/models/seriesConfig/seriesProcessor.types.js} +0 -0
  704. /package/modern/{context/PluginProvider/SeriesFormatter.types.js → ChartsLegend/colorLegend.types.js} +0 -0
  705. /package/modern/{context/SeriesProvider/Series.types.js → ChartsLegend/direction.js} +0 -0
  706. /package/modern/{context/SizeProvider/Size.types.js → ChartsLegend/legendContext.types.js} +0 -0
  707. /package/modern/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
  708. /package/node/{context/CartesianProvider/Cartesian.types.js → ChartsLegend/colorLegend.types.js} +0 -0
  709. /package/node/{context/DrawingAreaProvider/DrawingArea.types.js → ChartsLegend/direction.js} +0 -0
  710. /package/node/{context/PluginProvider/ColorProcessor.types.js → ChartsLegend/legendContext.types.js} +0 -0
  711. /package/node/{context/PluginProvider/ExtremumGetter.types.js → ChartsLegend/piecewiseColorLegend.types.js} +0 -0
  712. /package/node/{context/PluginProvider/Plugin.types.js → internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js} +0 -0
  713. /package/node/{context/PluginProvider/SeriesFormatter.types.js → internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js} +0 -0
  714. /package/node/{context/SeriesProvider/Series.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js} +0 -0
  715. /package/node/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
  716. /package/node/{context/SizeProvider/Size.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js} +0 -0
@@ -35,7 +35,7 @@ function AnimatedLine(props) {
35
35
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
36
36
  const stringInterpolator = (0, _useStringInterpolator.useStringInterpolator)(d);
37
37
  const transitionChange = (0, _web.useTransition)([stringInterpolator], {
38
- from: {
38
+ from: skipAnimation ? undefined : {
39
39
  value: 0
40
40
  },
41
41
  to: {
@@ -51,6 +51,7 @@ function AnimatedLine(props) {
51
51
  skipAnimation: skipAnimation,
52
52
  id: `${ownerState.id}-line-clip`,
53
53
  children: transitionChange((style, interpolator) => /*#__PURE__*/(0, _jsxRuntime.jsx)(_web.animated.path, (0, _extends2.default)({
54
+ // @ts-expect-error
54
55
  d: style.value.to(interpolator),
55
56
  stroke: ownerState.gradientId ? `url(#${ownerState.gradientId})` : ownerState.color,
56
57
  strokeWidth: 2,
@@ -18,7 +18,7 @@ function AppearingMask(props) {
18
18
  const drawingArea = (0, _hooks.useDrawingArea)();
19
19
  const chartId = (0, _hooks.useChartId)();
20
20
  const transitionAppear = (0, _web.useTransition)([drawingArea], {
21
- from: v => ({
21
+ from: props.skipAnimation ? undefined : v => ({
22
22
  animatedWidth: v.left
23
23
  }),
24
24
  enter: v => ({
@@ -35,6 +35,7 @@ function AppearingMask(props) {
35
35
  children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("clipPath", {
36
36
  id: clipId,
37
37
  children: transitionAppear(style => /*#__PURE__*/(0, _jsxRuntime.jsx)(_web.animated.rect, {
38
+ // @ts-expect-error
38
39
  x: 0,
39
40
  y: 0,
40
41
  width: style.animatedWidth,
@@ -13,14 +13,14 @@ var React = _interopRequireWildcard(require("react"));
13
13
  var _propTypes = _interopRequireDefault(require("prop-types"));
14
14
  var _styles = require("@mui/material/styles");
15
15
  var _d3Shape = require("@mui/x-charts-vendor/d3-shape");
16
- var _CartesianProvider = require("../context/CartesianProvider");
17
16
  var _AreaElement = require("./AreaElement");
18
17
  var _useScale = require("../hooks/useScale");
19
18
  var _getCurve = _interopRequireDefault(require("../internals/getCurve"));
20
19
  var _constants = require("../constants");
21
- var _ChartsAxesGradients = require("../internals/components/ChartsAxesGradients");
22
20
  var _useSeries = require("../hooks/useSeries");
23
21
  var _AnimationProvider = require("../context/AnimationProvider");
22
+ var _useChartGradientId = require("../hooks/useChartGradientId");
23
+ var _useAxis = require("../hooks/useAxis");
24
24
  var _jsxRuntime = require("react/jsx-runtime");
25
25
  const _excluded = ["slots", "slotProps", "onItemClick", "skipAnimation"];
26
26
  const AreaPlotRoot = (0, _styles.styled)('g', {
@@ -34,7 +34,15 @@ const AreaPlotRoot = (0, _styles.styled)('g', {
34
34
  });
35
35
  const useAggregatedData = () => {
36
36
  const seriesData = (0, _useSeries.useLineSeries)();
37
- const axisData = (0, _CartesianProvider.useCartesianContext)();
37
+ const {
38
+ xAxis,
39
+ xAxisIds
40
+ } = (0, _useAxis.useXAxes)();
41
+ const {
42
+ yAxis,
43
+ yAxisIds
44
+ } = (0, _useAxis.useYAxes)();
45
+ const getGradientId = (0, _useChartGradientId.useChartGradientIdBuilder)();
38
46
 
39
47
  // This memo prevents odd line chart behavior when hydrating.
40
48
  const allData = React.useMemo(() => {
@@ -45,12 +53,6 @@ const useAggregatedData = () => {
45
53
  series,
46
54
  stackingGroups
47
55
  } = seriesData;
48
- const {
49
- xAxis,
50
- yAxis,
51
- xAxisIds,
52
- yAxisIds
53
- } = axisData;
54
56
  const defaultXAxisId = xAxisIds[0];
55
57
  const defaultYAxisId = yAxisIds[0];
56
58
  return stackingGroups.flatMap(({
@@ -69,7 +71,7 @@ const useAggregatedData = () => {
69
71
  const xScale = (0, _useScale.getValueToPositionMapper)(xAxis[xAxisId].scale);
70
72
  const yScale = yAxis[yAxisId].scale;
71
73
  const xData = xAxis[xAxisId].data;
72
- const gradientUsed = yAxis[yAxisId].colorScale && [yAxisId, 'y'] || xAxis[xAxisId].colorScale && [xAxisId, 'x'] || undefined;
74
+ const gradientId = yAxis[yAxisId].colorScale && getGradientId(yAxisId) || xAxis[xAxisId].colorScale && getGradientId(xAxisId) || undefined;
73
75
  if (process.env.NODE_ENV !== 'production') {
74
76
  if (xData === undefined) {
75
77
  throw new Error(`MUI X: ${xAxisId === _constants.DEFAULT_X_AXIS_KEY ? 'The first `xAxis`' : `The x-axis with id "${xAxisId}"`} should have data property to be able to display a line plot.`);
@@ -102,13 +104,13 @@ const useAggregatedData = () => {
102
104
  const d3Data = connectNulls ? formattedData.filter((_, i) => data[i] != null) : formattedData;
103
105
  const d = areaPath.curve(curve)(d3Data) || '';
104
106
  return (0, _extends2.default)({}, series[seriesId], {
105
- gradientUsed,
107
+ gradientId,
106
108
  d,
107
109
  seriesId
108
110
  });
109
111
  });
110
112
  });
111
- }, [seriesData, axisData]);
113
+ }, [seriesData, xAxisIds, yAxisIds, xAxis, yAxis, getGradientId]);
112
114
  return allData;
113
115
  };
114
116
 
@@ -132,7 +134,6 @@ function AreaPlot(props) {
132
134
  } = props,
133
135
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
134
136
  const skipAnimation = (0, _AnimationProvider.useSkipAnimation)(inSkipAnimation);
135
- const getGradientId = (0, _ChartsAxesGradients.useChartGradient)();
136
137
  const completedData = useAggregatedData();
137
138
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(AreaPlotRoot, (0, _extends2.default)({}, other, {
138
139
  children: completedData.map(({
@@ -140,12 +141,12 @@ function AreaPlot(props) {
140
141
  seriesId,
141
142
  color,
142
143
  area,
143
- gradientUsed
144
+ gradientId
144
145
  }) => !!area && /*#__PURE__*/(0, _jsxRuntime.jsx)(_AreaElement.AreaElement, {
145
146
  id: seriesId,
146
147
  d: d,
147
148
  color: color,
148
- gradientId: gradientUsed && getGradientId(...gradientUsed),
149
+ gradientId: gradientId,
149
150
  slots: slots,
150
151
  slotProps: slotProps,
151
152
  onClick: onItemClick && (event => onItemClick(event, {
@@ -76,6 +76,7 @@ function CircleMarkElement(props) {
76
76
  };
77
77
  const classes = (0, _markElementClasses.useUtilityClasses)(ownerState);
78
78
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(_web.animated.circle, (0, _extends2.default)({}, other, {
79
+ // @ts-expect-error
79
80
  cx: position.x,
80
81
  cy: position.y,
81
82
  r: 5,
@@ -13,7 +13,6 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
13
13
  var _styles = require("@mui/material/styles");
14
14
  var _AreaPlot = require("./AreaPlot");
15
15
  var _LinePlot = require("./LinePlot");
16
- var _ChartContainer = require("../ChartContainer");
17
16
  var _MarkPlot = require("./MarkPlot");
18
17
  var _ChartsAxis = require("../ChartsAxis/ChartsAxis");
19
18
  var _ChartsTooltip = require("../ChartsTooltip");
@@ -25,6 +24,10 @@ var _ChartsGrid = require("../ChartsGrid");
25
24
  var _ChartsOnAxisClickHandler = require("../ChartsOnAxisClickHandler");
26
25
  var _ChartsOverlay = require("../ChartsOverlay");
27
26
  var _useLineChartProps = require("./useLineChartProps");
27
+ var _useChartContainerProps = require("../ChartContainer/useChartContainerProps");
28
+ var _context = require("../context");
29
+ var _ChartsSurface = require("../ChartsSurface");
30
+ var _ChartsWrapper = require("../internals/components/ChartsWrapper");
28
31
  var _jsxRuntime = require("react/jsx-runtime");
29
32
  /**
30
33
  * Demos:
@@ -42,6 +45,7 @@ const LineChart = exports.LineChart = /*#__PURE__*/React.forwardRef(function Lin
42
45
  name: 'MuiLineChart'
43
46
  });
44
47
  const {
48
+ chartsWrapperProps,
45
49
  chartContainerProps,
46
50
  axisClickHandlerProps,
47
51
  gridProps,
@@ -57,16 +61,22 @@ const LineChart = exports.LineChart = /*#__PURE__*/React.forwardRef(function Lin
57
61
  legendProps,
58
62
  children
59
63
  } = (0, _useLineChartProps.useLineChartProps)(props);
64
+ const {
65
+ chartDataProviderProps,
66
+ chartsSurfaceProps
67
+ } = (0, _useChartContainerProps.useChartContainerProps)(chartContainerProps, ref);
60
68
  const Tooltip = props.slots?.tooltip ?? _ChartsTooltip.ChartsTooltip;
61
- return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_ChartContainer.ChartContainer, (0, _extends2.default)({
62
- ref: ref
63
- }, chartContainerProps, {
64
- children: [props.onAxisClick && /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsOnAxisClickHandler.ChartsOnAxisClickHandler, (0, _extends2.default)({}, axisClickHandlerProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsGrid.ChartsGrid, (0, _extends2.default)({}, gridProps)), /*#__PURE__*/(0, _jsxRuntime.jsxs)("g", (0, _extends2.default)({}, clipPathGroupProps, {
65
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_AreaPlot.AreaPlot, (0, _extends2.default)({}, areaPlotProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_LinePlot.LinePlot, (0, _extends2.default)({}, linePlotProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsOverlay.ChartsOverlay, (0, _extends2.default)({}, overlayProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsAxisHighlight.ChartsAxisHighlight, (0, _extends2.default)({}, axisHighlightProps))]
66
- })), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsAxis.ChartsAxis, (0, _extends2.default)({}, chartsAxisProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)("g", {
67
- "data-drawing-container": true,
68
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_MarkPlot.MarkPlot, (0, _extends2.default)({}, markPlotProps))
69
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_LineHighlightPlot.LineHighlightPlot, (0, _extends2.default)({}, lineHighlightPlotProps)), !props.hideLegend && /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsLegend.ChartsLegend, (0, _extends2.default)({}, legendProps)), !props.loading && /*#__PURE__*/(0, _jsxRuntime.jsx)(Tooltip, (0, _extends2.default)({}, props.slotProps?.tooltip)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsClipPath.ChartsClipPath, (0, _extends2.default)({}, clipPathProps)), children]
69
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_context.ChartDataProvider, (0, _extends2.default)({}, chartDataProviderProps, {
70
+ children: /*#__PURE__*/(0, _jsxRuntime.jsxs)(_ChartsWrapper.ChartsWrapper, (0, _extends2.default)({}, chartsWrapperProps, {
71
+ children: [!props.hideLegend && /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsLegend.ChartsLegend, (0, _extends2.default)({}, legendProps)), /*#__PURE__*/(0, _jsxRuntime.jsxs)(_ChartsSurface.ChartsSurface, (0, _extends2.default)({}, chartsSurfaceProps, {
72
+ children: [props.onAxisClick && /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsOnAxisClickHandler.ChartsOnAxisClickHandler, (0, _extends2.default)({}, axisClickHandlerProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsGrid.ChartsGrid, (0, _extends2.default)({}, gridProps)), /*#__PURE__*/(0, _jsxRuntime.jsxs)("g", (0, _extends2.default)({}, clipPathGroupProps, {
73
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_AreaPlot.AreaPlot, (0, _extends2.default)({}, areaPlotProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_LinePlot.LinePlot, (0, _extends2.default)({}, linePlotProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsOverlay.ChartsOverlay, (0, _extends2.default)({}, overlayProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsAxisHighlight.ChartsAxisHighlight, (0, _extends2.default)({}, axisHighlightProps))]
74
+ })), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsAxis.ChartsAxis, (0, _extends2.default)({}, chartsAxisProps)), /*#__PURE__*/(0, _jsxRuntime.jsx)("g", {
75
+ "data-drawing-container": true,
76
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_MarkPlot.MarkPlot, (0, _extends2.default)({}, markPlotProps))
77
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_LineHighlightPlot.LineHighlightPlot, (0, _extends2.default)({}, lineHighlightPlotProps)), !props.loading && /*#__PURE__*/(0, _jsxRuntime.jsx)(Tooltip, (0, _extends2.default)({}, props.slotProps?.tooltip)), /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsClipPath.ChartsClipPath, (0, _extends2.default)({}, clipPathProps)), children]
78
+ }))]
79
+ }))
70
80
  }));
71
81
  });
72
82
  process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
@@ -74,6 +84,9 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
74
84
  // | These PropTypes are generated from the TypeScript type definitions |
75
85
  // | To update them edit the TypeScript types and run "pnpm proptypes" |
76
86
  // ----------------------------------------------------------------------
87
+ apiRef: _propTypes.default.shape({
88
+ current: _propTypes.default.object
89
+ }),
77
90
  /**
78
91
  * The configuration of axes highlight.
79
92
  * @see See {@link https://mui.com/x/react-charts/highlighting/ highlighting docs} for more details.
@@ -137,6 +150,11 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
137
150
  dataIndex: _propTypes.default.number,
138
151
  seriesId: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.string])
139
152
  }),
153
+ /**
154
+ * This prop is used to help implement the accessibility logic.
155
+ * If you don't provide this prop. It falls back to a randomly generated id.
156
+ */
157
+ id: _propTypes.default.string,
140
158
  /**
141
159
  * Indicate which axis to display the left of the charts.
142
160
  * Can be a string (the id of the axis) or an object `ChartsYAxisProps`.
@@ -152,7 +170,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
152
170
  * The margin between the SVG and the drawing area.
153
171
  * It's used for leaving some space for extra information such as the x- and y-axis or legend.
154
172
  * Accepts an object with the optional properties: `top`, `bottom`, `left`, and `right`.
155
- * @default object Depends on the charts type.
156
173
  */
157
174
  margin: _propTypes.default.shape({
158
175
  bottom: _propTypes.default.number,
@@ -212,6 +229,7 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
212
229
  */
213
230
  slots: _propTypes.default.object,
214
231
  sx: _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object, _propTypes.default.bool])), _propTypes.default.func, _propTypes.default.object]),
232
+ theme: _propTypes.default.oneOf(['dark', 'light']),
215
233
  title: _propTypes.default.string,
216
234
  /**
217
235
  * Indicate which axis to display the top of the charts.
@@ -13,14 +13,14 @@ var React = _interopRequireWildcard(require("react"));
13
13
  var _propTypes = _interopRequireDefault(require("prop-types"));
14
14
  var _useStore = require("../internals/store/useStore");
15
15
  var _useSelector = require("../internals/store/useSelector");
16
- var _CartesianProvider = require("../context/CartesianProvider");
17
16
  var _LineHighlightElement = require("./LineHighlightElement");
18
17
  var _useScale = require("../hooks/useScale");
19
18
  var _constants = require("../constants");
20
19
  var _getColor = _interopRequireDefault(require("./getColor"));
21
20
  var _useSeries = require("../hooks/useSeries");
22
- var _useDrawingArea = require("../hooks/useDrawingArea");
21
+ var _ChartProvider = require("../context/ChartProvider");
23
22
  var _useChartInteraction = require("../internals/plugins/featurePlugins/useChartInteraction");
23
+ var _useAxis = require("../hooks/useAxis");
24
24
  var _jsxRuntime = require("react/jsx-runtime");
25
25
  const _excluded = ["slots", "slotProps"];
26
26
  /**
@@ -40,8 +40,17 @@ function LineHighlightPlot(props) {
40
40
  } = props,
41
41
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
42
42
  const seriesData = (0, _useSeries.useLineSeries)();
43
- const axisData = (0, _CartesianProvider.useCartesianContext)();
44
- const drawingArea = (0, _useDrawingArea.useDrawingArea)();
43
+ const {
44
+ xAxis,
45
+ xAxisIds
46
+ } = (0, _useAxis.useXAxes)();
47
+ const {
48
+ yAxis,
49
+ yAxisIds
50
+ } = (0, _useAxis.useYAxes)();
51
+ const {
52
+ instance
53
+ } = (0, _ChartProvider.useChartContext)();
45
54
  const store = (0, _useStore.useStore)();
46
55
  const xAxisIdentifier = (0, _useSelector.useSelector)(store, _useChartInteraction.selectorChartsInteractionXAxis);
47
56
  const highlightedIndex = xAxisIdentifier?.index;
@@ -55,12 +64,6 @@ function LineHighlightPlot(props) {
55
64
  series,
56
65
  stackingGroups
57
66
  } = seriesData;
58
- const {
59
- xAxis,
60
- yAxis,
61
- xAxisIds,
62
- yAxisIds
63
- } = axisData;
64
67
  const defaultXAxisId = xAxisIds[0];
65
68
  const defaultYAxisId = yAxisIds[0];
66
69
  const Element = slots?.lineHighlight ?? _LineHighlightElement.LineHighlightElement;
@@ -88,7 +91,7 @@ function LineHighlightPlot(props) {
88
91
  const x = xScale(xData[highlightedIndex]);
89
92
  const y = yScale(stackedData[highlightedIndex][1]); // This should not be undefined since y should not be a band scale
90
93
 
91
- if (!drawingArea.isPointInside({
94
+ if (!instance.isPointInside({
92
95
  x,
93
96
  y
94
97
  })) {
@@ -13,14 +13,14 @@ var React = _interopRequireWildcard(require("react"));
13
13
  var _propTypes = _interopRequireDefault(require("prop-types"));
14
14
  var _styles = require("@mui/material/styles");
15
15
  var _d3Shape = require("@mui/x-charts-vendor/d3-shape");
16
- var _CartesianProvider = require("../context/CartesianProvider");
17
16
  var _LineElement = require("./LineElement");
18
17
  var _useScale = require("../hooks/useScale");
19
18
  var _getCurve = _interopRequireDefault(require("../internals/getCurve"));
20
19
  var _constants = require("../constants");
21
- var _ChartsAxesGradients = require("../internals/components/ChartsAxesGradients");
22
20
  var _useSeries = require("../hooks/useSeries");
23
21
  var _AnimationProvider = require("../context/AnimationProvider");
22
+ var _useChartGradientId = require("../hooks/useChartGradientId");
23
+ var _hooks = require("../hooks");
24
24
  var _jsxRuntime = require("react/jsx-runtime");
25
25
  const _excluded = ["slots", "slotProps", "skipAnimation", "onItemClick"];
26
26
  const LinePlotRoot = (0, _styles.styled)('g', {
@@ -34,7 +34,15 @@ const LinePlotRoot = (0, _styles.styled)('g', {
34
34
  });
35
35
  const useAggregatedData = () => {
36
36
  const seriesData = (0, _useSeries.useLineSeries)();
37
- const axisData = (0, _CartesianProvider.useCartesianContext)();
37
+ const {
38
+ xAxis,
39
+ xAxisIds
40
+ } = (0, _hooks.useXAxes)();
41
+ const {
42
+ yAxis,
43
+ yAxisIds
44
+ } = (0, _hooks.useYAxes)();
45
+ const getGradientId = (0, _useChartGradientId.useChartGradientIdBuilder)();
38
46
 
39
47
  // This memo prevents odd line chart behavior when hydrating.
40
48
  const allData = React.useMemo(() => {
@@ -45,12 +53,6 @@ const useAggregatedData = () => {
45
53
  series,
46
54
  stackingGroups
47
55
  } = seriesData;
48
- const {
49
- xAxis,
50
- yAxis,
51
- xAxisIds,
52
- yAxisIds
53
- } = axisData;
54
56
  const defaultXAxisId = xAxisIds[0];
55
57
  const defaultYAxisId = yAxisIds[0];
56
58
  return stackingGroups.flatMap(({
@@ -67,7 +69,7 @@ const useAggregatedData = () => {
67
69
  const xScale = (0, _useScale.getValueToPositionMapper)(xAxis[xAxisId].scale);
68
70
  const yScale = yAxis[yAxisId].scale;
69
71
  const xData = xAxis[xAxisId].data;
70
- const gradientUsed = yAxis[yAxisId].colorScale && [yAxisId, 'y'] || xAxis[xAxisId].colorScale && [xAxisId, 'x'] || undefined;
72
+ const gradientId = yAxis[yAxisId].colorScale && getGradientId(yAxisId) || xAxis[xAxisId].colorScale && getGradientId(xAxisId) || undefined;
71
73
  if (process.env.NODE_ENV !== 'production') {
72
74
  if (xData === undefined) {
73
75
  throw new Error(`MUI X: ${xAxisId === _constants.DEFAULT_X_AXIS_KEY ? 'The first `xAxis`' : `The x-axis with id "${xAxisId}"`} should have data property to be able to display a line plot.`);
@@ -84,13 +86,13 @@ const useAggregatedData = () => {
84
86
  const d3Data = connectNulls ? formattedData.filter((_, i) => data[i] != null) : formattedData;
85
87
  const d = linePath.curve((0, _getCurve.default)(series[seriesId].curve))(d3Data) || '';
86
88
  return (0, _extends2.default)({}, series[seriesId], {
87
- gradientUsed,
89
+ gradientId,
88
90
  d,
89
91
  seriesId
90
92
  });
91
93
  });
92
94
  });
93
- }, [seriesData, axisData]);
95
+ }, [seriesData, xAxisIds, yAxisIds, xAxis, yAxis, getGradientId]);
94
96
  return allData;
95
97
  };
96
98
 
@@ -113,20 +115,19 @@ function LinePlot(props) {
113
115
  } = props,
114
116
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
115
117
  const skipAnimation = (0, _AnimationProvider.useSkipAnimation)(inSkipAnimation);
116
- const getGradientId = (0, _ChartsAxesGradients.useChartGradient)();
117
118
  const completedData = useAggregatedData();
118
119
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(LinePlotRoot, (0, _extends2.default)({}, other, {
119
120
  children: completedData.map(({
120
121
  d,
121
122
  seriesId,
122
123
  color,
123
- gradientUsed
124
+ gradientId
124
125
  }) => {
125
126
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(_LineElement.LineElement, {
126
127
  id: seriesId,
127
128
  d: d,
128
129
  color: color,
129
- gradientId: gradientUsed && getGradientId(...gradientUsed),
130
+ gradientId: gradientId,
130
131
  skipAnimation: skipAnimation,
131
132
  slots: slots,
132
133
  slotProps: slotProps,
@@ -87,7 +87,9 @@ function MarkElement(props) {
87
87
  transform: (0, _web.to)([position.x, position.y], (pX, pY) => `translate(${pX}px, ${pY}px)`),
88
88
  transformOrigin: (0, _web.to)([position.x, position.y], (pX, pY) => `${pX}px ${pY}px`)
89
89
  },
90
- ownerState: ownerState,
90
+ ownerState: ownerState
91
+ // @ts-expect-error
92
+ ,
91
93
  className: classes.root,
92
94
  d: (0, _d3Shape.symbol)(_d3Shape.symbolsFill[(0, _getSymbol.getSymbol)(shape)])(),
93
95
  onClick: onClick,
@@ -13,15 +13,15 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
13
13
  var React = _interopRequireWildcard(require("react"));
14
14
  var _constants = require("../constants");
15
15
  var _AnimationProvider = require("../context/AnimationProvider");
16
- var _CartesianProvider = require("../context/CartesianProvider");
17
16
  var _useChartId = require("../hooks/useChartId");
18
- var _useDrawingArea = require("../hooks/useDrawingArea");
19
17
  var _useScale = require("../hooks/useScale");
20
18
  var _useSeries = require("../hooks/useSeries");
21
19
  var _cleanId = require("../internals/cleanId");
22
20
  var _CircleMarkElement = require("./CircleMarkElement");
23
21
  var _getColor = _interopRequireDefault(require("./getColor"));
24
22
  var _MarkElement = require("./MarkElement");
23
+ var _ChartProvider = require("../context/ChartProvider");
24
+ var _hooks = require("../hooks");
25
25
  var _jsxRuntime = require("react/jsx-runtime");
26
26
  const _excluded = ["slots", "slotProps", "skipAnimation", "onItemClick", "experimentalRendering"];
27
27
  /**
@@ -45,9 +45,18 @@ function MarkPlot(props) {
45
45
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
46
46
  const skipAnimation = (0, _AnimationProvider.useSkipAnimation)(inSkipAnimation);
47
47
  const seriesData = (0, _useSeries.useLineSeries)();
48
- const axisData = (0, _CartesianProvider.useCartesianContext)();
48
+ const {
49
+ xAxis,
50
+ xAxisIds
51
+ } = (0, _hooks.useXAxes)();
52
+ const {
53
+ yAxis,
54
+ yAxisIds
55
+ } = (0, _hooks.useYAxes)();
49
56
  const chartId = (0, _useChartId.useChartId)();
50
- const drawingArea = (0, _useDrawingArea.useDrawingArea)();
57
+ const {
58
+ instance
59
+ } = (0, _ChartProvider.useChartContext)();
51
60
  const Mark = slots?.mark ?? (experimentalRendering ? _CircleMarkElement.CircleMarkElement : _MarkElement.MarkElement);
52
61
  if (seriesData === undefined) {
53
62
  return null;
@@ -56,12 +65,6 @@ function MarkPlot(props) {
56
65
  series,
57
66
  stackingGroups
58
67
  } = seriesData;
59
- const {
60
- xAxis,
61
- yAxis,
62
- xAxisIds,
63
- yAxisIds
64
- } = axisData;
65
68
  const defaultXAxisId = xAxisIds[0];
66
69
  const defaultYAxisId = yAxisIds[0];
67
70
  return /*#__PURE__*/(0, _jsxRuntime.jsx)("g", (0, _extends2.default)({}, other, {
@@ -110,7 +113,7 @@ function MarkPlot(props) {
110
113
  // Remove missing data point
111
114
  return false;
112
115
  }
113
- if (!drawingArea.isPointInside({
116
+ if (!instance.isPointInside({
114
117
  x,
115
118
  y
116
119
  })) {
@@ -56,7 +56,9 @@ const formatter = (params, dataset) => {
56
56
  .order(stackingOrder).offset(stackingOffset)(d3Dataset);
57
57
  ids.forEach((id, index) => {
58
58
  const dataKey = series[id].dataKey;
59
- completedSeries[id] = (0, _extends2.default)({}, series[id], {
59
+ completedSeries[id] = (0, _extends2.default)({
60
+ labelMarkType: 'line'
61
+ }, series[id], {
60
62
  data: dataKey ? dataset.map(data => {
61
63
  const value = data[dataKey];
62
64
  if (typeof value !== 'number') {
@@ -16,6 +16,7 @@ const legendGetter = params => {
16
16
  return acc;
17
17
  }
18
18
  acc.push({
19
+ markType: series[seriesId].labelMarkType,
19
20
  id: seriesId,
20
21
  seriesId,
21
22
  color: series[seriesId].color,
@@ -9,9 +9,8 @@ var _extremums = require("./extremums");
9
9
  var _formatter = _interopRequireDefault(require("./formatter"));
10
10
  var _getColor = _interopRequireDefault(require("./getColor"));
11
11
  const plugin = exports.plugin = {
12
- seriesType: 'line',
13
12
  colorProcessor: _getColor.default,
14
- seriesFormatter: _formatter.default,
13
+ seriesProcessor: _formatter.default,
15
14
  xExtremumGetter: _extremums.getExtremumX,
16
15
  yExtremumGetter: _extremums.getExtremumY
17
16
  };
@@ -10,6 +10,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
10
10
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
11
11
  var _useId = _interopRequireDefault(require("@mui/utils/useId"));
12
12
  var _constants = require("../constants");
13
+ var _calculateMargins = require("../internals/calculateMargins");
13
14
  const _excluded = ["xAxis", "yAxis", "series", "width", "height", "margin", "colors", "dataset", "sx", "onAxisClick", "onAreaClick", "onLineClick", "onMarkClick", "axisHighlight", "disableLineItemHighlight", "hideLegend", "grid", "topAxis", "leftAxis", "rightAxis", "bottomAxis", "children", "slots", "slotProps", "skipAnimation", "loading", "highlightedItem", "onHighlightChange", "className", "experimentalMarkRendering"];
14
15
  /**
15
16
  * A helper function that extracts LineChartProps from the input props
@@ -35,6 +36,7 @@ const useLineChartProps = props => {
35
36
  onMarkClick,
36
37
  axisHighlight,
37
38
  disableLineItemHighlight,
39
+ hideLegend,
38
40
  grid,
39
41
  topAxis,
40
42
  leftAxis,
@@ -60,7 +62,12 @@ const useLineChartProps = props => {
60
62
  }, s)),
61
63
  width,
62
64
  height,
63
- margin,
65
+ margin: (0, _calculateMargins.calculateMargins)({
66
+ margin,
67
+ hideLegend,
68
+ slotProps,
69
+ series
70
+ }),
64
71
  colors,
65
72
  dataset,
66
73
  xAxis: xAxis ?? [{
@@ -71,7 +78,6 @@ const useLineChartProps = props => {
71
78
  }, (_, index) => index)
72
79
  }],
73
80
  yAxis,
74
- sx,
75
81
  highlightedItem,
76
82
  onHighlightChange,
77
83
  disableAxisListener: slotProps?.tooltip?.trigger !== 'axis' && axisHighlight?.x === 'none' && axisHighlight?.y === 'none' && !onAxisClick,
@@ -132,7 +138,13 @@ const useLineChartProps = props => {
132
138
  slots,
133
139
  slotProps
134
140
  };
141
+ const chartsWrapperProps = {
142
+ sx,
143
+ legendPosition: props.slotProps?.legend?.position,
144
+ legendDirection: props.slotProps?.legend?.direction
145
+ };
135
146
  return {
147
+ chartsWrapperProps,
136
148
  chartContainerProps,
137
149
  axisClickHandlerProps,
138
150
  gridProps,
@@ -85,7 +85,9 @@ function PieArc(props) {
85
85
  innerRadius: iR,
86
86
  outerRadius: oR
87
87
  })),
88
- visibility: (0, _web.to)([startAngle, endAngle], (sA, eA) => sA === eA ? 'hidden' : 'visible'),
88
+ visibility: (0, _web.to)([startAngle, endAngle], (sA, eA) => sA === eA ? 'hidden' : 'visible')
89
+ // @ts-expect-error
90
+ ,
89
91
  onClick: onClick,
90
92
  cursor: onClick ? 'pointer' : 'unset',
91
93
  ownerState: ownerState,
@@ -93,15 +93,19 @@ function PieArcLabel(props) {
93
93
  isHighlighted
94
94
  };
95
95
  const classes = useUtilityClasses(ownerState);
96
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(PieArcLabelRoot, (0, _extends2.default)({
97
- className: classes.root
98
- }, other, {
99
- style: (0, _extends2.default)({
100
- x: (0, _web.to)([startAngle, endAngle, paddingAngle, arcLabelRadius, cornerRadius], getLabelPosition(formattedArcLabel, 'x')),
101
- y: (0, _web.to)([startAngle, endAngle, paddingAngle, arcLabelRadius, cornerRadius], getLabelPosition(formattedArcLabel, 'y'))
102
- }, style),
103
- children: formattedArcLabel
104
- }));
96
+ return (
97
+ /*#__PURE__*/
98
+ // @ts-expect-error
99
+ (0, _jsxRuntime.jsx)(PieArcLabelRoot, (0, _extends2.default)({
100
+ className: classes.root
101
+ }, other, {
102
+ style: (0, _extends2.default)({
103
+ x: (0, _web.to)([startAngle, endAngle, paddingAngle, arcLabelRadius, cornerRadius], getLabelPosition(formattedArcLabel, 'x')),
104
+ y: (0, _web.to)([startAngle, endAngle, paddingAngle, arcLabelRadius, cornerRadius], getLabelPosition(formattedArcLabel, 'y'))
105
+ }, style),
106
+ children: formattedArcLabel
107
+ }))
108
+ );
105
109
  }
106
110
  process.env.NODE_ENV !== "production" ? PieArcLabel.propTypes = {
107
111
  // ----------------------------- Warning --------------------------------
@@ -72,7 +72,7 @@ function PieArcLabelPlot(props) {
72
72
  faded,
73
73
  data
74
74
  });
75
- const transition = (0, _web.useTransition)(transformedData, (0, _extends2.default)({}, _transition.defaultLabelTransitionConfig, {
75
+ const transition = (0, _web.useTransition)(transformedData, (0, _extends2.default)({}, (0, _transition.getDefaultLabelTransitionConfig)(skipAnimation), {
76
76
  immediate: skipAnimation
77
77
  }));
78
78
  if (data.length === 0) {
@@ -140,6 +140,7 @@ process.env.NODE_ENV !== "production" ? PieArcLabelPlot.propTypes = {
140
140
  id: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.string]).isRequired,
141
141
  index: _propTypes.default.number.isRequired,
142
142
  label: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.string]),
143
+ labelMarkType: _propTypes.default.oneOf(['circle', 'line', 'square']),
143
144
  padAngle: _propTypes.default.number.isRequired,
144
145
  startAngle: _propTypes.default.number.isRequired,
145
146
  value: _propTypes.default.number.isRequired
@@ -45,7 +45,7 @@ function PieArcPlot(props) {
45
45
  faded,
46
46
  data
47
47
  });
48
- const transition = (0, _web.useTransition)(transformedData, (0, _extends2.default)({}, _transition.defaultTransitionConfig, {
48
+ const transition = (0, _web.useTransition)(transformedData, (0, _extends2.default)({}, (0, _transition.getDefaultTransitionConfig)(skipAnimation), {
49
49
  immediate: skipAnimation
50
50
  }));
51
51
  if (data.length === 0) {
@@ -106,6 +106,7 @@ process.env.NODE_ENV !== "production" ? PieArcPlot.propTypes = {
106
106
  id: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.string]).isRequired,
107
107
  index: _propTypes.default.number.isRequired,
108
108
  label: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.string]),
109
+ labelMarkType: _propTypes.default.oneOf(['circle', 'line', 'square']),
109
110
  padAngle: _propTypes.default.number.isRequired,
110
111
  startAngle: _propTypes.default.number.isRequired,
111
112
  value: _propTypes.default.number.isRequired