@mui/x-charts 8.0.0-alpha.1 → 8.0.0-alpha.10

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 (1020) hide show
  1. package/BarChart/AnimatedBarElement.js +1 -0
  2. package/BarChart/BarChart.d.ts +1 -1
  3. package/BarChart/BarChart.js +29 -14
  4. package/BarChart/BarElement.js +1 -1
  5. package/BarChart/BarLabel/BarLabel.d.ts +2 -480
  6. package/BarChart/BarLabel/BarLabelItem.js +1 -1
  7. package/BarChart/BarLabel/BarLabelPlot.js +1 -1
  8. package/BarChart/BarLabel/barLabelClasses.d.ts +1 -1
  9. package/BarChart/BarPlot.js +8 -9
  10. package/BarChart/extremums.d.ts +3 -3
  11. package/BarChart/formatter.d.ts +2 -2
  12. package/BarChart/formatter.js +2 -1
  13. package/BarChart/getColor.d.ts +1 -1
  14. package/BarChart/legend.d.ts +1 -1
  15. package/BarChart/legend.js +1 -0
  16. package/BarChart/plugin.d.ts +2 -2
  17. package/BarChart/plugin.js +5 -2
  18. package/BarChart/tooltip.d.ts +3 -0
  19. package/BarChart/tooltip.js +25 -0
  20. package/BarChart/useBarChartProps.d.ts +5 -3
  21. package/BarChart/useBarChartProps.js +16 -3
  22. package/CHANGELOG.md +1903 -231
  23. package/ChartContainer/ChartContainer.d.ts +31 -3
  24. package/ChartContainer/ChartContainer.js +43 -20
  25. package/ChartContainer/useChartContainerProps.d.ts +6 -5
  26. package/ChartContainer/useChartContainerProps.js +10 -9
  27. package/ChartDataProvider/ChartDataProvider.d.ts +41 -0
  28. package/ChartDataProvider/ChartDataProvider.js +94 -0
  29. package/ChartDataProvider/package.json +6 -0
  30. package/ChartDataProvider/useChartDataProviderProps.d.ts +11 -0
  31. package/ChartDataProvider/useChartDataProviderProps.js +45 -0
  32. package/ChartsAxis/ChartsAxis.js +5 -7
  33. package/ChartsAxis/axisClasses.js +2 -1
  34. package/ChartsAxisHighlight/ChartsXAxisHighlight.js +3 -3
  35. package/ChartsAxisHighlight/ChartsYAxisHighlight.js +3 -3
  36. package/ChartsGrid/ChartsGrid.js +9 -5
  37. package/ChartsGrid/ChartsHorizontalGrid.d.ts +2 -2
  38. package/ChartsGrid/ChartsHorizontalGrid.js +4 -3
  39. package/ChartsGrid/ChartsVerticalGrid.d.ts +2 -2
  40. package/ChartsGrid/ChartsVerticalGrid.js +4 -3
  41. package/ChartsLabel/ChartsLabel.d.ts +18 -0
  42. package/ChartsLabel/ChartsLabel.js +43 -0
  43. package/ChartsLabel/ChartsLabelGradient.d.ts +41 -0
  44. package/ChartsLabel/ChartsLabelGradient.js +135 -0
  45. package/ChartsLabel/ChartsLabelMark.d.ts +26 -0
  46. package/ChartsLabel/ChartsLabelMark.js +111 -0
  47. package/ChartsLabel/index.d.ts +7 -0
  48. package/ChartsLabel/index.js +6 -0
  49. package/ChartsLabel/labelClasses.d.ts +8 -0
  50. package/ChartsLabel/labelClasses.js +13 -0
  51. package/ChartsLabel/labelGradientClasses.d.ts +16 -0
  52. package/ChartsLabel/labelGradientClasses.js +18 -0
  53. package/ChartsLabel/labelMarkClasses.d.ts +18 -0
  54. package/ChartsLabel/labelMarkClasses.js +18 -0
  55. package/ChartsLabel/package.json +6 -0
  56. package/ChartsLegend/ChartsLegend.d.ts +18 -22
  57. package/ChartsLegend/ChartsLegend.js +100 -109
  58. package/ChartsLegend/ContinuousColorLegend.d.ts +29 -38
  59. package/ChartsLegend/ContinuousColorLegend.js +198 -321
  60. package/ChartsLegend/PiecewiseColorLegend.d.ts +27 -19
  61. package/ChartsLegend/PiecewiseColorLegend.js +201 -111
  62. package/ChartsLegend/chartsLegend.types.d.ts +17 -60
  63. package/ChartsLegend/chartsLegendClasses.d.ts +7 -8
  64. package/ChartsLegend/chartsLegendClasses.js +18 -3
  65. package/ChartsLegend/colorLegend.types.d.ts +13 -0
  66. package/ChartsLegend/continuousColorLegendClasses.d.ts +26 -0
  67. package/ChartsLegend/continuousColorLegendClasses.js +23 -0
  68. package/ChartsLegend/direction.d.ts +1 -0
  69. package/ChartsLegend/index.d.ts +13 -3
  70. package/ChartsLegend/index.js +9 -3
  71. package/ChartsLegend/legend.types.d.ts +6 -59
  72. package/ChartsLegend/legendContext.types.d.ts +55 -0
  73. package/ChartsLegend/onClickContextBuilder.d.ts +2 -0
  74. package/ChartsLegend/onClickContextBuilder.js +7 -0
  75. package/ChartsLegend/piecewiseColorDefaultLabelFormatter.d.ts +2 -0
  76. package/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +9 -0
  77. package/ChartsLegend/piecewiseColorLegend.types.d.ts +26 -0
  78. package/ChartsLegend/piecewiseColorLegendClasses.d.ts +28 -0
  79. package/ChartsLegend/piecewiseColorLegendClasses.js +23 -0
  80. package/ChartsLegend/useAxis.d.ts +1 -1
  81. package/ChartsLegend/useAxis.js +7 -6
  82. package/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +8 -7
  83. package/ChartsReferenceLine/ChartsXReferenceLine.d.ts +1 -1
  84. package/ChartsReferenceLine/ChartsYReferenceLine.d.ts +1 -1
  85. package/ChartsSurface/ChartsSurface.d.ts +14 -0
  86. package/ChartsSurface/ChartsSurface.js +45 -24
  87. package/ChartsTooltip/ChartsAxisTooltipContent.js +11 -6
  88. package/ChartsTooltip/ChartsItemTooltipContent.js +6 -3
  89. package/ChartsTooltip/ChartsTooltip.js +2 -20
  90. package/ChartsTooltip/ChartsTooltipContainer.js +5 -23
  91. package/ChartsTooltip/ChartsTooltipTable.d.ts +0 -6
  92. package/ChartsTooltip/ChartsTooltipTable.js +15 -33
  93. package/ChartsTooltip/chartsTooltipClasses.d.ts +3 -1
  94. package/ChartsTooltip/chartsTooltipClasses.js +3 -2
  95. package/ChartsTooltip/index.d.ts +1 -0
  96. package/ChartsTooltip/index.js +2 -1
  97. package/ChartsTooltip/useAxisTooltip.d.ts +3 -1
  98. package/ChartsTooltip/useAxisTooltip.js +16 -13
  99. package/ChartsTooltip/useItemTooltip.d.ts +8 -6
  100. package/ChartsTooltip/useItemTooltip.js +20 -45
  101. package/ChartsTooltip/utils.js +2 -0
  102. package/ChartsVoronoiHandler/ChartsVoronoiHandler.js +22 -20
  103. package/ChartsXAxis/ChartsXAxis.js +14 -25
  104. package/ChartsYAxis/ChartsYAxis.js +10 -22
  105. package/Gauge/Gauge.d.ts +1 -1
  106. package/Gauge/Gauge.js +5 -1
  107. package/Gauge/GaugeContainer.d.ts +4 -11
  108. package/Gauge/GaugeContainer.js +44 -77
  109. package/Gauge/GaugeProvider.js +2 -0
  110. package/LineChart/AnimatedArea.js +2 -1
  111. package/LineChart/AnimatedLine.js +2 -1
  112. package/LineChart/AppearingMask.js +2 -1
  113. package/LineChart/AreaElement.js +1 -1
  114. package/LineChart/AreaPlot.js +60 -26
  115. package/LineChart/CircleMarkElement.d.ts +0 -4
  116. package/LineChart/CircleMarkElement.js +7 -11
  117. package/LineChart/LineChart.d.ts +0 -4
  118. package/LineChart/LineChart.js +32 -21
  119. package/LineChart/LineElement.js +1 -1
  120. package/LineChart/LineHighlightElement.d.ts +5 -1
  121. package/LineChart/LineHighlightElement.js +29 -9
  122. package/LineChart/LineHighlightPlot.js +21 -16
  123. package/LineChart/LinePlot.js +60 -25
  124. package/LineChart/MarkElement.js +7 -5
  125. package/LineChart/MarkPlot.d.ts +0 -6
  126. package/LineChart/MarkPlot.js +20 -23
  127. package/LineChart/extremums.d.ts +3 -3
  128. package/LineChart/formatter.d.ts +2 -2
  129. package/LineChart/formatter.js +3 -1
  130. package/LineChart/getColor.d.ts +1 -1
  131. package/LineChart/legend.d.ts +1 -1
  132. package/LineChart/legend.js +1 -0
  133. package/LineChart/plugin.d.ts +2 -2
  134. package/LineChart/plugin.js +5 -2
  135. package/LineChart/tooltip.d.ts +3 -0
  136. package/LineChart/tooltip.js +25 -0
  137. package/LineChart/useLineChartProps.d.ts +5 -3
  138. package/LineChart/useLineChartProps.js +18 -7
  139. package/PieChart/PieArc.js +14 -6
  140. package/PieChart/PieArcLabel.js +13 -9
  141. package/PieChart/PieArcLabelPlot.js +4 -3
  142. package/PieChart/PieArcPlot.js +13 -16
  143. package/PieChart/PieChart.js +54 -48
  144. package/PieChart/PiePlot.js +2 -2
  145. package/PieChart/dataTransform/transition.d.ts +2 -2
  146. package/PieChart/dataTransform/transition.js +8 -8
  147. package/PieChart/dataTransform/useTransformData.d.ts +1 -0
  148. package/PieChart/dataTransform/useTransformData.js +3 -2
  149. package/PieChart/formatter.d.ts +2 -2
  150. package/PieChart/formatter.js +4 -1
  151. package/PieChart/getColor.d.ts +1 -1
  152. package/PieChart/getPieCoordinates.d.ts +2 -2
  153. package/PieChart/legend.d.ts +1 -1
  154. package/PieChart/legend.js +4 -3
  155. package/PieChart/plugin.d.ts +2 -2
  156. package/PieChart/plugin.js +5 -2
  157. package/PieChart/tooltip.d.ts +3 -0
  158. package/PieChart/tooltip.js +29 -0
  159. package/README.md +1 -1
  160. package/ScatterChart/Scatter.js +12 -10
  161. package/ScatterChart/ScatterChart.d.ts +1 -2
  162. package/ScatterChart/ScatterChart.js +31 -20
  163. package/ScatterChart/ScatterPlot.js +11 -10
  164. package/ScatterChart/extremums.d.ts +3 -3
  165. package/ScatterChart/extremums.js +1 -1
  166. package/ScatterChart/formatter.d.ts +2 -2
  167. package/ScatterChart/formatter.js +7 -5
  168. package/ScatterChart/getColor.d.ts +1 -1
  169. package/ScatterChart/legend.d.ts +1 -1
  170. package/ScatterChart/legend.js +1 -0
  171. package/ScatterChart/plugin.d.ts +2 -2
  172. package/ScatterChart/plugin.js +5 -2
  173. package/ScatterChart/tooltip.d.ts +3 -0
  174. package/ScatterChart/tooltip.js +25 -0
  175. package/ScatterChart/useScatterChartProps.d.ts +5 -5
  176. package/ScatterChart/useScatterChartProps.js +16 -6
  177. package/SparkLineChart/SparkLineChart.d.ts +2 -2
  178. package/SparkLineChart/SparkLineChart.js +16 -13
  179. package/colorPalettes/colorPalettes.d.ts +3 -0
  180. package/colorPalettes/colorPalettes.js +3 -0
  181. package/constants/index.d.ts +1 -0
  182. package/constants/index.js +2 -1
  183. package/context/AnimationProvider/AnimationProvider.js +1 -1
  184. package/context/ChartProvider/ChartContext.d.ts +6 -0
  185. package/context/ChartProvider/ChartContext.js +8 -0
  186. package/context/ChartProvider/ChartProvider.d.ts +8 -0
  187. package/context/ChartProvider/ChartProvider.js +40 -0
  188. package/context/ChartProvider/ChartProvider.types.d.ts +39 -0
  189. package/context/ChartProvider/index.d.ts +3 -0
  190. package/context/ChartProvider/index.js +3 -0
  191. package/context/ChartProvider/useChartContext.d.ts +3 -0
  192. package/context/ChartProvider/useChartContext.js +11 -0
  193. package/context/PolarProvider/PolarProvider.d.ts +0 -4
  194. package/context/PolarProvider/PolarProvider.js +59 -47
  195. package/context/PolarProvider/getAxisExtremum.d.ts +0 -4
  196. package/context/PolarProvider/getAxisExtremum.js +48 -20
  197. package/context/PolarProvider/usePolarContext.d.ts +0 -2
  198. package/context/PolarProvider/usePolarContext.js +9 -8
  199. package/context/index.d.ts +1 -5
  200. package/context/index.js +1 -3
  201. package/hooks/index.d.ts +5 -0
  202. package/hooks/index.js +6 -1
  203. package/hooks/useAxis.d.ts +9 -1
  204. package/hooks/useAxis.js +32 -6
  205. package/hooks/useAxisEvents.js +13 -9
  206. package/hooks/useChartGradientId.d.ts +31 -0
  207. package/hooks/useChartGradientId.js +47 -0
  208. package/hooks/useChartId.d.ts +1 -1
  209. package/hooks/useChartId.js +5 -6
  210. package/hooks/useColorScale.js +5 -6
  211. package/hooks/useDrawingArea.d.ts +16 -2
  212. package/hooks/useDrawingArea.js +5 -20
  213. package/hooks/useInteractionItemProps.js +10 -27
  214. package/hooks/useItemHighlighted.d.ts +23 -0
  215. package/hooks/useItemHighlighted.js +23 -0
  216. package/hooks/useItemHighlightedGetter.d.ts +12 -0
  217. package/hooks/useItemHighlightedGetter.js +23 -0
  218. package/hooks/useLegend.d.ts +13 -0
  219. package/hooks/useLegend.js +30 -0
  220. package/hooks/useSeries.d.ts +11 -6
  221. package/hooks/useSeries.js +5 -10
  222. package/hooks/useSvgRef.d.ts +1 -1
  223. package/hooks/useSvgRef.js +4 -8
  224. package/hooks/useZAxis.d.ts +7 -0
  225. package/hooks/useZAxis.js +27 -0
  226. package/index.d.ts +2 -0
  227. package/index.js +4 -2
  228. package/internals/calculateMargins.d.ts +7 -0
  229. package/internals/calculateMargins.js +25 -0
  230. package/internals/components/ChartsAxesGradients/ChartsAxesGradients.d.ts +0 -2
  231. package/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +65 -32
  232. package/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
  233. package/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.d.ts +13 -0
  234. package/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +61 -0
  235. package/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.d.ts +1 -1
  236. package/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
  237. package/internals/components/ChartsWrapper/ChartsWrapper.d.ts +18 -0
  238. package/internals/components/ChartsWrapper/ChartsWrapper.js +66 -0
  239. package/internals/components/ChartsWrapper/index.d.ts +1 -0
  240. package/internals/components/ChartsWrapper/index.js +1 -0
  241. package/internals/consumeSlots.d.ts +48 -0
  242. package/internals/consumeSlots.js +101 -0
  243. package/internals/consumeThemeProps.d.ts +50 -0
  244. package/internals/consumeThemeProps.js +70 -0
  245. package/internals/defaultizeColor.d.ts +29 -22
  246. package/internals/defaultizeColor.js +1 -2
  247. package/internals/getCurve.d.ts +2 -2
  248. package/internals/getCurve.js +14 -26
  249. package/internals/index.d.ts +18 -13
  250. package/internals/index.js +21 -14
  251. package/internals/plugins/allPlugins.d.ts +14 -0
  252. package/internals/plugins/allPlugins.js +7 -0
  253. package/internals/plugins/corePlugins/corePlugins.d.ts +10 -0
  254. package/internals/plugins/corePlugins/corePlugins.js +9 -0
  255. package/internals/plugins/corePlugins/index.d.ts +2 -0
  256. package/internals/plugins/corePlugins/index.js +1 -0
  257. package/internals/plugins/corePlugins/useChartDimensions/index.d.ts +3 -0
  258. package/internals/plugins/corePlugins/useChartDimensions/index.js +2 -0
  259. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.d.ts +3 -0
  260. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +175 -0
  261. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.d.ts +264 -0
  262. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +25 -0
  263. package/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.d.ts +99 -0
  264. package/internals/plugins/corePlugins/useChartId/index.d.ts +3 -0
  265. package/internals/plugins/corePlugins/useChartId/index.js +2 -0
  266. package/internals/plugins/corePlugins/useChartId/useChartId.d.ts +3 -0
  267. package/internals/plugins/corePlugins/useChartId/useChartId.js +32 -0
  268. package/internals/plugins/corePlugins/useChartId/useChartId.selectors.d.ts +36 -0
  269. package/internals/plugins/corePlugins/useChartId/useChartId.selectors.js +9 -0
  270. package/internals/plugins/corePlugins/useChartId/useChartId.types.d.ts +20 -0
  271. package/internals/plugins/corePlugins/useChartId/useChartId.utils.d.ts +1 -0
  272. package/internals/plugins/corePlugins/useChartId/useChartId.utils.js +5 -0
  273. package/internals/plugins/corePlugins/useChartSeries/index.d.ts +3 -0
  274. package/internals/plugins/corePlugins/useChartSeries/index.js +2 -0
  275. package/internals/plugins/corePlugins/useChartSeries/processSeries.d.ts +18 -0
  276. package/{modern/context/SeriesProvider → internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
  277. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.d.ts +3 -0
  278. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +72 -0
  279. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.d.ts +61 -0
  280. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +4 -0
  281. package/internals/plugins/corePlugins/useChartSeries/useChartSeries.types.d.ts +51 -0
  282. package/internals/plugins/corePlugins/useChartSeries/useColorProcessor.d.ts +10 -0
  283. package/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +21 -0
  284. package/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.d.ts +29 -0
  285. package/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
  286. package/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.d.ts +18 -0
  287. package/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +61 -0
  288. package/internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.d.ts +39 -0
  289. package/{modern/context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +3 -11
  290. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.d.ts +6 -0
  291. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +22 -0
  292. package/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +6 -0
  293. package/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +5 -0
  294. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.d.ts +4 -0
  295. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +68 -0
  296. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.d.ts +1336 -0
  297. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +89 -0
  298. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.d.ts +75 -0
  299. package/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.d.ts +18 -0
  300. package/internals/plugins/featurePlugins/useChartHighlight/createIsFaded.d.ts +3 -0
  301. package/internals/plugins/featurePlugins/useChartHighlight/createIsFaded.js +12 -0
  302. package/internals/plugins/featurePlugins/useChartHighlight/createIsHighlighted.d.ts +3 -0
  303. package/internals/plugins/featurePlugins/useChartHighlight/createIsHighlighted.js +12 -0
  304. package/internals/plugins/featurePlugins/useChartHighlight/highlightConfig.types.d.ts +20 -0
  305. package/internals/plugins/featurePlugins/useChartHighlight/index.d.ts +4 -0
  306. package/internals/plugins/featurePlugins/useChartHighlight/index.js +2 -0
  307. package/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.d.ts +3 -0
  308. package/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.js +44 -0
  309. package/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.selectors.d.ts +678 -0
  310. package/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.selectors.js +31 -0
  311. package/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.types.d.ts +71 -0
  312. package/internals/plugins/featurePlugins/useChartInteraction/index.d.ts +3 -0
  313. package/internals/plugins/featurePlugins/useChartInteraction/index.js +2 -0
  314. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.d.ts +3 -0
  315. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +90 -0
  316. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +376 -0
  317. package/{context/InteractionSelectors.js → internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js} +2 -4
  318. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +62 -0
  319. package/internals/plugins/featurePlugins/useChartZAxis/index.d.ts +3 -0
  320. package/internals/plugins/featurePlugins/useChartZAxis/index.js +2 -0
  321. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.d.ts +3 -0
  322. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +86 -0
  323. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.d.ts +45 -0
  324. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +3 -0
  325. package/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.d.ts +39 -0
  326. package/internals/plugins/featurePlugins/useChartZAxis/utils.d.ts +0 -0
  327. package/internals/plugins/featurePlugins/useChartZAxis/utils.js +0 -0
  328. package/internals/plugins/models/chart.d.ts +14 -0
  329. package/internals/plugins/models/helpers.d.ts +7 -0
  330. package/internals/plugins/models/index.d.ts +4 -35
  331. package/internals/plugins/models/index.js +4 -1
  332. package/internals/plugins/models/plugin.d.ts +105 -0
  333. package/internals/plugins/models/seriesConfig/colorProcessor.types.d.ts +5 -0
  334. package/internals/plugins/models/seriesConfig/extremumGetter.types.d.ts +22 -0
  335. package/internals/plugins/models/seriesConfig/extremumGetter.types.js +1 -0
  336. package/internals/plugins/models/seriesConfig/index.d.ts +6 -0
  337. package/internals/plugins/models/seriesConfig/index.js +6 -0
  338. package/internals/plugins/models/seriesConfig/legendGetter.types.d.ts +4 -0
  339. package/internals/plugins/models/seriesConfig/legendGetter.types.js +1 -0
  340. package/internals/plugins/models/seriesConfig/seriesConfig.types.d.ts +18 -0
  341. package/internals/plugins/models/seriesConfig/seriesConfig.types.js +1 -0
  342. package/internals/plugins/models/seriesConfig/seriesProcessor.types.d.ts +16 -0
  343. package/internals/plugins/models/seriesConfig/seriesProcessor.types.js +1 -0
  344. package/internals/plugins/models/seriesConfig/tooltipGetter.types.d.ts +7 -0
  345. package/internals/plugins/models/seriesConfig/tooltipGetter.types.js +1 -0
  346. package/internals/plugins/utils/ChartStore.d.ts +9 -8
  347. package/internals/plugins/utils/ChartStore.js +0 -2
  348. package/internals/plugins/utils/selectors.d.ts +2 -2
  349. package/internals/store/extractPluginParamsFromProps.d.ts +7 -0
  350. package/internals/store/extractPluginParamsFromProps.js +28 -0
  351. package/internals/store/useChartModels.d.ts +7 -0
  352. package/internals/store/useChartModels.js +64 -0
  353. package/internals/store/useCharts.d.ts +16 -0
  354. package/internals/store/useCharts.js +83 -0
  355. package/internals/store/useCharts.types.d.ts +5 -0
  356. package/internals/store/useCharts.types.js +1 -0
  357. package/internals/store/useSelector.d.ts +4 -0
  358. package/internals/store/useStore.d.ts +9 -0
  359. package/internals/store/useStore.js +9 -0
  360. package/models/axis.d.ts +1 -13
  361. package/models/curve.d.ts +6 -0
  362. package/models/curve.js +1 -0
  363. package/models/index.d.ts +2 -0
  364. package/models/layout.d.ts +2 -1
  365. package/models/position.d.ts +10 -0
  366. package/models/position.js +1 -0
  367. package/models/seriesType/common.d.ts +8 -1
  368. package/models/seriesType/line.d.ts +12 -1
  369. package/models/seriesType/pie.d.ts +7 -1
  370. package/models/seriesType/scatter.d.ts +3 -3
  371. package/modern/BarChart/AnimatedBarElement.js +1 -0
  372. package/modern/BarChart/BarChart.js +29 -14
  373. package/modern/BarChart/BarElement.js +1 -1
  374. package/modern/BarChart/BarLabel/BarLabelItem.js +1 -1
  375. package/modern/BarChart/BarLabel/BarLabelPlot.js +1 -1
  376. package/modern/BarChart/BarPlot.js +8 -9
  377. package/modern/BarChart/formatter.js +2 -1
  378. package/modern/BarChart/legend.js +1 -0
  379. package/modern/BarChart/plugin.js +5 -2
  380. package/modern/BarChart/tooltip.js +25 -0
  381. package/modern/BarChart/useBarChartProps.js +16 -3
  382. package/modern/ChartContainer/ChartContainer.js +43 -20
  383. package/modern/ChartContainer/useChartContainerProps.js +10 -9
  384. package/modern/ChartDataProvider/ChartDataProvider.js +94 -0
  385. package/modern/ChartDataProvider/useChartDataProviderProps.js +45 -0
  386. package/modern/ChartsAxis/ChartsAxis.js +5 -7
  387. package/modern/ChartsAxis/axisClasses.js +2 -1
  388. package/modern/ChartsAxisHighlight/ChartsXAxisHighlight.js +3 -3
  389. package/modern/ChartsAxisHighlight/ChartsYAxisHighlight.js +3 -3
  390. package/modern/ChartsGrid/ChartsGrid.js +9 -5
  391. package/modern/ChartsGrid/ChartsHorizontalGrid.js +4 -3
  392. package/modern/ChartsGrid/ChartsVerticalGrid.js +4 -3
  393. package/modern/ChartsLabel/ChartsLabel.js +43 -0
  394. package/modern/ChartsLabel/ChartsLabelGradient.js +135 -0
  395. package/modern/ChartsLabel/ChartsLabelMark.js +111 -0
  396. package/modern/ChartsLabel/index.js +6 -0
  397. package/modern/ChartsLabel/labelClasses.js +13 -0
  398. package/modern/ChartsLabel/labelGradientClasses.js +18 -0
  399. package/modern/ChartsLabel/labelMarkClasses.js +18 -0
  400. package/modern/ChartsLegend/ChartsLegend.js +100 -109
  401. package/modern/ChartsLegend/ContinuousColorLegend.js +198 -321
  402. package/modern/ChartsLegend/PiecewiseColorLegend.js +201 -111
  403. package/modern/ChartsLegend/chartsLegendClasses.js +18 -3
  404. package/modern/ChartsLegend/colorLegend.types.js +1 -0
  405. package/modern/ChartsLegend/continuousColorLegendClasses.js +23 -0
  406. package/modern/ChartsLegend/direction.js +1 -0
  407. package/modern/ChartsLegend/index.js +9 -3
  408. package/modern/ChartsLegend/legendContext.types.js +1 -0
  409. package/modern/ChartsLegend/onClickContextBuilder.js +7 -0
  410. package/modern/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +9 -0
  411. package/modern/ChartsLegend/piecewiseColorLegend.types.js +1 -0
  412. package/modern/ChartsLegend/piecewiseColorLegendClasses.js +23 -0
  413. package/modern/ChartsLegend/useAxis.js +7 -6
  414. package/modern/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +8 -7
  415. package/modern/ChartsSurface/ChartsSurface.js +45 -24
  416. package/modern/ChartsTooltip/ChartsAxisTooltipContent.js +11 -6
  417. package/modern/ChartsTooltip/ChartsItemTooltipContent.js +6 -3
  418. package/modern/ChartsTooltip/ChartsTooltip.js +2 -20
  419. package/modern/ChartsTooltip/ChartsTooltipContainer.js +5 -23
  420. package/modern/ChartsTooltip/ChartsTooltipTable.js +15 -33
  421. package/modern/ChartsTooltip/chartsTooltipClasses.js +3 -2
  422. package/modern/ChartsTooltip/index.js +2 -1
  423. package/modern/ChartsTooltip/useAxisTooltip.js +16 -13
  424. package/modern/ChartsTooltip/useItemTooltip.js +20 -45
  425. package/modern/ChartsTooltip/utils.js +2 -0
  426. package/modern/ChartsVoronoiHandler/ChartsVoronoiHandler.js +22 -20
  427. package/modern/ChartsXAxis/ChartsXAxis.js +14 -25
  428. package/modern/ChartsYAxis/ChartsYAxis.js +10 -22
  429. package/modern/Gauge/Gauge.js +5 -1
  430. package/modern/Gauge/GaugeContainer.js +44 -77
  431. package/modern/Gauge/GaugeProvider.js +2 -0
  432. package/modern/LineChart/AnimatedArea.js +2 -1
  433. package/modern/LineChart/AnimatedLine.js +2 -1
  434. package/modern/LineChart/AppearingMask.js +2 -1
  435. package/modern/LineChart/AreaElement.js +1 -1
  436. package/modern/LineChart/AreaPlot.js +60 -26
  437. package/modern/LineChart/CircleMarkElement.js +7 -11
  438. package/modern/LineChart/LineChart.js +32 -21
  439. package/modern/LineChart/LineElement.js +1 -1
  440. package/modern/LineChart/LineHighlightElement.js +29 -9
  441. package/modern/LineChart/LineHighlightPlot.js +21 -16
  442. package/modern/LineChart/LinePlot.js +60 -25
  443. package/modern/LineChart/MarkElement.js +7 -5
  444. package/modern/LineChart/MarkPlot.js +20 -23
  445. package/modern/LineChart/formatter.js +3 -1
  446. package/modern/LineChart/legend.js +1 -0
  447. package/modern/LineChart/plugin.js +5 -2
  448. package/modern/LineChart/tooltip.js +25 -0
  449. package/modern/LineChart/useLineChartProps.js +18 -7
  450. package/modern/PieChart/PieArc.js +14 -6
  451. package/modern/PieChart/PieArcLabel.js +13 -9
  452. package/modern/PieChart/PieArcLabelPlot.js +4 -3
  453. package/modern/PieChart/PieArcPlot.js +13 -16
  454. package/modern/PieChart/PieChart.js +54 -48
  455. package/modern/PieChart/PiePlot.js +2 -2
  456. package/modern/PieChart/dataTransform/transition.js +8 -8
  457. package/modern/PieChart/dataTransform/useTransformData.js +3 -2
  458. package/modern/PieChart/formatter.js +4 -1
  459. package/modern/PieChart/legend.js +4 -3
  460. package/modern/PieChart/plugin.js +5 -2
  461. package/modern/PieChart/tooltip.js +29 -0
  462. package/modern/ScatterChart/Scatter.js +12 -10
  463. package/modern/ScatterChart/ScatterChart.js +31 -20
  464. package/modern/ScatterChart/ScatterPlot.js +11 -10
  465. package/modern/ScatterChart/extremums.js +1 -1
  466. package/modern/ScatterChart/formatter.js +7 -5
  467. package/modern/ScatterChart/legend.js +1 -0
  468. package/modern/ScatterChart/plugin.js +5 -2
  469. package/modern/ScatterChart/tooltip.js +25 -0
  470. package/modern/ScatterChart/useScatterChartProps.js +16 -6
  471. package/modern/SparkLineChart/SparkLineChart.js +16 -13
  472. package/modern/colorPalettes/colorPalettes.js +3 -0
  473. package/modern/constants/index.js +2 -1
  474. package/modern/context/AnimationProvider/AnimationProvider.js +1 -1
  475. package/modern/context/ChartProvider/ChartContext.js +8 -0
  476. package/modern/context/ChartProvider/ChartProvider.js +40 -0
  477. package/modern/context/ChartProvider/ChartProvider.types.js +1 -0
  478. package/modern/context/ChartProvider/index.js +3 -0
  479. package/modern/context/ChartProvider/useChartContext.js +11 -0
  480. package/modern/context/PolarProvider/PolarProvider.js +59 -47
  481. package/modern/context/PolarProvider/getAxisExtremum.js +48 -20
  482. package/modern/context/PolarProvider/usePolarContext.js +9 -8
  483. package/modern/context/index.js +1 -3
  484. package/modern/hooks/index.js +6 -1
  485. package/modern/hooks/useAxis.js +32 -6
  486. package/modern/hooks/useAxisEvents.js +13 -9
  487. package/modern/hooks/useChartGradientId.js +47 -0
  488. package/modern/hooks/useChartId.js +5 -6
  489. package/modern/hooks/useColorScale.js +5 -6
  490. package/modern/hooks/useDrawingArea.js +5 -20
  491. package/modern/hooks/useInteractionItemProps.js +10 -27
  492. package/modern/hooks/useItemHighlighted.js +23 -0
  493. package/modern/hooks/useItemHighlightedGetter.js +23 -0
  494. package/modern/hooks/useLegend.js +30 -0
  495. package/modern/hooks/useSeries.js +5 -10
  496. package/modern/hooks/useSvgRef.js +4 -8
  497. package/modern/hooks/useZAxis.js +27 -0
  498. package/modern/index.js +4 -2
  499. package/modern/internals/calculateMargins.js +25 -0
  500. package/modern/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +65 -32
  501. package/modern/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
  502. package/modern/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +61 -0
  503. package/modern/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
  504. package/modern/internals/components/ChartsWrapper/ChartsWrapper.js +66 -0
  505. package/modern/internals/components/ChartsWrapper/index.js +1 -0
  506. package/modern/internals/consumeSlots.js +101 -0
  507. package/modern/internals/consumeThemeProps.js +70 -0
  508. package/modern/internals/defaultizeColor.js +1 -2
  509. package/modern/internals/getCurve.js +14 -26
  510. package/modern/internals/index.js +21 -14
  511. package/modern/internals/plugins/allPlugins.js +7 -0
  512. package/modern/internals/plugins/corePlugins/corePlugins.js +9 -0
  513. package/modern/internals/plugins/corePlugins/index.js +1 -0
  514. package/modern/internals/plugins/corePlugins/useChartDimensions/index.js +2 -0
  515. package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +175 -0
  516. package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +25 -0
  517. package/modern/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js +1 -0
  518. package/modern/internals/plugins/corePlugins/useChartId/index.js +2 -0
  519. package/modern/internals/plugins/corePlugins/useChartId/useChartId.js +32 -0
  520. package/modern/internals/plugins/corePlugins/useChartId/useChartId.selectors.js +9 -0
  521. package/modern/internals/plugins/corePlugins/useChartId/useChartId.types.js +1 -0
  522. package/modern/internals/plugins/corePlugins/useChartId/useChartId.utils.js +5 -0
  523. package/modern/internals/plugins/corePlugins/useChartSeries/index.js +2 -0
  524. package/{context/SeriesProvider → modern/internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
  525. package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +72 -0
  526. package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +4 -0
  527. package/modern/internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js +1 -0
  528. package/modern/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +21 -0
  529. package/modern/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
  530. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +61 -0
  531. package/{context/ChartDataProvider/useDefaultizeAxis.js → modern/internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +3 -11
  532. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +22 -0
  533. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +5 -0
  534. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +68 -0
  535. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +89 -0
  536. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js +1 -0
  537. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js +1 -0
  538. package/modern/internals/plugins/featurePlugins/useChartHighlight/createIsFaded.js +12 -0
  539. package/modern/internals/plugins/featurePlugins/useChartHighlight/createIsHighlighted.js +12 -0
  540. package/modern/internals/plugins/featurePlugins/useChartHighlight/highlightConfig.types.js +1 -0
  541. package/modern/internals/plugins/featurePlugins/useChartHighlight/index.js +2 -0
  542. package/modern/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.js +44 -0
  543. package/modern/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.selectors.js +31 -0
  544. package/modern/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.types.js +1 -0
  545. package/modern/internals/plugins/featurePlugins/useChartInteraction/index.js +2 -0
  546. package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +90 -0
  547. package/modern/{context/InteractionSelectors.js → internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js} +2 -4
  548. package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.js +1 -0
  549. package/modern/internals/plugins/featurePlugins/useChartZAxis/index.js +2 -0
  550. package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +86 -0
  551. package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +3 -0
  552. package/modern/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js +1 -0
  553. package/modern/internals/plugins/featurePlugins/useChartZAxis/utils.js +0 -0
  554. package/modern/internals/plugins/models/chart.js +1 -0
  555. package/modern/internals/plugins/models/helpers.js +1 -0
  556. package/modern/internals/plugins/models/index.js +4 -1
  557. package/modern/internals/plugins/models/plugin.js +1 -0
  558. package/modern/internals/plugins/models/seriesConfig/colorProcessor.types.js +1 -0
  559. package/modern/internals/plugins/models/seriesConfig/extremumGetter.types.js +1 -0
  560. package/modern/internals/plugins/models/seriesConfig/index.js +6 -0
  561. package/modern/internals/plugins/models/seriesConfig/legendGetter.types.js +1 -0
  562. package/modern/internals/plugins/models/seriesConfig/seriesConfig.types.js +1 -0
  563. package/modern/internals/plugins/models/seriesConfig/seriesProcessor.types.js +1 -0
  564. package/modern/internals/plugins/models/seriesConfig/tooltipGetter.types.js +1 -0
  565. package/modern/internals/plugins/utils/ChartStore.js +0 -2
  566. package/modern/internals/store/extractPluginParamsFromProps.js +28 -0
  567. package/modern/internals/store/useChartModels.js +64 -0
  568. package/modern/internals/store/useCharts.js +83 -0
  569. package/modern/internals/store/useCharts.types.js +1 -0
  570. package/modern/internals/store/useStore.js +9 -0
  571. package/modern/models/curve.js +1 -0
  572. package/modern/models/position.js +1 -0
  573. package/node/BarChart/AnimatedBarElement.js +1 -0
  574. package/node/BarChart/BarChart.js +29 -14
  575. package/node/BarChart/BarElement.js +2 -2
  576. package/node/BarChart/BarLabel/BarLabelItem.js +2 -2
  577. package/node/BarChart/BarLabel/BarLabelPlot.js +1 -1
  578. package/node/BarChart/BarPlot.js +6 -6
  579. package/node/BarChart/formatter.js +2 -1
  580. package/node/BarChart/legend.js +1 -0
  581. package/node/BarChart/plugin.js +5 -2
  582. package/node/BarChart/tooltip.js +31 -0
  583. package/node/BarChart/useBarChartProps.js +15 -3
  584. package/node/ChartContainer/ChartContainer.js +43 -20
  585. package/node/ChartContainer/useChartContainerProps.js +10 -9
  586. package/node/ChartDataProvider/ChartDataProvider.js +100 -0
  587. package/node/ChartDataProvider/useChartDataProviderProps.js +52 -0
  588. package/node/ChartsAxis/ChartsAxis.js +5 -7
  589. package/node/ChartsAxis/axisClasses.js +5 -3
  590. package/node/ChartsAxisHighlight/ChartsXAxisHighlight.js +4 -4
  591. package/node/ChartsAxisHighlight/ChartsYAxisHighlight.js +4 -4
  592. package/node/ChartsGrid/ChartsGrid.js +9 -5
  593. package/node/ChartsGrid/ChartsHorizontalGrid.js +4 -3
  594. package/node/ChartsGrid/ChartsVerticalGrid.js +4 -3
  595. package/node/ChartsLabel/ChartsLabel.js +49 -0
  596. package/node/ChartsLabel/ChartsLabelGradient.js +141 -0
  597. package/node/ChartsLabel/ChartsLabelMark.js +117 -0
  598. package/node/ChartsLabel/index.js +26 -0
  599. package/node/ChartsLabel/labelClasses.js +22 -0
  600. package/node/ChartsLabel/labelGradientClasses.js +27 -0
  601. package/node/ChartsLabel/labelMarkClasses.js +27 -0
  602. package/node/ChartsLegend/ChartsLegend.js +99 -108
  603. package/node/ChartsLegend/ContinuousColorLegend.js +199 -322
  604. package/node/ChartsLegend/PiecewiseColorLegend.js +201 -111
  605. package/node/ChartsLegend/chartsLegendClasses.js +21 -5
  606. package/node/ChartsLegend/continuousColorLegendClasses.js +31 -0
  607. package/node/ChartsLegend/index.js +80 -16
  608. package/node/ChartsLegend/onClickContextBuilder.js +14 -0
  609. package/node/ChartsLegend/piecewiseColorDefaultLabelFormatter.js +15 -0
  610. package/node/ChartsLegend/piecewiseColorLegendClasses.js +31 -0
  611. package/node/ChartsLegend/useAxis.js +7 -7
  612. package/node/ChartsOnAxisClickHandler/ChartsOnAxisClickHandler.js +7 -6
  613. package/node/ChartsSurface/ChartsSurface.js +45 -24
  614. package/node/ChartsTooltip/ChartsAxisTooltipContent.js +10 -5
  615. package/node/ChartsTooltip/ChartsItemTooltipContent.js +5 -2
  616. package/node/ChartsTooltip/ChartsTooltip.js +2 -20
  617. package/node/ChartsTooltip/ChartsTooltipContainer.js +6 -24
  618. package/node/ChartsTooltip/ChartsTooltipTable.js +16 -34
  619. package/node/ChartsTooltip/chartsTooltipClasses.js +3 -2
  620. package/node/ChartsTooltip/index.js +13 -1
  621. package/node/ChartsTooltip/useAxisTooltip.js +16 -14
  622. package/node/ChartsTooltip/useItemTooltip.js +20 -47
  623. package/node/ChartsTooltip/utils.js +1 -0
  624. package/node/ChartsVoronoiHandler/ChartsVoronoiHandler.js +24 -22
  625. package/node/ChartsXAxis/ChartsXAxis.js +14 -25
  626. package/node/ChartsYAxis/ChartsYAxis.js +10 -22
  627. package/node/Gauge/Gauge.js +5 -1
  628. package/node/Gauge/GaugeContainer.js +44 -77
  629. package/node/Gauge/GaugeProvider.js +2 -2
  630. package/node/LineChart/AnimatedArea.js +2 -1
  631. package/node/LineChart/AnimatedLine.js +2 -1
  632. package/node/LineChart/AppearingMask.js +2 -1
  633. package/node/LineChart/AreaElement.js +2 -2
  634. package/node/LineChart/AreaPlot.js +60 -26
  635. package/node/LineChart/CircleMarkElement.js +9 -13
  636. package/node/LineChart/LineChart.js +32 -21
  637. package/node/LineChart/LineElement.js +2 -2
  638. package/node/LineChart/LineHighlightElement.js +29 -9
  639. package/node/LineChart/LineHighlightPlot.js +22 -17
  640. package/node/LineChart/LinePlot.js +60 -25
  641. package/node/LineChart/MarkElement.js +9 -7
  642. package/node/LineChart/MarkPlot.js +20 -23
  643. package/node/LineChart/formatter.js +3 -1
  644. package/node/LineChart/legend.js +1 -0
  645. package/node/LineChart/plugin.js +5 -2
  646. package/node/LineChart/tooltip.js +31 -0
  647. package/node/LineChart/useLineChartProps.js +17 -7
  648. package/node/PieChart/PieArc.js +14 -6
  649. package/node/PieChart/PieArcLabel.js +13 -9
  650. package/node/PieChart/PieArcLabelPlot.js +3 -2
  651. package/node/PieChart/PieArcPlot.js +12 -15
  652. package/node/PieChart/PieChart.js +54 -48
  653. package/node/PieChart/PiePlot.js +2 -2
  654. package/node/PieChart/dataTransform/transition.js +11 -9
  655. package/node/PieChart/dataTransform/useTransformData.js +3 -2
  656. package/node/PieChart/formatter.js +4 -1
  657. package/node/PieChart/legend.js +4 -3
  658. package/node/PieChart/plugin.js +5 -2
  659. package/node/PieChart/tooltip.js +36 -0
  660. package/node/ScatterChart/Scatter.js +13 -11
  661. package/node/ScatterChart/ScatterChart.js +31 -20
  662. package/node/ScatterChart/ScatterPlot.js +11 -10
  663. package/node/ScatterChart/extremums.js +1 -1
  664. package/node/ScatterChart/formatter.js +7 -5
  665. package/node/ScatterChart/legend.js +1 -0
  666. package/node/ScatterChart/plugin.js +5 -2
  667. package/node/ScatterChart/tooltip.js +31 -0
  668. package/node/ScatterChart/useScatterChartProps.js +15 -6
  669. package/node/SparkLineChart/SparkLineChart.js +15 -12
  670. package/node/colorPalettes/colorPalettes.js +5 -1
  671. package/node/constants/index.js +3 -2
  672. package/node/context/AnimationProvider/AnimationProvider.js +1 -1
  673. package/node/context/{SeriesProvider/SeriesContext.js → ChartProvider/ChartContext.js} +6 -6
  674. package/node/context/ChartProvider/ChartProvider.js +46 -0
  675. package/node/context/ChartProvider/index.js +38 -0
  676. package/node/context/ChartProvider/useChartContext.js +18 -0
  677. package/node/context/PolarProvider/PolarProvider.js +59 -51
  678. package/node/context/PolarProvider/getAxisExtremum.js +49 -27
  679. package/node/context/PolarProvider/usePolarContext.js +9 -14
  680. package/node/context/index.js +1 -31
  681. package/node/hooks/index.js +65 -2
  682. package/node/hooks/useAxis.js +34 -6
  683. package/node/hooks/useAxisEvents.js +13 -9
  684. package/node/hooks/useChartGradientId.js +56 -0
  685. package/node/hooks/useChartId.js +5 -7
  686. package/node/hooks/useColorScale.js +5 -7
  687. package/node/hooks/useDrawingArea.js +5 -21
  688. package/node/hooks/useInteractionItemProps.js +10 -28
  689. package/node/hooks/useItemHighlighted.js +28 -0
  690. package/node/hooks/useItemHighlightedGetter.js +27 -0
  691. package/node/hooks/useLegend.js +35 -0
  692. package/node/hooks/useSeries.js +5 -9
  693. package/node/hooks/useSvgRef.js +4 -9
  694. package/node/hooks/useZAxis.js +33 -0
  695. package/node/index.js +23 -1
  696. package/node/internals/calculateMargins.js +33 -0
  697. package/node/internals/components/ChartsAxesGradients/ChartsAxesGradients.js +64 -32
  698. package/node/internals/components/ChartsAxesGradients/ChartsContinuousGradient.js +6 -6
  699. package/node/internals/components/ChartsAxesGradients/ChartsContinuousGradientObjectBound.js +69 -0
  700. package/node/internals/components/ChartsAxesGradients/ChartsPiecewiseGradient.js +6 -0
  701. package/node/internals/components/ChartsWrapper/ChartsWrapper.js +72 -0
  702. package/node/internals/components/ChartsWrapper/index.js +16 -0
  703. package/node/internals/consumeSlots.js +109 -0
  704. package/node/internals/consumeThemeProps.js +78 -0
  705. package/node/internals/defaultizeColor.js +1 -2
  706. package/node/internals/getCurve.js +13 -25
  707. package/node/internals/index.js +135 -75
  708. package/node/internals/plugins/allPlugins.js +13 -0
  709. package/node/internals/plugins/corePlugins/corePlugins.js +14 -0
  710. package/node/internals/plugins/corePlugins/index.js +12 -0
  711. package/node/internals/plugins/corePlugins/useChartDimensions/index.js +27 -0
  712. package/node/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.js +183 -0
  713. package/node/internals/plugins/corePlugins/useChartDimensions/useChartDimensions.selectors.js +32 -0
  714. package/node/internals/plugins/corePlugins/useChartId/index.js +27 -0
  715. package/node/internals/plugins/corePlugins/useChartId/useChartId.js +41 -0
  716. package/node/internals/plugins/corePlugins/useChartId/useChartId.selectors.js +15 -0
  717. package/node/internals/plugins/corePlugins/useChartId/useChartId.utils.js +12 -0
  718. package/node/internals/plugins/corePlugins/useChartSeries/index.js +27 -0
  719. package/node/{context/SeriesProvider → internals/plugins/corePlugins/useChartSeries}/processSeries.js +9 -6
  720. package/node/internals/plugins/corePlugins/useChartSeries/useChartSeries.js +80 -0
  721. package/node/internals/plugins/corePlugins/useChartSeries/useChartSeries.selectors.js +11 -0
  722. package/node/internals/plugins/corePlugins/useChartSeries/useColorProcessor.js +27 -0
  723. package/node/internals/{computeAxisValue.js → plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js} +19 -27
  724. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/createAxisFilterMapper.js +69 -0
  725. package/node/{context/ChartDataProvider/useDefaultizeAxis.js → internals/plugins/featurePlugins/useChartCartesianAxis/defaultizeAxis.js} +4 -13
  726. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisExtremum.js +29 -0
  727. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +59 -0
  728. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +76 -0
  729. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.selectors.js +98 -0
  730. package/node/internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js +5 -0
  731. package/node/internals/plugins/featurePlugins/useChartHighlight/createIsFaded.js +19 -0
  732. package/node/{context/HighlightedProvider → internals/plugins/featurePlugins/useChartHighlight}/createIsHighlighted.js +4 -4
  733. package/node/internals/plugins/featurePlugins/useChartHighlight/highlightConfig.types.js +5 -0
  734. package/node/internals/plugins/featurePlugins/useChartHighlight/index.js +27 -0
  735. package/node/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.js +52 -0
  736. package/node/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.selectors.js +37 -0
  737. package/node/internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.types.js +5 -0
  738. package/node/internals/plugins/featurePlugins/useChartInteraction/index.js +27 -0
  739. package/node/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +98 -0
  740. package/node/{context/InteractionSelectors.js → internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js} +2 -4
  741. package/node/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.js +5 -0
  742. package/node/internals/plugins/featurePlugins/useChartZAxis/index.js +27 -0
  743. package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.js +94 -0
  744. package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.selectors.js +9 -0
  745. package/node/internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js +5 -0
  746. package/node/internals/plugins/featurePlugins/useChartZAxis/utils.js +1 -0
  747. package/node/internals/plugins/models/chart.js +5 -0
  748. package/node/internals/plugins/models/helpers.js +5 -0
  749. package/node/internals/plugins/models/index.js +44 -0
  750. package/node/internals/plugins/models/plugin.js +5 -0
  751. package/node/internals/plugins/models/seriesConfig/colorProcessor.types.js +5 -0
  752. package/node/internals/plugins/models/seriesConfig/extremumGetter.types.js +5 -0
  753. package/node/internals/plugins/models/seriesConfig/index.js +71 -0
  754. package/node/internals/plugins/models/seriesConfig/legendGetter.types.js +5 -0
  755. package/node/internals/plugins/models/seriesConfig/seriesConfig.types.js +5 -0
  756. package/node/internals/plugins/models/seriesConfig/seriesProcessor.types.js +5 -0
  757. package/node/internals/plugins/models/seriesConfig/tooltipGetter.types.js +5 -0
  758. package/node/internals/plugins/utils/ChartStore.js +0 -2
  759. package/node/internals/store/extractPluginParamsFromProps.js +36 -0
  760. package/node/internals/store/useChartModels.js +73 -0
  761. package/node/internals/store/useCharts.js +92 -0
  762. package/node/internals/store/useCharts.types.js +5 -0
  763. package/node/internals/store/useStore.js +15 -0
  764. package/node/models/curve.js +5 -0
  765. package/node/models/position.js +5 -0
  766. package/package.json +6 -5
  767. package/ChartContainer/ResizableContainer.d.ts +0 -22
  768. package/ChartContainer/ResizableContainer.js +0 -60
  769. package/ChartsLegend/ChartsLegendItem.d.ts +0 -26
  770. package/ChartsLegend/ChartsLegendItem.js +0 -65
  771. package/ChartsLegend/DefaultChartsLegend.d.ts +0 -25
  772. package/ChartsLegend/DefaultChartsLegend.js +0 -112
  773. package/ChartsLegend/LegendPerItem.d.ts +0 -65
  774. package/ChartsLegend/LegendPerItem.js +0 -129
  775. package/ChartsLegend/legendItemsPlacement.d.ts +0 -3
  776. package/ChartsLegend/legendItemsPlacement.js +0 -72
  777. package/ChartsLegend/utils.d.ts +0 -2
  778. package/ChartsLegend/utils.js +0 -16
  779. package/context/CartesianProvider/Cartesian.types.d.ts +0 -59
  780. package/context/CartesianProvider/CartesianContext.d.ts +0 -4
  781. package/context/CartesianProvider/CartesianContext.js +0 -13
  782. package/context/CartesianProvider/CartesianProvider.d.ts +0 -4
  783. package/context/CartesianProvider/CartesianProvider.js +0 -49
  784. package/context/CartesianProvider/defaultizeAxis.d.ts +0 -40
  785. package/context/CartesianProvider/defaultizeAxis.js +0 -13
  786. package/context/CartesianProvider/getAxisExtremum.d.ts +0 -5
  787. package/context/CartesianProvider/getAxisExtremum.js +0 -21
  788. package/context/CartesianProvider/index.d.ts +0 -4
  789. package/context/CartesianProvider/index.js +0 -4
  790. package/context/CartesianProvider/useCartesianContext.d.ts +0 -2
  791. package/context/CartesianProvider/useCartesianContext.js +0 -10
  792. package/context/ChartDataProvider/ChartDataProvider.d.ts +0 -31
  793. package/context/ChartDataProvider/ChartDataProvider.js +0 -250
  794. package/context/ChartDataProvider/useChartDataProviderProps.d.ts +0 -94
  795. package/context/ChartDataProvider/useChartDataProviderProps.js +0 -66
  796. package/context/ChartDataProvider/useDefaultizeAxis.d.ts +0 -41
  797. package/context/DrawingAreaProvider/DrawingArea.types.d.ts +0 -51
  798. package/context/DrawingAreaProvider/DrawingAreaContext.d.ts +0 -8
  799. package/context/DrawingAreaProvider/DrawingAreaContext.js +0 -16
  800. package/context/DrawingAreaProvider/DrawingAreaProvider.d.ts +0 -3
  801. package/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -48
  802. package/context/DrawingAreaProvider/index.d.ts +0 -3
  803. package/context/DrawingAreaProvider/index.js +0 -3
  804. package/context/HighlightedProvider/HighlightedContext.d.ts +0 -58
  805. package/context/HighlightedProvider/HighlightedContext.js +0 -32
  806. package/context/HighlightedProvider/HighlightedProvider.d.ts +0 -20
  807. package/context/HighlightedProvider/HighlightedProvider.js +0 -79
  808. package/context/HighlightedProvider/createIsFaded.d.ts +0 -2
  809. package/context/HighlightedProvider/createIsFaded.js +0 -12
  810. package/context/HighlightedProvider/createIsHighlighted.d.ts +0 -2
  811. package/context/HighlightedProvider/createIsHighlighted.js +0 -12
  812. package/context/HighlightedProvider/index.d.ts +0 -4
  813. package/context/HighlightedProvider/index.js +0 -4
  814. package/context/HighlightedProvider/useHighlighted.d.ts +0 -9
  815. package/context/HighlightedProvider/useHighlighted.js +0 -22
  816. package/context/HighlightedProvider/useItemHighlighted.d.ts +0 -21
  817. package/context/HighlightedProvider/useItemHighlighted.js +0 -27
  818. package/context/InteractionProvider.d.ts +0 -7
  819. package/context/InteractionProvider.js +0 -22
  820. package/context/InteractionSelectors.d.ts +0 -359
  821. package/context/PluginProvider/ColorProcessor.types.d.ts +0 -8
  822. package/context/PluginProvider/ExtremumGetter.types.d.ts +0 -25
  823. package/context/PluginProvider/Plugin.types.d.ts +0 -29
  824. package/context/PluginProvider/PluginContext.d.ts +0 -4
  825. package/context/PluginProvider/PluginContext.js +0 -15
  826. package/context/PluginProvider/PluginProvider.d.ts +0 -4
  827. package/context/PluginProvider/PluginProvider.js +0 -21
  828. package/context/PluginProvider/SeriesFormatter.types.d.ts +0 -21
  829. package/context/PluginProvider/index.d.ts +0 -12
  830. package/context/PluginProvider/index.js +0 -12
  831. package/context/PluginProvider/mergePlugins.d.ts +0 -46
  832. package/context/PluginProvider/mergePlugins.js +0 -40
  833. package/context/PluginProvider/useColorProcessor.d.ts +0 -4
  834. package/context/PluginProvider/useColorProcessor.js +0 -17
  835. package/context/PluginProvider/useRadiusExtremumGetter.d.ts +0 -4
  836. package/context/PluginProvider/useRadiusExtremumGetter.js +0 -17
  837. package/context/PluginProvider/useRotationExtremumGetter.d.ts +0 -4
  838. package/context/PluginProvider/useRotationExtremumGetter.js +0 -17
  839. package/context/PluginProvider/useSeriesFormatter.d.ts +0 -4
  840. package/context/PluginProvider/useSeriesFormatter.js +0 -17
  841. package/context/PluginProvider/useXExtremumGetter.d.ts +0 -4
  842. package/context/PluginProvider/useXExtremumGetter.js +0 -15
  843. package/context/PluginProvider/useYExtremumGetter.d.ts +0 -4
  844. package/context/PluginProvider/useYExtremumGetter.js +0 -15
  845. package/context/SeriesProvider/Series.types.d.ts +0 -26
  846. package/context/SeriesProvider/SeriesContext.d.ts +0 -4
  847. package/context/SeriesProvider/SeriesContext.js +0 -8
  848. package/context/SeriesProvider/SeriesProvider.d.ts +0 -5
  849. package/context/SeriesProvider/SeriesProvider.js +0 -33
  850. package/context/SeriesProvider/index.d.ts +0 -12
  851. package/context/SeriesProvider/index.js +0 -8
  852. package/context/SeriesProvider/processSeries.d.ts +0 -18
  853. package/context/SizeProvider/Size.types.d.ts +0 -30
  854. package/context/SizeProvider/SizeContext.d.ts +0 -4
  855. package/context/SizeProvider/SizeContext.js +0 -13
  856. package/context/SizeProvider/SizeProvider.d.ts +0 -11
  857. package/context/SizeProvider/SizeProvider.js +0 -26
  858. package/context/SizeProvider/index.d.ts +0 -4
  859. package/context/SizeProvider/index.js +0 -4
  860. package/context/SizeProvider/useChartContainerDimensions.d.ts +0 -9
  861. package/context/SizeProvider/useChartContainerDimensions.js +0 -104
  862. package/context/SizeProvider/useSize.d.ts +0 -5
  863. package/context/SizeProvider/useSize.js +0 -13
  864. package/context/SvgRefProvider/SvgRef.types.d.ts +0 -8
  865. package/context/SvgRefProvider/SvgRefContext.d.ts +0 -4
  866. package/context/SvgRefProvider/SvgRefContext.js +0 -17
  867. package/context/SvgRefProvider/SvgRefProvider.d.ts +0 -3
  868. package/context/SvgRefProvider/SvgRefProvider.js +0 -24
  869. package/context/SvgRefProvider/index.d.ts +0 -4
  870. package/context/SvgRefProvider/index.js +0 -4
  871. package/context/SvgRefProvider/useSurfaceRef.d.ts +0 -2
  872. package/context/SvgRefProvider/useSurfaceRef.js +0 -14
  873. package/context/ZAxisContextProvider.d.ts +0 -33
  874. package/context/ZAxisContextProvider.js +0 -96
  875. package/internals/computeAxisValue.d.ts +0 -38
  876. package/internals/plugins/utils/ChartsStore.d.ts +0 -12
  877. package/internals/plugins/utils/ChartsStore.js +0 -26
  878. package/internals/useCharts.d.ts +0 -6
  879. package/internals/useCharts.js +0 -29
  880. package/internals/useSelector.d.ts +0 -4
  881. package/internals/useStore.d.ts +0 -2
  882. package/internals/useStore.js +0 -17
  883. package/modern/ChartContainer/ResizableContainer.js +0 -60
  884. package/modern/ChartsLegend/ChartsLegendItem.js +0 -65
  885. package/modern/ChartsLegend/DefaultChartsLegend.js +0 -112
  886. package/modern/ChartsLegend/LegendPerItem.js +0 -129
  887. package/modern/ChartsLegend/legendItemsPlacement.js +0 -72
  888. package/modern/ChartsLegend/utils.js +0 -16
  889. package/modern/context/CartesianProvider/CartesianContext.js +0 -13
  890. package/modern/context/CartesianProvider/CartesianProvider.js +0 -49
  891. package/modern/context/CartesianProvider/defaultizeAxis.js +0 -13
  892. package/modern/context/CartesianProvider/getAxisExtremum.js +0 -21
  893. package/modern/context/CartesianProvider/index.js +0 -4
  894. package/modern/context/CartesianProvider/useCartesianContext.js +0 -10
  895. package/modern/context/ChartDataProvider/ChartDataProvider.js +0 -250
  896. package/modern/context/ChartDataProvider/useChartDataProviderProps.js +0 -66
  897. package/modern/context/DrawingAreaProvider/DrawingAreaContext.js +0 -16
  898. package/modern/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -48
  899. package/modern/context/DrawingAreaProvider/index.js +0 -3
  900. package/modern/context/HighlightedProvider/HighlightedContext.js +0 -32
  901. package/modern/context/HighlightedProvider/HighlightedProvider.js +0 -79
  902. package/modern/context/HighlightedProvider/createIsFaded.js +0 -12
  903. package/modern/context/HighlightedProvider/createIsHighlighted.js +0 -12
  904. package/modern/context/HighlightedProvider/index.js +0 -4
  905. package/modern/context/HighlightedProvider/useHighlighted.js +0 -22
  906. package/modern/context/HighlightedProvider/useItemHighlighted.js +0 -27
  907. package/modern/context/InteractionProvider.js +0 -22
  908. package/modern/context/PluginProvider/PluginContext.js +0 -15
  909. package/modern/context/PluginProvider/PluginProvider.js +0 -21
  910. package/modern/context/PluginProvider/index.js +0 -12
  911. package/modern/context/PluginProvider/mergePlugins.js +0 -40
  912. package/modern/context/PluginProvider/useColorProcessor.js +0 -17
  913. package/modern/context/PluginProvider/useRadiusExtremumGetter.js +0 -17
  914. package/modern/context/PluginProvider/useRotationExtremumGetter.js +0 -17
  915. package/modern/context/PluginProvider/useSeriesFormatter.js +0 -17
  916. package/modern/context/PluginProvider/useXExtremumGetter.js +0 -15
  917. package/modern/context/PluginProvider/useYExtremumGetter.js +0 -15
  918. package/modern/context/SeriesProvider/SeriesContext.js +0 -8
  919. package/modern/context/SeriesProvider/SeriesProvider.js +0 -33
  920. package/modern/context/SeriesProvider/index.js +0 -8
  921. package/modern/context/SizeProvider/SizeContext.js +0 -13
  922. package/modern/context/SizeProvider/SizeProvider.js +0 -26
  923. package/modern/context/SizeProvider/index.js +0 -4
  924. package/modern/context/SizeProvider/useChartContainerDimensions.js +0 -104
  925. package/modern/context/SizeProvider/useSize.js +0 -13
  926. package/modern/context/SvgRefProvider/SvgRefContext.js +0 -17
  927. package/modern/context/SvgRefProvider/SvgRefProvider.js +0 -24
  928. package/modern/context/SvgRefProvider/index.js +0 -4
  929. package/modern/context/SvgRefProvider/useSurfaceRef.js +0 -14
  930. package/modern/context/ZAxisContextProvider.js +0 -96
  931. package/modern/internals/plugins/utils/ChartsStore.js +0 -26
  932. package/modern/internals/useCharts.js +0 -29
  933. package/modern/internals/useStore.js +0 -17
  934. package/node/ChartContainer/ResizableContainer.js +0 -68
  935. package/node/ChartsLegend/ChartsLegendItem.js +0 -72
  936. package/node/ChartsLegend/DefaultChartsLegend.js +0 -118
  937. package/node/ChartsLegend/LegendPerItem.js +0 -137
  938. package/node/ChartsLegend/legendItemsPlacement.js +0 -79
  939. package/node/ChartsLegend/utils.js +0 -23
  940. package/node/context/CartesianProvider/CartesianContext.js +0 -20
  941. package/node/context/CartesianProvider/CartesianProvider.js +0 -54
  942. package/node/context/CartesianProvider/defaultizeAxis.js +0 -21
  943. package/node/context/CartesianProvider/getAxisExtremum.js +0 -28
  944. package/node/context/CartesianProvider/index.js +0 -49
  945. package/node/context/CartesianProvider/useCartesianContext.js +0 -17
  946. package/node/context/ChartDataProvider/ChartDataProvider.js +0 -256
  947. package/node/context/ChartDataProvider/useChartDataProviderProps.js +0 -72
  948. package/node/context/DrawingAreaProvider/DrawingAreaContext.js +0 -22
  949. package/node/context/DrawingAreaProvider/DrawingAreaProvider.js +0 -55
  950. package/node/context/DrawingAreaProvider/index.js +0 -38
  951. package/node/context/HighlightedProvider/HighlightedContext.js +0 -38
  952. package/node/context/HighlightedProvider/HighlightedProvider.js +0 -85
  953. package/node/context/HighlightedProvider/createIsFaded.js +0 -19
  954. package/node/context/HighlightedProvider/index.js +0 -49
  955. package/node/context/HighlightedProvider/useHighlighted.js +0 -27
  956. package/node/context/HighlightedProvider/useItemHighlighted.js +0 -32
  957. package/node/context/InteractionProvider.js +0 -28
  958. package/node/context/PluginProvider/PluginContext.js +0 -22
  959. package/node/context/PluginProvider/PluginProvider.js +0 -26
  960. package/node/context/PluginProvider/index.js +0 -137
  961. package/node/context/PluginProvider/mergePlugins.js +0 -47
  962. package/node/context/PluginProvider/useColorProcessor.js +0 -23
  963. package/node/context/PluginProvider/useRadiusExtremumGetter.js +0 -23
  964. package/node/context/PluginProvider/useRotationExtremumGetter.js +0 -23
  965. package/node/context/PluginProvider/useSeriesFormatter.js +0 -23
  966. package/node/context/PluginProvider/useXExtremumGetter.js +0 -22
  967. package/node/context/PluginProvider/useYExtremumGetter.js +0 -22
  968. package/node/context/SeriesProvider/SeriesProvider.js +0 -38
  969. package/node/context/SeriesProvider/index.js +0 -49
  970. package/node/context/SizeProvider/SizeContext.js +0 -20
  971. package/node/context/SizeProvider/SizeProvider.js +0 -29
  972. package/node/context/SizeProvider/index.js +0 -49
  973. package/node/context/SizeProvider/useChartContainerDimensions.js +0 -112
  974. package/node/context/SizeProvider/useSize.js +0 -20
  975. package/node/context/SvgRefProvider/SvgRefContext.js +0 -23
  976. package/node/context/SvgRefProvider/SvgRefProvider.js +0 -31
  977. package/node/context/SvgRefProvider/index.js +0 -49
  978. package/node/context/SvgRefProvider/useSurfaceRef.js +0 -20
  979. package/node/context/ZAxisContextProvider.js +0 -103
  980. package/node/internals/plugins/utils/ChartsStore.js +0 -33
  981. package/node/internals/useCharts.js +0 -36
  982. package/node/internals/useStore.js +0 -24
  983. /package/{context/ChartDataProvider → ChartDataProvider}/index.d.ts +0 -0
  984. /package/{context/ChartDataProvider → ChartDataProvider}/index.js +0 -0
  985. /package/{context/CartesianProvider/Cartesian.types.js → ChartsLegend/colorLegend.types.js} +0 -0
  986. /package/{context/DrawingAreaProvider/DrawingArea.types.js → ChartsLegend/direction.js} +0 -0
  987. /package/{context/PluginProvider/ColorProcessor.types.js → ChartsLegend/legendContext.types.js} +0 -0
  988. /package/{context/PluginProvider/ExtremumGetter.types.js → ChartsLegend/piecewiseColorLegend.types.js} +0 -0
  989. /package/context/{PluginProvider/Plugin.types.js → ChartProvider/ChartProvider.types.js} +0 -0
  990. /package/{context/PluginProvider/SeriesFormatter.types.js → internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js} +0 -0
  991. /package/{context/SeriesProvider/Series.types.js → internals/plugins/corePlugins/useChartId/useChartId.types.js} +0 -0
  992. /package/{context/SizeProvider/Size.types.js → internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js} +0 -0
  993. /package/{context/SvgRefProvider/SvgRef.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js} +0 -0
  994. /package/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.d.ts +0 -0
  995. /package/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
  996. /package/{modern/context/CartesianProvider/Cartesian.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/zoom.types.js} +0 -0
  997. /package/{modern/context/DrawingAreaProvider/DrawingArea.types.js → internals/plugins/featurePlugins/useChartHighlight/highlightConfig.types.js} +0 -0
  998. /package/{modern/context/PluginProvider/ColorProcessor.types.js → internals/plugins/featurePlugins/useChartHighlight/useChartHighlight.types.js} +0 -0
  999. /package/{modern/context/PluginProvider/ExtremumGetter.types.js → internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.js} +0 -0
  1000. /package/{modern/context/PluginProvider/Plugin.types.js → internals/plugins/featurePlugins/useChartZAxis/useChartZAxis.types.js} +0 -0
  1001. /package/{modern/context/PluginProvider/SeriesFormatter.types.js → internals/plugins/models/chart.js} +0 -0
  1002. /package/{modern/context/SeriesProvider/Series.types.js → internals/plugins/models/helpers.js} +0 -0
  1003. /package/{modern/context/SizeProvider/Size.types.js → internals/plugins/models/plugin.js} +0 -0
  1004. /package/{modern/context/SvgRefProvider/SvgRef.types.js → internals/plugins/models/seriesConfig/colorProcessor.types.js} +0 -0
  1005. /package/internals/{useSelector.js → store/useSelector.js} +0 -0
  1006. /package/modern/{context/ChartDataProvider → ChartDataProvider}/index.js +0 -0
  1007. /package/modern/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
  1008. /package/modern/internals/{useSelector.js → store/useSelector.js} +0 -0
  1009. /package/node/{context/ChartDataProvider → ChartDataProvider}/index.js +0 -0
  1010. /package/node/{context/CartesianProvider/Cartesian.types.js → ChartsLegend/colorLegend.types.js} +0 -0
  1011. /package/node/{context/DrawingAreaProvider/DrawingArea.types.js → ChartsLegend/direction.js} +0 -0
  1012. /package/node/{context/PluginProvider/ColorProcessor.types.js → ChartsLegend/legendContext.types.js} +0 -0
  1013. /package/node/{context/PluginProvider/ExtremumGetter.types.js → ChartsLegend/piecewiseColorLegend.types.js} +0 -0
  1014. /package/node/context/{PluginProvider/Plugin.types.js → ChartProvider/ChartProvider.types.js} +0 -0
  1015. /package/node/{context/PluginProvider/SeriesFormatter.types.js → internals/plugins/corePlugins/useChartDimensions/useChartDimensions.types.js} +0 -0
  1016. /package/node/{context/SeriesProvider/Series.types.js → internals/plugins/corePlugins/useChartId/useChartId.types.js} +0 -0
  1017. /package/node/{context/SizeProvider/Size.types.js → internals/plugins/corePlugins/useChartSeries/useChartSeries.types.js} +0 -0
  1018. /package/node/{context/SvgRefProvider/SvgRef.types.js → internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.types.js} +0 -0
  1019. /package/node/{context/CartesianProvider → internals/plugins/featurePlugins/useChartCartesianAxis}/zoom.js +0 -0
  1020. /package/node/internals/{useSelector.js → store/useSelector.js} +0 -0
@@ -6,7 +6,6 @@ import PropTypes from 'prop-types';
6
6
  import { useThemeProps } from '@mui/material/styles';
7
7
  import { AreaPlot } from "./AreaPlot.js";
8
8
  import { LinePlot } from "./LinePlot.js";
9
- import { ChartContainer } from "../ChartContainer/index.js";
10
9
  import { MarkPlot } from "./MarkPlot.js";
11
10
  import { ChartsAxis } from "../ChartsAxis/ChartsAxis.js";
12
11
  import { ChartsTooltip } from "../ChartsTooltip/index.js";
@@ -18,6 +17,10 @@ import { ChartsGrid } from "../ChartsGrid/index.js";
18
17
  import { ChartsOnAxisClickHandler } from "../ChartsOnAxisClickHandler/index.js";
19
18
  import { ChartsOverlay } from "../ChartsOverlay/index.js";
20
19
  import { useLineChartProps } from "./useLineChartProps.js";
20
+ import { useChartContainerProps } from "../ChartContainer/useChartContainerProps.js";
21
+ import { ChartDataProvider } from "../ChartDataProvider/index.js";
22
+ import { ChartsSurface } from "../ChartsSurface/index.js";
23
+ import { ChartsWrapper } from "../internals/components/ChartsWrapper/index.js";
21
24
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
22
25
  /**
23
26
  * Demos:
@@ -35,6 +38,7 @@ const LineChart = /*#__PURE__*/React.forwardRef(function LineChart(inProps, ref)
35
38
  name: 'MuiLineChart'
36
39
  });
37
40
  const {
41
+ chartsWrapperProps,
38
42
  chartContainerProps,
39
43
  axisClickHandlerProps,
40
44
  gridProps,
@@ -50,16 +54,22 @@ const LineChart = /*#__PURE__*/React.forwardRef(function LineChart(inProps, ref)
50
54
  legendProps,
51
55
  children
52
56
  } = useLineChartProps(props);
57
+ const {
58
+ chartDataProviderProps,
59
+ chartsSurfaceProps
60
+ } = useChartContainerProps(chartContainerProps, ref);
53
61
  const Tooltip = props.slots?.tooltip ?? ChartsTooltip;
54
- return /*#__PURE__*/_jsxs(ChartContainer, _extends({
55
- ref: ref
56
- }, chartContainerProps, {
57
- children: [props.onAxisClick && /*#__PURE__*/_jsx(ChartsOnAxisClickHandler, _extends({}, axisClickHandlerProps)), /*#__PURE__*/_jsx(ChartsGrid, _extends({}, gridProps)), /*#__PURE__*/_jsxs("g", _extends({}, clipPathGroupProps, {
58
- children: [/*#__PURE__*/_jsx(AreaPlot, _extends({}, areaPlotProps)), /*#__PURE__*/_jsx(LinePlot, _extends({}, linePlotProps)), /*#__PURE__*/_jsx(ChartsOverlay, _extends({}, overlayProps)), /*#__PURE__*/_jsx(ChartsAxisHighlight, _extends({}, axisHighlightProps))]
59
- })), /*#__PURE__*/_jsx(ChartsAxis, _extends({}, chartsAxisProps)), /*#__PURE__*/_jsx("g", {
60
- "data-drawing-container": true,
61
- children: /*#__PURE__*/_jsx(MarkPlot, _extends({}, markPlotProps))
62
- }), /*#__PURE__*/_jsx(LineHighlightPlot, _extends({}, lineHighlightPlotProps)), !props.hideLegend && /*#__PURE__*/_jsx(ChartsLegend, _extends({}, legendProps)), !props.loading && /*#__PURE__*/_jsx(Tooltip, _extends({}, props.slotProps?.tooltip)), /*#__PURE__*/_jsx(ChartsClipPath, _extends({}, clipPathProps)), children]
62
+ return /*#__PURE__*/_jsx(ChartDataProvider, _extends({}, chartDataProviderProps, {
63
+ children: /*#__PURE__*/_jsxs(ChartsWrapper, _extends({}, chartsWrapperProps, {
64
+ children: [!props.hideLegend && /*#__PURE__*/_jsx(ChartsLegend, _extends({}, legendProps)), /*#__PURE__*/_jsxs(ChartsSurface, _extends({}, chartsSurfaceProps, {
65
+ children: [props.onAxisClick && /*#__PURE__*/_jsx(ChartsOnAxisClickHandler, _extends({}, axisClickHandlerProps)), /*#__PURE__*/_jsx(ChartsGrid, _extends({}, gridProps)), /*#__PURE__*/_jsxs("g", _extends({}, clipPathGroupProps, {
66
+ children: [/*#__PURE__*/_jsx(AreaPlot, _extends({}, areaPlotProps)), /*#__PURE__*/_jsx(LinePlot, _extends({}, linePlotProps)), /*#__PURE__*/_jsx(ChartsOverlay, _extends({}, overlayProps)), /*#__PURE__*/_jsx(ChartsAxisHighlight, _extends({}, axisHighlightProps))]
67
+ })), /*#__PURE__*/_jsx(ChartsAxis, _extends({}, chartsAxisProps)), /*#__PURE__*/_jsx("g", {
68
+ "data-drawing-container": true,
69
+ children: /*#__PURE__*/_jsx(MarkPlot, _extends({}, markPlotProps))
70
+ }), /*#__PURE__*/_jsx(LineHighlightPlot, _extends({}, lineHighlightPlotProps)), !props.loading && /*#__PURE__*/_jsx(Tooltip, _extends({}, props.slotProps?.tooltip)), /*#__PURE__*/_jsx(ChartsClipPath, _extends({}, clipPathProps)), children]
71
+ }))]
72
+ }))
63
73
  }));
64
74
  });
65
75
  process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
@@ -67,6 +77,9 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
67
77
  // | These PropTypes are generated from the TypeScript type definitions |
68
78
  // | To update them edit the TypeScript types and run "pnpm proptypes" |
69
79
  // ----------------------------------------------------------------------
80
+ apiRef: PropTypes.shape({
81
+ current: PropTypes.object
82
+ }),
70
83
  /**
71
84
  * The configuration of axes highlight.
72
85
  * @see See {@link https://mui.com/x/react-charts/highlighting/ highlighting docs} for more details.
@@ -104,10 +117,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
104
117
  * If `true`, render the line highlight item.
105
118
  */
106
119
  disableLineItemHighlight: PropTypes.bool,
107
- /**
108
- * If `true` marks will render `<circle />` instead of `<path />` and drop theme override for faster rendering.
109
- */
110
- experimentalMarkRendering: PropTypes.bool,
111
120
  /**
112
121
  * Option to display a cartesian grid in the background.
113
122
  */
@@ -124,12 +133,18 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
124
133
  */
125
134
  hideLegend: PropTypes.bool,
126
135
  /**
127
- * The item currently highlighted. Turns highlighting into a controlled prop.
136
+ * The highlighted item.
137
+ * Used when the highlight is controlled.
128
138
  */
129
139
  highlightedItem: PropTypes.shape({
130
140
  dataIndex: PropTypes.number,
131
- seriesId: PropTypes.oneOfType([PropTypes.number, PropTypes.string])
141
+ seriesId: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired
132
142
  }),
143
+ /**
144
+ * This prop is used to help implement the accessibility logic.
145
+ * If you don't provide this prop. It falls back to a randomly generated id.
146
+ */
147
+ id: PropTypes.string,
133
148
  /**
134
149
  * Indicate which axis to display the left of the charts.
135
150
  * Can be a string (the id of the axis) or an object `ChartsYAxisProps`.
@@ -145,7 +160,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
145
160
  * The margin between the SVG and the drawing area.
146
161
  * It's used for leaving some space for extra information such as the x- and y-axis or legend.
147
162
  * Accepts an object with the optional properties: `top`, `bottom`, `left`, and `right`.
148
- * @default object Depends on the charts type.
149
163
  */
150
164
  margin: PropTypes.shape({
151
165
  bottom: PropTypes.number,
@@ -205,6 +219,7 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
205
219
  */
206
220
  slots: PropTypes.object,
207
221
  sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),
222
+ theme: PropTypes.oneOf(['dark', 'light']),
208
223
  title: PropTypes.string,
209
224
  /**
210
225
  * Indicate which axis to display the top of the charts.
@@ -247,7 +262,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
247
262
  hideTooltip: PropTypes.bool,
248
263
  id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
249
264
  label: PropTypes.string,
250
- labelFontSize: PropTypes.number,
251
265
  labelStyle: PropTypes.object,
252
266
  max: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.number]),
253
267
  min: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.number]),
@@ -258,7 +272,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
258
272
  slots: PropTypes.object,
259
273
  stroke: PropTypes.string,
260
274
  sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),
261
- tickFontSize: PropTypes.number,
262
275
  tickInterval: PropTypes.oneOfType([PropTypes.oneOf(['auto']), PropTypes.array, PropTypes.func]),
263
276
  tickLabelInterval: PropTypes.oneOfType([PropTypes.oneOf(['auto']), PropTypes.func]),
264
277
  tickLabelPlacement: PropTypes.oneOf(['middle', 'tick']),
@@ -301,7 +314,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
301
314
  hideTooltip: PropTypes.bool,
302
315
  id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
303
316
  label: PropTypes.string,
304
- labelFontSize: PropTypes.number,
305
317
  labelStyle: PropTypes.object,
306
318
  max: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.number]),
307
319
  min: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.number]),
@@ -312,7 +324,6 @@ process.env.NODE_ENV !== "production" ? LineChart.propTypes = {
312
324
  slots: PropTypes.object,
313
325
  stroke: PropTypes.string,
314
326
  sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),
315
- tickFontSize: PropTypes.number,
316
327
  tickInterval: PropTypes.oneOfType([PropTypes.oneOf(['auto']), PropTypes.array, PropTypes.func]),
317
328
  tickLabelInterval: PropTypes.oneOfType([PropTypes.oneOf(['auto']), PropTypes.func]),
318
329
  tickLabelPlacement: PropTypes.oneOf(['middle', 'tick']),
@@ -11,7 +11,7 @@ import generateUtilityClass from '@mui/utils/generateUtilityClass';
11
11
  import generateUtilityClasses from '@mui/utils/generateUtilityClasses';
12
12
  import { useInteractionItemProps } from "../hooks/useInteractionItemProps.js";
13
13
  import { AnimatedLine } from "./AnimatedLine.js";
14
- import { useItemHighlighted } from "../context/index.js";
14
+ import { useItemHighlighted } from "../hooks/useItemHighlighted.js";
15
15
  import { jsx as _jsx } from "react/jsx-runtime";
16
16
  export function getLineElementUtilityClass(slot) {
17
17
  return generateUtilityClass('MuiLineElement', slot);
@@ -14,7 +14,11 @@ interface LineHighlightElementOwnerState {
14
14
  }
15
15
  export declare function getHighlightElementUtilityClass(slot: string): string;
16
16
  export declare const lineHighlightElementClasses: LineHighlightElementClasses;
17
- export type LineHighlightElementProps = LineHighlightElementOwnerState & Omit<React.SVGProps<SVGCircleElement>, 'ref' | 'id'>;
17
+ export type LineHighlightElementProps = (LineHighlightElementOwnerState & ({
18
+ shape: 'circle';
19
+ } & Omit<React.SVGProps<SVGCircleElement>, 'ref' | 'id'>)) | (LineHighlightElementOwnerState & {
20
+ shape: 'cross' | 'diamond' | 'square' | 'star' | 'triangle' | 'wye';
21
+ } & Omit<React.SVGProps<SVGPathElement>, 'ref' | 'id'>);
18
22
  /**
19
23
  * Demos:
20
24
  *
@@ -2,13 +2,15 @@
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
5
- const _excluded = ["x", "y", "id", "classes", "color"];
5
+ const _excluded = ["x", "y", "id", "classes", "color", "shape"];
6
6
  import * as React from 'react';
7
7
  import PropTypes from 'prop-types';
8
+ import { symbol as d3Symbol, symbolsFill as d3SymbolsFill } from '@mui/x-charts-vendor/d3-shape';
8
9
  import composeClasses from '@mui/utils/composeClasses';
9
10
  import generateUtilityClass from '@mui/utils/generateUtilityClass';
10
11
  import { styled } from '@mui/material/styles';
11
12
  import generateUtilityClasses from '@mui/utils/generateUtilityClasses';
13
+ import { getSymbol } from "../internals/getSymbol.js";
12
14
  import { jsx as _jsx } from "react/jsx-runtime";
13
15
  export function getHighlightElementUtilityClass(slot) {
14
16
  return generateUtilityClass('MuiHighlightElement', slot);
@@ -24,7 +26,18 @@ const useUtilityClasses = ownerState => {
24
26
  };
25
27
  return composeClasses(slots, getHighlightElementUtilityClass, classes);
26
28
  };
27
- const HighlightElement = styled('circle', {
29
+ const HighlightPathElement = styled('path', {
30
+ name: 'MuiHighlightElement',
31
+ slot: 'Root',
32
+ overridesResolver: (_, styles) => styles.root
33
+ })(({
34
+ ownerState
35
+ }) => ({
36
+ transform: `translate(${ownerState.x}px, ${ownerState.y}px)`,
37
+ transformOrigin: `${ownerState.x}px ${ownerState.y}px`,
38
+ fill: ownerState.color
39
+ }));
40
+ const HighlightCircleElement = styled('circle', {
28
41
  name: 'MuiHighlightElement',
29
42
  slot: 'Root',
30
43
  overridesResolver: (_, styles) => styles.root
@@ -51,7 +64,8 @@ function LineHighlightElement(props) {
51
64
  y,
52
65
  id,
53
66
  classes: innerClasses,
54
- color
67
+ color,
68
+ shape
55
69
  } = props,
56
70
  other = _objectWithoutPropertiesLoose(props, _excluded);
57
71
  const ownerState = {
@@ -62,14 +76,19 @@ function LineHighlightElement(props) {
62
76
  y
63
77
  };
64
78
  const classes = useUtilityClasses(ownerState);
65
- return /*#__PURE__*/_jsx(HighlightElement, _extends({
66
- pointerEvents: "none",
67
- ownerState: ownerState,
68
- className: classes.root,
79
+ const Element = shape === 'circle' ? HighlightCircleElement : HighlightPathElement;
80
+ const additionalProps = shape === 'circle' ? {
69
81
  cx: 0,
70
82
  cy: 0,
71
83
  r: other.r === undefined ? 5 : other.r
72
- }, other));
84
+ } : {
85
+ d: d3Symbol(d3SymbolsFill[getSymbol(shape)])()
86
+ };
87
+ return /*#__PURE__*/_jsx(Element, _extends({
88
+ pointerEvents: "none",
89
+ ownerState: ownerState,
90
+ className: classes.root
91
+ }, additionalProps, other));
73
92
  }
74
93
  process.env.NODE_ENV !== "production" ? LineHighlightElement.propTypes = {
75
94
  // ----------------------------- Warning --------------------------------
@@ -77,6 +96,7 @@ process.env.NODE_ENV !== "production" ? LineHighlightElement.propTypes = {
77
96
  // | To update them edit the TypeScript types and run "pnpm proptypes" |
78
97
  // ----------------------------------------------------------------------
79
98
  classes: PropTypes.object,
80
- id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired
99
+ id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
100
+ shape: PropTypes.oneOf(['circle', 'cross', 'diamond', 'square', 'star', 'triangle', 'wye']).isRequired
81
101
  } : void 0;
82
102
  export { LineHighlightElement };
@@ -5,16 +5,16 @@ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWith
5
5
  const _excluded = ["slots", "slotProps"];
6
6
  import * as React from 'react';
7
7
  import PropTypes from 'prop-types';
8
- import { useStore } from "../internals/useStore.js";
9
- import { useSelector } from "../internals/useSelector.js";
10
- import { useCartesianContext } from "../context/CartesianProvider/index.js";
8
+ import { useStore } from "../internals/store/useStore.js";
9
+ import { useSelector } from "../internals/store/useSelector.js";
11
10
  import { LineHighlightElement } from "./LineHighlightElement.js";
12
11
  import { getValueToPositionMapper } from "../hooks/useScale.js";
13
12
  import { DEFAULT_X_AXIS_KEY } from "../constants/index.js";
14
13
  import getColor from "./getColor.js";
15
14
  import { useLineSeries } from "../hooks/useSeries.js";
16
- import { useDrawingArea } from "../hooks/useDrawingArea.js";
17
- import { selectorChartsInteractionXAxis } from "../context/InteractionSelectors.js";
15
+ import { useChartContext } from "../context/ChartProvider/index.js";
16
+ import { selectorChartsInteractionXAxis } from "../internals/plugins/featurePlugins/useChartInteraction/index.js";
17
+ import { useXAxes, useYAxes } from "../hooks/useAxis.js";
18
18
  import { jsx as _jsx } from "react/jsx-runtime";
19
19
  /**
20
20
  * Demos:
@@ -33,8 +33,17 @@ function LineHighlightPlot(props) {
33
33
  } = props,
34
34
  other = _objectWithoutPropertiesLoose(props, _excluded);
35
35
  const seriesData = useLineSeries();
36
- const axisData = useCartesianContext();
37
- const drawingArea = useDrawingArea();
36
+ const {
37
+ xAxis,
38
+ xAxisIds
39
+ } = useXAxes();
40
+ const {
41
+ yAxis,
42
+ yAxisIds
43
+ } = useYAxes();
44
+ const {
45
+ instance
46
+ } = useChartContext();
38
47
  const store = useStore();
39
48
  const xAxisIdentifier = useSelector(store, selectorChartsInteractionXAxis);
40
49
  const highlightedIndex = xAxisIdentifier?.index;
@@ -48,12 +57,6 @@ function LineHighlightPlot(props) {
48
57
  series,
49
58
  stackingGroups
50
59
  } = seriesData;
51
- const {
52
- xAxis,
53
- yAxis,
54
- xAxisIds,
55
- yAxisIds
56
- } = axisData;
57
60
  const defaultXAxisId = xAxisIds[0];
58
61
  const defaultYAxisId = yAxisIds[0];
59
62
  const Element = slots?.lineHighlight ?? LineHighlightElement;
@@ -67,7 +70,8 @@ function LineHighlightPlot(props) {
67
70
  yAxisId = defaultYAxisId,
68
71
  stackedData,
69
72
  data,
70
- disableHighlight
73
+ disableHighlight,
74
+ shape = 'circle'
71
75
  } = series[seriesId];
72
76
  if (disableHighlight || data[highlightedIndex] == null) {
73
77
  return null;
@@ -81,7 +85,7 @@ function LineHighlightPlot(props) {
81
85
  const x = xScale(xData[highlightedIndex]);
82
86
  const y = yScale(stackedData[highlightedIndex][1]); // This should not be undefined since y should not be a band scale
83
87
 
84
- if (!drawingArea.isPointInside({
88
+ if (!instance.isPointInside({
85
89
  x,
86
90
  y
87
91
  })) {
@@ -92,7 +96,8 @@ function LineHighlightPlot(props) {
92
96
  id: seriesId,
93
97
  color: colorGetter(highlightedIndex),
94
98
  x: x,
95
- y: y
99
+ y: y,
100
+ shape: shape
96
101
  }, slotProps?.lineHighlight), `${seriesId}`);
97
102
  });
98
103
  })
@@ -7,14 +7,15 @@ import * as React from 'react';
7
7
  import PropTypes from 'prop-types';
8
8
  import { styled } from '@mui/material/styles';
9
9
  import { line as d3Line } from '@mui/x-charts-vendor/d3-shape';
10
- import { useCartesianContext } from "../context/CartesianProvider/index.js";
11
10
  import { LineElement, lineElementClasses } from "./LineElement.js";
12
11
  import { getValueToPositionMapper } from "../hooks/useScale.js";
13
- import getCurveFactory from "../internals/getCurve.js";
12
+ import { getCurveFactory } from "../internals/getCurve.js";
13
+ import { isBandScale } from "../internals/isBandScale.js";
14
14
  import { DEFAULT_X_AXIS_KEY } from "../constants/index.js";
15
- import { useChartGradient } from "../internals/components/ChartsAxesGradients/index.js";
16
15
  import { useLineSeries } from "../hooks/useSeries.js";
17
16
  import { useSkipAnimation } from "../context/AnimationProvider/index.js";
17
+ import { useChartGradientIdBuilder } from "../hooks/useChartGradientId.js";
18
+ import { useXAxes, useYAxes } from "../hooks/index.js";
18
19
  import { jsx as _jsx } from "react/jsx-runtime";
19
20
  const LinePlotRoot = styled('g', {
20
21
  name: 'MuiAreaPlot',
@@ -27,7 +28,15 @@ const LinePlotRoot = styled('g', {
27
28
  });
28
29
  const useAggregatedData = () => {
29
30
  const seriesData = useLineSeries();
30
- const axisData = useCartesianContext();
31
+ const {
32
+ xAxis,
33
+ xAxisIds
34
+ } = useXAxes();
35
+ const {
36
+ yAxis,
37
+ yAxisIds
38
+ } = useYAxes();
39
+ const getGradientId = useChartGradientIdBuilder();
31
40
 
32
41
  // This memo prevents odd line chart behavior when hydrating.
33
42
  const allData = React.useMemo(() => {
@@ -38,12 +47,6 @@ const useAggregatedData = () => {
38
47
  series,
39
48
  stackingGroups
40
49
  } = seriesData;
41
- const {
42
- xAxis,
43
- yAxis,
44
- xAxisIds,
45
- yAxisIds
46
- } = axisData;
47
50
  const defaultXAxisId = xAxisIds[0];
48
51
  const defaultYAxisId = yAxisIds[0];
49
52
  return stackingGroups.flatMap(({
@@ -55,12 +58,15 @@ const useAggregatedData = () => {
55
58
  yAxisId = defaultYAxisId,
56
59
  stackedData,
57
60
  data,
58
- connectNulls
61
+ connectNulls,
62
+ curve,
63
+ strictStepCurve
59
64
  } = series[seriesId];
60
- const xScale = getValueToPositionMapper(xAxis[xAxisId].scale);
65
+ const xScale = xAxis[xAxisId].scale;
66
+ const xPosition = getValueToPositionMapper(xScale);
61
67
  const yScale = yAxis[yAxisId].scale;
62
68
  const xData = xAxis[xAxisId].data;
63
- const gradientUsed = yAxis[yAxisId].colorScale && [yAxisId, 'y'] || xAxis[xAxisId].colorScale && [xAxisId, 'x'] || undefined;
69
+ const gradientId = yAxis[yAxisId].colorScale && getGradientId(yAxisId) || xAxis[xAxisId].colorScale && getGradientId(xAxisId) || undefined;
64
70
  if (process.env.NODE_ENV !== 'production') {
65
71
  if (xData === undefined) {
66
72
  throw new Error(`MUI X: ${xAxisId === 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.`);
@@ -69,21 +75,51 @@ const useAggregatedData = () => {
69
75
  throw new Error(`MUI X: The data length of the x axis (${xData.length} items) is lower than the length of series (${stackedData.length} items).`);
70
76
  }
71
77
  }
72
- const linePath = d3Line().x(d => xScale(d.x)).defined((_, i) => connectNulls || data[i] != null).y(d => yScale(d.y[1]));
73
- const formattedData = xData?.map((x, index) => ({
74
- x,
75
- y: stackedData[index]
76
- })) ?? [];
77
- const d3Data = connectNulls ? formattedData.filter((_, i) => data[i] != null) : formattedData;
78
- const d = linePath.curve(getCurveFactory(series[seriesId].curve))(d3Data) || '';
78
+ const shouldExpand = curve?.includes('step') && !strictStepCurve && isBandScale(xScale);
79
+ const formattedData = xData?.flatMap((x, index) => {
80
+ const nullData = data[index] == null;
81
+ if (shouldExpand) {
82
+ const rep = [{
83
+ x,
84
+ y: stackedData[index],
85
+ nullData,
86
+ isExtension: false
87
+ }];
88
+ if (!nullData && (index === 0 || data[index - 1] == null)) {
89
+ rep.unshift({
90
+ x: (xScale(x) ?? 0) - (xScale.step() - xScale.bandwidth()) / 2,
91
+ y: stackedData[index],
92
+ nullData,
93
+ isExtension: true
94
+ });
95
+ }
96
+ if (!nullData && (index === data.length - 1 || data[index + 1] == null)) {
97
+ rep.push({
98
+ x: (xScale(x) ?? 0) + (xScale.step() + xScale.bandwidth()) / 2,
99
+ y: stackedData[index],
100
+ nullData,
101
+ isExtension: true
102
+ });
103
+ }
104
+ return rep;
105
+ }
106
+ return {
107
+ x,
108
+ y: stackedData[index],
109
+ nullData
110
+ };
111
+ }) ?? [];
112
+ const d3Data = connectNulls ? formattedData.filter(d => !d.nullData) : formattedData;
113
+ const linePath = d3Line().x(d => d.isExtension ? d.x : xPosition(d.x)).defined(d => connectNulls || !d.nullData || !!d.isExtension).y(d => yScale(d.y[1]));
114
+ const d = linePath.curve(getCurveFactory(curve))(d3Data) || '';
79
115
  return _extends({}, series[seriesId], {
80
- gradientUsed,
116
+ gradientId,
81
117
  d,
82
118
  seriesId
83
119
  });
84
120
  });
85
121
  });
86
- }, [seriesData, axisData]);
122
+ }, [seriesData, xAxisIds, yAxisIds, xAxis, yAxis, getGradientId]);
87
123
  return allData;
88
124
  };
89
125
 
@@ -106,20 +142,19 @@ function LinePlot(props) {
106
142
  } = props,
107
143
  other = _objectWithoutPropertiesLoose(props, _excluded);
108
144
  const skipAnimation = useSkipAnimation(inSkipAnimation);
109
- const getGradientId = useChartGradient();
110
145
  const completedData = useAggregatedData();
111
146
  return /*#__PURE__*/_jsx(LinePlotRoot, _extends({}, other, {
112
147
  children: completedData.map(({
113
148
  d,
114
149
  seriesId,
115
150
  color,
116
- gradientUsed
151
+ gradientId
117
152
  }) => {
118
153
  return /*#__PURE__*/_jsx(LineElement, {
119
154
  id: seriesId,
120
155
  d: d,
121
156
  color: color,
122
- gradientId: gradientUsed && getGradientId(...gradientUsed),
157
+ gradientId: gradientId,
123
158
  skipAnimation: skipAnimation,
124
159
  slots: slots,
125
160
  slotProps: slotProps,
@@ -10,11 +10,11 @@ import { symbol as d3Symbol, symbolsFill as d3SymbolsFill } from '@mui/x-charts-
10
10
  import { animated, to, useSpring } from '@react-spring/web';
11
11
  import { getSymbol } from "../internals/getSymbol.js";
12
12
  import { useInteractionItemProps } from "../hooks/useInteractionItemProps.js";
13
- import { useItemHighlighted } from "../context/index.js";
13
+ import { useItemHighlighted } from "../hooks/useItemHighlighted.js";
14
14
  import { useUtilityClasses } from "./markElementClasses.js";
15
- import { selectorChartsInteractionXAxis } from "../context/InteractionSelectors.js";
16
- import { useSelector } from "../internals/useSelector.js";
17
- import { useStore } from "../internals/useStore.js";
15
+ import { selectorChartsInteractionXAxis } from "../internals/plugins/featurePlugins/useChartInteraction/index.js";
16
+ import { useSelector } from "../internals/store/useSelector.js";
17
+ import { useStore } from "../internals/store/useStore.js";
18
18
  import { jsx as _jsx } from "react/jsx-runtime";
19
19
  const MarkElementPath = styled(animated.path, {
20
20
  name: 'MuiMarkElement',
@@ -80,7 +80,9 @@ function MarkElement(props) {
80
80
  transform: to([position.x, position.y], (pX, pY) => `translate(${pX}px, ${pY}px)`),
81
81
  transformOrigin: to([position.x, position.y], (pX, pY) => `${pX}px ${pY}px`)
82
82
  },
83
- ownerState: ownerState,
83
+ ownerState: ownerState
84
+ // @ts-expect-error
85
+ ,
84
86
  className: classes.root,
85
87
  d: d3Symbol(d3SymbolsFill[getSymbol(shape)])(),
86
88
  onClick: onClick,
@@ -24,12 +24,6 @@ export interface MarkPlotProps extends React.SVGAttributes<SVGSVGElement>, Pick<
24
24
  * @param {LineItemIdentifier} lineItemIdentifier The line mark item identifier.
25
25
  */
26
26
  onItemClick?: (event: React.MouseEvent<SVGElement, MouseEvent>, lineItemIdentifier: LineItemIdentifier) => void;
27
- /**
28
- * If `true` the mark element will only be able to render circle.
29
- * Giving fewer customization options, but saving around 40ms per 1.000 marks.
30
- * @default false
31
- */
32
- experimentalRendering?: boolean;
33
27
  }
34
28
  /**
35
29
  * Demos:
@@ -2,20 +2,20 @@
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
5
- const _excluded = ["slots", "slotProps", "skipAnimation", "onItemClick", "experimentalRendering"];
5
+ const _excluded = ["slots", "slotProps", "skipAnimation", "onItemClick"];
6
6
  import PropTypes from 'prop-types';
7
7
  import * as React from 'react';
8
8
  import { DEFAULT_X_AXIS_KEY } from "../constants/index.js";
9
9
  import { useSkipAnimation } from "../context/AnimationProvider/index.js";
10
- import { useCartesianContext } from "../context/CartesianProvider/index.js";
11
10
  import { useChartId } from "../hooks/useChartId.js";
12
- import { useDrawingArea } from "../hooks/useDrawingArea.js";
13
11
  import { getValueToPositionMapper } from "../hooks/useScale.js";
14
12
  import { useLineSeries } from "../hooks/useSeries.js";
15
13
  import { cleanId } from "../internals/cleanId.js";
16
14
  import { CircleMarkElement } from "./CircleMarkElement.js";
17
15
  import getColor from "./getColor.js";
18
16
  import { MarkElement } from "./MarkElement.js";
17
+ import { useChartContext } from "../context/ChartProvider/index.js";
18
+ import { useXAxes, useYAxes } from "../hooks/index.js";
19
19
  import { jsx as _jsx } from "react/jsx-runtime";
20
20
  /**
21
21
  * Demos:
@@ -32,16 +32,23 @@ function MarkPlot(props) {
32
32
  slots,
33
33
  slotProps,
34
34
  skipAnimation: inSkipAnimation,
35
- onItemClick,
36
- experimentalRendering
35
+ onItemClick
37
36
  } = props,
38
37
  other = _objectWithoutPropertiesLoose(props, _excluded);
39
38
  const skipAnimation = useSkipAnimation(inSkipAnimation);
40
39
  const seriesData = useLineSeries();
41
- const axisData = useCartesianContext();
40
+ const {
41
+ xAxis,
42
+ xAxisIds
43
+ } = useXAxes();
44
+ const {
45
+ yAxis,
46
+ yAxisIds
47
+ } = useYAxes();
42
48
  const chartId = useChartId();
43
- const drawingArea = useDrawingArea();
44
- const Mark = slots?.mark ?? (experimentalRendering ? CircleMarkElement : MarkElement);
49
+ const {
50
+ instance
51
+ } = useChartContext();
45
52
  if (seriesData === undefined) {
46
53
  return null;
47
54
  }
@@ -49,12 +56,6 @@ function MarkPlot(props) {
49
56
  series,
50
57
  stackingGroups
51
58
  } = seriesData;
52
- const {
53
- xAxis,
54
- yAxis,
55
- xAxisIds,
56
- yAxisIds
57
- } = axisData;
58
59
  const defaultXAxisId = xAxisIds[0];
59
60
  const defaultYAxisId = yAxisIds[0];
60
61
  return /*#__PURE__*/_jsx("g", _extends({}, other, {
@@ -67,7 +68,8 @@ function MarkPlot(props) {
67
68
  yAxisId = defaultYAxisId,
68
69
  stackedData,
69
70
  data,
70
- showMark = true
71
+ showMark = true,
72
+ shape = 'circle'
71
73
  } = series[seriesId];
72
74
  if (showMark === false) {
73
75
  return null;
@@ -81,6 +83,7 @@ function MarkPlot(props) {
81
83
  const clipId = cleanId(`${chartId}-${seriesId}-line-clip`); // We assume that if displaying line mark, the line will also be rendered
82
84
 
83
85
  const colorGetter = getColor(series[seriesId], xAxis[xAxisId], yAxis[yAxisId]);
86
+ const Mark = slots?.mark ?? (shape === 'circle' ? CircleMarkElement : MarkElement);
84
87
  return /*#__PURE__*/_jsx("g", {
85
88
  clipPath: `url(#${clipId})`,
86
89
  children: xData?.map((x, index) => {
@@ -103,7 +106,7 @@ function MarkPlot(props) {
103
106
  // Remove missing data point
104
107
  return false;
105
108
  }
106
- if (!drawingArea.isPointInside({
109
+ if (!instance.isPointInside({
107
110
  x,
108
111
  y
109
112
  })) {
@@ -128,7 +131,7 @@ function MarkPlot(props) {
128
131
  return /*#__PURE__*/_jsx(Mark, _extends({
129
132
  id: seriesId,
130
133
  dataIndex: index,
131
- shape: "circle",
134
+ shape: shape,
132
135
  color: colorGetter(index),
133
136
  x: x,
134
137
  y: y // Don't know why TS doesn't get from the filter that y can't be null
@@ -151,12 +154,6 @@ process.env.NODE_ENV !== "production" ? MarkPlot.propTypes = {
151
154
  // | These PropTypes are generated from the TypeScript type definitions |
152
155
  // | To update them edit the TypeScript types and run "pnpm proptypes" |
153
156
  // ----------------------------------------------------------------------
154
- /**
155
- * If `true` the mark element will only be able to render circle.
156
- * Giving fewer customization options, but saving around 40ms per 1.000 marks.
157
- * @default false
158
- */
159
- experimentalRendering: PropTypes.bool,
160
157
  /**
161
158
  * Callback fired when a line mark item is clicked.
162
159
  * @param {React.MouseEvent<SVGPathElement, MouseEvent>} event The event source of the callback.
@@ -1,3 +1,3 @@
1
- import { ExtremumGetter } from '../context/PluginProvider/ExtremumGetter.types';
2
- export declare const getExtremumX: ExtremumGetter<'line'>;
3
- export declare const getExtremumY: ExtremumGetter<'line'>;
1
+ import { CartesianExtremumGetter } from '../internals/plugins/models/seriesConfig/extremumGetter.types';
2
+ export declare const getExtremumX: CartesianExtremumGetter<'line'>;
3
+ export declare const getExtremumY: CartesianExtremumGetter<'line'>;
@@ -1,3 +1,3 @@
1
- import { SeriesFormatter } from '../context/PluginProvider/SeriesFormatter.types';
2
- declare const formatter: SeriesFormatter<'line'>;
1
+ import { SeriesProcessor } from '../internals/plugins/models';
2
+ declare const formatter: SeriesProcessor<'line'>;
3
3
  export default formatter;