@fluentui/react-charts 9.3.7 → 9.3.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (143) hide show
  1. package/CHANGELOG.md +27 -2
  2. package/dist/index.d.ts +55 -7
  3. package/lib/components/AreaChart/AreaChart.js +1 -28
  4. package/lib/components/AreaChart/AreaChart.js.map +1 -1
  5. package/lib/components/AreaChart/useAreaChartStyles.styles.js +1 -2
  6. package/lib/components/AreaChart/useAreaChartStyles.styles.js.map +1 -1
  7. package/lib/components/ChartTable/ChartTable.js +6 -1
  8. package/lib/components/ChartTable/ChartTable.js.map +1 -1
  9. package/lib/components/CommonComponents/Annotations/ChartAnnotationLayer.js +107 -67
  10. package/lib/components/CommonComponents/Annotations/ChartAnnotationLayer.js.map +1 -1
  11. package/lib/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.js +7 -1
  12. package/lib/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.js.map +1 -1
  13. package/lib/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.raw.js +7 -1
  14. package/lib/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.raw.js.map +1 -1
  15. package/lib/components/CommonComponents/CartesianChart.js +50 -32
  16. package/lib/components/CommonComponents/CartesianChart.js.map +1 -1
  17. package/lib/components/CommonComponents/CartesianChart.types.js.map +1 -1
  18. package/lib/components/CommonComponents/useCartesianChartStyles.styles.js +5 -5
  19. package/lib/components/CommonComponents/useCartesianChartStyles.styles.js.map +1 -1
  20. package/lib/components/CommonComponents/useCartesianChartStyles.styles.raw.js +4 -3
  21. package/lib/components/CommonComponents/useCartesianChartStyles.styles.raw.js.map +1 -1
  22. package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js +261 -187
  23. package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
  24. package/lib/components/DonutChart/DonutChart.js +6 -3
  25. package/lib/components/DonutChart/DonutChart.js.map +1 -1
  26. package/lib/components/FunnelChart/FunnelChart.js +6 -3
  27. package/lib/components/FunnelChart/FunnelChart.js.map +1 -1
  28. package/lib/components/GanttChart/GanttChart.js +1 -1
  29. package/lib/components/GanttChart/GanttChart.js.map +1 -1
  30. package/lib/components/GaugeChart/GaugeChart.js +6 -3
  31. package/lib/components/GaugeChart/GaugeChart.js.map +1 -1
  32. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +17 -17
  33. package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  34. package/lib/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.js +1 -2
  35. package/lib/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.js.map +1 -1
  36. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +2 -4
  37. package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
  38. package/lib/components/Legends/Legends.js +3 -4
  39. package/lib/components/Legends/Legends.js.map +1 -1
  40. package/lib/components/LineChart/LineChart.js +66 -64
  41. package/lib/components/LineChart/LineChart.js.map +1 -1
  42. package/lib/components/LineChart/useLineChartStyles.styles.js +1 -2
  43. package/lib/components/LineChart/useLineChartStyles.styles.js.map +1 -1
  44. package/lib/components/SankeyChart/SankeyChart.js +1 -1
  45. package/lib/components/SankeyChart/SankeyChart.js.map +1 -1
  46. package/lib/components/SankeyChart/useSankeyChartStyles.styles.js +1 -2
  47. package/lib/components/SankeyChart/useSankeyChartStyles.styles.js.map +1 -1
  48. package/lib/components/ScatterChart/ScatterChart.js +18 -26
  49. package/lib/components/ScatterChart/ScatterChart.js.map +1 -1
  50. package/lib/components/ScatterChart/ScatterChart.types.js.map +1 -1
  51. package/lib/components/ScatterChart/useScatterChartStyles.styles.js +1 -2
  52. package/lib/components/ScatterChart/useScatterChartStyles.styles.js.map +1 -1
  53. package/lib/components/VerticalBarChart/VerticalBarChart.js +13 -78
  54. package/lib/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  55. package/lib/components/VerticalBarChart/useVerticalBarChartStyles.styles.js +1 -2
  56. package/lib/components/VerticalBarChart/useVerticalBarChartStyles.styles.js.map +1 -1
  57. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js +21 -32
  58. package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  59. package/lib/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js +1 -2
  60. package/lib/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js.map +1 -1
  61. package/lib/types/ChartAnnotation.js.map +1 -1
  62. package/lib/types/DataPoint.js.map +1 -1
  63. package/lib/utilities/Common.styles.js +0 -1
  64. package/lib/utilities/Common.styles.js.map +1 -1
  65. package/lib/utilities/Common.styles.raw.js +0 -1
  66. package/lib/utilities/Common.styles.raw.js.map +1 -1
  67. package/lib/utilities/image-export-utils.js +4 -4
  68. package/lib/utilities/image-export-utils.js.map +1 -1
  69. package/lib/utilities/utilities.js +220 -78
  70. package/lib/utilities/utilities.js.map +1 -1
  71. package/lib-commonjs/components/AreaChart/AreaChart.js +0 -26
  72. package/lib-commonjs/components/AreaChart/AreaChart.js.map +1 -1
  73. package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.js +0 -2
  74. package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.js.map +1 -1
  75. package/lib-commonjs/components/ChartTable/ChartTable.js +6 -1
  76. package/lib-commonjs/components/ChartTable/ChartTable.js.map +1 -1
  77. package/lib-commonjs/components/CommonComponents/Annotations/ChartAnnotationLayer.js +107 -67
  78. package/lib-commonjs/components/CommonComponents/Annotations/ChartAnnotationLayer.js.map +1 -1
  79. package/lib-commonjs/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.js +7 -1
  80. package/lib-commonjs/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.js.map +1 -1
  81. package/lib-commonjs/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.raw.js +7 -1
  82. package/lib-commonjs/components/CommonComponents/Annotations/useChartAnnotationLayer.styles.raw.js.map +1 -1
  83. package/lib-commonjs/components/CommonComponents/CartesianChart.js +49 -31
  84. package/lib-commonjs/components/CommonComponents/CartesianChart.js.map +1 -1
  85. package/lib-commonjs/components/CommonComponents/CartesianChart.types.js.map +1 -1
  86. package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.js +3 -4
  87. package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.js.map +1 -1
  88. package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.raw.js +3 -2
  89. package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.raw.js.map +1 -1
  90. package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js +261 -186
  91. package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
  92. package/lib-commonjs/components/DonutChart/DonutChart.js +5 -2
  93. package/lib-commonjs/components/DonutChart/DonutChart.js.map +1 -1
  94. package/lib-commonjs/components/FunnelChart/FunnelChart.js +5 -2
  95. package/lib-commonjs/components/FunnelChart/FunnelChart.js.map +1 -1
  96. package/lib-commonjs/components/GanttChart/GanttChart.js +1 -1
  97. package/lib-commonjs/components/GanttChart/GanttChart.js.map +1 -1
  98. package/lib-commonjs/components/GaugeChart/GaugeChart.js +5 -2
  99. package/lib-commonjs/components/GaugeChart/GaugeChart.js.map +1 -1
  100. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +15 -15
  101. package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
  102. package/lib-commonjs/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.js +0 -2
  103. package/lib-commonjs/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.js.map +1 -1
  104. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +2 -4
  105. package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
  106. package/lib-commonjs/components/Legends/Legends.js +3 -4
  107. package/lib-commonjs/components/Legends/Legends.js.map +1 -1
  108. package/lib-commonjs/components/LineChart/LineChart.js +65 -63
  109. package/lib-commonjs/components/LineChart/LineChart.js.map +1 -1
  110. package/lib-commonjs/components/LineChart/useLineChartStyles.styles.js +0 -2
  111. package/lib-commonjs/components/LineChart/useLineChartStyles.styles.js.map +1 -1
  112. package/lib-commonjs/components/SankeyChart/SankeyChart.js +1 -1
  113. package/lib-commonjs/components/SankeyChart/SankeyChart.js.map +1 -1
  114. package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.js +0 -2
  115. package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.js.map +1 -1
  116. package/lib-commonjs/components/ScatterChart/ScatterChart.js +17 -25
  117. package/lib-commonjs/components/ScatterChart/ScatterChart.js.map +1 -1
  118. package/lib-commonjs/components/ScatterChart/ScatterChart.types.js.map +1 -1
  119. package/lib-commonjs/components/ScatterChart/useScatterChartStyles.styles.js +0 -2
  120. package/lib-commonjs/components/ScatterChart/useScatterChartStyles.styles.js.map +1 -1
  121. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js +12 -77
  122. package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
  123. package/lib-commonjs/components/VerticalBarChart/useVerticalBarChartStyles.styles.js +0 -2
  124. package/lib-commonjs/components/VerticalBarChart/useVerticalBarChartStyles.styles.js.map +1 -1
  125. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js +20 -31
  126. package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
  127. package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js +0 -2
  128. package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js.map +1 -1
  129. package/lib-commonjs/types/ChartAnnotation.js.map +1 -1
  130. package/lib-commonjs/types/DataPoint.js.map +1 -1
  131. package/lib-commonjs/utilities/Common.styles.js +0 -1
  132. package/lib-commonjs/utilities/Common.styles.js.map +1 -1
  133. package/lib-commonjs/utilities/Common.styles.raw.js +0 -1
  134. package/lib-commonjs/utilities/Common.styles.raw.js.map +1 -1
  135. package/lib-commonjs/utilities/image-export-utils.js +3 -3
  136. package/lib-commonjs/utilities/image-export-utils.js.map +1 -1
  137. package/lib-commonjs/utilities/utilities.js +232 -81
  138. package/lib-commonjs/utilities/utilities.js.map +1 -1
  139. package/package.json +9 -9
  140. package/lib/components/DeclarativeChart/imageExporter.js +0 -223
  141. package/lib/components/DeclarativeChart/imageExporter.js.map +0 -1
  142. package/lib-commonjs/components/DeclarativeChart/imageExporter.js +0 -233
  143. package/lib-commonjs/components/DeclarativeChart/imageExporter.js.map +0 -1
@@ -11,7 +11,6 @@ Object.defineProperty(exports, "AreaChart", {
11
11
  });
12
12
  const _interop_require_wildcard = require("@swc/helpers/_/_interop_require_wildcard");
13
13
  const _react = /*#__PURE__*/ _interop_require_wildcard._(require("react"));
14
- const _useAreaChartStylesstyles = require("./useAreaChartStyles.styles");
15
14
  const _d3array = require("d3-array");
16
15
  const _d3selection = require("d3-selection");
17
16
  const _reacttheme = require("@fluentui/react-theme");
@@ -35,7 +34,6 @@ const AreaChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
35
34
  const _verticalLineId = (0, _reactutilities.useId)('verticalLine_');
36
35
  const _circleId = (0, _reactutilities.useId)('circle');
37
36
  const _rectId = (0, _reactutilities.useId)('rectangle');
38
- const _tooltipId = (0, _reactutilities.useId)('AreaChartTooltipID');
39
37
  //enableComputationOptimization is used for optimized code to group data points by x value
40
38
  //from O(n^2) to O(n) using a map.
41
39
  const _enableComputationOptimization = true;
@@ -90,7 +88,6 @@ const AreaChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
90
88
  }, [
91
89
  props
92
90
  ]);
93
- const classes = (0, _useAreaChartStylesstyles.useAreaChartStyles)(props);
94
91
  function _getMinMaxOfYAxis(points, yAxisType, useSecondaryYScale) {
95
92
  return (0, _index1.findNumericMinMaxOfY)(points, yAxisType, useSecondaryYScale);
96
93
  }
@@ -671,29 +668,6 @@ const AreaChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
671
668
  visibility: displayOfLine,
672
669
  ...(0, _index1.getSecureProps)(pointLineOptions)
673
670
  }));
674
- // Removing un wanted tooltip div from DOM, when prop not provided.
675
- if (!props.showXAxisLablesTooltip) {
676
- try {
677
- // eslint-disable-next-line @nx/workspace-no-restricted-globals
678
- document.getElementById(_tooltipId) && document.getElementById(_tooltipId).remove();
679
- // eslint-disable-next-line no-empty
680
- } catch (e) {}
681
- }
682
- // Used to display tooltip at x axis labels.
683
- if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {
684
- const xAxisElement = (0, _d3selection.select)(xElement).call(xScale);
685
- try {
686
- // eslint-disable-next-line @nx/workspace-no-restricted-globals
687
- document.getElementById(_tooltipId) && document.getElementById(_tooltipId).remove();
688
- // eslint-disable-next-line no-empty
689
- } catch (e) {}
690
- const tooltipProps = {
691
- tooltipCls: classes.tooltip,
692
- id: _tooltipId,
693
- axis: xAxisElement
694
- };
695
- xAxisElement && (0, _index1.tooltipOfAxislabels)(tooltipProps);
696
- }
697
671
  return graph;
698
672
  }
