semiotic 2.0.3 → 3.0.0-beta.2
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/CLAUDE.md +828 -0
- package/README.md +215 -37
- package/ai/cli.js +48 -0
- package/ai/dist/ai/componentRegistry.js +45 -0
- package/ai/dist/ai/mcp-server.js +99 -0
- package/ai/dist/ai/renderHOCToSVG.js +77 -0
- package/ai/dist/src/components/Annotation.js +358 -0
- package/ai/dist/src/components/AnnotationLayer/AnnotationLayer.js +369 -0
- package/ai/dist/src/components/Axis/Axis.js +374 -0
- package/ai/dist/src/components/Axis/axisTitle.js +14 -0
- package/ai/dist/src/components/Axis/index.js +7 -0
- package/ai/dist/src/components/Axis/summaryGraphic.js +37 -0
- package/ai/dist/src/components/Brush.js +84 -0
- package/ai/dist/src/components/ChartErrorBoundary.js +91 -0
- package/ai/dist/src/components/DividedLine.js +65 -0
- package/ai/dist/src/components/Legend.js +140 -0
- package/ai/dist/src/components/LinkedCharts.js +95 -0
- package/ai/dist/src/components/ThemeProvider.js +79 -0
- package/ai/dist/src/components/Tooltip/Tooltip.js +309 -0
- package/ai/dist/src/components/TooltipPositioner/index.js +132 -0
- package/ai/dist/src/components/annotationLayerBehavior/annotationHandling.js +73 -0
- package/ai/dist/src/components/annotationLayerBehavior/d3labeler.js +254 -0
- package/ai/dist/src/components/annotationRules/baseRules.js +150 -0
- package/ai/dist/src/components/annotationRules/networkframeRules.js +196 -0
- package/ai/dist/src/components/annotationRules/xyframeRules.js +297 -0
- package/ai/dist/src/components/batchWork.js +35 -0
- package/ai/dist/src/components/charts/index.js +109 -0
- package/ai/dist/src/components/charts/network/ChordDiagram.js +142 -0
- package/ai/dist/src/components/charts/network/CirclePack.js +108 -0
- package/ai/dist/src/components/charts/network/ForceDirectedGraph.js +121 -0
- package/ai/dist/src/components/charts/network/SankeyDiagram.js +155 -0
- package/ai/dist/src/components/charts/network/TreeDiagram.js +110 -0
- package/ai/dist/src/components/charts/network/Treemap.js +106 -0
- package/ai/dist/src/components/charts/ordinal/BarChart.js +156 -0
- package/ai/dist/src/components/charts/ordinal/BoxPlot.js +139 -0
- package/ai/dist/src/components/charts/ordinal/DonutChart.js +130 -0
- package/ai/dist/src/components/charts/ordinal/DotPlot.js +126 -0
- package/ai/dist/src/components/charts/ordinal/GroupedBarChart.js +129 -0
- package/ai/dist/src/components/charts/ordinal/Histogram.js +132 -0
- package/ai/dist/src/components/charts/ordinal/PieChart.js +128 -0
- package/ai/dist/src/components/charts/ordinal/RidgelinePlot.js +130 -0
- package/ai/dist/src/components/charts/ordinal/StackedBarChart.js +130 -0
- package/ai/dist/src/components/charts/ordinal/SwarmPlot.js +147 -0
- package/ai/dist/src/components/charts/ordinal/ViolinPlot.js +138 -0
- package/ai/dist/src/components/charts/realtime/RealtimeHeatmap.js +79 -0
- package/ai/dist/src/components/charts/realtime/RealtimeHistogram.js +114 -0
- package/ai/dist/src/components/charts/realtime/RealtimeLineChart.js +93 -0
- package/ai/dist/src/components/charts/realtime/RealtimeSwarmChart.js +105 -0
- package/ai/dist/src/components/charts/realtime/RealtimeWaterfallChart.js +106 -0
- package/ai/dist/src/components/charts/shared/ChartError.js +72 -0
- package/ai/dist/src/components/charts/shared/colorUtils.js +138 -0
- package/ai/dist/src/components/charts/shared/formatUtils.js +213 -0
- package/ai/dist/src/components/charts/shared/hooks.js +49 -0
- package/ai/dist/src/components/charts/shared/legendUtils.js +57 -0
- package/ai/dist/src/components/charts/shared/selectionUtils.js +67 -0
- package/ai/dist/src/components/charts/shared/tooltipUtils.js +79 -0
- package/ai/dist/src/components/charts/shared/types.js +2 -0
- package/ai/dist/src/components/charts/shared/validateChartData.js +82 -0
- package/ai/dist/src/components/charts/shared/validateProps.js +736 -0
- package/ai/dist/src/components/charts/xy/AreaChart.js +230 -0
- package/ai/dist/src/components/charts/xy/BubbleChart.js +251 -0
- package/ai/dist/src/components/charts/xy/Heatmap.js +235 -0
- package/ai/dist/src/components/charts/xy/LineChart.js +307 -0
- package/ai/dist/src/components/charts/xy/MinimapChart.js +298 -0
- package/ai/dist/src/components/charts/xy/Scatterplot.js +172 -0
- package/ai/dist/src/components/charts/xy/ScatterplotMatrix.js +426 -0
- package/ai/dist/src/components/charts/xy/StackedAreaChart.js +231 -0
- package/ai/dist/src/components/constants/coordinateNames.js +11 -0
- package/ai/dist/src/components/constants/frame_props.js +251 -0
- package/ai/dist/src/components/data/dataFunctions.js +487 -0
- package/ai/dist/src/components/data/multiAccessorUtils.js +14 -0
- package/ai/dist/src/components/data/transforms.js +143 -0
- package/ai/dist/src/components/data/unflowedFunctions.js +5 -0
- package/ai/dist/src/components/export/exportChart.js +121 -0
- package/ai/dist/src/components/generic_utilities/functions.js +5 -0
- package/ai/dist/src/components/geometry/areaDrawing.js +312 -0
- package/ai/dist/src/components/geometry/contourLayout.js +73 -0
- package/ai/dist/src/components/geometry/hexbinLayout.js +163 -0
- package/ai/dist/src/components/geometry/lineDrawing.js +356 -0
- package/ai/dist/src/components/geometry/sankeyLinks.js +331 -0
- package/ai/dist/src/components/geometry/summaryLayouts.js +136 -0
- package/ai/dist/src/components/index.js +18 -0
- package/ai/dist/src/components/processing/InteractionItems.js +223 -0
- package/ai/dist/src/components/processing/hierarchyUtils.js +104 -0
- package/ai/dist/src/components/processing/layouts/chordLayout.js +58 -0
- package/ai/dist/src/components/processing/layouts/forceLayout.js +142 -0
- package/ai/dist/src/components/processing/layouts/hierarchyLayout.js +31 -0
- package/ai/dist/src/components/processing/layouts/index.js +32 -0
- package/ai/dist/src/components/processing/layouts/sankeyLayout.js +96 -0
- package/ai/dist/src/components/processing/layouts/simpleLayouts.js +34 -0
- package/ai/dist/src/components/processing/layouts/types.js +2 -0
- package/ai/dist/src/components/processing/networkDefaults.js +39 -0
- package/ai/dist/src/components/realtime/BinAccumulator.js +36 -0
- package/ai/dist/src/components/realtime/IncrementalExtent.js +55 -0
- package/ai/dist/src/components/realtime/RingBuffer.js +104 -0
- package/ai/dist/src/components/realtime/renderers/barRenderer.js +133 -0
- package/ai/dist/src/components/realtime/renderers/candlestickRenderer.js +7 -0
- package/ai/dist/src/components/realtime/renderers/lineRenderer.js +164 -0
- package/ai/dist/src/components/realtime/renderers/swarmRenderer.js +91 -0
- package/ai/dist/src/components/realtime/renderers/types.js +2 -0
- package/ai/dist/src/components/realtime/renderers/waterfallRenderer.js +163 -0
- package/ai/dist/src/components/realtime/types.js +2 -0
- package/ai/dist/src/components/semiotic-ai.js +89 -0
- package/ai/dist/src/components/semiotic-data.js +12 -0
- package/ai/dist/src/components/semiotic-network.js +38 -0
- package/ai/dist/src/components/semiotic-ordinal.js +28 -0
- package/ai/dist/src/components/semiotic-realtime.js +30 -0
- package/ai/dist/src/components/semiotic-server.js +8 -0
- package/ai/dist/src/components/semiotic-xy.js +35 -0
- package/ai/dist/src/components/semiotic.js +109 -0
- package/ai/dist/src/components/server/renderToStaticSVG.js +594 -0
- package/ai/dist/src/components/store/SelectionStore.js +91 -0
- package/ai/dist/src/components/store/ThemeStore.js +78 -0
- package/ai/dist/src/components/store/TooltipStore.js +13 -0
- package/ai/dist/src/components/store/createStore.js +81 -0
- package/ai/dist/src/components/store/useSelection.js +133 -0
- package/ai/dist/src/components/stream/CanvasHitTester.js +164 -0
- package/ai/dist/src/components/stream/DataSourceAdapter.js +99 -0
- package/ai/dist/src/components/stream/MarginalGraphics.js +266 -0
- package/ai/dist/src/components/stream/NetworkCanvasHitTester.js +228 -0
- package/ai/dist/src/components/stream/NetworkPipelineStore.js +498 -0
- package/ai/dist/src/components/stream/NetworkSVGOverlay.js +70 -0
- package/ai/dist/src/components/stream/NetworkSceneGraph.js +38 -0
- package/ai/dist/src/components/stream/OrdinalCanvasHitTester.js +146 -0
- package/ai/dist/src/components/stream/OrdinalPipelineStore.js +786 -0
- package/ai/dist/src/components/stream/OrdinalSVGOverlay.js +130 -0
- package/ai/dist/src/components/stream/ParticlePool.js +174 -0
- package/ai/dist/src/components/stream/PipelineStore.js +1243 -0
- package/ai/dist/src/components/stream/SVGOverlay.js +129 -0
- package/ai/dist/src/components/stream/SceneGraph.js +132 -0
- package/ai/dist/src/components/stream/StreamNetworkFrame.js +561 -0
- package/ai/dist/src/components/stream/StreamOrdinalFrame.js +492 -0
- package/ai/dist/src/components/stream/StreamXYFrame.js +590 -0
- package/ai/dist/src/components/stream/accessorUtils.js +20 -0
- package/ai/dist/src/components/stream/index.js +32 -0
- package/ai/dist/src/components/stream/layouts/chordLayoutPlugin.js +352 -0
- package/ai/dist/src/components/stream/layouts/forceLayoutPlugin.js +230 -0
- package/ai/dist/src/components/stream/layouts/hierarchyLayoutPlugin.js +568 -0
- package/ai/dist/src/components/stream/layouts/index.js +28 -0
- package/ai/dist/src/components/stream/layouts/sankeyLayoutPlugin.js +245 -0
- package/ai/dist/src/components/stream/networkTypes.js +17 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/barScene.js +126 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/connectorScene.js +62 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/pieScene.js +33 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/pointScene.js +63 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/statisticalScene.js +278 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/timelineScene.js +30 -0
- package/ai/dist/src/components/stream/ordinalSceneBuilders/types.js +2 -0
- package/ai/dist/src/components/stream/ordinalTypes.js +2 -0
- package/ai/dist/src/components/stream/renderers/areaCanvasRenderer.js +48 -0
- package/ai/dist/src/components/stream/renderers/barCanvasRenderer.js +70 -0
- package/ai/dist/src/components/stream/renderers/boxplotCanvasRenderer.js +75 -0
- package/ai/dist/src/components/stream/renderers/candlestickCanvasRenderer.js +28 -0
- package/ai/dist/src/components/stream/renderers/connectorCanvasRenderer.js +47 -0
- package/ai/dist/src/components/stream/renderers/heatmapCanvasRenderer.js +31 -0
- package/ai/dist/src/components/stream/renderers/lineCanvasRenderer.js +140 -0
- package/ai/dist/src/components/stream/renderers/networkArcRenderer.js +38 -0
- package/ai/dist/src/components/stream/renderers/networkCircleRenderer.js +37 -0
- package/ai/dist/src/components/stream/renderers/networkEdgeRenderer.js +102 -0
- package/ai/dist/src/components/stream/renderers/networkParticleRenderer.js +63 -0
- package/ai/dist/src/components/stream/renderers/networkRectRenderer.js +35 -0
- package/ai/dist/src/components/stream/renderers/pointCanvasRenderer.js +38 -0
- package/ai/dist/src/components/stream/renderers/swarmCanvasRenderer.js +10 -0
- package/ai/dist/src/components/stream/renderers/types.js +2 -0
- package/ai/dist/src/components/stream/renderers/violinCanvasRenderer.js +47 -0
- package/ai/dist/src/components/stream/renderers/waterfallCanvasRenderer.js +38 -0
- package/ai/dist/src/components/stream/renderers/wedgeCanvasRenderer.js +33 -0
- package/ai/dist/src/components/stream/types.js +2 -0
- package/ai/dist/src/components/types/annotationTypes.js +2 -0
- package/ai/dist/src/components/types/canvasTypes.js +2 -0
- package/ai/dist/src/components/types/generalTypes.js +2 -0
- package/ai/dist/src/components/types/interactionTypes.js +2 -0
- package/ai/dist/src/components/types/legendTypes.js +2 -0
- package/ai/dist/src/components/types/networkTypes.js +2 -0
- package/ai/dist/src/components/types/ordinalTypes.js +2 -0
- package/ai/dist/src/components/types/xyTypes.js +2 -0
- package/ai/dist/src/components/useBoundingRect.js +24 -0
- package/ai/dist/src/components/visualizationLayerBehavior/axis.js +301 -0
- package/ai/dist/src/components/visualizationLayerBehavior/general.js +435 -0
- package/ai/dist/src/setupTests.js +4 -0
- package/ai/examples.md +489 -0
- package/ai/schema.json +1338 -0
- package/ai/system-prompt.md +41 -0
- package/dist/AnnotationLayer/AnnotationLayer.d.ts +0 -1
- package/dist/Axis/axisTitle.d.ts +3 -3
- package/dist/Axis/summaryGraphic.d.ts +1 -1
- package/dist/ChartErrorBoundary.d.ts +39 -0
- package/dist/LinkedCharts.d.ts +42 -0
- package/dist/ThemeProvider.d.ts +12 -0
- package/dist/Tooltip/Tooltip.d.ts +141 -0
- package/dist/TooltipPositioner/index.d.ts +1 -1
- package/dist/annotationLayerBehavior/annotationHandling.d.ts +2 -2
- package/dist/annotationRules/networkframeRules.d.ts +2 -2
- package/dist/annotationRules/xyframeRules.d.ts +2 -2
- package/dist/batchWork.d.ts +1 -1
- package/dist/charts/index.d.ts +74 -0
- package/dist/charts/network/ChordDiagram.d.ts +36 -0
- package/dist/charts/network/CirclePack.d.ts +32 -0
- package/dist/charts/network/ForceDirectedGraph.d.ts +38 -0
- package/dist/charts/network/SankeyDiagram.d.ts +38 -0
- package/dist/charts/network/TreeDiagram.d.ts +34 -0
- package/dist/charts/network/Treemap.d.ts +33 -0
- package/dist/charts/ordinal/BarChart.d.ts +32 -0
- package/dist/charts/ordinal/BoxPlot.d.ts +27 -0
- package/dist/charts/ordinal/DonutChart.d.ts +23 -0
- package/dist/charts/ordinal/DotPlot.d.ts +27 -0
- package/dist/charts/ordinal/GroupedBarChart.d.ts +26 -0
- package/dist/charts/ordinal/Histogram.d.ts +26 -0
- package/dist/charts/ordinal/PieChart.d.ts +21 -0
- package/dist/charts/ordinal/RidgelinePlot.d.ts +34 -0
- package/dist/charts/ordinal/StackedBarChart.d.ts +27 -0
- package/dist/charts/ordinal/SwarmPlot.d.ts +29 -0
- package/dist/charts/ordinal/ViolinPlot.d.ts +28 -0
- package/dist/charts/realtime/RealtimeHeatmap.d.ts +95 -0
- package/dist/charts/realtime/RealtimeHistogram.d.ts +119 -0
- package/dist/charts/realtime/RealtimeLineChart.d.ts +98 -0
- package/dist/charts/realtime/RealtimeSwarmChart.d.ts +100 -0
- package/dist/charts/realtime/RealtimeWaterfallChart.d.ts +97 -0
- package/dist/charts/shared/ChartError.d.ts +19 -0
- package/dist/charts/shared/colorUtils.d.ts +62 -0
- package/dist/charts/shared/formatUtils.d.ts +94 -0
- package/dist/charts/shared/hooks.d.ts +20 -0
- package/dist/charts/shared/legendUtils.d.ts +32 -0
- package/dist/charts/shared/selectionUtils.d.ts +51 -0
- package/dist/charts/shared/tooltipUtils.d.ts +18 -0
- package/dist/charts/shared/types.d.ts +97 -0
- package/dist/charts/shared/validateChartData.d.ts +41 -0
- package/dist/charts/shared/validateProps.d.ts +18 -0
- package/dist/charts/xy/AreaChart.d.ts +130 -0
- package/dist/charts/xy/BubbleChart.d.ts +164 -0
- package/dist/charts/xy/Heatmap.d.ts +156 -0
- package/dist/charts/xy/LineChart.d.ts +196 -0
- package/dist/charts/xy/MinimapChart.d.ts +73 -0
- package/dist/charts/xy/Scatterplot.d.ts +55 -0
- package/dist/charts/xy/ScatterplotMatrix.d.ts +71 -0
- package/dist/charts/xy/StackedAreaChart.d.ts +134 -0
- package/dist/constants/frame_props.d.ts +9 -0
- package/dist/data/dataFunctions.d.ts +10 -11
- package/dist/data/transforms.d.ts +45 -0
- package/dist/export/exportChart.d.ts +16 -0
- package/dist/{svg → geometry}/areaDrawing.d.ts +3 -13
- package/dist/geometry/contourLayout.d.ts +6 -0
- package/dist/geometry/hexbinLayout.d.ts +7 -0
- package/dist/{svg → geometry}/lineDrawing.d.ts +7 -35
- package/dist/geometry/sankeyLinks.d.ts +2 -0
- package/dist/geometry/summaryLayouts.d.ts +45 -0
- package/dist/index.d.ts +1 -125
- package/dist/network.js +7495 -0
- package/dist/network.js.map +1 -0
- package/dist/network.min.js +1 -0
- package/dist/network.module.js +7458 -0
- package/dist/network.module.js.map +1 -0
- package/dist/network.module.min.js +1 -0
- package/dist/ordinal.js +6497 -0
- package/dist/ordinal.js.map +1 -0
- package/dist/ordinal.min.js +1 -0
- package/dist/ordinal.module.js +6465 -0
- package/dist/ordinal.module.js.map +1 -0
- package/dist/ordinal.module.min.js +1 -0
- package/dist/processing/InteractionItems.d.ts +5 -4
- package/dist/processing/hierarchyUtils.d.ts +16 -0
- package/dist/processing/layouts/chordLayout.d.ts +2 -0
- package/dist/processing/layouts/forceLayout.d.ts +3 -0
- package/dist/processing/layouts/hierarchyLayout.d.ts +10 -0
- package/dist/processing/layouts/index.d.ts +8 -0
- package/dist/processing/layouts/sankeyLayout.d.ts +8 -0
- package/dist/processing/layouts/simpleLayouts.d.ts +7 -0
- package/dist/processing/layouts/types.d.ts +17 -0
- package/dist/processing/networkDefaults.d.ts +36 -0
- package/dist/realtime/BinAccumulator.d.ts +8 -0
- package/dist/realtime/IncrementalExtent.d.ts +13 -0
- package/dist/realtime/RingBuffer.d.ts +19 -0
- package/dist/realtime/renderers/barRenderer.d.ts +2 -0
- package/dist/realtime/renderers/candlestickRenderer.d.ts +2 -0
- package/dist/realtime/renderers/lineRenderer.d.ts +2 -0
- package/dist/realtime/renderers/swarmRenderer.d.ts +2 -0
- package/dist/realtime/renderers/types.d.ts +9 -0
- package/dist/realtime/renderers/waterfallRenderer.d.ts +3 -0
- package/dist/realtime/types.d.ts +113 -0
- package/dist/realtime.js +7072 -0
- package/dist/realtime.js.map +1 -0
- package/dist/realtime.min.js +1 -0
- package/dist/realtime.module.js +7043 -0
- package/dist/realtime.module.js.map +1 -0
- package/dist/realtime.module.min.js +1 -0
- package/dist/semiotic-ai.d.ts +36 -0
- package/dist/semiotic-ai.js +13323 -0
- package/dist/semiotic-ai.js.map +1 -0
- package/dist/semiotic-ai.min.js +1 -0
- package/dist/semiotic-ai.module.js +13264 -0
- package/dist/semiotic-ai.module.js.map +1 -0
- package/dist/semiotic-ai.module.min.js +1 -0
- package/dist/semiotic-data.d.ts +5 -0
- package/dist/semiotic-data.js +141 -0
- package/dist/semiotic-data.js.map +1 -0
- package/dist/semiotic-data.min.js +1 -0
- package/dist/semiotic-data.module.js +136 -0
- package/dist/semiotic-data.module.js.map +1 -0
- package/dist/semiotic-data.module.min.js +1 -0
- package/dist/semiotic-network.d.ts +23 -0
- package/dist/semiotic-ordinal.d.ts +19 -0
- package/dist/semiotic-realtime.d.ts +22 -0
- package/dist/semiotic-server.d.ts +1 -0
- package/dist/semiotic-xy.d.ts +21 -0
- package/dist/semiotic.d.ts +41 -28
- package/dist/semiotic.js +16257 -13130
- package/dist/semiotic.js.map +1 -0
- package/dist/semiotic.min.js +1 -0
- package/dist/semiotic.module.js +16198 -13100
- package/dist/semiotic.module.js.map +1 -0
- package/dist/semiotic.module.min.js +1 -0
- package/dist/server/renderToStaticSVG.d.ts +9 -0
- package/dist/server.js +5191 -0
- package/dist/server.js.map +1 -0
- package/dist/server.min.js +1 -0
- package/dist/server.module.js +5166 -0
- package/dist/server.module.js.map +1 -0
- package/dist/server.module.min.js +1 -0
- package/dist/store/SelectionStore.d.ts +29 -0
- package/dist/store/ThemeStore.d.ts +26 -0
- package/dist/store/useSelection.d.ts +66 -0
- package/dist/stream/CanvasHitTester.d.ts +18 -0
- package/dist/stream/DataSourceAdapter.d.ts +32 -0
- package/dist/stream/MarginalGraphics.d.ts +19 -0
- package/dist/stream/NetworkCanvasHitTester.d.ts +14 -0
- package/dist/stream/NetworkPipelineStore.d.ts +74 -0
- package/dist/stream/NetworkSVGOverlay.d.ts +40 -0
- package/dist/stream/NetworkSceneGraph.d.ts +14 -0
- package/dist/stream/OrdinalCanvasHitTester.d.ts +9 -0
- package/dist/stream/OrdinalPipelineStore.d.ts +65 -0
- package/dist/stream/OrdinalSVGOverlay.d.ts +34 -0
- package/dist/stream/ParticlePool.d.ts +28 -0
- package/dist/stream/PipelineStore.d.ts +161 -0
- package/dist/stream/SVGOverlay.d.ts +37 -0
- package/dist/stream/SceneGraph.d.ts +16 -0
- package/dist/stream/StreamNetworkFrame.d.ts +4 -0
- package/dist/stream/StreamOrdinalFrame.d.ts +4 -0
- package/dist/stream/StreamXYFrame.d.ts +4 -0
- package/dist/stream/accessorUtils.d.ts +2 -0
- package/dist/stream/index.d.ts +16 -0
- package/dist/stream/layouts/chordLayoutPlugin.d.ts +8 -0
- package/dist/stream/layouts/forceLayoutPlugin.d.ts +9 -0
- package/dist/stream/layouts/hierarchyLayoutPlugin.d.ts +17 -0
- package/dist/stream/layouts/index.d.ts +11 -0
- package/dist/stream/layouts/sankeyLayoutPlugin.d.ts +8 -0
- package/dist/stream/networkTypes.d.ts +346 -0
- package/dist/stream/ordinalSceneBuilders/barScene.d.ts +4 -0
- package/dist/stream/ordinalSceneBuilders/connectorScene.d.ts +3 -0
- package/dist/stream/ordinalSceneBuilders/pieScene.d.ts +3 -0
- package/dist/stream/ordinalSceneBuilders/pointScene.d.ts +4 -0
- package/dist/stream/ordinalSceneBuilders/statisticalScene.d.ts +6 -0
- package/dist/stream/ordinalSceneBuilders/timelineScene.d.ts +3 -0
- package/dist/stream/ordinalSceneBuilders/types.d.ts +21 -0
- package/dist/stream/ordinalTypes.d.ts +225 -0
- package/dist/stream/renderers/areaCanvasRenderer.d.ts +7 -0
- package/dist/stream/renderers/barCanvasRenderer.d.ts +7 -0
- package/dist/stream/renderers/boxplotCanvasRenderer.d.ts +2 -0
- package/dist/stream/renderers/candlestickCanvasRenderer.d.ts +2 -0
- package/dist/stream/renderers/connectorCanvasRenderer.d.ts +2 -0
- package/dist/stream/renderers/heatmapCanvasRenderer.d.ts +6 -0
- package/dist/stream/renderers/lineCanvasRenderer.d.ts +8 -0
- package/dist/stream/renderers/networkArcRenderer.d.ts +5 -0
- package/dist/stream/renderers/networkCircleRenderer.d.ts +5 -0
- package/dist/stream/renderers/networkEdgeRenderer.d.ts +10 -0
- package/dist/stream/renderers/networkParticleRenderer.d.ts +11 -0
- package/dist/stream/renderers/networkRectRenderer.d.ts +5 -0
- package/dist/stream/renderers/pointCanvasRenderer.d.ts +7 -0
- package/dist/stream/renderers/swarmCanvasRenderer.d.ts +7 -0
- package/dist/stream/renderers/types.d.ts +7 -0
- package/dist/stream/renderers/violinCanvasRenderer.d.ts +2 -0
- package/dist/stream/renderers/waterfallCanvasRenderer.d.ts +8 -0
- package/dist/stream/renderers/wedgeCanvasRenderer.d.ts +2 -0
- package/dist/stream/types.d.ts +307 -0
- package/dist/types/annotationTypes.d.ts +13 -18
- package/dist/types/canvasTypes.d.ts +1 -1
- package/dist/types/generalTypes.d.ts +41 -36
- package/dist/types/interactionTypes.d.ts +7 -9
- package/dist/types/legendTypes.d.ts +2 -2
- package/dist/types/networkTypes.d.ts +40 -30
- package/dist/types/ordinalTypes.d.ts +27 -18
- package/dist/types/xyTypes.d.ts +1 -95
- package/dist/visualizationLayerBehavior/axis.d.ts +3 -5
- package/dist/visualizationLayerBehavior/general.d.ts +8 -12
- package/dist/xy.js +6993 -0
- package/dist/xy.js.map +1 -0
- package/dist/xy.min.js +1 -0
- package/dist/xy.module.js +6957 -0
- package/dist/xy.module.js.map +1 -0
- package/dist/xy.module.min.js +1 -0
- package/package.json +123 -67
- package/dist/AnnotationLayer/helpers.d.ts +0 -6
- package/dist/AnnotationLayer/index.d.ts +0 -2
- package/dist/FacetController.d.ts +0 -12
- package/dist/Frame.d.ts +0 -2
- package/dist/InteractionLayer.d.ts +0 -3
- package/dist/Mark/Mark.d.ts +0 -3
- package/dist/Mark/Mark.types.d.ts +0 -10
- package/dist/Mark/constants/markTransition.d.ts +0 -10
- package/dist/Mark/markBehavior/drawing.d.ts +0 -13
- package/dist/MiniMap.d.ts +0 -14
- package/dist/MinimapXYFrame.d.ts +0 -10
- package/dist/NetworkFrame.d.ts +0 -4
- package/dist/OrdinalFrame.d.ts +0 -4
- package/dist/ResponsiveFrame.d.ts +0 -22
- package/dist/ResponsiveMinimapXYFrame.d.ts +0 -6
- package/dist/ResponsiveNetworkFrame.d.ts +0 -6
- package/dist/ResponsiveOrdinalFrame.d.ts +0 -6
- package/dist/ResponsiveXYFrame.d.ts +0 -6
- package/dist/SpanOrDiv.d.ts +0 -10
- package/dist/SparkFrame.d.ts +0 -14
- package/dist/SparkNetworkFrame.d.ts +0 -5
- package/dist/SparkOrdinalFrame.d.ts +0 -5
- package/dist/SparkXYFrame.d.ts +0 -5
- package/dist/VisualizationLayer.d.ts +0 -33
- package/dist/XYFrame.d.ts +0 -4
- package/dist/annotationRules/orframeRules.d.ts +0 -105
- package/dist/components/Annotation.d.ts +0 -3
- package/dist/components/AnnotationLayer/AnnotationLayer.d.ts +0 -26
- package/dist/components/Axis/Axis.d.ts +0 -7
- package/dist/components/Axis/axisTitle.d.ts +0 -10
- package/dist/components/Axis/index.d.ts +0 -2
- package/dist/components/Axis/summaryGraphic.d.ts +0 -17
- package/dist/components/Brush.d.ts +0 -12
- package/dist/components/DividedLine.d.ts +0 -16
- package/dist/components/FacetController.d.ts +0 -12
- package/dist/components/Frame.d.ts +0 -2
- package/dist/components/InteractionLayer.d.ts +0 -3
- package/dist/components/Legend.d.ts +0 -3
- package/dist/components/Mark/Mark.d.ts +0 -3
- package/dist/components/Mark/Mark.types.d.ts +0 -10
- package/dist/components/Mark/markBehavior/drawing.d.ts +0 -13
- package/dist/components/MiniMap.d.ts +0 -14
- package/dist/components/MinimapXYFrame.d.ts +0 -10
- package/dist/components/NetworkFrame.d.ts +0 -4
- package/dist/components/OrdinalFrame.d.ts +0 -4
- package/dist/components/ResponsiveFrame.d.ts +0 -22
- package/dist/components/ResponsiveMinimapXYFrame.d.ts +0 -6
- package/dist/components/ResponsiveNetworkFrame.d.ts +0 -6
- package/dist/components/ResponsiveOrdinalFrame.d.ts +0 -6
- package/dist/components/ResponsiveXYFrame.d.ts +0 -6
- package/dist/components/SpanOrDiv.d.ts +0 -10
- package/dist/components/SparkFrame.d.ts +0 -14
- package/dist/components/SparkNetworkFrame.d.ts +0 -5
- package/dist/components/SparkOrdinalFrame.d.ts +0 -5
- package/dist/components/SparkXYFrame.d.ts +0 -5
- package/dist/components/TooltipPositioner/index.d.ts +0 -7
- package/dist/components/VisualizationLayer.d.ts +0 -33
- package/dist/components/XYFrame.d.ts +0 -4
- package/dist/components/annotationLayerBehavior/annotationHandling.d.ts +0 -19
- package/dist/components/annotationLayerBehavior/d3labeler.d.ts +0 -9
- package/dist/components/annotationRules/baseRules.d.ts +0 -25
- package/dist/components/annotationRules/networkframeRules.d.ts +0 -48
- package/dist/components/annotationRules/orframeRules.d.ts +0 -105
- package/dist/components/annotationRules/xyframeRules.d.ts +0 -117
- package/dist/components/batchWork.d.ts +0 -6
- package/dist/components/constants/coordinateNames.d.ts +0 -8
- package/dist/components/constants/frame_props.d.ts +0 -4
- package/dist/components/constants/jsx.d.ts +0 -19
- package/dist/components/data/dataFunctions.d.ts +0 -46
- package/dist/components/data/multiAccessorUtils.d.ts +0 -1
- package/dist/components/data/unflowedFunctions.d.ts +0 -1
- package/dist/components/generic_utilities/functions.d.ts +0 -1
- package/dist/components/index.d.ts +0 -125
- package/dist/components/interactionLayerBehavior/InteractionCanvas.d.ts +0 -20
- package/dist/components/processing/InteractionItems.d.ts +0 -12
- package/dist/components/processing/network.d.ts +0 -114
- package/dist/components/processing/ordinal.d.ts +0 -102
- package/dist/components/processing/xyDrawing.d.ts +0 -135
- package/dist/components/semiotic.d.ts +0 -35
- package/dist/components/store/TooltipStore.d.ts +0 -2
- package/dist/components/store/createStore.d.ts +0 -1
- package/dist/components/svg/SvgHelper.d.ts +0 -37
- package/dist/components/svg/areaDrawing.d.ts +0 -31
- package/dist/components/svg/ckmeans.d.ts +0 -69
- package/dist/components/svg/frameFunctions.d.ts +0 -119
- package/dist/components/svg/lineDrawing.d.ts +0 -99
- package/dist/components/svg/networkDrawing.d.ts +0 -134
- package/dist/components/svg/pieceDrawing.d.ts +0 -13
- package/dist/components/svg/pieceLayouts.d.ts +0 -71
- package/dist/components/svg/summaryLayouts.d.ts +0 -74
- package/dist/components/types/annotationTypes.d.ts +0 -140
- package/dist/components/types/canvasTypes.d.ts +0 -9
- package/dist/components/types/generalTypes.d.ts +0 -236
- package/dist/components/types/interactionTypes.d.ts +0 -74
- package/dist/components/types/legendTypes.d.ts +0 -20
- package/dist/components/types/networkTypes.d.ts +0 -165
- package/dist/components/types/ordinalTypes.d.ts +0 -103
- package/dist/components/types/xyTypes.d.ts +0 -118
- package/dist/components/useBoundingRect.d.ts +0 -2
- package/dist/components/useDerivedStateFromProps.d.ts +0 -1
- package/dist/components/useLegacyUnmountCallback.d.ts +0 -1
- package/dist/components/visualizationLayerBehavior/axis.d.ts +0 -38
- package/dist/components/visualizationLayerBehavior/general.d.ts +0 -84
- package/dist/constants/jsx.d.ts +0 -19
- package/dist/interactionLayerBehavior/InteractionCanvas.d.ts +0 -20
- package/dist/processing/network.d.ts +0 -114
- package/dist/processing/ordinal.d.ts +0 -102
- package/dist/processing/xyDrawing.d.ts +0 -135
- package/dist/setupTests.d.ts +0 -1
- package/dist/svg/SvgHelper.d.ts +0 -37
- package/dist/svg/ckmeans.d.ts +0 -69
- package/dist/svg/frameFunctions.d.ts +0 -119
- package/dist/svg/networkDrawing.d.ts +0 -134
- package/dist/svg/pieceDrawing.d.ts +0 -13
- package/dist/svg/pieceLayouts.d.ts +0 -71
- package/dist/svg/summaryLayouts.d.ts +0 -74
- package/dist/useDerivedStateFromProps.d.ts +0 -1
- package/dist/useLegacyUnmountCallback.d.ts +0 -1
package/dist/xy.min.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const t=require("react"),e=require("d3-brush"),n=require("d3-selection"),o=require("d3-scale"),r=require("d3-array"),s=require("d3-scale-chromatic"),i=require("labella"),a=require("d3-shape"),l=require("regression"),c=require("d3-contour"),u=require("d3-hexbin");function h(t){return t&&t.__esModule?t:{default:t}}function d(t){if(t&&t.__esModule)return t;const e=Object.create(null);if(t)for(const n in t)if("default"!==n){const o=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,o.get?o:{enumerable:!0,get:function(){return t[n]}})}return e.default=t,Object.freeze(e)}const f=d(t),p=h(i),y=h(l),m=5e3;class g{constructor(t){this.lastBoundedData=null,this.chunkTimer=0,this.callback=t}setBoundedData(t){if(t===this.lastBoundedData)return;if(this.lastBoundedData=t,this.chunkTimer&&(cancelAnimationFrame(this.chunkTimer),this.chunkTimer=0),5e3>=t.length)return void this.callback({inserts:t,bounded:!0});this.callback({inserts:t.slice(0,m),bounded:!0,totalSize:t.length});let e=m;const n=()=>{if(e>=t.length)return;if(t!==this.lastBoundedData)return;const o=Math.min(e+m,t.length);this.callback({inserts:t.slice(e,o),bounded:!1}),e=o,this.chunkTimer=t.length>e?requestAnimationFrame(n):0};this.chunkTimer=requestAnimationFrame(n)}push(t){this.callback({inserts:[t],bounded:!1})}pushMany(t){0!==t.length&&this.callback({inserts:t,bounded:!1})}clear(){this.chunkTimer&&(cancelAnimationFrame(this.chunkTimer),this.chunkTimer=0),this.lastBoundedData=null}}class x{constructor(t){if(this._capacity=t,this.head=0,this._size=0,1>t)throw Error("RingBuffer capacity must be at least 1");this.buffer=Array(t)}push(t){let e;return this._size===this._capacity?e=this.buffer[this.head]:this._size++,this.buffer[this.head]=t,this.head=(this.head+1)%this._capacity,e}pushMany(t){const e=[];for(const n of t){const t=this.push(n);void 0!==t&&e.push(t)}return e}get(t){if(t>=0&&this._size>t)return this.buffer[(this.head-this._size+t+this._capacity)%this._capacity]}peek(){if(0!==this._size)return this.buffer[(this.head-1+this._capacity)%this._capacity]}peekOldest(){if(0!==this._size)return this.buffer[(this.head-this._size+this._capacity)%this._capacity]}[Symbol.iterator](){let t=0;const e=this;return{next:()=>e._size>t?{done:!1,value:e.get(t++)}:{done:!0,value:void 0}}}toArray(){const t=[];for(const e of this)t.push(e);return t}resize(t){if(1>t)throw Error("RingBuffer capacity must be at least 1");const e=this.toArray(),n=[];for(;e.length>t;)n.push(e.shift());this._capacity=t,this.buffer=Array(t),this.head=0,this._size=0;for(const t of e)this.push(t);return n}clear(){this.buffer=Array(this._capacity),this.head=0,this._size=0}get size(){return this._size}get capacity(){return this._capacity}get full(){return this._size===this._capacity}}class b{constructor(){this._min=1/0,this._max=-1/0,this._dirty=!1}push(t){Number.isNaN(t)||(this._min>t&&(this._min=t),t>this._max&&(this._max=t))}evict(t){t!==this._min&&t!==this._max||(this._dirty=!0)}recalculate(t,e){this._min=1/0,this._max=-1/0;for(const n of t){const t=e?e(n):n;Number.isNaN(t)||(this._min>t&&(this._min=t),t>this._max&&(this._max=t))}this._dirty=!1}clear(){this._min=1/0,this._max=-1/0,this._dirty=!1}get extent(){return[this._min,this._max]}get min(){return this._min}get max(){return this._max}get dirty(){return this._dirty}}function v(t,e,n,o,r){const s=new Map;for(const i of t){const t=e(i),a=n(i);if(null==t||null==a||Number.isNaN(t)||Number.isNaN(a))continue;const l=Math.floor(t/o)*o;let c=s.get(l);if(c||(c={start:l,end:l+o,total:0,categories:new Map},s.set(l,c)),c.total+=a,r){const t=r(i);c.categories.set(t,(c.categories.get(t)||0)+a)}}return s}function k(t,e,n,o,r,s){const i=[],a=[];for(const r of t){const t=n(r),s=o(r);null==t||null==s||Number.isNaN(t)||Number.isNaN(s)||(i.push([e.x(t),e.y(s)]),a.push(s))}return{type:"line",path:i,rawValues:a,style:r,datum:t,group:s}}function E(t,e,n,o,r,s,i){const a=[],l=[];for(const s of t){const t=n(s),i=o(s);if(null==t||null==i||Number.isNaN(t)||Number.isNaN(i))continue;const c=e.x(t);a.push([c,e.y(i)]),l.push([c,e.y(r)])}return{type:"area",topPath:a,bottomPath:l,style:s,datum:t,group:i}}function w(t,e,n,o,r,s){const i=n(t),a=o(t);return null==i||null==a||Number.isNaN(i)||Number.isNaN(a)?null:{type:"point",x:e.x(i),y:e.y(a),r:r,style:s,datum:t}}function M(t,e,n,o,r,s,i){return{type:"rect",x:t,y:e,w:n,h:o,style:r,datum:s,group:i}}function A(t,e,n,o,r,s){return{type:"heatcell",x:t,y:e,w:n,h:o,fill:r,datum:s}}function S(t,e){if("function"==typeof t)return e=>+t(e);const n=t||e;return t=>+t[n]}function $(t,e){return"function"==typeof t?t:t?e=>e[t]+"":void 0}class P{constructor(t){this.xExtent=new b,this.yExtent=new b,this.timestampBuffer=null,this.activeTransition=null,this.prevPositionMap=new Map,this.lastIngestTime=0,this.scales=null,this.scene=[],this.version=0,this.config=t,this.buffer=new x(t.windowSize),this.growingCap=t.windowSize,["bar","swarm","waterfall"].includes(t.chartType)||"streaming"===t.runtimeMode?(this.getX=S(t.timeAccessor||t.xAccessor,"time"),this.getY=S(t.valueAccessor||t.yAccessor,"value")):(this.getX=S(t.xAccessor,"x"),this.getY=S(t.yAccessor,"y")),this.getGroup=$(t.groupAccessor),this.getCategory=$(t.categoryAccessor),this.getSize=t.sizeAccessor?S(t.sizeAccessor,"size"):void 0,this.getColor=$(t.colorAccessor),this.getBounds=t.boundsAccessor?S(t.boundsAccessor,"bounds"):void 0,"candlestick"===t.chartType&&(this.getOpen=S(t.openAccessor,"open"),this.getHigh=S(t.highAccessor,"high"),this.getLow=S(t.lowAccessor,"low"),this.getClose=S(t.closeAccessor,"close")),t.pulse&&(this.timestampBuffer=new x(t.windowSize))}ingest(t){const e="undefined"!=typeof performance?performance.now():Date.now();if(this.lastIngestTime=e,t.bounded){this.buffer.clear(),this.xExtent.clear(),this.yExtent.clear(),this.timestampBuffer&&this.timestampBuffer.clear();const n=t.totalSize||t.inserts.length;n>this.buffer.capacity&&(this.buffer.resize(n),this.timestampBuffer&&n>this.timestampBuffer.capacity&&this.timestampBuffer.resize(n));for(const n of t.inserts)this.buffer.push(n),this.timestampBuffer&&this.timestampBuffer.push(e),this.xExtent.push(this.getX(n)),"candlestick"===this.config.chartType&&this.getHigh&&this.getLow?(this.yExtent.push(this.getHigh(n)),this.yExtent.push(this.getLow(n))):this.yExtent.push(this.getY(n))}else for(const n of t.inserts){"growing"===this.config.windowMode&&this.buffer.full&&(this.growingCap*=2,this.buffer.resize(this.growingCap),this.timestampBuffer&&this.timestampBuffer.resize(this.growingCap));const t=this.buffer.push(n);this.timestampBuffer&&this.timestampBuffer.push(e),this.xExtent.push(this.getX(n)),"candlestick"===this.config.chartType&&this.getHigh&&this.getLow?(this.yExtent.push(this.getHigh(n)),this.yExtent.push(this.getLow(n))):this.yExtent.push(this.getY(n)),null!=t&&(this.xExtent.evict(this.getX(t)),"candlestick"===this.config.chartType&&this.getHigh&&this.getLow?(this.yExtent.evict(this.getHigh(t)),this.yExtent.evict(this.getLow(t))):this.yExtent.evict(this.getY(t)))}return!0}computeScene(t){var e,n,r,s,i,a;const{config:l,buffer:c}=this;if(this.xExtent.dirty&&this.xExtent.recalculate(c,this.getX),this.yExtent.dirty)if("candlestick"===l.chartType&&this.getHigh&&this.getLow){this.yExtent.clear();for(const t of c)this.yExtent.push(this.getHigh(t)),this.yExtent.push(this.getLow(t))}else this.yExtent.recalculate(c,this.getY);const u=this.xExtent.extent,h=this.yExtent.extent;let d=l.xExtent?[null!==(e=l.xExtent[0])&&void 0!==e?e:u[0],null!==(n=l.xExtent[1])&&void 0!==n?n:u[1]]:u,f=l.yExtent?[null!==(r=l.yExtent[0])&&void 0!==r?r:h[0],null!==(s=l.yExtent[1])&&void 0!==s?s:h[1]]:h;const p=l.yExtent&&null!=l.yExtent[0]&&null!=l.yExtent[1];if("stackedarea"===l.chartType&&!p&&c.size>0)if(l.normalize)f=[0,1+l.extentPadding];else{const t=c.toArray(),e=this.groupData(t),n=new Map;for(const t of e)for(const e of t.data){const t=this.getX(e),o=this.getY(e);null==t||null==o||Number.isNaN(t)||Number.isNaN(o)||n.set(t,(n.get(t)||0)+o)}let o=0;for(const t of n.values())t>o&&(o=t);f=[0,o+(o>0?o*l.extentPadding:1)]}else if("bar"===l.chartType&&l.binSize&&!p&&c.size>0){const[,t]=function(t,e,n,o,r){const s=v(t,e,n,o,r);if(0===s.size)return[0,0];let i=0;for(const t of s.values())t.total>i&&(i=t.total);return[0,i]}(c,this.getX,this.getY,l.binSize,this.getCategory);f=[0,t+t*l.extentPadding]}else if("waterfall"===l.chartType&&!p&&c.size>0){const[t,e]=function(t,e){let n=0,o=0,r=0;for(const s of t){const t=e(s);null==t||Number.isNaN(t)||(r+=t,n>r&&(n=r),r>o&&(o=r))}return[n,o]}(c,this.getY),n=e-t,o=n>0?n*l.extentPadding:1;f=[Math.min(0,t-Math.abs(o)),Math.max(0,e+Math.abs(o))]}else if(!p&&f[0]!==1/0){if(this.getBounds){const t=c.toArray();for(const e of t){const t=this.getY(e),n=this.getBounds(e);null!=t&&!Number.isNaN(t)&&n&&(t+n>f[1]&&(f[1]=t+n),f[0]>t-n&&(f[0]=t-n))}}const t=f[1]-f[0],e=t>0?t*l.extentPadding:1,n=null===(i=l.yExtent)||void 0===i?void 0:i[0],o=null===(a=l.yExtent)||void 0===a?void 0:a[1];f=[null!=n?f[0]:f[0]-e,null!=o?f[1]:f[1]+e]}if(d[0]!==1/0&&d[1]!==-1/0||(d=[0,1]),f[0]!==1/0&&f[1]!==-1/0||(f=[0,1]),void 0!==l.arrowOfTime)if("x"==("up"===(y=l.arrowOfTime)||"down"===y?"y":"x")){const e="right"===l.arrowOfTime?[0,t.width]:[t.width,0];this.scales={x:o.scaleLinear().domain(d).range(e),y:o.scaleLinear().domain(f).range([t.height,0])}}else{const e="down"===l.arrowOfTime?[0,t.height]:[t.height,0];this.scales={x:o.scaleLinear().domain(f).range([0,t.width]),y:o.scaleLinear().domain(d).range(e)}}else this.scales={x:o.scaleLinear().domain(d).range([0,t.width]),y:o.scaleLinear().domain(f).range([t.height,0])};var y;this.config.transition&&this.scene.length>0&&this.snapshotPositions();const m=c.toArray();this.scene=this.buildSceneNodes(t),this.config.decay&&this.applyDecay(this.scene,m),this.config.pulse&&this.applyPulse(this.scene,m),this.config.transition&&this.prevPositionMap.size>0&&this.startTransition(),this.version++}buildSceneNodes(t){const{config:e,buffer:n,scales:o}=this;if(!o||0===n.size)return[];const r=n.toArray();switch(e.chartType){case"line":return this.buildLineScene(r);case"area":return this.buildAreaScene(r);case"stackedarea":return this.buildStackedAreaScene(r);case"scatter":case"bubble":return this.buildPointScene(r);case"heatmap":return this.buildHeatmapScene(r,t);case"bar":return this.buildBarScene(r);case"swarm":return this.buildSwarmScene(r);case"waterfall":return this.buildWaterfallScene(r,t);case"candlestick":return this.buildCandlestickScene(r,t);default:return[]}}buildLineScene(t){var e;const n=this.groupData(t),o=[],r=null===(e=this.config.annotations)||void 0===e?void 0:e.filter(t=>"threshold"===t.type&&t.color).map(t=>({value:t.value,color:t.color,thresholdType:t.thresholdType||"greater"}));if(this.getBounds)for(const t of n){const e=this.buildBoundsForGroup(t.data,t.key);e&&o.push(e)}for(const t of n){const e=this.resolveLineStyle(t.key,t.data[0]),n=k(t.data,this.scales,this.getX,this.getY,e,t.key);r&&r.length>0&&(n.colorThresholds=r),o.push(n)}return o}buildAreaScene(t){const e=this.groupData(t),n=[],o=this.scales.y.domain()[0];for(const t of e){const e=this.resolveAreaStyle(t.key,t.data[0]);n.push(E(t.data,this.scales,this.getX,this.getY,o,e,t.key))}return n}buildStackedAreaScene(t){return function(t,e,n,o,r,s){var i;const a=new Set;for(const e of t)for(const t of e.data){const e=n(t);null==e||Number.isNaN(e)||a.add(e)}const l=Array.from(a).sort((t,e)=>t-e),c=new Map;for(const e of t){const t=new Map;for(const r of e.data){const e=n(r),s=o(r);null==e||null==s||Number.isNaN(e)||Number.isNaN(s)||t.set(e,(t.get(e)||0)+s)}c.set(e.key,t)}let u;if(s){u=new Map;for(const e of l){let n=0;for(const o of t)n+=(null===(i=c.get(o.key))||void 0===i?void 0:i.get(e))||0;u.set(e,n||1)}}const h=[],d=new Map;for(const t of l)d.set(t,0);for(const n of t){const t=c.get(n.key),o=[],i=[];for(const n of l){let r=t.get(n)||0;const a=d.get(n);s&&(r/=u.get(n));const l=e.x(n);i.push([l,e.y(a)]),o.push([l,e.y(a+r)]),d.set(n,a+r)}h.push({type:"area",topPath:o,bottomPath:i,style:r(n.key,n.data[0]),datum:n.data,group:n.key})}return h}(this.groupData(t),this.scales,this.getX,this.getY,(t,e)=>this.resolveAreaStyle(t,e),this.config.normalize)}buildPointScene(t){const e=[],n="bubble"===this.config.chartType?10:5,o=this.config.sizeRange||[3,15];let r=null;if(this.getSize&&!this.config.pointStyle){const e=t.map(t=>this.getSize(t)).filter(t=>null!=t&&!Number.isNaN(t));if(e.length>0){const t=Math.min(...e),n=Math.max(...e);r=e=>t===n?(o[0]+o[1])/2:o[0]+(e-t)/(n-t)*(o[1]-o[0])}}let s=null;if(this.getColor&&!this.config.pointStyle){const e=new Set;for(const n of t){const t=this.getColor(n);t&&e.add(t)}const n=Array.isArray(this.config.colorScheme)?this.config.colorScheme:["#4e79a7","#f28e2b","#e15759","#76b7b2","#59a14f","#edc948","#b07aa1","#ff9da7","#9c755f","#bab0ac"];s=new Map;let o=0;for(const t of e)s.set(t,n[o%n.length]),o++}for(const o of t){let t=this.config.pointStyle?this.config.pointStyle(o):{fill:"#4e79a7",opacity:.8},i=t.r||n;if(r&&this.getSize){const t=this.getSize(o);null==t||Number.isNaN(t)||(i=r(t))}if(s&&this.getColor){const e=this.getColor(o);e&&s.has(e)&&(t=Object.assign(Object.assign({},t),{fill:s.get(e)}))}const a=w(o,this.scales,this.getX,this.getY,i,t);a&&e.push(a)}return e}buildHeatmapScene(t,e){const n=[];if(this.config.heatmapAggregation)return this.buildStreamingHeatmapScene(t,e);const o=S(this.config.valueAccessor,"value"),r=new Set,s=new Set;for(const e of t)r.add(this.getX(e)),s.add(this.getY(e));const i=Array.from(r).sort((t,e)=>t-e),a=Array.from(s).sort((t,e)=>t-e);if(0===i.length||0===a.length)return n;const l=e.width/i.length,c=e.height/a.length,u=new Map;for(const e of t){const t=`${this.getX(e)}_${this.getY(e)}`;u.set(t,{val:o(e),datum:e})}let h=1/0,d=-1/0;for(const{val:t}of u.values())h>t&&(h=t),t>d&&(d=t);const f=d-h||1;for(let t=0;i.length>t;t++)for(let e=0;a.length>e;e++){const o=u.get(`${i[t]}_${a[e]}`);if(!o)continue;const r=(o.val-h)/f;n.push(A(t*l,(a.length-1-e)*c,l,c,`rgb(${Math.round(220-180*r)},${Math.round(220-100*r)},${Math.round(255-50*r)})`,o.datum))}return n}buildStreamingHeatmapScene(t,e){var n,o,r;const s=[],i=null!==(n=this.config.heatmapXBins)&&void 0!==n?n:20,a=null!==(o=this.config.heatmapYBins)&&void 0!==o?o:20,l=null!==(r=this.config.heatmapAggregation)&&void 0!==r?r:"count",c=S(this.config.valueAccessor,"value");if(!this.scales||0===t.length)return s;const[u,h]=this.scales.x.domain(),[d,f]=this.scales.y.domain(),p=(h-u||1)/i,y=(f-d||1)/a,m=new Map;for(const e of t){const t=this.getX(e),n=this.getY(e),o=Math.min(Math.floor((t-u)/p),i-1),r=Math.min(Math.floor((n-d)/y),a-1);if(0>o||0>r)continue;const s=`${o}_${r}`;let l=m.get(s);l||(l={sum:0,count:0,data:[]},m.set(s,l)),l.count++,l.sum+=c(e),l.data.push(e)}let g=1/0,x=-1/0;const b=new Map;for(const[t,e]of m){let n;switch(l){case"sum":n=e.sum;break;case"mean":n=e.count>0?e.sum/e.count:0;break;default:n=e.count}b.set(t,n),g>n&&(g=n),n>x&&(x=n)}const v=x-g||1,k=e.width/i,E=e.height/a;for(const[t,e]of b){const[n,o]=t.split("_"),r=+n,i=+o,l=(e-g)/v,c=`rgb(${Math.round(220-180*l)},${Math.round(220-100*l)},${Math.round(255-50*l)})`,u=m.get(t);s.push(A(r*k,(a-1-i)*E,k,E,c,{xi:r,yi:i,value:e,count:u.count,sum:u.sum,data:u.data}))}return s}buildBarScene(t){var e;if(!this.config.binSize)return[];const n=v(t,this.getX,this.getY,this.config.binSize,this.getCategory);if(0===n.size)return[];let o=null;if(this.getCategory){const t=new Set;for(const e of n.values())for(const n of e.categories.keys())t.add(n);const e=this.config.barColors?Object.keys(this.config.barColors):[],r=new Set(e),s=Array.from(t).filter(t=>!r.has(t)).sort();o=[...e.filter(e=>t.has(e)),...s]}const r=[],s=this.scales,[i,a]=s.x.domain();for(const t of n.values()){const n=Math.max(t.start,i),l=Math.min(t.end,a);if(n>=l)continue;const c=s.x(n),u=s.x(l),h=Math.min(c,u)+.5,d=Math.max(c,u)-.5-h;if(d>0)if(o&&t.categories.size>0){let n=0;for(const i of o){const o=t.categories.get(i)||0;if(0===o)continue;const a=s.y(n),l=s.y(n+o);r.push(M(h,Math.min(a,l),d,Math.abs(a-l),{fill:(null===(e=this.config.barColors)||void 0===e?void 0:e[i])||"#4e79a7"},{binStart:t.start,binEnd:t.end,total:t.total,category:i,categoryValue:o},i)),n+=o}}else{const e=s.y(0),n=s.y(t.total);r.push(M(h,Math.min(e,n),d,Math.abs(e-n),{fill:"#007bff"},{binStart:t.start,binEnd:t.end,total:t.total}))}}return r}buildSwarmScene(t){var e,n,o,r;const s=[],i=this.config.swarmStyle||{},a=null!==(e=i.radius)&&void 0!==e?e:3,l=null!==(n=i.fill)&&void 0!==n?n:"#007bff",c=null!==(o=i.opacity)&&void 0!==o?o:.7,u=i.stroke,h=i.strokeWidth;for(const e of t){const t=this.getX(e),n=this.getY(e);if(null==n||Number.isNaN(n))continue;const o=this.scales.x(t),i=this.scales.y(n);let d=l;if(this.getCategory){const t=this.getCategory(e);d=(null===(r=this.config.barColors)||void 0===r?void 0:r[t])||d}s.push({type:"point",x:o,y:i,r:a,style:{fill:d,opacity:c,stroke:u,strokeWidth:h},datum:e})}return s}buildWaterfallScene(t,e){const n=[],o=this.scales,r=t.filter(t=>{const e=this.getY(t);return null!=e&&!Number.isNaN(e)});if(0===r.length)return n;let s=0;for(let t=0;r.length>t;t++){const i=r[t],a=this.getX(i),l=this.getY(i),c=s+l;let u;u=r.length-1>t?this.getX(r[t+1])-a:t>0?a-this.getX(r[t-1]):0;const h=o.x(a),d=0!==u?o.x(a+u):h+e.width/10,f=Math.min(h,d)+.5,p=Math.max(h,d)-.5-f;if(0>=p){s=c;continue}const y=o.y(s),m=o.y(c);n.push(M(f,Math.min(y,m),p,Math.abs(y-m),{fill:0>l?"#dc3545":"#28a745"},Object.assign(Object.assign({},i),{baseline:s,cumEnd:c,delta:l}))),s=c}return n}buildCandlestickScene(t,e){if(!(this.getOpen&&this.getHigh&&this.getLow&&this.getClose&&this.scales))return[];const n=[],o=this.config.candlestickStyle||{},r=o.upColor||"#28a745",s=o.downColor||"#dc3545",i=o.wickColor||"#333",a=o.wickWidth||1,l=t.map(t=>this.getX(t)).filter(t=>null!=t&&!Number.isNaN(t)).sort((t,e)=>t-e);let c=o.bodyWidth||6;if(!o.bodyWidth&&l.length>1){let t=1/0;for(let e=1;l.length>e;e++){const n=Math.abs(this.scales.x(l[e])-this.scales.x(l[e-1]));n>0&&t>n&&(t=n)}t!==1/0&&(c=Math.max(2,Math.min(.6*t,20)))}for(const e of t){const t=this.getX(e);if(null==t||Number.isNaN(t))continue;const o=this.getOpen(e),l=this.getHigh(e),u=this.getLow(e),h=this.getClose(e);if([o,l,u,h].some(t=>null==t||Number.isNaN(t)))continue;const d=h>=o;n.push({type:"candlestick",x:this.scales.x(t),openY:this.scales.y(o),closeY:this.scales.y(h),highY:this.scales.y(l),lowY:this.scales.y(u),bodyWidth:c,upColor:r,downColor:s,wickColor:i,wickWidth:a,isUp:d,datum:e})}return n}buildBoundsForGroup(t,e){if(!this.getBounds||!this.scales)return null;const n=[],o=[];for(const e of t){const t=this.getX(e),r=this.getY(e);if(null==t||null==r||Number.isNaN(t)||Number.isNaN(r))continue;const s=this.getBounds(e),i=this.scales.x(t);if(s&&0!==s)n.push([i,this.scales.y(r+s)]),o.push([i,this.scales.y(r-s)]);else{const t=this.scales.y(r);n.push([i,t]),o.push([i,t])}}return 2>n.length?null:{type:"area",topPath:n,bottomPath:o,style:this.resolveBoundsStyle(e,t[0]),datum:t,group:e,interactive:!1}}resolveBoundsStyle(t,e){const n=this.config.boundsStyle;return"function"==typeof n?n(e||{},t):n&&"object"==typeof n?n:{fill:this.resolveLineStyle(t,e).stroke||"#4e79a7",fillOpacity:.2,stroke:"none"}}computeDecayOpacity(t,e){var n,o,r;const s=this.config.decay;if(!s||1>=e)return 1;const i=null!==(n=s.minOpacity)&&void 0!==n?n:.1,a=e-1-t;switch(s.type){case"linear":return i+(1-a/(e-1))*(1-i);case"exponential":{const t=null!==(o=s.halfLife)&&void 0!==o?o:e/2;return i+Math.pow(.5,a/t)*(1-i)}case"step":return(null!==(r=s.stepThreshold)&&void 0!==r?r:.5*e)>a?1:i;default:return 1}}applyDecay(t,e){var n,o;if(!this.config.decay)return;const r=e.length;if(1>=r)return;const s=new Map;for(let t=0;e.length>t;t++)s.set(e[t],t);for(const e of t){if("line"===e.type||"area"===e.type)continue;const t=s.get(e.datum);if(null==t)continue;const i=this.computeDecayOpacity(t,r);if("heatcell"===e.type)e.style={opacity:i};else if("candlestick"===e.type)e._decayOpacity=i;else{const t=null!==(o=null===(n=e.style)||void 0===n?void 0:n.opacity)&&void 0!==o?o:1;e.style=Object.assign(Object.assign({},e.style),{opacity:t*i})}}}computePulseIntensity(t,e){var n;const o=this.config.pulse;if(!o)return 0;const r=null!==(n=o.duration)&&void 0!==n?n:500,s=e-t;return r>s?1-s/r:0}applyPulse(t,e){var n;if(!this.config.pulse||!this.timestampBuffer)return;const o="undefined"!=typeof performance?performance.now():Date.now(),r=null!==(n=this.config.pulse.color)&&void 0!==n?n:"rgba(255,255,255,0.6)",s=new Map;for(let t=0;e.length>t;t++)s.set(e[t],t);for(const e of t){if("line"===e.type||"area"===e.type)continue;const t=s.get(e.datum);if(null==t)continue;const n=this.timestampBuffer.get(t);if(null==n)continue;const i=this.computePulseIntensity(n,o);i>0&&(e._pulseIntensity=i,e._pulseColor=r)}}get hasActivePulses(){var t;if(!this.config.pulse||!this.timestampBuffer||0===this.timestampBuffer.size)return!1;const e="undefined"!=typeof performance?performance.now():Date.now(),n=null!==(t=this.config.pulse.duration)&&void 0!==t?t:500,o=this.timestampBuffer.peek();return null!=o&&n>e-o}snapshotPositions(){this.prevPositionMap.clear();for(let t=0;this.scene.length>t;t++){const e=this.scene[t],n=this.getNodeIdentity(e,t);n&&("point"===e.type?this.prevPositionMap.set(n,{x:e.x,y:e.y,r:e.r}):"rect"===e.type||"heatcell"===e.type?this.prevPositionMap.set(n,{x:e.x,y:e.y,w:e.w,h:e.h}):"candlestick"===e.type&&this.prevPositionMap.set(n,{x:e.x,y:e.openY}))}}getNodeIdentity(t,e){var n,o,r,s;switch(t.type){case"point":return`p:${void 0===t.datum?e:this.getX(t.datum)}_${this.getY(t.datum)}`;case"rect":return`r:${t.group||""}:${null!==(s=null!==(o=null===(n=t.datum)||void 0===n?void 0:n.binStart)&&void 0!==o?o:null===(r=t.datum)||void 0===r?void 0:r.category)&&void 0!==s?s:e}`;case"heatcell":return`h:${t.x}_${t.y}`;case"candlestick":return"c:"+this.getX(t.datum);default:return null}}startTransition(){var t,e,n,o,r,s;if(!this.config.transition||0===this.prevPositionMap.size)return;const i=null!==(t=this.config.transition.duration)&&void 0!==t?t:300;let a=!1;for(let t=0;this.scene.length>t;t++){const i=this.scene[t],l=this.getNodeIdentity(i,t);if(!l)continue;const c=this.prevPositionMap.get(l);if(c)if("point"===i.type){const t={x:i.x,y:i.y,r:i.r};c.x===t.x&&c.y===t.y||(i._targetX=t.x,i._targetY=t.y,i._targetR=t.r,i.x=c.x,i.y=c.y,i.r=null!==(e=c.r)&&void 0!==e?e:i.r,a=!0)}else if("rect"===i.type){const t={x:i.x,y:i.y,w:i.w,h:i.h};c.x===t.x&&c.y===t.y&&c.w===t.w&&c.h===t.h||(i._targetX=t.x,i._targetY=t.y,i._targetW=t.w,i._targetH=t.h,i.x=c.x,i.y=c.y,i.w=null!==(n=c.w)&&void 0!==n?n:i.w,i.h=null!==(o=c.h)&&void 0!==o?o:i.h,a=!0)}else if("heatcell"===i.type){const t={x:i.x,y:i.y,w:i.w,h:i.h};c.x===t.x&&c.y===t.y||(i._targetX=t.x,i._targetY=t.y,i._targetW=t.w,i._targetH=t.h,i.x=c.x,i.y=c.y,i.w=null!==(r=c.w)&&void 0!==r?r:i.w,i.h=null!==(s=c.h)&&void 0!==s?s:i.h,a=!0)}}a&&(this.activeTransition={startTime:"undefined"!=typeof performance?performance.now():Date.now(),duration:i})}advanceTransition(t){var e;if(!this.activeTransition)return!1;const n=Math.min((t-this.activeTransition.startTime)/this.activeTransition.duration,1),o="linear"===(null===(e=this.config.transition)||void 0===e?void 0:e.easing)?n:1-Math.pow(1-n,3);for(const t of this.scene)if("point"===t.type){if(void 0===t._targetX)continue;const e=this.getNodeIdentity(t,0);if(!e)continue;const n=this.prevPositionMap.get(e);if(!n)continue;t.x=n.x+(t._targetX-n.x)*o,t.y=n.y+(t._targetY-n.y)*o,void 0!==t._targetR&&void 0!==n.r&&(t.r=n.r+(t._targetR-n.r)*o)}else if("rect"===t.type){if(void 0===t._targetX)continue;const e=this.getNodeIdentity(t,0);if(!e)continue;const n=this.prevPositionMap.get(e);if(!n)continue;t.x=n.x+(t._targetX-n.x)*o,t.y=n.y+(t._targetY-n.y)*o,void 0!==n.w&&(t.w=n.w+(t._targetW-n.w)*o),void 0!==n.h&&(t.h=n.h+(t._targetH-n.h)*o)}else if("heatcell"===t.type){if(void 0===t._targetX)continue;const e=this.getNodeIdentity(t,0);if(!e)continue;const n=this.prevPositionMap.get(e);if(!n)continue;t.x=n.x+(t._targetX-n.x)*o,t.y=n.y+(t._targetY-n.y)*o,void 0!==n.w&&(t.w=n.w+(t._targetW-n.w)*o),void 0!==n.h&&(t.h=n.h+(t._targetH-n.h)*o)}if(n>=1){for(const t of this.scene)if("point"===t.type){if(void 0===t._targetX)continue;t.x=t._targetX,t.y=t._targetY,void 0!==t._targetR&&(t.r=t._targetR),t._targetX=void 0,t._targetY=void 0,t._targetR=void 0}else if("rect"===t.type){if(void 0===t._targetX)continue;t.x=t._targetX,t.y=t._targetY,t.w=t._targetW,t.h=t._targetH,t._targetX=void 0,t._targetY=void 0,t._targetW=void 0,t._targetH=void 0}else if("heatcell"===t.type){if(void 0===t._targetX)continue;t.x=t._targetX,t.y=t._targetY,t.w=t._targetW,t.h=t._targetH,t._targetX=void 0,t._targetY=void 0,t._targetW=void 0,t._targetH=void 0}return this.activeTransition=null,!1}return!0}groupData(t){if(!this.getGroup)return[{key:"_default",data:t}];const e=new Map;for(const n of t){const t=this.getGroup(n);e.has(t)||e.set(t,[]),e.get(t).push(n)}return Array.from(e.entries()).map(([t,e])=>({key:t,data:e}))}resolveLineStyle(t,e){const n=this.config.lineStyle;return"function"==typeof n?n(e||{},t):n&&"object"==typeof n?{stroke:n.stroke||"#007bff",strokeWidth:n.strokeWidth||2,strokeDasharray:n.strokeDasharray,fill:n.fill,fillOpacity:n.fillOpacity,opacity:n.opacity}:{stroke:"#007bff",strokeWidth:2}}resolveAreaStyle(t,e){var n;if(this.config.areaStyle)return this.config.areaStyle(e||{});const o=this.config.lineStyle;return"function"==typeof o?o(e||{},t):o&&"object"==typeof o?{fill:o.fill||o.stroke||"#4e79a7",fillOpacity:null!==(n=o.fillOpacity)&&void 0!==n?n:.7,stroke:o.stroke||"#4e79a7",strokeWidth:o.strokeWidth||2}:{fill:"#4e79a7",fillOpacity:.7,stroke:"#4e79a7",strokeWidth:2}}getData(){return this.buffer.toArray()}getExtents(){return this.xExtent.min===1/0?null:{x:this.xExtent.extent,y:this.yExtent.extent}}clear(){this.buffer.clear(),this.xExtent.clear(),this.yExtent.clear(),this.timestampBuffer&&this.timestampBuffer.clear(),this.prevPositionMap.clear(),this.activeTransition=null,this.lastIngestTime=0,this.scales=null,this.scene=[],this.version++}get size(){return this.buffer.size}getBuffer(){return this.buffer}getXAccessor(){return this.getX}getYAccessor(){return this.getY}getCategoryAccessor(){return this.getCategory}updateConfig(t){Object.assign(this.config,t)}}function N(t,e,n){const o=e-t.x,r=n-t.y,s=Math.sqrt(o*o+r*r);return s>t.r+5?null:{node:t,datum:t.datum,x:t.x,y:t.y,distance:s}}function _(t,e,n){if(0===t.path.length)return null;const o=C(t.path,e);if(0>o)return null;const[r,s]=t.path[o],i=e-r,a=n-s,l=Math.sqrt(i*i+a*a);return{node:t,datum:Array.isArray(t.datum)&&t.datum[o]?t.datum[o]:t.datum,x:r,y:s,distance:l}}function O(t,e,n){return t.x>e||e>t.x+t.w||t.y>n||n>t.y+t.h?null:{node:t,datum:t.datum,x:t.x+t.w/2,y:t.y+t.h/2,distance:0}}function D(t,e,n){return t.x>e||e>t.x+t.w||t.y>n||n>t.y+t.h?null:{node:t,datum:t.datum,x:t.x+t.w/2,y:t.y+t.h/2,distance:0}}function j(t,e,n){const o=t.bodyWidth/2,r=Math.min(t.openY,t.closeY);if(!(t.x-o-3>e||e>t.x+o+3||t.highY-3>n||n>t.lowY+3)){const o=r+Math.max(Math.max(t.openY,t.closeY)-r,1)/2,s=e-t.x,i=n-o;return{node:t,datum:t.datum,x:t.x,y:o,distance:Math.sqrt(s*s+i*i)}}return null}function T(t,e,n){if(0===t.topPath.length)return null;const o=C(t.topPath,e);if(0>o)return null;const[r,s]=t.topPath[o],i=e-r,a=n-s;return{node:t,datum:t.datum,x:r,y:s,distance:Math.sqrt(i*i+a*a)}}function C(t,e){if(0===t.length)return-1;let n=0,o=t.length-1;for(;o>n;){const r=n+o>>1;e>t[r][0]?n=r+1:o=r}return n>0&&Math.abs(t[n][0]-e)>=Math.abs(t[n-1][0]-e)?n-1:n}const z={fill:t=>f.createElement("rect",{style:t,width:20,height:20}),line:t=>f.createElement("line",{style:t,x1:0,y1:0,x2:20,y2:20})};function B(t,e,n,o){let r;return r="function"==typeof n?n(t):(0,z[n])(o(t,e)),r}function W(t){const{legendGroups:e,customClickBehavior:n,title:o="Legend",width:r=100,height:s=20,orientation:i="vertical"}=t,a="vertical"===i?(({legendGroups:t,width:e,customClickBehavior:n})=>{let o=30;const r=[];return t.forEach((t,s)=>{o+=5,r.push(f.createElement("line",{key:"legend-top-line legend-symbol-"+s,stroke:"gray",x1:0,y1:o,x2:e,y2:o})),o+=10,t.label&&(o+=20,r.push(f.createElement("text",{key:"legend-text-"+s,y:o,className:"legend-group-label"},t.label)),o+=10),r.push(f.createElement("g",{key:"legend-group-"+s,className:"legend-item",transform:`translate(0,${o})`},((t,e)=>{const{type:n="fill",styleFn:o,items:r}=t,s=[];let i=0;return r.forEach((t,r)=>{const a=B(t,r,n,o);s.push(f.createElement("g",{key:"legend-item-"+r,transform:`translate(0,${i})`,onClick:e?()=>e(t):void 0,style:{cursor:e?"pointer":"default"}},a,f.createElement("text",{y:15,x:30},t.label))),i+=25}),s})(t,n))),o+=25*t.items.length+10}),r})({legendGroups:e,width:r,customClickBehavior:n}):(({legendGroups:t,title:e,height:n,customClickBehavior:o})=>{let r=0;const s=[],i=!1===e?10:40;return t.forEach((e,a)=>{e.label&&(s.push(f.createElement("text",{key:"legend-text-"+a,transform:`translate(${r},${i}) rotate(90)`,textAnchor:"start",className:"legend-group-label"},e.label)),r+=20);const l=((t,e)=>{const{type:n="fill",styleFn:o,items:r}=t,s=[];let i=0;return r.forEach((t,r)=>{const a=B(t,r,n,o);s.push(f.createElement("g",{key:"legend-item-"+r,transform:`translate(${i},0)`,onClick:e?()=>e(t):void 0,style:{cursor:e?"pointer":"default"}},a,f.createElement("text",{y:15,x:25},t.label))),i+=35,i+=8*t.label.length}),{items:s,offset:i}})(e,o);s.push(f.createElement("g",{key:"legend-group-"+a,className:"legend-item",transform:`translate(${r},${i})`},l.items)),r+=l.offset+5,t[a+1]&&s.push(f.createElement("line",{key:"legend-top-line legend-symbol-"+a,stroke:"gray",x1:r,y1:i-10,x2:r,y2:n+i+10})),r+=15}),f.createElement("g",null,!1!==e&&f.createElement("line",{x1:0,x2:r+10,y1:i-10,y2:i-10,stroke:"gray",className:"title-neatline"}),s)})({legendGroups:e,title:o,height:s,customClickBehavior:n});return f.createElement("g",null,void 0!==o&&f.createElement("text",{className:"legend-title",y:20,x:"horizontal"===i?0:r/2,textAnchor:"horizontal"===i?"start":"middle"},o),a)}function L(t){return"string"==typeof t?{type:t}:t}function F({orient:e,config:n,values:o,scale:s,size:i,length:a}){const l=function(t){var e,n,o,r,s;return{type:t.type,bins:null!==(e=t.bins)&&void 0!==e?e:20,fill:null!==(n=t.fill)&&void 0!==n?n:"#4e79a7",fillOpacity:null!==(o=t.fillOpacity)&&void 0!==o?o:.5,stroke:null!==(r=t.stroke)&&void 0!==r?r:"none",strokeWidth:null!==(s=t.strokeWidth)&&void 0!==s?s:1}}(n),c="top"===e||"bottom"===e,u=t.useMemo(()=>{if(0===o.length)return null;const t=s.domain(),n=i-8;if("boxplot"===l.type){const t=function(t){const e=[...t].sort((t,e)=>t-e),n=e.length;if(0===n)return null;const o=e[Math.floor(.25*n)],r=e[Math.floor(.5*n)],s=e[Math.floor(.75*n)],i=s-o;return{q1:o,median:r,q3:s,whiskerLow:Math.max(e[0],o-1.5*i),whiskerHigh:Math.min(e[n-1],s+1.5*i)}}(o);if(!t)return null;const{q1:r,median:i,q3:a,whiskerLow:u,whiskerHigh:h}=t,d=Math.min(.5*n,20),p=(n-d)/2+4;if(c){const t=s(r),n=s(a),o=s(i),c=s(u),y=s(h),m="top"===e?-1:1,g=0;return f.createElement("g",{"data-testid":"marginal-boxplot-"+e},f.createElement("line",{x1:c,y1:g+m*(p+d/2),x2:y,y2:g+m*(p+d/2),stroke:l.fill,strokeWidth:l.strokeWidth}),f.createElement("line",{x1:c,y1:g+m*p,x2:c,y2:g+m*(p+d),stroke:l.fill,strokeWidth:l.strokeWidth}),f.createElement("line",{x1:y,y1:g+m*p,x2:y,y2:g+m*(p+d),stroke:l.fill,strokeWidth:l.strokeWidth}),f.createElement("rect",{x:Math.min(t,n),y:"top"===e?g-p-d:g+p,width:Math.abs(n-t),height:d,fill:l.fill,fillOpacity:l.fillOpacity,stroke:"none"===l.stroke?l.fill:l.stroke,strokeWidth:l.strokeWidth}),f.createElement("line",{x1:o,y1:"top"===e?g-p-d:g+p,x2:o,y2:"top"===e?g-p:g+p+d,stroke:l.fill,strokeWidth:2}))}{const t=s(r),n=s(a),o=s(i),c=s(u),y=s(h),m="left"===e?-1:1,g=0;return f.createElement("g",{"data-testid":"marginal-boxplot-"+e},f.createElement("line",{x1:g+m*(p+d/2),y1:c,x2:g+m*(p+d/2),y2:y,stroke:l.fill,strokeWidth:l.strokeWidth}),f.createElement("line",{x1:g+m*p,y1:c,x2:g+m*(p+d),y2:c,stroke:l.fill,strokeWidth:l.strokeWidth}),f.createElement("line",{x1:g+m*p,y1:y,x2:g+m*(p+d),y2:y,stroke:l.fill,strokeWidth:l.strokeWidth}),f.createElement("rect",{x:"left"===e?g-p-d:g+p,y:Math.min(t,n),width:d,height:Math.abs(n-t),fill:l.fill,fillOpacity:l.fillOpacity,stroke:"none"===l.stroke?l.fill:l.stroke,strokeWidth:l.strokeWidth}),f.createElement("line",{x1:"left"===e?g-p-d:g+p,y1:o,x2:"left"===e?g-p:g+p+d,y2:o,stroke:l.fill,strokeWidth:2}))}}const u=r.bin().domain(t).thresholds(l.bins)(o);if(0===u.length)return null;const h=Math.max(...u.map(t=>t.length));if(0===h)return null;if("histogram"===l.type)return f.createElement("g",{"data-testid":"marginal-histogram-"+e},u.map((t,o)=>{if(null==t.x0||null==t.x1)return null;const r=t.length/h*n;if(c){const n=s(t.x0),i=s(t.x1)-s(t.x0);return f.createElement("rect",{key:o,x:n,y:"top"===e?-4-r:4,width:Math.max(i,.5),height:r,fill:l.fill,fillOpacity:l.fillOpacity,stroke:l.stroke,strokeWidth:l.strokeWidth})}{const n=s(t.x0),i=s(t.x1)-s(t.x0);return f.createElement("rect",{key:o,x:"left"===e?-4-r:4,y:Math.min(n,n+i),width:r,height:Math.abs(i),fill:l.fill,fillOpacity:l.fillOpacity,stroke:l.stroke,strokeWidth:l.strokeWidth})}}));if("violin"===l.type){const t=n/2+4,o=[];for(const r of u){if(null==r.x0||null==r.x1)continue;const i=r.length/h*(n/2),a=s((r.x0+r.x1)/2);o.push(c?`${a},${"top"===e?-(t-i):t-i}`:`${"left"===e?-(t-i):t-i},${a}`)}for(let r=u.length-1;r>=0;r--){const i=u[r];if(null==i.x0||null==i.x1)continue;const a=i.length/h*(n/2),l=s((i.x0+i.x1)/2);o.push(c?`${l},${"top"===e?-(t+a):t+a}`:`${"left"===e?-(t+a):t+a},${l}`)}return f.createElement("g",{"data-testid":"marginal-violin-"+e},f.createElement("polygon",{points:o.join(" "),fill:l.fill,fillOpacity:l.fillOpacity,stroke:"none"===l.stroke?l.fill:l.stroke,strokeWidth:l.strokeWidth}))}if("ridgeline"===l.type){const t=[];if(c){const o=0,r=null!=u[0].x0?s(u[0].x0):0;t.push(`M${r},${o}`);for(const o of u){if(null==o.x0||null==o.x1)continue;const r=o.length/h*n,i=s((o.x0+o.x1)/2);t.push(`L${i},${"top"===e?-r-4:r+4}`)}const i=null!=u[u.length-1].x1?s(u[u.length-1].x1):a;t.push(`L${i},${o}`),t.push("Z")}else{const o=0,r=null!=u[0].x0?s(u[0].x0):0;t.push(`M${o},${r}`);for(const o of u){if(null==o.x0||null==o.x1)continue;const r=o.length/h*n,i=s((o.x0+o.x1)/2);t.push(`L${"left"===e?-r-4:r+4},${i}`)}const i=null!=u[u.length-1].x1?s(u[u.length-1].x1):a;t.push(`L${o},${i}`),t.push("Z")}return f.createElement("g",{"data-testid":"marginal-ridgeline-"+e},f.createElement("path",{d:t.join(" "),fill:l.fill,fillOpacity:l.fillOpacity,stroke:"none"===l.stroke?l.fill:l.stroke,strokeWidth:l.strokeWidth}))}return null},[o,s,l,i,a,e,c,4]);return u?f.createElement("g",{className:"marginal-"+e,"data-testid":"marginal-"+e},u):null}function Y(t){return Math.round(100*t)/100+""}function R(e){const{width:n,height:o,totalWidth:r,totalHeight:s,margin:i,scales:a,showAxes:l,xLabel:c,yLabel:u,xFormat:h,yFormat:d,showGrid:p,title:y,legend:m,foregroundGraphics:g,marginalGraphics:x,xValues:b,yValues:v,annotations:k,svgAnnotationRules:E,annotationFrame:w,children:M}=e,A=t.useMemo(()=>l&&a?a.x.ticks(5).map(t=>({value:t,pixel:a.x(t),label:(h||Y)(t)})):[],[l,a,h]),S=t.useMemo(()=>l&&a?a.y.ticks(5).map(t=>({value:t,pixel:a.y(t),label:(d||Y)(t)})):[],[l,a,d]),$=t.useMemo(()=>k&&0!==k.length&&E?k.map((t,e)=>E(t,e,{scales:a?{time:a.x,value:a.y}:null,timeAxis:"x",width:n,height:o})).filter(Boolean):null,[k,E,n,o,w]);return l||y||m||g||x||$&&$.length>0||p||M?f.createElement("svg",{width:r,height:s,style:{position:"absolute",top:0,left:0,pointerEvents:"none"}},f.createElement("g",{transform:`translate(${i.left},${i.top})`},p&&a&&f.createElement("g",{className:"stream-grid"},A.map((t,e)=>f.createElement("line",{key:"xgrid-"+e,x1:t.pixel,y1:0,x2:t.pixel,y2:o,stroke:"#e0e0e0",strokeWidth:1})),S.map((t,e)=>f.createElement("line",{key:"ygrid-"+e,x1:0,y1:t.pixel,x2:n,y2:t.pixel,stroke:"#e0e0e0",strokeWidth:1}))),l&&a&&f.createElement("g",{className:"stream-axes"},f.createElement("line",{x1:0,y1:o,x2:n,y2:o,stroke:"#ccc",strokeWidth:1}),A.map((t,e)=>f.createElement("g",{key:"xtick-"+e,transform:`translate(${t.pixel},${o})`},f.createElement("line",{y2:5,stroke:"#ccc",strokeWidth:1}),f.createElement("text",{y:18,textAnchor:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},t.label))),c&&f.createElement("text",{x:n/2,y:o+40,textAnchor:"middle",fontSize:12,fill:"#333",style:{userSelect:"none"}},c),f.createElement("line",{x1:0,y1:0,x2:0,y2:o,stroke:"#ccc",strokeWidth:1}),S.map((t,e)=>f.createElement("g",{key:"ytick-"+e,transform:`translate(0,${t.pixel})`},f.createElement("line",{x2:-5,stroke:"#ccc",strokeWidth:1}),f.createElement("text",{x:-8,textAnchor:"end",dominantBaseline:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},t.label))),u&&f.createElement("text",{x:15-i.left,y:o/2,textAnchor:"middle",fontSize:12,fill:"#333",transform:`rotate(-90, ${15-i.left}, ${o/2})`,style:{userSelect:"none"}},u)),$,x&&a&&b&&v&&f.createElement(f.Fragment,null,x.top&&f.createElement("g",{transform:"translate(0, 0)"},f.createElement(F,{orient:"top",config:L(x.top),values:b,scale:a.x,size:i.top,length:n})),x.bottom&&f.createElement("g",{transform:`translate(0, ${o})`},f.createElement(F,{orient:"bottom",config:L(x.bottom),values:b,scale:a.x,size:i.bottom,length:n})),x.left&&f.createElement("g",{transform:"translate(0, 0)"},f.createElement(F,{orient:"left",config:L(x.left),values:v,scale:a.y,size:i.left,length:o})),x.right&&f.createElement("g",{transform:`translate(${n}, 0)`},f.createElement(F,{orient:"right",config:L(x.right),values:v,scale:a.y,size:i.right,length:o}))),g,M),y&&f.createElement("text",{x:r/2,y:20,textAnchor:"middle",fontSize:14,fontWeight:"bold",fill:"#333",style:{userSelect:"none"}},"string"==typeof y?y:null),m&&f.createElement("g",{transform:`translate(${r-i.right+10}, ${i.top})`},"object"==typeof(P=m)&&null!==P&&!f.isValidElement(P)&&"legendGroups"in P?f.createElement(W,{legendGroups:m.legendGroups,title:"",width:100}):m)):null;var P}function X(t,e,n){let o=n;for(const n of e)"lesser"===n.thresholdType?n.value>t&&(o=n.color):t>n.value&&(o=n.color);return o}const I=(t,e,n,o)=>{var r;const s=e.filter(t=>"area"===t.type);for(const e of s){if(2>e.topPath.length)continue;t.beginPath();const[n,o]=e.topPath[0];t.moveTo(n,o);for(let n=1;e.topPath.length>n;n++)t.lineTo(e.topPath[n][0],e.topPath[n][1]);for(let n=e.bottomPath.length-1;n>=0;n--)t.lineTo(e.bottomPath[n][0],e.bottomPath[n][1]);t.closePath();const s=null!==(r=e.style.fillOpacity)&&void 0!==r?r:.7;if(t.globalAlpha=s,t.fillStyle=e.style.fill||"#4e79a7",t.fill(),e.style.stroke&&"none"!==e.style.stroke){t.globalAlpha=1,t.strokeStyle=e.style.stroke,t.lineWidth=e.style.strokeWidth||2,t.setLineDash([]),t.beginPath(),t.moveTo(e.topPath[0][0],e.topPath[0][1]);for(let n=1;e.topPath.length>n;n++)t.lineTo(e.topPath[n][0],e.topPath[n][1]);t.stroke()}t.globalAlpha=1}},H=(t,e,n,o)=>{var r;const s=e.filter(t=>"point"===t.type);for(const e of s){t.beginPath(),t.arc(e.x,e.y,e.r,0,2*Math.PI);const n=null!==(r=e.style.opacity)&&void 0!==r?r:e.style.fillOpacity;if(null!=n&&(t.globalAlpha=n),t.fillStyle=e.style.fill||"#4e79a7",t.fill(),e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=e.style.strokeWidth||1,t.stroke()),e._pulseIntensity&&e._pulseIntensity>0){const n=4;t.beginPath(),t.arc(e.x,e.y,e.r+n*e._pulseIntensity,0,2*Math.PI),t.strokeStyle=e._pulseColor||"rgba(255,255,255,0.6)",t.lineWidth=2*e._pulseIntensity,t.globalAlpha=.5*e._pulseIntensity,t.stroke()}t.globalAlpha=1}},V=(t,e,n,o)=>{const r=e.filter(t=>"rect"===t.type);for(const e of r)null!=e.style.opacity&&(t.globalAlpha=e.style.opacity),e.style.icon?G(t,e):(t.fillStyle=e.style.fill||"#007bff",t.fillRect(e.x,e.y,e.w,e.h),e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=e.style.strokeWidth||1,t.strokeRect(e.x,e.y,e.w,e.h))),e._pulseIntensity&&e._pulseIntensity>0&&(t.globalAlpha=.3*e._pulseIntensity,t.fillStyle=e._pulseColor||"rgba(255,255,255,0.6)",t.fillRect(e.x,e.y,e.w,e.h)),t.globalAlpha=1};function G(t,e){const n=e.style.icon,o=e.style.iconPadding||2,r=Math.min(e.w,e.w)-o;if(0>=r)return;const s=e.h>e.w;if(t.save(),t.beginPath(),t.rect(e.x,e.y,e.w,e.h),t.clip(),s){const s=r+o,i=e.x+(e.w-r)/2;for(let o=e.y+e.h-r;o>=e.y-r;o-=s)t.drawImage(n,i,o,r,r)}else{const s=r+o,i=e.y+(e.h-r)/2;for(let o=e.x;e.x+e.w>o;o+=s)t.drawImage(n,o,i,r,r)}t.restore()}const q={line:[I,(t,e,n,o)=>{const r=e.filter(t=>"line"===t.type);for(const s of r){if(2>s.path.length)continue;const i=s.style.stroke||"#007bff",a=s.style.strokeWidth||2,l=s.colorThresholds,c=s.rawValues;if(t.setLineDash(s.style.strokeDasharray?s.style.strokeDasharray.split(/[\s,]+/).map(Number):[]),null!=s.style.opacity&&(t.globalAlpha=s.style.opacity),t.lineWidth=a,l&&0!==l.length&&c&&c.length===s.path.length){let u=null,h=null,d=null,f=null,p=!1;function y(e,n,o){t.beginPath(),t.strokeStyle=e,t.moveTo(n,o),p=!0}function m(){p&&(t.stroke(),p=!1)}for(let g=0;s.path.length>g;g++){const[x,b]=s.path[g],v=c[g],k=X(v,l,i);if(null!==u&&null!==f&&null!==d){if(k===f)t.lineTo(x,b);else{const E=[];for(const w of l){const M=w.value;(d>M||M>v)&&(M>d||v>M)||d===M||v===M||E.push({t:(M-d)/(v-d)})}E.sort((t,e)=>t.t-e.t);for(const A of E){const S=u+(x-u)*A.t,$=h+(b-h)*A.t,P=X(d+(v-d)*Math.min(A.t+1e-4,1),l,i);t.lineTo(S,$),m(),y(P,S,$)}t.lineTo(x,b)}u=x,h=b,d=v,f=k}else y(k,x,b),u=x,h=b,d=v,f=k}m()}else{t.beginPath(),t.strokeStyle=i;const[N,_]=s.path[0];t.moveTo(N,_);for(let O=1;s.path.length>O;O++)t.lineTo(s.path[O][0],s.path[O][1]);t.stroke()}if(s.style.fill&&s.style.fillOpacity&&s.style.fillOpacity>0){t.beginPath(),t.globalAlpha=s.style.fillOpacity,t.fillStyle=s.style.fill;const[D,j]=s.path[0];t.moveTo(D,j);for(let C=1;s.path.length>C;C++)t.lineTo(s.path[C][0],s.path[C][1]);const T=s.path[0][0];t.lineTo(s.path[s.path.length-1][0],o.height),t.lineTo(T,o.height),t.closePath(),t.fill()}t.globalAlpha=1,t.setLineDash([])}}],area:[I],stackedarea:[I],scatter:[H],bubble:[H],heatmap:[(t,e,n,o)=>{const r=e.filter(t=>"heatcell"===t.type);for(const e of r){const n=e.style;null!=(null==n?void 0:n.opacity)&&(t.globalAlpha=n.opacity),t.fillStyle=e.fill,t.fillRect(e.x,e.y,e.w,e.h),t.strokeStyle="#fff",t.lineWidth=1,t.strokeRect(e.x,e.y,e.w,e.h),e._pulseIntensity&&e._pulseIntensity>0&&(t.globalAlpha=.3*e._pulseIntensity,t.fillStyle=e._pulseColor||"rgba(255,255,255,0.6)",t.fillRect(e.x,e.y,e.w,e.h)),t.globalAlpha=1}}],bar:[V],swarm:[H],waterfall:[(t,e,n,o)=>{var r,s;V(t,e);const i=e.filter(t=>"rect"===t.type);if(i.length>=2){t.save(),t.strokeStyle="#999",t.lineWidth=1,t.setLineDash([]);for(let e=0;i.length-1>e;e++){const o=i[e],a=i[e+1];if(!(null===(r=o.datum)||void 0===r?void 0:r.cumEnd)||!(null===(s=a.datum)||void 0===s?void 0:s.baseline))continue;const l=n.y(o.datum.cumEnd),c=o.x+o.w,u=a.x;t.beginPath(),t.moveTo(c,l),t.lineTo(u,l),t.stroke()}t.restore()}}],candlestick:[(t,e,n,o)=>{for(const n of e){if("candlestick"!==n.type)continue;const e=n;t.beginPath(),t.moveTo(e.x,e.highY),t.lineTo(e.x,e.lowY),t.strokeStyle=e.wickColor,t.lineWidth=e.wickWidth,t.stroke();const o=Math.min(e.openY,e.closeY),r=Math.abs(e.openY-e.closeY),s=e.isUp?e.upColor:e.downColor;t.fillStyle=s,t.fillRect(e.x-e.bodyWidth/2,o,e.bodyWidth,Math.max(r,1)),t.strokeStyle=s,t.lineWidth=1,t.strokeRect(e.x-e.bodyWidth/2,o,e.bodyWidth,Math.max(r,1))}}]},J={top:20,right:20,bottom:30,left:40},K={axisStroke:"#ccc",tickText:"#666",crosshair:"rgba(0, 0, 0, 0.25)",hoverFill:"rgba(255, 255, 255, 0.3)",hoverStroke:"rgba(0, 0, 0, 0.4)",pointRing:"white"},Z={background:"rgba(0, 0, 0, 0.85)",color:"white",padding:"6px 10px",borderRadius:4,fontSize:12,lineHeight:1.5,boxShadow:"0 2px 8px rgba(0, 0, 0, 0.15)",pointerEvents:"none",whiteSpace:"nowrap"};function U({hover:t}){const e=t=>Number.isInteger(t)?t+"":t.toFixed(2);return f.createElement("div",{className:"semiotic-tooltip",style:Z},f.createElement("div",{style:{fontWeight:600,marginBottom:2}},e(t.value)),f.createElement("div",{style:{opacity:.7,fontSize:11}},e(t.time)))}function Q({width:o,height:r,totalWidth:s,totalHeight:i,margin:a,dimension:l,scales:c,onBrush:u}){const h=t.useRef(null),d=t.useRef(null);return t.useEffect(()=>{if(!h.current)return;const t=n.select(h.current).select(".brush-g"),s="x"===l?e.brushX():"y"===l?e.brushY():e.brush();return s.extent([[0,0],[o,r]]),s.on("brush end",t=>{if(!c)return;if(!t.selection)return void u(null);let e,n;if("x"===l){const[o,s]=t.selection;e=[c.x.invert(o),c.x.invert(s)],n=[c.y.invert(r),c.y.invert(0)]}else if("y"===l){const[r,s]=t.selection;e=[c.x.invert(0),c.x.invert(o)],n=[c.y.invert(s),c.y.invert(r)]}else{const[[o,r],[s,i]]=t.selection;e=[c.x.invert(o),c.x.invert(s)],n=[c.y.invert(i),c.y.invert(r)]}u({x:e,y:n})}),t.call(s),d.current=s,t.select(".selection").attr("fill","steelblue").attr("fill-opacity",.15).attr("stroke","steelblue").attr("stroke-width",1),()=>{s.on("brush end",null),d.current=null}},[o,r,l,c,u]),f.createElement("svg",{ref:h,width:s,height:i,style:{position:"absolute",top:0,left:0,pointerEvents:"all"}},f.createElement("g",{className:"brush-g",transform:`translate(${a.left},${a.top})`}))}const tt=t.forwardRef(function(e,n){var o;const{chartType:r,runtimeMode:s,data:i,xAccessor:a,yAccessor:l,colorAccessor:c,sizeAccessor:u,groupAccessor:h,lineDataAccessor:d,normalize:p,binSize:y,valueAccessor:m,arrowOfTime:x="right",windowMode:b="sliding",windowSize:v=200,timeAccessor:k,xExtent:E,yExtent:w,extentPadding:M=.1,sizeRange:A,size:S=[500,300],margin:$,className:C,background:z,lineStyle:B,pointStyle:W,areaStyle:L,swarmStyle:F,barColors:Y,colorScheme:X,boundsAccessor:I,boundsStyle:H,openAccessor:V,highAccessor:G,lowAccessor:Z,closeAccessor:tt,candlestickStyle:et,showAxes:nt=!0,xLabel:ot,yLabel:rt,xFormat:st,yFormat:it,tickFormatTime:at,tickFormatValue:lt,hoverAnnotation:ct,tooltipContent:ut,customHoverBehavior:ht,enableHover:dt,annotations:ft,svgAnnotationRules:pt,showGrid:yt,legend:mt,backgroundGraphics:gt,foregroundGraphics:xt,title:bt,categoryAccessor:vt,brush:kt,onBrush:Et,decay:wt,pulse:Mt,transition:At,staleness:St,heatmapAggregation:$t,heatmapXBins:Pt,heatmapYBins:Nt,marginalGraphics:_t}=e,Ot=Object.assign(Object.assign({},J),$);if(_t){const t=60;_t.top&&t>Ot.top&&(Ot.top=t),_t.bottom&&t>Ot.bottom&&(Ot.bottom=t),_t.left&&t>Ot.left&&(Ot.left=t),_t.right&&t>Ot.right&&(Ot.right=t)}const Dt=S[0]-Ot.left-Ot.right,jt=S[1]-Ot.top-Ot.bottom,Tt=null!=ct?ct:dt,Ct=t.useRef(null),zt=t.useRef(0),Bt=t.useRef(!1),[Wt,Lt]=t.useState(0),[Ft,Yt]=t.useState(null),Rt=t.useRef(null),[Xt,It]=t.useState(null),[Ht,Vt]=t.useState(!1),[Gt,qt]=t.useState([]),[Jt,Kt]=t.useState([]),Zt=t.useRef(()=>{}),Ut="streaming"===s||["bar","swarm","waterfall"].includes(r),Qt=t.useMemo(()=>({chartType:r,runtimeMode:Ut?"streaming":"bounded",windowSize:v,windowMode:b,arrowOfTime:Ut?x:"right",extentPadding:M,xAccessor:Ut?void 0:a,yAccessor:Ut?void 0:l,timeAccessor:Ut?k:void 0,valueAccessor:m,colorAccessor:c,sizeAccessor:u,groupAccessor:h,categoryAccessor:vt,lineDataAccessor:d,xExtent:E,yExtent:w,sizeRange:A,binSize:y,normalize:p,boundsAccessor:I,boundsStyle:H,openAccessor:V,highAccessor:G,lowAccessor:Z,closeAccessor:tt,candlestickStyle:et,lineStyle:B,pointStyle:W,areaStyle:L,swarmStyle:F,colorScheme:X,barColors:Y,annotations:ft,decay:wt,pulse:Mt,transition:At,staleness:St,heatmapAggregation:$t,heatmapXBins:Pt,heatmapYBins:Nt}),[r,v,b,x,M,a,l,k,m,c,u,h,vt,d,E,w,A,y,p,I,H,V,G,Z,tt,et,B,W,L,F,X,Y,ft,wt,Mt,At,St,$t,Pt,Nt,Ut]),te=t.useRef(null);te.current||(te.current=new P(Qt));const ee=t.useCallback(()=>{zt.current||(zt.current=requestAnimationFrame(()=>Zt.current()))},[]);t.useEffect(()=>{var t;null===(t=te.current)||void 0===t||t.updateConfig(Qt),Bt.current=!0,ee()},[Qt,ee]);const ne=t.useRef(null);ne.current||(ne.current=new g(t=>{const e=te.current;e&&e.ingest(t)&&(Bt.current=!0,ee())}));const oe=t.useCallback(t=>{var e;null===(e=ne.current)||void 0===e||e.push(t)},[]),re=t.useCallback(t=>{var e;null===(e=ne.current)||void 0===e||e.pushMany(t)},[]),se=t.useCallback(()=>{var t,e;null===(t=ne.current)||void 0===t||t.clear(),null===(e=te.current)||void 0===e||e.clear(),Bt.current=!0,ee()},[ee]);t.useImperativeHandle(n,()=>({push:oe,pushMany:re,clear:se,getData:()=>{var t,e;return null!==(e=null===(t=te.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]},getScales:()=>{var t,e;return null!==(e=null===(t=te.current)||void 0===t?void 0:t.scales)&&void 0!==e?e:null},getExtents:()=>{var t,e;return null!==(e=null===(t=te.current)||void 0===t?void 0:t.getExtents())&&void 0!==e?e:null}}),[oe,re,se]),t.useEffect(()=>{var t;i&&(null===(t=ne.current)||void 0===t||t.setBoundedData(i))},[i]);const ie=t.useRef(()=>{}),ae=t.useRef(()=>{});ie.current=t=>{if(!Tt)return;const e=Ct.current;if(!e)return;const n=e.getBoundingClientRect(),o=t.clientX-n.left-Ot.left,r=t.clientY-n.top-Ot.top;if(0>o||o>Dt||0>r||r>jt)return void(Rt.current&&(Rt.current=null,It(null),ht&&ht(null),ee()));const s=te.current;if(!s||0===s.scene.length)return;const i=function(t,e,n,o=30){let r=null;for(const s of t){let t=null;switch(s.type){case"point":t=N(s,e,n);break;case"line":t=_(s,e,n);break;case"rect":t=O(s,e,n);break;case"heatcell":t=D(s,e,n);break;case"area":if(!1===s.interactive)break;t=T(s,e,n);break;case"candlestick":t=j(s,e,n)}t&&o>t.distance&&(r&&t.distance>=r.distance||(r=t))}return r}(s.scene,o,r);if(!i)return void(Rt.current&&(Rt.current=null,It(null),ht&&ht(null),ee()));const a={data:i.datum,time:i.x,value:i.y,x:i.x,y:i.y};Rt.current=a,It(a),ht&&ht(a),ee()},ae.current=()=>{Rt.current&&(Rt.current=null,It(null),ht&&ht(null),ee())};const le=t.useCallback(t=>ie.current(t),[]),ce=t.useCallback(()=>ae.current(),[]);Zt.current=()=>{var t,e;zt.current=0;const n=Ct.current;if(!n)return;const o=n.getContext("2d");if(!o)return;const s=te.current;if(!s)return;const i="undefined"!=typeof performance?performance.now():Date.now(),c=s.advanceTransition(i);c||s.computeScene({width:Dt,height:jt});const u="undefined"!=typeof window&&window.devicePixelRatio||1;n.width=S[0]*u,n.height=S[1]*u,n.style.width=S[0]+"px",n.style.height=S[1]+"px",o.scale(u,u),o.translate(Ot.left,Ot.top),o.clearRect(-Ot.left,-Ot.top,S[0],S[1]);const h=function(t){if(!t)return K;const e=getComputedStyle(t),n=e.getPropertyValue("--text-secondary").trim(),o=e.getPropertyValue("--text-primary").trim(),r=e.getPropertyValue("--surface-3").trim(),s=e.getPropertyValue("--surface-0").trim();return n||o?{axisStroke:r||K.axisStroke,tickText:n||K.tickText,crosshair:n?n+"66":K.crosshair,hoverFill:s?s+"4D":K.hoverFill,hoverStroke:n?n+"99":K.hoverStroke,pointRing:s||K.pointRing}:K}(n),d=null!==(t=null==St?void 0:St.threshold)&&void 0!==t?t:5e3,f=St&&s.lastIngestTime>0&&i-s.lastIngestTime>d;f&&(o.globalAlpha=null!==(e=null==St?void 0:St.dimOpacity)&&void 0!==e?e:.5),z&&(o.fillStyle=z,o.fillRect(0,0,Dt,jt));const p=q[r];if(p&&s.scales)for(const t of p)t(o,s.scene,s.scales,{width:Dt,height:jt});f&&(o.globalAlpha=1),Tt&&Rt.current&&s.scales&&function(t,e,n,o,r,s,i){if(!1===r.crosshair)return;t.save();const a="object"==typeof r.crosshair?r.crosshair:{};t.strokeStyle=a.stroke||i.crosshair,t.lineWidth=a.strokeWidth||1,t.setLineDash(a.strokeDasharray?a.strokeDasharray.split(/[\s,]+/).map(Number):[4,4]),t.beginPath(),t.moveTo(e.x,0),t.lineTo(e.x,o),t.stroke(),t.beginPath(),t.moveTo(0,e.y),t.lineTo(n,e.y),t.stroke(),t.restore(),t.beginPath(),t.arc(e.x,e.y,4,0,2*Math.PI),t.fillStyle="#007bff",t.fill(),t.strokeStyle=i.pointRing,t.lineWidth=2,t.stroke()}(o,Rt.current,Dt,jt,"object"==typeof Tt?Tt:{},0,h);const y=Bt.current;if(Bt.current=!1,y&&s.scales&&(Yt(s.scales),_t)){const t=s.getData(),e="function"==typeof a?a:t=>t[a||"x"],n="function"==typeof l?l:t=>t[l||"y"];qt(t.map(t=>e(t)).filter(t=>"number"==typeof t&&isFinite(t))),Kt(t.map(t=>n(t)).filter(t=>"number"==typeof t&&isFinite(t)))}y&&ft&&ft.length>0&&pt&&Lt(t=>t+1),(null==St?void 0:St.showBadge)&&Vt(!!f),(c||s.hasActivePulses)&&(zt.current=requestAnimationFrame(()=>Zt.current()))},t.useEffect(()=>(ee(),()=>{zt.current&&cancelAnimationFrame(zt.current)}),[ee]),t.useEffect(()=>{Bt.current=!0,ee()},[r,Dt,jt,nt,z,B,ee]),t.useEffect(()=>{if(!St)return;const t=setInterval(()=>{var t;const e=te.current;if(!e||0===e.lastIngestTime)return;const n="undefined"!=typeof performance?performance.now():Date.now(),o=null!==(t=St.threshold)&&void 0!==t?t:5e3,r=n-e.lastIngestTime>o;r!==Ht&&(Vt(r),Bt.current=!0,ee())},1e3);return()=>clearInterval(t)},[St,Ht,ee]);const ue=Tt&&Xt?ut?ut(Xt):f.createElement(U,{hover:Xt}):null,he=ue?f.createElement("div",{className:"stream-frame-tooltip",style:{position:"absolute",left:Ot.left+Xt.x,top:Ot.top+Xt.y,transform:`translate(${Xt.x>.7*Dt?"calc(-100% - 12px)":"12px"}, ${.3*jt>Xt.y?"4px":"calc(-100% - 4px)"})`,pointerEvents:"none",zIndex:1}},ue):null;return f.createElement("div",{className:"stream-xy-frame"+(C?" "+C:""),style:{position:"relative",width:S[0],height:S[1]},onMouseMove:Tt?le:void 0,onMouseLeave:Tt?ce:void 0},gt&&f.createElement("svg",{style:{position:"absolute",left:0,top:0,width:S[0],height:S[1],pointerEvents:"none"}},gt),f.createElement("canvas",{ref:Ct,style:{position:"absolute",left:0,top:0}}),f.createElement(R,{width:Dt,height:jt,totalWidth:S[0],totalHeight:S[1],margin:Ot,scales:Ft,showAxes:nt,xLabel:ot,yLabel:rt,xFormat:st||at,yFormat:it||lt,showGrid:yt,title:bt,legend:mt,foregroundGraphics:xt,marginalGraphics:_t,xValues:Gt,yValues:Jt,annotations:ft,svgAnnotationRules:pt,annotationFrame:Wt}),(kt||Et)&&f.createElement(Q,{width:Dt,height:jt,totalWidth:S[0],totalHeight:S[1],margin:Ot,dimension:null!==(o=null==kt?void 0:kt.dimension)&&void 0!==o?o:"xy",scales:Ft,onBrush:null!=Et?Et:()=>{}}),(null==St?void 0:St.showBadge)&&f.createElement("div",{className:"stream-staleness-badge",style:Object.assign(Object.assign({position:"absolute"},"top-left"===St.badgePosition?{top:4,left:4}:"bottom-left"===St.badgePosition?{bottom:4,left:4}:"bottom-right"===St.badgePosition?{bottom:4,right:4}:{top:4,right:4}),{padding:"2px 8px",borderRadius:4,fontSize:11,fontWeight:600,pointerEvents:"none",background:Ht?"#dc3545":"#28a745",color:"white"})},Ht?"STALE":"LIVE"),he)});tt.displayName="StreamXYFrame";const et={category10:s.schemeCategory10,tableau10:s.schemeTableau10,set3:s.schemeSet3,blues:s.interpolateBlues,reds:s.interpolateReds,greens:s.interpolateGreens,oranges:s.interpolateOranges,purples:s.interpolatePurples,viridis:s.interpolateViridis,plasma:s.interpolatePlasma},nt=s.schemeCategory10;function ot(t,e,n){if("function"==typeof e)return e(t);const o=t[e];return n?n(o):nt[Math.abs(function(t){let e=0;for(let n=0;t.length>n;n++)e=(e<<5)-e+t.charCodeAt(n),e&=e;return Math.abs(e)}(o+""))%nt.length]}const rt="#007bff";const st={background:"rgba(0, 0, 0, 0.85)",color:"white",padding:"8px 12px",borderRadius:"4px",fontSize:"14px",lineHeight:"1.5",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.15)",pointerEvents:"none",maxWidth:"300px",wordWrap:"break-word"};function it(t,e){return"function"==typeof e?e(t):t[e]}function at(t,e){return e?e(t):null==t?"":"number"==typeof t?t.toLocaleString():t instanceof Date?t.toLocaleDateString():"object"==typeof t&&null!==t?void 0!==t.id?t.id+"":void 0!==t.name?t.name+"":JSON.stringify(t):t+""}function lt(t){return!0===t||("function"==typeof t?t:!1!==t&&void 0!==t&&("object"!=typeof t||null===t||!("fields"in t)&&!("title"in t)||function(t={}){const{fields:e,title:n,format:o,style:r={},className:s=""}=t;return t=>{if(!t||"object"!=typeof t)return null;let i;const a=[];if(n){const e=it(t,n);i=at(e,o)}if(e&&e.length>0)e.forEach(e=>{let n,r,s;"string"==typeof e?(n=e,r=e,s=o):(n=e.label,r=e.accessor||e.key||"",s=e.format||o);const i=it(t,r);a.push({label:n,value:at(i,s)})});else if(!n){const e=["value","y","name","id","label"];for(const n of e)if(void 0!==t[n]){i=at(t[n],o);break}if(!i){const e=Object.keys(t).filter(t=>!t.startsWith("_"));e.length>0&&(i=at(t[e[0]],o))}}const l=Object.assign(Object.assign({},st),r);return f.createElement("div",{className:("semiotic-tooltip "+s).trim(),style:l},i&&f.createElement("div",{style:{fontWeight:a.length>0?"bold":"normal"}},i),a.map((t,e)=>f.createElement("div",{key:e,style:{marginTop:0===e&&i?"4px":0}},t.label&&f.createElement("span",null,t.label,": "),t.value)))}}(t)))}function ct({componentName:t,message:e,width:n,height:o}){return f.createElement("div",{role:"alert",style:{width:n,height:Math.max(o,120),display:"flex",alignItems:"center",justifyContent:"center",border:"1px dashed rgba(128, 128, 128, 0.4)",borderRadius:8,background:"rgba(128, 128, 128, 0.04)",padding:24,boxSizing:"border-box"}},f.createElement("div",{style:{textAlign:"center",maxWidth:400}},f.createElement("div",{style:{fontSize:13,fontWeight:600,color:"rgba(128, 128, 128, 0.7)",marginBottom:6,fontFamily:"monospace"}},t),f.createElement("div",{style:{fontSize:14,color:"rgba(128, 128, 128, 0.9)",lineHeight:1.5}},e)))}function ut({width:o,height:r,margin:s,scales:i,brushDirection:a,extent:l,onBrush:c}){const u=t.useRef(null),h=t.useRef(null),d=t.useRef(!1),p=o+s.left+s.right,y=r+s.top+s.bottom;return t.useEffect(()=>{if(!u.current||!i)return;const t=n.select(u.current).select(".brush-group"),s="x"===a?e.brushX().extent([[0,0],[o,r]]):e.brushY().extent([[0,0],[o,r]]);return s.on("brush end",t=>{if(d.current)return;if(!t.sourceEvent)return;const e=t.selection;if(!e)return void c(null);const n=("x"===a?i.x:i.y).invert;if(!n)return;const o=[n(e[0]),n(e[1])];c(o)}),t.call(s),h.current=s,t.select(".selection").attr("fill","steelblue").attr("fill-opacity",.2).attr("stroke","steelblue").attr("stroke-width",1),()=>{s.on("brush end",null)}},[i,o,r,a,c]),t.useEffect(()=>{if(!h.current||!i||!u.current)return;const t=n.select(u.current).select(".brush-group"),e="x"===a?i.x:i.y;if(d.current=!0,l){const n=[e(l[0]),e(l[1])];t.call(h.current.move,n)}else t.call(h.current.move,null);d.current=!1},[l,i,a]),f.createElement("svg",{ref:u,width:p,height:y,style:{position:"absolute",top:0,left:0,pointerEvents:"all"}},f.createElement("g",{className:"brush-group",transform:`translate(${s.left},${s.top})`}))}function ht(e){var n,r;const{data:s,width:i=600,height:a=400,margin:l,className:c,title:u,xLabel:h,yLabel:d,xFormat:p,yFormat:y,xAccessor:m="x",yAccessor:g="y",lineBy:x,lineDataAccessor:b="coordinates",colorBy:v,colorScheme:k="category10",curve:E="linear",lineWidth:w=2,fillArea:M=!1,areaOpacity:A=.3,showPoints:S=!1,pointRadius:$=3,enableHover:P=!0,showGrid:N=!1,showLegend:_,tooltip:O,minimap:D={},renderBefore:j=!1,onBrush:T,brushExtent:C,frameProps:z={}}=e,B=s||[],[W,L]=t.useState(null),F=null!=C?C:W,Y=t.useCallback(t=>{C||L(t),null==T||T(t)},[C,T]),R=t.useRef(null),[X,I]=t.useState(null);t.useEffect(()=>{const t=()=>{var e,n;const o=null===(n=null===(e=R.current)||void 0===e?void 0:e.getScales)||void 0===n?void 0:n.call(e);o?I(o):requestAnimationFrame(t)};requestAnimationFrame(t)},[s]);const H=void 0!==(null===(n=B[0])||void 0===n?void 0:n[b]),V=t.useMemo(()=>{if(H)return B;if(x){const t=B.reduce((t,e)=>{const n="function"==typeof x?x(e):e[x];if(!t[n]){const e={[b]:[]};"string"==typeof x&&(e[x]=n),t[n]=e}return t[n][b].push(e),t},{});return Object.values(t)}return[{[b]:B}]},[B,x,b,H]),G=t.useMemo(()=>H||x?V.flatMap(t=>{const e=t[b]||[];return x&&"string"==typeof x?e.map(e=>Object.assign(Object.assign({},e),{[x]:t[x]})):e}):B,[V,b,H,x,B]),q=function(e,n,r="category10"){return t.useMemo(()=>{if(n&&"function"!=typeof n)return function(t,e,n="category10"){const r=Array.from(new Set(t.map(t=>t[e]))),s=r.every(t=>"number"==typeof t||!isNaN(Number(t)));if(Array.isArray(n))return o.scaleOrdinal().domain(r).range(n).unknown("#999");const i=et[n]||et.category10;if(s&&"function"==typeof i)return t=>i(Number(t)/Math.max(...r.map(Number)));{const t=Array.isArray(i)?i:nt;return o.scaleOrdinal().domain(r).range(t).unknown("#999")}}(e,n,r)},[e,n,r])}(B,v,k),J=t.useMemo(()=>t=>{const e={strokeWidth:w};return e.stroke=v?ot(t,v,q):rt,M&&(e.fill=e.stroke,e.fillOpacity=A),e},[v,q,w,M,A]),K=t.useMemo(()=>D.lineStyle?D.lineStyle:t=>{const e={strokeWidth:1};return e.stroke=v?ot(t,v,q):rt,e},[v,q,D.lineStyle]),Z=t.useMemo(()=>{if(S)return t=>{const e={r:$,fillOpacity:1};return e.fill=v?ot(t.parentLine||t,v,q):rt,e}},[S,$,v,q]),U=void 0!==_?_:V.length>1,Q=t.useMemo(()=>{if(U&&v)return function({data:t,colorBy:e,colorScale:n,getColor:o,strokeColor:r,strokeWidth:s}){return{legendGroups:[{styleFn:t=>{const e={fill:t.color,stroke:t.color};return void 0!==r&&(e.stroke=r),void 0!==s&&(e.strokeWidth=s),e},type:"fill",items:Array.from(new Set(t.map(t=>"function"==typeof e?e(t):t[e]))).map(r=>{const s=t.find("function"==typeof e?t=>e(t)===r:t=>t[e]===r),i=s?o(s,e,n):n?n(r):"#000000";return{label:r+"",color:i}}),label:""}]}}({data:V,colorBy:v,colorScale:q,getColor:ot})},[U,v,V,q]),st=t.useMemo(()=>{const t=Object.assign(Object.assign({},{top:50,bottom:60,left:70,right:40}),l);return Q&&120>t.right&&(t.right=120),t},[l,Q]),it=D.height||60,at=t.useMemo(()=>{var t,e,n,o,r,s,i,a;return{top:null!==(e=null===(t=D.margin)||void 0===t?void 0:t.top)&&void 0!==e?e:0,bottom:null!==(o=null===(n=D.margin)||void 0===n?void 0:n.bottom)&&void 0!==o?o:20,left:null!==(s=null===(r=D.margin)||void 0===r?void 0:r.left)&&void 0!==s?s:st.left,right:null!==(a=null===(i=D.margin)||void 0===i?void 0:i.right)&&void 0!==a?a:st.right}},[D.margin,st]),ht=D.brushDirection||"x",dt=function({data:t,accessors:e,requiredProps:n}){if(n)for(const[t,e]of Object.entries(n))if(null==e)return t+" is required. Provide a field name or function.";if(!t||!Array.isArray(t)||0===t.length)return"No data provided. Pass a non-empty array to the data prop.";if(e){const n=t[0];if(n&&"object"==typeof n)for(const[t,o]of Object.entries(e))if(o&&"string"==typeof o&&!(o in n))return`${t} "${o}" not found in data. Available fields: ${Object.keys(n).join(", ")}.`}return null}({componentName:"MinimapChart",data:B,accessors:{xAccessor:m,yAccessor:g}});if(dt)return f.createElement(ct,{componentName:"MinimapChart",message:dt,width:i,height:a});const ft=M?"area":"line",pt=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({chartType:ft,data:G,xAccessor:m,yAccessor:g,groupAccessor:x||void 0,curve:E,lineStyle:J},S&&{pointStyle:Z}),{size:[i,a],margin:st,showAxes:!0,xLabel:h,yLabel:d,xFormat:p,yFormat:y,enableHover:P,showGrid:N}),Q&&{legend:Q}),u&&{title:u}),O&&{tooltipContent:lt(O)}),F&&{xExtent:F}),z),yt={chartType:ft,data:G,xAccessor:m,yAccessor:g,groupAccessor:x||void 0,curve:E,lineStyle:K,size:[i,it+at.top+at.bottom],margin:at,showAxes:null!==(r=D.showAxes)&&void 0!==r&&r,background:D.background,enableHover:!1},mt=f.createElement("div",{key:"minimap",style:{position:"relative",width:i}},f.createElement(tt,Object.assign({ref:R},yt)),f.createElement(ut,{width:i-at.left-at.right,height:it,margin:at,scales:X,brushDirection:ht,extent:F,onBrush:Y})),gt=f.createElement("div",{key:"main"},f.createElement(tt,Object.assign({},pt)));return f.createElement("div",{className:"minimap-chart"+(c?" "+c:"")},j?mt:gt,j?gt:mt)}ht.displayName="MinimapChart";const dt=({xy:t,orient:e,i:n,className:o="",jaggedBase:r})=>{let s=`M${t.x1},${t.y1}L${t.x2},${t.y2}`;return r&&0===n&&(s=((t,e)=>{let n="";const{x1:o,x2:r,y1:s,y2:i}=e;if("left"===t||"right"===t){const e=Math.abs(r-o);n=((t,e,n,o)=>{const r=t/e;let s=0,i="M0,"+n;const a="right"===o?-1:1;for(;t>=s;)i+=`L${s},${n}`,t>s&&(i+=`L${s+r/2},${n+10*a}`),s+=r;return i})(e,Math.ceil(e/40),"right"===t?0:s,t)}else{const e=Math.abs(i-s);n=((t,e,n,o)=>{const r=t/e;let s=0,i=`M${n},0`;const a="bottom"===o?-1:1;for(;t>=s;)i+=`L${n},${s}`,t>s&&(i+=`L${n+10*a},${s+r/2}`),s+=r;return i})(e,Math.ceil(e/40),o,t)}return n})(e,t)),f.createElement("path",{key:n,fill:"none",stroke:"currentColor",strokeWidth:"1px",d:s,className:`tick-line tick ${e} ${o}`})};function ft(t,e,n){const o=Math.abs(n.range()[1]-n.range()[0]);return t||(e||(e=Math.max(1,Math.floor(o/40))),t=n.ticks&&n.ticks(e)||n.domain()),t}function pt({t:t,o:e,w:n}){return"contour"!==t&&"boxplot"!==t||"left"!==e&&"right"!==e?0:n/2}function yt({t:t,o:e,w:n}){return"contour"!==t&&"boxplot"!==t||"top"!==e&&"bottom"!==e?0:n/2}function mt(t){const{translation:e,orient:n,decoratedSummaryType:o,summaryWidth:r,renderedSummary:s,points:i}=t;return f.default.createElement("g",{className:"marginal-graphics",transform:`translate(${e[n]})`},f.default.createElement("g",{transform:`translate(${pt({t:o.type,o:n,w:r})},${yt({t:o.type,o:n,w:r})})`},s),i)}function gt(t){const{className:e,translation:n,position:o,rotation:r,labelName:s,anchorMod:i}=t;return f.default.createElement("g",{className:"axis-title "+e,transform:`translate(${[n[0]+o[0],n[1]+o[1]]}) rotate(${r})`},f.default.isValidElement(s)?s:f.default.createElement("text",{textAnchor:i},s))}function xt(t){if(null==t)return"";if("number"!=typeof t)return t+"";if(!isFinite(t))return t+"";if(0===t)return"0";const e=parseFloat(t.toPrecision(12)),n=Math.abs(e);return 1e9>n?1e6>n?1e4>n?Number.isInteger(e)?e+"":parseFloat(e.toPrecision(6))+"":parseFloat((e/1e3).toPrecision(3))+"K":parseFloat((e/1e6).toPrecision(3))+"M":parseFloat((e/1e9).toPrecision(3))+"B"}function bt(t,e){var n={};for(var o in t)Object.prototype.hasOwnProperty.call(t,o)&&0>e.indexOf(o)&&(n[o]=t[o]);if(null!=t&&"function"==typeof Object.getOwnPropertySymbols){var r=0;for(o=Object.getOwnPropertySymbols(t);o.length>r;r++)0>e.indexOf(o[r])&&Object.prototype.propertyIsEnumerable.call(t,o[r])&&(n[o[r]]=t[o[r]])}return n}"function"==typeof SuppressedError&&SuppressedError;function vt(t,e=120,n=8){if(!t)return[];const o=Math.max(1,Math.floor(e/n)),r=t.split(/\s+/),s=[];let i="";for(const t of r)i&&i.length+1+t.length>o?(s.push(i),i=t):i=i?`${i} ${t}`:t;return i&&s.push(i),s}function kt(t,e,n,o){return"curly"===t?o?`M0,0 C${.6*n},0 ${.4*n},${e/2} ${n},${e/2} C${.4*n},${e/2} ${.6*n},${e} 0,${e}`:`M0,0 C0,${.6*n} ${e/2},${.4*n} ${e/2},${n} C${e/2},${.4*n} ${e},${.6*n} ${e},0`:o?`M0,0 L${n},0 L${n},${e} L0,${e}`:`M0,0 L0,${n} L${e},${n} L${e},0`}function Et(t){const{x:e=0,y:n=0,dx:o,dy:r,nx:s,ny:i,note:a,connector:l,subject:c,type:u,color:h,className:d,disable:p,events:y={},"data-testid":m}=t,g=new Set(Array.isArray(p)?p:[]);let x=o||0,b=r||0;null!=s&&(x=s-e),null!=i&&(b=i-n);const v="string"==typeof u?u:"label";if("bracket"===v&&c&&0===x&&0===b)if(void 0!==c.width){x=c.width/2;const t=c.depth||30;b=t+(0>t?-5:5)}else if(void 0!==c.height){const t=c.depth||30;x=t+(0>t?-5:5),b=c.height/2}return f.createElement("g",Object.assign({className:("annotation "+(d||"")).trim(),transform:`translate(${e},${n})`,"data-testid":m},y),!g.has("connector")&&function(t,e,n,o,r,s){const i=[];let a=0,l=0;if("callout-circle"!==r&&"label"!==r||!(null==s?void 0:s.radius)){if("callout-rect"===r&&s){const n=s.width||0,o=s.height||0;if(n>0||o>0){const r=n/2,s=o/2,i=t-r,c=e-s;if(0!==i||0!==c){const t=Math.abs(i),e=Math.abs(c),u=n/2,h=o/2,d=t*h>e*u?u/t:h/e;a=r+i*d,l=s+c*d}}}else if("bracket"===r&&s){const t=s.width,e=s.height,n=s.depth||30;void 0!==t?(a=t/2,l=n):void 0!==e&&(a=n,l=e/2)}}else{const n=(s.radius||0)+(s.radiusPadding||0);if(n>0&&(0!==t||0!==e)){const o=Math.atan2(e,t);a=Math.cos(o)*n,l=Math.sin(o)*n}}if(Math.sqrt(Math.pow(t-a,2)+Math.pow(e-l,2))>.5&&(i.push(f.createElement("line",{key:"connector-line",x1:a,y1:l,x2:t,y2:e,stroke:o||"currentColor"})),"arrow"===(null==n?void 0:n.end))){const n=10,r=16/180*Math.PI,s=Math.atan2(e-l,t-a);i.push(f.createElement("path",{key:"connector-arrow",d:`M${a},${l}L${a+n*Math.cos(s+r)},${l+n*Math.sin(s+r)}L${a+n*Math.cos(s-r)},${l+n*Math.sin(s-r)}Z`,fill:o||"currentColor",stroke:"none"}))}return f.createElement("g",{className:"annotation-connector"},i)}(x,b,l,h,v,c),!g.has("subject")&&function(t,e,n,o,r){var s;const i=[];switch(t){case"callout-circle":{const t=((null==e?void 0:e.radius)||0)+((null==e?void 0:e.radiusPadding)||0);t>0&&i.push(f.createElement("circle",{key:"subject-circle",r:t,fill:"none",stroke:n||"currentColor"}));break}case"callout-rect":{const t=(null==e?void 0:e.width)||0,o=(null==e?void 0:e.height)||0;(t>0||o>0)&&i.push(f.createElement("rect",{key:"subject-rect",width:t,height:o,fill:"none",stroke:n||"currentColor"}));break}case"callout-custom":(null==e?void 0:e.custom)&&i.push(...Array.isArray(e.custom)?e.custom:[e.custom]);break;case"xy-threshold":{const t=o||0,s=r||0;if(void 0!==(null==e?void 0:e.x)){const o=(e.x||0)-t;i.push(f.createElement("line",{key:"threshold-line",x1:o,y1:(e.y1||0)-s,x2:o,y2:(e.y2||0)-s,stroke:n||"currentColor",strokeDasharray:"5,5"}))}else if(void 0!==(null==e?void 0:e.y)){const o=(e.y||0)-s;i.push(f.createElement("line",{key:"threshold-line",x1:(e.x1||0)-t,y1:o,x2:(e.x2||0)-t,y2:o,stroke:n||"currentColor",strokeDasharray:"5,5"}))}else void 0!==(null==e?void 0:e.x1)||void 0!==(null==e?void 0:e.x2)?i.push(f.createElement("line",{key:"threshold-line",x1:(e.x1||0)-t,y1:0,x2:(e.x2||0)-t,y2:0,stroke:n||"currentColor",strokeDasharray:"5,5"})):void 0===(null==e?void 0:e.y1)&&void 0===(null==e?void 0:e.y2)||i.push(f.createElement("line",{key:"threshold-line",x1:0,y1:(e.y1||0)-s,x2:0,y2:(e.y2||0)-s,stroke:n||"currentColor",strokeDasharray:"5,5"}));break}case"bracket":{const t=null!==(s=null==e?void 0:e.width)&&void 0!==s?s:null==e?void 0:e.height;void 0!==t&&i.push(f.createElement("path",{key:"bracket-path",d:kt((null==e?void 0:e.type)||"curly",t,(null==e?void 0:e.depth)||30,void 0===(null==e?void 0:e.width)),fill:"none",stroke:n||"currentColor"}));break}}return f.createElement("g",{className:"annotation-subject"},i)}(v,c,h,e,n),!g.has("note")&&function(t,e,n,o){if(!t)return f.createElement("g",{className:"annotation-note"});const{label:r,title:s,orientation:i,align:a,wrap:l=120,noWrap:c}=t;if(!r&&!s)return f.createElement("g",{className:"annotation-note"});let u=i;u||(u=Math.abs(e)>Math.abs(n)?"leftRight":"topBottom");let h=a;h&&"dynamic"!==h||(h="topBottom"===u?0>e?"right":"left":0>n?"bottom":"top");let d="start";"topBottom"===u?"right"===h?d="end":"middle"===h&&(d="middle"):d=0>e?"end":"start";const p=16,y=s?c?[s]:vt(s,l):[],m=r?c?[r]:vt(r,l):[],g="leftRight"===u?"end"===d?-4:4:0;let x=0;const b=[];y.length>0&&(b.push(f.createElement("text",{key:"annotation-note-title",className:"annotation-note-title",fill:o||void 0,textAnchor:d,fontWeight:"bold"},y.map((t,e)=>f.createElement("tspan",{key:e,x:g,dy:0===e?0:p},t)))),x=y.length*p),m.length>0&&b.push(f.createElement("text",{key:"annotation-note-label",className:"annotation-note-label",fill:o||void 0,textAnchor:d,y:x},m.map((t,e)=>f.createElement("tspan",{key:e,x:g,dy:p},t))));let v=null;if((s||r)&&(0!==e||0!==n))if("topBottom"===u){const t=Math.min(l,120);let e=0,n=t;"end"===d?(e=-t,n=0):"middle"===d&&(e=-t/2,n=t/2),v=f.createElement("line",{className:"note-line",x1:e,x2:n,y1:0,y2:0,stroke:o||"currentColor"})}else{const t=(y.length+m.length)*p+(m.length>0?p:0);let e=0,n=t;"bottom"===h?(e=-t,n=0):"middle"===h&&(e=-t/2,n=t/2),v=f.createElement("line",{className:"note-line",x1:0,x2:0,y1:e,y2:n,stroke:o||"currentColor"})}const k=(y.length+m.length)*p+(m.length>0?p:0);let E=0;return"topBottom"===u?0>n&&(E=-k):"leftRight"===u&&("middle"===h?E=-k/2:("bottom"===h||0>n)&&(E=-k)),f.createElement("g",{className:"annotation-note",transform:`translate(${e},${n})`},f.createElement("g",{className:"annotation-note-content",transform:0!==E?`translate(0,${E})`:void 0},b),v)}(a,x,b,h))}function wt(t){const{noteData:e}=t,{screenCoordinates:n}=e,o="string"==typeof e.type?e.type:"label",r=e.eventListeners||e.events||{};if(e.coordinates&&n){const t=e.nx||n[0][0]+e.dx,r=e.ny||n[0][1]+e.dy,s=n.map((n,s)=>{const i=Object.assign({},e,{note:0===s?e.note:{label:""},x:n[0],y:n[1],nx:t,ny:r});return f.createElement(Et,Object.assign({"data-testid":"semiotic-annotation",key:"multi-annotation-"+s},i,{type:o}))});return f.createElement("g",null,s)}const s=e.note||{title:"none",label:e.label};return f.createElement(Et,Object.assign({"data-testid":"semiotic-annotation",key:`${s.label}-${s.title}-${e.i}`,events:r},e,{type:o}))}const Mt=(t,e,n,o)=>{const r=(t.note.label||t.note.title).length;return[Math.min(t.note.wrap||120,r*e)+2*o,Math.ceil(r*e/120)*n+2*o]};function At(t){let e=new EventTarget,n=t(function(t){n=Object.assign(n,t(n)),e.dispatchEvent(new CustomEvent("update"))});return{getState:()=>n,subscribe:function(t){return e.addEventListener("update",t),()=>e.removeEventListener("update",t)}}}let[St,$t]=function(e){let n=t.createContext(null),o=At(e);return[function({children:o}){let r=t.useMemo(()=>At(e),[]);return f.createElement(n.Provider,{value:r,children:o})},e=>{var r;let s=null!==(r=t.useContext(n))&&void 0!==r?r:o;return function(e,n){const[o,r]=t.useState(n);return t.useLayoutEffect(()=>e(()=>r(n)),[e]),o}(s.subscribe,()=>e(s.getState()))}]}(t=>({tooltip:null,changeTooltip(e){t(()=>({tooltip:e}))}}));function Pt(t,e,n){return"number"==typeof n?n:e&&e.find(e=>e.props.orient===t)?50:10}const Nt=(t,e,n)=>`${t.map(_t).join(",")}${JSON.stringify(e)}${n.join(",")}`;function _t(t){if(!t||!t.props||!t.props.noteData)return"";const{note:e={}}=t.props.noteData,{label:n,title:o}=e;return`${t.props.noteData.id||`${t.props.noteData.x}-${t.props.noteData.y}`}-${n}=${o}`}function Ot(t,e=8,n){const{noteWidth:o=n}=t;let r=o;"number"==typeof o&&(r=()=>o);const s=t.note&&t.note.wrap||120,i=t.note.label||t.note.label||"";return o&&r(t)||(f.default.isValidElement(t.note)?100:Math.min(s,i.length*e))}function Dt(t,e=8,n=20,o){const{noteHeight:r=o}=t;let s=r;"number"==typeof r&&(s=()=>r);const i=t.note&&t.note.wrap||120,a=t.note.label||t.note.title||"";return r&&s(t)||(f.default.isValidElement(t.note)?30:Math.ceil(a.length*e/i)*n+(t.note.label&&t.note.title?n:0))}const jt=(t,e)=>e.map((e,n)=>t.svgAnnotationRule(e,n,t)).filter(t=>null!=t),Tt=(t,e)=>{let n=e.adjustedAnnotations,o=e.adjustedAnnotationsKey,r=e.adjustableAnnotations,s=e.fixedAnnotations,i=[],a=[];const l=e.adjustedAnnotationsKey,c=e.adjustedAnnotationsDataVersion,{annotations:u,annotationHandling:h=!1,size:d,svgAnnotationRule:y,htmlAnnotationRule:m}=t,g="object"==typeof h?h:{layout:{type:h},dataVersion:""},{dataVersion:x=""}=g;if(y){const e=jt(t,u);o=Nt(e,g,d),!1===h&&(n=r),n=n.length!==r.length||l!==o||c!==x?((t,e,n)=>{const{layout:o={type:!1,noteHeight:void 0,noteWidth:void 0}}=e;if(!1===o.type)return t;const{noteWidth:r,noteHeight:s}=o;let{margin:i={top:0,bottom:0,left:0,right:0}}=n;const{size:a,axes:l=[]}=n;if(i="number"==typeof i?{top:i,left:i,right:i,bottom:i}:i,"bump"===o.type)return function(t,e,n,o,r){const{padding:s=1,characterWidth:i=8,lineHeight:a=20,iterations:l=500,pointSizeFunction:c=o,labelSizeFunction:u=r||Mt}=e,h=t.map((t,e)=>{const n=(t.props.noteData.x[0]||t.props.noteData.x)+(void 0!==t.props.noteData.dx?t.props.noteData.dx:-10*(e%3-1)),o=(t.props.noteData.y[0]||t.props.noteData.y)+(void 0!==t.props.noteData.dy?t.props.noteData.dy:10*(e%3-1)),[r,l]=u(t.props.noteData,i,a,s);return{x:n,y:o,above:t.props.noteData.y>o,left:t.props.noteData.x>n,width:r,height:l,type:"label",name:"",originalNote:t}}),d=t.map(t=>({x:t.props.noteData.x,y:t.props.noteData.y,fx:t.props.noteData.x,fy:t.props.noteData.y,r:c&&c(t.props.noteData)||5,type:"point",originalNote:t})),f=function(){let t,e=[],n=[],o=1,r=1,s={start:t=>{},width:t=>{},height:t=>{},label:t=>{},anchor:t=>{},alt_energy:t=>{},alt_schedule:t=>{}},i=!1;const a=function(t){let o=e.length,r=0,s=e[t].x-n[t].x,i=n[t].y-e[t].y,a=Math.sqrt(s*s+i*i);a>0&&(r+=.2*a),s/=a,i/=a,r+=s>0&&i>0?0:0>s&&i>0?3:0>s&&0>i?6:9;let l,c,h,d,f,p,y,m=e[t].x,g=e[t].y-e[t].height+2,x=e[t].x+e[t].width,b=e[t].y+2;for(let s=0;o>s;s++)s!==t&&(u(n[t].x,e[t].x,n[s].x,e[s].x,n[t].y,e[t].y,n[s].y,e[s].y)&&(r+=1),l=e[s].x,h=e[s].y-e[s].height+2,c=e[s].x+e[s].width,d=e[s].y+2,f=Math.max(0,Math.min(c,x)-Math.max(l,m)),p=Math.max(0,Math.min(d,b)-Math.max(h,g)),y=f*p,r+=30*y),l=n[s].x-n[s].r,h=n[s].y-n[s].r,c=n[s].x+n[s].r,d=n[s].y+n[s].r,f=Math.max(0,Math.min(c,x)-Math.max(l,m)),p=Math.max(0,Math.min(d,b)-Math.max(h,g)),y=f*p,r+=30*y;return r},l=function(s){let l,c,u=Math.floor(Math.random()*e.length),h=e[u].x,d=e[u].y;l=i?t(u,e,n):a(u),e[u].x+=5*(Math.random()-.5),e[u].y+=5*(Math.random()-.5),e[u].x>o&&(e[u].x=h),0>e[u].x&&(e[u].x=h),e[u].y>r&&(e[u].y=d),0>e[u].y&&(e[u].y=d),c=i?t(u,e,n):a(u);let f=c-l;Math.random()<Math.exp(-f/s)||(e[u].x=h,e[u].y=d)},c=function(s){let l,c=Math.floor(Math.random()*e.length),u=e[c].x,h=e[c].y;l=i?t(c,e,n):a(c);let d=.5*(Math.random()-.5),f=Math.sin(d),p=Math.cos(d);e[c].x-=n[c].x,e[c].y-=n[c].y;let y,m=e[c].x*f+e[c].y*p;e[c].x=e[c].x*p-e[c].y*f+n[c].x,e[c].y=m+n[c].y,e[c].x>o&&(e[c].x=u),0>e[c].x&&(e[c].x=u),e[c].y>r&&(e[c].y=h),0>e[c].y&&(e[c].y=h),y=i?t(c,e,n):a(c);let g=y-l;Math.random()<Math.exp(-g/s)||(e[c].x=u,e[c].y=h)},u=function(t,e,n,o,r,s,i,a){let l,c,u,h,d;return u=(a-i)*(e-t)-(o-n)*(s-r),h=(o-n)*(r-i)-(a-i)*(t-n),d=(e-t)*(r-i)-(s-r)*(t-n),l=h/u,c=d/u,!(0>l||l>1||0>c||c>1)},h=function(t,e,n){return t-e/n};return s.start=function(t){let n=e.length,o=1;for(let e=0;t>e;e++){for(let t=0;n>t;t++).5>Math.random()?l(o):c(o);o=h(o,1,t)}},s.width=function(t){return arguments.length?(o=t,s):o},s.height=function(t){return arguments.length?(r=t,s):r},s.label=function(t){return arguments.length?(e=t,s):e},s.anchor=function(t){return arguments.length?(n=t,s):n},s.alt_energy=function(e){return arguments.length?(t=e,i=!0,s):a},s.alt_schedule=function(t){return arguments.length?s:h},s}();return f.label(h),f.anchor(d),f.width(n[0]),f.height(n[1]),f.start(l),h.forEach(t=>{if("label"===t.type){const e=function(t,e,n){return t.y>e.y?[e.x+e.width/2+n/2,e.y-e.height+n/2]:[e.x+e.width/2,e.y]}(t.originalNote.props.noteData,t,s);t.originalNote.props.noteData.nx=e[0],t.originalNote.props.noteData.ny=e[1]}}),t}(t,o,a,n.pointSizeFunction,n.labelSizeFunction);if("marginalia"===o.type){const{marginOffset:e,orient:n="nearest",characterWidth:c=8,lineHeight:u=20,padding:h=2,axisMarginOverride:d={}}=o,y="nearest"===n?["left","right","top","bottom"]:Array.isArray(n)?n:[n],m=y.find(t=>"left"===t),g=y.find(t=>"right"===t),x=y.find(t=>"top"===t),b=y.find(t=>"bottom"===t),v=[],k=[],E=[],w=[];for(const e of t){const t=e.props.noteData,n=t.x[0]||t.x,o=t.y[0]||t.y,r=m?n:1/0,s=g?a[0]-n:1/0,i=x?o:1/0,l=Math.min(r,s,i,b?a[1]-o:1/0);r===l?v.push(e):s===l?k.push(e):i===l?E.push(e):w.push(e)}const M=new p.default.Force({minPos:void 0!==d.top?0+d.top:0-i.top,maxPos:void 0!==d.bottom?a[1]-d.bottom:b?a[1]:a[1]+i.bottom}).nodes(v.map(t=>new p.default.Node(t.props.noteData.y[0]||t.props.noteData.y,Dt(t.props.noteData,c,u,r)+h))).compute(),A=new p.default.Force({minPos:void 0!==d.top?0+d.top:x?0:0-i.top,maxPos:void 0!==d.bottom?a[1]-d.bottom:a[1]+i.bottom}).nodes(k.map(t=>new p.default.Node(t.props.noteData.y[0]||t.props.noteData.y,Dt(t.props.noteData,c,u,r)+h))).compute(),S=new p.default.Force({minPos:void 0!==d.left?0+d.left:m?0:0-i.left,maxPos:void 0!==d.right?a[0]-d.right:a[0]+i.right}).nodes(E.map(t=>new p.default.Node(t.props.noteData.x[0]||t.props.noteData.x,Ot(t.props.noteData,c,s)+h))).compute(),$=new p.default.Force({minPos:void 0!==d.left?0+d.left:0-i.left,maxPos:void 0!==d.right?a[0]-d.right:g?a[0]:a[0]+i.right}).nodes(w.map(t=>new p.default.Node(t.props.noteData.x[0]||t.props.noteData.x,Ot(t.props.noteData,c,s)+h))).compute(),P=Math.max(...w.map(t=>Dt(t.props.noteData,c,u,r)+h)),N=Math.max(...E.map(t=>Dt(t.props.noteData,c,u,r)+h)),_=Math.max(...v.map(t=>Ot(t.props.noteData,c,s)+h)),O=Math.max(...k.map(t=>Ot(t.props.noteData,c,s)+h)),D=M.nodes(),j=A.nodes(),T=S.nodes(),C=$.nodes();return v.forEach((t,n)=>{const o=0-D[n].layerIndex*_-Pt("left",l,e),r=D[n].currentPos;t.props.noteData.nx=o,t.props.noteData.ny=r,t.props.noteData.note&&!f.isValidElement(t)&&(t.props.noteData.note.orientation=t.props.noteData.note.orientation||"leftRight",t.props.noteData.note.align=t.props.noteData.note.align||"right")}),k.forEach((t,n)=>{const o=a[0]+j[n].layerIndex*O+Pt("right",l,e),r=j[n].currentPos;t.props.noteData.nx=o,t.props.noteData.ny=r,t.props.noteData.note&&!f.isValidElement(t)&&(t.props.noteData.note.orientation=t.props.noteData.note.orientation||"leftRight",t.props.noteData.note.align=t.props.noteData.note.align||"left")}),E.forEach((t,n)=>{const o=T[n].currentPos,r=0-T[n].layerIndex*N-Pt("top",l,e);t.props.noteData.nx=o,t.props.noteData.ny=r}),w.forEach((t,n)=>{const o=C[n].currentPos,r=a[1]+C[n].layerIndex*P+Pt("bottom",l,e);t.props.noteData.nx=o,t.props.noteData.ny=r}),t}return t})(r,g,t):r.map((t,e)=>{const o=Object.assign(Object.assign({},n[e].props.noteData),t.props.noteData);return f.createElement(wt,{key:t.key,noteData:o})}),i=[...n,...s]}return m&&(a=((t,e)=>e.map((e,n)=>t.htmlAnnotationRule(e,n,t)).filter(t=>null!=t))(t,u)),{svgAnnotations:i,htmlAnnotations:a,adjustedAnnotations:n,adjustedAnnotationsKey:o,adjustedAnnotationsDataVersion:x}},Ct=t=>t.reduce((t,e)=>t.concat(Array.isArray(e)?Ct(e.slice().sort((t,e)=>t-e)):e),[]);function zt(t=[]){if(!Array.isArray(t))return"not-array";let e=t.slice();return Array.isArray(e[0])||(e=e.slice().sort((t,e)=>t-e)),""+Ct(e).map(t=>t instanceof Date&&""+t||void 0!==t&&t.toFixed&&t.toFixed(2)||"empty")}const Bt=t=>t instanceof Date?t.getTime():t,Wt=({data:t,lineDataAccessor:e,xProp:n,xPropTop:o,xPropBottom:r,yProp:s,yPropTop:i,yPropBottom:a,xAccessor:l,yAccessor:c})=>{Array.isArray(t)||(t=[t]);const u=[];return e.forEach((e,h)=>{l.forEach((l,d)=>{c.forEach((c,f)=>{t.forEach(t=>{const p=Object.assign(Object.assign({},t),{xIndex:d,yIndex:f,lineIndex:h});p.data=e(t).map((t,e)=>{const u={data:t};return u[n]=l(t,e),u[o]=u[n],u[r]=u[n],u[s]=c(t,e),u[i]=u[s],u[a]=u[s],u}),p.key=p.key||u.length,u.push(p)})})})}),u},Lt=({type:t="stackedarea",data:e,xProp:n,yProp:o,yPropMiddle:s,sort:i,yPropTop:a,yPropBottom:l})=>{const c=new Map,u=e.map(()=>0);let h=0;for(const t of e){t.__lineIndex=h;for(const e of t.data){const t=Bt(e[n]);u[h]+=e[o],c.has(t)||c.set(t,[]),c.get(t)[h]=e}h++}let d=(t,e)=>u[e.key]-u[t.key];"stackedpercent-invert"!==t&&"stackedarea-invert"!==t||(d=(t,e)=>u[t.key]-u[e.key]),null!==(i=void 0===i?d:i)&&(e=e.sort(i));const f=e.map(t=>t.__lineIndex);for(const[,e]of c){let n=0,i=0;const c=r.sum(e,t=>(null==t?void 0:t[o])>0?t[o]:0),u=r.sum(e,t=>0>(null==t?void 0:t[o])?t[o]:0);for(const r of f){const h=e[r];if(h)if(0>h[o]){if("linepercent"===t||"stackedpercent"===t||"stackedpercent-invert"===t){const e=h[o]/u;if(h.percent=e,"linepercent"===t)h[l]=h[l]=h[a]=h[s]=e;else{const t=0>u?e:0;h[l]=0===u?0:-n/u,h[a]=h[l]-t,h[s]=h[l]-t/2}}else h[l]=n,h[a]=n+h[o],h[s]=n+h[o]/2;n+=h[o]}else{if("linepercent"===t||"stackedpercent"===t||"stackedpercent-invert"===t){const e=h[o]/c;if(h.percent=e,"linepercent"===t)h[l]=h[a]=h[s]=e;else{const t=c>0?e:0;h[l]=0===c?0:i/c,h[a]=h[l]+t,h[s]=h[l]+t/2}}else h[l]=i,h[a]=i+h[o],h[s]=i+h[o]/2;i+=h[o]}}}return e},Ft=({data:t,y1:e,x1:n,yPropTop:o,yPropMiddle:r,yPropBottom:s,xPropTop:i,xPropMiddle:a,xPropBottom:l})=>{if(e)for(const n of t)for(const t of n.data)t[s]=e(t),t[r]=t[o];if(n)for(const e of t)for(const t of e.data)t[l]=n(t),t[a]=(t[l]+t[i])/2;return t},Yt=({data:t,y1:e,yPropTop:n,yPropMiddle:o,yPropBottom:r,type:s="cumulative"})=>{for(const i of t){let t=0;const a="cumulative-reverse"===s?i.data.reverse():i.data;for(const s of a)t+=s[n],s[r]=s[n]=s[o]=t,e&&(s[r]=e(s),s[o]=s[r]+s[n]/2)}return t},Rt=({type:t="bumpline",data:e,xProp:n,yProp:o,yPropMiddle:r,yPropTop:s,yPropBottom:i})=>{const a=new Map;for(const t of e)for(const e of t.data){const t=Bt(e[n]);a.has(t)||a.set(t,[]),a.get(t).push(e)}let l=(t,e)=>t[o]>e[o]?1:-1;"bumparea-invert"!==t&&"bumpline-invert"!==t||(l=(t,e)=>e[o]>t[o]?1:-1);for(const[,e]of a){let n=0,a=0;e.sort(l);let c=1;for(const l of e)"bumparea"===t||"bumparea-invert"===t?0>l[o]?(l[s]=n+l[o],l[r]=n+l[o]/2,l[i]=n,n+=l[o]):(l[s]=a+l[o],l[r]=a+l[o]/2,l[i]=a,a+=l[o]):(l[o]=c,l[s]=c,l[i]=c),c++}return e};function Xt({pointA:t,pointB:e,currentParameters:n,parameters:o,keys:r}){const s={};return r.forEach(n=>{s[n]="number"==typeof t[n]?(t[n]+e[n])/2:void 0}),JSON.stringify(o(s))===JSON.stringify(n)?[s,e]:[t,s]}const It="x",Ht="y",Vt="yMiddle",Gt="yTop",qt="yBottom",Jt="xMiddle",Kt="xTop",Zt="xBottom";function Ut({preprocess:t=!0,processedData:e=!1,summaryType:n,data:r,finalXExtent:s,finalYExtent:i,size:a,xScaleType:l=o.scaleLinear(),yScaleType:c=o.scaleLinear(),margin:h,styleFn:d,classFn:p,renderFn:y,chartSize:m}){let g=s,x=i;if(!g){const t=r.coordinates.map(t=>t.x);g=[Math.min(...t),Math.max(...t)]}if(!x){const t=r.coordinates.map(t=>t.y);x=[Math.min(...t),Math.max(...t)]}if(e&&r)return r.coordinates;let b,v=[];b=n.type?n:{type:b};const{bins:k=.05,cellPx:E,binValue:w=t=>t.length,binMax:M,customMark:A}=b;r.coordinates&&!r._xyfCoordinates&&(r._xyfCoordinates=r.coordinates.map(t=>[t.x,t.y]));const S=Array.isArray(r)?r:[r],$=l.domain(g).range([0,a[0]]),P=c.domain(x).range([0,a[1]]),N=E&&E/2||(k>1?1/k:k)*a[0]/2,_=u.hexbin().x(t=>$(t._xyfPoint[0])).y(t=>P(t._xyfPoint[1])).radius(N).size(a);let O;const D=_.centers();return S.forEach(t=>{O=0;const e=_(t._xyfCoordinates.map((e,n)=>Object.assign({_xyfPoint:e},t.coordinates[n]))),n={};e.forEach(t=>{n[`${parseInt(t.x)}-${parseInt(t.y)}`]=!0}),D.forEach(t=>{if(!n[`${parseInt(t[0])}-${parseInt(t[1])}`]){const n=[];n.x=t[0],n.y=t[1],e.push(n)}}),O=Math.max(...e.map(t=>w(t))),M&&M(O);const o=[[0,-1],[.866,-.5],[.866,.5],[0,1],[-.866,.5],[-.866,-.5]],r=$.invert(N)-g[0],s=P.invert(N)-x[0],i=o.map(t=>[t[0]*r,t[1]*s]),l=e.map(e=>{const n=w(e),r=e.x,s=e.y;e.x=$.invert(e.x),e.y=P.invert(e.y);const l=n/O;return{customMark:A&&f.createElement("g",{transform:`translate(${r},${a[1]-s})`},A({d:Object.assign(Object.assign({},e),{binItems:e,percent:l,value:n,radius:N,hexCoordinates:o.map(t=>[t[0]*N,t[1]*N])}),margin:h,styleFn:d,classFn:p,renderFn:y,chartSize:m,adjustedSize:a})),_xyfCoordinates:i.map(t=>[t[0]+e.x,t[1]+e.y]),value:n,percent:l,data:e,parentSummary:t,centroid:!0}});v=[...v,...l]}),t?(v.forEach(t=>{t.x=t.data.x,t.y=t.data.y}),{type:"hexbin",processedData:!0,coordinates:v,binMax:O}):v}const Qt=(t,e,n,o)=>[...t.map((t,o)=>[t[0],t[1]+n(e[o])]),...t.map((t,n)=>[t[0],t[1]-o(e[n])]).reverse()];function te({preprocess:t=!0,processedData:e=!1,summaryType:n,data:r,finalXExtent:s=[Math.min(...r.coordinates.map(t=>t.x)),Math.max(...r.coordinates.map(t=>t.x))],finalYExtent:i=[Math.min(...r.coordinates.map(t=>t.y)),Math.max(...r.coordinates.map(t=>t.y))],size:a,xScaleType:l=o.scaleLinear(),yScaleType:c=o.scaleLinear(),margin:u,styleFn:h,classFn:d,renderFn:p,chartSize:y}){if(e&&r)return r.coordinates;r.coordinates&&!r._xyfCoordinates&&(r._xyfCoordinates=r.coordinates.map(t=>[t.x,t.y]));const m=Array.isArray(r)?r:[r];let g,x=[];g=n.type?n:{type:g};const{binValue:b=t=>t.length,xBins:v=g.yBins||.05,yBins:k=v,xCellPx:E=!g.xBins&&g.xCellPx,yCellPx:w=!g.yBins&&g.yCellPx,customMark:M,binMax:A}=g,S=1>v?v:1/v,$=1>k?k:1/k,P=l.domain(s).range([0,a[0]]),N=c.domain(i).range([a[1],0]),_=[Math.ceil((E&&E/a[0]||S)*a[0]*10)/10,Math.ceil((w&&w/a[1]||$)*a[1]*10)/10];let O=-1/0;return m.forEach(t=>{const e=[],n=[];let o,r;for(let s=0;a[0]>Math.ceil(s);s+=_[0]){const i=P.invert(s),l=P.invert(s+_[0]);r=[],e.push(r);for(let e=0;a[1]>Math.ceil(e);e+=_[1]){const a=N.invert(e),c=N.invert(e+_[1]);o={gx:s,gy:e,gw:_[0],gh:_[1],x:(i+l)/2,y:(a+c)/2,binItems:[],value:0,_xyfCoordinates:[[i,a],[l,a],[l,c],[i,c]],parentSummary:t},r.push(o),n.push(o)}r.push(o)}e.push(r),t._xyfCoordinates.forEach((n,o)=>{const r=P(n[0]),s=N(n[1]),i=Math.floor(r/_[0]),a=Math.floor(s/_[1]);e[i][a]&&e[i][a].binItems.push(t.coordinates[o])}),n.forEach(t=>{t.value=b(t.binItems),O=Math.max(O,t.value)}),n.forEach(t=>{t.percent=t.value/O,t.customMark=M&&f.createElement("g",{transform:`translate(${t.gx},${t.gy})`},M({d:t,margin:u,styleFn:h,classFn:d,renderFn:p,chartSize:y,adjustedSize:a}))}),x=[...x,...n]}),A&&A(O),t?{type:"heatmap",processedData:!0,_baseData:[],_xyfCoordinates:[],data:[],bounds:[],x:0,y:0,coordinates:x,binMax:O}:x}const ee=t=>t&&t.extent||Array.isArray(t)&&t||[],ne=()=>!0,oe={top:Gt,bottom:qt,orphan:Ht},re={top:Kt,bottom:Zt,orphan:It},se={stackedarea:Lt,"stackedarea-invert":Lt,stackedpercent:Lt,"stackedpercent-invert":Lt,linepercent:Lt,difference:({data:t,yProp:e,yPropTop:n,yPropBottom:o})=>(t.forEach((r,s)=>{r.data.forEach((r,i)=>{const a=0===s?1:0;r[e]>t[a].data[i][e]?(r[o]=t[a].data[i][e],r[n]=r[e]):(r[n]=r[e],r[o]=r[e])})}),t),bumparea:Rt,bumpline:Rt,"bumparea-invert":Rt,line:Ft,area:Ft,cumulative:Yt,"cumulative-reverse":Yt};function ie(t,e){const n=[];for(const t of e)n.push(Object.assign({},t));for(const e of t)e.parentSummary||n.push(e);return n}exports.Annotation=wt,exports.AnnotationLayer=function(e){const{legendSettings:n,margin:o,size:r,annotations:s,annotationHandling:i}=e,a=$t(t=>t.tooltip);let l=null!=a?s.concat(a):s,c=$t(t=>t.changeTooltip);const u=Object.assign(Object.assign({},e),{annotations:l,voronoiHover:t=>{c(t)}}),h="object"==typeof i?i:{layout:{type:i},dataVersion:""},{dataVersion:d=""}=h,[p,y]=t.useState([]),[m,g]=t.useState([]),[x,b]=t.useState([]),[v,k]=t.useState(""),[E,w]=t.useState(d),M=jt(u,l),A=M.filter(t=>t.props&&t.props.noteData&&!t.props.noteData.fixedPosition),S=Nt(A,h,r);let $;if(t.useEffect(()=>{const t=M.filter(t=>!t.props||!t.props.noteData||t.props.noteData.fixedPosition),e=Tt(u,{adjustedAnnotations:p,adjustedAnnotationsKey:v,adjustedAnnotationsDataVersion:E,adjustableAnnotations:A,fixedAnnotations:t});y(e.adjustedAnnotations),k(e.adjustedAnnotationsKey),w(e.adjustedAnnotationsDataVersion),g(e.svgAnnotations),b(e.htmlAnnotations)},[S,d,l.length,l.map(t=>function(t){const e=new Set;return JSON.stringify(t,(t,n)=>e.has(n)?"...":"object"==typeof n?(e.add(n),"note"===t?`${n.label}-${n.title}`:"connector"===t?`${n.end}-${n.type}`:"subject"===t?""+n.radius:"object"==typeof n.column?`${n.column.x}-${n.column.y}-${n.column.name}`:n.voronoiX||n.voronoiY||n.x||n.y||n.dx||n.dy||n.label||n.type||n.key||n.hierarchicalID||n.id||n.name?`${n.voronoiX}-${n.voronoiY}-${n.dx}-${n.dy}-${n.x}-${n.y}-${n.label}-${n.type}-${n.key}-${n.hierarchicalID}-${n.id}-${n.name}`:"..."):n)}(t)).join("-")]),n){const t={left:[15,15],right:[r[0]+15,15]},{position:e="right",title:o="Legend"}=n;$=f.createElement("g",{transform:`translate(${t[e].join(",")})`},f.createElement(W,Object.assign({},n,{title:o,position:e})))}return 0!==l.length||n?f.createElement("div",{className:"annotation-layer",style:{position:"absolute",pointerEvents:"none",background:"none"}},f.createElement("svg",{className:"annotation-layer-svg",height:r[1],width:r[0],style:{background:"none",pointerEvents:"none",position:"absolute",left:o.left+"px",top:o.top+"px",overflow:"visible"}},f.createElement("g",null,$,m)),f.createElement("div",{className:"annotation-layer-html",style:{background:"none",pointerEvents:"none",position:"absolute",height:r[1]+"px",width:r[0]+"px",left:o.left+"px",top:o.top+"px"}},x)):null},exports.Axis=function(e){const{rotate:n,label:o,dynamicLabelPosition:r,orient:s="left",marginalSummaryType:i,tickFormat:a=(i?()=>"":xt),size:l,width:c=l&&l[0]||0,height:u=l&&l[1]||0,className:h,padding:d,tickValues:p,scale:y,ticks:m,footer:g,tickSize:x,tickLineGenerator:b,baseline:v=!0,margin:k={top:0,bottom:0,left:0,right:0},center:E=!1,annotationFunction:w,glyphFunction:M,xyPoints:A}=e,[S,$]=t.useState(0),[P,N]=t.useState(void 0),_=t.useRef(null);t.useEffect(()=>{if(!(null==o?void 0:o.position)&&r){const t=((t,e)=>{const n=t.current;if(!n)return 30;const o="left"===e||"right"===e?"width":"height";return Math.max(...[...n.querySelectorAll(".axis-label")].map(t=>t.getBBox&&t.getBBox()||{height:30,width:30}).map(t=>t[o]))+25})(_,s);t!==P&&N(t)}},[o,r]);let O,{axisParts:D,position:j=[0,0]}=e;if(D||(D=function({renderMode:t=()=>{},padding:e=5,scale:n,ticks:o,tickValues:r=ft(void 0,o,n),orient:s="left",size:i,footer:a=!1,tickSize:l=(a?-10:["top","bottom"].find(t=>t===s)?i?i[1]:0:i?i[0]:0),jaggedBase:c}){let u,h,d,f,p,y,m=[],g=0,x=0,b="middle";switch(s){case"top":u="x1",h="x2",d="y1",f="y2",m=[0,l],p="tx",y="ty",g-=20-e;break;case"bottom":u="x1",h="x2",d="y2",f="y1",m=i?[i[1],i[1]-l]:[0,-l],p="tx",y="ty",g+=20+e;break;case"right":u="y2",h="y1",d="x2",f="x1",m=i?[i[0],i[0]-l]:[0,-l],p="ty",y="tx",g+=5+e,x+=5,b="start";break;default:u="y1",h="y2",d="x1",f="x2",m=[0,l],p="ty",y="tx",g-=5+e,x+=5,b="end"}let v=r instanceof Function?r({orient:s}):r;return c&&void 0===v.find(t=>t===n.domain()[0])&&(v=[n.domain()[0],...v]),v.map((e,o)=>{const r=n(e);return{[u]:r,[h]:r,[d]:m[0],[f]:m[1],[p]:r+x,[y]:m[0]+g,defaultAnchor:b,renderMode:t(e,o),value:e}})}({padding:d,tickValues:p,scale:y,ticks:m,orient:s,size:[c,u],footer:g,tickSize:x}),O=f.createElement("g",{className:"axis "+h},(({axisParts:t,orient:e,tickLineGenerator:n=dt,className:o,jaggedBase:r,scale:s,showOutboundTickLines:i=!1})=>{const a=t.map((t,i)=>n({xy:t,orient:e,i:i,className:o,jaggedBase:r,scale:s})),l=i?t.map((t,n)=>(({xy:t,orient:e,i:n,className:o=""})=>{let r=`M-4,${t.y1}L${t.x1},${t.y2}`;return"left"===e?r=`M${t.x1-8},${t.y1}L${t.x1},${t.y2}`:"right"===e?r=`M${t.x2},${t.y1}L${t.x2+8},${t.y2}`:"top"===e?r=`M${t.x1},${t.y1-8}L${t.x1},${t.y1}`:"bottom"===e&&(r=`M${t.x1},${t.y2}L${t.x1},${t.y2+8}`),f.createElement("path",{key:n,fill:"none",stroke:"currentColor",strokeWidth:"1px",d:r,className:`outbound-tick-line tick ${e} ${o}`})})({xy:t,orient:e,i:n,className:o})):[];return[...a,l]})({axisParts:D,orient:s,tickLineGenerator:b,className:h,scale:y}))),0===D.length)return null;let T,C,z,B,W=50,L=u,F=-50,Y=0,R=0,X=0,I=0,H=u,V=25,G=-25,q=18,J=c+25,K=0,Z=S,U=0,Q="y";switch(s){case"right":j=[j[0],j[1]],F=c,I=R=c,U=k.top,J=-c-25,G=5,T=t=>{$(t.nativeEvent.offsetY-U)},!0===E&&(I=R=c/2);break;case"top":j=[j[0],0],W=c,L=50,Y=-50,F=0,U=k.left,Q="x",I=c,H=0,!0===E&&(H=X=u/2),T=t=>{$(t.nativeEvent.offsetX-U)},V=S,Z=25,G=0,q=-10,J=0,K=u+25;break;case"bottom":j=[j[0],0],W=c,L=50,X=H=Y=u,R=F=0,I=c,U=k.left,T=t=>{$(t.nativeEvent.offsetX-U)},V=S,Z=25,G=0,q=15,J=0,K=-u-25,Q="x",!0===E&&(H=X=u/2);break;default:j=[j[0],j[1]],U=k.top,!0===E&&(I=R=c/2),T=t=>{$(t.nativeEvent.offsetY-U)}}if(w){const t=function(t,e){return e.tickFormat?e.tickFormat(t):t.toString?""+t:t}(y.invert(S),e),n=M?M({lineHeight:K,lineWidth:J,value:y.invert(S)}):f.createElement("g",null,f.isValidElement(t)?f.createElement("g",{transform:`translate(${G},${q})`},t):f.createElement("text",{x:G,y:q},t),f.createElement("circle",{r:5}),f.createElement("line",{x1:J,y1:K,style:{stroke:"black"}})),o=S?f.createElement("g",{style:{pointerEvents:"none"},transform:`translate(${V},${Z})`},n):null;C=f.createElement("g",{className:"annotation-brush",transform:`translate(${F},${Y})`},f.createElement("rect",{style:{fillOpacity:0},height:L,width:W,onMouseMove:T,onClick:t=>w({className:"dynamic-axis-annotation",type:Q,value:y.invert(S),e:t}),onMouseOut:()=>{$(void 0)}}),o)}if(i&&A){const t=Math.max(k[s]-6,5),e="string"==typeof i?{type:i}:i;void 0!==e.flip||"bottom"!==s&&"right"!==s||(e.flip=!0);const n=e.summaryStyle?()=>e.summaryStyle:()=>({fill:"black",fillOpacity:.5,stroke:"black",strokeDasharray:"0"}),o=e.renderMode?()=>e.renderMode:()=>{},r=e.summaryClass?()=>e.summaryClass:()=>"",a=e.filter||(()=>!0),c=A.filter(t=>void 0!==t.x&&void 0!==t.y&&a(t.data)).map(t=>Object.assign(Object.assign({},t),{xy:{x:"top"===s||"bottom"===s?y(t.x):0,y:"left"===s||"right"===s?y(t.y):0},piece:{scaledVerticalValue:y(t.y),scaledValue:y(t.x)},value:y("top"===s||"bottom"===s?t.y:t.x),scaledValue:y(t.x),scaledVerticalValue:y(t.y)})),u=function(t){const e=[];for(const n of t){const t=[],{elements:o,containerProps:r}=n;if(n.Mark)e.push(n.Mark);else{for(let e=0;o.length>e;e++){const n=o[e],{markType:r,style:s={}}=n,i=bt(n,["markType","style"]),a=Object.assign({},i);void 0!==s.fill&&(a.fill=s.fill),void 0!==s.stroke&&(a.stroke=s.stroke),void 0!==s.strokeWidth&&(a.strokeWidth=s.strokeWidth),void 0!==s.opacity&&(a.opacity=s.opacity),void 0!==s.fillOpacity&&(a.fillOpacity=s.fillOpacity),void 0!==s.strokeOpacity&&(a.strokeOpacity=s.strokeOpacity);const l=Object.assign({},s);delete l.fill,delete l.stroke,delete l.strokeWidth,delete l.opacity,delete l.fillOpacity,delete l.strokeOpacity,Object.keys(l).length>0&&(a.style=l),a.key=n.key||e,r&&t.push(f.createElement(r,a))}r?e.push(f.createElement("g",Object.assign({},r),t)):e.push(...t)}}return e}((({data:t,type:e,renderMode:n,eventListenersGenerator:o,styleFn:r,classFn:s,projection:i,adjustedSize:a,margin:l,axisCreator:c})=>{if(e&&e.type)return function({data:t,type:e,renderMode:n,eventListenersGenerator:o,styleFn:r,classFn:s,projection:i,adjustedSize:a,chartSize:l,margin:c,axisCreator:u}){return"function"==typeof e.type?e.type({data:t,type:e,renderMode:n,eventListenersGenerator:o,styleFn:r,classFn:s,projection:i,adjustedSize:a,chartSize:l,margin:c,axisCreator:u}):(console.error(`Invalid summary type: ${e.type} - Must be a function`),{})}({data:t,type:e="string"==typeof e?{type:e}:e,renderMode:n,eventListenersGenerator:o,styleFn:r,classFn:s,projection:i,adjustedSize:a,chartSize:"vertical"===i?a[1]:a[0],margin:l,axisCreator:c})})({data:{column:{middle:t/2,pieceData:c,width:t,xyData:c}},type:e,renderMode:o,eventListenersGenerator:e.eventListenersGenerator||(()=>({})),styleFn:n,classFn:r,projection:"top"===s||"bottom"===s?"horizontal":"vertical",adjustedSize:l,margin:{top:0,bottom:0,left:0,right:0}}).marks);let h;if(!0===e.showPoints){const n=((t,e,n)=>{const o="left"===t||"right"===t?e/2:0,r="bottom"===t||"top"===t?e/2:0;return n.map(t=>[t.xy.x+o,t.xy.y+r])})(s,t,c);h=n.map((t,n)=>f.createElement("circle",{key:"axis-summary-point-"+n,cx:t[0],cy:t[1],r:e.r||3,style:e.pointStyle||{fill:"black",fillOpacity:.1}}))}z=f.createElement(mt,{translation:{left:[2-k.left,0],right:[l[0]+2,0],top:[0,2-k.top],bottom:[0,l[1]+2]},orient:s,decoratedSummaryType:e,summaryWidth:t,renderedSummary:u,points:h})}const tt=(({axisParts:t,tickFormat:e,rotate:n=0,center:o=!1,orient:r})=>{const s=t.map((t,n)=>({axisPart:t,i:n,formatted:e(t.value,n)})),i="left"===r||"right"===r;let a=s;if(!n&&s.length>1){const t=8,e=14,n=8,o=t=>"string"==typeof t?t:"number"==typeof t?t+"":null;if("top"===r||"bottom"===r){const e=[...s].sort((t,e)=>t.axisPart.tx-e.axisPart.tx);let r=-1/0;const i=new Set;for(const s of e){const e=o(s.formatted);if(!e){i.add(s.i);continue}const a=e.length*t/2;r+n>s.axisPart.tx-a||(i.add(s.i),r=s.axisPart.tx+a)}a=s.filter(t=>i.has(t.i))}else if(i){const t=[...s].sort((t,e)=>t.axisPart.ty-e.axisPart.ty);let o=-1/0;const r=new Set;for(const s of t)o+e+n>s.axisPart.ty||(r.add(s.i),o=s.axisPart.ty);a=s.filter(t=>r.has(t.i))}}return a.map(({axisPart:t,i:e,formatted:s})=>{("object"!=typeof s||s instanceof Date)&&(s=f.createElement("text",{textAnchor:t.defaultAnchor,className:"axis-label"},s.toString?""+s:s));let i=t.tx,a=t.ty;if(o)switch(r){case"right":i-=(t.x2-t.x1)/2;break;case"left":i+=(t.x2-t.x1)/2;break;case"top":a+=(t.y2-t.y1)/2;break;case"bottom":a-=(t.y2-t.y1)/2}return f.createElement("g",{key:e,pointerEvents:"none",transform:`translate(${i},${a}) rotate(${n})`,className:"axis-label"},s)})})({tickFormat:a,axisParts:D,orient:s,rotate:n,center:E});if(o){const t=o.name||o,e=o.position||{};let n=e.anchor||"middle";const r=o.locationDistance||P,i=e.rotation||{left:-90,right:90,top:0,bottom:0}[s],a={left:{start:[0,l[1]],middle:[0,l[1]/2],end:[0,0],inside:[r||15,0],outside:[-(r||45),0]},right:{start:[l[0]+0,l[1]],middle:[l[0]+0,l[1]/2],end:[l[0]+0,0],inside:[-(r||15),0],outside:[r||45,0]},top:{start:[0,0],middle:[0+l[0]/2,0],end:[0+l[0],0],inside:[0,r||15],outside:[0,-(r||40)]},bottom:{start:[0,l[1]],middle:[0+l[0]/2,l[1]],end:[0+l[0],l[1]],inside:[0,-(r||5)],outside:[0,r||50]}},c=a[s][n],u=a[s][e.location||"outside"];c[0]=c[0]+u[0],c[1]=c[1]+u[1],"start"===n&&"right"===s?n="end":"end"===n&&"right"===s&&(n="start"),B=f.createElement(gt,{className:h,translation:c,position:j,rotation:i,labelName:t,anchorMod:n})}const et=`${s} axis ${D&&D.length>0&&`from ${a(D[0].value,0)} to ${a(D[D.length-1].value,D.length-1)}`||"without ticks"}`;return f.createElement("g",{className:h,"aria-label":et,ref:_},C,tt,O,!0===v?f.createElement("line",{key:"baseline",className:"axis-baseline "+h,stroke:"black",strokeLinecap:"square",x1:R,x2:I,y1:X,y2:H}):null,B,z)},exports.Brush=function(e){const{extent:o,selectedExtent:r}=e,s=t.useRef(null),i=zt(o),a=zt(r);t.useEffect(()=>{(null==s?void 0:s.current)&&((t,e)=>{const{svgBrush:o,selectedExtent:r}=e;if(n.select(t).call(o),r){let e=r;if(Array.isArray(r[0])){const t=[e[0][1],e[1][1]].sort((t,e)=>t-e);e=[[e[0][0],t[0]],[e[1][0],t[1]]]}n.select(t).call(o.move,e)}})(s.current,e)},[i,a,s]);const{position:l=[0,0]}=e;return f.createElement("g",{transform:`translate(${l})`,ref:s,className:"xybrush"})},exports.DividedLine=function(t){const e=(t=>{const{parameters:e,className:n,interpolate:o=a.curveLinear,customAccessors:r,lineDataAccessor:s,data:i,searchIterations:l}=t,c=bt(t,["parameters","className","interpolate","customAccessors","lineDataAccessor","data","searchIterations"]),{x:u,y:h}=r,d=Wt({data:i,lineDataAccessor:[s],xProp:"x",yProp:"y",xAccessor:[u],yAccessor:[h]});for(const t of d)t.data=t.data.map(t=>Object.assign(Object.assign({},t.data),t));const p=((t,e,n=10)=>{let o=t(e[0],0),r=[];const s=[{key:o,points:r}];return e.forEach((e,i)=>{const a=t(e,i);let l=a===o;const c=JSON.stringify(a),u=JSON.stringify(o);if("object"==typeof o&&(l=c===u),l)r.push(e);else{let i=r[r.length-1],l=e,u=c,h=0;for(;n>h&&c===u;){const e=Xt({pointA:i,pointB:l,currentParameters:o,parameters:t,keys:Object.keys(i)});i=e[0],l=e[1],u=JSON.stringify(t(l)),h++}r.push(l),r=[l,e],s.push({key:a,points:r}),o=a}}),s})(e,d[0].data,l),y=a.line().curve(o).x(t=>t.x).y(t=>t.y);return p.map((t,e)=>f.createElement("path",Object.assign({},c,{className:n,key:"DividedLine-"+e,style:t.key,d:y(t.points)})))})(t);return f.createElement("g",null,e)},exports.Legend=W,exports.MinimapChart=ht,exports.StreamXYFrame=tt,exports.calculateDataExtent=({lineDataAccessor:t,xAccessor:e,yAccessor:n,summaries:r,points:s,lines:i,lineType:l,showLinePoints:u,showSummaryPoints:h,xExtent:d,yExtent:f,invertX:p,invertY:m,summaryDataAccessor:g,summaryType:x,adjustedSize:b,margin:v,summaryStyleFn:k,summaryClassFn:E,summaryRenderModeFn:w,chartSize:M,filterRenderedLines:A,filterRenderedSummaries:S,filterRenderedPoints:$,defined:P=ne,annotations:N=[]})=>{let _=[],O=[],D=[],j=[],T=[];if(s){e.forEach((t,e)=>{n.forEach((n,o)=>{let r=0;for(const i of s){const s=t(i,r),a=n(i,r),l={x:s,y:a,data:i,xIndex:e,yIndex:o};Array.isArray(a)&&(l[qt]=Math.min(...a),l[Gt]=Math.max(...a),l[Vt]=(l[qt]+l[Gt])/2),Array.isArray(s)&&(l[Zt]=Math.min(...s),l[Kt]=Math.max(...s),l[Jt]=(l[Zt]+l[Kt])/2),D.push(l),r++}})});for(const t of D)_.push(Object.assign(Object.assign({},t),{[It]:t[Kt]||t[Zt]||t.x,[Ht]:t[Gt]||t[qt]||t.y}))}if(i){O=Wt({data:i,lineDataAccessor:t,xProp:It,xPropTop:Kt,xPropBottom:Zt,yProp:Ht,yPropTop:Gt,yPropBottom:qt,xAccessor:e,yAccessor:n}),j=function(t,e){return n=>se[((t,e)=>!se[t]||"difference"===t&&2!==e.length?"line":t)(t.type,n)](Object.assign(Object.assign(Object.assign({},t),e),{data:n}))}(l,{xProp:It,yProp:Ht,yPropMiddle:Vt,yPropTop:Gt,yPropBottom:qt,xPropMiddle:Jt,xPropTop:Kt,xPropBottom:Zt})(O);for(const t of j)for(let e=0;t.data.length>e;e++){const n=t.data[e];if(!P(Object.assign({},n.data,n),e))continue;const o={parentLine:t,y:n.y,x:n.x,xTop:n.xTop,xMiddle:n.xMiddle,xBottom:n.xBottom,yTop:n.yTop,yMiddle:n.yMiddle,yBottom:n.yBottom,data:n.data};n.percent&&(o.percent=n.percent),_.push(o)}if(u){const t=!0===u?Jt:re[u],e=!0===u?Vt:oe[u];j.forEach(n=>{n.data.filter((t,e)=>{if(P(Object.assign({},t.data,t))){if("orphan"===u){const t=n.data[e-1],o=n.data[e+1];return!(t&&P(Object.assign({},t.data,t))||o&&P(Object.assign({},o.data,o)))}return!0}return!1}).forEach(o=>{D.push(Object.assign(Object.assign({},o),{parentLine:n,[Ht]:void 0!==o[e]?o[e]:void 0!==o[Vt]?o[Vt]:void 0!==o[qt]?o[qt]:o.y,[It]:void 0!==o[t]?o[t]:void 0!==o[Jt]?o[Jt]:void 0!==o[Zt]?o[Zt]:o.y}))})})}}r&&(T=(({data:t,summaryDataAccessor:e,xAccessor:n,yAccessor:o})=>{const r=[];return e.forEach(e=>{n.forEach(n=>{o.forEach(o=>{const s=t=>e(t).map((t,e)=>[n(t,e),o(t,e)]);t.forEach(t=>{r.push(Object.assign(Object.assign({},t),{_baseData:e(t),_xyfCoordinates:s(t)}))})})})}),r})({data:r,summaryDataAccessor:g,xAccessor:e,yAccessor:n}),T.forEach(t=>{const e=t._baseData;t._xyfCoordinates.length>0&&t._xyfCoordinates[0][0][0]?t._xyfCoordinates[0].forEach(n=>{Array.isArray(n)&&n.map((n,o)=>Object.assign({parentSummary:t},e[o],{[It]:n[0],[Ht]:n[1]})).forEach(t=>{h&&D.push(Object.assign(Object.assign({x:0},t),{[Ht]:t[Gt]||t[qt]||t[Ht]})),_.push(Object.assign({x:0,y:0},t))})}):t._xyfCoordinates.length>0&&Array.isArray(t._xyfCoordinates)&&t._xyfCoordinates.map((n,o)=>Object.assign(Object.assign({parentSummary:t},e[o]),{[It]:n[0],[Ht]:n[1]})).forEach(t=>{h&&D.push(Object.assign(Object.assign({x:0},t),{[Ht]:t[Gt]||t[qt]||t[Ht]})),_.push(Object.assign({x:0,y:0},t))})}));let C,z,B,W,L=[],F=[];d&&!Array.isArray(d)&&!0===d.includeAnnotations&&e.forEach(t=>{N.forEach((e,n)=>{const o=t(e,n);isFinite(o)&&L.push({[It]:o})})}),f&&!Array.isArray(f)&&!0===f.includeAnnotations&&n.forEach(t=>{N.forEach((e,n)=>{const o=t(e,n);isFinite(o)&&F.push({[Ht]:o})})});for(const t of _){const e=void 0===t[Zt]?t[It]:Math.min(t[Kt],t[Zt]),n=void 0===t[Kt]?t[It]:Math.max(t[Zt],t[Kt]),o=void 0===t[qt]?t[Ht]:Math.min(t[Gt],t[qt]),r=void 0===t[Gt]?t[Ht]:Math.max(t[qt],t[Gt]);void 0===e||void 0!==C&&e>=C||(C=e),void 0===n||void 0!==z&&z>=n||(z=n),void 0===o||void 0!==B&&o>=B||(B=o),void 0===r||void 0!==W&&W>=r||(W=r)}for(const t of L){const e=t[It];void 0===e||void 0!==C&&e>=C||(C=e),void 0===e||void 0!==z&&z>=e||(z=e)}for(const t of F){const e=t[Ht];void 0===e||void 0!==B&&e>=B||(B=e),void 0===e||void 0!==W&&W>=e||(W=e)}const Y=[C,z],R=[B,W],X=ee(d),I=ee(f);let H=[I&&void 0!==I[0]?I[0]:R[0],I&&void 0!==I[1]?I[1]:R[1]],V=[X&&void 0!==X[0]?X[0]:Y[0],X&&void 0!==X[1]?X[1]:Y[1]];if(!p||X&&2===X.length||(V=[V[1],V[0]]),"bumpline"!==l.type&&!m||I&&2===I.length||(H=[H[1],H[0]]),x.type&&"contour"===x.type)T=function({summaryType:t,data:e,finalXExtent:n,finalYExtent:r}){let s=[];t.type||(t={type:t});const{resolution:i=500,thresholds:a=10,bandwidth:l=20,neighborhood:u}=t,h=o.scaleLinear().domain(n).rangeRound([0,i]).nice(),d=o.scaleLinear().domain(r).rangeRound([i,0]).nice();return e.forEach(t=>{let e=c.contourDensity().size([i,i]).x(t=>h(t[0])).y(t=>d(t[1])).thresholds(a).bandwidth(l)(t._xyfCoordinates);u&&(e=[e[0]]);const n=Math.max(...e.map(t=>t.value));e.forEach(e=>{e.parentSummary=t,e.bounds=[],e.percent=e.value/n,e.coordinates.forEach(t=>{t.forEach((n,o)=>{t[o]=n.map(t=>[h.invert(t[0]),d.invert(t[1])]),0===o&&e.bounds.push(function(t){let e=[1/0,0],n=[-1/0,0],o=[0,1/0],r=[0,-1/0];return t.forEach(t=>{e=e[0]>t[0]?t:e,n=t[0]>n[0]?t:n,r=t[1]>r[1]?t:r,o=o[1]>t[1]?t:o}),{center:[(e[0]+n[0])/2,(o[1]+r[1])/2],top:o,left:e,right:n,bottom:r}}(t[o]))})})}),s=[...s,...e]}),s}({summaryType:x,data:T,finalXExtent:V,finalYExtent:H});else if(x.type&&"linebounds"===x.type){if(T=function({summaryType:t,data:e,defined:n}){let o=[];t.type||(t={type:t});const{boundingAccessor:r,topBoundingAccessor:s=r,bottomBoundingAccessor:i=r}=t;return e.forEach(t=>{const e=t._baseData.map(n);let r=[],a=[];const l=[{xyf:a,base:r}];e.forEach((n,o)=>{!0===n?(r.push(t._baseData[o]),a.push(t._xyfCoordinates[o])):e[o+1]&&(r=[],a=[],l.push({xyf:a,base:r}))}),l.forEach(({xyf:e,base:n})=>{const r={data:t,parentSummary:t,_xyfCoordinates:Qt(e,n,s,i)};o=[...o,r]})}),o}({summaryType:x,data:T,defined:P}),!I||2!==I.length)for(const t of T)for(const e of t._xyfCoordinates){const t=e[1];void 0!==t&&isFinite(t)&&(H[0]>t&&(H[0]=t),t>H[1]&&(H[1]=t))}}else x.type&&"hexbin"===x.type?(T=Ut({summaryType:x,data:T[0],processedData:r&&!!r[0].processedData,preprocess:!1,finalXExtent:V,finalYExtent:H,size:b,margin:v,styleFn:k,classFn:E,renderFn:w,chartSize:M}),_=ie(_,T)):x.type&&"heatmap"===x.type?(T=te({summaryType:x,data:T[0],processedData:r&&!!r[0].processedData,preprocess:!1,finalXExtent:V,finalYExtent:H,size:b,margin:v,styleFn:k,classFn:E,renderFn:w,chartSize:M}),_=ie(_,T)):x.type&&"trendline"===x.type&&(T=function({preprocess:t=!1,summaryType:e,data:n,finalXExtent:r=[Math.min(...n.coordinates.map(t=>t.x)),Math.max(...n.coordinates.map(t=>t.x))],xScaleType:s=o.scaleLinear()}){if(t)return n[0].coordinates;let i,l=[];i=e.type?e:{type:i};const{regressionType:c="linear",order:u=2,precision:h=4,controlPoints:d=20,curve:f=a.curveCardinal}=i;let p=c;r[0]>=0||"logarithmic"!==c&&"power"!==c&&"exponential"!==c||(console.error(`Cannot use this ${c} regressionType type with value range that goes below 0, defaulting to linear`),p="linear"),n.coordinates&&!n._xyfCoordinates&&(n._xyfCoordinates=n.coordinates.map(t=>[t.x,t.y]));const m=Array.isArray(n)?n:[n],g=s.domain([0,1]).range(r);return l=[],m.forEach(t=>{const e=y.default[p](t._xyfCoordinates.map(t=>{let e=t[0],n=t[1];return"number"!=typeof e&&(e=e.getTime()),"number"!=typeof n&&(n=n.getTime()),[e,n]}),{order:u,precision:h}),n=1/d;let o=[0,1];if("linear"!==p){o=[];for(let t=0;1+n>t;t+=n)o.push(t)}const r=[];o.forEach(t=>{r.push(e.predict(g(t)))}),l.push({centroid:!1,customMark:void 0,data:t,parentSummary:t,value:e.string,r2:e.r2,curve:f,_xyfCoordinates:r})}),l}({summaryType:x,data:T[0],preprocess:r&&!!r[0].processedData,finalXExtent:V}),_=ie(_,T));return A&&(j=j.filter(A),_=_.filter((t,e)=>!t.parentLine||A(t.parentLine,e,[]))),$&&(_=_.filter($)),S&&(T=T.filter(S),_=_.filter((t,e)=>!t.parentSummary||S(t.parentSummary,e,[]))),{xExtent:V,yExtent:H,projectedLines:j,projectedPoints:D,projectedSummaries:T,fullDataset:_,calculatedXExtent:Y,calculatedYExtent:R}},exports.funnelize=function({data:t,steps:e,key:n}){const o=[];return Array.isArray(t)||(t=[t]),e||(e=t.map(t=>Object.keys(t)).reduce((t,e)=>t.concat(e),[])),t.forEach((t,r)=>{const s=n?t[n]:r;e.forEach(e=>{const n={funnelKey:s,stepName:"",stepValue:0};n.stepName=e,n.stepValue=t[e]?t[e]:0,o.push(n)})}),o},exports.heatmapping=te,exports.hexbinning=Ut;
|