@fluentui/react-charts 9.1.10 → 9.2.1
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.
- package/CHANGELOG.md +41 -2
- package/dist/index.d.ts +44 -3
- package/lib/AreaChart.js.map +1 -1
- package/lib/CartesianChart.js.map +1 -1
- package/lib/DeclarativeChart.js.map +1 -1
- package/lib/DonutChart.js.map +1 -1
- package/lib/FunnelChart.js.map +1 -1
- package/lib/GanttChart.js.map +1 -1
- package/lib/GaugeChart.js.map +1 -1
- package/lib/GroupedVerticalBarChart.js.map +1 -1
- package/lib/HeatMapChart.js.map +1 -1
- package/lib/HorizontalBarChart.js.map +1 -1
- package/lib/HorizontalBarChartWithAxis.js.map +1 -1
- package/lib/Legends.js.map +1 -1
- package/lib/LineChart.js.map +1 -1
- package/lib/Popover.js.map +1 -1
- package/lib/ResponsiveContainer.js.map +1 -1
- package/lib/SankeyChart.js.map +1 -1
- package/lib/ScatterChart.js.map +1 -1
- package/lib/Sparkline.js.map +1 -1
- package/lib/VerticalBarChart.js.map +1 -1
- package/lib/VerticalStackedBarChart.js.map +1 -1
- package/lib/components/AreaChart/AreaChart.js +11 -3
- package/lib/components/AreaChart/AreaChart.js.map +1 -1
- package/lib/components/AreaChart/AreaChart.types.js.map +1 -1
- package/lib/components/AreaChart/index.js.map +1 -1
- package/lib/components/AreaChart/useAreaChartStyles.styles.js +1 -2
- package/lib/components/AreaChart/useAreaChartStyles.styles.raw.js +41 -0
- package/lib/components/AreaChart/useAreaChartStyles.styles.raw.js.map +1 -0
- package/lib/components/CommonComponents/CartesianChart.js +2 -1
- package/lib/components/CommonComponents/CartesianChart.js.map +1 -1
- package/lib/components/CommonComponents/CartesianChart.types.js.map +1 -1
- package/lib/components/CommonComponents/ChartPopover.js.map +1 -1
- package/lib/components/CommonComponents/ChartPopover.types.js.map +1 -1
- package/lib/components/CommonComponents/index.js.map +1 -1
- package/lib/components/CommonComponents/useCartesianChartStyles.styles.js +1 -2
- package/lib/components/CommonComponents/useCartesianChartStyles.styles.raw.js +128 -0
- package/lib/components/CommonComponents/useCartesianChartStyles.styles.raw.js.map +1 -0
- package/lib/components/CommonComponents/useChartPopoverStyles.styles.js +1 -2
- package/lib/components/CommonComponents/useChartPopoverStyles.styles.raw.js +126 -0
- package/lib/components/CommonComponents/useChartPopoverStyles.styles.raw.js.map +1 -0
- package/lib/components/DeclarativeChart/DeclarativeChart.js +15 -7
- package/lib/components/DeclarativeChart/DeclarativeChart.js.map +1 -1
- package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js +90 -29
- package/lib/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
- package/lib/components/DeclarativeChart/imageExporter.js +1 -0
- package/lib/components/DeclarativeChart/imageExporter.js.map +1 -1
- package/lib/components/DeclarativeChart/index.js.map +1 -1
- package/lib/components/DonutChart/Arc/Arc.js.map +1 -1
- package/lib/components/DonutChart/Arc/Arc.types.js.map +1 -1
- package/lib/components/DonutChart/Arc/index.js.map +1 -1
- package/lib/components/DonutChart/Arc/useArcStyles.styles.js +1 -2
- package/lib/components/DonutChart/Arc/useArcStyles.styles.raw.js +44 -0
- package/lib/components/DonutChart/Arc/useArcStyles.styles.raw.js.map +1 -0
- package/lib/components/DonutChart/DonutChart.js +11 -3
- package/lib/components/DonutChart/DonutChart.js.map +1 -1
- package/lib/components/DonutChart/DonutChart.types.js.map +1 -1
- package/lib/components/DonutChart/Pie/Pie.js.map +1 -1
- package/lib/components/DonutChart/Pie/Pie.types.js.map +1 -1
- package/lib/components/DonutChart/Pie/index.js.map +1 -1
- package/lib/components/DonutChart/Pie/usePieStyles.styles.js +1 -2
- package/lib/components/DonutChart/Pie/usePieStyles.styles.raw.js +29 -0
- package/lib/components/DonutChart/Pie/usePieStyles.styles.raw.js.map +1 -0
- package/lib/components/DonutChart/index.js.map +1 -1
- package/lib/components/DonutChart/useDonutChartStyles.styles.js +1 -2
- package/lib/components/DonutChart/useDonutChartStyles.styles.raw.js +45 -0
- package/lib/components/DonutChart/useDonutChartStyles.styles.raw.js.map +1 -0
- package/lib/components/FunnelChart/FunnelChart.js +10 -1
- package/lib/components/FunnelChart/FunnelChart.js.map +1 -1
- package/lib/components/FunnelChart/FunnelChart.types.js.map +1 -1
- package/lib/components/FunnelChart/funnelGeometry.js.map +1 -1
- package/lib/components/FunnelChart/index.js.map +1 -1
- package/lib/components/FunnelChart/useFunnelChartStyles.styles.js +1 -2
- package/lib/components/FunnelChart/useFunnelChartStyles.styles.raw.js +51 -0
- package/lib/components/FunnelChart/useFunnelChartStyles.styles.raw.js.map +1 -0
- package/lib/components/GanttChart/GanttChart.js +19 -2
- package/lib/components/GanttChart/GanttChart.js.map +1 -1
- package/lib/components/GanttChart/GanttChart.types.js.map +1 -1
- package/lib/components/GanttChart/index.js.map +1 -1
- package/lib/components/GanttChart/useGanttChartStyles.styles.js +1 -2
- package/lib/components/GanttChart/useGanttChartStyles.styles.raw.js +23 -0
- package/lib/components/GanttChart/useGanttChartStyles.styles.raw.js.map +1 -0
- package/lib/components/GaugeChart/GaugeChart.js +9 -2
- package/lib/components/GaugeChart/GaugeChart.js.map +1 -1
- package/lib/components/GaugeChart/GaugeChart.types.js.map +1 -1
- package/lib/components/GaugeChart/index.js.map +1 -1
- package/lib/components/GaugeChart/useGaugeChartStyles.styles.js +1 -2
- package/lib/components/GaugeChart/useGaugeChartStyles.styles.raw.js +142 -0
- package/lib/components/GaugeChart/useGaugeChartStyles.styles.raw.js.map +1 -0
- package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +70 -58
- package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
- package/lib/components/GroupedVerticalBarChart/GroupedVerticalBarChart.types.js.map +1 -1
- package/lib/components/GroupedVerticalBarChart/index.js.map +1 -1
- package/lib/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.js +1 -2
- package/lib/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.raw.js +53 -0
- package/lib/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.raw.js.map +1 -0
- package/lib/components/HeatMapChart/HeatMapChart.js +11 -3
- package/lib/components/HeatMapChart/HeatMapChart.js.map +1 -1
- package/lib/components/HeatMapChart/HeatMapChart.types.js.map +1 -1
- package/lib/components/HeatMapChart/index.js.map +1 -1
- package/lib/components/HeatMapChart/useHeatMapChartStyles.styles.js +1 -2
- package/lib/components/HeatMapChart/useHeatMapChartStyles.styles.raw.js +38 -0
- package/lib/components/HeatMapChart/useHeatMapChartStyles.styles.raw.js.map +1 -0
- package/lib/components/HorizontalBarChart/HorizontalBarChart.js +23 -26
- package/lib/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
- package/lib/components/HorizontalBarChart/HorizontalBarChart.types.js.map +1 -1
- package/lib/components/HorizontalBarChart/index.js.map +1 -1
- package/lib/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.js +1 -2
- package/lib/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.raw.js +120 -0
- package/lib/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.raw.js.map +1 -0
- package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +9 -2
- package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
- package/lib/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.types.js.map +1 -1
- package/lib/components/HorizontalBarChartWithAxis/index.js.map +1 -1
- package/lib/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.js +1 -2
- package/lib/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.raw.js +39 -0
- package/lib/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.raw.js.map +1 -0
- package/lib/components/Legends/Legends.js +28 -10
- package/lib/components/Legends/Legends.js.map +1 -1
- package/lib/components/Legends/Legends.types.js.map +1 -1
- package/lib/components/Legends/OverflowMenu.js.map +1 -1
- package/lib/components/Legends/index.js.map +1 -1
- package/lib/components/Legends/shape.js.map +1 -1
- package/lib/components/Legends/useLegendsStyles.styles.js +57 -14
- package/lib/components/Legends/useLegendsStyles.styles.js.map +1 -1
- package/lib/components/Legends/useLegendsStyles.styles.raw.js +138 -0
- package/lib/components/Legends/useLegendsStyles.styles.raw.js.map +1 -0
- package/lib/components/LineChart/LineChart.js +9 -2
- package/lib/components/LineChart/LineChart.js.map +1 -1
- package/lib/components/LineChart/LineChart.types.js.map +1 -1
- package/lib/components/LineChart/eventAnnotation/EventAnnotation.js.map +1 -1
- package/lib/components/LineChart/eventAnnotation/LabelLink.js.map +1 -1
- package/lib/components/LineChart/eventAnnotation/Textbox.js.map +1 -1
- package/lib/components/LineChart/index.js.map +1 -1
- package/lib/components/LineChart/useLineChartStyles.styles.js +1 -2
- package/lib/components/LineChart/useLineChartStyles.styles.raw.js +52 -0
- package/lib/components/LineChart/useLineChartStyles.styles.raw.js.map +1 -0
- package/lib/components/ResponsiveContainer/ResponsiveContainer.js.map +1 -1
- package/lib/components/ResponsiveContainer/ResponsiveContainer.types.js.map +1 -1
- package/lib/components/ResponsiveContainer/index.js.map +1 -1
- package/lib/components/ResponsiveContainer/useResponsiveChildStyles.styles.js +1 -2
- package/lib/components/ResponsiveContainer/useResponsiveChildStyles.styles.raw.js +28 -0
- package/lib/components/ResponsiveContainer/useResponsiveChildStyles.styles.raw.js.map +1 -0
- package/lib/components/ResponsiveContainer/withResponsiveContainer.js.map +1 -1
- package/lib/components/SankeyChart/SankeyChart.js +5 -1
- package/lib/components/SankeyChart/SankeyChart.js.map +1 -1
- package/lib/components/SankeyChart/SankeyChart.types.js.map +1 -1
- package/lib/components/SankeyChart/index.js.map +1 -1
- package/lib/components/SankeyChart/useSankeyChartStyles.styles.js +1 -2
- package/lib/components/SankeyChart/useSankeyChartStyles.styles.raw.js +77 -0
- package/lib/components/SankeyChart/useSankeyChartStyles.styles.raw.js.map +1 -0
- package/lib/components/ScatterChart/ScatterChart.js +11 -3
- package/lib/components/ScatterChart/ScatterChart.js.map +1 -1
- package/lib/components/ScatterChart/ScatterChart.types.js.map +1 -1
- package/lib/components/ScatterChart/index.js.map +1 -1
- package/lib/components/ScatterChart/useScatterChartStyles.styles.js +1 -2
- package/lib/components/ScatterChart/useScatterChartStyles.styles.raw.js +43 -0
- package/lib/components/ScatterChart/useScatterChartStyles.styles.raw.js.map +1 -0
- package/lib/components/Sparkline/Sparkline.js.map +1 -1
- package/lib/components/Sparkline/Sparkline.types.js.map +1 -1
- package/lib/components/Sparkline/index.js.map +1 -1
- package/lib/components/Sparkline/useSparklineStyles.styles.js +1 -2
- package/lib/components/Sparkline/useSparklineStyles.styles.raw.js +30 -0
- package/lib/components/Sparkline/useSparklineStyles.styles.raw.js.map +1 -0
- package/lib/components/VerticalBarChart/VerticalBarChart.js +62 -28
- package/lib/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
- package/lib/components/VerticalBarChart/VerticalBarChart.types.js.map +1 -1
- package/lib/components/VerticalBarChart/index.js.map +1 -1
- package/lib/components/VerticalBarChart/useVerticalBarChartStyles.styles.js +1 -2
- package/lib/components/VerticalBarChart/useVerticalBarChartStyles.styles.raw.js +58 -0
- package/lib/components/VerticalBarChart/useVerticalBarChartStyles.styles.raw.js.map +1 -0
- package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js +22 -8
- package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
- package/lib/components/VerticalStackedBarChart/VerticalStackedBarChart.types.js.map +1 -1
- package/lib/components/VerticalStackedBarChart/index.js.map +1 -1
- package/lib/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js +1 -2
- package/lib/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.raw.js +49 -0
- package/lib/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.raw.js.map +1 -0
- package/lib/index.js.map +1 -1
- package/lib/types/DataPoint.js.map +1 -1
- package/lib/types/EventAnnotation.js.map +1 -1
- package/lib/types/LegendDataItem.js.map +1 -1
- package/lib/types/index.js.map +1 -1
- package/lib/utilities/FocusableTooltipText.js.map +1 -1
- package/lib/utilities/KeyCodes.js.map +1 -1
- package/lib/utilities/SVGTooltipText.js +2 -0
- package/lib/utilities/SVGTooltipText.js.map +1 -1
- package/lib/utilities/async-utils.js.map +1 -1
- package/lib/utilities/colors.js.map +1 -1
- package/lib/utilities/getWindow.js.map +1 -1
- package/lib/utilities/image-export-utils.js +256 -0
- package/lib/utilities/image-export-utils.js.map +1 -0
- package/lib/utilities/index.js.map +1 -1
- package/lib/utilities/overflow-utils.js.map +1 -1
- package/lib/utilities/string.js.map +1 -1
- package/lib/utilities/test-data.js.map +1 -1
- package/lib/utilities/utilities.js +50 -5
- package/lib/utilities/utilities.js.map +1 -1
- package/lib/utilities/vbc-utils.js.map +1 -1
- package/lib-commonjs/AreaChart.js.map +1 -1
- package/lib-commonjs/CartesianChart.js.map +1 -1
- package/lib-commonjs/DeclarativeChart.js.map +1 -1
- package/lib-commonjs/DonutChart.js.map +1 -1
- package/lib-commonjs/FunnelChart.js.map +1 -1
- package/lib-commonjs/GanttChart.js.map +1 -1
- package/lib-commonjs/GaugeChart.js.map +1 -1
- package/lib-commonjs/GroupedVerticalBarChart.js.map +1 -1
- package/lib-commonjs/HeatMapChart.js.map +1 -1
- package/lib-commonjs/HorizontalBarChart.js.map +1 -1
- package/lib-commonjs/HorizontalBarChartWithAxis.js.map +1 -1
- package/lib-commonjs/Legends.js.map +1 -1
- package/lib-commonjs/LineChart.js.map +1 -1
- package/lib-commonjs/Popover.js.map +1 -1
- package/lib-commonjs/ResponsiveContainer.js.map +1 -1
- package/lib-commonjs/SankeyChart.js.map +1 -1
- package/lib-commonjs/ScatterChart.js.map +1 -1
- package/lib-commonjs/Sparkline.js.map +1 -1
- package/lib-commonjs/VerticalBarChart.js.map +1 -1
- package/lib-commonjs/VerticalStackedBarChart.js.map +1 -1
- package/lib-commonjs/components/AreaChart/AreaChart.js +10 -2
- package/lib-commonjs/components/AreaChart/AreaChart.js.map +1 -1
- package/lib-commonjs/components/AreaChart/AreaChart.types.js.map +1 -1
- package/lib-commonjs/components/AreaChart/index.js.map +1 -1
- package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.js +1 -1
- package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.js.map +1 -1
- package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.raw.js +57 -0
- package/lib-commonjs/components/AreaChart/useAreaChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/CommonComponents/CartesianChart.js +2 -1
- package/lib-commonjs/components/CommonComponents/CartesianChart.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/CartesianChart.types.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/ChartPopover.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/ChartPopover.types.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/index.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.js +1 -1
- package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.raw.js +142 -0
- package/lib-commonjs/components/CommonComponents/useCartesianChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/CommonComponents/useChartPopoverStyles.styles.js +1 -1
- package/lib-commonjs/components/CommonComponents/useChartPopoverStyles.styles.js.map +1 -1
- package/lib-commonjs/components/CommonComponents/useChartPopoverStyles.styles.raw.js +140 -0
- package/lib-commonjs/components/CommonComponents/useChartPopoverStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/DeclarativeChart/DeclarativeChart.js +14 -6
- package/lib-commonjs/components/DeclarativeChart/DeclarativeChart.js.map +1 -1
- package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js +93 -29
- package/lib-commonjs/components/DeclarativeChart/PlotlySchemaAdapter.js.map +1 -1
- package/lib-commonjs/components/DeclarativeChart/imageExporter.js +1 -0
- package/lib-commonjs/components/DeclarativeChart/imageExporter.js.map +1 -1
- package/lib-commonjs/components/DeclarativeChart/index.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Arc/Arc.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Arc/Arc.types.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Arc/index.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Arc/useArcStyles.styles.js +1 -1
- package/lib-commonjs/components/DonutChart/Arc/useArcStyles.styles.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Arc/useArcStyles.styles.raw.js +58 -0
- package/lib-commonjs/components/DonutChart/Arc/useArcStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/DonutChart/DonutChart.js +10 -2
- package/lib-commonjs/components/DonutChart/DonutChart.js.map +1 -1
- package/lib-commonjs/components/DonutChart/DonutChart.types.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Pie/Pie.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Pie/Pie.types.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Pie/index.js.map +1 -1
- package/lib-commonjs/components/DonutChart/Pie/usePieStyles.styles.js +1 -1
- package/lib-commonjs/components/DonutChart/Pie/usePieStyles.styles.raw.js +43 -0
- package/lib-commonjs/components/DonutChart/Pie/usePieStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/DonutChart/index.js.map +1 -1
- package/lib-commonjs/components/DonutChart/useDonutChartStyles.styles.js +1 -1
- package/lib-commonjs/components/DonutChart/useDonutChartStyles.styles.raw.js +59 -0
- package/lib-commonjs/components/DonutChart/useDonutChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/FunnelChart/FunnelChart.js +10 -1
- package/lib-commonjs/components/FunnelChart/FunnelChart.js.map +1 -1
- package/lib-commonjs/components/FunnelChart/FunnelChart.types.js.map +1 -1
- package/lib-commonjs/components/FunnelChart/funnelGeometry.js.map +1 -1
- package/lib-commonjs/components/FunnelChart/index.js.map +1 -1
- package/lib-commonjs/components/FunnelChart/useFunnelChartStyles.styles.js +1 -1
- package/lib-commonjs/components/FunnelChart/useFunnelChartStyles.styles.js.map +1 -1
- package/lib-commonjs/components/FunnelChart/useFunnelChartStyles.styles.raw.js +65 -0
- package/lib-commonjs/components/FunnelChart/useFunnelChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/GanttChart/GanttChart.js +18 -1
- package/lib-commonjs/components/GanttChart/GanttChart.js.map +1 -1
- package/lib-commonjs/components/GanttChart/GanttChart.types.js.map +1 -1
- package/lib-commonjs/components/GanttChart/index.js.map +1 -1
- package/lib-commonjs/components/GanttChart/useGanttChartStyles.styles.js +1 -1
- package/lib-commonjs/components/GanttChart/useGanttChartStyles.styles.raw.js +39 -0
- package/lib-commonjs/components/GanttChart/useGanttChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/GaugeChart/GaugeChart.js +9 -2
- package/lib-commonjs/components/GaugeChart/GaugeChart.js.map +1 -1
- package/lib-commonjs/components/GaugeChart/GaugeChart.types.js.map +1 -1
- package/lib-commonjs/components/GaugeChart/index.js.map +1 -1
- package/lib-commonjs/components/GaugeChart/useGaugeChartStyles.styles.js +1 -1
- package/lib-commonjs/components/GaugeChart/useGaugeChartStyles.styles.js.map +1 -1
- package/lib-commonjs/components/GaugeChart/useGaugeChartStyles.styles.raw.js +160 -0
- package/lib-commonjs/components/GaugeChart/useGaugeChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js +70 -58
- package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.js.map +1 -1
- package/lib-commonjs/components/GroupedVerticalBarChart/GroupedVerticalBarChart.types.js.map +1 -1
- package/lib-commonjs/components/GroupedVerticalBarChart/index.js.map +1 -1
- package/lib-commonjs/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.js +1 -1
- package/lib-commonjs/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.raw.js +69 -0
- package/lib-commonjs/components/GroupedVerticalBarChart/useGroupedVerticalBarChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/HeatMapChart/HeatMapChart.js +10 -2
- package/lib-commonjs/components/HeatMapChart/HeatMapChart.js.map +1 -1
- package/lib-commonjs/components/HeatMapChart/HeatMapChart.types.js.map +1 -1
- package/lib-commonjs/components/HeatMapChart/index.js.map +1 -1
- package/lib-commonjs/components/HeatMapChart/useHeatMapChartStyles.styles.js +1 -1
- package/lib-commonjs/components/HeatMapChart/useHeatMapChartStyles.styles.raw.js +56 -0
- package/lib-commonjs/components/HeatMapChart/useHeatMapChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js +23 -26
- package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.js.map +1 -1
- package/lib-commonjs/components/HorizontalBarChart/HorizontalBarChart.types.js.map +1 -1
- package/lib-commonjs/components/HorizontalBarChart/index.js.map +1 -1
- package/lib-commonjs/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.js +1 -1
- package/lib-commonjs/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.raw.js +134 -0
- package/lib-commonjs/components/HorizontalBarChart/useHorizontalBarChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js +9 -2
- package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.js.map +1 -1
- package/lib-commonjs/components/HorizontalBarChartWithAxis/HorizontalBarChartWithAxis.types.js.map +1 -1
- package/lib-commonjs/components/HorizontalBarChartWithAxis/index.js.map +1 -1
- package/lib-commonjs/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.js +1 -1
- package/lib-commonjs/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.raw.js +55 -0
- package/lib-commonjs/components/HorizontalBarChartWithAxis/useHorizontalBarChartWithAxisStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/Legends/Legends.js +28 -10
- package/lib-commonjs/components/Legends/Legends.js.map +1 -1
- package/lib-commonjs/components/Legends/Legends.types.js.map +1 -1
- package/lib-commonjs/components/Legends/OverflowMenu.js.map +1 -1
- package/lib-commonjs/components/Legends/index.js.map +1 -1
- package/lib-commonjs/components/Legends/shape.js.map +1 -1
- package/lib-commonjs/components/Legends/useLegendsStyles.styles.js +101 -28
- package/lib-commonjs/components/Legends/useLegendsStyles.styles.js.map +1 -1
- package/lib-commonjs/components/Legends/useLegendsStyles.styles.raw.js +174 -0
- package/lib-commonjs/components/Legends/useLegendsStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/LineChart/LineChart.js +9 -2
- package/lib-commonjs/components/LineChart/LineChart.js.map +1 -1
- package/lib-commonjs/components/LineChart/LineChart.types.js.map +1 -1
- package/lib-commonjs/components/LineChart/eventAnnotation/EventAnnotation.js.map +1 -1
- package/lib-commonjs/components/LineChart/eventAnnotation/LabelLink.js.map +1 -1
- package/lib-commonjs/components/LineChart/eventAnnotation/Textbox.js.map +1 -1
- package/lib-commonjs/components/LineChart/index.js.map +1 -1
- package/lib-commonjs/components/LineChart/useLineChartStyles.styles.js +1 -1
- package/lib-commonjs/components/LineChart/useLineChartStyles.styles.raw.js +66 -0
- package/lib-commonjs/components/LineChart/useLineChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/ResponsiveContainer/ResponsiveContainer.js.map +1 -1
- package/lib-commonjs/components/ResponsiveContainer/ResponsiveContainer.types.js.map +1 -1
- package/lib-commonjs/components/ResponsiveContainer/index.js.map +1 -1
- package/lib-commonjs/components/ResponsiveContainer/useResponsiveChildStyles.styles.js +1 -1
- package/lib-commonjs/components/ResponsiveContainer/useResponsiveChildStyles.styles.raw.js +46 -0
- package/lib-commonjs/components/ResponsiveContainer/useResponsiveChildStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/ResponsiveContainer/withResponsiveContainer.js.map +1 -1
- package/lib-commonjs/components/SankeyChart/SankeyChart.js +5 -1
- package/lib-commonjs/components/SankeyChart/SankeyChart.js.map +1 -1
- package/lib-commonjs/components/SankeyChart/SankeyChart.types.js.map +1 -1
- package/lib-commonjs/components/SankeyChart/index.js.map +1 -1
- package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.js +1 -1
- package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.js.map +1 -1
- package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.raw.js +95 -0
- package/lib-commonjs/components/SankeyChart/useSankeyChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/ScatterChart/ScatterChart.js +10 -2
- package/lib-commonjs/components/ScatterChart/ScatterChart.js.map +1 -1
- package/lib-commonjs/components/ScatterChart/ScatterChart.types.js.map +1 -1
- package/lib-commonjs/components/ScatterChart/index.js.map +1 -1
- package/lib-commonjs/components/ScatterChart/useScatterChartStyles.styles.js +1 -1
- package/lib-commonjs/components/ScatterChart/useScatterChartStyles.styles.raw.js +57 -0
- package/lib-commonjs/components/ScatterChart/useScatterChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/Sparkline/Sparkline.js.map +1 -1
- package/lib-commonjs/components/Sparkline/Sparkline.types.js.map +1 -1
- package/lib-commonjs/components/Sparkline/index.js.map +1 -1
- package/lib-commonjs/components/Sparkline/useSparklineStyles.styles.js +1 -1
- package/lib-commonjs/components/Sparkline/useSparklineStyles.styles.raw.js +44 -0
- package/lib-commonjs/components/Sparkline/useSparklineStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js +62 -28
- package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.js.map +1 -1
- package/lib-commonjs/components/VerticalBarChart/VerticalBarChart.types.js.map +1 -1
- package/lib-commonjs/components/VerticalBarChart/index.js.map +1 -1
- package/lib-commonjs/components/VerticalBarChart/useVerticalBarChartStyles.styles.js +1 -1
- package/lib-commonjs/components/VerticalBarChart/useVerticalBarChartStyles.styles.raw.js +74 -0
- package/lib-commonjs/components/VerticalBarChart/useVerticalBarChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js +22 -8
- package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.js.map +1 -1
- package/lib-commonjs/components/VerticalStackedBarChart/VerticalStackedBarChart.types.js.map +1 -1
- package/lib-commonjs/components/VerticalStackedBarChart/index.js.map +1 -1
- package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js +1 -1
- package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.js.map +1 -1
- package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.raw.js +67 -0
- package/lib-commonjs/components/VerticalStackedBarChart/useVerticalStackedBarChartStyles.styles.raw.js.map +1 -0
- package/lib-commonjs/index.js.map +1 -1
- package/lib-commonjs/types/DataPoint.js.map +1 -1
- package/lib-commonjs/types/EventAnnotation.js.map +1 -1
- package/lib-commonjs/types/LegendDataItem.js.map +1 -1
- package/lib-commonjs/types/index.js.map +1 -1
- package/lib-commonjs/utilities/FocusableTooltipText.js.map +1 -1
- package/lib-commonjs/utilities/KeyCodes.js.map +1 -1
- package/lib-commonjs/utilities/SVGTooltipText.js +2 -0
- package/lib-commonjs/utilities/SVGTooltipText.js.map +1 -1
- package/lib-commonjs/utilities/async-utils.js.map +1 -1
- package/lib-commonjs/utilities/colors.js.map +1 -1
- package/lib-commonjs/utilities/getWindow.js.map +1 -1
- package/lib-commonjs/utilities/image-export-utils.js +274 -0
- package/lib-commonjs/utilities/image-export-utils.js.map +1 -0
- package/lib-commonjs/utilities/index.js.map +1 -1
- package/lib-commonjs/utilities/overflow-utils.js.map +1 -1
- package/lib-commonjs/utilities/string.js.map +1 -1
- package/lib-commonjs/utilities/test-data.js.map +1 -1
- package/lib-commonjs/utilities/utilities.js +56 -5
- package/lib-commonjs/utilities/utilities.js.map +1 -1
- package/lib-commonjs/utilities/vbc-utils.js.map +1 -1
- package/package.json +12 -22
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["FunnelChart.ts"],"sourcesContent":["export * from './components/FunnelChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,iCAAiC"}
|
|
1
|
+
{"version":3,"sources":["../src/FunnelChart.ts"],"sourcesContent":["export * from './components/FunnelChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,iCAAiC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["GanttChart.ts"],"sourcesContent":["export * from './components/GanttChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,gCAAgC"}
|
|
1
|
+
{"version":3,"sources":["../src/GanttChart.ts"],"sourcesContent":["export * from './components/GanttChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,gCAAgC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["GaugeChart.ts"],"sourcesContent":["export * from './components/GaugeChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,gCAAgC"}
|
|
1
|
+
{"version":3,"sources":["../src/GaugeChart.ts"],"sourcesContent":["export * from './components/GaugeChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,gCAAgC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["GroupedVerticalBarChart.ts"],"sourcesContent":["export * from './components/GroupedVerticalBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,6CAA6C"}
|
|
1
|
+
{"version":3,"sources":["../src/GroupedVerticalBarChart.ts"],"sourcesContent":["export * from './components/GroupedVerticalBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,6CAA6C"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["HeatMapChart.ts"],"sourcesContent":["export * from './components/HeatMapChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,kCAAkC"}
|
|
1
|
+
{"version":3,"sources":["../src/HeatMapChart.ts"],"sourcesContent":["export * from './components/HeatMapChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,kCAAkC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["HorizontalBarChart.ts"],"sourcesContent":["export * from './components/HorizontalBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,wCAAwC"}
|
|
1
|
+
{"version":3,"sources":["../src/HorizontalBarChart.ts"],"sourcesContent":["export * from './components/HorizontalBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,wCAAwC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["HorizontalBarChartWithAxis.ts"],"sourcesContent":["export * from './components/HorizontalBarChartWithAxis/index';\n"],"names":[],"mappings":";;;;;uBAAc,gDAAgD"}
|
|
1
|
+
{"version":3,"sources":["../src/HorizontalBarChartWithAxis.ts"],"sourcesContent":["export * from './components/HorizontalBarChartWithAxis/index';\n"],"names":[],"mappings":";;;;;uBAAc,gDAAgD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["Legends.ts"],"sourcesContent":["export * from './components/Legends/index';\n"],"names":[],"mappings":";;;;;uBAAc,6BAA6B"}
|
|
1
|
+
{"version":3,"sources":["../src/Legends.ts"],"sourcesContent":["export * from './components/Legends/index';\n"],"names":[],"mappings":";;;;;uBAAc,6BAA6B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["LineChart.ts"],"sourcesContent":["export * from './components/LineChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,+BAA+B"}
|
|
1
|
+
{"version":3,"sources":["../src/LineChart.ts"],"sourcesContent":["export * from './components/LineChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,+BAA+B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["Popover.ts"],"sourcesContent":["export * from './components/CommonComponents/index';\n"],"names":[],"mappings":";;;;;uBAAc,sCAAsC"}
|
|
1
|
+
{"version":3,"sources":["../src/Popover.ts"],"sourcesContent":["export * from './components/CommonComponents/index';\n"],"names":[],"mappings":";;;;;uBAAc,sCAAsC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["ResponsiveContainer.ts"],"sourcesContent":["export * from './components/ResponsiveContainer/index';\n"],"names":[],"mappings":";;;;;uBAAc,yCAAyC"}
|
|
1
|
+
{"version":3,"sources":["../src/ResponsiveContainer.ts"],"sourcesContent":["export * from './components/ResponsiveContainer/index';\n"],"names":[],"mappings":";;;;;uBAAc,yCAAyC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["SankeyChart.ts"],"sourcesContent":["export * from './components/SankeyChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,iCAAiC"}
|
|
1
|
+
{"version":3,"sources":["../src/SankeyChart.ts"],"sourcesContent":["export * from './components/SankeyChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,iCAAiC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["ScatterChart.ts"],"sourcesContent":["export * from './components/ScatterChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,kCAAkC"}
|
|
1
|
+
{"version":3,"sources":["../src/ScatterChart.ts"],"sourcesContent":["export * from './components/ScatterChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,kCAAkC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["Sparkline.ts"],"sourcesContent":["export * from './components/Sparkline/index';\n"],"names":[],"mappings":";;;;;uBAAc,+BAA+B"}
|
|
1
|
+
{"version":3,"sources":["../src/Sparkline.ts"],"sourcesContent":["export * from './components/Sparkline/index';\n"],"names":[],"mappings":";;;;;uBAAc,+BAA+B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["VerticalBarChart.ts"],"sourcesContent":["export * from './components/VerticalBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,sCAAsC"}
|
|
1
|
+
{"version":3,"sources":["../src/VerticalBarChart.ts"],"sourcesContent":["export * from './components/VerticalBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,sCAAsC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["VerticalStackedBarChart.ts"],"sourcesContent":["export * from './components/VerticalStackedBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,6CAA6C"}
|
|
1
|
+
{"version":3,"sources":["../src/VerticalStackedBarChart.ts"],"sourcesContent":["export * from './components/VerticalStackedBarChart/index';\n"],"names":[],"mappings":";;;;;uBAAc,6CAA6C"}
|
|
@@ -19,6 +19,7 @@ const _index = require("../../index");
|
|
|
19
19
|
const _index1 = require("../../utilities/index");
|
|
20
20
|
const _reactutilities = require("@fluentui/react-utilities");
|
|
21
21
|
const _index2 = require("../Legends/index");
|
|
22
|
+
const _imageexportutils = require("../../utilities/image-export-utils");
|
|
22
23
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
23
24
|
const bisect = (0, _d3array.bisector)((d)=>d.x).left;
|
|
24
25
|
var InterceptVisibility = /*#__PURE__*/ function(InterceptVisibility) {
|
|
@@ -53,6 +54,8 @@ const AreaChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
|
|
|
53
54
|
// determines if the given area chart has multiple stacked bar charts
|
|
54
55
|
let _isMultiStackChart;
|
|
55
56
|
const cartesianChartRef = _react.useRef(null);
|
|
57
|
+
const _legendsRef = _react.useRef(null);
|
|
58
|
+
const _isRTL = (0, _index1.useRtl)();
|
|
56
59
|
const [selectedLegends, setSelectedLegends] = _react.useState(((_props_legendProps = props.legendProps) === null || _props_legendProps === void 0 ? void 0 : _props_legendProps.selectedLegends) || []);
|
|
57
60
|
const [activeLegend, setActiveLegend] = _react.useState(undefined);
|
|
58
61
|
const [hoverXValue, setHoverXValue] = _react.useState('');
|
|
@@ -89,7 +92,11 @@ const AreaChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
|
|
|
89
92
|
var _cartesianChartRef_current;
|
|
90
93
|
var _cartesianChartRef_current_chartContainer;
|
|
91
94
|
return {
|
|
92
|
-
chartContainer: (_cartesianChartRef_current_chartContainer = (_cartesianChartRef_current = cartesianChartRef.current) === null || _cartesianChartRef_current === void 0 ? void 0 : _cartesianChartRef_current.chartContainer) !== null && _cartesianChartRef_current_chartContainer !== void 0 ? _cartesianChartRef_current_chartContainer : null
|
|
95
|
+
chartContainer: (_cartesianChartRef_current_chartContainer = (_cartesianChartRef_current = cartesianChartRef.current) === null || _cartesianChartRef_current === void 0 ? void 0 : _cartesianChartRef_current.chartContainer) !== null && _cartesianChartRef_current_chartContainer !== void 0 ? _cartesianChartRef_current_chartContainer : null,
|
|
96
|
+
toImage: (opts)=>{
|
|
97
|
+
var _cartesianChartRef_current, _legendsRef_current;
|
|
98
|
+
return (0, _imageexportutils.toImage)((_cartesianChartRef_current = cartesianChartRef.current) === null || _cartesianChartRef_current === void 0 ? void 0 : _cartesianChartRef_current.chartContainer, (_legendsRef_current = _legendsRef.current) === null || _legendsRef_current === void 0 ? void 0 : _legendsRef_current.toSVG, _isRTL, opts);
|
|
99
|
+
}
|
|
93
100
|
};
|
|
94
101
|
}, []);
|
|
95
102
|
const classes = (0, _useAreaChartStylesstyles.useAreaChartStyles)(props);
|
|
@@ -400,7 +407,8 @@ const AreaChart = /*#__PURE__*/ _react.forwardRef((props, forwardedRef)=>{
|
|
|
400
407
|
legends: actions,
|
|
401
408
|
enabledWrapLines: props.enabledLegendsWrapLines,
|
|
402
409
|
...props.legendProps,
|
|
403
|
-
onChange: _onLegendSelectionChange
|
|
410
|
+
onChange: _onLegendSelectionChange,
|
|
411
|
+
legendRef: _legendsRef
|
|
404
412
|
});
|
|
405
413
|
}
|
|
406
414
|
function _onLegendSelectionChange(selectedLegends, event, currentLegend) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["AreaChart.tsx"],"sourcesContent":["import * 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 Chart,\n} from '../../index';\nimport {\n calloutData,\n getXAxisType,\n ChartTypes,\n XAxisTypes,\n getTypeOfAxis,\n tooltipOfAxislabels,\n getNextColor,\n getColorFromToken,\n formatDate,\n getSecureProps,\n areArraysEqual,\n getCurveFactory,\n find,\n findNumericMinMaxOfY,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfNumericForAreaChart,\n domainRangeOfDateForAreaLineVerticalBarChart,\n createStringYAxis,\n} from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport { Legend, Legends } from '../Legends/index';\nimport { ScaleLinear } from 'd3-scale';\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\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 // 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: JSX.Element[];\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 = React.useRef<Chart>(null);\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 React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n }),\n [],\n );\n\n const classes = useAreaChartStyles(props);\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 = domainRangeOfNumericForAreaChart(points, margins, width, isRTL);\n } else if (xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = domainRangeOfDateForAreaLineVerticalBarChart(\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 ? formatDate(pointToHighlight, props.useUTC) : pointToHighlight;\n const modifiedXVal = pointToHighlight instanceof Date ? pointToHighlight.getTime() : pointToHighlight;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const found: any = find(_calloutPoints, (element: { x: string | number }) => {\n return element.x === modifiedXVal;\n });\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) {\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 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 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, index: number) => {\n singleDataset.xVal = singleDataPoint.x;\n singleDataset[`chart${index}`] = 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 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 }\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[]): JSX.Element {\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 />\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 ): JSX.Element[] {\n const points = _addDefaultColors(props.data.lineChartData);\n const { pointOptions, pointLineOptions } = props.data;\n\n const graph: JSX.Element[] = [];\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\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 onClick={() => _onDataPointClick(points[index]!.data[pointIndex].onDataPointClick!)}\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={_getAriaLabel(index, pointIndex)}\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 onClick={() => _onDataPointClick(points[index]!.data[pointIndex].onDataPointClick!)}\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 _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 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 ? formatDate(x, props.useUTC) : x;\n const modifiedXVal = x instanceof Date ? x.getTime() : x;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const found: any = _calloutPoints.find((e: { x: string | number }) => e.x === modifiedXVal);\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 // 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 = point.x instanceof Date ? formatDate(point.x, props.useUTC) : 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 _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: JSX.Element = _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,\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={findNumericMinMaxOfY}\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","formatDate","getSecureProps","areArraysEqual","getCurveFactory","find","findNumericMinMaxOfY","createNumericYAxis","domainRangeOfNumericForAreaChart","domainRangeOfDateForAreaLineVerticalBarChart","createStringYAxis","useId","Legends","bisect","d","x","left","InterceptVisibility","AreaChart","forwardRef","props","forwardedRef","_uniqueIdForGraph","_verticalLineId","_circleId","_rectId","_tooltipId","_enableComputationOptimization","_firstRenderOptimization","_emptyChartId","_containsSecondaryYAxis","_calloutPoints","_createSet","_colors","_opacity","_data","_chart","_margins","_xAxisRectScale","_isMultiStackChart","cartesianChartRef","useRef","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","useEffect","current","prevProps","useImperativeHandle","componentRef","chartContainer","classes","_getDomainNRangeValues","points","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","useUTC","modifiedXVal","found","element","_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","tempArr","valToCheck","filteredChartPoints","filter","point","val","_getCustomizedCallout","onRenderCalloutPerStack","onRenderCalloutPerDataPoint","_getGraphData","xAxis","yAxis","containerHeight","containerWidth","xElement","yAxisElement","yScaleSecondary","_drawGraph","_onLegendHover","legend","_onLegendLeave","_getLegendData","actions","singleChartData","checkSimilarLegends","leg","title","hoverAction","onMouseOutAction","legends","enabledWrapLines","enabledLegendsWrapLines","onChange","_onLegendSelectionChange","event","currentLegend","canSelectMultipleLegends","slice","_onDataPointClick","func","_getOpacity","_legendHighlighted","_noLegendHighlighted","_getLineOpacity","_updateCircleFillColor","xDataPoint","lineColor","circleId","fillColor","colorNeutralBackground1","xScale","yScalePrimary","_addDefaultColors","pointOptions","pointLineOptions","graph","singleStackedData","yScale","useSecondaryYScale","curveFactory","lineOptions","curve","y0","y1","layerOpacity","Fragment","enableGradient","defs","linearGradient","id","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","onClick","onDataPointClick","onBlur","_handleBlur","_getCircleRadius","_getAriaLabel","visibility","showXAxisLablesTooltip","remove","e","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","axis","_getHighlightedLegend","includes","item","lineIndex","targetRect","target","getBoundingClientRect","top","height","yValue","yAxisCalloutData","callOutAccessibilityData","ariaLabel","_isChartEmpty","_getChartTitle","chartTitle","mode","secondaryYScaleOptions","some","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":["import * 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 Chart,\n ImageExportOptions,\n} from '../../index';\nimport {\n calloutData,\n getXAxisType,\n ChartTypes,\n XAxisTypes,\n getTypeOfAxis,\n tooltipOfAxislabels,\n getNextColor,\n getColorFromToken,\n formatDate,\n getSecureProps,\n areArraysEqual,\n getCurveFactory,\n find,\n findNumericMinMaxOfY,\n createNumericYAxis,\n IDomainNRange,\n domainRangeOfNumericForAreaChart,\n domainRangeOfDateForAreaLineVerticalBarChart,\n createStringYAxis,\n useRtl,\n} from '../../utilities/index';\nimport { useId } from '@fluentui/react-utilities';\nimport { Legend, LegendContainer, Legends } from '../Legends/index';\nimport { ScaleLinear } from 'd3-scale';\nimport { toImage } from '../../utilities/image-export-utils';\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\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 // 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: JSX.Element[];\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 = React.useRef<Chart>(null);\n const _legendsRef = React.useRef<LegendContainer>(null);\n const _isRTL: boolean = useRtl();\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 React.useImperativeHandle(\n props.componentRef,\n () => ({\n chartContainer: cartesianChartRef.current?.chartContainer ?? null,\n toImage: (opts?: ImageExportOptions): Promise<string> => {\n return toImage(cartesianChartRef.current?.chartContainer, _legendsRef.current?.toSVG, _isRTL, opts);\n },\n }),\n [],\n );\n\n const classes = useAreaChartStyles(props);\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 = domainRangeOfNumericForAreaChart(points, margins, width, isRTL);\n } else if (xAxisType === XAxisTypes.DateAxis) {\n domainNRangeValue = domainRangeOfDateForAreaLineVerticalBarChart(\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 ? formatDate(pointToHighlight, props.useUTC) : pointToHighlight;\n const modifiedXVal = pointToHighlight instanceof Date ? pointToHighlight.getTime() : pointToHighlight;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const found: any = find(_calloutPoints, (element: { x: string | number }) => {\n return element.x === modifiedXVal;\n });\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) {\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 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 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, index: number) => {\n singleDataset.xVal = singleDataPoint.x;\n singleDataset[`chart${index}`] = 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 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 }\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[]): JSX.Element {\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 ): JSX.Element[] {\n const points = _addDefaultColors(props.data.lineChartData);\n const { pointOptions, pointLineOptions } = props.data;\n\n const graph: JSX.Element[] = [];\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\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 onClick={() => _onDataPointClick(points[index]!.data[pointIndex].onDataPointClick!)}\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={_getAriaLabel(index, pointIndex)}\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 onClick={() => _onDataPointClick(points[index]!.data[pointIndex].onDataPointClick!)}\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 _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 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 ? formatDate(x, props.useUTC) : x;\n const modifiedXVal = x instanceof Date ? x.getTime() : x;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const found: any = _calloutPoints.find((e: { x: string | number }) => e.x === modifiedXVal);\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 // 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 = point.x instanceof Date ? formatDate(point.x, props.useUTC) : 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 _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: JSX.Element = _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,\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={findNumericMinMaxOfY}\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","formatDate","getSecureProps","areArraysEqual","getCurveFactory","find","findNumericMinMaxOfY","createNumericYAxis","domainRangeOfNumericForAreaChart","domainRangeOfDateForAreaLineVerticalBarChart","createStringYAxis","useRtl","useId","Legends","toImage","bisect","d","x","left","InterceptVisibility","AreaChart","forwardRef","props","forwardedRef","_uniqueIdForGraph","_verticalLineId","_circleId","_rectId","_tooltipId","_enableComputationOptimization","_firstRenderOptimization","_emptyChartId","_containsSecondaryYAxis","_calloutPoints","_createSet","_colors","_opacity","_data","_chart","_margins","_xAxisRectScale","_isMultiStackChart","cartesianChartRef","useRef","_legendsRef","_isRTL","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","useEffect","current","prevProps","useImperativeHandle","componentRef","chartContainer","opts","toSVG","classes","_getDomainNRangeValues","points","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","useUTC","modifiedXVal","found","element","_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","tempArr","valToCheck","filteredChartPoints","filter","point","val","_getCustomizedCallout","onRenderCalloutPerStack","onRenderCalloutPerDataPoint","_getGraphData","xAxis","yAxis","containerHeight","containerWidth","xElement","yAxisElement","yScaleSecondary","_drawGraph","_onLegendHover","legend","_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","useSecondaryYScale","curveFactory","lineOptions","curve","y0","y1","layerOpacity","Fragment","enableGradient","defs","linearGradient","id","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","onClick","onDataPointClick","onBlur","_handleBlur","_getCircleRadius","_getAriaLabel","visibility","showXAxisLablesTooltip","remove","e","wrapXAxisLables","xAxisElement","call","tooltipProps","tooltipCls","tooltip","axis","_getHighlightedLegend","includes","item","lineIndex","targetRect","target","getBoundingClientRect","top","height","yValue","yAxisCalloutData","callOutAccessibilityData","ariaLabel","_isChartEmpty","_getChartTitle","chartTitle","mode","secondaryYScaleOptions","some","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 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["AreaChart.types.ts"],"sourcesContent":["import { RenderFunction } from '../../utilities/index';\nimport {\n ChartProps,\n RefArrayData,\n Basestate,\n LineChartDataPoint,\n LineChartPoints,\n CustomizedCalloutData,\n Margins,\n} from '../../types/index';\nimport {\n CartesianChartStyles,\n CartesianChartStyleProps,\n CartesianChartProps,\n ChildProps,\n} from '../CommonComponents/CartesianChart.types';\n\nexport type { ChildProps, RefArrayData, Basestate, LineChartDataPoint, LineChartPoints, Margins };\n\n/**\n * Area Chart properties.\n * {@docCategory AreaChart}\n */\nexport interface AreaChartProps extends CartesianChartProps {\n /**\n * Data to render in the chart.\n */\n data: ChartProps;\n\n /**\n * Call to provide customized styling that will layer on top of the variant rules.\n */\n styles?: CartesianChartStyles;\n\n /**\n * Define a custom callout renderer for a data point\n */\n onRenderCalloutPerDataPoint?: RenderFunction<CustomizedCalloutData>;\n\n /**\n * Define a custom callout renderer for a stack; default is to render per data point\n */\n onRenderCalloutPerStack?: RenderFunction<CustomizedCalloutData>;\n\n /**\n * The prop used to define the culture to localized the numbers\n */\n culture?: string;\n\n /**\n * @default false\n * The prop used to enable the perf optimization\n */\n enablePerfOptimization?: boolean;\n\n /*\n * Optimize area chart rendering for large data set.\n */\n optimizeLargeData?: boolean;\n\n /**\n * @default false\n * The prop used to enable gradient fill color for the chart.\n */\n enableGradient?: boolean;\n\n /**\n * @default tonexty\n * The prop used to define the Y axis mode (tonexty or tozeroy)\n */\n mode?: 'tozeroy' | 'tonexty';\n}\n\n/**\n * Area Chart styles\n * {@docCategory AreaChart}\n */\nexport interface AreaChartStyles extends CartesianChartStyles {}\n\n/**\n * Area Chart style properties\n * {@docCategory AreaChart}\n */\nexport interface AreaChartStyleProps extends CartesianChartStyleProps {}\n"],"names":[],"mappings":"AA+EA;;;CAGC,GACD,WAAwE"}
|
|
1
|
+
{"version":3,"sources":["../src/components/AreaChart/AreaChart.types.ts"],"sourcesContent":["import { RenderFunction } from '../../utilities/index';\nimport {\n ChartProps,\n RefArrayData,\n Basestate,\n LineChartDataPoint,\n LineChartPoints,\n CustomizedCalloutData,\n Margins,\n} from '../../types/index';\nimport {\n CartesianChartStyles,\n CartesianChartStyleProps,\n CartesianChartProps,\n ChildProps,\n} from '../CommonComponents/CartesianChart.types';\n\nexport type { ChildProps, RefArrayData, Basestate, LineChartDataPoint, LineChartPoints, Margins };\n\n/**\n * Area Chart properties.\n * {@docCategory AreaChart}\n */\nexport interface AreaChartProps extends CartesianChartProps {\n /**\n * Data to render in the chart.\n */\n data: ChartProps;\n\n /**\n * Call to provide customized styling that will layer on top of the variant rules.\n */\n styles?: CartesianChartStyles;\n\n /**\n * Define a custom callout renderer for a data point\n */\n onRenderCalloutPerDataPoint?: RenderFunction<CustomizedCalloutData>;\n\n /**\n * Define a custom callout renderer for a stack; default is to render per data point\n */\n onRenderCalloutPerStack?: RenderFunction<CustomizedCalloutData>;\n\n /**\n * The prop used to define the culture to localized the numbers\n */\n culture?: string;\n\n /**\n * @default false\n * The prop used to enable the perf optimization\n */\n enablePerfOptimization?: boolean;\n\n /*\n * Optimize area chart rendering for large data set.\n */\n optimizeLargeData?: boolean;\n\n /**\n * @default false\n * The prop used to enable gradient fill color for the chart.\n */\n enableGradient?: boolean;\n\n /**\n * @default tonexty\n * The prop used to define the Y axis mode (tonexty or tozeroy)\n */\n mode?: 'tozeroy' | 'tonexty';\n}\n\n/**\n * Area Chart styles\n * {@docCategory AreaChart}\n */\nexport interface AreaChartStyles extends CartesianChartStyles {}\n\n/**\n * Area Chart style properties\n * {@docCategory AreaChart}\n */\nexport interface AreaChartStyleProps extends CartesianChartStyleProps {}\n"],"names":[],"mappings":"AA+EA;;;CAGC,GACD,WAAwE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["index.ts"],"sourcesContent":["export * from './AreaChart';\nexport * from './AreaChart.types';\nexport * from '../../types/index';\n"],"names":[],"mappings":";;;;;uBAAc,cAAc;uBACd,oBAAoB;uBACpB,oBAAoB"}
|
|
1
|
+
{"version":3,"sources":["../src/components/AreaChart/index.ts"],"sourcesContent":["export * from './AreaChart';\nexport * from './AreaChart.types';\nexport * from '../../types/index';\n"],"names":[],"mappings":";;;;;uBAAc,cAAc;uBACd,oBAAoB;uBACpB,oBAAoB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["useAreaChartStyles.styles.js"],"sourcesContent":["import { makeStyles, mergeClasses, shorthands } from '@griffel/react';\nimport { tokens, typographyStyles } from '@fluentui/react-theme';\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};\nconst useStyles = makeStyles({\n tooltip: {\n ...typographyStyles.body1,\n display: 'flex',\n flexDirection: 'column',\n ...shorthands.padding(tokens.spacingHorizontalS),\n position: 'absolute',\n textAlign: 'center',\n top: tokens.spacingVerticalNone,\n backgroundColor: tokens.colorNeutralBackground1,\n borderRadius: tokens.borderRadiusSmall,\n pointerEvents: 'none',\n color: tokens.colorNeutralForeground1\n }\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","shorthands","tokens","typographyStyles","areaChartClassNames","tooltip","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","opacityChangeOnHover","shapeStyles","chartWrapper","svgTooltip","chart","useStyles","Bahqtrf","Be2twd7","Bhrd7zp","Bg96gwp","mc9l5x","Beiy3e4","z8tnut","z189sj","Byoj8tv","uwmqm3","qhf8xq","fsow6f","Bhzewxz","De3pzq","Beyfa6y","Bbmb7ep","Btl43ni","B7oj6ja","Dimara","Bkecrkj","sj55zd","d","p","useAreaChartStyles","props","baseStyles"],"mappings":";;;;;;;;;;;IAEaK,mBAAmB;;;sBAiCG
|
|
1
|
+
{"version":3,"sources":["useAreaChartStyles.styles.js"],"sourcesContent":["import { makeStyles, mergeClasses, shorthands } from '@griffel/react';\nimport { tokens, typographyStyles } from '@fluentui/react-theme';\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};\nconst useStyles = makeStyles({\n tooltip: {\n ...typographyStyles.body1,\n display: 'flex',\n flexDirection: 'column',\n ...shorthands.padding(tokens.spacingHorizontalS),\n position: 'absolute',\n textAlign: 'center',\n top: tokens.spacingVerticalNone,\n backgroundColor: tokens.colorNeutralBackground1,\n borderRadius: tokens.borderRadiusSmall,\n pointerEvents: 'none',\n color: tokens.colorNeutralForeground1\n }\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","shorthands","tokens","typographyStyles","areaChartClassNames","tooltip","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","opacityChangeOnHover","shapeStyles","chartWrapper","svgTooltip","chart","useStyles","Bahqtrf","Be2twd7","Bhrd7zp","Bg96gwp","mc9l5x","Beiy3e4","z8tnut","z189sj","Byoj8tv","uwmqm3","qhf8xq","fsow6f","Bhzewxz","De3pzq","Beyfa6y","Bbmb7ep","Btl43ni","B7oj6ja","Dimara","Bkecrkj","sj55zd","d","p","useAreaChartStyles","props","baseStyles"],"mappings":";;;;;;;;;;;IAEaK,mBAAmB;;;sBAiCG;;;;uBAnCkB,gBAAgB;AAE9D,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;AACX,CAAC;AACD,MAAMC,SAAS,GAAA,WAAA,GAAGpB,mBAAA,EAAA;IAAAM,OAAA,EAAA;QAAAe,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;QAAAC,MAAA,EAAA;YAAA;YAAA;SAAA;QAAAC,OAAA,EAAA;QAAAC,MAAA,EAAA;YAAA;YAAA;SAAA;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;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;QAAA;YAAA;YAAA;gBAAAC,CAAA,EAAA,CAAA;YAAA;SAAA;QAAA;QAAA;KAAA;AAAA,CAcjB,CAAC;AAGS,MAAMC,sBAAsBC,KAAK,IAAG;IAC3C,MAAMC,UAAU,GAAG1B,SAAS,CAAC,CAAC;IAC9B,OAAO;QACHd,OAAO,MAAEL,mBAAY,EAACI,mBAAmB,CAACC,OAAO,EAAEwC,UAAU,CAACxC,OAAO,CAAC,uBAAA,EAA0B;IACpG,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
areaChartClassNames: function() {
|
|
13
|
+
return areaChartClassNames;
|
|
14
|
+
},
|
|
15
|
+
useAreaChartStyles: function() {
|
|
16
|
+
return useAreaChartStyles;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
const _react = require("@griffel/react");
|
|
20
|
+
const _reacttheme = require("@fluentui/react-theme");
|
|
21
|
+
const areaChartClassNames = {
|
|
22
|
+
tooltip: 'fui-ac__tooltip',
|
|
23
|
+
root: '',
|
|
24
|
+
xAxis: '',
|
|
25
|
+
yAxis: '',
|
|
26
|
+
legendContainer: '',
|
|
27
|
+
hover: '',
|
|
28
|
+
descriptionMessage: '',
|
|
29
|
+
axisTitle: '',
|
|
30
|
+
chartTitle: '',
|
|
31
|
+
opacityChangeOnHover: '',
|
|
32
|
+
shapeStyles: '',
|
|
33
|
+
chartWrapper: '',
|
|
34
|
+
svgTooltip: '',
|
|
35
|
+
chart: ''
|
|
36
|
+
};
|
|
37
|
+
const useStyles = (0, _react.makeStyles)({
|
|
38
|
+
tooltip: {
|
|
39
|
+
..._reacttheme.typographyStyles.body1,
|
|
40
|
+
display: 'flex',
|
|
41
|
+
flexDirection: 'column',
|
|
42
|
+
..._react.shorthands.padding(_reacttheme.tokens.spacingHorizontalS),
|
|
43
|
+
position: 'absolute',
|
|
44
|
+
textAlign: 'center',
|
|
45
|
+
top: _reacttheme.tokens.spacingVerticalNone,
|
|
46
|
+
backgroundColor: _reacttheme.tokens.colorNeutralBackground1,
|
|
47
|
+
borderRadius: _reacttheme.tokens.borderRadiusSmall,
|
|
48
|
+
pointerEvents: 'none',
|
|
49
|
+
color: _reacttheme.tokens.colorNeutralForeground1
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
const useAreaChartStyles = (props)=>{
|
|
53
|
+
const baseStyles = useStyles();
|
|
54
|
+
return {
|
|
55
|
+
tooltip: (0, _react.mergeClasses)(areaChartClassNames.tooltip, baseStyles.tooltip /*props.styles?.tooltip*/ )
|
|
56
|
+
};
|
|
57
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/AreaChart/useAreaChartStyles.styles.ts"],"sourcesContent":["import { makeStyles, mergeClasses, shorthands } from '@griffel/react';\nimport { AreaChartProps, AreaChartStyles } from './index';\nimport { SlotClassNames } from '@fluentui/react-utilities';\nimport { tokens, typographyStyles } from '@fluentui/react-theme';\n\nexport const areaChartClassNames: SlotClassNames<AreaChartStyles> = {\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};\n\nconst useStyles = makeStyles({\n tooltip: {\n ...typographyStyles.body1,\n display: 'flex',\n flexDirection: 'column',\n ...shorthands.padding(tokens.spacingHorizontalS),\n position: 'absolute',\n textAlign: 'center',\n top: tokens.spacingVerticalNone,\n backgroundColor: tokens.colorNeutralBackground1,\n borderRadius: tokens.borderRadiusSmall,\n pointerEvents: 'none',\n color: tokens.colorNeutralForeground1,\n },\n});\n\n/**\n * Apply styling to the AreaChart slots based on the state\n */\nexport const useAreaChartStyles = (props: AreaChartProps): AreaChartStyles => {\n const baseStyles = useStyles();\n\n return {\n tooltip: mergeClasses(areaChartClassNames.tooltip, baseStyles.tooltip /*props.styles?.tooltip*/),\n };\n};\n"],"names":["makeStyles","mergeClasses","shorthands","tokens","typographyStyles","areaChartClassNames","tooltip","root","xAxis","yAxis","legendContainer","hover","descriptionMessage","axisTitle","chartTitle","opacityChangeOnHover","shapeStyles","chartWrapper","svgTooltip","chart","useStyles","body1","display","flexDirection","padding","spacingHorizontalS","position","textAlign","top","spacingVerticalNone","backgroundColor","colorNeutralBackground1","borderRadius","borderRadiusSmall","pointerEvents","color","colorNeutralForeground1","useAreaChartStyles","props","baseStyles"],"mappings":";;;;;;;;;;;IAKaK,mBAAAA;;;sBAoCAgC;;;;uBAzCwC,iBAAiB;4BAG7B,wBAAwB;AAE1D,4BAA6D;IAClE/B,SAAS;IACTC,MAAM;IACNC,OAAO;IACPC,OAAO;IACPC,iBAAiB;IACjBC,OAAO;IACPC,oBAAoB;IACpBC,WAAW;IACXC,YAAY;IACZC,sBAAsB;IACtBC,aAAa;IACbC,cAAc;IACdC,YAAY;IACZC,OAAO;AACT,EAAE;AAEF,MAAMC,gBAAYpB,iBAAAA,EAAW;IAC3BM,SAAS;QACP,GAAGF,4BAAAA,CAAiBiB,KAAK;QACzBC,SAAS;QACTC,eAAe;QACf,GAAGrB,iBAAAA,CAAWsB,OAAO,CAACrB,kBAAAA,CAAOsB,kBAAkB,CAAC;QAChDC,UAAU;QACVC,WAAW;QACXC,KAAKzB,kBAAAA,CAAO0B,mBAAmB;QAC/BC,iBAAiB3B,kBAAAA,CAAO4B,uBAAuB;QAC/CC,cAAc7B,kBAAAA,CAAO8B,iBAAiB;QACtCC,eAAe;QACfC,OAAOhC,kBAAAA,CAAOiC,uBAAuB;IACvC;AACF;AAKO,MAAMC,qBAAqB,CAACC;IACjC,MAAMC,aAAanB;IAEnB,OAAO;QACLd,aAASL,mBAAAA,EAAaI,oBAAoBC,OAAO,EAAEiC,WAAWjC,OAAO,CAAC,uBAAuB;IAC/F;AACF,EAAE"}
|