@fluentui/react-charts 9.3.16 → 9.3.18

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 (259) hide show
  1. package/CHANGELOG.md +27 -2
  2. package/dist/index.d.ts +11 -11
  3. package/lib/components/AnnotationOnlyChart/AnnotationOnlyChart.types.js +3 -1
  4. package/lib/components/AnnotationOnlyChart/AnnotationOnlyChart.types.js.map +1 -1
  5. package/lib/components/AreaChart/AreaChart.js +3 -5
  6. package/lib/components/AreaChart/AreaChart.js.map +1 -1
  7. package/lib/components/AreaChart/AreaChart.types.js.map +1 -1
  8. package/lib/components/AreaChart/useAreaChartStyles.styles.raw.js.map +1 -1
  9. package/lib/components/ChartTable/ChartTable.js.map +1 -1
  10. package/lib/components/ChartTable/ChartTable.types.js +4 -1
  11. package/lib/components/ChartTable/ChartTable.types.js.map +1 -1
  12. package/lib/components/ChartTable/useChartTableStyles.styles.raw.js.map +1 -1
  13. package/lib/components/CommonComponents/Annotations/ChartAnnotationLayer.types.js.map +1 -1
  14. package/lib/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.raw.js.map +1 -1
  15. package/lib/components/CommonComponents/CartesianChart.js +6 -6
  16. package/lib/components/CommonComponents/CartesianChart.js.map +1 -1
  17. package/lib/components/CommonComponents/CartesianChart.types.js +2 -1
  18. package/lib/components/CommonComponents/CartesianChart.types.js.map +1 -1
  19. package/lib/components/CommonComponents/ChartPopover.js.map +1 -1
  20. package/lib/components/CommonComponents/ChartPopover.types.js.map +1 -1
  21. package/lib/components/CommonComponents/useCartesianChartStyles.styles.raw.js.map +1 -1
  22. package/lib/components/CommonComponents/useChartPopoverStyles.styles.raw.js.map +1 -1
  23. package/lib/components/DeclarativeChart/DeclarativeChart.js +0 -1
  24. package/lib/components/DeclarativeChart/DeclarativeChart.js.map +1 -1
  25. package/lib/components/DeclarativeChart/PlotlyColorAdapter.js +0 -1
  26. package/lib/components/DeclarativeChart/PlotlyColorAdapter.js.map +1 -1
  27. package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js +0 -1
  28. package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
  29. package/lib/components/DonutChart/Arc/Arc.js.map +1 -1
  30. package/lib/components/DonutChart/Arc/Arc.types.js.map +1 -1
  31. package/lib/components/DonutChart/Arc/useArcStyles.styles.raw.js.map +1 -1
  32. package/lib/components/DonutChart/DonutChart.js +1 -2
  33. package/lib/components/DonutChart/DonutChart.js.map +1 -1
  34. package/lib/components/DonutChart/DonutChart.types.js +4 -1
  35. package/lib/components/DonutChart/DonutChart.types.js.map +1 -1
  36. package/lib/components/DonutChart/Pie/Pie.js +2 -5
  37. package/lib/components/DonutChart/Pie/Pie.js.map +1 -1
  38. package/lib/components/DonutChart/Pie/Pie.types.js.map +1 -1
  39. package/lib/components/DonutChart/Pie/usePieStyles.styles.raw.js.map +1 -1
  40. package/lib/components/DonutChart/useDonutChartStyles.styles.raw.js.map +1 -1
  41. package/lib/components/FunnelChart/FunnelChart.js.map +1 -1
  42. package/lib/components/FunnelChart/FunnelChart.types.js +4 -1
  43. package/lib/components/FunnelChart/FunnelChart.types.js.map +1 -1
  44. package/lib/components/FunnelChart/funnelGeometry.js +0 -1
  45. package/lib/components/FunnelChart/funnelGeometry.js.map +1 -1
  46. package/lib/components/FunnelChart/useFunnelChartStyles.styles.raw.js.map +1 -1
  47. package/lib/components/GanttChart/GanttChart.js.map +1 -1
  48. package/lib/components/GanttChart/GanttChart.types.js.map +1 -1
  49. package/lib/components/GanttChart/useGanttChartStyles.styles.raw.js.map +1 -1
  50. package/lib/components/GaugeChart/GaugeChart.js +1 -4
  51. package/lib/components/GaugeChart/GaugeChart.js.map +1 -1
  52. package/lib/components/GaugeChart/GaugeChart.types.js.map +1 -1
  53. package/lib/components/GaugeChart/useGaugeChartStyles.styles.raw.js.map +1 -1
  54. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +2 -3
  55. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  56. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.types.js.map +1 -1
  57. package/lib/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.raw.js.map +1 -1
  58. package/lib/components/HeatMapChart/HeatMapChart.js.map +1 -1
  59. package/lib/components/HorizontalBarChart/HorizontalBarChart.js +1 -1
  60. package/lib/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
  61. package/lib/components/HorizontalBarChart/HorizontalBarChart.types.js +0 -1
  62. package/lib/components/HorizontalBarChart/HorizontalBarChart.types.js.map +1 -1
  63. package/lib/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.raw.js.map +1 -1
  64. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +1 -2
  65. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
  66. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.types.js.map +1 -1
  67. package/lib/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.raw.js.map +1 -1
  68. package/lib/components/Legends/Legends.js +1 -1
  69. package/lib/components/Legends/Legends.js.map +1 -1
  70. package/lib/components/Legends/Legends.types.js +3 -1
  71. package/lib/components/Legends/Legends.types.js.map +1 -1
  72. package/lib/components/Legends/shape.js.map +1 -1
  73. package/lib/components/Legends/useLegendsStyles.styles.raw.js.map +1 -1
  74. package/lib/components/LineChart/LineChart.js +16 -16
  75. package/lib/components/LineChart/LineChart.js.map +1 -1
  76. package/lib/components/LineChart/LineChart.types.js.map +1 -1
  77. package/lib/components/LineChart/eventAnnotation/EventAnnotation.js.map +1 -1
  78. package/lib/components/LineChart/eventAnnotation/LabelLink.js.map +1 -1
  79. package/lib/components/LineChart/useLineChartStyles.styles.raw.js.map +1 -1
  80. package/lib/components/PolarChart/PolarChart.js.map +1 -1
  81. package/lib/components/PolarChart/PolarChart.types.js +4 -1
  82. package/lib/components/PolarChart/PolarChart.types.js.map +1 -1
  83. package/lib/components/PolarChart/PolarChart.utils.js.map +1 -1
  84. package/lib/components/PolarChart/usePolarChartStyles.styles.raw.js.map +1 -1
  85. package/lib/components/ResponsiveContainer/ResponsiveContainer.js.map +1 -1
  86. package/lib/components/ResponsiveContainer/ResponsiveContainer.types.js +4 -1
  87. package/lib/components/ResponsiveContainer/ResponsiveContainer.types.js.map +1 -1
  88. package/lib/components/ResponsiveContainer/useResponsiveChildStyles.styles.raw.js.map +1 -1
  89. package/lib/components/ResponsiveContainer/withResponsiveContainer.js.map +1 -1
  90. package/lib/components/SankeyChart/SankeyChart.js +2 -2
  91. package/lib/components/SankeyChart/SankeyChart.js.map +1 -1
  92. package/lib/components/SankeyChart/SankeyChart.types.js.map +1 -1
  93. package/lib/components/SankeyChart/useSankeyChartStyles.styles.raw.js.map +1 -1
  94. package/lib/components/ScatterChart/ScatterChart.js +3 -4
  95. package/lib/components/ScatterChart/ScatterChart.js.map +1 -1
  96. package/lib/components/ScatterChart/ScatterChart.types.js +1 -1
  97. package/lib/components/ScatterChart/ScatterChart.types.js.map +1 -1
  98. package/lib/components/ScatterChart/useScatterChartStyles.styles.raw.js.map +1 -1
  99. package/lib/components/Sparkline/Sparkline.js +3 -4
  100. package/lib/components/Sparkline/Sparkline.js.map +1 -1
  101. package/lib/components/Sparkline/Sparkline.types.js.map +1 -1
  102. package/lib/components/Sparkline/useSparklineStyles.styles.raw.js.map +1 -1
  103. package/lib/components/VegaDeclarativeChart/VegaDeclarativeChartHooks.js.map +1 -1
  104. package/lib/components/VegaDeclarativeChart/VegaLiteSchemaAdapter.js +1 -1
  105. package/lib/components/VegaDeclarativeChart/VegaLiteSchemaAdapter.js.map +1 -1
  106. package/lib/components/VerticalBarChart/VerticalBarChart.js +5 -8
  107. package/lib/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  108. package/lib/components/VerticalBarChart/VerticalBarChart.types.js.map +1 -1
  109. package/lib/components/VerticalBarChart/useVerticalBarChartStyles.styles.raw.js.map +1 -1
  110. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js +5 -5
  111. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  112. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.types.js +4 -1
  113. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.types.js.map +1 -1
  114. package/lib/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.raw.js.map +1 -1
  115. package/lib/types/ChartAnnotation.js +1 -1
  116. package/lib/types/ChartAnnotation.js.map +1 -1
  117. package/lib/types/DataPoint.js.map +1 -1
  118. package/lib/types/EventAnnotation.js +1 -1
  119. package/lib/types/EventAnnotation.js.map +1 -1
  120. package/lib/utilities/ChartTitle.js.map +1 -1
  121. package/lib/utilities/FocusableTooltipText.js.map +1 -1
  122. package/lib/utilities/async-utils.js +20 -20
  123. package/lib/utilities/async-utils.js.map +1 -1
  124. package/lib/utilities/hooks.js.map +1 -1
  125. package/lib/utilities/image-export-utils.js.map +1 -1
  126. package/lib/utilities/scatterpolar-utils.js.map +1 -1
  127. package/lib/utilities/test-data.js.map +1 -1
  128. package/lib/utilities/utilities.js +4 -7
  129. package/lib/utilities/utilities.js.map +1 -1
  130. package/lib/utilities/vbc-utils.js.map +1 -1
  131. package/lib-commonjs/components/AnnotationOnlyChart/AnnotationOnlyChart.types.js +3 -3
  132. package/lib-commonjs/components/AnnotationOnlyChart/AnnotationOnlyChart.types.js.map +1 -1
  133. package/lib-commonjs/components/AreaChart/AreaChart.js +3 -5
  134. package/lib-commonjs/components/AreaChart/AreaChart.js.map +1 -1
  135. package/lib-commonjs/components/AreaChart/AreaChart.types.js.map +1 -1
  136. package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.raw.js.map +1 -1
  137. package/lib-commonjs/components/ChartTable/ChartTable.js.map +1 -1
  138. package/lib-commonjs/components/ChartTable/ChartTable.types.js +4 -3
  139. package/lib-commonjs/components/ChartTable/ChartTable.types.js.map +1 -1
  140. package/lib-commonjs/components/ChartTable/useChartTableStyles.styles.raw.js.map +1 -1
  141. package/lib-commonjs/components/CommonComponents/Annotations/ChartAnnotationLayer.types.js.map +1 -1
  142. package/lib-commonjs/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.raw.js.map +1 -1
  143. package/lib-commonjs/components/CommonComponents/CartesianChart.js +6 -6
  144. package/lib-commonjs/components/CommonComponents/CartesianChart.js.map +1 -1
  145. package/lib-commonjs/components/CommonComponents/CartesianChart.types.js +1 -2
  146. package/lib-commonjs/components/CommonComponents/CartesianChart.types.js.map +1 -1
  147. package/lib-commonjs/components/CommonComponents/ChartPopover.js.map +1 -1
  148. package/lib-commonjs/components/CommonComponents/ChartPopover.types.js.map +1 -1
  149. package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.raw.js.map +1 -1
  150. package/lib-commonjs/components/CommonComponents/useChartPopoverStyles.styles.raw.js.map +1 -1
  151. package/lib-commonjs/components/DeclarativeChart/DeclarativeChart.js +0 -1
  152. package/lib-commonjs/components/DeclarativeChart/DeclarativeChart.js.map +1 -1
  153. package/lib-commonjs/components/DeclarativeChart/PlotlyColorAdapter.js +0 -2
  154. package/lib-commonjs/components/DeclarativeChart/PlotlyColorAdapter.js.map +1 -1
  155. package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js +0 -2
  156. package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
  157. package/lib-commonjs/components/DonutChart/Arc/Arc.js.map +1 -1
  158. package/lib-commonjs/components/DonutChart/Arc/Arc.types.js.map +1 -1
  159. package/lib-commonjs/components/DonutChart/Arc/useArcStyles.styles.raw.js.map +1 -1
  160. package/lib-commonjs/components/DonutChart/DonutChart.js +1 -2
  161. package/lib-commonjs/components/DonutChart/DonutChart.js.map +1 -1
  162. package/lib-commonjs/components/DonutChart/DonutChart.types.js +4 -3
  163. package/lib-commonjs/components/DonutChart/DonutChart.types.js.map +1 -1
  164. package/lib-commonjs/components/DonutChart/Pie/Pie.js +2 -5
  165. package/lib-commonjs/components/DonutChart/Pie/Pie.js.map +1 -1
  166. package/lib-commonjs/components/DonutChart/Pie/Pie.types.js.map +1 -1
  167. package/lib-commonjs/components/DonutChart/Pie/usePieStyles.styles.raw.js.map +1 -1
  168. package/lib-commonjs/components/DonutChart/useDonutChartStyles.styles.raw.js.map +1 -1
  169. package/lib-commonjs/components/FunnelChart/FunnelChart.js.map +1 -1
  170. package/lib-commonjs/components/FunnelChart/FunnelChart.types.js +4 -3
  171. package/lib-commonjs/components/FunnelChart/FunnelChart.types.js.map +1 -1
  172. package/lib-commonjs/components/FunnelChart/funnelGeometry.js +0 -2
  173. package/lib-commonjs/components/FunnelChart/funnelGeometry.js.map +1 -1
  174. package/lib-commonjs/components/FunnelChart/useFunnelChartStyles.styles.raw.js.map +1 -1
  175. package/lib-commonjs/components/GanttChart/GanttChart.js.map +1 -1
  176. package/lib-commonjs/components/GanttChart/GanttChart.types.js.map +1 -1
  177. package/lib-commonjs/components/GanttChart/useGanttChartStyles.styles.raw.js.map +1 -1
  178. package/lib-commonjs/components/GaugeChart/GaugeChart.js +1 -4
  179. package/lib-commonjs/components/GaugeChart/GaugeChart.js.map +1 -1
  180. package/lib-commonjs/components/GaugeChart/GaugeChart.types.js.map +1 -1
  181. package/lib-commonjs/components/GaugeChart/useGaugeChartStyles.styles.raw.js.map +1 -1
  182. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +2 -3
  183. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  184. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.types.js.map +1 -1
  185. package/lib-commonjs/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.raw.js.map +1 -1
  186. package/lib-commonjs/components/HeatMapChart/HeatMapChart.js.map +1 -1
  187. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js +1 -1
  188. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
  189. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.types.js +3 -3
  190. package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.types.js.map +1 -1
  191. package/lib-commonjs/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.raw.js.map +1 -1
  192. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +1 -2
  193. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
  194. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.types.js.map +1 -1
  195. package/lib-commonjs/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.raw.js.map +1 -1
  196. package/lib-commonjs/components/Legends/Legends.js +1 -1
  197. package/lib-commonjs/components/Legends/Legends.js.map +1 -1
  198. package/lib-commonjs/components/Legends/Legends.types.js +3 -3
  199. package/lib-commonjs/components/Legends/Legends.types.js.map +1 -1
  200. package/lib-commonjs/components/Legends/shape.js.map +1 -1
  201. package/lib-commonjs/components/Legends/useLegendsStyles.styles.raw.js.map +1 -1
  202. package/lib-commonjs/components/LineChart/LineChart.js +16 -16
  203. package/lib-commonjs/components/LineChart/LineChart.js.map +1 -1
  204. package/lib-commonjs/components/LineChart/LineChart.types.js.map +1 -1
  205. package/lib-commonjs/components/LineChart/eventAnnotation/EventAnnotation.js.map +1 -1
  206. package/lib-commonjs/components/LineChart/eventAnnotation/LabelLink.js.map +1 -1
  207. package/lib-commonjs/components/LineChart/useLineChartStyles.styles.raw.js.map +1 -1
  208. package/lib-commonjs/components/PolarChart/PolarChart.js.map +1 -1
  209. package/lib-commonjs/components/PolarChart/PolarChart.types.js +4 -3
  210. package/lib-commonjs/components/PolarChart/PolarChart.types.js.map +1 -1
  211. package/lib-commonjs/components/PolarChart/PolarChart.utils.js.map +1 -1
  212. package/lib-commonjs/components/PolarChart/usePolarChartStyles.styles.raw.js.map +1 -1
  213. package/lib-commonjs/components/ResponsiveContainer/ResponsiveContainer.js.map +1 -1
  214. package/lib-commonjs/components/ResponsiveContainer/ResponsiveContainer.types.js +4 -3
  215. package/lib-commonjs/components/ResponsiveContainer/ResponsiveContainer.types.js.map +1 -1
  216. package/lib-commonjs/components/ResponsiveContainer/useResponsiveChildStyles.styles.raw.js.map +1 -1
  217. package/lib-commonjs/components/ResponsiveContainer/withResponsiveContainer.js.map +1 -1
  218. package/lib-commonjs/components/SankeyChart/SankeyChart.js +2 -2
  219. package/lib-commonjs/components/SankeyChart/SankeyChart.js.map +1 -1
  220. package/lib-commonjs/components/SankeyChart/SankeyChart.types.js.map +1 -1
  221. package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.raw.js.map +1 -1
  222. package/lib-commonjs/components/ScatterChart/ScatterChart.js +3 -4
  223. package/lib-commonjs/components/ScatterChart/ScatterChart.js.map +1 -1
  224. package/lib-commonjs/components/ScatterChart/ScatterChart.types.js +1 -1
  225. package/lib-commonjs/components/ScatterChart/ScatterChart.types.js.map +1 -1
  226. package/lib-commonjs/components/ScatterChart/useScatterChartStyles.styles.raw.js.map +1 -1
  227. package/lib-commonjs/components/Sparkline/Sparkline.js +3 -4
  228. package/lib-commonjs/components/Sparkline/Sparkline.js.map +1 -1
  229. package/lib-commonjs/components/Sparkline/Sparkline.types.js.map +1 -1
  230. package/lib-commonjs/components/Sparkline/useSparklineStyles.styles.raw.js.map +1 -1
  231. package/lib-commonjs/components/VegaDeclarativeChart/VegaDeclarativeChartHooks.js.map +1 -1
  232. package/lib-commonjs/components/VegaDeclarativeChart/VegaLiteSchemaAdapter.js +1 -1
  233. package/lib-commonjs/components/VegaDeclarativeChart/VegaLiteSchemaAdapter.js.map +1 -1
  234. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js +5 -8
  235. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  236. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.types.js.map +1 -1
  237. package/lib-commonjs/components/VerticalBarChart/useVerticalBarChartStyles.styles.raw.js.map +1 -1
  238. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js +5 -5
  239. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  240. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.types.js +4 -3
  241. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.types.js.map +1 -1
  242. package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.raw.js.map +1 -1
  243. package/lib-commonjs/types/ChartAnnotation.js +0 -2
  244. package/lib-commonjs/types/ChartAnnotation.js.map +1 -1
  245. package/lib-commonjs/types/DataPoint.js.map +1 -1
  246. package/lib-commonjs/types/EventAnnotation.js +0 -2
  247. package/lib-commonjs/types/EventAnnotation.js.map +1 -1
  248. package/lib-commonjs/utilities/ChartTitle.js.map +1 -1
  249. package/lib-commonjs/utilities/FocusableTooltipText.js.map +1 -1
  250. package/lib-commonjs/utilities/async-utils.js +20 -20
  251. package/lib-commonjs/utilities/async-utils.js.map +1 -1
  252. package/lib-commonjs/utilities/hooks.js.map +1 -1
  253. package/lib-commonjs/utilities/image-export-utils.js.map +1 -1
  254. package/lib-commonjs/utilities/scatterpolar-utils.js.map +1 -1
  255. package/lib-commonjs/utilities/test-data.js.map +1 -1
  256. package/lib-commonjs/utilities/utilities.js +2 -2
  257. package/lib-commonjs/utilities/utilities.js.map +1 -1
  258. package/lib-commonjs/utilities/vbc-utils.js.map +1 -1
  259. package/package.json +8 -8