699
673
  function _getOnClickHandler(points, index, pointIndex) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/AreaChart/AreaChart.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { useAreaChartStyles } from './useAreaChartStyles.styles';\nimport { max as d3Max, bisector } from 'd3-array';\nimport { pointer } from 'd3-selection';\nimport { select as d3Select } from 'd3-selection';\nimport { tokens } from '@fluentui/react-theme';\nimport { area as d3Area, stack as d3Stack, curveMonotoneX as d3CurveBasis, line as d3Line } from 'd3-shape';\nimport {\n AccessibilityProps,\n CartesianChart,\n CustomizedCalloutData,\n AreaChartProps,\n LineChartDataPoint,\n LineChartPoints,\n ChildProps,\n Margins,\n YValueHover,\n ChartPopoverProps,\n} from '../../index';\nimport {\n calloutData,\n getXAxisType,\n ChartTypes,\n XAxisTypes,\n getTypeOfAxis,\n tooltipOfAxislabels,\n getNextColor,\n getColorFromToken,\n getSecureProps,\n areArraysEqual,\n getCurveFactory,\n findNumericMinMaxOfY,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfNumericForAreaLineScatterCharts,\n domainRangeOfDateForAreaLineScatterVerticalBarCharts,\n createStringYAxis,\n YAxisType,\n findCalloutPoints,\n} from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport type { JSXElement } from '@fluentui/react-utilities';\nimport { Legend, Legends } from '../Legends/index';\nimport { ScaleLinear } from 'd3-scale';\nimport { formatDateToLocaleString } from '@fluentui/chart-utilities';\nimport { useImageExport } from '../../utilities/hooks';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst bisect = bisector((d: any) => d.x).left;\n\nenum InterceptVisibility {\n show = 'visibility',\n hide = 'hidden',\n}\n\nexport interface AreaChartAreaPoint {\n xVal: string | number;\n values: AreaChartDataSetPoint;\n}\nexport interface AreaChartDataSetPoint {\n [key: string]: number | string | number[];\n}\nexport interface DPointType {\n values: { 0: number; 1: number; data: {} };\n xVal: number | Date;\n}\nexport interface MapXToDataSet {\n [key: string]: LineChartDataPoint[];\n [key: number]: LineChartDataPoint[];\n}\n\ninterface ILineChartDataPointWithLegend extends LineChartDataPoint {\n /**\n * Legend text for the datapoint in the chart\n */\n legend?: string;\n}\n\ntype ILineChartPointsWithoutData = Omit<LineChartPoints, 'data'>;\ninterface LineChartPointsWithLegend extends ILineChartPointsWithoutData {\n data: ILineChartDataPointWithLegend[];\n}\n\n//by default d3-shape 3.2.0 limits the< path> data point precision to 3 digits(d3/d3-path#10)\n\nexport const AreaChart: React.FunctionComponent<AreaChartProps> = React.forwardRef<HTMLDivElement, AreaChartProps>(\n (props, forwardedRef) => {\n const _uniqueIdForGraph: string = useId('areaChart_');\n const _verticalLineId: string = useId('verticalLine_');\n const _circleId: string = useId('circle');\n const _rectId: string = useId('rectangle');\n const _tooltipId: string = useId('AreaChartTooltipID');\n //enableComputationOptimization is used for optimized code to group data points by x value\n //from O(n^2) to O(n) using a map.\n const _enableComputationOptimization: boolean = true;\n const _firstRenderOptimization: boolean = true;\n const _emptyChartId: string = useId('_AreaChart_empty');\n let _containsSecondaryYAxis = false;\n let _hasMissingXValues = _containsMissingXValues();\n let _hasDuplicateXValues = _xCoordinateContainsMultipleY();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _calloutPoints: any;\n let _createSet: (data: LineChartPoints[]) => {\n colors: string[];\n opacity: number[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n calloutPoints: any;\n };\n let _colors: string[];\n let _opacity: number[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _data: any;\n let _chart: JSXElement[];\n let _margins: Margins;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _xAxisRectScale: any;\n // determines if the given area chart has multiple stacked bar charts\n let _isMultiStackChart: boolean;\n const { cartesianChartRef, legendsRef: _legendsRef } = useImageExport(props.componentRef, props.hideLegend);\n\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [hoverXValue, setHoverXValue] = React.useState<string | number | undefined | null>('');\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const [YValueHover, setYValueHover] = React.useState<YValueHover[]>([]);\n const [lineXValue, setLineXValue] = React.useState<number>(0);\n const [displayOfLine, setDisplayOfLine] = React.useState<InterceptVisibility>(InterceptVisibility.hide);\n const [isCircleClicked, setIsCircleClicked] = React.useState<boolean>(false);\n const [nearestCircleToHighlight, setNearestCircleToHighlight] = React.useState<number | string | Date | null>(null);\n const [activePoint, setActivePoint] = React.useState<string>('');\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<CustomizedCalloutData>();\n const [stackCalloutProps, setStackCalloutProps] = React.useState<CustomizedCalloutData>();\n const [xAxisCalloutAccessibilityData, setXAxisCalloutAccessibilityData] = React.useState<AccessibilityProps>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const prevPropsRef = React.useRef<AreaChartProps | 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 }\n prevPropsRef.current = props;\n }, [props]);\n\n const classes = useAreaChartStyles(props);\n\n function _getMinMaxOfYAxis(points: LineChartPoints[], yAxisType: YAxisType, useSecondaryYScale: boolean) {\n return findNumericMinMaxOfY(points, yAxisType, useSecondaryYScale);\n }\n\n function _getDomainNRangeValues(\n points: LineChartPoints[],\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 = domainRangeOfNumericForAreaLineScatterCharts(points, margins, width, isRTL);\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 = { dStartValue: 0, dEndValue: 0, rStartValue: 0, rEndValue: 0 };\n }\n return domainNRangeValue;\n }\n\n function _getMargins(margins: Margins) {\n _margins = margins;\n }\n\n function _onRectMouseMove(mouseEvent: React.MouseEvent<SVGRectElement | SVGPathElement | SVGCircleElement>) {\n mouseEvent.persist();\n const { data } = props;\n const { lineChartData } = data;\n _updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n // This will get the value of the X when mouse is on the chart\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n const xOffset = _xAxisRectScale.invert(pointer(mouseEvent)[0], document.getElementById(_rectId)!);\n const i = bisect(lineChartData![0].data, xOffset);\n const d0 = lineChartData![0].data[i - 1] as LineChartDataPoint;\n const d1 = lineChartData![0].data[i] as LineChartDataPoint;\n let pointToHighlight: string | Date | number | null = null;\n let index: null | number = null;\n const axisType =\n lineChartData![0].data.length > 0 ? (getTypeOfAxis(lineChartData![0].data[0].x, true) as XAxisTypes) : null;\n if (d0 === undefined && d1 !== undefined) {\n pointToHighlight = d1.x;\n index = i;\n } else if (d0 !== undefined && d1 === undefined) {\n pointToHighlight = d0.x;\n index = i - 1;\n } else {\n let x0;\n let point0;\n let point1;\n switch (axisType) {\n case XAxisTypes.DateAxis:\n x0 = new Date(xOffset).getTime();\n point0 = (d0.x as Date).getTime();\n point1 = (d1.x as Date).getTime();\n pointToHighlight = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? d1.x : d0.x;\n index = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? i : i - 1;\n break;\n case XAxisTypes.NumericAxis:\n x0 = xOffset as number;\n point0 = d0.x as number;\n point1 = d1.x as number;\n pointToHighlight = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? d1.x : d0.x;\n index = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? i : i - 1;\n break;\n default:\n break;\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { xAxisCalloutData, xAxisCalloutAccessibilityData } = lineChartData![0].data[index as number];\n const formattedDate =\n pointToHighlight instanceof Date\n ? formatDateToLocaleString(pointToHighlight, props.culture, props.useUTC as boolean)\n : pointToHighlight;\n const found = findCalloutPoints(_calloutPoints, pointToHighlight);\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const _nearestCircleToHighlight =\n axisType === XAxisTypes.DateAxis ? (pointToHighlight as Date).getTime() : pointToHighlight;\n // if no points need to be called out then don't show vertical line and callout card\n if (found) {\n const filteredValues = _getFilteredLegendValues(found.values);\n setNearestCircleToHighlight(_nearestCircleToHighlight);\n setLineXValue(_xAxisRectScale(pointToHighlight));\n setDisplayOfLine(InterceptVisibility.show);\n setIsCircleClicked(false);\n setStackCalloutProps({ ...found, values: filteredValues });\n setYValueHover(filteredValues);\n setDataPointCalloutProps({ ...found, values: filteredValues });\n setHoverXValue(xAxisCalloutData ? xAxisCalloutData : formattedDate);\n setXAxisCalloutAccessibilityData(xAxisCalloutAccessibilityData);\n setActivePoint('');\n } else {\n setPopoverOpen(false);\n setNearestCircleToHighlight(nearestCircleToHighlight);\n setDisplayOfLine(InterceptVisibility.hide);\n setIsCircleClicked(false);\n }\n }\n /**\n * just cleaning up the state which we have set in the mouse move event\n */\n function _onRectMouseOut() {\n /**/\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 function _handleChartMouseLeave() {\n setPopoverOpen(false);\n setNearestCircleToHighlight(null);\n setLineXValue(0);\n setDisplayOfLine(InterceptVisibility.hide);\n setIsCircleClicked(false);\n setStackCalloutProps(undefined);\n setDataPointCalloutProps(undefined);\n setHoverXValue(undefined);\n setYValueHover([]);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _getDataPoints(keys: string[], dataSet: any) {\n const renderPoints: Array<AreaChartDataSetPoint[]> = [];\n let maxOfYVal = 0;\n\n if (_shouldFillToZeroY()) {\n keys.forEach((key, index) => {\n const currentLayer: AreaChartDataSetPoint[] = [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n dataSet.forEach((d: any) => {\n currentLayer.push({\n values: [0, d[key]], // Start from zero for \"tozeroy\" mode\n xVal: d.xVal,\n });\n if (d[key] > maxOfYVal) {\n maxOfYVal = d[key];\n }\n });\n renderPoints.push(currentLayer);\n });\n } else {\n const dataValues = d3Stack().keys(keys)(dataSet);\n maxOfYVal = d3Max(dataValues[dataValues.length - 1], dp => dp[1])!;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n dataValues.forEach((layer: any) => {\n const currentLayer: AreaChartDataSetPoint[] = [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n layer.forEach((d: any) => {\n currentLayer.push({\n values: d,\n xVal: d.data.xVal,\n });\n });\n renderPoints.push(currentLayer);\n });\n }\n\n _isMultiStackChart = !!(props.legendProps?.selectedLegends\n ? renderPoints?.length >= 1\n : renderPoints?.length > 1);\n return {\n renderData: renderPoints,\n // The maxOfYVal prop is only required for the primary y-axis. When the data includes\n // a secondary y-axis, the mode defaults to tozeroy, so maxOfYVal should be calculated using\n // only the data points associated with the primary y-axis.\n maxOfYVal: _containsSecondaryYAxis ? findNumericMinMaxOfY(props.data.lineChartData!).endValue : maxOfYVal,\n };\n }\n\n function _createDataSet(points: LineChartPoints[]) {\n if (props.enablePerfOptimization && _enableComputationOptimization && !_hasDuplicateXValues) {\n const allChartPoints: LineChartDataPoint[] = [];\n const dataSet: AreaChartDataSetPoint[] = [];\n const colors: string[] = [];\n const opacity: number[] = [];\n const calloutPoints = calloutData(points!);\n\n points &&\n points.length &&\n points.forEach((singleChartPoint: LineChartPoints) => {\n colors.push(singleChartPoint.color!);\n opacity.push(singleChartPoint.opacity || 1);\n allChartPoints.push(...(singleChartPoint.data as LineChartDataPoint[]));\n });\n\n const mapOfXvalToListOfDataPoints: MapXToDataSet = {};\n allChartPoints.forEach((dataPoint: LineChartDataPoint) => {\n const xValue = dataPoint.x instanceof Date ? dataPoint.x.toLocaleString() : dataPoint.x;\n // map of x value to the list of data points which share the same x value .\n if (mapOfXvalToListOfDataPoints[xValue]) {\n mapOfXvalToListOfDataPoints[xValue].push(dataPoint);\n } else {\n mapOfXvalToListOfDataPoints[xValue] = [dataPoint];\n }\n });\n\n Object.keys(mapOfXvalToListOfDataPoints).forEach((key: number | string) => {\n const value: LineChartDataPoint[] = mapOfXvalToListOfDataPoints[key];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDataset: any = {};\n value.forEach((singleDataPoint: LineChartDataPoint, index: number) => {\n singleDataset.xVal = singleDataPoint.x;\n singleDataset[`chart${index}`] = singleDataPoint.y;\n });\n dataSet.push(singleDataset);\n });\n\n // get keys from dataset, used to render data\n const keysLength: number = dataSet && Object.keys(dataSet[0])!.length;\n const keys: string[] = [];\n for (let i = 0; i < keysLength - 1; i++) {\n const keyVal = `chart${i}`;\n keys.push(keyVal);\n }\n\n // Data used to draw graph\n const data = _getDataPoints(keys, dataSet);\n\n return {\n colors,\n opacity,\n keys,\n data,\n calloutPoints,\n };\n } else {\n const allChartPoints: LineChartDataPoint[] = [];\n const dataSet: AreaChartDataSetPoint[] = [];\n const colors: string[] = [];\n const opacity: number[] = [];\n const calloutPoints = calloutData(points!);\n\n let data = {};\n const keys: string[] = [];\n let index = 0;\n\n points &&\n points.length &&\n points.forEach((singleChartPoint: LineChartPoints) => {\n // if legend is not populated, then assign a legend\n if (_hasDuplicateXValues && !singleChartPoint.legend) {\n singleChartPoint.legend = `chart${index}`;\n ++index;\n }\n singleChartPoint.data.forEach((point: ILineChartDataPointWithLegend) => {\n point.legend = singleChartPoint.legend;\n });\n colors.push(singleChartPoint.color!);\n opacity.push(singleChartPoint.opacity || 1);\n allChartPoints.push(...(singleChartPoint.data as LineChartDataPoint[]));\n });\n\n if (!_hasDuplicateXValues) {\n let tempArr = allChartPoints;\n while (tempArr.length) {\n const valToCheck = tempArr[0].x instanceof Date ? tempArr[0].x.toLocaleString() : tempArr[0].x;\n const filteredChartPoints: LineChartDataPoint[] = tempArr.filter(\n (point: LineChartDataPoint) =>\n (point.x instanceof Date ? point.x.toLocaleString() : point.x) === valToCheck,\n );\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDataset: any = {};\n filteredChartPoints.forEach((singleDataPoint: LineChartDataPoint, id: number) => {\n singleDataset.xVal = singleDataPoint.x;\n singleDataset[`chart${id}`] = singleDataPoint.y;\n });\n dataSet.push(singleDataset);\n // removing compared objects from array\n const val = tempArr[0].x instanceof Date ? tempArr[0].x.toLocaleString() : tempArr[0].x;\n tempArr = tempArr.filter(\n (point: LineChartDataPoint) => (point.x instanceof Date ? point.x.toLocaleString() : point.x) !== val,\n );\n }\n\n // get keys from dataset, used to create stacked data\n const keysLength: number = dataSet && Object.keys(dataSet[0])!.length;\n for (let i = 0; i < keysLength - 1; i++) {\n const keyVal = `chart${i}`;\n keys.push(keyVal);\n }\n // Data used to draw graph\n data = _getDataPoints(keys, dataSet);\n } else {\n const datasetForDuplicateValues = _createDatasetForXCoordinateWithMultipleYValues(allChartPoints);\n data = _getDataPoints(datasetForDuplicateValues.keys, datasetForDuplicateValues.filteredDataSet);\n }\n\n return {\n colors,\n opacity,\n keys,\n data,\n calloutPoints,\n };\n }\n }\n\n function _createDatasetForXCoordinateWithMultipleYValues(allChartPoints: LineChartDataPoint[]) {\n const dataSet: AreaChartDataSetPoint[] = [];\n\n // Group data points by x-axis value\n const groupedData: Record<string | number, ILineChartDataPointWithLegend[]> = {};\n allChartPoints.forEach((dataPoint: ILineChartDataPointWithLegend) => {\n const xValue = dataPoint.x instanceof Date ? dataPoint.x.toLocaleString() : dataPoint.x;\n if (!groupedData[xValue]) {\n groupedData[xValue] = [];\n }\n groupedData[xValue].push(dataPoint);\n });\n\n // Aggregate data points for each x-axis value\n Object.keys(groupedData).forEach(xValue => {\n const dataPoints = groupedData[xValue];\n dataPoints.forEach((dataPoint, id) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDataset: any = { xVal: dataPoints[0].x };\n\n const key = dataPoint.legend ? dataPoint.legend : `chart${id}`;\n singleDataset[key] = dataPoint.y;\n dataSet.push(singleDataset);\n });\n });\n\n // get all unique keys from each array within the dataSet\n const allLegends: string[] = [];\n dataSet.forEach(item => {\n Object.keys(item).forEach(key => {\n if (key !== 'xVal' && !allLegends.includes(key)) {\n allLegends.push(key);\n }\n });\n });\n\n dataSet.forEach(item => {\n allLegends.forEach(legend => {\n if (!item[legend]) {\n item[legend] = 0; // Fill with 0 if the legend is missing\n }\n });\n });\n\n // exclude all items within dataset having all legend values 0\n const filteredDataSet = dataSet.filter(item => {\n return allLegends.some(legend => item[legend] !== 0);\n });\n\n const keys = Array.from(\n new Set(filteredDataSet.flatMap(item => Object.keys(item).filter(key => key !== 'xVal'))),\n );\n\n return {\n keys,\n filteredDataSet,\n };\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerStack\n ? props.onRenderCalloutPerStack(stackCalloutProps)\n : props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps)\n : null;\n }\n\n function _getGraphData(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xAxis: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yAxis: any,\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement | null,\n yAxisElement?: SVGElement | null,\n yScaleSecondary?: ScaleLinear<number, number>,\n ) {\n _chart = _drawGraph(containerHeight, xAxis, yAxis, yScaleSecondary, xElement!);\n }\n\n function _onLegendHover(legend: string): void {\n setActiveLegend(legend);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _getLegendData(points: LineChartPoints[]): JSXElement {\n const data = points;\n const actions: Legend[] = [];\n\n data.forEach((singleChartData: LineChartPoints) => {\n const color: string = singleChartData.color!;\n const checkSimilarLegends = actions.filter(\n (leg: Legend) => leg.title === singleChartData.legend && leg.color === color,\n );\n if (checkSimilarLegends!.length > 0) {\n return;\n }\n\n const legend: Legend = {\n title: singleChartData.legend,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(singleChartData.legend);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n\n actions.push(legend);\n });\n return (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n {...props.legendProps}\n onChange={_onLegendSelectionChange}\n legendRef={_legendsRef}\n />\n );\n }\n\n function _onLegendSelectionChange(\n // eslint-disable-next-line @typescript-eslint/no-shadow\n selectedLegends: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(selectedLegends);\n } else {\n setSelectedLegends(selectedLegends.slice(-1));\n }\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(selectedLegends, event, currentLegend);\n }\n }\n\n function _onDataPointClick(func: (() => void) | undefined) {\n if (func) {\n func();\n }\n setIsCircleClicked(true);\n }\n\n function _getOpacity(legend: string): number {\n if (!_isMultiStackChart) {\n return 0.7;\n } else {\n const opacity = _legendHighlighted(legend) || _noLegendHighlighted() ? 0.7 : 0.1;\n return opacity;\n }\n }\n\n function _getLineOpacity(legend: string): number {\n if (!_isMultiStackChart) {\n return 1;\n } else {\n let opacity = 0.3;\n if (isPopoverOpen) {\n opacity = 1;\n }\n if (!_noLegendHighlighted()) {\n opacity = _legendHighlighted(legend) ? 0 : 0.1;\n }\n return opacity;\n }\n }\n\n function _updateCircleFillColor(xDataPoint: number | Date, lineColor: string, circleId: string): string {\n let fillColor = lineColor;\n if (nearestCircleToHighlight === xDataPoint || activePoint === circleId) {\n if (!isCircleClicked) {\n fillColor = tokens.colorNeutralBackground1;\n }\n }\n\n return fillColor;\n }\n\n function _drawGraph(\n containerHeight: number,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n yScalePrimary: ScaleLinear<number, number>,\n yScaleSecondary: ScaleLinear<number, number> | undefined,\n xElement: SVGElement,\n ): JSXElement[] {\n const points = _addDefaultColors(props.data.lineChartData);\n const { pointOptions, pointLineOptions } = props.data;\n\n const graph: JSXElement[] = [];\n let lineColor: string;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _data.forEach((singleStackedData: Array<any>, index: number) => {\n const yScale = points[index]?.useSecondaryYScale && yScaleSecondary ? yScaleSecondary : yScalePrimary;\n const curveFactory = getCurveFactory(points[index]?.lineOptions?.curve, d3CurveBasis);\n const area = d3Area()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => xScale(d.xVal))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y0((d: any) => yScale(d.values[0]))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y1((d: any) => yScale(d.values[1]))\n .curve(curveFactory);\n const line = d3Line()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => xScale(d.xVal))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y((d: any) => yScale(d.values[1]))\n .curve(curveFactory);\n const layerOpacity = _shouldFillToZeroY() ? 0.8 : _opacity[index];\n graph.push(\n <React.Fragment key={`${index}-graph-${_uniqueIdForGraph}`}>\n {props.enableGradient && (\n <defs>\n <linearGradient id={`gradient_${index}`} x1=\"0%\" x2=\"0%\" y1=\"0%\" y2=\"100%\">\n <stop offset=\"0\" stopColor={_colors[index]} />\n <stop offset=\"100%\" stopColor=\"transparent\" />\n </linearGradient>\n </defs>\n )}\n <path\n id={`${index}-line-${_uniqueIdForGraph}`}\n d={line(singleStackedData)!}\n fill={'transparent'}\n strokeWidth={points[index]?.lineOptions?.strokeWidth ?? 3}\n stroke={_colors[index]}\n opacity={_getLineOpacity(points[index]!.legend)}\n onMouseMove={event => _onRectMouseMove(event)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n strokeDasharray={points[index]?.lineOptions?.strokeDasharray}\n strokeDashoffset={points[index]?.lineOptions?.strokeDashoffset}\n strokeLinecap={points[index]?.lineOptions?.strokeLinecap}\n />\n {singleStackedData.length === 1 ? (\n <circle\n id={`${index}-graph-${_uniqueIdForGraph}`}\n cx={xScale(singleStackedData[0].xVal)}\n cy={yScale(singleStackedData[0].values[1])}\n r={6}\n stroke={_colors[index]}\n strokeWidth={3}\n fill={_colors[index]}\n opacity={layerOpacity}\n fillOpacity={_getOpacity(points[index]!.legend)}\n onMouseMove={event => _onRectMouseMove(event)}\n onFocus={event => _handleFocus(event, index, 0, `${_circleId}_${index}`)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n />\n ) : (\n <path\n id={`${index}-graph-${_uniqueIdForGraph}`}\n d={area(singleStackedData)!}\n fill={props.enableGradient ? `url(#gradient_${index})` : _colors[index]}\n opacity={layerOpacity}\n fillOpacity={_getOpacity(points[index]!.legend)}\n onMouseMove={event => _onRectMouseMove(event)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n {...(props.optimizeLargeData && {\n tabIndex: _legendHighlighted(points[index]!.legend) || _noLegendHighlighted() ? 0 : undefined,\n role: 'img',\n 'aria-label': `${points[index].legend}, series ${index + 1} of ${points.length} with ${\n points[index].data.length\n } data points.`,\n })}\n />\n )}\n </React.Fragment>,\n );\n });\n\n const circleRadius = pointOptions && pointOptions.r ? Number(pointOptions.r) : 8;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _data.forEach((singleStackedData: Array<any>, index: number) => {\n if (points.length === index) {\n return;\n }\n const yScale = points[index]?.useSecondaryYScale && yScaleSecondary ? yScaleSecondary : yScalePrimary;\n if (!props.optimizeLargeData || singleStackedData.length === 1) {\n // Render circles for all data points\n graph.push(\n <g\n key={`${index}-dots-${_uniqueIdForGraph}`}\n clipPath=\"url(#clip)\"\n role=\"region\"\n aria-label={`${points[index].legend}, series ${index + 1} of ${points.length} with ${\n points[index].data.length\n } data points.`}\n >\n {singleStackedData.map((singlePoint: DPointType, pointIndex: number) => {\n const circleId = `${_circleId}_${index * _data[0].length + pointIndex}`;\n const xDataPoint = singlePoint.xVal instanceof Date ? singlePoint.xVal.getTime() : singlePoint.xVal;\n lineColor = points[index]!.color!;\n const legend = points[index]!.legend;\n return (\n <circle\n key={circleId}\n id={circleId}\n tabIndex={_legendHighlighted(points[index]!.legend) || _noLegendHighlighted() ? 0 : undefined}\n cx={xScale(singlePoint.xVal)}\n cy={yScale(singlePoint.values[1])}\n stroke={lineColor}\n strokeWidth={3}\n fill={_updateCircleFillColor(xDataPoint, lineColor, circleId)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n {..._getOnClickHandler(points, index, pointIndex)}\n onFocus={event => _handleFocus(event, index, pointIndex, circleId)}\n onBlur={_handleBlur}\n {...getSecureProps(pointOptions)}\n r={_getCircleRadius(xDataPoint, circleRadius, circleId, legend)}\n role=\"img\"\n aria-label={\n (!_hasDuplicateXValues && !_hasMissingXValues && _getAriaLabel(index, pointIndex)) || undefined\n }\n />\n );\n })}\n </g>,\n );\n } else {\n // Render circles for data points close to the mouse pointer only\n singleStackedData.forEach((singlePoint: DPointType, pointIndex: number) => {\n const xDataPoint = singlePoint.xVal instanceof Date ? singlePoint.xVal.getTime() : singlePoint.xVal;\n if (nearestCircleToHighlight === xDataPoint) {\n const circleId = `${_circleId}_${index * _data[0].length + pointIndex}`;\n lineColor = points[index]!.color!;\n const legend = points[index]!.legend;\n graph.push(\n <circle\n key={circleId}\n id={circleId}\n cx={xScale(singlePoint.xVal)}\n cy={yScale(singlePoint.values[1])}\n stroke={lineColor}\n strokeWidth={3}\n fill={_updateCircleFillColor(xDataPoint, lineColor, circleId)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n onFocus={event => _handleFocus(event, index, pointIndex, circleId)}\n {..._getOnClickHandler(points, index, pointIndex)}\n {...getSecureProps(pointOptions)}\n r={_getCircleRadius(xDataPoint, circleRadius, circleId, legend)}\n />,\n );\n }\n });\n }\n });\n graph.push(\n <line\n id={_verticalLineId}\n key={_verticalLineId}\n x1={lineXValue}\n y1={0}\n x2={lineXValue}\n y2={containerHeight}\n strokeWidth={1}\n strokeDasharray={5.5}\n stroke={lineColor!}\n opacity={0.5}\n visibility={displayOfLine}\n {...getSecureProps(pointLineOptions)}\n />,\n );\n // Removing un wanted tooltip div from DOM, when prop not provided.\n if (!props.showXAxisLablesTooltip) {\n try {\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n // Used to display tooltip at x axis labels.\n if (!props.wrapXAxisLables && props.showXAxisLablesTooltip) {\n const xAxisElement = d3Select(xElement).call(xScale);\n try {\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n document.getElementById(_tooltipId) && document.getElementById(_tooltipId)!.remove();\n // eslint-disable-next-line no-empty\n } catch (e) {}\n const tooltipProps = {\n tooltipCls: classes.tooltip!,\n id: _tooltipId,\n axis: xAxisElement,\n };\n xAxisElement && tooltipOfAxislabels(tooltipProps);\n }\n return graph;\n }\n\n function _getOnClickHandler(points: LineChartPoints[], index: number, pointIndex: number) {\n if (!_hasDuplicateXValues && !_hasMissingXValues) {\n return {\n onClick: () => _onDataPointClick(points[index]!.data[pointIndex].onDataPointClick!),\n };\n }\n return {};\n }\n\n function _getCircleRadius(xDataPoint: number, circleRadius: number, circleId: string, legend: string): number {\n // Show the circle if no legends are selected or if the point's legend is in the selected legends\n if (!_noLegendHighlighted() && !_legendHighlighted(legend)) {\n return 0;\n }\n\n if (isCircleClicked && nearestCircleToHighlight === xDataPoint) {\n return 1;\n } else if (nearestCircleToHighlight === xDataPoint || activePoint === circleId) {\n return circleRadius;\n } else {\n return 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(legend: string) {\n return _getHighlightedLegend().includes(legend!);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n function _noLegendHighlighted() {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _addDefaultColors(lineChartData?: LineChartPoints[]): LineChartPoints[] {\n if (_hasMissingXValues) {\n // get union of all x values\n const allXValues: Set<string | number> = new Set();\n lineChartData &&\n lineChartData.forEach((line: LineChartPoints) => {\n line.data.forEach((point: LineChartDataPoint) => {\n const xValue = point.x instanceof Date ? point.x.toLocaleString() : point.x;\n allXValues.add(xValue);\n });\n });\n lineChartData &&\n lineChartData.forEach((line: LineChartPointsWithLegend) => {\n allXValues.forEach((xValue: string | number) => {\n const point = line.data.find((item: ILineChartDataPointWithLegend) => {\n return item.x instanceof Date ? item.x.toLocaleString() === xValue : item.x === xValue;\n });\n if (!point) {\n line.data.push({\n x: typeof xValue === 'string' ? new Date(xValue) : xValue,\n y: 0,\n legend: line.legend,\n });\n }\n });\n // sort the data points by x value\n line.data.sort((a: LineChartDataPoint, b: LineChartDataPoint) => {\n const xA = a.x instanceof Date ? a.x.getTime() : a.x;\n const xB = b.x instanceof Date ? b.x.getTime() : b.x;\n return xA < xB ? -1 : xA > xB ? 1 : 0;\n });\n });\n }\n return lineChartData\n ? lineChartData.map((item, index) => {\n let color: string;\n // isInverted property is applicable to v8 themes only\n if (typeof item.color === 'undefined') {\n color = getNextColor(index, 0);\n } else {\n color = getColorFromToken(item.color);\n }\n\n return { ...item, color };\n })\n : [];\n }\n\n function _handleFocus(\n event: React.FocusEvent<SVGCircleElement, Element>,\n lineIndex: number,\n pointIndex: number,\n circleId: string,\n ) {\n let cx = 0;\n let cy = 0;\n\n const targetRect = (event.target as SVGCircleElement).getBoundingClientRect();\n cx = targetRect.left + targetRect.width / 2;\n cy = targetRect.top + targetRect.height / 2;\n _updatePosition(cx, cy);\n\n const { x, y, xAxisCalloutData } = props.data.lineChartData![lineIndex].data[pointIndex];\n const formattedDate = x instanceof Date ? formatDateToLocaleString(x, props.culture, props.useUTC as boolean) : x;\n const found = findCalloutPoints(_calloutPoints, x);\n if (found) {\n // Show details in the callout for the focused point only\n found.values = found.values.filter((e: { y: number }) => e.y === y);\n const filteredValues = _getFilteredLegendValues(found.values);\n\n setPopoverOpen(true);\n setHoverXValue(xAxisCalloutData ? xAxisCalloutData : formattedDate);\n setYValueHover(filteredValues!);\n setStackCalloutProps({ ...found, values: filteredValues });\n setDataPointCalloutProps({ ...found, values: filteredValues });\n setActivePoint(circleId);\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _getFilteredLegendValues(values: any) {\n return !_noLegendHighlighted()\n ? values.filter((value: { legend: string }) => _legendHighlighted(value.legend))\n : values;\n }\n\n function _handleBlur() {\n setPopoverOpen(false);\n setHoverXValue(undefined);\n setYValueHover([]);\n setStackCalloutProps(undefined);\n setDataPointCalloutProps(undefined);\n setActivePoint('');\n }\n\n function _getAriaLabel(lineIndex: number, pointIndex: number): string {\n const line = props.data.lineChartData![lineIndex];\n const point = line.data[pointIndex];\n const formattedDate =\n point.x instanceof Date ? formatDateToLocaleString(point.x, props.culture, props.useUTC as boolean) : point.x;\n const xValue = point.xAxisCalloutData || formattedDate;\n const legend = line.legend;\n const yValue = point.yAxisCalloutData || point.y;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ${legend}, ${yValue}.`;\n }\n\n function _isChartEmpty(): boolean {\n return !(\n (\n props.data &&\n props.data.lineChartData &&\n props.data.lineChartData.length > 0 &&\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n props.data.lineChartData.filter((item: { data: string | any[] }) => item.data.length === 0).length === 0\n )\n // if all the data sets have no data\n // filtering all items which have no data and checking if the length of the filtered array is 0\n // which means chart is not empty\n );\n }\n\n function _getChartTitle(): string {\n const { chartTitle, lineChartData } = props.data;\n return (chartTitle ? `${chartTitle}. ` : '') + `Area chart with ${lineChartData?.length || 0} data series. `;\n }\n\n function _xCoordinateContainsMultipleY(): boolean {\n const { lineChartData } = props.data;\n if (!lineChartData) {\n return false;\n }\n for (const item of lineChartData) {\n const xValueMap: Record<string, number[]> = {};\n for (const point of item.data) {\n const xValue = point.x instanceof Date ? point.x.toLocaleString() : point.x;\n if (!xValueMap[xValue]) {\n xValueMap[xValue] = [];\n }\n xValueMap[xValue].push(point.y);\n if (xValueMap[xValue].length > 1) {\n return true;\n }\n }\n }\n return false;\n }\n\n function _containsMissingXValues(): boolean {\n const { lineChartData } = props.data;\n if (!lineChartData) {\n return false;\n }\n const allXValues: Set<string | number> = new Set();\n lineChartData.forEach((line: LineChartPoints) => {\n line.data.forEach((point: LineChartDataPoint) => {\n const xValue = point.x instanceof Date ? point.x.toLocaleString() : point.x;\n allXValues.add(xValue);\n });\n });\n // for all x values, check if the x value is present in all series\n let hasMissingValues = false;\n lineChartData.forEach((line: LineChartPoints) => {\n allXValues.forEach((xValue: string | number) => {\n const point = line.data.find((item: LineChartDataPoint) => {\n return item.x instanceof Date ? item.x.toLocaleString() === xValue : item.x === xValue;\n });\n if (!point) {\n hasMissingValues = true;\n }\n });\n });\n return hasMissingValues;\n }\n\n function _shouldFillToZeroY() {\n return props.mode === 'tozeroy' || _containsSecondaryYAxis;\n }\n\n if (!_isChartEmpty()) {\n const { lineChartData } = props.data;\n const points = _addDefaultColors(lineChartData);\n _containsSecondaryYAxis = !!props.secondaryYScaleOptions && points.some(point => point.useSecondaryYScale);\n _createSet = _createDataSet;\n const { colors, opacity, data, calloutPoints } = _createSet(points);\n _calloutPoints = calloutPoints;\n const isXAxisDateType = getXAxisType(points);\n _colors = colors;\n _opacity = opacity;\n _data = data.renderData;\n const legends: JSXElement = _getLegendData(points);\n\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n\n const calloutProps: ChartPopoverProps = {\n YValueHover: YValueHover!,\n hoverXValue: hoverXValue!,\n xAxisCalloutAccessibilityData,\n ...props.calloutProps,\n clickPosition,\n isPopoverOpen: isPopoverOpen && !_hasDuplicateXValues && !_hasMissingXValues,\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() !== null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n isCalloutForStack: true,\n };\n return (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={points}\n chartType={ChartTypes.AreaChart}\n calloutProps={calloutProps}\n legendBars={legends}\n createYAxis={createNumericYAxis}\n xAxisType={isXAxisDateType ? XAxisTypes.DateAxis : XAxisTypes.NumericAxis}\n tickParams={tickParams}\n maxOfYVal={data.maxOfYVal}\n getGraphData={_getGraphData}\n getDomainNRangeValues={_getDomainNRangeValues}\n createStringYAxis={createStringYAxis}\n getmargins={_getMargins}\n onChartMouseLeave={_handleChartMouseLeave}\n getMinMaxOfYAxis={_getMinMaxOfYAxis}\n enableFirstRenderOptimization={props.enablePerfOptimization && _firstRenderOptimization}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line react/no-children-prop, @typescript-eslint/no-shadow\n children={(props: ChildProps) => {\n _xAxisRectScale = props.xScale;\n const ticks = _xAxisRectScale.ticks();\n const width1 = _xAxisRectScale(ticks[ticks.length - 1]);\n const rectHeight = props.containerHeight! - _margins.top!;\n return (\n <>\n <g>\n <rect\n id={_rectId}\n width={width1}\n height={rectHeight}\n fill={'transparent'}\n onMouseMove={event => _onRectMouseMove(event)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n />\n </g>\n <g>{_chart}</g>\n </>\n );\n }}\n />\n );\n }\n return (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n },\n);\nAreaChart.displayName = 'AreaChart';\n"],"names":["React","useAreaChartStyles","max","d3Max","bisector","pointer","select","d3Select","tokens","area","d3Area","stack","d3Stack","curveMonotoneX","d3CurveBasis","line","d3Line","CartesianChart","calloutData","getXAxisType","ChartTypes","XAxisTypes","getTypeOfAxis","tooltipOfAxislabels","getNextColor","getColorFromToken","getSecureProps","areArraysEqual","getCurveFactory","findNumericMinMaxOfY","createNumericYAxis","domainRangeOfNumericForAreaLineScatterCharts","domainRangeOfDateForAreaLineScatterVerticalBarCharts","createStringYAxis","findCalloutPoints","useId","Legends","formatDateToLocaleString","useImageExport","bisect","d","x","left","InterceptVisibility","AreaChart","forwardRef","props","forwardedRef","_uniqueIdForGraph","_verticalLineId","_circleId","_rectId","_tooltipId","_enableComputationOptimization","_firstRenderOptimization","_emptyChartId","_containsSecondaryYAxis","_hasMissingXValues","_containsMissingXValues","_hasDuplicateXValues","_xCoordinateContainsMultipleY","_calloutPoints","_createSet","_colors","_opacity","_data","_chart","_margins","_xAxisRectScale","_isMultiStackChart","cartesianChartRef","legendsRef","_legendsRef","componentRef","hideLegend","selectedLegends","setSelectedLegends","useState","legendProps","activeLegend","setActiveLegend","undefined","hoverXValue","setHoverXValue","YValueHover","setYValueHover","lineXValue","setLineXValue","displayOfLine","setDisplayOfLine","isCircleClicked","setIsCircleClicked","nearestCircleToHighlight","setNearestCircleToHighlight","activePoint","setActivePoint","dataPointCalloutProps","setDataPointCalloutProps","stackCalloutProps","setStackCalloutProps","xAxisCalloutAccessibilityData","setXAxisCalloutAccessibilityData","clickPosition","setClickPosition","y","isPopoverOpen","setPopoverOpen","prevPropsRef","useRef","useEffect","current","prevProps","classes","_getMinMaxOfYAxis","points","yAxisType","useSecondaryYScale","_getDomainNRangeValues","margins","width","chartType","isRTL","xAxisType","barWidth","tickValues","domainNRangeValue","NumericAxis","DateAxis","dStartValue","dEndValue","rStartValue","rEndValue","_getMargins","_onRectMouseMove","mouseEvent","persist","data","lineChartData","_updatePosition","clientX","clientY","xOffset","invert","document","getElementById","i","d0","d1","pointToHighlight","index","axisType","length","x0","point0","point1","Date","getTime","Math","abs","xAxisCalloutData","formattedDate","culture","useUTC","found","_nearestCircleToHighlight","filteredValues","_getFilteredLegendValues","values","_onRectMouseOut","newX","newY","threshold","distance","sqrt","pow","_handleChartMouseLeave","_getDataPoints","keys","dataSet","renderPoints","maxOfYVal","_shouldFillToZeroY","forEach","key","currentLayer","push","xVal","dataValues","dp","layer","renderData","endValue","_createDataSet","enablePerfOptimization","allChartPoints","colors","opacity","calloutPoints","singleChartPoint","color","mapOfXvalToListOfDataPoints","dataPoint","xValue","toLocaleString","Object","value","singleDataset","singleDataPoint","keysLength","keyVal","legend","point","tempArr","valToCheck","filteredChartPoints","filter","id","val","datasetForDuplicateValues","_createDatasetForXCoordinateWithMultipleYValues","filteredDataSet","groupedData","dataPoints","allLegends","item","includes","some","Array","from","Set","flatMap","_getCustomizedCallout","onRenderCalloutPerStack","onRenderCalloutPerDataPoint","_getGraphData","xAxis","yAxis","containerHeight","containerWidth","xElement","yAxisElement","yScaleSecondary","_drawGraph","_onLegendHover","_onLegendLeave","_getLegendData","actions","singleChartData","checkSimilarLegends","leg","title","hoverAction","onMouseOutAction","legends","enabledWrapLines","enabledLegendsWrapLines","onChange","_onLegendSelectionChange","legendRef","event","currentLegend","canSelectMultipleLegends","slice","_onDataPointClick","func","_getOpacity","_legendHighlighted","_noLegendHighlighted","_getLineOpacity","_updateCircleFillColor","xDataPoint","lineColor","circleId","fillColor","colorNeutralBackground1","xScale","yScalePrimary","_addDefaultColors","pointOptions","pointLineOptions","graph","singleStackedData","yScale","curveFactory","lineOptions","curve","y0","y1","layerOpacity","Fragment","enableGradient","defs","linearGradient","x1","x2","y2","stop","offset","stopColor","path","fill","strokeWidth","stroke","onMouseMove","onMouseOut","onMouseOver","strokeDasharray","strokeDashoffset","strokeLinecap","circle","cx","cy","r","fillOpacity","onFocus","_handleFocus","optimizeLargeData","tabIndex","role","circleRadius","Number","g","clipPath","aria-label","map","singlePoint","pointIndex","_getOnClickHandler","onBlur","_handleBlur","_getCircleRadius","_getAriaLabel","visibility","showXAxisLablesTooltip","remove","e","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","axis","onClick","onDataPointClick","_getHighlightedLegend","allXValues","add","find","sort","a","b","xA","xB","lineIndex","targetRect","target","getBoundingClientRect","top","height","yValue","yAxisCalloutData","callOutAccessibilityData","ariaLabel","_isChartEmpty","_getChartTitle","chartTitle","xValueMap","hasMissingValues","mode","secondaryYScaleOptions","isXAxisDateType","tickParams","tickFormat","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","isCalloutForStack","legendBars","createYAxis","getGraphData","getDomainNRangeValues","getmargins","onChartMouseLeave","getMinMaxOfYAxis","enableFirstRenderOptimization","children","ticks","width1","rectHeight","rect","div","style","displayName"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/components/AreaChart/AreaChart.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { max as d3Max, bisector } from 'd3-array';\nimport { pointer } from 'd3-selection';\nimport { tokens } from '@fluentui/react-theme';\nimport { area as d3Area, stack as d3Stack, curveMonotoneX as d3CurveBasis, line as d3Line } from 'd3-shape';\nimport {\n AccessibilityProps,\n CartesianChart,\n CustomizedCalloutData,\n AreaChartProps,\n LineChartDataPoint,\n LineChartPoints,\n ChildProps,\n Margins,\n YValueHover,\n ChartPopoverProps,\n} from '../../index';\nimport {\n calloutData,\n getXAxisType,\n ChartTypes,\n XAxisTypes,\n getTypeOfAxis,\n getNextColor,\n getColorFromToken,\n getSecureProps,\n areArraysEqual,\n getCurveFactory,\n findNumericMinMaxOfY,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfNumericForAreaLineScatterCharts,\n domainRangeOfDateForAreaLineScatterVerticalBarCharts,\n createStringYAxis,\n YAxisType,\n findCalloutPoints,\n} from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport type { JSXElement } from '@fluentui/react-utilities';\nimport { Legend, Legends } from '../Legends/index';\nimport { ScaleLinear } from 'd3-scale';\nimport { formatDateToLocaleString } from '@fluentui/chart-utilities';\nimport { useImageExport } from '../../utilities/hooks';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst bisect = bisector((d: any) => d.x).left;\n\nenum InterceptVisibility {\n show = 'visibility',\n hide = 'hidden',\n}\n\nexport interface AreaChartAreaPoint {\n xVal: string | number;\n values: AreaChartDataSetPoint;\n}\nexport interface AreaChartDataSetPoint {\n [key: string]: number | string | number[];\n}\nexport interface DPointType {\n values: { 0: number; 1: number; data: {} };\n xVal: number | Date;\n}\nexport interface MapXToDataSet {\n [key: string]: LineChartDataPoint[];\n [key: number]: LineChartDataPoint[];\n}\n\ninterface ILineChartDataPointWithLegend extends LineChartDataPoint {\n /**\n * Legend text for the datapoint in the chart\n */\n legend?: string;\n}\n\ntype ILineChartPointsWithoutData = Omit<LineChartPoints, 'data'>;\ninterface LineChartPointsWithLegend extends ILineChartPointsWithoutData {\n data: ILineChartDataPointWithLegend[];\n}\n\n//by default d3-shape 3.2.0 limits the< path> data point precision to 3 digits(d3/d3-path#10)\n\nexport const AreaChart: React.FunctionComponent<AreaChartProps> = React.forwardRef<HTMLDivElement, AreaChartProps>(\n (props, forwardedRef) => {\n const _uniqueIdForGraph: string = useId('areaChart_');\n const _verticalLineId: string = useId('verticalLine_');\n const _circleId: string = useId('circle');\n const _rectId: string = useId('rectangle');\n //enableComputationOptimization is used for optimized code to group data points by x value\n //from O(n^2) to O(n) using a map.\n const _enableComputationOptimization: boolean = true;\n const _firstRenderOptimization: boolean = true;\n const _emptyChartId: string = useId('_AreaChart_empty');\n let _containsSecondaryYAxis = false;\n let _hasMissingXValues = _containsMissingXValues();\n let _hasDuplicateXValues = _xCoordinateContainsMultipleY();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _calloutPoints: any;\n let _createSet: (data: LineChartPoints[]) => {\n colors: string[];\n opacity: number[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n calloutPoints: any;\n };\n let _colors: string[];\n let _opacity: number[];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _data: any;\n let _chart: JSXElement[];\n let _margins: Margins;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let _xAxisRectScale: any;\n // determines if the given area chart has multiple stacked bar charts\n let _isMultiStackChart: boolean;\n const { cartesianChartRef, legendsRef: _legendsRef } = useImageExport(props.componentRef, props.hideLegend);\n\n const [selectedLegends, setSelectedLegends] = React.useState<string[]>(props.legendProps?.selectedLegends || []);\n const [activeLegend, setActiveLegend] = React.useState<string | undefined>(undefined);\n const [hoverXValue, setHoverXValue] = React.useState<string | number | undefined | null>('');\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const [YValueHover, setYValueHover] = React.useState<YValueHover[]>([]);\n const [lineXValue, setLineXValue] = React.useState<number>(0);\n const [displayOfLine, setDisplayOfLine] = React.useState<InterceptVisibility>(InterceptVisibility.hide);\n const [isCircleClicked, setIsCircleClicked] = React.useState<boolean>(false);\n const [nearestCircleToHighlight, setNearestCircleToHighlight] = React.useState<number | string | Date | null>(null);\n const [activePoint, setActivePoint] = React.useState<string>('');\n const [dataPointCalloutProps, setDataPointCalloutProps] = React.useState<CustomizedCalloutData>();\n const [stackCalloutProps, setStackCalloutProps] = React.useState<CustomizedCalloutData>();\n const [xAxisCalloutAccessibilityData, setXAxisCalloutAccessibilityData] = React.useState<AccessibilityProps>();\n const [clickPosition, setClickPosition] = React.useState({ x: 0, y: 0 });\n const [isPopoverOpen, setPopoverOpen] = React.useState(false);\n const prevPropsRef = React.useRef<AreaChartProps | 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 }\n prevPropsRef.current = props;\n }, [props]);\n\n function _getMinMaxOfYAxis(points: LineChartPoints[], yAxisType: YAxisType, useSecondaryYScale: boolean) {\n return findNumericMinMaxOfY(points, yAxisType, useSecondaryYScale);\n }\n\n function _getDomainNRangeValues(\n points: LineChartPoints[],\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 = domainRangeOfNumericForAreaLineScatterCharts(points, margins, width, isRTL);\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 = { dStartValue: 0, dEndValue: 0, rStartValue: 0, rEndValue: 0 };\n }\n return domainNRangeValue;\n }\n\n function _getMargins(margins: Margins) {\n _margins = margins;\n }\n\n function _onRectMouseMove(mouseEvent: React.MouseEvent<SVGRectElement | SVGPathElement | SVGCircleElement>) {\n mouseEvent.persist();\n const { data } = props;\n const { lineChartData } = data;\n _updatePosition(mouseEvent.clientX, mouseEvent.clientY);\n // This will get the value of the X when mouse is on the chart\n // eslint-disable-next-line @nx/workspace-no-restricted-globals\n const xOffset = _xAxisRectScale.invert(pointer(mouseEvent)[0], document.getElementById(_rectId)!);\n const i = bisect(lineChartData![0].data, xOffset);\n const d0 = lineChartData![0].data[i - 1] as LineChartDataPoint;\n const d1 = lineChartData![0].data[i] as LineChartDataPoint;\n let pointToHighlight: string | Date | number | null = null;\n let index: null | number = null;\n const axisType =\n lineChartData![0].data.length > 0 ? (getTypeOfAxis(lineChartData![0].data[0].x, true) as XAxisTypes) : null;\n if (d0 === undefined && d1 !== undefined) {\n pointToHighlight = d1.x;\n index = i;\n } else if (d0 !== undefined && d1 === undefined) {\n pointToHighlight = d0.x;\n index = i - 1;\n } else {\n let x0;\n let point0;\n let point1;\n switch (axisType) {\n case XAxisTypes.DateAxis:\n x0 = new Date(xOffset).getTime();\n point0 = (d0.x as Date).getTime();\n point1 = (d1.x as Date).getTime();\n pointToHighlight = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? d1.x : d0.x;\n index = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? i : i - 1;\n break;\n case XAxisTypes.NumericAxis:\n x0 = xOffset as number;\n point0 = d0.x as number;\n point1 = d1.x as number;\n pointToHighlight = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? d1.x : d0.x;\n index = Math.abs(x0 - point0) > Math.abs(x0 - point1) ? i : i - 1;\n break;\n default:\n break;\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const { xAxisCalloutData, xAxisCalloutAccessibilityData } = lineChartData![0].data[index as number];\n const formattedDate =\n pointToHighlight instanceof Date\n ? formatDateToLocaleString(pointToHighlight, props.culture, props.useUTC as boolean)\n : pointToHighlight;\n const found = findCalloutPoints(_calloutPoints, pointToHighlight);\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const _nearestCircleToHighlight =\n axisType === XAxisTypes.DateAxis ? (pointToHighlight as Date).getTime() : pointToHighlight;\n // if no points need to be called out then don't show vertical line and callout card\n if (found) {\n const filteredValues = _getFilteredLegendValues(found.values);\n setNearestCircleToHighlight(_nearestCircleToHighlight);\n setLineXValue(_xAxisRectScale(pointToHighlight));\n setDisplayOfLine(InterceptVisibility.show);\n setIsCircleClicked(false);\n setStackCalloutProps({ ...found, values: filteredValues });\n setYValueHover(filteredValues);\n setDataPointCalloutProps({ ...found, values: filteredValues });\n setHoverXValue(xAxisCalloutData ? xAxisCalloutData : formattedDate);\n setXAxisCalloutAccessibilityData(xAxisCalloutAccessibilityData);\n setActivePoint('');\n } else {\n setPopoverOpen(false);\n setNearestCircleToHighlight(nearestCircleToHighlight);\n setDisplayOfLine(InterceptVisibility.hide);\n setIsCircleClicked(false);\n }\n }\n /**\n * just cleaning up the state which we have set in the mouse move event\n */\n function _onRectMouseOut() {\n /**/\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 function _handleChartMouseLeave() {\n setPopoverOpen(false);\n setNearestCircleToHighlight(null);\n setLineXValue(0);\n setDisplayOfLine(InterceptVisibility.hide);\n setIsCircleClicked(false);\n setStackCalloutProps(undefined);\n setDataPointCalloutProps(undefined);\n setHoverXValue(undefined);\n setYValueHover([]);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _getDataPoints(keys: string[], dataSet: any) {\n const renderPoints: Array<AreaChartDataSetPoint[]> = [];\n let maxOfYVal = 0;\n\n if (_shouldFillToZeroY()) {\n keys.forEach((key, index) => {\n const currentLayer: AreaChartDataSetPoint[] = [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n dataSet.forEach((d: any) => {\n currentLayer.push({\n values: [0, d[key]], // Start from zero for \"tozeroy\" mode\n xVal: d.xVal,\n });\n if (d[key] > maxOfYVal) {\n maxOfYVal = d[key];\n }\n });\n renderPoints.push(currentLayer);\n });\n } else {\n const dataValues = d3Stack().keys(keys)(dataSet);\n maxOfYVal = d3Max(dataValues[dataValues.length - 1], dp => dp[1])!;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n dataValues.forEach((layer: any) => {\n const currentLayer: AreaChartDataSetPoint[] = [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n layer.forEach((d: any) => {\n currentLayer.push({\n values: d,\n xVal: d.data.xVal,\n });\n });\n renderPoints.push(currentLayer);\n });\n }\n\n _isMultiStackChart = !!(props.legendProps?.selectedLegends\n ? renderPoints?.length >= 1\n : renderPoints?.length > 1);\n return {\n renderData: renderPoints,\n // The maxOfYVal prop is only required for the primary y-axis. When the data includes\n // a secondary y-axis, the mode defaults to tozeroy, so maxOfYVal should be calculated using\n // only the data points associated with the primary y-axis.\n maxOfYVal: _containsSecondaryYAxis ? findNumericMinMaxOfY(props.data.lineChartData!).endValue : maxOfYVal,\n };\n }\n\n function _createDataSet(points: LineChartPoints[]) {\n if (props.enablePerfOptimization && _enableComputationOptimization && !_hasDuplicateXValues) {\n const allChartPoints: LineChartDataPoint[] = [];\n const dataSet: AreaChartDataSetPoint[] = [];\n const colors: string[] = [];\n const opacity: number[] = [];\n const calloutPoints = calloutData(points!);\n\n points &&\n points.length &&\n points.forEach((singleChartPoint: LineChartPoints) => {\n colors.push(singleChartPoint.color!);\n opacity.push(singleChartPoint.opacity || 1);\n allChartPoints.push(...(singleChartPoint.data as LineChartDataPoint[]));\n });\n\n const mapOfXvalToListOfDataPoints: MapXToDataSet = {};\n allChartPoints.forEach((dataPoint: LineChartDataPoint) => {\n const xValue = dataPoint.x instanceof Date ? dataPoint.x.toLocaleString() : dataPoint.x;\n // map of x value to the list of data points which share the same x value .\n if (mapOfXvalToListOfDataPoints[xValue]) {\n mapOfXvalToListOfDataPoints[xValue].push(dataPoint);\n } else {\n mapOfXvalToListOfDataPoints[xValue] = [dataPoint];\n }\n });\n\n Object.keys(mapOfXvalToListOfDataPoints).forEach((key: number | string) => {\n const value: LineChartDataPoint[] = mapOfXvalToListOfDataPoints[key];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDataset: any = {};\n value.forEach((singleDataPoint: LineChartDataPoint, index: number) => {\n singleDataset.xVal = singleDataPoint.x;\n singleDataset[`chart${index}`] = singleDataPoint.y;\n });\n dataSet.push(singleDataset);\n });\n\n // get keys from dataset, used to render data\n const keysLength: number = dataSet && Object.keys(dataSet[0])!.length;\n const keys: string[] = [];\n for (let i = 0; i < keysLength - 1; i++) {\n const keyVal = `chart${i}`;\n keys.push(keyVal);\n }\n\n // Data used to draw graph\n const data = _getDataPoints(keys, dataSet);\n\n return {\n colors,\n opacity,\n keys,\n data,\n calloutPoints,\n };\n } else {\n const allChartPoints: LineChartDataPoint[] = [];\n const dataSet: AreaChartDataSetPoint[] = [];\n const colors: string[] = [];\n const opacity: number[] = [];\n const calloutPoints = calloutData(points!);\n\n let data = {};\n const keys: string[] = [];\n let index = 0;\n\n points &&\n points.length &&\n points.forEach((singleChartPoint: LineChartPoints) => {\n // if legend is not populated, then assign a legend\n if (_hasDuplicateXValues && !singleChartPoint.legend) {\n singleChartPoint.legend = `chart${index}`;\n ++index;\n }\n singleChartPoint.data.forEach((point: ILineChartDataPointWithLegend) => {\n point.legend = singleChartPoint.legend;\n });\n colors.push(singleChartPoint.color!);\n opacity.push(singleChartPoint.opacity || 1);\n allChartPoints.push(...(singleChartPoint.data as LineChartDataPoint[]));\n });\n\n if (!_hasDuplicateXValues) {\n let tempArr = allChartPoints;\n while (tempArr.length) {\n const valToCheck = tempArr[0].x instanceof Date ? tempArr[0].x.toLocaleString() : tempArr[0].x;\n const filteredChartPoints: LineChartDataPoint[] = tempArr.filter(\n (point: LineChartDataPoint) =>\n (point.x instanceof Date ? point.x.toLocaleString() : point.x) === valToCheck,\n );\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDataset: any = {};\n filteredChartPoints.forEach((singleDataPoint: LineChartDataPoint, id: number) => {\n singleDataset.xVal = singleDataPoint.x;\n singleDataset[`chart${id}`] = singleDataPoint.y;\n });\n dataSet.push(singleDataset);\n // removing compared objects from array\n const val = tempArr[0].x instanceof Date ? tempArr[0].x.toLocaleString() : tempArr[0].x;\n tempArr = tempArr.filter(\n (point: LineChartDataPoint) => (point.x instanceof Date ? point.x.toLocaleString() : point.x) !== val,\n );\n }\n\n // get keys from dataset, used to create stacked data\n const keysLength: number = dataSet && Object.keys(dataSet[0])!.length;\n for (let i = 0; i < keysLength - 1; i++) {\n const keyVal = `chart${i}`;\n keys.push(keyVal);\n }\n // Data used to draw graph\n data = _getDataPoints(keys, dataSet);\n } else {\n const datasetForDuplicateValues = _createDatasetForXCoordinateWithMultipleYValues(allChartPoints);\n data = _getDataPoints(datasetForDuplicateValues.keys, datasetForDuplicateValues.filteredDataSet);\n }\n\n return {\n colors,\n opacity,\n keys,\n data,\n calloutPoints,\n };\n }\n }\n\n function _createDatasetForXCoordinateWithMultipleYValues(allChartPoints: LineChartDataPoint[]) {\n const dataSet: AreaChartDataSetPoint[] = [];\n\n // Group data points by x-axis value\n const groupedData: Record<string | number, ILineChartDataPointWithLegend[]> = {};\n allChartPoints.forEach((dataPoint: ILineChartDataPointWithLegend) => {\n const xValue = dataPoint.x instanceof Date ? dataPoint.x.toLocaleString() : dataPoint.x;\n if (!groupedData[xValue]) {\n groupedData[xValue] = [];\n }\n groupedData[xValue].push(dataPoint);\n });\n\n // Aggregate data points for each x-axis value\n Object.keys(groupedData).forEach(xValue => {\n const dataPoints = groupedData[xValue];\n dataPoints.forEach((dataPoint, id) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const singleDataset: any = { xVal: dataPoints[0].x };\n\n const key = dataPoint.legend ? dataPoint.legend : `chart${id}`;\n singleDataset[key] = dataPoint.y;\n dataSet.push(singleDataset);\n });\n });\n\n // get all unique keys from each array within the dataSet\n const allLegends: string[] = [];\n dataSet.forEach(item => {\n Object.keys(item).forEach(key => {\n if (key !== 'xVal' && !allLegends.includes(key)) {\n allLegends.push(key);\n }\n });\n });\n\n dataSet.forEach(item => {\n allLegends.forEach(legend => {\n if (!item[legend]) {\n item[legend] = 0; // Fill with 0 if the legend is missing\n }\n });\n });\n\n // exclude all items within dataset having all legend values 0\n const filteredDataSet = dataSet.filter(item => {\n return allLegends.some(legend => item[legend] !== 0);\n });\n\n const keys = Array.from(\n new Set(filteredDataSet.flatMap(item => Object.keys(item).filter(key => key !== 'xVal'))),\n );\n\n return {\n keys,\n filteredDataSet,\n };\n }\n\n function _getCustomizedCallout() {\n return props.onRenderCalloutPerStack\n ? props.onRenderCalloutPerStack(stackCalloutProps)\n : props.onRenderCalloutPerDataPoint\n ? props.onRenderCalloutPerDataPoint(dataPointCalloutProps)\n : null;\n }\n\n function _getGraphData(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xAxis: any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n yAxis: any,\n containerHeight: number,\n containerWidth: number,\n xElement: SVGElement | null,\n yAxisElement?: SVGElement | null,\n yScaleSecondary?: ScaleLinear<number, number>,\n ) {\n _chart = _drawGraph(containerHeight, xAxis, yAxis, yScaleSecondary, xElement!);\n }\n\n function _onLegendHover(legend: string): void {\n setActiveLegend(legend);\n }\n\n function _onLegendLeave(): void {\n setActiveLegend(undefined);\n }\n\n function _getLegendData(points: LineChartPoints[]): JSXElement {\n const data = points;\n const actions: Legend[] = [];\n\n data.forEach((singleChartData: LineChartPoints) => {\n const color: string = singleChartData.color!;\n const checkSimilarLegends = actions.filter(\n (leg: Legend) => leg.title === singleChartData.legend && leg.color === color,\n );\n if (checkSimilarLegends!.length > 0) {\n return;\n }\n\n const legend: Legend = {\n title: singleChartData.legend,\n color,\n hoverAction: () => {\n _handleChartMouseLeave();\n _onLegendHover(singleChartData.legend);\n },\n onMouseOutAction: () => {\n _onLegendLeave();\n },\n };\n\n actions.push(legend);\n });\n return (\n <Legends\n legends={actions}\n enabledWrapLines={props.enabledLegendsWrapLines}\n {...props.legendProps}\n onChange={_onLegendSelectionChange}\n legendRef={_legendsRef}\n />\n );\n }\n\n function _onLegendSelectionChange(\n // eslint-disable-next-line @typescript-eslint/no-shadow\n selectedLegends: string[],\n event: React.MouseEvent<HTMLButtonElement>,\n currentLegend?: Legend,\n ): void {\n if (props.legendProps?.canSelectMultipleLegends) {\n setSelectedLegends(selectedLegends);\n } else {\n setSelectedLegends(selectedLegends.slice(-1));\n }\n if (props.legendProps?.onChange) {\n props.legendProps.onChange(selectedLegends, event, currentLegend);\n }\n }\n\n function _onDataPointClick(func: (() => void) | undefined) {\n if (func) {\n func();\n }\n setIsCircleClicked(true);\n }\n\n function _getOpacity(legend: string): number {\n if (!_isMultiStackChart) {\n return 0.7;\n } else {\n const opacity = _legendHighlighted(legend) || _noLegendHighlighted() ? 0.7 : 0.1;\n return opacity;\n }\n }\n\n function _getLineOpacity(legend: string): number {\n if (!_isMultiStackChart) {\n return 1;\n } else {\n let opacity = 0.3;\n if (isPopoverOpen) {\n opacity = 1;\n }\n if (!_noLegendHighlighted()) {\n opacity = _legendHighlighted(legend) ? 0 : 0.1;\n }\n return opacity;\n }\n }\n\n function _updateCircleFillColor(xDataPoint: number | Date, lineColor: string, circleId: string): string {\n let fillColor = lineColor;\n if (nearestCircleToHighlight === xDataPoint || activePoint === circleId) {\n if (!isCircleClicked) {\n fillColor = tokens.colorNeutralBackground1;\n }\n }\n\n return fillColor;\n }\n\n function _drawGraph(\n containerHeight: number,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n xScale: any,\n yScalePrimary: ScaleLinear<number, number>,\n yScaleSecondary: ScaleLinear<number, number> | undefined,\n xElement: SVGElement,\n ): JSXElement[] {\n const points = _addDefaultColors(props.data.lineChartData);\n const { pointOptions, pointLineOptions } = props.data;\n\n const graph: JSXElement[] = [];\n let lineColor: string;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _data.forEach((singleStackedData: Array<any>, index: number) => {\n const yScale = points[index]?.useSecondaryYScale && yScaleSecondary ? yScaleSecondary : yScalePrimary;\n const curveFactory = getCurveFactory(points[index]?.lineOptions?.curve, d3CurveBasis);\n const area = d3Area()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => xScale(d.xVal))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y0((d: any) => yScale(d.values[0]))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y1((d: any) => yScale(d.values[1]))\n .curve(curveFactory);\n const line = d3Line()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .x((d: any) => xScale(d.xVal))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .y((d: any) => yScale(d.values[1]))\n .curve(curveFactory);\n const layerOpacity = _shouldFillToZeroY() ? 0.8 : _opacity[index];\n graph.push(\n <React.Fragment key={`${index}-graph-${_uniqueIdForGraph}`}>\n {props.enableGradient && (\n <defs>\n <linearGradient id={`gradient_${index}`} x1=\"0%\" x2=\"0%\" y1=\"0%\" y2=\"100%\">\n <stop offset=\"0\" stopColor={_colors[index]} />\n <stop offset=\"100%\" stopColor=\"transparent\" />\n </linearGradient>\n </defs>\n )}\n <path\n id={`${index}-line-${_uniqueIdForGraph}`}\n d={line(singleStackedData)!}\n fill={'transparent'}\n strokeWidth={points[index]?.lineOptions?.strokeWidth ?? 3}\n stroke={_colors[index]}\n opacity={_getLineOpacity(points[index]!.legend)}\n onMouseMove={event => _onRectMouseMove(event)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n strokeDasharray={points[index]?.lineOptions?.strokeDasharray}\n strokeDashoffset={points[index]?.lineOptions?.strokeDashoffset}\n strokeLinecap={points[index]?.lineOptions?.strokeLinecap}\n />\n {singleStackedData.length === 1 ? (\n <circle\n id={`${index}-graph-${_uniqueIdForGraph}`}\n cx={xScale(singleStackedData[0].xVal)}\n cy={yScale(singleStackedData[0].values[1])}\n r={6}\n stroke={_colors[index]}\n strokeWidth={3}\n fill={_colors[index]}\n opacity={layerOpacity}\n fillOpacity={_getOpacity(points[index]!.legend)}\n onMouseMove={event => _onRectMouseMove(event)}\n onFocus={event => _handleFocus(event, index, 0, `${_circleId}_${index}`)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n />\n ) : (\n <path\n id={`${index}-graph-${_uniqueIdForGraph}`}\n d={area(singleStackedData)!}\n fill={props.enableGradient ? `url(#gradient_${index})` : _colors[index]}\n opacity={layerOpacity}\n fillOpacity={_getOpacity(points[index]!.legend)}\n onMouseMove={event => _onRectMouseMove(event)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n {...(props.optimizeLargeData && {\n tabIndex: _legendHighlighted(points[index]!.legend) || _noLegendHighlighted() ? 0 : undefined,\n role: 'img',\n 'aria-label': `${points[index].legend}, series ${index + 1} of ${points.length} with ${\n points[index].data.length\n } data points.`,\n })}\n />\n )}\n </React.Fragment>,\n );\n });\n\n const circleRadius = pointOptions && pointOptions.r ? Number(pointOptions.r) : 8;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _data.forEach((singleStackedData: Array<any>, index: number) => {\n if (points.length === index) {\n return;\n }\n const yScale = points[index]?.useSecondaryYScale && yScaleSecondary ? yScaleSecondary : yScalePrimary;\n if (!props.optimizeLargeData || singleStackedData.length === 1) {\n // Render circles for all data points\n graph.push(\n <g\n key={`${index}-dots-${_uniqueIdForGraph}`}\n clipPath=\"url(#clip)\"\n role=\"region\"\n aria-label={`${points[index].legend}, series ${index + 1} of ${points.length} with ${\n points[index].data.length\n } data points.`}\n >\n {singleStackedData.map((singlePoint: DPointType, pointIndex: number) => {\n const circleId = `${_circleId}_${index * _data[0].length + pointIndex}`;\n const xDataPoint = singlePoint.xVal instanceof Date ? singlePoint.xVal.getTime() : singlePoint.xVal;\n lineColor = points[index]!.color!;\n const legend = points[index]!.legend;\n return (\n <circle\n key={circleId}\n id={circleId}\n tabIndex={_legendHighlighted(points[index]!.legend) || _noLegendHighlighted() ? 0 : undefined}\n cx={xScale(singlePoint.xVal)}\n cy={yScale(singlePoint.values[1])}\n stroke={lineColor}\n strokeWidth={3}\n fill={_updateCircleFillColor(xDataPoint, lineColor, circleId)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n {..._getOnClickHandler(points, index, pointIndex)}\n onFocus={event => _handleFocus(event, index, pointIndex, circleId)}\n onBlur={_handleBlur}\n {...getSecureProps(pointOptions)}\n r={_getCircleRadius(xDataPoint, circleRadius, circleId, legend)}\n role=\"img\"\n aria-label={\n (!_hasDuplicateXValues && !_hasMissingXValues && _getAriaLabel(index, pointIndex)) || undefined\n }\n />\n );\n })}\n </g>,\n );\n } else {\n // Render circles for data points close to the mouse pointer only\n singleStackedData.forEach((singlePoint: DPointType, pointIndex: number) => {\n const xDataPoint = singlePoint.xVal instanceof Date ? singlePoint.xVal.getTime() : singlePoint.xVal;\n if (nearestCircleToHighlight === xDataPoint) {\n const circleId = `${_circleId}_${index * _data[0].length + pointIndex}`;\n lineColor = points[index]!.color!;\n const legend = points[index]!.legend;\n graph.push(\n <circle\n key={circleId}\n id={circleId}\n cx={xScale(singlePoint.xVal)}\n cy={yScale(singlePoint.values[1])}\n stroke={lineColor}\n strokeWidth={3}\n fill={_updateCircleFillColor(xDataPoint, lineColor, circleId)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n onFocus={event => _handleFocus(event, index, pointIndex, circleId)}\n {..._getOnClickHandler(points, index, pointIndex)}\n {...getSecureProps(pointOptions)}\n r={_getCircleRadius(xDataPoint, circleRadius, circleId, legend)}\n />,\n );\n }\n });\n }\n });\n graph.push(\n <line\n id={_verticalLineId}\n key={_verticalLineId}\n x1={lineXValue}\n y1={0}\n x2={lineXValue}\n y2={containerHeight}\n strokeWidth={1}\n strokeDasharray={5.5}\n stroke={lineColor!}\n opacity={0.5}\n visibility={displayOfLine}\n {...getSecureProps(pointLineOptions)}\n />,\n );\n return graph;\n }\n\n function _getOnClickHandler(points: LineChartPoints[], index: number, pointIndex: number) {\n if (!_hasDuplicateXValues && !_hasMissingXValues) {\n return {\n onClick: () => _onDataPointClick(points[index]!.data[pointIndex].onDataPointClick!),\n };\n }\n return {};\n }\n\n function _getCircleRadius(xDataPoint: number, circleRadius: number, circleId: string, legend: string): number {\n // Show the circle if no legends are selected or if the point's legend is in the selected legends\n if (!_noLegendHighlighted() && !_legendHighlighted(legend)) {\n return 0;\n }\n\n if (isCircleClicked && nearestCircleToHighlight === xDataPoint) {\n return 1;\n } else if (nearestCircleToHighlight === xDataPoint || activePoint === circleId) {\n return circleRadius;\n } else {\n return 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(legend: string) {\n return _getHighlightedLegend().includes(legend!);\n }\n\n /**\n * This function checks if none of the legends is selected or hovered.\n */\n function _noLegendHighlighted() {\n return _getHighlightedLegend().length === 0;\n }\n\n function _getHighlightedLegend() {\n return selectedLegends.length > 0 ? selectedLegends : activeLegend ? [activeLegend] : [];\n }\n\n function _addDefaultColors(lineChartData?: LineChartPoints[]): LineChartPoints[] {\n if (_hasMissingXValues) {\n // get union of all x values\n const allXValues: Set<string | number> = new Set();\n lineChartData &&\n lineChartData.forEach((line: LineChartPoints) => {\n line.data.forEach((point: LineChartDataPoint) => {\n const xValue = point.x instanceof Date ? point.x.toLocaleString() : point.x;\n allXValues.add(xValue);\n });\n });\n lineChartData &&\n lineChartData.forEach((line: LineChartPointsWithLegend) => {\n allXValues.forEach((xValue: string | number) => {\n const point = line.data.find((item: ILineChartDataPointWithLegend) => {\n return item.x instanceof Date ? item.x.toLocaleString() === xValue : item.x === xValue;\n });\n if (!point) {\n line.data.push({\n x: typeof xValue === 'string' ? new Date(xValue) : xValue,\n y: 0,\n legend: line.legend,\n });\n }\n });\n // sort the data points by x value\n line.data.sort((a: LineChartDataPoint, b: LineChartDataPoint) => {\n const xA = a.x instanceof Date ? a.x.getTime() : a.x;\n const xB = b.x instanceof Date ? b.x.getTime() : b.x;\n return xA < xB ? -1 : xA > xB ? 1 : 0;\n });\n });\n }\n return lineChartData\n ? lineChartData.map((item, index) => {\n let color: string;\n // isInverted property is applicable to v8 themes only\n if (typeof item.color === 'undefined') {\n color = getNextColor(index, 0);\n } else {\n color = getColorFromToken(item.color);\n }\n\n return { ...item, color };\n })\n : [];\n }\n\n function _handleFocus(\n event: React.FocusEvent<SVGCircleElement, Element>,\n lineIndex: number,\n pointIndex: number,\n circleId: string,\n ) {\n let cx = 0;\n let cy = 0;\n\n const targetRect = (event.target as SVGCircleElement).getBoundingClientRect();\n cx = targetRect.left + targetRect.width / 2;\n cy = targetRect.top + targetRect.height / 2;\n _updatePosition(cx, cy);\n\n const { x, y, xAxisCalloutData } = props.data.lineChartData![lineIndex].data[pointIndex];\n const formattedDate = x instanceof Date ? formatDateToLocaleString(x, props.culture, props.useUTC as boolean) : x;\n const found = findCalloutPoints(_calloutPoints, x);\n if (found) {\n // Show details in the callout for the focused point only\n found.values = found.values.filter((e: { y: number }) => e.y === y);\n const filteredValues = _getFilteredLegendValues(found.values);\n\n setPopoverOpen(true);\n setHoverXValue(xAxisCalloutData ? xAxisCalloutData : formattedDate);\n setYValueHover(filteredValues!);\n setStackCalloutProps({ ...found, values: filteredValues });\n setDataPointCalloutProps({ ...found, values: filteredValues });\n setActivePoint(circleId);\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function _getFilteredLegendValues(values: any) {\n return !_noLegendHighlighted()\n ? values.filter((value: { legend: string }) => _legendHighlighted(value.legend))\n : values;\n }\n\n function _handleBlur() {\n setPopoverOpen(false);\n setHoverXValue(undefined);\n setYValueHover([]);\n setStackCalloutProps(undefined);\n setDataPointCalloutProps(undefined);\n setActivePoint('');\n }\n\n function _getAriaLabel(lineIndex: number, pointIndex: number): string {\n const line = props.data.lineChartData![lineIndex];\n const point = line.data[pointIndex];\n const formattedDate =\n point.x instanceof Date ? formatDateToLocaleString(point.x, props.culture, props.useUTC as boolean) : point.x;\n const xValue = point.xAxisCalloutData || formattedDate;\n const legend = line.legend;\n const yValue = point.yAxisCalloutData || point.y;\n return point.callOutAccessibilityData?.ariaLabel || `${xValue}. ${legend}, ${yValue}.`;\n }\n\n function _isChartEmpty(): boolean {\n return !(\n (\n props.data &&\n props.data.lineChartData &&\n props.data.lineChartData.length > 0 &&\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n props.data.lineChartData.filter((item: { data: string | any[] }) => item.data.length === 0).length === 0\n )\n // if all the data sets have no data\n // filtering all items which have no data and checking if the length of the filtered array is 0\n // which means chart is not empty\n );\n }\n\n function _getChartTitle(): string {\n const { chartTitle, lineChartData } = props.data;\n return (chartTitle ? `${chartTitle}. ` : '') + `Area chart with ${lineChartData?.length || 0} data series. `;\n }\n\n function _xCoordinateContainsMultipleY(): boolean {\n const { lineChartData } = props.data;\n if (!lineChartData) {\n return false;\n }\n for (const item of lineChartData) {\n const xValueMap: Record<string, number[]> = {};\n for (const point of item.data) {\n const xValue = point.x instanceof Date ? point.x.toLocaleString() : point.x;\n if (!xValueMap[xValue]) {\n xValueMap[xValue] = [];\n }\n xValueMap[xValue].push(point.y);\n if (xValueMap[xValue].length > 1) {\n return true;\n }\n }\n }\n return false;\n }\n\n function _containsMissingXValues(): boolean {\n const { lineChartData } = props.data;\n if (!lineChartData) {\n return false;\n }\n const allXValues: Set<string | number> = new Set();\n lineChartData.forEach((line: LineChartPoints) => {\n line.data.forEach((point: LineChartDataPoint) => {\n const xValue = point.x instanceof Date ? point.x.toLocaleString() : point.x;\n allXValues.add(xValue);\n });\n });\n // for all x values, check if the x value is present in all series\n let hasMissingValues = false;\n lineChartData.forEach((line: LineChartPoints) => {\n allXValues.forEach((xValue: string | number) => {\n const point = line.data.find((item: LineChartDataPoint) => {\n return item.x instanceof Date ? item.x.toLocaleString() === xValue : item.x === xValue;\n });\n if (!point) {\n hasMissingValues = true;\n }\n });\n });\n return hasMissingValues;\n }\n\n function _shouldFillToZeroY() {\n return props.mode === 'tozeroy' || _containsSecondaryYAxis;\n }\n\n if (!_isChartEmpty()) {\n const { lineChartData } = props.data;\n const points = _addDefaultColors(lineChartData);\n _containsSecondaryYAxis = !!props.secondaryYScaleOptions && points.some(point => point.useSecondaryYScale);\n _createSet = _createDataSet;\n const { colors, opacity, data, calloutPoints } = _createSet(points);\n _calloutPoints = calloutPoints;\n const isXAxisDateType = getXAxisType(points);\n _colors = colors;\n _opacity = opacity;\n _data = data.renderData;\n const legends: JSXElement = _getLegendData(points);\n\n const tickParams = {\n tickValues: props.tickValues,\n tickFormat: props.tickFormat,\n };\n\n const calloutProps: ChartPopoverProps = {\n YValueHover: YValueHover!,\n hoverXValue: hoverXValue!,\n xAxisCalloutAccessibilityData,\n ...props.calloutProps,\n clickPosition,\n isPopoverOpen: isPopoverOpen && !_hasDuplicateXValues && !_hasMissingXValues,\n isCartesian: true,\n customCallout: {\n customizedCallout: _getCustomizedCallout() !== null ? _getCustomizedCallout()! : undefined,\n customCalloutProps: props.calloutPropsPerDataPoint\n ? props.calloutPropsPerDataPoint(dataPointCalloutProps!)\n : undefined,\n },\n isCalloutForStack: true,\n };\n return (\n <CartesianChart\n {...props}\n chartTitle={_getChartTitle()}\n points={points}\n chartType={ChartTypes.AreaChart}\n calloutProps={calloutProps}\n legendBars={legends}\n createYAxis={createNumericYAxis}\n xAxisType={isXAxisDateType ? XAxisTypes.DateAxis : XAxisTypes.NumericAxis}\n tickParams={tickParams}\n maxOfYVal={data.maxOfYVal}\n getGraphData={_getGraphData}\n getDomainNRangeValues={_getDomainNRangeValues}\n createStringYAxis={createStringYAxis}\n getmargins={_getMargins}\n onChartMouseLeave={_handleChartMouseLeave}\n getMinMaxOfYAxis={_getMinMaxOfYAxis}\n enableFirstRenderOptimization={props.enablePerfOptimization && _firstRenderOptimization}\n componentRef={cartesianChartRef}\n /* eslint-disable react/jsx-no-bind */\n // eslint-disable-next-line react/no-children-prop, @typescript-eslint/no-shadow\n children={(props: ChildProps) => {\n _xAxisRectScale = props.xScale;\n const ticks = _xAxisRectScale.ticks();\n const width1 = _xAxisRectScale(ticks[ticks.length - 1]);\n const rectHeight = props.containerHeight! - _margins.top!;\n return (\n <>\n <g>\n <rect\n id={_rectId}\n width={width1}\n height={rectHeight}\n fill={'transparent'}\n onMouseMove={event => _onRectMouseMove(event)}\n onMouseOut={_onRectMouseOut}\n onMouseOver={event => _onRectMouseMove(event)}\n />\n </g>\n <g>{_chart}</g>\n </>\n );\n }}\n />\n );\n }\n return (\n <div id={_emptyChartId} role={'alert'} style={{ opacity: '0' }} aria-label={'Graph has no data to display'} />\n );\n },\n);\nAreaChart.displayName = 'AreaChart';\n"],"names":["React","max","d3Max","bisector","pointer","tokens","area","d3Area","stack","d3Stack","curveMonotoneX","d3CurveBasis","line","d3Line","CartesianChart","calloutData","getXAxisType","ChartTypes","XAxisTypes","getTypeOfAxis","getNextColor","getColorFromToken","getSecureProps","areArraysEqual","getCurveFactory","findNumericMinMaxOfY","createNumericYAxis","domainRangeOfNumericForAreaLineScatterCharts","domainRangeOfDateForAreaLineScatterVerticalBarCharts","createStringYAxis","findCalloutPoints","useId","Legends","formatDateToLocaleString","useImageExport","bisect","d","x","left","InterceptVisibility","AreaChart","forwardRef","props","forwardedRef","_uniqueIdForGraph","_verticalLineId","_circleId","_rectId","_enableComputationOptimization","_firstRenderOptimization","_emptyChartId","_containsSecondaryYAxis","_hasMissingXValues","_containsMissingXValues","_hasDuplicateXValues","_xCoordinateContainsMultipleY","_calloutPoints","_createSet","_colors","_opacity","_data","_chart","_margins","_xAxisRectScale","_isMultiStackChart","cartesianChartRef","legendsRef","_legendsRef","componentRef","hideLegend","selectedLegends","setSelectedLegends","useState","legendProps","activeLegend","setActiveLegend","undefined","hoverXValue","setHoverXValue","YValueHover","setYValueHover","lineXValue","setLineXValue","displayOfLine","setDisplayOfLine","isCircleClicked","setIsCircleClicked","nearestCircleToHighlight","setNearestCircleToHighlight","activePoint","setActivePoint","dataPointCalloutProps","setDataPointCalloutProps","stackCalloutProps","setStackCalloutProps","xAxisCalloutAccessibilityData","setXAxisCalloutAccessibilityData","clickPosition","setClickPosition","y","isPopoverOpen","setPopoverOpen","prevPropsRef","useRef","useEffect","current","prevProps","_getMinMaxOfYAxis","points","yAxisType","useSecondaryYScale","_getDomainNRangeValues","margins","width","chartType","isRTL","xAxisType","barWidth","tickValues","domainNRangeValue","NumericAxis","DateAxis","dStartValue","dEndValue","rStartValue","rEndValue","_getMargins","_onRectMouseMove","mouseEvent","persist","data","lineChartData","_updatePosition","clientX","clientY","xOffset","invert","document","getElementById","i","d0","d1","pointToHighlight","index","axisType","length","x0","point0","point1","Date","getTime","Math","abs","xAxisCalloutData","formattedDate","culture","useUTC","found","_nearestCircleToHighlight","filteredValues","_getFilteredLegendValues","values","_onRectMouseOut","newX","newY","threshold","distance","sqrt","pow","_handleChartMouseLeave","_getDataPoints","keys","dataSet","renderPoints","maxOfYVal","_shouldFillToZeroY","forEach","key","currentLayer","push","xVal","dataValues","dp","layer","renderData","endValue","_createDataSet","enablePerfOptimization","allChartPoints","colors","opacity","calloutPoints","singleChartPoint","color","mapOfXvalToListOfDataPoints","dataPoint","xValue","toLocaleString","Object","value","singleDataset","singleDataPoint","keysLength","keyVal","legend","point","tempArr","valToCheck","filteredChartPoints","filter","id","val","datasetForDuplicateValues","_createDatasetForXCoordinateWithMultipleYValues","filteredDataSet","groupedData","dataPoints","allLegends","item","includes","some","Array","from","Set","flatMap","_getCustomizedCallout","onRenderCalloutPerStack","onRenderCalloutPerDataPoint","_getGraphData","xAxis","yAxis","containerHeight","containerWidth","xElement","yAxisElement","yScaleSecondary","_drawGraph","_onLegendHover","_onLegendLeave","_getLegendData","actions","singleChartData","checkSimilarLegends","leg","title","hoverAction","onMouseOutAction","legends","enabledWrapLines","enabledLegendsWrapLines","onChange","_onLegendSelectionChange","legendRef","event","currentLegend","canSelectMultipleLegends","slice","_onDataPointClick","func","_getOpacity","_legendHighlighted","_noLegendHighlighted","_getLineOpacity","_updateCircleFillColor","xDataPoint","lineColor","circleId","fillColor","colorNeutralBackground1","xScale","yScalePrimary","_addDefaultColors","pointOptions","pointLineOptions","graph","singleStackedData","yScale","curveFactory","lineOptions","curve","y0","y1","layerOpacity","Fragment","enableGradient","defs","linearGradient","x1","x2","y2","stop","offset","stopColor","path","fill","strokeWidth","stroke","onMouseMove","onMouseOut","onMouseOver","strokeDasharray","strokeDashoffset","strokeLinecap","circle","cx","cy","r","fillOpacity","onFocus","_handleFocus","optimizeLargeData","tabIndex","role","circleRadius","Number","g","clipPath","aria-label","map","singlePoint","pointIndex","_getOnClickHandler","onBlur","_handleBlur","_getCircleRadius","_getAriaLabel","visibility","onClick","onDataPointClick","_getHighlightedLegend","allXValues","add","find","sort","a","b","xA","xB","lineIndex","targetRect","target","getBoundingClientRect","top","height","e","yValue","yAxisCalloutData","callOutAccessibilityData","ariaLabel","_isChartEmpty","_getChartTitle","chartTitle","xValueMap","hasMissingValues","mode","secondaryYScaleOptions","isXAxisDateType","tickParams","tickFormat","calloutProps","isCartesian","customCallout","customizedCallout","customCalloutProps","calloutPropsPerDataPoint","isCalloutForStack","legendBars","createYAxis","getGraphData","getDomainNRangeValues","getmargins","onChartMouseLeave","getMinMaxOfYAxis","enableFirstRenderOptimization","children","ticks","width1","rectHeight","rect","div","style","displayName"],"mappings":"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"}
