@mui/x-charts 8.0.0-beta.1 → 8.0.0-beta.3

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 (450) hide show
  1. package/BarChart/AnimatedBarElement.d.ts +38 -8
  2. package/BarChart/AnimatedBarElement.js +5 -5
  3. package/BarChart/BarChart.js +2 -0
  4. package/BarChart/BarClipPath.d.ts +19 -1
  5. package/BarChart/BarClipPath.js +84 -17
  6. package/BarChart/BarElement.d.ts +9 -20
  7. package/BarChart/BarElement.js +29 -26
  8. package/BarChart/BarLabel/BarLabel.d.ts +27 -854
  9. package/BarChart/BarLabel/BarLabel.js +32 -5
  10. package/BarChart/BarLabel/BarLabel.types.d.ts +2 -0
  11. package/BarChart/BarLabel/BarLabelItem.d.ts +24 -0
  12. package/BarChart/BarLabel/BarLabelItem.js +18 -6
  13. package/BarChart/BarLabel/BarLabelPlot.js +16 -46
  14. package/BarChart/BarLabel/barLabelClasses.d.ts +3 -1
  15. package/BarChart/BarLabel/barLabelClasses.js +4 -3
  16. package/BarChart/BarPlot.js +37 -61
  17. package/BarChart/barElementClasses.d.ts +21 -0
  18. package/BarChart/barElementClasses.js +29 -0
  19. package/BarChart/getRadius.d.ts +1 -1
  20. package/BarChart/index.d.ts +2 -1
  21. package/BarChart/index.js +11 -0
  22. package/BarChart/seriesConfig/index.js +3 -1
  23. package/BarChart/seriesConfig/tooltip.d.ts +2 -1
  24. package/BarChart/seriesConfig/tooltip.js +14 -1
  25. package/BarChart/types.d.ts +2 -2
  26. package/BarChart/useBarChartProps.d.ts +2 -1
  27. package/BarChart/useBarChartProps.js +20 -13
  28. package/CHANGELOG.md +235 -0
  29. package/ChartContainer/ChartContainer.js +4 -0
  30. package/ChartsAxisHighlight/ChartsXAxisHighlight.js +8 -8
  31. package/ChartsAxisHighlight/ChartsYAxisHighlight.js +8 -8
  32. package/ChartsLabel/ChartsLabelMark.js +0 -4
  33. package/ChartsLabel/index.d.ts +1 -0
  34. package/ChartsLabel/index.js +7 -0
  35. package/ChartsLegend/continuousColorLegendClasses.d.ts +1 -1
  36. package/ChartsOverlay/ChartsLoadingOverlay.js +1 -1
  37. package/ChartsOverlay/ChartsNoDataOverlay.js +1 -1
  38. package/ChartsTooltip/ChartsAxisTooltipContent.js +47 -55
  39. package/ChartsTooltip/ChartsItemTooltipContent.js +11 -9
  40. package/ChartsTooltip/ChartsTooltip.js +2 -2
  41. package/ChartsTooltip/ChartsTooltipContainer.js +4 -8
  42. package/ChartsTooltip/ChartsTooltipTable.d.ts +3 -1
  43. package/ChartsTooltip/ChartsTooltipTable.js +24 -9
  44. package/ChartsTooltip/chartsTooltipClasses.d.ts +4 -4
  45. package/ChartsTooltip/chartsTooltipClasses.js +2 -2
  46. package/ChartsTooltip/index.d.ts +1 -0
  47. package/ChartsTooltip/index.js +12 -0
  48. package/ChartsTooltip/useAxesTooltip.d.ts +7 -0
  49. package/ChartsTooltip/useAxesTooltip.js +18 -0
  50. package/ChartsTooltip/useAxisTooltip.d.ts +24 -3
  51. package/ChartsTooltip/useAxisTooltip.js +72 -38
  52. package/ChartsTooltip/useItemTooltip.js +4 -1
  53. package/ChartsXAxis/ChartsXAxis.js +5 -2
  54. package/ChartsYAxis/ChartsYAxis.js +69 -17
  55. package/LineChart/AnimatedArea.js +5 -22
  56. package/LineChart/AnimatedLine.d.ts +1 -4
  57. package/LineChart/AnimatedLine.js +10 -25
  58. package/LineChart/AppearingMask.d.ts +5 -0
  59. package/LineChart/AppearingMask.js +25 -18
  60. package/LineChart/CircleMarkElement.js +17 -23
  61. package/LineChart/LineChart.js +2 -0
  62. package/LineChart/LineHighlightPlot.js +3 -4
  63. package/LineChart/MarkElement.js +16 -27
  64. package/LineChart/MarkPlot.js +0 -1
  65. package/LineChart/markElementClasses.d.ts +3 -0
  66. package/LineChart/markElementClasses.js +4 -3
  67. package/LineChart/seriesConfig/index.js +3 -1
  68. package/LineChart/seriesConfig/tooltip.d.ts +2 -1
  69. package/LineChart/seriesConfig/tooltip.js +8 -1
  70. package/LineChart/useLineChartProps.d.ts +2 -1
  71. package/LineChart/useLineChartProps.js +7 -4
  72. package/PieChart/PieArc.d.ts +19 -11
  73. package/PieChart/PieArc.js +37 -24
  74. package/PieChart/PieArcLabel.d.ts +22 -13
  75. package/PieChart/PieArcLabel.js +52 -48
  76. package/PieChart/PieArcLabelPlot.js +16 -34
  77. package/PieChart/PieArcPlot.js +21 -34
  78. package/PieChart/seriesConfig/tooltip.js +3 -0
  79. package/RadarChart/RadarAxisHighlight/useRadarAxisHighlight.js +9 -5
  80. package/RadarChart/RadarGrid/RadarGrid.d.ts +1 -1
  81. package/RadarChart/RadarGrid/RadarGrid.js +5 -1
  82. package/RadarChart/RadarGrid/useRadarGridData.d.ts +1 -1
  83. package/RadarChart/RadarGrid/useRadarGridData.js +3 -0
  84. package/RadarChart/RadarSeriesPlot/useRadarSeriesData.js +2 -2
  85. package/ScatterChart/ScatterChart.js +2 -0
  86. package/ScatterChart/useScatterChartProps.d.ts +2 -1
  87. package/ScatterChart/useScatterChartProps.js +6 -3
  88. package/SparkLineChart/SparkLineChart.js +2 -0
  89. package/colorPalettes/colorPalettes.js +2 -2
  90. package/constants/index.d.ts +1 -1
  91. package/constants/index.js +1 -1
  92. package/context/AnimationProvider/AnimationProvider.js +4 -6
  93. package/esm/BarChart/AnimatedBarElement.d.ts +38 -8
  94. package/esm/BarChart/AnimatedBarElement.js +5 -5
  95. package/esm/BarChart/BarChart.js +2 -0
  96. package/esm/BarChart/BarClipPath.d.ts +19 -1
  97. package/esm/BarChart/BarClipPath.js +84 -17
  98. package/esm/BarChart/BarElement.d.ts +9 -20
  99. package/esm/BarChart/BarElement.js +28 -23
  100. package/esm/BarChart/BarLabel/BarLabel.d.ts +27 -854
  101. package/esm/BarChart/BarLabel/BarLabel.js +32 -5
  102. package/esm/BarChart/BarLabel/BarLabel.types.d.ts +2 -0
  103. package/esm/BarChart/BarLabel/BarLabelItem.d.ts +24 -0
  104. package/esm/BarChart/BarLabel/BarLabelItem.js +18 -6
  105. package/esm/BarChart/BarLabel/BarLabelPlot.js +16 -46
  106. package/esm/BarChart/BarLabel/barLabelClasses.d.ts +3 -1
  107. package/esm/BarChart/BarLabel/barLabelClasses.js +4 -3
  108. package/esm/BarChart/BarPlot.js +37 -61
  109. package/esm/BarChart/barElementClasses.d.ts +21 -0
  110. package/esm/BarChart/barElementClasses.js +19 -0
  111. package/esm/BarChart/getRadius.d.ts +1 -1
  112. package/esm/BarChart/index.d.ts +2 -1
  113. package/esm/BarChart/index.js +2 -1
  114. package/esm/BarChart/seriesConfig/index.js +2 -1
  115. package/esm/BarChart/seriesConfig/tooltip.d.ts +2 -1
  116. package/esm/BarChart/seriesConfig/tooltip.js +12 -0
  117. package/esm/BarChart/types.d.ts +2 -2
  118. package/esm/BarChart/useBarChartProps.d.ts +2 -1
  119. package/esm/BarChart/useBarChartProps.js +19 -13
  120. package/esm/ChartContainer/ChartContainer.js +4 -0
  121. package/esm/ChartsAxisHighlight/ChartsXAxisHighlight.js +8 -8
  122. package/esm/ChartsAxisHighlight/ChartsYAxisHighlight.js +8 -8
  123. package/esm/ChartsLabel/ChartsLabelMark.js +0 -4
  124. package/esm/ChartsLabel/index.d.ts +1 -0
  125. package/esm/ChartsLabel/index.js +1 -0
  126. package/esm/ChartsLegend/continuousColorLegendClasses.d.ts +1 -1
  127. package/esm/ChartsOverlay/ChartsLoadingOverlay.js +1 -1
  128. package/esm/ChartsOverlay/ChartsNoDataOverlay.js +1 -1
  129. package/esm/ChartsTooltip/ChartsAxisTooltipContent.js +47 -55
  130. package/esm/ChartsTooltip/ChartsItemTooltipContent.js +11 -9
  131. package/esm/ChartsTooltip/ChartsTooltip.js +2 -2
  132. package/esm/ChartsTooltip/ChartsTooltipContainer.js +5 -9
  133. package/esm/ChartsTooltip/ChartsTooltipTable.d.ts +3 -1
  134. package/esm/ChartsTooltip/ChartsTooltipTable.js +23 -9
  135. package/esm/ChartsTooltip/chartsTooltipClasses.d.ts +4 -4
  136. package/esm/ChartsTooltip/chartsTooltipClasses.js +2 -2
  137. package/esm/ChartsTooltip/index.d.ts +1 -0
  138. package/esm/ChartsTooltip/index.js +1 -0
  139. package/esm/ChartsTooltip/useAxesTooltip.d.ts +7 -0
  140. package/esm/ChartsTooltip/useAxesTooltip.js +12 -0
  141. package/esm/ChartsTooltip/useAxisTooltip.d.ts +24 -3
  142. package/esm/ChartsTooltip/useAxisTooltip.js +72 -38
  143. package/esm/ChartsTooltip/useItemTooltip.js +4 -1
  144. package/esm/ChartsXAxis/ChartsXAxis.js +5 -2
  145. package/esm/ChartsYAxis/ChartsYAxis.js +69 -17
  146. package/esm/LineChart/AnimatedArea.js +5 -22
  147. package/esm/LineChart/AnimatedLine.d.ts +1 -4
  148. package/esm/LineChart/AnimatedLine.js +9 -24
  149. package/esm/LineChart/AppearingMask.d.ts +5 -0
  150. package/esm/LineChart/AppearingMask.js +23 -18
  151. package/esm/LineChart/CircleMarkElement.js +19 -25
  152. package/esm/LineChart/LineChart.js +2 -0
  153. package/esm/LineChart/LineHighlightPlot.js +3 -4
  154. package/esm/LineChart/MarkElement.js +17 -28
  155. package/esm/LineChart/MarkPlot.js +0 -1
  156. package/esm/LineChart/markElementClasses.d.ts +3 -0
  157. package/esm/LineChart/markElementClasses.js +4 -3
  158. package/esm/LineChart/seriesConfig/index.js +2 -1
  159. package/esm/LineChart/seriesConfig/tooltip.d.ts +2 -1
  160. package/esm/LineChart/seriesConfig/tooltip.js +6 -0
  161. package/esm/LineChart/useLineChartProps.d.ts +2 -1
  162. package/esm/LineChart/useLineChartProps.js +6 -4
  163. package/esm/PieChart/PieArc.d.ts +19 -11
  164. package/esm/PieChart/PieArc.js +36 -23
  165. package/esm/PieChart/PieArcLabel.d.ts +22 -13
  166. package/esm/PieChart/PieArcLabel.js +51 -47
  167. package/esm/PieChart/PieArcLabelPlot.js +16 -34
  168. package/esm/PieChart/PieArcPlot.js +21 -34
  169. package/esm/PieChart/seriesConfig/tooltip.js +3 -0
  170. package/esm/RadarChart/RadarAxisHighlight/useRadarAxisHighlight.js +9 -5
  171. package/esm/RadarChart/RadarGrid/RadarGrid.d.ts +1 -1
  172. package/esm/RadarChart/RadarGrid/RadarGrid.js +5 -1
  173. package/esm/RadarChart/RadarGrid/useRadarGridData.d.ts +1 -1
  174. package/esm/RadarChart/RadarGrid/useRadarGridData.js +3 -0
  175. package/esm/RadarChart/RadarSeriesPlot/useRadarSeriesData.js +2 -2
  176. package/esm/ScatterChart/ScatterChart.js +2 -0
  177. package/esm/ScatterChart/useScatterChartProps.d.ts +2 -1
  178. package/esm/ScatterChart/useScatterChartProps.js +5 -3
  179. package/esm/SparkLineChart/SparkLineChart.js +2 -0
  180. package/esm/colorPalettes/colorPalettes.js +2 -2
  181. package/esm/constants/index.d.ts +1 -1
  182. package/esm/constants/index.js +1 -1
  183. package/esm/context/AnimationProvider/AnimationProvider.js +3 -6
  184. package/esm/hooks/animation/index.d.ts +6 -0
  185. package/esm/hooks/animation/index.js +6 -0
  186. package/esm/hooks/animation/useAnimateArea.d.ts +15 -0
  187. package/esm/hooks/animation/useAnimateArea.js +27 -0
  188. package/esm/hooks/animation/useAnimateBar.d.ts +17 -0
  189. package/esm/hooks/animation/useAnimateBar.js +56 -0
  190. package/esm/hooks/animation/useAnimateBarLabel.d.ts +19 -0
  191. package/esm/hooks/animation/useAnimateBarLabel.js +59 -0
  192. package/esm/hooks/animation/useAnimateLine.d.ts +14 -0
  193. package/esm/hooks/animation/useAnimateLine.js +26 -0
  194. package/esm/hooks/animation/useAnimatePieArc.d.ts +15 -0
  195. package/esm/hooks/animation/useAnimatePieArc.js +70 -0
  196. package/esm/hooks/animation/useAnimatePieArcLabel.d.ts +15 -0
  197. package/esm/hooks/animation/useAnimatePieArcLabel.js +72 -0
  198. package/esm/hooks/index.d.ts +2 -1
  199. package/esm/hooks/index.js +2 -1
  200. package/esm/hooks/useAxis.d.ts +5 -5
  201. package/esm/hooks/useInteractionItemProps.js +11 -0
  202. package/esm/hooks/useScale.d.ts +2 -2
  203. package/esm/hooks/useScale.js +2 -2
  204. package/esm/index.js +1 -1
  205. package/esm/internals/animation/Transition.d.ts +37 -0
  206. package/esm/internals/animation/Transition.js +83 -0
  207. package/esm/internals/animation/animation.d.ts +4 -0
  208. package/esm/internals/animation/animation.js +4 -0
  209. package/esm/internals/animation/useAnimate.d.ts +19 -0
  210. package/esm/internals/animation/useAnimate.js +74 -0
  211. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.d.ts +1 -1
  212. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js +9 -3
  213. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisTriggerTooltip.d.ts +5 -0
  214. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisTriggerTooltip.js +21 -0
  215. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.d.ts +8 -6
  216. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.js +28 -22
  217. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +1 -0
  218. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +1 -0
  219. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +9 -42
  220. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxisRendering.selectors.d.ts +8 -32
  221. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.d.ts +9 -0
  222. package/esm/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.js +75 -0
  223. package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +7 -20
  224. package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +36 -242
  225. package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js +4 -10
  226. package/esm/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +9 -15
  227. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.d.ts +12 -0
  228. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.js +8 -0
  229. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.d.ts +6 -4
  230. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.js +18 -13
  231. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarAxis.js +16 -32
  232. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.d.ts +3669 -0
  233. package/esm/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.js +22 -0
  234. package/esm/internals/plugins/models/seriesConfig/seriesConfig.types.d.ts +3 -1
  235. package/esm/internals/plugins/models/seriesConfig/tooltipGetter.types.d.ts +10 -4
  236. package/esm/internals/shallowEqual.d.ts +8 -0
  237. package/esm/internals/shallowEqual.js +31 -0
  238. package/esm/models/axis.d.ts +8 -0
  239. package/esm/themeAugmentation/overrides.d.ts +1 -1
  240. package/hooks/animation/index.d.ts +6 -0
  241. package/hooks/animation/index.js +71 -0
  242. package/hooks/animation/useAnimateArea.d.ts +15 -0
  243. package/hooks/animation/useAnimateArea.js +34 -0
  244. package/hooks/animation/useAnimateBar.d.ts +17 -0
  245. package/hooks/animation/useAnimateBar.js +62 -0
  246. package/hooks/animation/useAnimateBarLabel.d.ts +19 -0
  247. package/hooks/animation/useAnimateBarLabel.js +65 -0
  248. package/hooks/animation/useAnimateLine.d.ts +14 -0
  249. package/hooks/animation/useAnimateLine.js +33 -0
  250. package/hooks/animation/useAnimatePieArc.d.ts +15 -0
  251. package/hooks/animation/useAnimatePieArc.js +77 -0
  252. package/hooks/animation/useAnimatePieArcLabel.d.ts +15 -0
  253. package/hooks/animation/useAnimatePieArcLabel.js +79 -0
  254. package/hooks/index.d.ts +2 -1
  255. package/hooks/index.js +13 -1
  256. package/hooks/useAxis.d.ts +5 -5
  257. package/hooks/useInteractionItemProps.js +11 -0
  258. package/hooks/useScale.d.ts +2 -2
  259. package/hooks/useScale.js +2 -2
  260. package/index.js +1 -1
  261. package/internals/animation/Transition.d.ts +37 -0
  262. package/internals/animation/Transition.js +89 -0
  263. package/internals/animation/animation.d.ts +4 -0
  264. package/internals/animation/animation.js +11 -0
  265. package/internals/animation/useAnimate.d.ts +19 -0
  266. package/internals/animation/useAnimate.js +80 -0
  267. package/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.d.ts +1 -1
  268. package/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js +9 -3
  269. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisTriggerTooltip.d.ts +5 -0
  270. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisTriggerTooltip.js +28 -0
  271. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.d.ts +8 -6
  272. package/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.js +29 -22
  273. package/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +1 -0
  274. package/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +12 -0
  275. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +7 -40
  276. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxisRendering.selectors.d.ts +8 -32
  277. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.d.ts +9 -0
  278. package/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.js +81 -0
  279. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +7 -20
  280. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +36 -242
  281. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js +5 -11
  282. package/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +9 -15
  283. package/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.d.ts +12 -0
  284. package/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.js +17 -0
  285. package/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.d.ts +6 -4
  286. package/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.js +19 -13
  287. package/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarAxis.js +16 -32
  288. package/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.d.ts +3669 -0
  289. package/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.js +28 -0
  290. package/internals/plugins/models/seriesConfig/seriesConfig.types.d.ts +3 -1
  291. package/internals/plugins/models/seriesConfig/tooltipGetter.types.d.ts +10 -4
  292. package/internals/shallowEqual.d.ts +8 -0
  293. package/internals/shallowEqual.js +37 -0
  294. package/models/axis.d.ts +8 -0
  295. package/modern/BarChart/AnimatedBarElement.d.ts +38 -8
  296. package/modern/BarChart/AnimatedBarElement.js +5 -5
  297. package/modern/BarChart/BarChart.js +2 -0
  298. package/modern/BarChart/BarClipPath.d.ts +19 -1
  299. package/modern/BarChart/BarClipPath.js +84 -17
  300. package/modern/BarChart/BarElement.d.ts +9 -20
  301. package/modern/BarChart/BarElement.js +28 -23
  302. package/modern/BarChart/BarLabel/BarLabel.d.ts +27 -854
  303. package/modern/BarChart/BarLabel/BarLabel.js +32 -5
  304. package/modern/BarChart/BarLabel/BarLabel.types.d.ts +2 -0
  305. package/modern/BarChart/BarLabel/BarLabelItem.d.ts +24 -0
  306. package/modern/BarChart/BarLabel/BarLabelItem.js +18 -6
  307. package/modern/BarChart/BarLabel/BarLabelPlot.js +16 -46
  308. package/modern/BarChart/BarLabel/barLabelClasses.d.ts +3 -1
  309. package/modern/BarChart/BarLabel/barLabelClasses.js +4 -3
  310. package/modern/BarChart/BarPlot.js +37 -61
  311. package/modern/BarChart/barElementClasses.d.ts +21 -0
  312. package/modern/BarChart/barElementClasses.js +19 -0
  313. package/modern/BarChart/getRadius.d.ts +1 -1
  314. package/modern/BarChart/index.d.ts +2 -1
  315. package/modern/BarChart/index.js +2 -1
  316. package/modern/BarChart/seriesConfig/index.js +2 -1
  317. package/modern/BarChart/seriesConfig/tooltip.d.ts +2 -1
  318. package/modern/BarChart/seriesConfig/tooltip.js +12 -0
  319. package/modern/BarChart/types.d.ts +2 -2
  320. package/modern/BarChart/useBarChartProps.d.ts +2 -1
  321. package/modern/BarChart/useBarChartProps.js +19 -13
  322. package/modern/ChartContainer/ChartContainer.js +4 -0
  323. package/modern/ChartsAxisHighlight/ChartsXAxisHighlight.js +8 -8
  324. package/modern/ChartsAxisHighlight/ChartsYAxisHighlight.js +8 -8
  325. package/modern/ChartsLabel/ChartsLabelMark.js +0 -4
  326. package/modern/ChartsLabel/index.d.ts +1 -0
  327. package/modern/ChartsLabel/index.js +1 -0
  328. package/modern/ChartsLegend/continuousColorLegendClasses.d.ts +1 -1
  329. package/modern/ChartsOverlay/ChartsLoadingOverlay.js +1 -1
  330. package/modern/ChartsOverlay/ChartsNoDataOverlay.js +1 -1
  331. package/modern/ChartsTooltip/ChartsAxisTooltipContent.js +47 -55
  332. package/modern/ChartsTooltip/ChartsItemTooltipContent.js +11 -9
  333. package/modern/ChartsTooltip/ChartsTooltip.js +2 -2
  334. package/modern/ChartsTooltip/ChartsTooltipContainer.js +5 -9
  335. package/modern/ChartsTooltip/ChartsTooltipTable.d.ts +3 -1
  336. package/modern/ChartsTooltip/ChartsTooltipTable.js +23 -9
  337. package/modern/ChartsTooltip/chartsTooltipClasses.d.ts +4 -4
  338. package/modern/ChartsTooltip/chartsTooltipClasses.js +2 -2
  339. package/modern/ChartsTooltip/index.d.ts +1 -0
  340. package/modern/ChartsTooltip/index.js +1 -0
  341. package/modern/ChartsTooltip/useAxesTooltip.d.ts +7 -0
  342. package/modern/ChartsTooltip/useAxesTooltip.js +12 -0
  343. package/modern/ChartsTooltip/useAxisTooltip.d.ts +24 -3
  344. package/modern/ChartsTooltip/useAxisTooltip.js +72 -38
  345. package/modern/ChartsTooltip/useItemTooltip.js +4 -1
  346. package/modern/ChartsXAxis/ChartsXAxis.js +5 -2
  347. package/modern/ChartsYAxis/ChartsYAxis.js +69 -17
  348. package/modern/LineChart/AnimatedArea.js +5 -22
  349. package/modern/LineChart/AnimatedLine.d.ts +1 -4
  350. package/modern/LineChart/AnimatedLine.js +9 -24
  351. package/modern/LineChart/AppearingMask.d.ts +5 -0
  352. package/modern/LineChart/AppearingMask.js +23 -18
  353. package/modern/LineChart/CircleMarkElement.js +19 -25
  354. package/modern/LineChart/LineChart.js +2 -0
  355. package/modern/LineChart/LineHighlightPlot.js +3 -4
  356. package/modern/LineChart/MarkElement.js +17 -28
  357. package/modern/LineChart/MarkPlot.js +0 -1
  358. package/modern/LineChart/markElementClasses.d.ts +3 -0
  359. package/modern/LineChart/markElementClasses.js +4 -3
  360. package/modern/LineChart/seriesConfig/index.js +2 -1
  361. package/modern/LineChart/seriesConfig/tooltip.d.ts +2 -1
  362. package/modern/LineChart/seriesConfig/tooltip.js +6 -0
  363. package/modern/LineChart/useLineChartProps.d.ts +2 -1
  364. package/modern/LineChart/useLineChartProps.js +6 -4
  365. package/modern/PieChart/PieArc.d.ts +19 -11
  366. package/modern/PieChart/PieArc.js +36 -23
  367. package/modern/PieChart/PieArcLabel.d.ts +22 -13
  368. package/modern/PieChart/PieArcLabel.js +51 -47
  369. package/modern/PieChart/PieArcLabelPlot.js +16 -34
  370. package/modern/PieChart/PieArcPlot.js +21 -34
  371. package/modern/PieChart/seriesConfig/tooltip.js +3 -0
  372. package/modern/RadarChart/RadarAxisHighlight/useRadarAxisHighlight.js +9 -5
  373. package/modern/RadarChart/RadarGrid/RadarGrid.d.ts +1 -1
  374. package/modern/RadarChart/RadarGrid/RadarGrid.js +5 -1
  375. package/modern/RadarChart/RadarGrid/useRadarGridData.d.ts +1 -1
  376. package/modern/RadarChart/RadarGrid/useRadarGridData.js +3 -0
  377. package/modern/RadarChart/RadarSeriesPlot/useRadarSeriesData.js +2 -2
  378. package/modern/ScatterChart/ScatterChart.js +2 -0
  379. package/modern/ScatterChart/useScatterChartProps.d.ts +2 -1
  380. package/modern/ScatterChart/useScatterChartProps.js +5 -3
  381. package/modern/SparkLineChart/SparkLineChart.js +2 -0
  382. package/modern/colorPalettes/colorPalettes.js +2 -2
  383. package/modern/constants/index.d.ts +1 -1
  384. package/modern/constants/index.js +1 -1
  385. package/modern/context/AnimationProvider/AnimationProvider.js +3 -6
  386. package/modern/hooks/animation/index.d.ts +6 -0
  387. package/modern/hooks/animation/index.js +6 -0
  388. package/modern/hooks/animation/useAnimateArea.d.ts +15 -0
  389. package/modern/hooks/animation/useAnimateArea.js +27 -0
  390. package/modern/hooks/animation/useAnimateBar.d.ts +17 -0
  391. package/modern/hooks/animation/useAnimateBar.js +56 -0
  392. package/modern/hooks/animation/useAnimateBarLabel.d.ts +19 -0
  393. package/modern/hooks/animation/useAnimateBarLabel.js +59 -0
  394. package/modern/hooks/animation/useAnimateLine.d.ts +14 -0
  395. package/modern/hooks/animation/useAnimateLine.js +26 -0
  396. package/modern/hooks/animation/useAnimatePieArc.d.ts +15 -0
  397. package/modern/hooks/animation/useAnimatePieArc.js +70 -0
  398. package/modern/hooks/animation/useAnimatePieArcLabel.d.ts +15 -0
  399. package/modern/hooks/animation/useAnimatePieArcLabel.js +72 -0
  400. package/modern/hooks/index.d.ts +2 -1
  401. package/modern/hooks/index.js +2 -1
  402. package/modern/hooks/useAxis.d.ts +5 -5
  403. package/modern/hooks/useInteractionItemProps.js +11 -0
  404. package/modern/hooks/useScale.d.ts +2 -2
  405. package/modern/hooks/useScale.js +2 -2
  406. package/modern/index.js +1 -1
  407. package/modern/internals/animation/Transition.d.ts +37 -0
  408. package/modern/internals/animation/Transition.js +83 -0
  409. package/modern/internals/animation/animation.d.ts +4 -0
  410. package/modern/internals/animation/animation.js +4 -0
  411. package/modern/internals/animation/useAnimate.d.ts +19 -0
  412. package/modern/internals/animation/useAnimate.js +74 -0
  413. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.d.ts +1 -1
  414. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/computeAxisValue.js +9 -3
  415. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisTriggerTooltip.d.ts +5 -0
  416. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisTriggerTooltip.js +21 -0
  417. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.d.ts +8 -6
  418. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/getAxisValue.js +28 -22
  419. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.d.ts +1 -0
  420. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/index.js +1 -0
  421. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxis.js +9 -42
  422. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianAxisRendering.selectors.d.ts +8 -32
  423. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.d.ts +9 -0
  424. package/modern/internals/plugins/featurePlugins/useChartCartesianAxis/useChartCartesianInteraction.selectors.js +75 -0
  425. package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.js +7 -20
  426. package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.d.ts +36 -242
  427. package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.selectors.js +4 -10
  428. package/modern/internals/plugins/featurePlugins/useChartInteraction/useChartInteraction.types.d.ts +9 -15
  429. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.d.ts +12 -0
  430. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/coordinateTransformation.js +8 -0
  431. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.d.ts +6 -4
  432. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/getAxisValue.js +18 -13
  433. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarAxis.js +16 -32
  434. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.d.ts +3669 -0
  435. package/modern/internals/plugins/featurePlugins/useChartPolarAxis/useChartPolarInteraction.selectors.js +22 -0
  436. package/modern/internals/plugins/models/seriesConfig/seriesConfig.types.d.ts +3 -1
  437. package/modern/internals/plugins/models/seriesConfig/tooltipGetter.types.d.ts +10 -4
  438. package/modern/internals/shallowEqual.d.ts +8 -0
  439. package/modern/internals/shallowEqual.js +31 -0
  440. package/modern/models/axis.d.ts +8 -0
  441. package/modern/themeAugmentation/overrides.d.ts +1 -1
  442. package/package.json +8 -9
  443. package/themeAugmentation/overrides.d.ts +1 -1
  444. package/tsconfig.build.tsbuildinfo +1 -1
  445. package/PieChart/dataTransform/transition.d.ts +0 -4
  446. package/PieChart/dataTransform/transition.js +0 -145
  447. package/esm/PieChart/dataTransform/transition.d.ts +0 -4
  448. package/esm/PieChart/dataTransform/transition.js +0 -137
  449. package/modern/PieChart/dataTransform/transition.d.ts +0 -4
  450. package/modern/PieChart/dataTransform/transition.js +0 -137
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
3
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
5
  Object.defineProperty(exports, "__esModule", {
5
6
  value: true
@@ -9,13 +10,14 @@ var _extremums = require("./extremums");
9
10
  var _seriesProcessor = _interopRequireDefault(require("./seriesProcessor"));
10
11
  var _getColor = _interopRequireDefault(require("./getColor"));
11
12
  var _legend = _interopRequireDefault(require("./legend"));
12
- var _tooltip = _interopRequireDefault(require("./tooltip"));
13
+ var _tooltip = _interopRequireWildcard(require("./tooltip"));
13
14
  var _getSeriesWithDefaultValues = _interopRequireDefault(require("./getSeriesWithDefaultValues"));
14
15
  const seriesConfig = exports.seriesConfig = {
15
16
  colorProcessor: _getColor.default,
16
17
  seriesProcessor: _seriesProcessor.default,
17
18
  legendGetter: _legend.default,
18
19
  tooltipGetter: _tooltip.default,
20
+ axisTooltipGetter: _tooltip.axisTooltipGetter,
19
21
  xExtremumGetter: _extremums.getExtremumX,
20
22
  yExtremumGetter: _extremums.getExtremumY,
21
23
  getSeriesWithDefaultValues: _getSeriesWithDefaultValues.default
@@ -1,3 +1,4 @@
1
- import type { TooltipGetter } from '../../internals/plugins/models';
1
+ import type { AxisTooltipGetter, TooltipGetter } from '../../internals/plugins/models';
2
2
  declare const tooltipGetter: TooltipGetter<'line'>;
3
+ export declare const axisTooltipGetter: AxisTooltipGetter<'line', 'x' | 'y'>;
3
4
  export default tooltipGetter;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.default = void 0;
6
+ exports.default = exports.axisTooltipGetter = void 0;
7
7
  var _getLabel = require("../../internals/getLabel");
8
8
  const tooltipGetter = params => {
9
9
  const {
@@ -28,4 +28,11 @@ const tooltipGetter = params => {
28
28
  markType: series.labelMarkType
29
29
  };
30
30
  };
31
+ const axisTooltipGetter = series => {
32
+ return Object.values(series).map(s => ({
33
+ direction: 'x',
34
+ axisId: s.xAxisId
35
+ }));
36
+ };
37
+ exports.axisTooltipGetter = axisTooltipGetter;
31
38
  var _default = exports.default = tooltipGetter;
@@ -1,3 +1,4 @@
1
+ import * as React from 'react';
1
2
  import { ChartsAxisProps } from "../ChartsAxis/index.js";
2
3
  import { ChartsAxisHighlightProps } from "../ChartsAxisHighlight/index.js";
3
4
  import { ChartsClipPathProps } from "../ChartsClipPath/index.js";
@@ -35,5 +36,5 @@ export declare const useLineChartProps: (props: LineChartProps) => {
35
36
  axisHighlightProps: ChartsAxisHighlightProps;
36
37
  lineHighlightPlotProps: LineHighlightPlotProps;
37
38
  legendProps: ChartsLegendSlotExtension;
38
- children: import("react").ReactNode;
39
+ children: React.ReactNode;
39
40
  };
@@ -2,12 +2,14 @@
2
2
  'use client';
3
3
 
4
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
6
  Object.defineProperty(exports, "__esModule", {
6
7
  value: true
7
8
  });
8
9
  exports.useLineChartProps = void 0;
9
10
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
11
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
12
+ var React = _interopRequireWildcard(require("react"));
11
13
  var _useId = _interopRequireDefault(require("@mui/utils/useId"));
12
14
  var _constants = require("../constants");
13
15
  var _LineChart = require("./LineChart.plugins");
@@ -48,11 +50,12 @@ const useLineChartProps = props => {
48
50
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
49
51
  const id = (0, _useId.default)();
50
52
  const clipPathId = `${id}-clip-path`;
53
+ const seriesWithDefault = React.useMemo(() => series.map(s => (0, _extends2.default)({
54
+ disableHighlight: !!disableLineItemHighlight,
55
+ type: 'line'
56
+ }, s)), [disableLineItemHighlight, series]);
51
57
  const chartContainerProps = (0, _extends2.default)({}, other, {
52
- series: series.map(s => (0, _extends2.default)({
53
- disableHighlight: !!disableLineItemHighlight,
54
- type: 'line'
55
- }, s)),
58
+ series: seriesWithDefault,
56
59
  width,
57
60
  height,
58
61
  margin,
@@ -1,5 +1,4 @@
1
1
  import * as React from 'react';
2
- import { SpringValue } from '@react-spring/web';
3
2
  import { PieItemId } from "../models/index.js";
4
3
  export interface PieArcClasses {
5
4
  /** Styles applied to the root element. */
@@ -21,16 +20,25 @@ interface PieArcOwnerState {
21
20
  export declare function getPieArcUtilityClass(slot: string): string;
22
21
  export declare const pieArcClasses: PieArcClasses;
23
22
  export type PieArcProps = Omit<React.SVGProps<SVGPathElement>, 'ref' | 'id'> & PieArcOwnerState & {
24
- cornerRadius: SpringValue<number>;
25
- endAngle: SpringValue<number>;
26
- innerRadius: SpringValue<number>;
23
+ cornerRadius: number;
24
+ endAngle: number;
25
+ innerRadius: number;
27
26
  onClick?: (event: React.MouseEvent<SVGPathElement, MouseEvent>) => void;
28
- outerRadius: SpringValue<number>;
29
- paddingAngle: SpringValue<number>;
30
- startAngle: SpringValue<number>;
27
+ outerRadius: number;
28
+ paddingAngle: number;
29
+ startAngle: number;
30
+ /** @default false */
31
+ skipAnimation: boolean;
31
32
  };
32
- declare function PieArc(props: PieArcProps): React.JSX.Element;
33
- declare namespace PieArc {
34
- var propTypes: any;
35
- }
33
+ declare const PieArc: React.ForwardRefExoticComponent<Omit<React.SVGProps<SVGPathElement>, "ref" | "id"> & PieArcOwnerState & {
34
+ cornerRadius: number;
35
+ endAngle: number;
36
+ innerRadius: number;
37
+ onClick?: (event: React.MouseEvent<SVGPathElement, MouseEvent>) => void;
38
+ outerRadius: number;
39
+ paddingAngle: number;
40
+ startAngle: number;
41
+ /** @default false */
42
+ skipAnimation: boolean;
43
+ } & React.RefAttributes<SVGPathElement>>;
36
44
  export { PieArc };
@@ -6,22 +6,22 @@ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWild
6
6
  Object.defineProperty(exports, "__esModule", {
7
7
  value: true
8
8
  });
9
- exports.PieArc = PieArc;
9
+ exports.PieArc = void 0;
10
10
  exports.getPieArcUtilityClass = getPieArcUtilityClass;
11
11
  exports.pieArcClasses = void 0;
12
12
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
13
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
14
14
  var React = _interopRequireWildcard(require("react"));
15
15
  var _propTypes = _interopRequireDefault(require("prop-types"));
16
- var _d3Shape = require("@mui/x-charts-vendor/d3-shape");
17
- var _web = require("@react-spring/web");
18
16
  var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
19
17
  var _generateUtilityClass = _interopRequireDefault(require("@mui/utils/generateUtilityClass"));
20
18
  var _styles = require("@mui/material/styles");
21
19
  var _generateUtilityClasses = _interopRequireDefault(require("@mui/utils/generateUtilityClasses"));
20
+ var _hooks = require("../hooks");
21
+ var _animation = require("../internals/animation/animation");
22
22
  var _useInteractionItemProps = require("../hooks/useInteractionItemProps");
23
23
  var _jsxRuntime = require("react/jsx-runtime");
24
- const _excluded = ["classes", "color", "cornerRadius", "dataIndex", "endAngle", "id", "innerRadius", "isFaded", "isHighlighted", "onClick", "outerRadius", "paddingAngle", "startAngle"];
24
+ const _excluded = ["classes", "color", "dataIndex", "id", "isFaded", "isHighlighted", "onClick", "cornerRadius", "startAngle", "endAngle", "innerRadius", "outerRadius", "paddingAngle", "skipAnimation"];
25
25
  function getPieArcUtilityClass(slot) {
26
26
  return (0, _generateUtilityClass.default)('MuiPieArc', slot);
27
27
  }
@@ -39,7 +39,7 @@ const useUtilityClasses = ownerState => {
39
39
  };
40
40
  return (0, _composeClasses.default)(slots, getPieArcUtilityClass, classes);
41
41
  };
42
- const PieArcRoot = (0, _styles.styled)(_web.animated.path, {
42
+ const PieArcRoot = (0, _styles.styled)('path', {
43
43
  name: 'MuiPieArc',
44
44
  slot: 'Root',
45
45
  overridesResolver: (_, styles) => styles.arc
@@ -48,23 +48,26 @@ const PieArcRoot = (0, _styles.styled)(_web.animated.path, {
48
48
  }) => ({
49
49
  // Got to move stroke to an element prop instead of style.
50
50
  stroke: (theme.vars || theme).palette.background.paper,
51
- transition: 'opacity 0.2s ease-in, fill 0.2s ease-in, filter 0.2s ease-in'
51
+ transitionProperty: 'opacity, fill, filter',
52
+ transitionDuration: `${_animation.ANIMATION_DURATION_MS}ms`,
53
+ transitionTimingFunction: _animation.ANIMATION_TIMING_FUNCTION
52
54
  }));
53
- function PieArc(props) {
55
+ const PieArc = exports.PieArc = /*#__PURE__*/React.forwardRef(function PieArc(props, ref) {
54
56
  const {
55
57
  classes: innerClasses,
56
58
  color,
57
- cornerRadius,
58
59
  dataIndex,
59
- endAngle,
60
60
  id,
61
- innerRadius,
62
61
  isFaded,
63
62
  isHighlighted,
64
63
  onClick,
64
+ cornerRadius,
65
+ startAngle,
66
+ endAngle,
67
+ innerRadius,
65
68
  outerRadius,
66
69
  paddingAngle,
67
- startAngle
70
+ skipAnimation
68
71
  } = props,
69
72
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
70
73
  const ownerState = {
@@ -81,17 +84,17 @@ function PieArc(props) {
81
84
  seriesId: id,
82
85
  dataIndex
83
86
  });
87
+ const animatedProps = (0, _hooks.useAnimatePieArc)({
88
+ cornerRadius,
89
+ startAngle,
90
+ endAngle,
91
+ innerRadius,
92
+ outerRadius,
93
+ paddingAngle,
94
+ skipAnimation,
95
+ ref
96
+ });
84
97
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(PieArcRoot, (0, _extends2.default)({
85
- d: (0, _web.to)([startAngle, endAngle, paddingAngle, innerRadius, outerRadius, cornerRadius], (sA, eA, pA, iR, oR, cR) => (0, _d3Shape.arc)().cornerRadius(cR)({
86
- padAngle: pA,
87
- startAngle: sA,
88
- endAngle: eA,
89
- innerRadius: iR,
90
- outerRadius: oR
91
- })),
92
- visibility: (0, _web.to)([startAngle, endAngle], (sA, eA) => sA === eA ? 'hidden' : 'visible')
93
- // @ts-expect-error
94
- ,
95
98
  onClick: onClick,
96
99
  cursor: onClick ? 'pointer' : 'unset',
97
100
  ownerState: ownerState,
@@ -101,16 +104,26 @@ function PieArc(props) {
101
104
  filter: ownerState.isHighlighted ? 'brightness(120%)' : 'none',
102
105
  strokeWidth: 1,
103
106
  strokeLinejoin: "round"
104
- }, other, interactionProps));
105
- }
107
+ }, other, interactionProps, animatedProps));
108
+ });
106
109
  process.env.NODE_ENV !== "production" ? PieArc.propTypes = {
107
110
  // ----------------------------- Warning --------------------------------
108
111
  // | These PropTypes are generated from the TypeScript type definitions |
109
112
  // | To update them edit the TypeScript types and run "pnpm proptypes" |
110
113
  // ----------------------------------------------------------------------
111
114
  classes: _propTypes.default.object,
115
+ cornerRadius: _propTypes.default.number.isRequired,
112
116
  dataIndex: _propTypes.default.number.isRequired,
117
+ endAngle: _propTypes.default.number.isRequired,
113
118
  id: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.string]).isRequired,
119
+ innerRadius: _propTypes.default.number.isRequired,
114
120
  isFaded: _propTypes.default.bool.isRequired,
115
- isHighlighted: _propTypes.default.bool.isRequired
121
+ isHighlighted: _propTypes.default.bool.isRequired,
122
+ outerRadius: _propTypes.default.number.isRequired,
123
+ paddingAngle: _propTypes.default.number.isRequired,
124
+ /**
125
+ * @default false
126
+ */
127
+ skipAnimation: _propTypes.default.bool.isRequired,
128
+ startAngle: _propTypes.default.number.isRequired
116
129
  } : void 0;
@@ -1,5 +1,4 @@
1
1
  import * as React from 'react';
2
- import { SpringValue } from '@react-spring/web';
3
2
  import { PieItemId } from "../models/seriesType/pie.js";
4
3
  export interface PieArcLabelClasses {
5
4
  /** Styles applied to the root element. */
@@ -8,6 +7,8 @@ export interface PieArcLabelClasses {
8
7
  highlighted: string;
9
8
  /** Styles applied to the root element when faded. */
10
9
  faded: string;
10
+ /** Styles applied to the root element when animation is not skipped. */
11
+ animate: string;
11
12
  }
12
13
  export type PieArcLabelClassKey = keyof PieArcLabelClasses;
13
14
  interface PieArcLabelOwnerState {
@@ -15,23 +16,31 @@ interface PieArcLabelOwnerState {
15
16
  color: string;
16
17
  isFaded: boolean;
17
18
  isHighlighted: boolean;
19
+ skipAnimation: boolean;
18
20
  classes?: Partial<PieArcLabelClasses>;
19
21
  }
20
22
  export declare function getPieArcLabelUtilityClass(slot: string): string;
21
23
  export declare const pieArcLabelClasses: PieArcLabelClasses;
22
24
  export type PieArcLabelProps = PieArcLabelOwnerState & Omit<React.SVGProps<SVGTextElement>, 'ref' | 'color' | 'id'> & {
23
- startAngle: SpringValue<number>;
24
- endAngle: SpringValue<number>;
25
- innerRadius: SpringValue<number>;
26
- outerRadius: SpringValue<number>;
27
- arcLabelRadius: SpringValue<number>;
28
- cornerRadius: SpringValue<number>;
29
- paddingAngle: SpringValue<number>;
30
- } & {
25
+ startAngle: number;
26
+ endAngle: number;
27
+ innerRadius: number;
28
+ outerRadius: number;
29
+ arcLabelRadius: number;
30
+ cornerRadius: number;
31
+ paddingAngle: number;
32
+ skipAnimation: boolean;
31
33
  formattedArcLabel?: string | null;
32
34
  };
33
- declare function PieArcLabel(props: PieArcLabelProps): React.JSX.Element;
34
- declare namespace PieArcLabel {
35
- var propTypes: any;
36
- }
35
+ declare const PieArcLabel: React.ForwardRefExoticComponent<PieArcLabelOwnerState & Omit<React.SVGProps<SVGTextElement>, "ref" | "color" | "id"> & {
36
+ startAngle: number;
37
+ endAngle: number;
38
+ innerRadius: number;
39
+ outerRadius: number;
40
+ arcLabelRadius: number;
41
+ cornerRadius: number;
42
+ paddingAngle: number;
43
+ skipAnimation: boolean;
44
+ formattedArcLabel?: string | null;
45
+ } & React.RefAttributes<SVGTextElement>>;
37
46
  export { PieArcLabel };
@@ -6,38 +6,39 @@ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWild
6
6
  Object.defineProperty(exports, "__esModule", {
7
7
  value: true
8
8
  });
9
- exports.PieArcLabel = PieArcLabel;
9
+ exports.PieArcLabel = void 0;
10
10
  exports.getPieArcLabelUtilityClass = getPieArcLabelUtilityClass;
11
11
  exports.pieArcLabelClasses = void 0;
12
12
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
13
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
14
14
  var React = _interopRequireWildcard(require("react"));
15
15
  var _propTypes = _interopRequireDefault(require("prop-types"));
16
- var _web = require("@react-spring/web");
17
- var _d3Shape = require("@mui/x-charts-vendor/d3-shape");
18
16
  var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
19
17
  var _generateUtilityClass = _interopRequireDefault(require("@mui/utils/generateUtilityClass"));
20
18
  var _styles = require("@mui/material/styles");
21
19
  var _generateUtilityClasses = _interopRequireDefault(require("@mui/utils/generateUtilityClasses"));
20
+ var _animation = require("../internals/animation/animation");
21
+ var _useAnimatePieArcLabel = require("../hooks/animation/useAnimatePieArcLabel");
22
22
  var _jsxRuntime = require("react/jsx-runtime");
23
- const _excluded = ["id", "classes", "color", "startAngle", "endAngle", "paddingAngle", "arcLabelRadius", "innerRadius", "outerRadius", "cornerRadius", "formattedArcLabel", "isHighlighted", "isFaded", "style"];
23
+ const _excluded = ["id", "classes", "color", "startAngle", "endAngle", "paddingAngle", "arcLabelRadius", "innerRadius", "outerRadius", "cornerRadius", "formattedArcLabel", "isHighlighted", "isFaded", "style", "skipAnimation"];
24
24
  function getPieArcLabelUtilityClass(slot) {
25
25
  return (0, _generateUtilityClass.default)('MuiPieArcLabel', slot);
26
26
  }
27
- const pieArcLabelClasses = exports.pieArcLabelClasses = (0, _generateUtilityClasses.default)('MuiPieArcLabel', ['root', 'highlighted', 'faded']);
27
+ const pieArcLabelClasses = exports.pieArcLabelClasses = (0, _generateUtilityClasses.default)('MuiPieArcLabel', ['root', 'highlighted', 'faded', 'animate']);
28
28
  const useUtilityClasses = ownerState => {
29
29
  const {
30
30
  classes,
31
31
  id,
32
32
  isFaded,
33
- isHighlighted
33
+ isHighlighted,
34
+ skipAnimation
34
35
  } = ownerState;
35
36
  const slots = {
36
- root: ['root', `series-${id}`, isHighlighted && 'highlighted', isFaded && 'faded']
37
+ root: ['root', `series-${id}`, isHighlighted && 'highlighted', isFaded && 'faded', !skipAnimation && 'animate']
37
38
  };
38
39
  return (0, _composeClasses.default)(slots, getPieArcLabelUtilityClass, classes);
39
40
  };
40
- const PieArcLabelRoot = (0, _styles.styled)(_web.animated.text, {
41
+ const PieArcLabelRoot = (0, _styles.styled)('text', {
41
42
  name: 'MuiPieArcLabel',
42
43
  slot: 'Root',
43
44
  overridesResolver: (_, styles) => styles.root
@@ -47,29 +48,20 @@ const PieArcLabelRoot = (0, _styles.styled)(_web.animated.text, {
47
48
  fill: (theme.vars || theme).palette.text.primary,
48
49
  textAnchor: 'middle',
49
50
  dominantBaseline: 'middle',
50
- pointerEvents: 'none'
51
- }));
52
- /**
53
- * Helper to compute label position.
54
- * It's not an inline function because we need it in interpolation.
55
- */
56
- const getLabelPosition = (formattedArcLabel, variable) => (startAngle, endAngle, padAngle, arcLabelRadius, cornerRadius) => {
57
- if (!formattedArcLabel) {
58
- return 0;
59
- }
60
- const [x, y] = (0, _d3Shape.arc)().cornerRadius(cornerRadius).centroid({
61
- padAngle,
62
- startAngle,
63
- endAngle,
64
- innerRadius: arcLabelRadius,
65
- outerRadius: arcLabelRadius
66
- });
67
- if (variable === 'x') {
68
- return x;
51
+ pointerEvents: 'none',
52
+ animationName: 'animate-opacity',
53
+ animationDuration: '0s',
54
+ animationTimingFunction: _animation.ANIMATION_TIMING_FUNCTION,
55
+ [`&.${pieArcLabelClasses.animate}`]: {
56
+ animationDuration: `${_animation.ANIMATION_DURATION_MS}ms`
57
+ },
58
+ '@keyframes animate-opacity': {
59
+ from: {
60
+ opacity: 0
61
+ }
69
62
  }
70
- return y;
71
- };
72
- function PieArcLabel(props) {
63
+ }));
64
+ const PieArcLabel = exports.PieArcLabel = /*#__PURE__*/React.forwardRef(function PieArcLabel(props, ref) {
73
65
  const {
74
66
  id,
75
67
  classes: innerClasses,
@@ -77,12 +69,13 @@ function PieArcLabel(props) {
77
69
  startAngle,
78
70
  endAngle,
79
71
  paddingAngle,
80
- arcLabelRadius,
72
+ innerRadius,
73
+ outerRadius,
81
74
  cornerRadius,
82
75
  formattedArcLabel,
83
76
  isHighlighted,
84
77
  isFaded,
85
- style
78
+ skipAnimation
86
79
  } = props,
87
80
  other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded);
88
81
  const ownerState = {
@@ -90,32 +83,43 @@ function PieArcLabel(props) {
90
83
  classes: innerClasses,
91
84
  color,
92
85
  isFaded,
93
- isHighlighted
86
+ isHighlighted,
87
+ skipAnimation
94
88
  };
95
89
  const classes = useUtilityClasses(ownerState);
96
- return (
97
- /*#__PURE__*/
98
- // @ts-expect-error
99
- (0, _jsxRuntime.jsx)(PieArcLabelRoot, (0, _extends2.default)({
100
- className: classes.root
101
- }, other, {
102
- style: (0, _extends2.default)({
103
- x: (0, _web.to)([startAngle, endAngle, paddingAngle, arcLabelRadius, cornerRadius], getLabelPosition(formattedArcLabel, 'x')),
104
- y: (0, _web.to)([startAngle, endAngle, paddingAngle, arcLabelRadius, cornerRadius], getLabelPosition(formattedArcLabel, 'y'))
105
- }, style),
106
- children: formattedArcLabel
107
- }))
108
- );
109
- }
90
+ const animatedProps = (0, _useAnimatePieArcLabel.useAnimatePieArcLabel)({
91
+ cornerRadius,
92
+ startAngle,
93
+ endAngle,
94
+ innerRadius,
95
+ outerRadius,
96
+ paddingAngle,
97
+ skipAnimation,
98
+ ref
99
+ });
100
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(PieArcLabelRoot, (0, _extends2.default)({
101
+ className: classes.root
102
+ }, other, animatedProps, {
103
+ children: formattedArcLabel
104
+ }));
105
+ });
110
106
  process.env.NODE_ENV !== "production" ? PieArcLabel.propTypes = {
111
107
  // ----------------------------- Warning --------------------------------
112
108
  // | These PropTypes are generated from the TypeScript type definitions |
113
109
  // | To update them edit the TypeScript types and run "pnpm proptypes" |
114
110
  // ----------------------------------------------------------------------
111
+ arcLabelRadius: _propTypes.default.number.isRequired,
115
112
  classes: _propTypes.default.object,
116
113
  color: _propTypes.default.string.isRequired,
114
+ cornerRadius: _propTypes.default.number.isRequired,
115
+ endAngle: _propTypes.default.number.isRequired,
117
116
  formattedArcLabel: _propTypes.default.string,
118
117
  id: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.string]).isRequired,
118
+ innerRadius: _propTypes.default.number.isRequired,
119
119
  isFaded: _propTypes.default.bool.isRequired,
120
- isHighlighted: _propTypes.default.bool.isRequired
120
+ isHighlighted: _propTypes.default.bool.isRequired,
121
+ outerRadius: _propTypes.default.number.isRequired,
122
+ paddingAngle: _propTypes.default.number.isRequired,
123
+ skipAnimation: _propTypes.default.bool.isRequired,
124
+ startAngle: _propTypes.default.number.isRequired
121
125
  } : void 0;
@@ -11,14 +11,11 @@ var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runt
11
11
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
12
12
  var React = _interopRequireWildcard(require("react"));
13
13
  var _propTypes = _interopRequireDefault(require("prop-types"));
14
- var _web = require("@react-spring/web");
15
- var _transition = require("./dataTransform/transition");
16
14
  var _useTransformData = require("./dataTransform/useTransformData");
17
15
  var _PieArcLabel = require("./PieArcLabel");
18
16
  var _getLabel = require("../internals/getLabel");
19
17
  var _jsxRuntime = require("react/jsx-runtime");
20
- const _excluded = ["arcLabel", "arcLabelMinAngle", "arcLabelRadius", "cornerRadius", "data", "faded", "highlighted", "id", "innerRadius", "outerRadius", "paddingAngle", "skipAnimation", "slotProps", "slots"],
21
- _excluded2 = ["startAngle", "endAngle", "paddingAngle", "innerRadius", "outerRadius", "arcLabelRadius", "cornerRadius"];
18
+ const _excluded = ["arcLabel", "arcLabelMinAngle", "arcLabelRadius", "cornerRadius", "data", "faded", "highlighted", "id", "innerRadius", "outerRadius", "paddingAngle", "skipAnimation", "slotProps", "slots"];
22
19
  const RATIO = 180 / Math.PI;
23
20
  function getItemLabel(arcLabel, arcLabelMinAngle, item) {
24
21
  if (!arcLabel) {
@@ -72,41 +69,26 @@ function PieArcLabelPlot(props) {
72
69
  faded,
73
70
  data
74
71
  });
75
- const transition = (0, _web.useTransition)(transformedData, (0, _extends2.default)({}, (0, _transition.getDefaultLabelTransitionConfig)(skipAnimation), {
76
- immediate: skipAnimation
77
- }));
78
72
  if (data.length === 0) {
79
73
  return null;
80
74
  }
81
75
  const ArcLabel = slots?.pieArcLabel ?? _PieArcLabel.PieArcLabel;
82
76
  return /*#__PURE__*/(0, _jsxRuntime.jsx)("g", (0, _extends2.default)({}, other, {
83
- children: transition((_ref, item) => {
84
- let {
85
- startAngle,
86
- endAngle,
87
- paddingAngle: pA,
88
- innerRadius: iR,
89
- outerRadius: oR,
90
- arcLabelRadius: aLR,
91
- cornerRadius: cR
92
- } = _ref,
93
- style = (0, _objectWithoutPropertiesLoose2.default)(_ref, _excluded2);
94
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(ArcLabel, (0, _extends2.default)({
95
- startAngle: startAngle,
96
- endAngle: endAngle,
97
- paddingAngle: pA,
98
- innerRadius: iR,
99
- outerRadius: oR,
100
- arcLabelRadius: aLR,
101
- cornerRadius: cR,
102
- style: style,
103
- id: id,
104
- color: item.color,
105
- isFaded: item.isFaded,
106
- isHighlighted: item.isHighlighted,
107
- formattedArcLabel: getItemLabel(arcLabel, arcLabelMinAngle, item)
108
- }, slotProps?.pieArcLabel));
109
- })
77
+ children: transformedData.map(item => /*#__PURE__*/(0, _jsxRuntime.jsx)(ArcLabel, (0, _extends2.default)({
78
+ startAngle: item.startAngle,
79
+ endAngle: item.endAngle,
80
+ paddingAngle: item.paddingAngle,
81
+ innerRadius: item.innerRadius,
82
+ outerRadius: item.outerRadius,
83
+ arcLabelRadius: item.arcLabelRadius,
84
+ cornerRadius: item.cornerRadius,
85
+ id: id,
86
+ color: item.color,
87
+ isFaded: item.isFaded,
88
+ isHighlighted: item.isHighlighted,
89
+ formattedArcLabel: getItemLabel(arcLabel, arcLabelMinAngle, item),
90
+ skipAnimation: skipAnimation ?? false
91
+ }, slotProps?.pieArcLabel), item.id ?? item.dataIndex))
110
92
  }));
111
93
  }
112
94
  process.env.NODE_ENV !== "production" ? PieArcLabelPlot.propTypes = {
@@ -11,9 +11,7 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
11
11
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
12
12
  var React = _interopRequireWildcard(require("react"));
13
13
  var _propTypes = _interopRequireDefault(require("prop-types"));
14
- var _web = require("@react-spring/web");
15
14
  var _PieArc = require("./PieArc");
16
- var _transition = require("./dataTransform/transition");
17
15
  var _useTransformData = require("./dataTransform/useTransformData");
18
16
  var _jsxRuntime = require("react/jsx-runtime");
19
17
  const _excluded = ["slots", "slotProps", "innerRadius", "outerRadius", "cornerRadius", "paddingAngle", "id", "highlighted", "faded", "data", "onItemClick", "skipAnimation"];
@@ -45,43 +43,32 @@ function PieArcPlot(props) {
45
43
  faded,
46
44
  data
47
45
  });
48
- const transition = (0, _web.useTransition)(transformedData, (0, _extends2.default)({}, (0, _transition.getDefaultTransitionConfig)(skipAnimation), {
49
- immediate: skipAnimation
50
- }));
51
46
  if (data.length === 0) {
52
47
  return null;
53
48
  }
54
49
  const Arc = slots?.pieArc ?? _PieArc.PieArc;
55
50
  return /*#__PURE__*/(0, _jsxRuntime.jsx)("g", (0, _extends2.default)({}, other, {
56
- children: transition(({
57
- startAngle,
58
- endAngle,
59
- paddingAngle: pA,
60
- innerRadius: iR,
61
- outerRadius: oR,
62
- cornerRadius: cR
63
- }, item, _, index) => {
64
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(Arc, (0, _extends2.default)({
65
- startAngle: startAngle,
66
- endAngle: endAngle,
67
- paddingAngle: pA,
68
- innerRadius: iR,
69
- outerRadius: oR,
70
- cornerRadius: cR,
71
- id: id,
72
- color: item.color,
73
- dataIndex: index,
74
- isFaded: item.isFaded,
75
- isHighlighted: item.isHighlighted,
76
- onClick: onItemClick && (event => {
77
- onItemClick(event, {
78
- type: 'pie',
79
- seriesId: id,
80
- dataIndex: index
81
- }, item);
82
- })
83
- }, slotProps?.pieArc));
84
- })
51
+ children: transformedData.map((item, index) => /*#__PURE__*/(0, _jsxRuntime.jsx)(Arc, (0, _extends2.default)({
52
+ startAngle: item.startAngle,
53
+ endAngle: item.endAngle,
54
+ paddingAngle: item.paddingAngle,
55
+ innerRadius: item.innerRadius,
56
+ outerRadius: item.outerRadius,
57
+ cornerRadius: item.cornerRadius,
58
+ skipAnimation: skipAnimation ?? false,
59
+ id: id,
60
+ color: item.color,
61
+ dataIndex: index,
62
+ isFaded: item.isFaded,
63
+ isHighlighted: item.isHighlighted,
64
+ onClick: onItemClick && (event => {
65
+ onItemClick(event, {
66
+ type: 'pie',
67
+ seriesId: id,
68
+ dataIndex: index
69
+ }, item);
70
+ })
71
+ }, slotProps?.pieArc), item.dataIndex))
85
72
  }));
86
73
  }
87
74
  process.env.NODE_ENV !== "production" ? PieArcPlot.propTypes = {
@@ -17,6 +17,9 @@ const tooltipGetter = params => {
17
17
  return null;
18
18
  }
19
19
  const point = series.data[identifier.dataIndex];
20
+ if (point == null) {
21
+ return null;
22
+ }
20
23
  const label = (0, _getLabel.getLabel)(point.label, 'tooltip');
21
24
  const value = (0, _extends2.default)({}, point, {
22
25
  label