@@ -298,7 +298,6 @@ const MIN_DOMAIN_MARGIN = 8;
298
298
  }
299
299
  function _getCalloutContentForLineAndBar(point) {
300
300
  var _selectedPoint__lineData;
301
- // eslint-disable-next-line @typescript-eslint/no-shadow
302
301
  const YValueHover = [];
303
302
  const { useSingleColor = false } = props;
304
303
  const { data, lineLegendText, lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;
@@ -364,7 +363,6 @@ const MIN_DOMAIN_MARGIN = 8;
364
363
  setYValueHover([]);
365
364
  setHoverXValue('');
366
365
  }
367
- // eslint-disable-next-line @typescript-eslint/no-shadow
368
366
  function _onBarFocus(event, point, refArrayIndexNumber, color) {
369
367
  let x = 0;
370
368
  let y = 0;
@@ -866,16 +864,16 @@ const MIN_DOMAIN_MARGIN = 8;
866
864
  const calloutProps = {
867
865
  ..._isHavingLine && {
868
866
  YValueHover: hoveredYValues,
869
- hoverXValue: hoverXValue
867
+ hoverXValue
870
868
  },
871
- color: color,
869
+ color,
872
870
  legend: calloutLegend,
873
871
  XValue: xCalloutValue,
874
872
  YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,
875
873
  ...props.calloutProps,
876
874
  ...getAccessibleDataObject(callOutAccessibilityData),
877
- clickPosition: clickPosition,
878
- isPopoverOpen: isPopoverOpen,
875
+ clickPosition,
876
+ isPopoverOpen,
879
877
  isCalloutForStack: _isHavingLine && (_noLegendHighlighted() || _getHighlightedLegend().length > 1),
880
878
  culture: props.culture,
881
879
  isCartesian: true,
@@ -917,8 +915,7 @@ const MIN_DOMAIN_MARGIN = 8;
917
915
  },
918
916
  componentRef: cartesianChartRef,
919
917
  showRoundOffXTickValues: !isScalePaddingDefined(props.xAxisInnerPadding, props.xAxisPadding) && props.mode !== 'histogram',
920
- /* eslint-disable react/jsx-no-bind */ // eslint-disable-next-line react/no-children-prop
921
- children: (props)=>{
918
+ /* eslint-disable react/jsx-no-bind */ children: (props)=>{
922
919
  return /*#__PURE__*/ React.createElement(React.Fragment, null, /*#__PURE__*/ React.createElement("g", null, _bars), _isHavingLine && /*#__PURE__*/ React.createElement("g", null, _createLine(props.xScale, props.yScalePrimary, props.containerHeight, props.containerWidth, props.yScaleSecondary)));
923
920
  }
924
921
  }) : /*#__PURE__*/ React.createElement("div", {
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/VerticalBarChart/VerticalBarChart.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { useVerticalBarChartStyles } from './useVerticalBarChartStyles.styles';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { line as d3Line } from 'd3-shape';\nimport {\n scaleLinear as d3ScaleLinear,\n ScaleLinear as D3ScaleLinear,\n scaleBand as d3ScaleBand,\n scaleUtc as d3ScaleUtc,\n} from 'd3-scale';\nimport { useId } from '@fluentui/react-utilities';\nimport type { JSXElement } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport {\n AccessibilityProps,\n CartesianChart,\n Margins,\n Legend,\n RefArrayData,\n VerticalBarChartProps,\n VerticalBarChartDataPoint,\n Legends,\n ChildProps,\n YValueHover,\n ChartPopover,\n DataPoint,\n} from '../../index';\nimport {\n ChartTypes,\n IAxisData,\n getAccessibleDataObject,\n XAxisTypes,\n NumericAxis,\n getTypeOfAxis,\n formatScientificLimitWidth,\n getBarWidth,\n getScalePadding,\n isScalePaddingDefined,\n calculateAppropriateBarWidth,\n useRtl,\n areArraysEqual,\n calculateLongestLabelWidth,\n findVerticalNumericMinMaxOfY,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfVerticalNumeric,\n domainRangeOfDateForAreaLineScatterVerticalBarCharts,\n domainRangeOfXStringAxis,\n createStringYAxis,\n calcTotalWidth,\n calcBandwidth,\n calcRequiredWidth,\n sortAxisCategories,\n} from '../../utilities/index';\nimport { useImageExport } from '../../utilities/hooks';\n\nenum CircleVisbility {\n show = 'visibility',\n hide = 'hidden',\n}\n\nconst MIN_DOMAIN_MARGIN = 8;\n\n// Create a VerticalBarChart variant which uses these default styles and this styled subcomponent.\n/**\n * VerticalBarchart component\n * {@docCategory VerticalBarChart}\n */\nexport const VerticalBarChart: React.FunctionComponent<VerticalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n VerticalBarChartProps\n>((_props, forwardedRef) => {\n const props: VerticalBarChartProps = {\n xAxisCategoryOrder: 'default',\n maxBarWidth: 24,\n ..._props,\n };\n let _points: VerticalBarChartDataPoint[] = [];\n let _barWidth: number = 0;\n let _colors: string[];\n const _refArray: RefArrayData[] = [];\n let margins: Margins;\n const _useRtl: boolean = useRtl();\n let _bars: JSXElement[];\n let _xAxisLabels: string[];\n let _yMax: number;\n let _yMin: number;\n let _isHavingLine: boolean = _checkForLine();\n let _xAxisType: XAxisTypes;\n let _calloutAnchorPoint: VerticalBarChartDataPoint | null;\n let _domainMargin: number;\n const _emptyChartId: string = useId('_VBC_empty');\n const _vbcLineId: string = useId('_VBC_line_');\n const _vbcPointId: string = useId('_VBC_point_');\n const _vbcBarId: string = useId('_VBC_bar_');\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n type ColorScale = (_p?: number) => string;\n const { cartesianChartRef, legendsRef: _legendsRef } = useImageExport(props.componentRef, props.hideLegend);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [xCalloutValue, setXCalloutValue] = React.useState<string | undefined>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string | undefined>('');\n const [activeXdataPoint, setActiveXDatapoint] = React.useState<string | number | Date | null>(null);\n const [hoveredYValues, setYValueHover] = React.useState<YValueHover[]>();\n const [hoverXValue, setHoverXValue] = React.useState<string | number | undefined>('');\n const [calloutLegend, setCalloutLegend] = React.useState<string>('');\n const [callOutAccessibilityData, setCalloutAccessibilityData] = React.useState<AccessibilityProps>();\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<VerticalBarChartDataPoint>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const prevPropsRef = React.useRef<VerticalBarChartProps | null>(null);\n\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n if (prevProps.height !== props.height || prevProps.width !== props.width) {\n _adjustProps();\n }\n }\n prevPropsRef.current = props;\n }, [props, prevPropsRef, _adjustProps]);\n\n function _getDomainNRangeValues(\n points: DataPoint[],\n margins: Margins,\n width: number,\n chartType: ChartTypes,\n isRTL: boolean,\n xAxisType: XAxisTypes,\n barWidth: number,\n tickValues: Date[] | number[] | undefined,\n ) {\n let domainNRangeValue: IDomainNRange;\n if (xAxisType === XAxisTypes.NumericAxis) {\n domainNRangeValue = domainRangeOfVerticalNumeric(points, margins, width, isRTL, barWidth!);\n } else if (xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = domainRangeOfDateForAreaLineScatterVerticalBarCharts(\n points,\n margins,\n width,\n isRTL,\n tickValues! as Date[],\n chartType,\n barWidth,\n );\n } else {\n domainNRangeValue = domainRangeOfXStringAxis(margins, width, isRTL);\n }\n return domainNRangeValue;\n }\n\n function _createLine(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScalePrimary: any,\n containerHeight: number = 0,\n containerWidth: number = 0,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScaleSecondary?: any,\n ): React.ReactNode {\n const isStringAxis = _xAxisType === XAxisTypes.StringAxis;\n const colorScale = _createColors();\n const { data, lineLegendColor = tokens.colorPaletteYellowBackground1, lineLegendText } = props;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const lineData: Array<any> = [];\n const line: JSXElement[] = [];\n data &&\n data.forEach((item: VerticalBarChartDataPoint, index: number) => {\n if (item.lineData && item.lineData.y) {\n lineData.push({\n x: item.x,\n y: item.lineData!.y,\n useSecondaryYScale: item.lineData!.useSecondaryYScale ?? false,\n point: item,\n index,\n });\n }\n });\n const linePath = d3Line()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => (isStringAxis ? xScale(d.x) + 0.5 * xScale.bandwidth() : xScale(d.x)))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y((d: any) => (d.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(d.y) : yScalePrimary(d.y)));\n const shouldHighlight = _legendHighlighted(lineLegendText!) || _noLegendHighlighted() ? true : false;\n const lineBorderWidth = props.lineOptions?.lineBorderWidth\n ? Number.parseFloat(props.lineOptions!.lineBorderWidth!.toString())\n : 0;\n\n if (lineBorderWidth > 0) {\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3 + lineBorderWidth * 2}\n className={classes.lineBorder}\n />,\n );\n }\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3}\n stroke={lineLegendColor}\n />,\n );\n\n const dots: React.ReactNode[] = lineData.map(\n (\n item: {\n x: number | string;\n y: number;\n useSecondaryYScale: boolean;\n point: VerticalBarChartDataPoint;\n index: number;\n },\n index: number,\n ) => {\n // Create an object to store line point ref so that the object can be passed by reference to the focus handler\n const circleRef: { refElement: SVGCircleElement | null } = { refElement: null };\n return (\n <circle\n key={index}\n id={`${_vbcPointId}-${index}`}\n cx={isStringAxis ? xScale(item.x) + 0.5 * xScale.bandwidth() : xScale(item.x)}\n cy={item.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(item.y) : yScalePrimary(item.y)}\n onMouseOver={event =>\n _legendHighlighted(lineLegendText!)\n ? _lineHover(item.point, event)\n : _onBarHover(item.point, colorScale(item.y), event)\n }\n onMouseOut={_onBarLeave}\n r={_getCircleVisibilityAndRadius(item.x, lineLegendText!).radius}\n stroke={lineLegendColor}\n fill={tokens.colorNeutralBackground1}\n strokeWidth={3}\n visibility={_getCircleVisibilityAndRadius(item.x, lineLegendText!).visibility}\n onClick={item.point.lineData?.onClick}\n // When no legend is highlighted: Line points are automatically displayed along with the bars\n // at the same x-axis point in the stack callout. So to prevent an increase in focusable elements\n // and avoid conveying duplicate info, make these line points non-focusable.\n data-is-focusable={_legendHighlighted(lineLegendText!)}\n ref={e => {\n circleRef.refElement = e;\n }}\n onFocus={event => _lineFocus(event, item.point, circleRef)}\n onBlur={_handleChartMouseLeave}\n tabIndex={_legendHighlighted(lineLegendText!) ? 0 : undefined}\n />\n );\n },\n );\n\n return (\n <>\n {line}\n {dots}\n </>\n );\n }\n\n function _getCircleVisibilityAndRadius(\n xAxisPoint: string | number | Date,\n legend: string,\n ): { visibility: CircleVisbility; radius: number } {\n if (!_noLegendHighlighted()) {\n if (xAxisPoint === activeXdataPoint && _legendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 8 };\n } else if (_legendHighlighted(legend)) {\n // Don't hide the circle to keep it focusable. For more information,\n // see https://fuzzbomb.github.io/accessibility-demos/visually-hidden-focus-test.html\n return { visibility: CircleVisbility.show, radius: 0.3 };\n } else {\n return { visibility: CircleVisbility.hide, radius: 0 };\n }\n } else {\n return {\n visibility: activeXdataPoint === xAxisPoint ? CircleVisbility.show : CircleVisbility.hide,\n radius: 8,\n };\n }\n }\n\n function _checkForLine(): boolean {\n const { data } = props;\n return data!.some((item: VerticalBarChartDataPoint) => item?.lineData?.y !== undefined);\n }\n\n function _adjustProps(): void {\n _xAxisType =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].x, true) as XAxisTypes)\n : XAxisTypes.StringAxis;\n _points = props.data || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, undefined, props.mode);\n const defaultColors: string[] = [\n tokens.colorPaletteBlueForeground2,\n tokens.colorPaletteCornflowerForeground2,\n tokens.colorPaletteDarkGreenForeground2,\n tokens.colorPaletteNavyForeground2,\n tokens.colorPaletteDarkOrangeForeground2,\n ];\n _colors = props.colors || defaultColors;\n _isHavingLine = _checkForLine();\n _xAxisInnerPadding =\n props.mode === 'histogram'\n ? 0\n : getScalePadding(\n props.xAxisInnerPadding,\n props.xAxisPadding,\n _xAxisType === XAxisTypes.StringAxis ? 2 / 3 : 1 / 2,\n );\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding, props.xAxisPadding, 0);\n }\n\n function _getMargins(_margins: Margins) {\n margins = _margins;\n }\n\n function _renderContentForBothLineAndBars(point: VerticalBarChartDataPoint): JSXElement {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n const content: JSXElement[] = YValueHover.map((item: YValueHover, index: number) => {\n return (\n <>\n <ChartPopover\n culture={props.culture}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={item.legend!}\n {...(index === 0 && { XValue: `${hoverXValue || item.data}` })}\n YValue={item.data || item.y}\n color={item.color}\n isCalloutForStack={false}\n />\n </>\n );\n });\n return <>{content}</>;\n }\n\n function _renderContentForOnlyBars(_props: VerticalBarChartDataPoint): JSXElement {\n return (\n <>\n <ChartPopover\n XValue={_props.xAxisCalloutData || (_props.x as string)}\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n culture={props.culture}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={_props.legend!}\n YValue={_props.yAxisCalloutData || _props.y}\n color={!props.useSingleColor && _props.color ? _props.color : _createColors()(_props.y)}\n isCalloutForStack={false}\n />\n </>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _renderCallout(props?: VerticalBarChartDataPoint): JSXElement | null {\n return props ? (_isHavingLine ? _renderContentForBothLineAndBars(props) : _renderContentForOnlyBars(props)) : null;\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _getGraphData(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n yScale: NumericAxis,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n ) {\n return (_bars =\n _xAxisType === XAxisTypes.NumericAxis\n ? _createNumericBars(containerHeight, containerWidth, xElement!)\n : _xAxisType === XAxisTypes.DateAxis\n ? _createDateBars(containerHeight, containerWidth, xElement!)\n : _createStringBars(containerHeight, containerWidth, xElement!));\n }\n\n function _createColors(): D3ScaleLinear<string, string> | ColorScale {\n const increment = _colors.length <= 1 ? 1 : 1 / (_colors.length - 1);\n const { useSingleColor = false } = props;\n if (useSingleColor) {\n return (_p?: number) => {\n const { colors } = props;\n return colors && colors.length > 0 ? colors[0] : tokens.colorPaletteBlueBackground2;\n };\n }\n const domainValues = [];\n for (let i = 0; i < _colors.length; i++) {\n domainValues.push(increment * i * _yMax);\n }\n const colorScale = d3ScaleLinear<string>().domain(domainValues).range(_colors);\n return colorScale;\n }\n\n function _refCallback(element: SVGRectElement, legendTitle: string): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _getCalloutContentForLineAndBar(point: VerticalBarChartDataPoint): {\n YValueHover: YValueHover[];\n hoverXValue: string | number | undefined;\n } {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const YValueHover: YValueHover[] = [];\n const { useSingleColor = false } = props;\n const { data, lineLegendText, lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n const selectedPoint = data!.filter((xDataPoint: VerticalBarChartDataPoint) => xDataPoint.x === point.x);\n // Check if the line legend is highlighted or no legend is highlighted\n if (\n _isHavingLine &&\n selectedPoint[0].lineData?.y !== undefined &&\n (_legendHighlighted(lineLegendText) || _noLegendHighlighted())\n ) {\n // Add callout data for the line\n YValueHover.push({\n legend: lineLegendText,\n color: lineLegendColor,\n y: selectedPoint[0].lineData?.y,\n data: selectedPoint[0].lineData?.yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].lineData?.yAxisCalloutData,\n });\n }\n // Check if the bar legend is highlighted or no legend is highlighted\n if (selectedLegends.includes(selectedPoint[0].legend!) || _noLegendHighlighted()) {\n // Add callout data for the bar\n YValueHover.push({\n legend: selectedPoint[0].legend,\n y: selectedPoint[0].y,\n color: !useSingleColor\n ? selectedPoint[0].color\n ? selectedPoint[0].color\n : _createColors()(selectedPoint[0].y)\n : _createColors()(1),\n data: selectedPoint[0].yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].yAxisCalloutData,\n });\n }\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const hoverXValue = point.x instanceof Date ? point.x.toLocaleString() : point.x.toString();\n return {\n YValueHover,\n hoverXValue: point.xAxisCalloutData || hoverXValue,\n };\n }\n\n function _onBarHover(\n point: VerticalBarChartDataPoint,\n // eslint-disable-next-line @typescript-eslint/no-shadow\n color: string,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void {\n mouseEvent.persist();\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n if (_calloutAnchorPoint !== point) {\n _calloutAnchorPoint = point;\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(_noLegendHighlighted() ? point.x : null);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _onBarLeave(): void {\n /**/\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n setActiveXDatapoint(null);\n setYValueHover([]);\n setHoverXValue('');\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _onBarFocus(\n event: React.FocusEvent<SVGRectElement, Element>,\n point: VerticalBarChartDataPoint,\n refArrayIndexNumber: number,\n color: string,\n ): void {\n let x = 0;\n let y = 0;\n\n const targetRect = (event.target as SVGRectElement).getBoundingClientRect();\n x = targetRect.left + targetRect.width / 2;\n y = targetRect.top + targetRect.height / 2;\n updatePosition(x, y);\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n _refArray.forEach((obj: RefArrayData, index: number) => {\n if (obj.index === point.legend! && refArrayIndexNumber === index) {\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.yAxisCalloutData!);\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(point.x);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n });\n }\n\n function _lineHover(point: VerticalBarChartDataPoint, mouseEvent: React.MouseEvent<SVGElement>) {\n mouseEvent.persist();\n _lineHoverFocus(point, mouseEvent);\n }\n\n function _lineFocus(\n event: React.FocusEvent<SVGCircleElement, Element>,\n point: VerticalBarChartDataPoint,\n ref: { refElement: SVGCircleElement | null },\n ) {\n if (ref.refElement) {\n _lineHoverFocus(point, ref.refElement);\n }\n }\n\n function _lineHoverFocus(\n point: VerticalBarChartDataPoint,\n _refSelected: React.MouseEvent<SVGElement> | SVGCircleElement,\n ) {\n const { lineLegendText = '', lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(lineLegendText));\n setCalloutLegend(lineLegendText);\n setDataForHoverCard(point.lineData!.y);\n setColor(lineLegendColor);\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.lineData!.yAxisCalloutData);\n setDataPointCalloutProps(point);\n setActiveXDatapoint(point.x);\n }\n\n function _getScales(\n containerHeight: number,\n containerWidth: number,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): { xBarScale: any; yBarScale: any } {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let xBarScale: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const yBarScale: any = d3ScaleLinear()\n .domain([_yMin, _yMax])\n .range([0, containerHeight - margins.bottom! - margins.top!]);\n\n if (_xAxisType === XAxisTypes.NumericAxis) {\n const xMax = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n const xMin = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n xBarScale = d3ScaleLinear()\n .domain(_useRtl ? [xMax, xMin] : [xMin, xMax])\n .range([margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin]);\n if (!isScalePaddingDefined(props.xAxisInnerPadding, props.xAxisPadding) && props.mode !== 'histogram') {\n xBarScale.nice();\n }\n } else if (_xAxisType === XAxisTypes.DateAxis) {\n const sDate = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n const lDate = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n xBarScale = d3ScaleUtc()\n .domain([sDate, lDate])\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n );\n } else {\n xBarScale = d3ScaleBand()\n .domain(_xAxisLabels)\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n )\n .paddingInner(_xAxisInnerPadding)\n .paddingOuter(_xAxisOuterPadding);\n }\n\n return { xBarScale, yBarScale };\n }\n\n const classes = useVerticalBarChartStyles(props);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _calculateMinBarHeight(yMin: number, yMax: number, yReferencePoint: number, yBarScale: any): number {\n const maxHeightFromBaseline =\n yMax < 0\n ? Math.abs(yMin - yReferencePoint)\n : Math.max(Math.abs(yMax - yReferencePoint), Math.abs(yMin - yReferencePoint));\n return Math.ceil(yBarScale(maxHeightFromBaseline) / 100.0);\n }\n\n function _createNumericBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSXElement[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={`${point.x}_${index}` as string}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={event => _onBarFocus(event, point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={!props.hideTooltip && shouldHighlight ? 0 : undefined}\n opacity={shouldHighlight ? 1 : 0.1}\n rx={props.roundCorners ? 3 : 0}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative, point.barLabel)}\n </g>\n );\n });\n return bars;\n }\n\n function _createStringBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSXElement[] {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x);\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n // Setting the bar width here is safe because there are no dependencies earlier in the code\n // that rely on the width of bars in vertical bar charts with string x-axis.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, xBarScale.bandwidth(), props.mode);\n return (\n <g\n key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}\n transform={`translate(${0.5 * (xBarScale.bandwidth() - _barWidth)}, 0)`}\n >\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n onMouseLeave={_onBarLeave}\n onBlur={_onBarLeave}\n onFocus={event => _onBarFocus(event, point, index, colorScale(point.y))}\n fill={point.color ? point.color : colorScale(point.y)}\n tabIndex={!props.hideTooltip && shouldHighlight ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative, point.barLabel)}\n </g>\n );\n });\n return bars;\n }\n\n function _createDateBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSXElement[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n className={classes.opacityChangeOnHover}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={event => _onBarFocus(event, point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={!props.hideTooltip && shouldHighlight ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative, point.barLabel)}\n </g>\n );\n });\n return bars;\n }\n\n function _onLegendHover(legendTitle: string): void {\n setActiveLegend(legendTitle);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _getLegendData(data: VerticalBarChartDataPoint[]): JSXElement {\n const { useSingleColor } = props;\n const { lineLegendText, lineLegendColor = tokens.colorPaletteYellowForeground1 } = props;\n const actions: Legend[] = [];\n const mapLegendToColor: Record<string, string> = {};\n data.forEach((point: VerticalBarChartDataPoint, _index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const color: string = !useSingleColor ? point.color! : _createColors()(1);\n mapLegendToColor[point.legend!] = color;\n });\n Object.entries(mapLegendToColor).forEach(([legendTitle, color]) => {\n // mapping data to the format Legends component needs\n const legend: Legend = {\n title: legendTitle,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n actions.push(legend);\n });\n if (_isHavingLine && lineLegendText && lineLegendColor) {\n const lineLegend: Legend = {\n title: lineLegendText,\n color: lineLegendColor,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(lineLegendText);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n isLineLegendInBarChart: true,\n };\n actions.unshift(lineLegend);\n }\n const legends = (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n selectedLegends={selectedLegends}\n onChange={_onLegendSelectionChange}\n legendRef={_legendsRef}\n />\n );\n return legends;\n }\n\n function _onLegendSelectionChange(\n legendsSelected: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(legendsSelected);\n } else {\n setSelectedLegends(legendsSelected.slice(-1));\n }\n\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(legendsSelected, event, currentLegend);\n }\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n const { yAxisDomainValues: domainValue } = yAxisData;\n _yMax = Math.max(domainValue[domainValue.length - 1], props.yMaxValue || 0);\n _yMin = Math.min(domainValue[0], props.yMinValue || 0);\n }\n }\n\n /**\n * This function checks if the given legend is highlighted or not.\n * A legend can be highlighted in 2 ways:\n * 1. selection: if the user clicks on it\n * 2. hovering: if there is no selected legend and the user hovers over it\n */\n function _legendHighlighted(legendTitle: string | undefined): boolean {\n return _getHighlightedLegend().includes(legendTitle!);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n function _noLegendHighlighted(): boolean {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _getAriaLabel(point: VerticalBarChartDataPoint): string {\n const xValue = point.xAxisCalloutData\n ? point.xAxisCalloutData\n : point.x instanceof Date\n ? point.x.toLocaleString()\n : point.x;\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.y;\n const lineLegend = props.lineLegendText || 'Line';\n const lineYValue = point.lineData?.yAxisCalloutData || point.lineData?.y;\n return (\n point.callOutAccessibilityData?.ariaLabel ||\n `${xValue}. ` +\n (legend ? `${legend}, ` : '') +\n `${yValue}.` +\n (typeof lineYValue !== 'undefined' ? ` ${lineLegend}, ${lineYValue}.` : '')\n );\n }\n\n function _renderBarLabel(\n xPoint: number,\n yPoint: number,\n barValue: number,\n legend: string,\n isNegativeBar: boolean,\n customBarLabel?: string,\n ) {\n if (props.hideLabels || _barWidth < 16 || !(_legendHighlighted(legend) || _noLegendHighlighted())) {\n return null;\n }\n\n // Use custom barLabel if provided, otherwise use the formatted barValue\n const displayLabel =\n customBarLabel !== undefined\n ? customBarLabel\n : typeof props.yAxisTickFormat === 'function'\n ? props.yAxisTickFormat(barValue)\n : formatScientificLimitWidth(barValue);\n\n return (\n <text\n x={xPoint + _barWidth / 2}\n y={isNegativeBar ? yPoint + 12 : yPoint - 6}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-hidden={true}\n style={{ direction: 'ltr', unicodeBidi: 'isolate' }}\n >\n {displayLabel}\n </text>\n );\n }\n\n function _getDomainMargins(containerWidth: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n\n const mapX: Record<string, number | string | Date> = {};\n props.data?.forEach(point => {\n if (point.x instanceof Date) {\n mapX[point.x.getTime()] = point.x;\n } else {\n mapX[point.x] = point.x;\n }\n });\n const uniqueX = Object.values(mapX);\n\n /** Total width available to render the bars */\n const totalWidth = calcTotalWidth(containerWidth, margins, MIN_DOMAIN_MARGIN);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding, props.xAxisPadding)) {\n // Setting the domain margin for string x-axis to 0 because the xAxisOuterPadding prop is now available\n // to adjust the space before the first bar and after the last bar.\n _domainMargin = 0;\n } else if (props.barWidth !== 'auto' && props.mode !== 'histogram') {\n // Update the bar width so that when CartesianChart rerenders,\n // the following calculations don't use the previous bar width.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n /** Total width required to render the bars. Directly proportional to bar width */\n const reqWidth = calcRequiredWidth(_barWidth, uniqueX.length, _xAxisInnerPadding);\n\n if (totalWidth >= reqWidth) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalWidth - reqWidth) / 2;\n }\n } else if (['plotly', 'histogram'].includes(props.mode!) && uniqueX.length > 1) {\n // Calculate the remaining width after rendering bars at their maximum allowable width\n const bandwidth = calcBandwidth(totalWidth, uniqueX.length, _xAxisInnerPadding);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, bandwidth, props.mode);\n let reqWidth = calcRequiredWidth(barWidth, uniqueX.length, _xAxisInnerPadding);\n const margin1 = (totalWidth - reqWidth) / 2;\n\n let margin2 = Number.POSITIVE_INFINITY;\n // This logic may introduce gaps between histogram bars when the barWidth is restricted.\n // So disable it for histogram mode.\n if (props.mode !== 'histogram') {\n // Calculate the remaining width after accounting for the space required to render x-axis labels\n const step = calculateLongestLabelWidth(uniqueX as string[]) + 20;\n reqWidth = (uniqueX.length - _xAxisInnerPadding) * step;\n margin2 = (totalWidth - reqWidth) / 2;\n }\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n } else {\n if (props.mode === 'histogram') {\n // Try center-aligning the bars to eliminate any gaps caused by a restricted barWidth.\n // This only works if the bin centers are consistent across all legend groups; otherwise,\n // the calculated domainMargin may be too small.\n const barWidth = props.maxBarWidth!;\n const reqWidth = calcRequiredWidth(barWidth, uniqueX.length, _xAxisInnerPadding);\n _domainMargin += Math.max(0, (totalWidth - reqWidth) / 2);\n }\n\n // The histogram may appear distorted when bin centers/sizes vary across different legend groups.\n // Currently, we calculate the appropriate bar width using the closest unique x-values to make\n // the bars of the same legend group adjacent. But these x-values can come from different legend groups\n // and result in misleading visuals. Even if we compute bar widths separately within each group,\n // we still lack support for rendering bars with different widths and must use the minimum width,\n // which can cause the same issue.\n // Solution: Instead of estimating the appropriate bar width, render each bar to span the full range\n // of its corresponding bin explicitly.\n _barWidth = getBarWidth(\n props.barWidth,\n props.maxBarWidth,\n calculateAppropriateBarWidth(\n uniqueX as number[] | Date[],\n calcTotalWidth(containerWidth, margins, _domainMargin),\n _xAxisInnerPadding,\n ),\n props.mode,\n );\n _domainMargin += _barWidth / 2;\n _domainMargin += _barWidth / 2;\n }\n\n return {\n ...margins,\n left: margins.left! + _domainMargin,\n right: margins.right! + _domainMargin,\n };\n }\n\n function _getChartTitle(): string {\n const { chartTitle, data } = props;\n return (\n (chartTitle ? `${chartTitle}. ` : '') +\n `Vertical bar chart with ${data?.length || 0} bars` +\n (_isHavingLine ? ' and 1 line' : '') +\n '. '\n );\n }\n\n function _isChartEmpty(): boolean {\n return _points.length === 0 || (_points.every(point => point.y === 0) && !_isHavingLine);\n }\n\n function _getOrderedXAxisLabels() {\n if (_xAxisType !== XAxisTypes.StringAxis) {\n return [];\n }\n\n return sortAxisCategories(_mapCategoryToValues(), props.xAxisCategoryOrder);\n }\n\n function _mapCategoryToValues() {\n const categoryToValues: Record<string, number[]> = {};\n _points.forEach(point => {\n const xValue = point.x as string;\n if (!categoryToValues[xValue]) {\n categoryToValues[xValue] = [];\n }\n categoryToValues[xValue].push(point.y);\n if (point.lineData) {\n categoryToValues[xValue].push(point.lineData.y);\n }\n });\n return categoryToValues;\n }\n\n function updatePosition(newX: number, newY: number) {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n _adjustProps();\n _xAxisLabels = _getOrderedXAxisLabels();\n _yMax = Math.max(d3Max(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMaxValue || 0);\n _yMin = Math.min(d3Min(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMinValue || 0);\n const legendBars: JSXElement = _getLegendData(_points);\n const calloutProps = {\n ...(_isHavingLine && {\n YValueHover: hoveredYValues,\n hoverXValue: hoverXValue,\n }),\n color: color,\n legend: calloutLegend,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n clickPosition: clickPosition,\n isPopoverOpen: isPopoverOpen,\n isCalloutForStack: _isHavingLine && (_noLegendHighlighted() || _getHighlightedLegend().length > 1),\n culture: props.culture,\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() != null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n };\n\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n return !_isChartEmpty() ? (\n <CartesianChart\n {...props}\n points={_points}\n chartTitle={_getChartTitle()}\n chartType={ChartTypes.VerticalBarChart}\n xAxisType={_xAxisType!}\n createYAxis={createNumericYAxis}\n calloutProps={calloutProps}\n tickParams={tickParams}\n {...(_isHavingLine && _noLegendHighlighted() && { isCalloutForStack: true })}\n legendBars={legendBars}\n datasetForXAxisDomain={_xAxisLabels}\n barwidth={_barWidth}\n createStringYAxis={createStringYAxis}\n getmargins={_getMargins}\n getMinMaxOfYAxis={findVerticalNumericMinMaxOfY}\n getGraphData={_getGraphData}\n getDomainNRangeValues={_getDomainNRangeValues}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n getDomainMargins={_getDomainMargins}\n {...(_xAxisType! === XAxisTypes.StringAxis && {\n xAxisInnerPadding: _xAxisInnerPadding,\n xAxisOuterPadding: _xAxisOuterPadding,\n })}\n componentRef={cartesianChartRef}\n showRoundOffXTickValues={\n !isScalePaddingDefined(props.xAxisInnerPadding, props.xAxisPadding) && props.mode !== 'histogram'\n }\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line react/no-children-prop\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n {_isHavingLine && (\n <g>\n {_createLine(\n props.xScale!,\n props.yScalePrimary!,\n props.containerHeight,\n props.containerWidth,\n props.yScaleSecondary,\n )}\n </g>\n )}\n </>\n );\n }}\n />\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n});\nVerticalBarChart.displayName = 'VerticalBarChart';\n"],"names":["React","useVerticalBarChartStyles","max","d3Max","min","d3Min","line","d3Line","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","scaleUtc","d3ScaleUtc","useId","tokens","CartesianChart","Legends","ChartPopover","ChartTypes","getAccessibleDataObject","XAxisTypes","getTypeOfAxis","formatScientificLimitWidth","getBarWidth","getScalePadding","isScalePaddingDefined","calculateAppropriateBarWidth","useRtl","areArraysEqual","calculateLongestLabelWidth","findVerticalNumericMinMaxOfY","createNumericYAxis","domainRangeOfVerticalNumeric","domainRangeOfDateForAreaLineScatterVerticalBarCharts","domainRangeOfXStringAxis","createStringYAxis","calcTotalWidth","calcBandwidth","calcRequiredWidth","sortAxisCategories","useImageExport","CircleVisbility","MIN_DOMAIN_MARGIN","VerticalBarChart","forwardRef","_props","forwardedRef","props","xAxisCategoryOrder","maxBarWidth","_points","_barWidth","_colors","_refArray","margins","_useRtl","_bars","_xAxisLabels","_yMax","_yMin","_isHavingLine","_checkForLine","_xAxisType","_calloutAnchorPoint","_domainMargin","_emptyChartId","_vbcLineId","_vbcPointId","_vbcBarId","_xAxisInnerPadding","_xAxisOuterPadding","cartesianChartRef","legendsRef","_legendsRef","componentRef","hideLegend","color","setColor","useState","dataForHoverCard","setDataForHoverCard","activeLegend","setActiveLegend","undefined","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","activeXdataPoint","setActiveXDatapoint","hoveredYValues","setYValueHover","hoverXValue","setHoverXValue","calloutLegend","setCalloutLegend","callOutAccessibilityData","setCalloutAccessibilityData","dataPointCalloutProps","setDataPointCalloutProps","clickPosition","setClickPosition","x","y","isPopoverOpen","setPopoverOpen","selectedLegends","setSelectedLegends","legendProps","prevPropsRef","useRef","useEffect","current","prevProps","height","width","_adjustProps","_getDomainNRangeValues","points","chartType","isRTL","xAxisType","barWidth","tickValues","domainNRangeValue","NumericAxis","DateAxis","_createLine","xScale","yScalePrimary","containerHeight","containerWidth","yScaleSecondary","isStringAxis","StringAxis","colorScale","_createColors","data","lineLegendColor","colorPaletteYellowBackground1","lineLegendText","lineData","forEach","item","index","push","useSecondaryYScale","point","linePath","d","bandwidth","shouldHighlight","_legendHighlighted","_noLegendHighlighted","lineBorderWidth","lineOptions","Number","parseFloat","toString","path","key","id","opacity","fill","strokeLinecap","strokeWidth","className","classes","lineBorder","stroke","dots","map","circleRef","refElement","circle","cx","cy","onMouseOver","event","_lineHover","_onBarHover","onMouseOut","_onBarLeave","r","_getCircleVisibilityAndRadius","radius","colorNeutralBackground1","visibility","onClick","data-is-focusable","ref","e","onFocus","_lineFocus","onBlur","_handleChartMouseLeave","tabIndex","xAxisPoint","legend","some","length","mode","defaultColors","colorPaletteBlueForeground2","colorPaletteCornflowerForeground2","colorPaletteDarkGreenForeground2","colorPaletteNavyForeground2","colorPaletteDarkOrangeForeground2","colors","xAxisInnerPadding","xAxisPadding","xAxisOuterPadding","_getMargins","_margins","_renderContentForBothLineAndBars","YValueHover","_getCalloutContentForLineAndBar","content","culture","XValue","YValue","isCalloutForStack","_renderContentForOnlyBars","xAxisCalloutData","yAxisCalloutData","useSingleColor","_renderCallout","_getCustomizedCallout","onRenderCalloutPerDataPoint","_getGraphData","yScale","xElement","_createNumericBars","_createDateBars","_createStringBars","increment","_p","colorPaletteBlueBackground2","domainValues","i","domain","range","_refCallback","element","legendTitle","selectedPoint","filter","xDataPoint","includes","Date","toLocaleString","mouseEvent","persist","updatePosition","clientX","clientY","toLocaleDateString","_onBarFocus","refArrayIndexNumber","targetRect","target","getBoundingClientRect","left","top","obj","_lineHoverFocus","_refSelected","_getScales","xBarScale","yBarScale","bottom","xMax","xMin","right","nice","sDate","lDate","paddingInner","paddingOuter","_calculateMinBarHeight","yMin","yMax","yReferencePoint","maxHeightFromBaseline","Math","abs","ceil","bars","barHeight","isHeightNegative","minBarHeight","adjustedBarHeight","Fragment","xPoint","yPoint","baselineHeight","g","rect","aria-label","_getAriaLabel","role","onMouseLeave","hideTooltip","rx","roundCorners","_renderBarLabel","barLabel","getTime","transform","opacityChangeOnHover","_onLegendHover","_onLegendLeave","_getLegendData","colorPaletteYellowForeground1","actions","mapLegendToColor","_index","Object","entries","title","hoverAction","onMouseOutAction","lineLegend","isLineLegendInBarChart","unshift","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","legendRef","legendsSelected","currentLegend","canSelectMultipleLegends","slice","_getAxisData","yAxisData","yAxisDomainValues","domainValue","yMaxValue","yMinValue","_getHighlightedLegend","xValue","yValue","lineYValue","ariaLabel","barValue","isNegativeBar","customBarLabel","hideLabels","displayLabel","yAxisTickFormat","text","textAnchor","aria-hidden","style","direction","unicodeBidi","_getDomainMargins","mapX","uniqueX","values","totalWidth","reqWidth","margin1","margin2","POSITIVE_INFINITY","step","_getChartTitle","chartTitle","_isChartEmpty","every","_getOrderedXAxisLabels","_mapCategoryToValues","categoryToValues","newX","newY","threshold","distance","sqrt","pow","legendBars","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","tickParams","tickFormat","createYAxis","datasetForXAxisDomain","barwidth","getmargins","getMinMaxOfYAxis","getGraphData","getDomainNRangeValues","getAxisData","onChartMouseLeave","getDomainMargins","showRoundOffXTickValues","children","div","displayName"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/components/VerticalBarChart/VerticalBarChart.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { useVerticalBarChartStyles } from './useVerticalBarChartStyles.styles';\nimport { max as d3Max, min as d3Min } from 'd3-array';\nimport { line as d3Line } from 'd3-shape';\nimport type { ScaleLinear as D3ScaleLinear } from 'd3-scale';\nimport { scaleLinear as d3ScaleLinear, scaleBand as d3ScaleBand, scaleUtc as d3ScaleUtc } from 'd3-scale';\nimport { useId } from '@fluentui/react-utilities';\nimport type { JSXElement } from '@fluentui/react-utilities';\nimport { tokens } from '@fluentui/react-theme';\nimport type {\n AccessibilityProps,\n Margins,\n Legend,\n RefArrayData,\n VerticalBarChartProps,\n VerticalBarChartDataPoint,\n ChildProps,\n YValueHover,\n DataPoint,\n} from '../../index';\nimport { CartesianChart, Legends, ChartPopover } from '../../index';\nimport type { IAxisData, NumericAxis, IDomainNRange } from '../../utilities/index';\nimport {\n ChartTypes,\n getAccessibleDataObject,\n XAxisTypes,\n getTypeOfAxis,\n formatScientificLimitWidth,\n getBarWidth,\n getScalePadding,\n isScalePaddingDefined,\n calculateAppropriateBarWidth,\n useRtl,\n areArraysEqual,\n calculateLongestLabelWidth,\n findVerticalNumericMinMaxOfY,\n createNumericYAxis,\n domainRangeOfVerticalNumeric,\n domainRangeOfDateForAreaLineScatterVerticalBarCharts,\n domainRangeOfXStringAxis,\n createStringYAxis,\n calcTotalWidth,\n calcBandwidth,\n calcRequiredWidth,\n sortAxisCategories,\n} from '../../utilities/index';\nimport { useImageExport } from '../../utilities/hooks';\n\nenum CircleVisbility {\n show = 'visibility',\n hide = 'hidden',\n}\n\nconst MIN_DOMAIN_MARGIN = 8;\n\n// Create a VerticalBarChart variant which uses these default styles and this styled subcomponent.\n/**\n * VerticalBarchart component\n * {@docCategory VerticalBarChart}\n */\nexport const VerticalBarChart: React.FunctionComponent<VerticalBarChartProps> = React.forwardRef<\n HTMLDivElement,\n VerticalBarChartProps\n>((_props, forwardedRef) => {\n const props: VerticalBarChartProps = {\n xAxisCategoryOrder: 'default',\n maxBarWidth: 24,\n ..._props,\n };\n let _points: VerticalBarChartDataPoint[] = [];\n let _barWidth: number = 0;\n let _colors: string[];\n const _refArray: RefArrayData[] = [];\n let margins: Margins;\n const _useRtl: boolean = useRtl();\n let _bars: JSXElement[];\n let _xAxisLabels: string[];\n let _yMax: number;\n let _yMin: number;\n let _isHavingLine: boolean = _checkForLine();\n let _xAxisType: XAxisTypes;\n let _calloutAnchorPoint: VerticalBarChartDataPoint | null;\n let _domainMargin: number;\n const _emptyChartId: string = useId('_VBC_empty');\n const _vbcLineId: string = useId('_VBC_line_');\n const _vbcPointId: string = useId('_VBC_point_');\n const _vbcBarId: string = useId('_VBC_bar_');\n let _xAxisInnerPadding: number = 0;\n let _xAxisOuterPadding: number = 0;\n type ColorScale = (_p?: number) => string;\n const { cartesianChartRef, legendsRef: _legendsRef } = useImageExport(props.componentRef, props.hideLegend);\n\n const [color, setColor] = React.useState<string>('');\n const [dataForHoverCard, setDataForHoverCard] = React.useState<number>(0);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [xCalloutValue, setXCalloutValue] = React.useState<string | undefined>('');\n const [yCalloutValue, setYCalloutValue] = React.useState<string | undefined>('');\n const [activeXdataPoint, setActiveXDatapoint] = React.useState<string | number | Date | null>(null);\n const [hoveredYValues, setYValueHover] = React.useState<YValueHover[]>();\n const [hoverXValue, setHoverXValue] = React.useState<string | number | undefined>('');\n const [calloutLegend, setCalloutLegend] = React.useState<string>('');\n const [callOutAccessibilityData, setCalloutAccessibilityData] = React.useState<AccessibilityProps>();\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<VerticalBarChartDataPoint>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const prevPropsRef = React.useRef<VerticalBarChartProps | null>(null);\n\n React.useEffect(() => {\n if (prevPropsRef.current) {\n const prevProps = prevPropsRef.current;\n if (!areArraysEqual(prevProps.legendProps?.selectedLegends, props.legendProps?.selectedLegends)) {\n setSelectedLegends(props.legendProps?.selectedLegends || []);\n }\n if (prevProps.height !== props.height || prevProps.width !== props.width) {\n _adjustProps();\n }\n }\n prevPropsRef.current = props;\n }, [props, prevPropsRef, _adjustProps]);\n\n function _getDomainNRangeValues(\n points: DataPoint[],\n margins: Margins,\n width: number,\n chartType: ChartTypes,\n isRTL: boolean,\n xAxisType: XAxisTypes,\n barWidth: number,\n tickValues: Date[] | number[] | undefined,\n ) {\n let domainNRangeValue: IDomainNRange;\n if (xAxisType === XAxisTypes.NumericAxis) {\n domainNRangeValue = domainRangeOfVerticalNumeric(points, margins, width, isRTL, barWidth!);\n } else if (xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = domainRangeOfDateForAreaLineScatterVerticalBarCharts(\n points,\n margins,\n width,\n isRTL,\n tickValues! as Date[],\n chartType,\n barWidth,\n );\n } else {\n domainNRangeValue = domainRangeOfXStringAxis(margins, width, isRTL);\n }\n return domainNRangeValue;\n }\n\n function _createLine(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScalePrimary: any,\n containerHeight: number = 0,\n containerWidth: number = 0,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yScaleSecondary?: any,\n ): React.ReactNode {\n const isStringAxis = _xAxisType === XAxisTypes.StringAxis;\n const colorScale = _createColors();\n const { data, lineLegendColor = tokens.colorPaletteYellowBackground1, lineLegendText } = props;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const lineData: Array<any> = [];\n const line: JSXElement[] = [];\n data &&\n data.forEach((item: VerticalBarChartDataPoint, index: number) => {\n if (item.lineData && item.lineData.y) {\n lineData.push({\n x: item.x,\n y: item.lineData!.y,\n useSecondaryYScale: item.lineData!.useSecondaryYScale ?? false,\n point: item,\n index,\n });\n }\n });\n const linePath = d3Line()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => (isStringAxis ? xScale(d.x) + 0.5 * xScale.bandwidth() : xScale(d.x)))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y((d: any) => (d.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(d.y) : yScalePrimary(d.y)));\n const shouldHighlight = _legendHighlighted(lineLegendText!) || _noLegendHighlighted() ? true : false;\n const lineBorderWidth = props.lineOptions?.lineBorderWidth\n ? Number.parseFloat(props.lineOptions!.lineBorderWidth!.toString())\n : 0;\n\n if (lineBorderWidth > 0) {\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3 + lineBorderWidth * 2}\n className={classes.lineBorder}\n />,\n );\n }\n line.push(\n <path\n key={_vbcLineId}\n id={_vbcLineId}\n opacity={shouldHighlight ? 1 : 0.1}\n d={linePath(lineData)!}\n fill=\"transparent\"\n strokeLinecap=\"square\"\n strokeWidth={3}\n stroke={lineLegendColor}\n />,\n );\n\n const dots: React.ReactNode[] = lineData.map(\n (\n item: {\n x: number | string;\n y: number;\n useSecondaryYScale: boolean;\n point: VerticalBarChartDataPoint;\n index: number;\n },\n index: number,\n ) => {\n // Create an object to store line point ref so that the object can be passed by reference to the focus handler\n const circleRef: { refElement: SVGCircleElement | null } = { refElement: null };\n return (\n <circle\n key={index}\n id={`${_vbcPointId}-${index}`}\n cx={isStringAxis ? xScale(item.x) + 0.5 * xScale.bandwidth() : xScale(item.x)}\n cy={item.useSecondaryYScale && yScaleSecondary ? yScaleSecondary(item.y) : yScalePrimary(item.y)}\n onMouseOver={event =>\n _legendHighlighted(lineLegendText!)\n ? _lineHover(item.point, event)\n : _onBarHover(item.point, colorScale(item.y), event)\n }\n onMouseOut={_onBarLeave}\n r={_getCircleVisibilityAndRadius(item.x, lineLegendText!).radius}\n stroke={lineLegendColor}\n fill={tokens.colorNeutralBackground1}\n strokeWidth={3}\n visibility={_getCircleVisibilityAndRadius(item.x, lineLegendText!).visibility}\n onClick={item.point.lineData?.onClick}\n // When no legend is highlighted: Line points are automatically displayed along with the bars\n // at the same x-axis point in the stack callout. So to prevent an increase in focusable elements\n // and avoid conveying duplicate info, make these line points non-focusable.\n data-is-focusable={_legendHighlighted(lineLegendText!)}\n ref={e => {\n circleRef.refElement = e;\n }}\n onFocus={event => _lineFocus(event, item.point, circleRef)}\n onBlur={_handleChartMouseLeave}\n tabIndex={_legendHighlighted(lineLegendText!) ? 0 : undefined}\n />\n );\n },\n );\n\n return (\n <>\n {line}\n {dots}\n </>\n );\n }\n\n function _getCircleVisibilityAndRadius(\n xAxisPoint: string | number | Date,\n legend: string,\n ): { visibility: CircleVisbility; radius: number } {\n if (!_noLegendHighlighted()) {\n if (xAxisPoint === activeXdataPoint && _legendHighlighted(legend)) {\n return { visibility: CircleVisbility.show, radius: 8 };\n } else if (_legendHighlighted(legend)) {\n // Don't hide the circle to keep it focusable. For more information,\n // see https://fuzzbomb.github.io/accessibility-demos/visually-hidden-focus-test.html\n return { visibility: CircleVisbility.show, radius: 0.3 };\n } else {\n return { visibility: CircleVisbility.hide, radius: 0 };\n }\n } else {\n return {\n visibility: activeXdataPoint === xAxisPoint ? CircleVisbility.show : CircleVisbility.hide,\n radius: 8,\n };\n }\n }\n\n function _checkForLine(): boolean {\n const { data } = props;\n return data!.some((item: VerticalBarChartDataPoint) => item?.lineData?.y !== undefined);\n }\n\n function _adjustProps(): void {\n _xAxisType =\n props.data! && props.data!.length > 0\n ? (getTypeOfAxis(props.data![0].x, true) as XAxisTypes)\n : XAxisTypes.StringAxis;\n _points = props.data || [];\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, undefined, props.mode);\n const defaultColors: string[] = [\n tokens.colorPaletteBlueForeground2,\n tokens.colorPaletteCornflowerForeground2,\n tokens.colorPaletteDarkGreenForeground2,\n tokens.colorPaletteNavyForeground2,\n tokens.colorPaletteDarkOrangeForeground2,\n ];\n _colors = props.colors || defaultColors;\n _isHavingLine = _checkForLine();\n _xAxisInnerPadding =\n props.mode === 'histogram'\n ? 0\n : getScalePadding(\n props.xAxisInnerPadding,\n props.xAxisPadding,\n _xAxisType === XAxisTypes.StringAxis ? 2 / 3 : 1 / 2,\n );\n _xAxisOuterPadding = getScalePadding(props.xAxisOuterPadding, props.xAxisPadding, 0);\n }\n\n function _getMargins(_margins: Margins) {\n margins = _margins;\n }\n\n function _renderContentForBothLineAndBars(point: VerticalBarChartDataPoint): JSXElement {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n const content: JSXElement[] = YValueHover.map((item: YValueHover, index: number) => {\n return (\n <>\n <ChartPopover\n culture={props.culture}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={item.legend!}\n {...(index === 0 && { XValue: `${hoverXValue || item.data}` })}\n YValue={item.data || item.y}\n color={item.color}\n isCalloutForStack={false}\n />\n </>\n );\n });\n return <>{content}</>;\n }\n\n function _renderContentForOnlyBars(_props: VerticalBarChartDataPoint): JSXElement {\n return (\n <>\n <ChartPopover\n XValue={_props.xAxisCalloutData || (_props.x as string)}\n xCalloutValue={xCalloutValue}\n yCalloutValue={yCalloutValue}\n culture={props.culture}\n clickPosition={clickPosition}\n isPopoverOpen={isPopoverOpen}\n legend={_props.legend!}\n YValue={_props.yAxisCalloutData || _props.y}\n color={!props.useSingleColor && _props.color ? _props.color : _createColors()(_props.y)}\n isCalloutForStack={false}\n />\n </>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function _renderCallout(props?: VerticalBarChartDataPoint): JSXElement | null {\n return props ? (_isHavingLine ? _renderContentForBothLineAndBars(props) : _renderContentForOnlyBars(props)) : null;\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps, _renderCallout)\n : null;\n }\n\n function _getGraphData(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n yScale: NumericAxis,\n containerHeight: number,\n containerWidth: number,\n xElement?: SVGElement | null,\n ) {\n return (_bars =\n _xAxisType === XAxisTypes.NumericAxis\n ? _createNumericBars(containerHeight, containerWidth, xElement!)\n : _xAxisType === XAxisTypes.DateAxis\n ? _createDateBars(containerHeight, containerWidth, xElement!)\n : _createStringBars(containerHeight, containerWidth, xElement!));\n }\n\n function _createColors(): D3ScaleLinear<string, string> | ColorScale {\n const increment = _colors.length <= 1 ? 1 : 1 / (_colors.length - 1);\n const { useSingleColor = false } = props;\n if (useSingleColor) {\n return (_p?: number) => {\n const { colors } = props;\n return colors && colors.length > 0 ? colors[0] : tokens.colorPaletteBlueBackground2;\n };\n }\n const domainValues = [];\n for (let i = 0; i < _colors.length; i++) {\n domainValues.push(increment * i * _yMax);\n }\n const colorScale = d3ScaleLinear<string>().domain(domainValues).range(_colors);\n return colorScale;\n }\n\n function _refCallback(element: SVGRectElement, legendTitle: string): void {\n _refArray.push({ index: legendTitle, refElement: element });\n }\n\n function _getCalloutContentForLineAndBar(point: VerticalBarChartDataPoint): {\n YValueHover: YValueHover[];\n hoverXValue: string | number | undefined;\n } {\n const YValueHover: YValueHover[] = [];\n const { useSingleColor = false } = props;\n const { data, lineLegendText, lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n const selectedPoint = data!.filter((xDataPoint: VerticalBarChartDataPoint) => xDataPoint.x === point.x);\n // Check if the line legend is highlighted or no legend is highlighted\n if (\n _isHavingLine &&\n selectedPoint[0].lineData?.y !== undefined &&\n (_legendHighlighted(lineLegendText) || _noLegendHighlighted())\n ) {\n // Add callout data for the line\n YValueHover.push({\n legend: lineLegendText,\n color: lineLegendColor,\n y: selectedPoint[0].lineData?.y,\n data: selectedPoint[0].lineData?.yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].lineData?.yAxisCalloutData,\n });\n }\n // Check if the bar legend is highlighted or no legend is highlighted\n if (selectedLegends.includes(selectedPoint[0].legend!) || _noLegendHighlighted()) {\n // Add callout data for the bar\n YValueHover.push({\n legend: selectedPoint[0].legend,\n y: selectedPoint[0].y,\n color: !useSingleColor\n ? selectedPoint[0].color\n ? selectedPoint[0].color\n : _createColors()(selectedPoint[0].y)\n : _createColors()(1),\n data: selectedPoint[0].yAxisCalloutData,\n yAxisCalloutData: selectedPoint[0].yAxisCalloutData,\n });\n }\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const hoverXValue = point.x instanceof Date ? point.x.toLocaleString() : point.x.toString();\n return {\n YValueHover,\n hoverXValue: point.xAxisCalloutData || hoverXValue,\n };\n }\n\n function _onBarHover(\n point: VerticalBarChartDataPoint,\n // eslint-disable-next-line @typescript-eslint/no-shadow\n color: string,\n mouseEvent: React.MouseEvent<SVGElement>,\n ): void {\n mouseEvent.persist();\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n if (_calloutAnchorPoint !== point) {\n _calloutAnchorPoint = point;\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(_noLegendHighlighted() ? point.x : null);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n }\n\n function _onBarLeave(): void {\n /**/\n }\n\n function _handleChartMouseLeave(): void {\n _calloutAnchorPoint = null;\n setPopoverOpen(false);\n setActiveXDatapoint(null);\n setYValueHover([]);\n setHoverXValue('');\n }\n\n function _onBarFocus(\n event: React.FocusEvent<SVGRectElement, Element>,\n point: VerticalBarChartDataPoint,\n refArrayIndexNumber: number,\n color: string,\n ): void {\n let x = 0;\n let y = 0;\n\n const targetRect = (event.target as SVGRectElement).getBoundingClientRect();\n x = targetRect.left + targetRect.width / 2;\n y = targetRect.top + targetRect.height / 2;\n updatePosition(x, y);\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { YValueHover, hoverXValue } = _getCalloutContentForLineAndBar(point);\n _refArray.forEach((obj: RefArrayData, index: number) => {\n if (obj.index === point.legend! && refArrayIndexNumber === index) {\n /** Show the callout if highlighted bar is hovered and Hide it if unhighlighted bar is hovered */\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(point.legend));\n setDataForHoverCard(point.y);\n setCalloutLegend(point.legend!);\n setColor(point.color || color);\n // To display callout value, if no callout value given, taking given point.x value as a string.\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.yAxisCalloutData!);\n setDataPointCalloutProps(point);\n // Hovering over a bar should highlight corresponding line points only when no legend is selected\n setActiveXDatapoint(point.x);\n setYValueHover(YValueHover);\n setHoverXValue(hoverXValue);\n setCalloutAccessibilityData(point.callOutAccessibilityData);\n }\n });\n }\n\n function _lineHover(point: VerticalBarChartDataPoint, mouseEvent: React.MouseEvent<SVGElement>) {\n mouseEvent.persist();\n _lineHoverFocus(point, mouseEvent);\n }\n\n function _lineFocus(\n event: React.FocusEvent<SVGCircleElement, Element>,\n point: VerticalBarChartDataPoint,\n ref: { refElement: SVGCircleElement | null },\n ) {\n if (ref.refElement) {\n _lineHoverFocus(point, ref.refElement);\n }\n }\n\n function _lineHoverFocus(\n point: VerticalBarChartDataPoint,\n _refSelected: React.MouseEvent<SVGElement> | SVGCircleElement,\n ) {\n const { lineLegendText = '', lineLegendColor = tokens.colorPaletteYellowBackground1 } = props;\n setPopoverOpen(_noLegendHighlighted() || _legendHighlighted(lineLegendText));\n setCalloutLegend(lineLegendText);\n setDataForHoverCard(point.lineData!.y);\n setColor(lineLegendColor);\n setXCalloutValue(\n point.xAxisCalloutData || (point.x instanceof Date ? point.x.toLocaleDateString() : point.x.toString()),\n );\n setYCalloutValue(point.lineData!.yAxisCalloutData);\n setDataPointCalloutProps(point);\n setActiveXDatapoint(point.x);\n }\n\n function _getScales(\n containerHeight: number,\n containerWidth: number,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): { xBarScale: any; yBarScale: any } {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let xBarScale: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const yBarScale: any = d3ScaleLinear()\n .domain([_yMin, _yMax])\n .range([0, containerHeight - margins.bottom! - margins.top!]);\n\n if (_xAxisType === XAxisTypes.NumericAxis) {\n const xMax = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n const xMin = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as number)!;\n xBarScale = d3ScaleLinear()\n .domain(_useRtl ? [xMax, xMin] : [xMin, xMax])\n .range([margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin]);\n if (!isScalePaddingDefined(props.xAxisInnerPadding, props.xAxisPadding) && props.mode !== 'histogram') {\n xBarScale.nice();\n }\n } else if (_xAxisType === XAxisTypes.DateAxis) {\n const sDate = d3Min(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n const lDate = d3Max(_points, (point: VerticalBarChartDataPoint) => point.x as Date)!;\n xBarScale = d3ScaleUtc()\n .domain([sDate, lDate])\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n );\n } else {\n xBarScale = d3ScaleBand()\n .domain(_xAxisLabels)\n .range(\n _useRtl\n ? [containerWidth - margins.right! - _domainMargin, margins.left! + _domainMargin]\n : [margins.left! + _domainMargin, containerWidth - margins.right! - _domainMargin],\n )\n .paddingInner(_xAxisInnerPadding)\n .paddingOuter(_xAxisOuterPadding);\n }\n\n return { xBarScale, yBarScale };\n }\n\n const classes = useVerticalBarChartStyles(props);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _calculateMinBarHeight(yMin: number, yMax: number, yReferencePoint: number, yBarScale: any): number {\n const maxHeightFromBaseline =\n yMax < 0\n ? Math.abs(yMin - yReferencePoint)\n : Math.max(Math.abs(yMax - yReferencePoint), Math.abs(yMin - yReferencePoint));\n return Math.ceil(yBarScale(maxHeightFromBaseline) / 100.0);\n }\n\n function _createNumericBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSXElement[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={`${point.x}_${index}` as string}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={event => _onBarFocus(event, point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={!props.hideTooltip && shouldHighlight ? 0 : undefined}\n opacity={shouldHighlight ? 1 : 0.1}\n rx={props.roundCorners ? 3 : 0}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative, point.barLabel)}\n </g>\n );\n });\n return bars;\n }\n\n function _createStringBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSXElement[] {\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x);\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n // Setting the bar width here is safe because there are no dependencies earlier in the code\n // that rely on the width of bars in vertical bar charts with string x-axis.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth, xBarScale.bandwidth(), props.mode);\n return (\n <g\n key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}\n transform={`translate(${0.5 * (xBarScale.bandwidth() - _barWidth)}, 0)`}\n >\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n onMouseLeave={_onBarLeave}\n onBlur={_onBarLeave}\n onFocus={event => _onBarFocus(event, point, index, colorScale(point.y))}\n fill={point.color ? point.color : colorScale(point.y)}\n tabIndex={!props.hideTooltip && shouldHighlight ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative, point.barLabel)}\n </g>\n );\n });\n return bars;\n }\n\n function _createDateBars(containerHeight: number, containerWidth: number, xElement: SVGElement): JSXElement[] {\n const { useSingleColor = false } = props;\n const { xBarScale, yBarScale } = _getScales(containerHeight, containerWidth);\n const colorScale = _createColors();\n const yReferencePoint = _yMax < 0 ? _yMax : 0;\n const bars = _points.map((point: VerticalBarChartDataPoint, index: number) => {\n const shouldHighlight = _legendHighlighted(point.legend!) || _noLegendHighlighted() ? true : false;\n let barHeight: number = yBarScale(point.y) - yBarScale(yReferencePoint);\n const isHeightNegative = barHeight < 0;\n barHeight = Math.abs(barHeight);\n // Calculate threshold for minimum visible bar height\n const minBarHeight = _calculateMinBarHeight(_yMin, _yMax, yReferencePoint, yBarScale);\n let adjustedBarHeight = barHeight;\n\n if (barHeight === 0) {\n return <React.Fragment key={point.x as string}> </React.Fragment>;\n }\n // Adjust bar height if it's smaller than the threshold\n else if (barHeight <= minBarHeight) {\n adjustedBarHeight = minBarHeight;\n }\n const xPoint = xBarScale(point.x as number) - _barWidth / 2;\n const yPoint =\n containerHeight -\n margins.bottom! -\n (isHeightNegative ? -1 * adjustedBarHeight : adjustedBarHeight) -\n yBarScale(yReferencePoint);\n const baselineHeight = containerHeight - margins.bottom! - yBarScale(yReferencePoint);\n return (\n <g key={point.x instanceof Date ? `${point.x.getTime()}_${index}` : `${point.x}_${index}`}>\n <rect\n id={`${_vbcBarId}-${index}`}\n x={xPoint}\n className={classes.opacityChangeOnHover}\n y={!isHeightNegative ? yPoint : baselineHeight}\n width={_barWidth}\n height={adjustedBarHeight}\n ref={(e: SVGRectElement) => {\n _refCallback(e, point.legend!);\n }}\n onClick={point.onClick}\n onMouseOver={event => _onBarHover(point, colorScale(point.y), event)}\n aria-label={_getAriaLabel(point)}\n role=\"img\"\n onMouseLeave={_onBarLeave}\n onFocus={event => _onBarFocus(event, point, index, colorScale(point.y))}\n onBlur={_onBarLeave}\n fill={point.color && !useSingleColor ? point.color : colorScale(point.y)}\n tabIndex={!props.hideTooltip && shouldHighlight ? 0 : undefined}\n rx={props.roundCorners ? 3 : 0}\n opacity={shouldHighlight ? 1 : 0.1}\n />\n {_renderBarLabel(xPoint, yPoint, point.y, point.legend!, isHeightNegative, point.barLabel)}\n </g>\n );\n });\n return bars;\n }\n\n function _onLegendHover(legendTitle: string): void {\n setActiveLegend(legendTitle);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _getLegendData(data: VerticalBarChartDataPoint[]): JSXElement {\n const { useSingleColor } = props;\n const { lineLegendText, lineLegendColor = tokens.colorPaletteYellowForeground1 } = props;\n const actions: Legend[] = [];\n const mapLegendToColor: Record<string, string> = {};\n data.forEach((point: VerticalBarChartDataPoint, _index: number) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const color: string = !useSingleColor ? point.color! : _createColors()(1);\n mapLegendToColor[point.legend!] = color;\n });\n Object.entries(mapLegendToColor).forEach(([legendTitle, color]) => {\n // mapping data to the format Legends component needs\n const legend: Legend = {\n title: legendTitle,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(legendTitle);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n actions.push(legend);\n });\n if (_isHavingLine && lineLegendText && lineLegendColor) {\n const lineLegend: Legend = {\n title: lineLegendText,\n color: lineLegendColor,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(lineLegendText);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n isLineLegendInBarChart: true,\n };\n actions.unshift(lineLegend);\n }\n const legends = (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n overflowText={props.legendsOverflowText}\n {...props.legendProps}\n selectedLegends={selectedLegends}\n onChange={_onLegendSelectionChange}\n legendRef={_legendsRef}\n />\n );\n return legends;\n }\n\n function _onLegendSelectionChange(\n legendsSelected: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(legendsSelected);\n } else {\n setSelectedLegends(legendsSelected.slice(-1));\n }\n\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(legendsSelected, event, currentLegend);\n }\n }\n\n function _getAxisData(yAxisData: IAxisData) {\n if (yAxisData && yAxisData.yAxisDomainValues.length) {\n const { yAxisDomainValues: domainValue } = yAxisData;\n _yMax = Math.max(domainValue[domainValue.length - 1], props.yMaxValue || 0);\n _yMin = Math.min(domainValue[0], props.yMinValue || 0);\n }\n }\n\n /**\n * This function checks if the given legend is highlighted or not.\n * A legend can be highlighted in 2 ways:\n * 1. selection: if the user clicks on it\n * 2. hovering: if there is no selected legend and the user hovers over it\n */\n function _legendHighlighted(legendTitle: string | undefined): boolean {\n return _getHighlightedLegend().includes(legendTitle!);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n function _noLegendHighlighted(): boolean {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _getAriaLabel(point: VerticalBarChartDataPoint): string {\n const xValue = point.xAxisCalloutData\n ? point.xAxisCalloutData\n : point.x instanceof Date\n ? point.x.toLocaleString()\n : point.x;\n const legend = point.legend;\n const yValue = point.yAxisCalloutData || point.y;\n const lineLegend = props.lineLegendText || 'Line';\n const lineYValue = point.lineData?.yAxisCalloutData || point.lineData?.y;\n return (\n point.callOutAccessibilityData?.ariaLabel ||\n `${xValue}. ` +\n (legend ? `${legend}, ` : '') +\n `${yValue}.` +\n (typeof lineYValue !== 'undefined' ? ` ${lineLegend}, ${lineYValue}.` : '')\n );\n }\n\n function _renderBarLabel(\n xPoint: number,\n yPoint: number,\n barValue: number,\n legend: string,\n isNegativeBar: boolean,\n customBarLabel?: string,\n ) {\n if (props.hideLabels || _barWidth < 16 || !(_legendHighlighted(legend) || _noLegendHighlighted())) {\n return null;\n }\n\n // Use custom barLabel if provided, otherwise use the formatted barValue\n const displayLabel =\n customBarLabel !== undefined\n ? customBarLabel\n : typeof props.yAxisTickFormat === 'function'\n ? props.yAxisTickFormat(barValue)\n : formatScientificLimitWidth(barValue);\n\n return (\n <text\n x={xPoint + _barWidth / 2}\n y={isNegativeBar ? yPoint + 12 : yPoint - 6}\n textAnchor=\"middle\"\n className={classes.barLabel}\n aria-hidden={true}\n style={{ direction: 'ltr', unicodeBidi: 'isolate' }}\n >\n {displayLabel}\n </text>\n );\n }\n\n function _getDomainMargins(containerWidth: number): Margins {\n _domainMargin = MIN_DOMAIN_MARGIN;\n\n const mapX: Record<string, number | string | Date> = {};\n props.data?.forEach(point => {\n if (point.x instanceof Date) {\n mapX[point.x.getTime()] = point.x;\n } else {\n mapX[point.x] = point.x;\n }\n });\n const uniqueX = Object.values(mapX);\n\n /** Total width available to render the bars */\n const totalWidth = calcTotalWidth(containerWidth, margins, MIN_DOMAIN_MARGIN);\n\n if (_xAxisType === XAxisTypes.StringAxis) {\n if (isScalePaddingDefined(props.xAxisOuterPadding, props.xAxisPadding)) {\n // Setting the domain margin for string x-axis to 0 because the xAxisOuterPadding prop is now available\n // to adjust the space before the first bar and after the last bar.\n _domainMargin = 0;\n } else if (props.barWidth !== 'auto' && props.mode !== 'histogram') {\n // Update the bar width so that when CartesianChart rerenders,\n // the following calculations don't use the previous bar width.\n _barWidth = getBarWidth(props.barWidth, props.maxBarWidth);\n /** Total width required to render the bars. Directly proportional to bar width */\n const reqWidth = calcRequiredWidth(_barWidth, uniqueX.length, _xAxisInnerPadding);\n\n if (totalWidth >= reqWidth) {\n // Center align the chart by setting equal left and right margins for domain\n _domainMargin = MIN_DOMAIN_MARGIN + (totalWidth - reqWidth) / 2;\n }\n } else if (['plotly', 'histogram'].includes(props.mode!) && uniqueX.length > 1) {\n // Calculate the remaining width after rendering bars at their maximum allowable width\n const bandwidth = calcBandwidth(totalWidth, uniqueX.length, _xAxisInnerPadding);\n const barWidth = getBarWidth(props.barWidth, props.maxBarWidth, bandwidth, props.mode);\n let reqWidth = calcRequiredWidth(barWidth, uniqueX.length, _xAxisInnerPadding);\n const margin1 = (totalWidth - reqWidth) / 2;\n\n let margin2 = Number.POSITIVE_INFINITY;\n // This logic may introduce gaps between histogram bars when the barWidth is restricted.\n // So disable it for histogram mode.\n if (props.mode !== 'histogram') {\n // Calculate the remaining width after accounting for the space required to render x-axis labels\n const step = calculateLongestLabelWidth(uniqueX as string[]) + 20;\n reqWidth = (uniqueX.length - _xAxisInnerPadding) * step;\n margin2 = (totalWidth - reqWidth) / 2;\n }\n\n _domainMargin = MIN_DOMAIN_MARGIN + Math.max(0, Math.min(margin1, margin2));\n }\n } else {\n if (props.mode === 'histogram') {\n // Try center-aligning the bars to eliminate any gaps caused by a restricted barWidth.\n // This only works if the bin centers are consistent across all legend groups; otherwise,\n // the calculated domainMargin may be too small.\n const barWidth = props.maxBarWidth!;\n const reqWidth = calcRequiredWidth(barWidth, uniqueX.length, _xAxisInnerPadding);\n _domainMargin += Math.max(0, (totalWidth - reqWidth) / 2);\n }\n\n // The histogram may appear distorted when bin centers/sizes vary across different legend groups.\n // Currently, we calculate the appropriate bar width using the closest unique x-values to make\n // the bars of the same legend group adjacent. But these x-values can come from different legend groups\n // and result in misleading visuals. Even if we compute bar widths separately within each group,\n // we still lack support for rendering bars with different widths and must use the minimum width,\n // which can cause the same issue.\n // Solution: Instead of estimating the appropriate bar width, render each bar to span the full range\n // of its corresponding bin explicitly.\n _barWidth = getBarWidth(\n props.barWidth,\n props.maxBarWidth,\n calculateAppropriateBarWidth(\n uniqueX as number[] | Date[],\n calcTotalWidth(containerWidth, margins, _domainMargin),\n _xAxisInnerPadding,\n ),\n props.mode,\n );\n _domainMargin += _barWidth / 2;\n _domainMargin += _barWidth / 2;\n }\n\n return {\n ...margins,\n left: margins.left! + _domainMargin,\n right: margins.right! + _domainMargin,\n };\n }\n\n function _getChartTitle(): string {\n const { chartTitle, data } = props;\n return (\n (chartTitle ? `${chartTitle}. ` : '') +\n `Vertical bar chart with ${data?.length || 0} bars` +\n (_isHavingLine ? ' and 1 line' : '') +\n '. '\n );\n }\n\n function _isChartEmpty(): boolean {\n return _points.length === 0 || (_points.every(point => point.y === 0) && !_isHavingLine);\n }\n\n function _getOrderedXAxisLabels() {\n if (_xAxisType !== XAxisTypes.StringAxis) {\n return [];\n }\n\n return sortAxisCategories(_mapCategoryToValues(), props.xAxisCategoryOrder);\n }\n\n function _mapCategoryToValues() {\n const categoryToValues: Record<string, number[]> = {};\n _points.forEach(point => {\n const xValue = point.x as string;\n if (!categoryToValues[xValue]) {\n categoryToValues[xValue] = [];\n }\n categoryToValues[xValue].push(point.y);\n if (point.lineData) {\n categoryToValues[xValue].push(point.lineData.y);\n }\n });\n return categoryToValues;\n }\n\n function updatePosition(newX: number, newY: number) {\n const threshold = 1; // Set a threshold for movement\n const { x, y } = clickPosition;\n // Calculate the distance moved\n const distance = Math.sqrt(Math.pow(newX - x, 2) + Math.pow(newY - y, 2));\n // Update the position only if the distance moved is greater than the threshold\n if (distance > threshold) {\n setClickPosition({ x: newX, y: newY });\n setPopoverOpen(true);\n }\n }\n\n _adjustProps();\n _xAxisLabels = _getOrderedXAxisLabels();\n _yMax = Math.max(d3Max(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMaxValue || 0);\n _yMin = Math.min(d3Min(_points, (point: VerticalBarChartDataPoint) => point.y)!, props.yMinValue || 0);\n const legendBars: JSXElement = _getLegendData(_points);\n const calloutProps = {\n ...(_isHavingLine && {\n YValueHover: hoveredYValues,\n hoverXValue,\n }),\n color,\n legend: calloutLegend,\n XValue: xCalloutValue,\n YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,\n ...props.calloutProps,\n ...getAccessibleDataObject(callOutAccessibilityData),\n clickPosition,\n isPopoverOpen,\n isCalloutForStack: _isHavingLine && (_noLegendHighlighted() || _getHighlightedLegend().length > 1),\n culture: props.culture,\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() != null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n };\n\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n return !_isChartEmpty() ? (\n <CartesianChart\n {...props}\n points={_points}\n chartTitle={_getChartTitle()}\n chartType={ChartTypes.VerticalBarChart}\n xAxisType={_xAxisType!}\n createYAxis={createNumericYAxis}\n calloutProps={calloutProps}\n tickParams={tickParams}\n {...(_isHavingLine && _noLegendHighlighted() && { isCalloutForStack: true })}\n legendBars={legendBars}\n datasetForXAxisDomain={_xAxisLabels}\n barwidth={_barWidth}\n createStringYAxis={createStringYAxis}\n getmargins={_getMargins}\n getMinMaxOfYAxis={findVerticalNumericMinMaxOfY}\n getGraphData={_getGraphData}\n getDomainNRangeValues={_getDomainNRangeValues}\n getAxisData={_getAxisData}\n onChartMouseLeave={_handleChartMouseLeave}\n getDomainMargins={_getDomainMargins}\n {...(_xAxisType! === XAxisTypes.StringAxis && {\n xAxisInnerPadding: _xAxisInnerPadding,\n xAxisOuterPadding: _xAxisOuterPadding,\n })}\n componentRef={cartesianChartRef}\n showRoundOffXTickValues={\n !isScalePaddingDefined(props.xAxisInnerPadding, props.xAxisPadding) && props.mode !== 'histogram'\n }\n /* eslint-disable react/jsx-no-bind */\n\n children={(props: ChildProps) => {\n return (\n <>\n <g>{_bars}</g>\n {_isHavingLine && (\n <g>\n {_createLine(\n props.xScale!,\n props.yScalePrimary!,\n props.containerHeight,\n props.containerWidth,\n props.yScaleSecondary,\n )}\n </g>\n )}\n </>\n );\n }}\n />\n ) : (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n});\nVerticalBarChart.displayName = 'VerticalBarChart';\n"],"names":["React","useVerticalBarChartStyles","max","d3Max","min","d3Min","line","d3Line","scaleLinear","d3ScaleLinear","scaleBand","d3ScaleBand","scaleUtc","d3ScaleUtc","useId","tokens","CartesianChart","Legends","ChartPopover","ChartTypes","getAccessibleDataObject","XAxisTypes","getTypeOfAxis","formatScientificLimitWidth","getBarWidth","getScalePadding","isScalePaddingDefined","calculateAppropriateBarWidth","useRtl","areArraysEqual","calculateLongestLabelWidth","findVerticalNumericMinMaxOfY","createNumericYAxis","domainRangeOfVerticalNumeric","domainRangeOfDateForAreaLineScatterVerticalBarCharts","domainRangeOfXStringAxis","createStringYAxis","calcTotalWidth","calcBandwidth","calcRequiredWidth","sortAxisCategories","useImageExport","CircleVisbility","MIN_DOMAIN_MARGIN","VerticalBarChart","forwardRef","_props","forwardedRef","props","xAxisCategoryOrder","maxBarWidth","_points","_barWidth","_colors","_refArray","margins","_useRtl","_bars","_xAxisLabels","_yMax","_yMin","_isHavingLine","_checkForLine","_xAxisType","_calloutAnchorPoint","_domainMargin","_emptyChartId","_vbcLineId","_vbcPointId","_vbcBarId","_xAxisInnerPadding","_xAxisOuterPadding","cartesianChartRef","legendsRef","_legendsRef","componentRef","hideLegend","color","setColor","useState","dataForHoverCard","setDataForHoverCard","activeLegend","setActiveLegend","undefined","xCalloutValue","setXCalloutValue","yCalloutValue","setYCalloutValue","activeXdataPoint","setActiveXDatapoint","hoveredYValues","setYValueHover","hoverXValue","setHoverXValue","calloutLegend","setCalloutLegend","callOutAccessibilityData","setCalloutAccessibilityData","dataPointCalloutProps","setDataPointCalloutProps","clickPosition","setClickPosition","x","y","isPopoverOpen","setPopoverOpen","selectedLegends","setSelectedLegends","legendProps","prevPropsRef","useRef","useEffect","current","prevProps","height","width","_adjustProps","_getDomainNRangeValues","points","chartType","isRTL","xAxisType","barWidth","tickValues","domainNRangeValue","NumericAxis","DateAxis","_createLine","xScale","yScalePrimary","containerHeight","containerWidth","yScaleSecondary","isStringAxis","StringAxis","colorScale","_createColors","data","lineLegendColor","colorPaletteYellowBackground1","lineLegendText","lineData","forEach","item","index","push","useSecondaryYScale","point","linePath","d","bandwidth","shouldHighlight","_legendHighlighted","_noLegendHighlighted","lineBorderWidth","lineOptions","Number","parseFloat","toString","path","key","id","opacity","fill","strokeLinecap","strokeWidth","className","classes","lineBorder","stroke","dots","map","circleRef","refElement","circle","cx","cy","onMouseOver","event","_lineHover","_onBarHover","onMouseOut","_onBarLeave","r","_getCircleVisibilityAndRadius","radius","colorNeutralBackground1","visibility","onClick","data-is-focusable","ref","e","onFocus","_lineFocus","onBlur","_handleChartMouseLeave","tabIndex","xAxisPoint","legend","some","length","mode","defaultColors","colorPaletteBlueForeground2","colorPaletteCornflowerForeground2","colorPaletteDarkGreenForeground2","colorPaletteNavyForeground2","colorPaletteDarkOrangeForeground2","colors","xAxisInnerPadding","xAxisPadding","xAxisOuterPadding","_getMargins","_margins","_renderContentForBothLineAndBars","YValueHover","_getCalloutContentForLineAndBar","content","culture","XValue","YValue","isCalloutForStack","_renderContentForOnlyBars","xAxisCalloutData","yAxisCalloutData","useSingleColor","_renderCallout","_getCustomizedCallout","onRenderCalloutPerDataPoint","_getGraphData","yScale","xElement","_createNumericBars","_createDateBars","_createStringBars","increment","_p","colorPaletteBlueBackground2","domainValues","i","domain","range","_refCallback","element","legendTitle","selectedPoint","filter","xDataPoint","includes","Date","toLocaleString","mouseEvent","persist","updatePosition","clientX","clientY","toLocaleDateString","_onBarFocus","refArrayIndexNumber","targetRect","target","getBoundingClientRect","left","top","obj","_lineHoverFocus","_refSelected","_getScales","xBarScale","yBarScale","bottom","xMax","xMin","right","nice","sDate","lDate","paddingInner","paddingOuter","_calculateMinBarHeight","yMin","yMax","yReferencePoint","maxHeightFromBaseline","Math","abs","ceil","bars","barHeight","isHeightNegative","minBarHeight","adjustedBarHeight","Fragment","xPoint","yPoint","baselineHeight","g","rect","aria-label","_getAriaLabel","role","onMouseLeave","hideTooltip","rx","roundCorners","_renderBarLabel","barLabel","getTime","transform","opacityChangeOnHover","_onLegendHover","_onLegendLeave","_getLegendData","colorPaletteYellowForeground1","actions","mapLegendToColor","_index","Object","entries","title","hoverAction","onMouseOutAction","lineLegend","isLineLegendInBarChart","unshift","legends","enabledWrapLines","enabledLegendsWrapLines","overflowText","legendsOverflowText","onChange","_onLegendSelectionChange","legendRef","legendsSelected","currentLegend","canSelectMultipleLegends","slice","_getAxisData","yAxisData","yAxisDomainValues","domainValue","yMaxValue","yMinValue","_getHighlightedLegend","xValue","yValue","lineYValue","ariaLabel","barValue","isNegativeBar","customBarLabel","hideLabels","displayLabel","yAxisTickFormat","text","textAnchor","aria-hidden","style","direction","unicodeBidi","_getDomainMargins","mapX","uniqueX","values","totalWidth","reqWidth","margin1","margin2","POSITIVE_INFINITY","step","_getChartTitle","chartTitle","_isChartEmpty","every","_getOrderedXAxisLabels","_mapCategoryToValues","categoryToValues","newX","newY","threshold","distance","sqrt","pow","legendBars","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","tickParams","tickFormat","createYAxis","datasetForXAxisDomain","barwidth","getmargins","getMinMaxOfYAxis","getGraphData","getDomainNRangeValues","getAxisData","onChartMouseLeave","getDomainMargins","showRoundOffXTickValues","children","div","displayName"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/VerticalBarChart/VerticalBarChart.types.ts"],"sourcesContent":["import { RenderFunction } from '../../utilities/index';\nimport {\n CartesianChartProps,\n CartesianChartStyleProps,\n CartesianChartStyles,\n VerticalBarChartDataPoint,\n} from '../../index';\nimport { LineChartLineOptions } from '../../types/index';\n\n/**\n * Vertical Bar Chart properties\n * {@docCategory VerticalBarChart}\n */\nexport interface VerticalBarChartProps extends CartesianChartProps {\n /**\n * Data to render in the chart.\n */\n data?: VerticalBarChartDataPoint[];\n\n /**\n * Define a custom callout renderer for a data point.\n */\n onRenderCalloutPerDataPoint?: RenderFunction<VerticalBarChartDataPoint>;\n\n /**\n * Width of each bar in the chart. When set to `undefined` or `'default'`, the bar width defaults to 16px,\n * which may decrease to prevent overlap. When set to `'auto'`, the bar width is calculated from padding values.\n * @default 16\n */\n barWidth?: number | 'default' | 'auto';\n\n /**\n * Colors from which to select the color of each bar.\n */\n colors?: string[];\n\n /**\n * chart title for the chart\n */\n chartTitle?: string;\n\n /**\n * Legend text for the line datapoint in the chart\n */\n lineLegendText?: string;\n\n /**\n * color for the legend of the line in the chart\n * @default theme.yellow\n */\n\n lineLegendColor?: string;\n\n /**\n * This prop makes sure that all the bars are of same color.\n * it will take the first color from the array of colors in\n * prop `colors` or if `colors` prop is not given then default color is palette.blueLight\n * @default false\n */\n useSingleColor?: boolean;\n\n /**\n * Call to provide customized styling that will layer on top of the variant rules.\n */\n styles?: Partial<VerticalBarChartStyles>;\n\n /**\n * The prop used to define the culture to localized the numbers\n */\n culture?: string;\n\n /**\n * it's padding between bar's or lines in the graph\n */\n xAxisPadding?: number;\n\n /**\n * options for the line drawn\n */\n lineOptions?: LineChartLineOptions;\n\n /**\n * Prop to hide the bar labels\n * @default false\n */\n hideLabels?: boolean;\n\n /**\n * Maximum width of a bar, in pixels.\n * @default 24\n */\n maxBarWidth?: number;\n\n /**\n * Padding between bars as a fraction of the [step](https://d3js.org/d3-scale/band#band_step).\n * Takes a number in the range [0, 1]. Only applicable to string x-axis.\n * @default 2/3\n */\n xAxisInnerPadding?: number;\n\n /**\n * Padding before the first bar and after the last bar as a fraction of\n * the [step](https://d3js.org/d3-scale/band#band_step). Takes a number in the range [0, 1].\n * Only applicable to string x-axis.\n */\n xAxisOuterPadding?: number;\n\n /**\n * @default false\n * The prop used to enable gradient fill color for the chart.\n */\n enableGradient?: boolean;\n\n /**\n * @default false\n * The prop used to enable rounded corners for the chart.\n */\n roundCorners?: boolean;\n\n /**\n * Specifies the mode of the chart.\n * @default 'default'\n */\n mode?: 'default' | 'plotly' | 'histogram';\n}\n\n/**\n * Vertical Bar Chart style properties\n * {@docCategory VerticalBarChart}\n */\nexport interface VerticalBarChartStyleProps extends CartesianChartStyleProps {\n /**\n * color of the datapoint legend\n */\n legendColor?: string;\n}\n\n/**\n * Vertical Bar Chart styles\n * {@docCategory VerticalBarChart}\n */\nexport interface VerticalBarChartStyles extends CartesianChartStyles {\n /**\n * Style for the bar labels\n */\n barLabel: string;\n\n /**\n * Styles for line border\n */\n lineBorder: string;\n}\n"],"names":[],"mappings":"AAyIA;;;CAGC,GACD,WAUC"}
1
+ {"version":3,"sources":["../src/components/VerticalBarChart/VerticalBarChart.types.ts"],"sourcesContent":["import type { RenderFunction } from '../../utilities/index';\nimport type {\n CartesianChartProps,\n CartesianChartStyleProps,\n CartesianChartStyles,\n VerticalBarChartDataPoint,\n} from '../../index';\nimport type { LineChartLineOptions } from '../../types/index';\n\n/**\n * Vertical Bar Chart properties\n * {@docCategory VerticalBarChart}\n */\nexport interface VerticalBarChartProps extends CartesianChartProps {\n /**\n * Data to render in the chart.\n */\n data?: VerticalBarChartDataPoint[];\n\n /**\n * Define a custom callout renderer for a data point.\n */\n onRenderCalloutPerDataPoint?: RenderFunction<VerticalBarChartDataPoint>;\n\n /**\n * Width of each bar in the chart. When set to `undefined` or `'default'`, the bar width defaults to 16px,\n * which may decrease to prevent overlap. When set to `'auto'`, the bar width is calculated from padding values.\n * @default 16\n */\n barWidth?: number | 'default' | 'auto';\n\n /**\n * Colors from which to select the color of each bar.\n */\n colors?: string[];\n\n /**\n * chart title for the chart\n */\n chartTitle?: string;\n\n /**\n * Legend text for the line datapoint in the chart\n */\n lineLegendText?: string;\n\n /**\n * color for the legend of the line in the chart\n * @default theme.yellow\n */\n\n lineLegendColor?: string;\n\n /**\n * This prop makes sure that all the bars are of same color.\n * it will take the first color from the array of colors in\n * prop `colors` or if `colors` prop is not given then default color is palette.blueLight\n * @default false\n */\n useSingleColor?: boolean;\n\n /**\n * Call to provide customized styling that will layer on top of the variant rules.\n */\n styles?: Partial<VerticalBarChartStyles>;\n\n /**\n * The prop used to define the culture to localized the numbers\n */\n culture?: string;\n\n /**\n * it's padding between bar's or lines in the graph\n */\n xAxisPadding?: number;\n\n /**\n * options for the line drawn\n */\n lineOptions?: LineChartLineOptions;\n\n /**\n * Prop to hide the bar labels\n * @default false\n */\n hideLabels?: boolean;\n\n /**\n * Maximum width of a bar, in pixels.\n * @default 24\n */\n maxBarWidth?: number;\n\n /**\n * Padding between bars as a fraction of the [step](https://d3js.org/d3-scale/band#band_step).\n * Takes a number in the range [0, 1]. Only applicable to string x-axis.\n * @default 2/3\n */\n xAxisInnerPadding?: number;\n\n /**\n * Padding before the first bar and after the last bar as a fraction of\n * the [step](https://d3js.org/d3-scale/band#band_step). Takes a number in the range [0, 1].\n * Only applicable to string x-axis.\n */\n xAxisOuterPadding?: number;\n\n /**\n * @default false\n * The prop used to enable gradient fill color for the chart.\n */\n enableGradient?: boolean;\n\n /**\n * @default false\n * The prop used to enable rounded corners for the chart.\n */\n roundCorners?: boolean;\n\n /**\n * Specifies the mode of the chart.\n * @default 'default'\n */\n mode?: 'default' | 'plotly' | 'histogram';\n}\n\n/**\n * Vertical Bar Chart style properties\n * {@docCategory VerticalBarChart}\n */\nexport interface VerticalBarChartStyleProps extends CartesianChartStyleProps {\n /**\n * color of the datapoint legend\n */\n legendColor?: string;\n}\n\n/**\n * Vertical Bar Chart styles\n * {@docCategory VerticalBarChart}\n */\nexport interface VerticalBarChartStyles extends CartesianChartStyles {\n /**\n * Style for the bar labels\n */\n barLabel: string;\n\n /**\n * Styles for line border\n */\n lineBorder: string;\n}\n"],"names":[],"mappings":"AAyIA;;;CAGC,GACD,WAUC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/VerticalBarChart/useVerticalBarChartStyles.styles.ts"],"sourcesContent":["'use client';\n\nimport { GriffelStyle, makeStyles, mergeClasses } from '@griffel/react';\nimport { VerticalBarChartProps, VerticalBarChartStyles } from '../../index';\nimport { SlotClassNames } from '@fluentui/react-utilities/src/index';\nimport { tokens } from '@fluentui/react-theme';\nimport { HighContrastSelector } from '../../utilities/utilities';\nimport { getBarLabelStyle, getTooltipStyle } from '../../utilities/index';\n\nexport const verticalbarchartClassNames: SlotClassNames<VerticalBarChartStyles> = {\n opacityChangeOnHover: 'fui-vbc__opacityChangeOnHover',\n tooltip: 'fui-vbc__tooltip',\n barLabel: 'fui-vbc__barLabel',\n lineBorder: 'fui-vbc_lineBorder',\n root: '',\n xAxis: '',\n yAxis: '',\n legendContainer: '',\n hover: '',\n descriptionMessage: '',\n axisTitle: '',\n chartTitle: '',\n shapeStyles: '',\n chartWrapper: '',\n svgTooltip: '',\n chart: '',\n axisAnnotation: '',\n plotContainer: '',\n annotationLayer: '',\n};\nconst useStyles = makeStyles({\n opacityChangeOnHover: {},\n tooltip: getTooltipStyle() as GriffelStyle,\n barLabel: getBarLabelStyle() as GriffelStyle,\n lineBorder: {\n stroke: tokens.colorNeutralBackground1,\n [HighContrastSelector]: {\n stroke: 'Canvas',\n },\n },\n});\n\n/**\n * Apply styling to the Carousel slots based on the state\n */\nexport const useVerticalBarChartStyles = (props: VerticalBarChartProps): VerticalBarChartStyles => {\n const baseStyles = useStyles();\n\n return {\n opacityChangeOnHover: mergeClasses(\n verticalbarchartClassNames.opacityChangeOnHover,\n baseStyles.opacityChangeOnHover /*props.styles?.opacityChangeOnHover*/,\n ),\n tooltip: mergeClasses(verticalbarchartClassNames.tooltip, baseStyles.tooltip /*props.styles?.tooltip*/),\n barLabel: mergeClasses(verticalbarchartClassNames.barLabel, baseStyles.barLabel /*props.styles?.barLabel*/),\n lineBorder: mergeClasses(verticalbarchartClassNames.lineBorder, baseStyles.lineBorder /*props.styles?.lineBorder*/),\n };\n};\n"],"names":["makeStyles","mergeClasses","tokens","HighContrastSelector","getBarLabelStyle","getTooltipStyle","verticalbarchartClassNames","opacityChangeOnHover","tooltip","barLabel","lineBorder","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","shapeStyles","chartWrapper","svgTooltip","chart","axisAnnotation","plotContainer","annotationLayer","useStyles","stroke","colorNeutralBackground1","useVerticalBarChartStyles","props","baseStyles"],"mappings":"AAAA;AAEA,SAAuBA,UAAU,EAAEC,YAAY,QAAQ,iBAAiB;AAGxE,SAASC,MAAM,QAAQ,wBAAwB;AAC/C,SAASC,oBAAoB,QAAQ,4BAA4B;AACjE,SAASC,gBAAgB,EAAEC,eAAe,QAAQ,wBAAwB;AAE1E,OAAO,MAAMC,6BAAqE;IAChFC,sBAAsB;IACtBC,SAAS;IACTC,UAAU;IACVC,YAAY;IACZC,MAAM;IACNC,OAAO;IACPC,OAAO;IACPC,iBAAiB;IACjBC,OAAO;IACPC,oBAAoB;IACpBC,WAAW;IACXC,YAAY;IACZC,aAAa;IACbC,cAAc;IACdC,YAAY;IACZC,OAAO;IACPC,gBAAgB;IAChBC,eAAe;IACfC,iBAAiB;AACnB,EAAE;AACF,MAAMC,YAAY1B,WAAW;IAC3BO,sBAAsB,CAAC;IACvBC,SAASH;IACTI,UAAUL;IACVM,YAAY;QACViB,QAAQzB,OAAO0B,uBAAuB;QACtC,CAACzB,qBAAqB,EAAE;YACtBwB,QAAQ;QACV;IACF;AACF;AAEA;;CAEC,GACD,OAAO,MAAME,4BAA4B,CAACC;IACxC,MAAMC,aAAaL;IAEnB,OAAO;QACLnB,sBAAsBN,aACpBK,2BAA2BC,oBAAoB,EAC/CwB,WAAWxB,oBAAoB,CAAC,oCAAoC;QAEtEC,SAASP,aAAaK,2BAA2BE,OAAO,EAAEuB,WAAWvB,OAAO,CAAC,uBAAuB;QACpGC,UAAUR,aAAaK,2BAA2BG,QAAQ,EAAEsB,WAAWtB,QAAQ,CAAC,wBAAwB;QACxGC,YAAYT,aAAaK,2BAA2BI,UAAU,EAAEqB,WAAWrB,UAAU,CAAC,0BAA0B;IAClH;AACF,EAAE"}
1
+ {"version":3,"sources":["../src/components/VerticalBarChart/useVerticalBarChartStyles.styles.ts"],"sourcesContent":["'use client';\n\nimport type { GriffelStyle } from '@griffel/react';\nimport { makeStyles, mergeClasses } from '@griffel/react';\nimport type { VerticalBarChartProps, VerticalBarChartStyles } from '../../index';\nimport type { SlotClassNames } from '@fluentui/react-utilities/src/index';\nimport { tokens } from '@fluentui/react-theme';\nimport { HighContrastSelector } from '../../utilities/utilities';\nimport { getBarLabelStyle, getTooltipStyle } from '../../utilities/index';\n\nexport const verticalbarchartClassNames: SlotClassNames<VerticalBarChartStyles> = {\n opacityChangeOnHover: 'fui-vbc__opacityChangeOnHover',\n tooltip: 'fui-vbc__tooltip',\n barLabel: 'fui-vbc__barLabel',\n lineBorder: 'fui-vbc_lineBorder',\n root: '',\n xAxis: '',\n yAxis: '',\n legendContainer: '',\n hover: '',\n descriptionMessage: '',\n axisTitle: '',\n chartTitle: '',\n shapeStyles: '',\n chartWrapper: '',\n svgTooltip: '',\n chart: '',\n axisAnnotation: '',\n plotContainer: '',\n annotationLayer: '',\n};\nconst useStyles = makeStyles({\n opacityChangeOnHover: {},\n tooltip: getTooltipStyle() as GriffelStyle,\n barLabel: getBarLabelStyle() as GriffelStyle,\n lineBorder: {\n stroke: tokens.colorNeutralBackground1,\n [HighContrastSelector]: {\n stroke: 'Canvas',\n },\n },\n});\n\n/**\n * Apply styling to the Carousel slots based on the state\n */\nexport const useVerticalBarChartStyles = (props: VerticalBarChartProps): VerticalBarChartStyles => {\n const baseStyles = useStyles();\n\n return {\n opacityChangeOnHover: mergeClasses(\n verticalbarchartClassNames.opacityChangeOnHover,\n baseStyles.opacityChangeOnHover /*props.styles?.opacityChangeOnHover*/,\n ),\n tooltip: mergeClasses(verticalbarchartClassNames.tooltip, baseStyles.tooltip /*props.styles?.tooltip*/),\n barLabel: mergeClasses(verticalbarchartClassNames.barLabel, baseStyles.barLabel /*props.styles?.barLabel*/),\n lineBorder: mergeClasses(verticalbarchartClassNames.lineBorder, baseStyles.lineBorder /*props.styles?.lineBorder*/),\n };\n};\n"],"names":["makeStyles","mergeClasses","tokens","HighContrastSelector","getBarLabelStyle","getTooltipStyle","verticalbarchartClassNames","opacityChangeOnHover","tooltip","barLabel","lineBorder","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","shapeStyles","chartWrapper","svgTooltip","chart","axisAnnotation","plotContainer","annotationLayer","useStyles","stroke","colorNeutralBackground1","useVerticalBarChartStyles","props","baseStyles"],"mappings":"AAAA;AAGA,SAASA,UAAU,EAAEC,YAAY,QAAQ,iBAAiB;AAG1D,SAASC,MAAM,QAAQ,wBAAwB;AAC/C,SAASC,oBAAoB,QAAQ,4BAA4B;AACjE,SAASC,gBAAgB,EAAEC,eAAe,QAAQ,wBAAwB;AAE1E,OAAO,MAAMC,6BAAqE;IAChFC,sBAAsB;IACtBC,SAAS;IACTC,UAAU;IACVC,YAAY;IACZC,MAAM;IACNC,OAAO;IACPC,OAAO;IACPC,iBAAiB;IACjBC,OAAO;IACPC,oBAAoB;IACpBC,WAAW;IACXC,YAAY;IACZC,aAAa;IACbC,cAAc;IACdC,YAAY;IACZC,OAAO;IACPC,gBAAgB;IAChBC,eAAe;IACfC,iBAAiB;AACnB,EAAE;AACF,MAAMC,YAAY1B,WAAW;IAC3BO,sBAAsB,CAAC;IACvBC,SAASH;IACTI,UAAUL;IACVM,YAAY;QACViB,QAAQzB,OAAO0B,uBAAuB;QACtC,CAACzB,qBAAqB,EAAE;YACtBwB,QAAQ;QACV;IACF;AACF;AAEA;;CAEC,GACD,OAAO,MAAME,4BAA4B,CAACC;IACxC,MAAMC,aAAaL;IAEnB,OAAO;QACLnB,sBAAsBN,aACpBK,2BAA2BC,oBAAoB,EAC/CwB,WAAWxB,oBAAoB,CAAC,oCAAoC;QAEtEC,SAASP,aAAaK,2BAA2BE,OAAO,EAAEuB,WAAWvB,OAAO,CAAC,uBAAuB;QACpGC,UAAUR,aAAaK,2BAA2BG,QAAQ,EAAEsB,WAAWtB,QAAQ,CAAC,wBAAwB;QACxGC,YAAYT,aAAaK,2BAA2BI,UAAU,EAAEqB,WAAWrB,UAAU,CAAC,0BAA0B;IAClH;AACF,EAAE"}
@@ -1006,16 +1006,16 @@ export const VerticalStackedBarChart = /*#__PURE__*/ React.forwardRef((_props, f
1006
1006
  _dataset = _createDataSetLayer();
1007
1007
  const legendBars = _getLegendData(_points, _createLegendsForLine(props.data));
1008
1008
  const calloutProps = {
1009
- color: color,
1009
+ color,
1010
1010
  legend: calloutLegend,
1011
1011
  XValue: xCalloutValue,
1012
1012
  YValue: yCalloutValue ? yCalloutValue : dataForHoverCard,
1013
- YValueHover: YValueHover,
1014
- hoverXValue: hoverXValue,
1013
+ YValueHover,
1014
+ hoverXValue,
1015
1015
  ...props.calloutProps,
1016
1016
  ...getAccessibleDataObject(callOutAccessibilityData),
1017
- clickPosition: clickPosition,
1018
- isPopoverOpen: isPopoverOpen,
1017
+ clickPosition,
1018
+ isPopoverOpen,
1019
1019
  isCalloutForStack: shouldFocusWholeStack,
1020
1020
  isCartesian: true,
1021
1021
  customCallout: {