@@ -52,7 +52,6 @@ const useStyles = /*#__PURE__*/ (0, _react.__styles)({
52
52
  B0ocmuz: "f1bnz8pu",
53
53
  qhf8xq: "f1euv43f",
54
54
  fsow6f: "f17mccla",
55
- Bhzewxz: "fr6rvge",
56
55
  De3pzq: "fxugw4r",
57
56
  Beyfa6y: 0,
58
57
  Bbmb7ep: 0,
@@ -78,7 +77,6 @@ const useStyles = /*#__PURE__*/ (0, _react.__styles)({
78
77
  ],
79
78
  ".f1euv43f{position:absolute;}",
80
79
  ".f17mccla{text-align:center;}",
81
- ".fr6rvge{top:var(--spacingVerticalNone);}",
82
80
  ".fxugw4r{background-color:var(--colorNeutralBackground1);}",
83
81
  [
84
82
  ".fq9zq91{border-radius:var(--borderRadiusSmall);}",
@@ -1 +1 @@
1
- {"version":3,"sources":["useAreaChartStyles.styles.js"],"sourcesContent":["'use client';\nimport { makeStyles, mergeClasses } from '@griffel/react';\nimport { getTooltipStyle } from '../../utilities/index';\nexport const areaChartClassNames = {\n tooltip: 'fui-ac__tooltip',\n root: '',\n xAxis: '',\n yAxis: '',\n legendContainer: '',\n hover: '',\n descriptionMessage: '',\n axisTitle: '',\n chartTitle: '',\n opacityChangeOnHover: '',\n shapeStyles: '',\n chartWrapper: '',\n svgTooltip: '',\n chart: '',\n axisAnnotation: '',\n plotContainer: '',\n annotationLayer: ''\n};\nconst useStyles = makeStyles({\n tooltip: getTooltipStyle()\n});\n/**\n * Apply styling to the AreaChart slots based on the state\n */ export const useAreaChartStyles = (props)=>{\n const baseStyles = useStyles();\n return {\n tooltip: mergeClasses(areaChartClassNames.tooltip, baseStyles.tooltip /*props.styles?.tooltip*/ )\n };\n};\n"],"names":["__styles","mergeClasses","getTooltipStyle","areaChartClassNames","tooltip","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","opacityChangeOnHover","shapeStyles","chartWrapper","svgTooltip","chart","axisAnnotation","plotContainer","annotationLayer","useStyles","Bahqtrf","Be2twd7","Bhrd7zp","Bg96gwp","mc9l5x","Beiy3e4","Byoj8tv","uwmqm3","z189sj","z8tnut","B0ocmuz","qhf8xq","fsow6f","Bhzewxz","De3pzq","Beyfa6y","Bbmb7ep","Btl43ni","B7oj6ja","Dimara","Bkecrkj","sj55zd","d","p","useAreaChartStyles","props","baseStyles"],"mappings":"AAAA,YAAY;;;;;;;;;;;;IAGCG,mBAAmB;;;sBAwBG;;;;uBA1BM,gBAAgB;AAElD,4BAA4B;IAC/BC,OAAO,EAAE,iBAAiB;IAC1BC,IAAI,EAAE,EAAE;IACRC,KAAK,EAAE,EAAE;IACTC,KAAK,EAAE,EAAE;IACTC,eAAe,EAAE,EAAE;IACnBC,KAAK,EAAE,EAAE;IACTC,kBAAkB,EAAE,EAAE;IACtBC,SAAS,EAAE,EAAE;IACbC,UAAU,EAAE,EAAE;IACdC,oBAAoB,EAAE,EAAE;IACxBC,WAAW,EAAE,EAAE;IACfC,YAAY,EAAE,EAAE;IAChBC,UAAU,EAAE,EAAE;IACdC,KAAK,EAAE,EAAE;IACTC,cAAc,EAAE,EAAE;IAClBC,aAAa,EAAE,EAAE;IACjBC,eAAe,EAAE;AACrB,CAAC;AACD,MAAMC,SAAS,GAAA,WAAA,GAAGrB,mBAAA,EAAA;IAAAI,OAAA,EAAA;QAAAkB,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;IAAA;AAAA,GAAA;IAAAC,CAAA,EAAA;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;YAAA;YAAA;gBAAAC,CAAA,EAAA,CAAA;YAAA;SAAA;QAAA;QAAA;QAAA;QAAA;QAAA;YAAA;YAAA;gBAAAA,CAAA,EAAA,CAAA;YAAA;SAAA;QAAA;QAAA;KAAA;AAAA,CAEjB,CAAC;AAGS,MAAMC,sBAAsBC,KAAK,IAAG;IAC3C,MAAMC,UAAU,GAAG3B,SAAS,CAAC,CAAC;IAC9B,OAAO;QACHjB,OAAO,MAAEH,mBAAY,EAACE,mBAAmB,CAACC,OAAO,EAAE4C,UAAU,CAAC5C,OAAO,CAAC,uBAAA,EAA0B;IACpG,CAAC;AACL,CAAC"}
1
+ {"version":3,"sources":["useAreaChartStyles.styles.js"],"sourcesContent":["'use client';\nimport { makeStyles, mergeClasses } from '@griffel/react';\nimport { getTooltipStyle } from '../../utilities/index';\nexport const areaChartClassNames = {\n tooltip: 'fui-ac__tooltip',\n root: '',\n xAxis: '',\n yAxis: '',\n legendContainer: '',\n hover: '',\n descriptionMessage: '',\n axisTitle: '',\n chartTitle: '',\n opacityChangeOnHover: '',\n shapeStyles: '',\n chartWrapper: '',\n svgTooltip: '',\n chart: '',\n axisAnnotation: '',\n plotContainer: '',\n annotationLayer: ''\n};\nconst useStyles = makeStyles({\n tooltip: getTooltipStyle()\n});\n/**\n * Apply styling to the AreaChart slots based on the state\n */ export const useAreaChartStyles = (props)=>{\n const baseStyles = useStyles();\n return {\n tooltip: mergeClasses(areaChartClassNames.tooltip, baseStyles.tooltip /*props.styles?.tooltip*/ )\n };\n};\n"],"names":["__styles","mergeClasses","getTooltipStyle","areaChartClassNames","tooltip","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","opacityChangeOnHover","shapeStyles","chartWrapper","svgTooltip","chart","axisAnnotation","plotContainer","annotationLayer","useStyles","Bahqtrf","Be2twd7","Bhrd7zp","Bg96gwp","mc9l5x","Beiy3e4","Byoj8tv","uwmqm3","z189sj","z8tnut","B0ocmuz","qhf8xq","fsow6f","De3pzq","Beyfa6y","Bbmb7ep","Btl43ni","B7oj6ja","Dimara","Bkecrkj","sj55zd","d","p","useAreaChartStyles","props","baseStyles"],"mappings":"AAAA,YAAY;;;;;;;;;;;;IAGCG,mBAAmB;;;sBAwBG;;;;uBA1BM,gBAAgB;AAElD,4BAA4B;IAC/BC,OAAO,EAAE,iBAAiB;IAC1BC,IAAI,EAAE,EAAE;IACRC,KAAK,EAAE,EAAE;IACTC,KAAK,EAAE,EAAE;IACTC,eAAe,EAAE,EAAE;IACnBC,KAAK,EAAE,EAAE;IACTC,kBAAkB,EAAE,EAAE;IACtBC,SAAS,EAAE,EAAE;IACbC,UAAU,EAAE,EAAE;IACdC,oBAAoB,EAAE,EAAE;IACxBC,WAAW,EAAE,EAAE;IACfC,YAAY,EAAE,EAAE;IAChBC,UAAU,EAAE,EAAE;IACdC,KAAK,EAAE,EAAE;IACTC,cAAc,EAAE,EAAE;IAClBC,aAAa,EAAE,EAAE;IACjBC,eAAe,EAAE;AACrB,CAAC;AACD,MAAMC,SAAS,GAAA,WAAA,GAAGrB,mBAAA,EAAA;IAAAI,OAAA,EAAA;QAAAkB,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;IAAA;AAAA,GAAA;IAAAC,CAAA,EAAA;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;YAAA;YAAA;gBAAAC,CAAA,EAAA,CAAA;YAAA;SAAA;QAAA;QAAA;QAAA;QAAA;YAAA;YAAA;gBAAAA,CAAA,EAAA,CAAA;YAAA;SAAA;QAAA;QAAA;KAAA;AAAA,CAEjB,CAAC;AAGS,MAAMC,sBAAsBC,KAAK,IAAG;IAC3C,MAAMC,UAAU,GAAG1B,SAAS,CAAC,CAAC;IAC9B,OAAO;QACHjB,OAAO,MAAEH,mBAAY,EAACE,mBAAmB,CAACC,OAAO,EAAE2C,UAAU,CAAC3C,OAAO,CAAC,uBAAA,EAA0B;IACpG,CAAC;AACL,CAAC"}
@@ -17,6 +17,7 @@ const _d3color = /*#__PURE__*/ _interop_require_wildcard._(require("d3-color"));
17
17
  const _colors = require("../../utilities/colors");
18
18
  const _utilities = require("../../utilities/utilities");
19
19
  const _hooks = require("../../utilities/hooks");
20
+ const _reacttabster = require("@fluentui/react-tabster");
20
21
  function invertHexColor(hex) {
21
22
  const color = _d3color.color(hex);
22
23
  if (!color) {
@@ -50,6 +51,9 @@ const ChartTable = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
50
51
  const { headers, rows, width, height } = props;
51
52
  const { chartContainerRef: _rootElem } = (0, _hooks.useImageExport)(props.componentRef, true, false);
52
53
  const classes = (0, _useChartTableStylesstyles.useChartTableStyles)(props);
54
+ const arrowAttributes = (0, _reacttabster.useArrowNavigationGroup)({
55
+ axis: 'grid'
56
+ });
53
57
  if (!headers || headers.length === 0) {
54
58
  return /*#__PURE__*/ _react.createElement("div", null, "No data available");
55
59
  }
@@ -112,7 +116,8 @@ const ChartTable = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
112
116
  className: classes.table,
113
117
  style: {
114
118
  width: width ? `${width}px` : '100%'
115
- }
119
+ },
120
+ ...arrowAttributes
116
121
  }, /*#__PURE__*/ _react.createElement("thead", null, /*#__PURE__*/ _react.createElement("tr", null, headers.map((header, idx)=>{
117
122
  const style = {
118
123
  ...header === null || header === void 0 ? void 0 : header.style
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/ChartTable/ChartTable.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { ChartTableProps } from './ChartTable.types';\nimport { useChartTableStyles } from './useChartTableStyles.styles';\nimport { tokens } from '@fluentui/react-theme';\nimport * as d3 from 'd3-color';\nimport { getColorContrast } from '../../utilities/colors';\nimport { resolveCSSVariables } from '../../utilities/utilities';\nimport { useImageExport } from '../../utilities/hooks';\n\nfunction invertHexColor(hex: string): string {\n const color = d3.color(hex);\n if (!color) {\n return tokens.colorNeutralForeground1!;\n }\n const rgb = color.rgb();\n return d3.rgb(255 - rgb.r, 255 - rgb.g, 255 - rgb.b).formatHex();\n}\n\nfunction getSafeBackgroundColor(chartContainer: HTMLElement, foreground?: string, background?: string): string {\n const fallbackFg = tokens.colorNeutralForeground1;\n const fallbackBg = tokens.colorNeutralBackground1;\n if (!chartContainer) {\n return fallbackBg;\n }\n\n const resolvedFg = resolveCSSVariables(chartContainer, foreground || fallbackFg);\n const resolvedBg = resolveCSSVariables(chartContainer, background || fallbackBg);\n\n const fg = d3.color(resolvedFg);\n const bg = d3.color(resolvedBg);\n\n if (!fg || !bg) {\n return resolvedBg;\n }\n const contrast = getColorContrast(fg.formatHex(), bg.formatHex());\n if (contrast >= 3) {\n return bg.formatHex();\n }\n\n const invertedBg = invertHexColor(bg.formatHex());\n const invertedContrast = getColorContrast(fg.formatHex(), invertedBg);\n return invertedContrast >= 3 ? invertedBg : fallbackBg;\n}\n\nexport const ChartTable: React.FunctionComponent<ChartTableProps> = React.forwardRef<HTMLDivElement, ChartTableProps>(\n (props, forwardedRef) => {\n const { headers, rows, width, height } = props;\n const { chartContainerRef: _rootElem } = useImageExport(props.componentRef, true, false);\n const classes = useChartTableStyles(props);\n\n if (!headers || headers.length === 0) {\n return <div>No data available</div>;\n }\n\n const bgColorSet = new Set<string>();\n headers.forEach(header => {\n const bg = header?.style?.backgroundColor;\n const normalized = d3.color(bg || '')?.formatHex();\n if (normalized) {\n bgColorSet.add(normalized);\n }\n });\n let sharedBackgroundColor: string | undefined;\n let useSharedBackground = false;\n\n /*\n If we have only one or two unique background colors, we can consider using a shared background color\n for the table headers. This is to ensure better contrast with the foreground text.\n For size 1, we will consider that as default color if it satisfies the contrast ratio.\n There could also be a scenario where backgroundcolor array is of size 2, for eg: [\"dimsgray\", \"gray\"],\n which will assign 1st column header bg color to dimsgray and rest to gray. so our logic of shared background\n color won't run here. So will consider for size 2 as well.\n For size greater than this, we will consider that user wants different colors and will let color contrast fail\n if any.\n */\n if (bgColorSet.size === 1 || bgColorSet.size === 2) {\n const candidateBg = bgColorSet.size === 1 ? Array.from(bgColorSet)[0] : Array.from(bgColorSet)[1];\n for (const header of headers) {\n const fg = header?.style?.color;\n if (fg && getColorContrast(fg, candidateBg) >= 3) {\n sharedBackgroundColor = candidateBg;\n useSharedBackground = true;\n break;\n }\n }\n }\n\n return (\n <div\n ref={el => {\n _rootElem.current = el;\n }}\n className={classes.root as string}\n style={{ height: height ? `${height}px` : '650px', overflow: 'hidden' }}\n >\n <svg width={width ?? '100%'} height={height ?? '650px'}>\n <foreignObject x=\"0\" y=\"0\" width=\"100%\" height=\"100%\">\n <div\n style={{\n maxHeight: height ? `${height}px` : '650px',\n overflowY: 'auto',\n overflowX: 'auto',\n }}\n >\n <table\n className={classes.table}\n style={{\n width: width ? `${width}px` : '100%',\n }}\n >\n <thead>\n <tr>\n {headers.map((header, idx) => {\n const style = { ...header?.style };\n const fg = style.color;\n const bg = style.backgroundColor;\n\n if (useSharedBackground) {\n style.backgroundColor = sharedBackgroundColor;\n } else if (fg || bg) {\n style.backgroundColor = getSafeBackgroundColor(_rootElem.current!, fg, bg);\n }\n return (\n <th key={idx} className={classes.headerCell} style={style} tabIndex={0}>\n {header.value}\n </th>\n );\n })}\n </tr>\n </thead>\n {rows && rows.length > 0 && (\n <tbody>\n {rows.map((row, rowIdx) => (\n <tr key={rowIdx}>\n {row.map((cell, colIdx) => {\n const style = { ...cell?.style };\n const fg = style.color;\n const bg = style.backgroundColor;\n if (fg || bg) {\n style.backgroundColor = getSafeBackgroundColor(_rootElem.current!, fg, bg);\n }\n return (\n <td key={colIdx} className={classes.bodyCell} style={style} tabIndex={0}>\n {cell.value}\n </td>\n );\n })}\n </tr>\n ))}\n </tbody>\n )}\n </table>\n </div>\n </foreignObject>\n </svg>\n </div>\n );\n },\n);\n\nChartTable.displayName = 'ChartTable';\n"],"names":["React","useChartTableStyles","tokens","d3","getColorContrast","resolveCSSVariables","useImageExport","invertHexColor","hex","color","colorNeutralForeground1","rgb","r","g","b","formatHex","getSafeBackgroundColor","chartContainer","foreground","background","fallbackFg","fallbackBg","colorNeutralBackground1","resolvedFg","resolvedBg","fg","bg","contrast","invertedBg","invertedContrast","ChartTable","forwardRef","props","forwardedRef","headers","rows","width","height","chartContainerRef","_rootElem","componentRef","classes","length","div","bgColorSet","Set","forEach","header","style","backgroundColor","normalized","add","sharedBackgroundColor","useSharedBackground","size","candidateBg","Array","from","ref","el","current","className","root","overflow","svg","foreignObject","x","y","maxHeight","overflowY","overflowX","table","thead","tr","map","idx","th","key","headerCell","tabIndex","value","tbody","row","rowIdx","cell","colIdx","td","bodyCell","displayName"],"mappings":"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"}
1
+ {"version":3,"sources":["../src/components/ChartTable/ChartTable.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { ChartTableProps } from './ChartTable.types';\nimport { useChartTableStyles } from './useChartTableStyles.styles';\nimport { tokens } from '@fluentui/react-theme';\nimport * as d3 from 'd3-color';\nimport { getColorContrast } from '../../utilities/colors';\nimport { resolveCSSVariables } from '../../utilities/utilities';\nimport { useImageExport } from '../../utilities/hooks';\nimport { useArrowNavigationGroup } from '@fluentui/react-tabster';\n\nfunction invertHexColor(hex: string): string {\n const color = d3.color(hex);\n if (!color) {\n return tokens.colorNeutralForeground1!;\n }\n const rgb = color.rgb();\n return d3.rgb(255 - rgb.r, 255 - rgb.g, 255 - rgb.b).formatHex();\n}\n\nfunction getSafeBackgroundColor(chartContainer: HTMLElement, foreground?: string, background?: string): string {\n const fallbackFg = tokens.colorNeutralForeground1;\n const fallbackBg = tokens.colorNeutralBackground1;\n if (!chartContainer) {\n return fallbackBg;\n }\n\n const resolvedFg = resolveCSSVariables(chartContainer, foreground || fallbackFg);\n const resolvedBg = resolveCSSVariables(chartContainer, background || fallbackBg);\n\n const fg = d3.color(resolvedFg);\n const bg = d3.color(resolvedBg);\n\n if (!fg || !bg) {\n return resolvedBg;\n }\n const contrast = getColorContrast(fg.formatHex(), bg.formatHex());\n if (contrast >= 3) {\n return bg.formatHex();\n }\n\n const invertedBg = invertHexColor(bg.formatHex());\n const invertedContrast = getColorContrast(fg.formatHex(), invertedBg);\n return invertedContrast >= 3 ? invertedBg : fallbackBg;\n}\n\nexport const ChartTable: React.FunctionComponent<ChartTableProps> = React.forwardRef<HTMLDivElement, ChartTableProps>(\n (props, forwardedRef) => {\n const { headers, rows, width, height } = props;\n const { chartContainerRef: _rootElem } = useImageExport(props.componentRef, true, false);\n const classes = useChartTableStyles(props);\n const arrowAttributes = useArrowNavigationGroup({ axis: 'grid' });\n\n if (!headers || headers.length === 0) {\n return <div>No data available</div>;\n }\n\n const bgColorSet = new Set<string>();\n headers.forEach(header => {\n const bg = header?.style?.backgroundColor;\n const normalized = d3.color(bg || '')?.formatHex();\n if (normalized) {\n bgColorSet.add(normalized);\n }\n });\n let sharedBackgroundColor: string | undefined;\n let useSharedBackground = false;\n\n /*\n If we have only one or two unique background colors, we can consider using a shared background color\n for the table headers. This is to ensure better contrast with the foreground text.\n For size 1, we will consider that as default color if it satisfies the contrast ratio.\n There could also be a scenario where backgroundcolor array is of size 2, for eg: [\"dimsgray\", \"gray\"],\n which will assign 1st column header bg color to dimsgray and rest to gray. so our logic of shared background\n color won't run here. So will consider for size 2 as well.\n For size greater than this, we will consider that user wants different colors and will let color contrast fail\n if any.\n */\n if (bgColorSet.size === 1 || bgColorSet.size === 2) {\n const candidateBg = bgColorSet.size === 1 ? Array.from(bgColorSet)[0] : Array.from(bgColorSet)[1];\n for (const header of headers) {\n const fg = header?.style?.color;\n if (fg && getColorContrast(fg, candidateBg) >= 3) {\n sharedBackgroundColor = candidateBg;\n useSharedBackground = true;\n break;\n }\n }\n }\n\n return (\n <div\n ref={el => {\n _rootElem.current = el;\n }}\n className={classes.root as string}\n style={{ height: height ? `${height}px` : '650px', overflow: 'hidden' }}\n >\n <svg width={width ?? '100%'} height={height ?? '650px'}>\n <foreignObject x=\"0\" y=\"0\" width=\"100%\" height=\"100%\">\n <div\n style={{\n maxHeight: height ? `${height}px` : '650px',\n overflowY: 'auto',\n overflowX: 'auto',\n }}\n >\n <table\n className={classes.table}\n style={{\n width: width ? `${width}px` : '100%',\n }}\n {...arrowAttributes}\n >\n <thead>\n <tr>\n {headers.map((header, idx) => {\n const style = { ...header?.style };\n const fg = style.color;\n const bg = style.backgroundColor;\n\n if (useSharedBackground) {\n style.backgroundColor = sharedBackgroundColor;\n } else if (fg || bg) {\n style.backgroundColor = getSafeBackgroundColor(_rootElem.current!, fg, bg);\n }\n return (\n <th key={idx} className={classes.headerCell} style={style} tabIndex={0}>\n {header.value}\n </th>\n );\n })}\n </tr>\n </thead>\n {rows && rows.length > 0 && (\n <tbody>\n {rows.map((row, rowIdx) => (\n <tr key={rowIdx}>\n {row.map((cell, colIdx) => {\n const style = { ...cell?.style };\n const fg = style.color;\n const bg = style.backgroundColor;\n if (fg || bg) {\n style.backgroundColor = getSafeBackgroundColor(_rootElem.current!, fg, bg);\n }\n return (\n <td key={colIdx} className={classes.bodyCell} style={style} tabIndex={0}>\n {cell.value}\n </td>\n );\n })}\n </tr>\n ))}\n </tbody>\n )}\n </table>\n </div>\n </foreignObject>\n </svg>\n </div>\n );\n },\n);\n\nChartTable.displayName = 'ChartTable';\n"],"names":["React","useChartTableStyles","tokens","d3","getColorContrast","resolveCSSVariables","useImageExport","useArrowNavigationGroup","invertHexColor","hex","color","colorNeutralForeground1","rgb","r","g","b","formatHex","getSafeBackgroundColor","chartContainer","foreground","background","fallbackFg","fallbackBg","colorNeutralBackground1","resolvedFg","resolvedBg","fg","bg","contrast","invertedBg","invertedContrast","ChartTable","forwardRef","props","forwardedRef","headers","rows","width","height","chartContainerRef","_rootElem","componentRef","classes","arrowAttributes","axis","length","div","bgColorSet","Set","forEach","header","style","backgroundColor","normalized","add","sharedBackgroundColor","useSharedBackground","size","candidateBg","Array","from","ref","el","current","className","root","overflow","svg","foreignObject","x","y","maxHeight","overflowY","overflowX","table","thead","tr","map","idx","th","key","headerCell","tabIndex","value","tbody","row","rowIdx","cell","colIdx","td","bodyCell","displayName"],"mappings":"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"}