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
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import*as t from"react";import{useMemo as e,forwardRef as n,useRef as i,useState as o,useCallback as r,useEffect as s,useImperativeHandle as l,createContext as a,useContext as c,useLayoutEffect as u,useId as h}from"react";import{brushX as d,brushY as f,brush as y}from"d3-brush";import{select as g}from"d3-selection";import{scaleLinear as p}from"d3-scale";import{bin as m,min as v,max as x}from"d3-array";import{interpolateNumber as b}from"d3-interpolate";import{sankeyCircular as k,sankeyJustify as w,sankeyCenter as A,sankeyRight as E,sankeyLeft as S}from"d3-sankey-circular";import{schemeCategory10 as M}from"d3-scale-chromatic";import{line as _,curveLinearClosed as W,arc as N}from"d3-shape";import{forceLink as P,forceSimulation as z,forceManyBody as T,forceX as $,forceY as O}from"d3-force";import{ribbon as D,chord as C}from"d3-chord";import{hierarchy as Y,partition as B,pack as L,treemap as F,treemapBinary as X,cluster as R,tree as j}from"d3-hierarchy";const I=5e3;class H{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,I),bounded:!0,totalSize:t.length});let e=I;const n=()=>{if(e>=t.length)return;if(t!==this.lastBoundedData)return;const i=Math.min(e+I,t.length);this.callback({inserts:t.slice(e,i),bounded:!1}),e=i,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 G{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 V{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 q(t,e,n,i,o){const r=new Map;for(const s of t){const t=e(s),l=n(s);if(null==t||null==l||Number.isNaN(t)||Number.isNaN(l))continue;const a=Math.floor(t/i)*i;let c=r.get(a);if(c||(c={start:a,end:a+i,total:0,categories:new Map},r.set(a,c)),c.total+=l,o){const t=o(s);c.categories.set(t,(c.categories.get(t)||0)+l)}}return r}function Z(t,e,n,i,o,r){const s=[],l=[];for(const o of t){const t=n(o),r=i(o);null==t||null==r||Number.isNaN(t)||Number.isNaN(r)||(s.push([e.x(t),e.y(r)]),l.push(r))}return{type:"line",path:s,rawValues:l,style:o,datum:t,group:r}}function K(t,e,n,i,o,r,s){const l=[],a=[];for(const r of t){const t=n(r),s=i(r);if(null==t||null==s||Number.isNaN(t)||Number.isNaN(s))continue;const c=e.x(t);l.push([c,e.y(s)]),a.push([c,e.y(o)])}return{type:"area",topPath:l,bottomPath:a,style:r,datum:t,group:s}}function Q(t,e,n,i,o,r){const s=n(t),l=i(t);return null==s||null==l||Number.isNaN(s)||Number.isNaN(l)?null:{type:"point",x:e.x(s),y:e.y(l),r:o,style:r,datum:t}}function U(t,e,n,i,o,r,s){return{type:"rect",x:t,y:e,w:n,h:i,style:o,datum:r,group:s}}function J(t,e,n,i,o,r){return{type:"heatcell",x:t,y:e,w:n,h:i,fill:o,datum:r}}function tt(t,e){if("function"==typeof t)return e=>+t(e);const n=t||e;return t=>+t[n]}function et(t,e){return"function"==typeof t?t:t?e=>e[t]+"":void 0}class nt{constructor(t){this.xExtent=new V,this.yExtent=new V,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 G(t.windowSize),this.growingCap=t.windowSize,["bar","swarm","waterfall"].includes(t.chartType)||"streaming"===t.runtimeMode?(this.getX=tt(t.timeAccessor||t.xAccessor,"time"),this.getY=tt(t.valueAccessor||t.yAccessor,"value")):(this.getX=tt(t.xAccessor,"x"),this.getY=tt(t.yAccessor,"y")),this.getGroup=et(t.groupAccessor),this.getCategory=et(t.categoryAccessor),this.getSize=t.sizeAccessor?tt(t.sizeAccessor,"size"):void 0,this.getColor=et(t.colorAccessor),this.getBounds=t.boundsAccessor?tt(t.boundsAccessor,"bounds"):void 0,"candlestick"===t.chartType&&(this.getOpen=tt(t.openAccessor,"open"),this.getHigh=tt(t.highAccessor,"high"),this.getLow=tt(t.lowAccessor,"low"),this.getClose=tt(t.closeAccessor,"close")),t.pulse&&(this.timestampBuffer=new G(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,i,o,r,s;const{config:l,buffer:a}=this;if(this.xExtent.dirty&&this.xExtent.recalculate(a,this.getX),this.yExtent.dirty)if("candlestick"===l.chartType&&this.getHigh&&this.getLow){this.yExtent.clear();for(const t of a)this.yExtent.push(this.getHigh(t)),this.yExtent.push(this.getLow(t))}else this.yExtent.recalculate(a,this.getY);const c=this.xExtent.extent,u=this.yExtent.extent;let h=l.xExtent?[null!==(e=l.xExtent[0])&&void 0!==e?e:c[0],null!==(n=l.xExtent[1])&&void 0!==n?n:c[1]]:c,d=l.yExtent?[null!==(i=l.yExtent[0])&&void 0!==i?i:u[0],null!==(o=l.yExtent[1])&&void 0!==o?o:u[1]]:u;const f=l.yExtent&&null!=l.yExtent[0]&&null!=l.yExtent[1];if("stackedarea"===l.chartType&&!f&&a.size>0)if(l.normalize)d=[0,1+l.extentPadding];else{const t=a.toArray(),e=this.groupData(t),n=new Map;for(const t of e)for(const e of t.data){const t=this.getX(e),i=this.getY(e);null==t||null==i||Number.isNaN(t)||Number.isNaN(i)||n.set(t,(n.get(t)||0)+i)}let i=0;for(const t of n.values())t>i&&(i=t);d=[0,i+(i>0?i*l.extentPadding:1)]}else if("bar"===l.chartType&&l.binSize&&!f&&a.size>0){const[,t]=function(t,e,n,i,o){const r=q(t,e,n,i,o);if(0===r.size)return[0,0];let s=0;for(const t of r.values())t.total>s&&(s=t.total);return[0,s]}(a,this.getX,this.getY,l.binSize,this.getCategory);d=[0,t+t*l.extentPadding]}else if("waterfall"===l.chartType&&!f&&a.size>0){const[t,e]=function(t,e){let n=0,i=0,o=0;for(const r of t){const t=e(r);null==t||Number.isNaN(t)||(o+=t,n>o&&(n=o),o>i&&(i=o))}return[n,i]}(a,this.getY),n=e-t,i=n>0?n*l.extentPadding:1;d=[Math.min(0,t-Math.abs(i)),Math.max(0,e+Math.abs(i))]}else if(!f&&d[0]!==1/0){if(this.getBounds){const t=a.toArray();for(const e of t){const t=this.getY(e),n=this.getBounds(e);null!=t&&!Number.isNaN(t)&&n&&(t+n>d[1]&&(d[1]=t+n),d[0]>t-n&&(d[0]=t-n))}}const t=d[1]-d[0],e=t>0?t*l.extentPadding:1,n=null===(r=l.yExtent)||void 0===r?void 0:r[0],i=null===(s=l.yExtent)||void 0===s?void 0:s[1];d=[null!=n?d[0]:d[0]-e,null!=i?d[1]:d[1]+e]}if(h[0]!==1/0&&h[1]!==-1/0||(h=[0,1]),d[0]!==1/0&&d[1]!==-1/0||(d=[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:p().domain(h).range(e),y:p().domain(d).range([t.height,0])}}else{const e="down"===l.arrowOfTime?[0,t.height]:[t.height,0];this.scales={x:p().domain(d).range([0,t.width]),y:p().domain(h).range(e)}}else this.scales={x:p().domain(h).range([0,t.width]),y:p().domain(d).range([t.height,0])};var y;this.config.transition&&this.scene.length>0&&this.snapshotPositions();const g=a.toArray();this.scene=this.buildSceneNodes(t),this.config.decay&&this.applyDecay(this.scene,g),this.config.pulse&&this.applyPulse(this.scene,g),this.config.transition&&this.prevPositionMap.size>0&&this.startTransition(),this.version++}buildSceneNodes(t){const{config:e,buffer:n,scales:i}=this;if(!i||0===n.size)return[];const o=n.toArray();switch(e.chartType){case"line":return this.buildLineScene(o);case"area":return this.buildAreaScene(o);case"stackedarea":return this.buildStackedAreaScene(o);case"scatter":case"bubble":return this.buildPointScene(o);case"heatmap":return this.buildHeatmapScene(o,t);case"bar":return this.buildBarScene(o);case"swarm":return this.buildSwarmScene(o);case"waterfall":return this.buildWaterfallScene(o,t);case"candlestick":return this.buildCandlestickScene(o,t);default:return[]}}buildLineScene(t){var e;const n=this.groupData(t),i=[],o=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&&i.push(e)}for(const t of n){const e=this.resolveLineStyle(t.key,t.data[0]),n=Z(t.data,this.scales,this.getX,this.getY,e,t.key);o&&o.length>0&&(n.colorThresholds=o),i.push(n)}return i}buildAreaScene(t){const e=this.groupData(t),n=[],i=this.scales.y.domain()[0];for(const t of e){const e=this.resolveAreaStyle(t.key,t.data[0]);n.push(K(t.data,this.scales,this.getX,this.getY,i,e,t.key))}return n}buildStackedAreaScene(t){return function(t,e,n,i,o,r){var s;const l=new Set;for(const e of t)for(const t of e.data){const e=n(t);null==e||Number.isNaN(e)||l.add(e)}const a=Array.from(l).sort((t,e)=>t-e),c=new Map;for(const e of t){const t=new Map;for(const o of e.data){const e=n(o),r=i(o);null==e||null==r||Number.isNaN(e)||Number.isNaN(r)||t.set(e,(t.get(e)||0)+r)}c.set(e.key,t)}let u;if(r){u=new Map;for(const e of a){let n=0;for(const i of t)n+=(null===(s=c.get(i.key))||void 0===s?void 0:s.get(e))||0;u.set(e,n||1)}}const h=[],d=new Map;for(const t of a)d.set(t,0);for(const n of t){const t=c.get(n.key),i=[],s=[];for(const n of a){let o=t.get(n)||0;const l=d.get(n);r&&(o/=u.get(n));const a=e.x(n);s.push([a,e.y(l)]),i.push([a,e.y(l+o)]),d.set(n,l+o)}h.push({type:"area",topPath:i,bottomPath:s,style:o(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,i=this.config.sizeRange||[3,15];let o=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);o=e=>t===n?(i[0]+i[1])/2:i[0]+(e-t)/(n-t)*(i[1]-i[0])}}let r=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"];r=new Map;let i=0;for(const t of e)r.set(t,n[i%n.length]),i++}for(const i of t){let t=this.config.pointStyle?this.config.pointStyle(i):{fill:"#4e79a7",opacity:.8},s=t.r||n;if(o&&this.getSize){const t=this.getSize(i);null==t||Number.isNaN(t)||(s=o(t))}if(r&&this.getColor){const e=this.getColor(i);e&&r.has(e)&&(t=Object.assign(Object.assign({},t),{fill:r.get(e)}))}const l=Q(i,this.scales,this.getX,this.getY,s,t);l&&e.push(l)}return e}buildHeatmapScene(t,e){const n=[];if(this.config.heatmapAggregation)return this.buildStreamingHeatmapScene(t,e);const i=tt(this.config.valueAccessor,"value"),o=new Set,r=new Set;for(const e of t)o.add(this.getX(e)),r.add(this.getY(e));const s=Array.from(o).sort((t,e)=>t-e),l=Array.from(r).sort((t,e)=>t-e);if(0===s.length||0===l.length)return n;const a=e.width/s.length,c=e.height/l.length,u=new Map;for(const e of t){const t=`${this.getX(e)}_${this.getY(e)}`;u.set(t,{val:i(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;s.length>t;t++)for(let e=0;l.length>e;e++){const i=u.get(`${s[t]}_${l[e]}`);if(!i)continue;const o=(i.val-h)/f;n.push(J(t*a,(l.length-1-e)*c,a,c,`rgb(${Math.round(220-180*o)},${Math.round(220-100*o)},${Math.round(255-50*o)})`,i.datum))}return n}buildStreamingHeatmapScene(t,e){var n,i,o;const r=[],s=null!==(n=this.config.heatmapXBins)&&void 0!==n?n:20,l=null!==(i=this.config.heatmapYBins)&&void 0!==i?i:20,a=null!==(o=this.config.heatmapAggregation)&&void 0!==o?o:"count",c=tt(this.config.valueAccessor,"value");if(!this.scales||0===t.length)return r;const[u,h]=this.scales.x.domain(),[d,f]=this.scales.y.domain(),y=(h-u||1)/s,g=(f-d||1)/l,p=new Map;for(const e of t){const t=this.getX(e),n=this.getY(e),i=Math.min(Math.floor((t-u)/y),s-1),o=Math.min(Math.floor((n-d)/g),l-1);if(0>i||0>o)continue;const r=`${i}_${o}`;let a=p.get(r);a||(a={sum:0,count:0,data:[]},p.set(r,a)),a.count++,a.sum+=c(e),a.data.push(e)}let m=1/0,v=-1/0;const x=new Map;for(const[t,e]of p){let n;switch(a){case"sum":n=e.sum;break;case"mean":n=e.count>0?e.sum/e.count:0;break;default:n=e.count}x.set(t,n),m>n&&(m=n),n>v&&(v=n)}const b=v-m||1,k=e.width/s,w=e.height/l;for(const[t,e]of x){const[n,i]=t.split("_"),o=+n,s=+i,a=(e-m)/b,c=`rgb(${Math.round(220-180*a)},${Math.round(220-100*a)},${Math.round(255-50*a)})`,u=p.get(t);r.push(J(o*k,(l-1-s)*w,k,w,c,{xi:o,yi:s,value:e,count:u.count,sum:u.sum,data:u.data}))}return r}buildBarScene(t){var e;if(!this.config.binSize)return[];const n=q(t,this.getX,this.getY,this.config.binSize,this.getCategory);if(0===n.size)return[];let i=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):[],o=new Set(e),r=Array.from(t).filter(t=>!o.has(t)).sort();i=[...e.filter(e=>t.has(e)),...r]}const o=[],r=this.scales,[s,l]=r.x.domain();for(const t of n.values()){const n=Math.max(t.start,s),a=Math.min(t.end,l);if(n>=a)continue;const c=r.x(n),u=r.x(a),h=Math.min(c,u)+.5,d=Math.max(c,u)-.5-h;if(d>0)if(i&&t.categories.size>0){let n=0;for(const s of i){const i=t.categories.get(s)||0;if(0===i)continue;const l=r.y(n),a=r.y(n+i);o.push(U(h,Math.min(l,a),d,Math.abs(l-a),{fill:(null===(e=this.config.barColors)||void 0===e?void 0:e[s])||"#4e79a7"},{binStart:t.start,binEnd:t.end,total:t.total,category:s,categoryValue:i},s)),n+=i}}else{const e=r.y(0),n=r.y(t.total);o.push(U(h,Math.min(e,n),d,Math.abs(e-n),{fill:"#007bff"},{binStart:t.start,binEnd:t.end,total:t.total}))}}return o}buildSwarmScene(t){var e,n,i,o;const r=[],s=this.config.swarmStyle||{},l=null!==(e=s.radius)&&void 0!==e?e:3,a=null!==(n=s.fill)&&void 0!==n?n:"#007bff",c=null!==(i=s.opacity)&&void 0!==i?i:.7,u=s.stroke,h=s.strokeWidth;for(const e of t){const t=this.getX(e),n=this.getY(e);if(null==n||Number.isNaN(n))continue;const i=this.scales.x(t),s=this.scales.y(n);let d=a;if(this.getCategory){const t=this.getCategory(e);d=(null===(o=this.config.barColors)||void 0===o?void 0:o[t])||d}r.push({type:"point",x:i,y:s,r:l,style:{fill:d,opacity:c,stroke:u,strokeWidth:h},datum:e})}return r}buildWaterfallScene(t,e){const n=[],i=this.scales,o=t.filter(t=>{const e=this.getY(t);return null!=e&&!Number.isNaN(e)});if(0===o.length)return n;let r=0;for(let t=0;o.length>t;t++){const s=o[t],l=this.getX(s),a=this.getY(s),c=r+a;let u;u=o.length-1>t?this.getX(o[t+1])-l:t>0?l-this.getX(o[t-1]):0;const h=i.x(l),d=0!==u?i.x(l+u):h+e.width/10,f=Math.min(h,d)+.5,y=Math.max(h,d)-.5-f;if(0>=y){r=c;continue}const g=i.y(r),p=i.y(c);n.push(U(f,Math.min(g,p),y,Math.abs(g-p),{fill:0>a?"#dc3545":"#28a745"},Object.assign(Object.assign({},s),{baseline:r,cumEnd:c,delta:a}))),r=c}return n}buildCandlestickScene(t,e){if(!(this.getOpen&&this.getHigh&&this.getLow&&this.getClose&&this.scales))return[];const n=[],i=this.config.candlestickStyle||{},o=i.upColor||"#28a745",r=i.downColor||"#dc3545",s=i.wickColor||"#333",l=i.wickWidth||1,a=t.map(t=>this.getX(t)).filter(t=>null!=t&&!Number.isNaN(t)).sort((t,e)=>t-e);let c=i.bodyWidth||6;if(!i.bodyWidth&&a.length>1){let t=1/0;for(let e=1;a.length>e;e++){const n=Math.abs(this.scales.x(a[e])-this.scales.x(a[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 i=this.getOpen(e),a=this.getHigh(e),u=this.getLow(e),h=this.getClose(e);if([i,a,u,h].some(t=>null==t||Number.isNaN(t)))continue;const d=h>=i;n.push({type:"candlestick",x:this.scales.x(t),openY:this.scales.y(i),closeY:this.scales.y(h),highY:this.scales.y(a),lowY:this.scales.y(u),bodyWidth:c,upColor:o,downColor:r,wickColor:s,wickWidth:l,isUp:d,datum:e})}return n}buildBoundsForGroup(t,e){if(!this.getBounds||!this.scales)return null;const n=[],i=[];for(const e of t){const t=this.getX(e),o=this.getY(e);if(null==t||null==o||Number.isNaN(t)||Number.isNaN(o))continue;const r=this.getBounds(e),s=this.scales.x(t);if(r&&0!==r)n.push([s,this.scales.y(o+r)]),i.push([s,this.scales.y(o-r)]);else{const t=this.scales.y(o);n.push([s,t]),i.push([s,t])}}return 2>n.length?null:{type:"area",topPath:n,bottomPath:i,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,i,o;const r=this.config.decay;if(!r||1>=e)return 1;const s=null!==(n=r.minOpacity)&&void 0!==n?n:.1,l=e-1-t;switch(r.type){case"linear":return s+(1-l/(e-1))*(1-s);case"exponential":{const t=null!==(i=r.halfLife)&&void 0!==i?i:e/2;return s+Math.pow(.5,l/t)*(1-s)}case"step":return(null!==(o=r.stepThreshold)&&void 0!==o?o:.5*e)>l?1:s;default:return 1}}applyDecay(t,e){var n,i;if(!this.config.decay)return;const o=e.length;if(1>=o)return;const r=new Map;for(let t=0;e.length>t;t++)r.set(e[t],t);for(const e of t){if("line"===e.type||"area"===e.type)continue;const t=r.get(e.datum);if(null==t)continue;const s=this.computeDecayOpacity(t,o);if("heatcell"===e.type)e.style={opacity:s};else if("candlestick"===e.type)e._decayOpacity=s;else{const t=null!==(i=null===(n=e.style)||void 0===n?void 0:n.opacity)&&void 0!==i?i:1;e.style=Object.assign(Object.assign({},e.style),{opacity:t*s})}}}computePulseIntensity(t,e){var n;const i=this.config.pulse;if(!i)return 0;const o=null!==(n=i.duration)&&void 0!==n?n:500,r=e-t;return o>r?1-r/o:0}applyPulse(t,e){var n;if(!this.config.pulse||!this.timestampBuffer)return;const i="undefined"!=typeof performance?performance.now():Date.now(),o=null!==(n=this.config.pulse.color)&&void 0!==n?n:"rgba(255,255,255,0.6)",r=new Map;for(let t=0;e.length>t;t++)r.set(e[t],t);for(const e of t){if("line"===e.type||"area"===e.type)continue;const t=r.get(e.datum);if(null==t)continue;const n=this.timestampBuffer.get(t);if(null==n)continue;const s=this.computePulseIntensity(n,i);s>0&&(e._pulseIntensity=s,e._pulseColor=o)}}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,i=this.timestampBuffer.peek();return null!=i&&n>e-i}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,i,o,r;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!==(r=null!==(i=null===(n=t.datum)||void 0===n?void 0:n.binStart)&&void 0!==i?i:null===(o=t.datum)||void 0===o?void 0:o.category)&&void 0!==r?r: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,i,o,r;if(!this.config.transition||0===this.prevPositionMap.size)return;const s=null!==(t=this.config.transition.duration)&&void 0!==t?t:300;let l=!1;for(let t=0;this.scene.length>t;t++){const s=this.scene[t],a=this.getNodeIdentity(s,t);if(!a)continue;const c=this.prevPositionMap.get(a);if(c)if("point"===s.type){const t={x:s.x,y:s.y,r:s.r};c.x===t.x&&c.y===t.y||(s._targetX=t.x,s._targetY=t.y,s._targetR=t.r,s.x=c.x,s.y=c.y,s.r=null!==(e=c.r)&&void 0!==e?e:s.r,l=!0)}else if("rect"===s.type){const t={x:s.x,y:s.y,w:s.w,h:s.h};c.x===t.x&&c.y===t.y&&c.w===t.w&&c.h===t.h||(s._targetX=t.x,s._targetY=t.y,s._targetW=t.w,s._targetH=t.h,s.x=c.x,s.y=c.y,s.w=null!==(n=c.w)&&void 0!==n?n:s.w,s.h=null!==(i=c.h)&&void 0!==i?i:s.h,l=!0)}else if("heatcell"===s.type){const t={x:s.x,y:s.y,w:s.w,h:s.h};c.x===t.x&&c.y===t.y||(s._targetX=t.x,s._targetY=t.y,s._targetW=t.w,s._targetH=t.h,s.x=c.x,s.y=c.y,s.w=null!==(o=c.w)&&void 0!==o?o:s.w,s.h=null!==(r=c.h)&&void 0!==r?r:s.h,l=!0)}}l&&(this.activeTransition={startTime:"undefined"!=typeof performance?performance.now():Date.now(),duration:s})}advanceTransition(t){var e;if(!this.activeTransition)return!1;const n=Math.min((t-this.activeTransition.startTime)/this.activeTransition.duration,1),i="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)*i,t.y=n.y+(t._targetY-n.y)*i,void 0!==t._targetR&&void 0!==n.r&&(t.r=n.r+(t._targetR-n.r)*i)}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)*i,t.y=n.y+(t._targetY-n.y)*i,void 0!==n.w&&(t.w=n.w+(t._targetW-n.w)*i),void 0!==n.h&&(t.h=n.h+(t._targetH-n.h)*i)}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)*i,t.y=n.y+(t._targetY-n.y)*i,void 0!==n.w&&(t.w=n.w+(t._targetW-n.w)*i),void 0!==n.h&&(t.h=n.h+(t._targetH-n.h)*i)}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 i=this.config.lineStyle;return"function"==typeof i?i(e||{},t):i&&"object"==typeof i?{fill:i.fill||i.stroke||"#4e79a7",fillOpacity:null!==(n=i.fillOpacity)&&void 0!==n?n:.7,stroke:i.stroke||"#4e79a7",strokeWidth:i.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 it(t,e,n){const i=e-t.x,o=n-t.y,r=Math.sqrt(i*i+o*o);return r>t.r+5?null:{node:t,datum:t.datum,x:t.x,y:t.y,distance:r}}function ot(t,e,n){if(0===t.path.length)return null;const i=ct(t.path,e);if(0>i)return null;const[o,r]=t.path[i],s=e-o,l=n-r,a=Math.sqrt(s*s+l*l);return{node:t,datum:Array.isArray(t.datum)&&t.datum[i]?t.datum[i]:t.datum,x:o,y:r,distance:a}}function rt(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 st(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 lt(t,e,n){const i=t.bodyWidth/2,o=Math.min(t.openY,t.closeY);if(!(t.x-i-3>e||e>t.x+i+3||t.highY-3>n||n>t.lowY+3)){const i=o+Math.max(Math.max(t.openY,t.closeY)-o,1)/2,r=e-t.x,s=n-i;return{node:t,datum:t.datum,x:t.x,y:i,distance:Math.sqrt(r*r+s*s)}}return null}function at(t,e,n){if(0===t.topPath.length)return null;const i=ct(t.topPath,e);if(0>i)return null;const[o,r]=t.topPath[i],s=e-o,l=n-r;return{node:t,datum:t.datum,x:o,y:r,distance:Math.sqrt(s*s+l*l)}}function ct(t,e){if(0===t.length)return-1;let n=0,i=t.length-1;for(;i>n;){const o=n+i>>1;e>t[o][0]?n=o+1:i=o}return n>0&&Math.abs(t[n][0]-e)>=Math.abs(t[n-1][0]-e)?n-1:n}const ut={fill:e=>t.createElement("rect",{style:e,width:20,height:20}),line:e=>t.createElement("line",{style:e,x1:0,y1:0,x2:20,y2:20})};function ht(t,e,n,i){let o;return o="function"==typeof n?n(t):(0,ut[n])(i(t,e)),o}function dt(e){const{legendGroups:n,customClickBehavior:i,title:o="Legend",width:r=100,height:s=20,orientation:l="vertical"}=e,a="vertical"===l?(({legendGroups:e,width:n,customClickBehavior:i})=>{let o=30;const r=[];return e.forEach((e,s)=>{o+=5,r.push(t.createElement("line",{key:"legend-top-line legend-symbol-"+s,stroke:"gray",x1:0,y1:o,x2:n,y2:o})),o+=10,e.label&&(o+=20,r.push(t.createElement("text",{key:"legend-text-"+s,y:o,className:"legend-group-label"},e.label)),o+=10),r.push(t.createElement("g",{key:"legend-group-"+s,className:"legend-item",transform:`translate(0,${o})`},((e,n)=>{const{type:i="fill",styleFn:o,items:r}=e,s=[];let l=0;return r.forEach((e,r)=>{const a=ht(e,r,i,o);s.push(t.createElement("g",{key:"legend-item-"+r,transform:`translate(0,${l})`,onClick:n?()=>n(e):void 0,style:{cursor:n?"pointer":"default"}},a,t.createElement("text",{y:15,x:30},e.label))),l+=25}),s})(e,i))),o+=25*e.items.length+10}),r})({legendGroups:n,width:r,customClickBehavior:i}):(({legendGroups:e,title:n,height:i,customClickBehavior:o})=>{let r=0;const s=[],l=!1===n?10:40;return e.forEach((n,a)=>{n.label&&(s.push(t.createElement("text",{key:"legend-text-"+a,transform:`translate(${r},${l}) rotate(90)`,textAnchor:"start",className:"legend-group-label"},n.label)),r+=20);const c=((e,n)=>{const{type:i="fill",styleFn:o,items:r}=e,s=[];let l=0;return r.forEach((e,r)=>{const a=ht(e,r,i,o);s.push(t.createElement("g",{key:"legend-item-"+r,transform:`translate(${l},0)`,onClick:n?()=>n(e):void 0,style:{cursor:n?"pointer":"default"}},a,t.createElement("text",{y:15,x:25},e.label))),l+=35,l+=8*e.label.length}),{items:s,offset:l}})(n,o);s.push(t.createElement("g",{key:"legend-group-"+a,className:"legend-item",transform:`translate(${r},${l})`},c.items)),r+=c.offset+5,e[a+1]&&s.push(t.createElement("line",{key:"legend-top-line legend-symbol-"+a,stroke:"gray",x1:r,y1:l-10,x2:r,y2:i+l+10})),r+=15}),t.createElement("g",null,!1!==n&&t.createElement("line",{x1:0,x2:r+10,y1:l-10,y2:l-10,stroke:"gray",className:"title-neatline"}),s)})({legendGroups:n,title:o,height:s,customClickBehavior:i});return t.createElement("g",null,void 0!==o&&t.createElement("text",{className:"legend-title",y:20,x:"horizontal"===l?0:r/2,textAnchor:"horizontal"===l?"start":"middle"},o),a)}function ft(t){return"string"==typeof t?{type:t}:t}function yt({orient:n,config:i,values:o,scale:r,size:s,length:l}){const a=function(t){var e,n,i,o,r;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!==(i=t.fillOpacity)&&void 0!==i?i:.5,stroke:null!==(o=t.stroke)&&void 0!==o?o:"none",strokeWidth:null!==(r=t.strokeWidth)&&void 0!==r?r:1}}(i),c="top"===n||"bottom"===n,u=e(()=>{if(0===o.length)return null;const e=r.domain(),i=s-8;if("boxplot"===a.type){const e=function(t){const e=[...t].sort((t,e)=>t-e),n=e.length;if(0===n)return null;const i=e[Math.floor(.25*n)],o=e[Math.floor(.5*n)],r=e[Math.floor(.75*n)],s=r-i;return{q1:i,median:o,q3:r,whiskerLow:Math.max(e[0],i-1.5*s),whiskerHigh:Math.min(e[n-1],r+1.5*s)}}(o);if(!e)return null;const{q1:s,median:l,q3:u,whiskerLow:h,whiskerHigh:d}=e,f=Math.min(.5*i,20),y=(i-f)/2+4;if(c){const e=r(s),i=r(u),o=r(l),c=r(h),g=r(d),p="top"===n?-1:1,m=0;return t.createElement("g",{"data-testid":"marginal-boxplot-"+n},t.createElement("line",{x1:c,y1:m+p*(y+f/2),x2:g,y2:m+p*(y+f/2),stroke:a.fill,strokeWidth:a.strokeWidth}),t.createElement("line",{x1:c,y1:m+p*y,x2:c,y2:m+p*(y+f),stroke:a.fill,strokeWidth:a.strokeWidth}),t.createElement("line",{x1:g,y1:m+p*y,x2:g,y2:m+p*(y+f),stroke:a.fill,strokeWidth:a.strokeWidth}),t.createElement("rect",{x:Math.min(e,i),y:"top"===n?m-y-f:m+y,width:Math.abs(i-e),height:f,fill:a.fill,fillOpacity:a.fillOpacity,stroke:"none"===a.stroke?a.fill:a.stroke,strokeWidth:a.strokeWidth}),t.createElement("line",{x1:o,y1:"top"===n?m-y-f:m+y,x2:o,y2:"top"===n?m-y:m+y+f,stroke:a.fill,strokeWidth:2}))}{const e=r(s),i=r(u),o=r(l),c=r(h),g=r(d),p="left"===n?-1:1,m=0;return t.createElement("g",{"data-testid":"marginal-boxplot-"+n},t.createElement("line",{x1:m+p*(y+f/2),y1:c,x2:m+p*(y+f/2),y2:g,stroke:a.fill,strokeWidth:a.strokeWidth}),t.createElement("line",{x1:m+p*y,y1:c,x2:m+p*(y+f),y2:c,stroke:a.fill,strokeWidth:a.strokeWidth}),t.createElement("line",{x1:m+p*y,y1:g,x2:m+p*(y+f),y2:g,stroke:a.fill,strokeWidth:a.strokeWidth}),t.createElement("rect",{x:"left"===n?m-y-f:m+y,y:Math.min(e,i),width:f,height:Math.abs(i-e),fill:a.fill,fillOpacity:a.fillOpacity,stroke:"none"===a.stroke?a.fill:a.stroke,strokeWidth:a.strokeWidth}),t.createElement("line",{x1:"left"===n?m-y-f:m+y,y1:o,x2:"left"===n?m-y:m+y+f,y2:o,stroke:a.fill,strokeWidth:2}))}}const u=m().domain(e).thresholds(a.bins)(o);if(0===u.length)return null;const h=Math.max(...u.map(t=>t.length));if(0===h)return null;if("histogram"===a.type)return t.createElement("g",{"data-testid":"marginal-histogram-"+n},u.map((e,o)=>{if(null==e.x0||null==e.x1)return null;const s=e.length/h*i;if(c){const i=r(e.x0),l=r(e.x1)-r(e.x0);return t.createElement("rect",{key:o,x:i,y:"top"===n?-4-s:4,width:Math.max(l,.5),height:s,fill:a.fill,fillOpacity:a.fillOpacity,stroke:a.stroke,strokeWidth:a.strokeWidth})}{const i=r(e.x0),l=r(e.x1)-r(e.x0);return t.createElement("rect",{key:o,x:"left"===n?-4-s:4,y:Math.min(i,i+l),width:s,height:Math.abs(l),fill:a.fill,fillOpacity:a.fillOpacity,stroke:a.stroke,strokeWidth:a.strokeWidth})}}));if("violin"===a.type){const e=i/2+4,o=[];for(const t of u){if(null==t.x0||null==t.x1)continue;const s=t.length/h*(i/2),l=r((t.x0+t.x1)/2);o.push(c?`${l},${"top"===n?-(e-s):e-s}`:`${"left"===n?-(e-s):e-s},${l}`)}for(let t=u.length-1;t>=0;t--){const s=u[t];if(null==s.x0||null==s.x1)continue;const l=s.length/h*(i/2),a=r((s.x0+s.x1)/2);o.push(c?`${a},${"top"===n?-(e+l):e+l}`:`${"left"===n?-(e+l):e+l},${a}`)}return t.createElement("g",{"data-testid":"marginal-violin-"+n},t.createElement("polygon",{points:o.join(" "),fill:a.fill,fillOpacity:a.fillOpacity,stroke:"none"===a.stroke?a.fill:a.stroke,strokeWidth:a.strokeWidth}))}if("ridgeline"===a.type){const e=[];if(c){const t=0,o=null!=u[0].x0?r(u[0].x0):0;e.push(`M${o},${t}`);for(const t of u){if(null==t.x0||null==t.x1)continue;const o=t.length/h*i,s=r((t.x0+t.x1)/2);e.push(`L${s},${"top"===n?-o-4:o+4}`)}const s=null!=u[u.length-1].x1?r(u[u.length-1].x1):l;e.push(`L${s},${t}`),e.push("Z")}else{const t=0,o=null!=u[0].x0?r(u[0].x0):0;e.push(`M${t},${o}`);for(const t of u){if(null==t.x0||null==t.x1)continue;const o=t.length/h*i,s=r((t.x0+t.x1)/2);e.push(`L${"left"===n?-o-4:o+4},${s}`)}const s=null!=u[u.length-1].x1?r(u[u.length-1].x1):l;e.push(`L${t},${s}`),e.push("Z")}return t.createElement("g",{"data-testid":"marginal-ridgeline-"+n},t.createElement("path",{d:e.join(" "),fill:a.fill,fillOpacity:a.fillOpacity,stroke:"none"===a.stroke?a.fill:a.stroke,strokeWidth:a.strokeWidth}))}return null},[o,r,a,s,l,n,c,4]);return u?t.createElement("g",{className:"marginal-"+n,"data-testid":"marginal-"+n},u):null}function gt(t){return Math.round(100*t)/100+""}function pt(n){const{width:i,height:o,totalWidth:r,totalHeight:s,margin:l,scales:a,showAxes:c,xLabel:u,yLabel:h,xFormat:d,yFormat:f,showGrid:y,title:g,legend:p,foregroundGraphics:m,marginalGraphics:v,xValues:x,yValues:b,annotations:k,svgAnnotationRules:w,annotationFrame:A,children:E}=n,S=e(()=>c&&a?a.x.ticks(5).map(t=>({value:t,pixel:a.x(t),label:(d||gt)(t)})):[],[c,a,d]),M=e(()=>c&&a?a.y.ticks(5).map(t=>({value:t,pixel:a.y(t),label:(f||gt)(t)})):[],[c,a,f]),_=e(()=>k&&0!==k.length&&w?k.map((t,e)=>w(t,e,{scales:a?{time:a.x,value:a.y}:null,timeAxis:"x",width:i,height:o})).filter(Boolean):null,[k,w,i,o,A]);return c||g||p||m||v||_&&_.length>0||y||E?t.createElement("svg",{width:r,height:s,style:{position:"absolute",top:0,left:0,pointerEvents:"none"}},t.createElement("g",{transform:`translate(${l.left},${l.top})`},y&&a&&t.createElement("g",{className:"stream-grid"},S.map((e,n)=>t.createElement("line",{key:"xgrid-"+n,x1:e.pixel,y1:0,x2:e.pixel,y2:o,stroke:"#e0e0e0",strokeWidth:1})),M.map((e,n)=>t.createElement("line",{key:"ygrid-"+n,x1:0,y1:e.pixel,x2:i,y2:e.pixel,stroke:"#e0e0e0",strokeWidth:1}))),c&&a&&t.createElement("g",{className:"stream-axes"},t.createElement("line",{x1:0,y1:o,x2:i,y2:o,stroke:"#ccc",strokeWidth:1}),S.map((e,n)=>t.createElement("g",{key:"xtick-"+n,transform:`translate(${e.pixel},${o})`},t.createElement("line",{y2:5,stroke:"#ccc",strokeWidth:1}),t.createElement("text",{y:18,textAnchor:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},e.label))),u&&t.createElement("text",{x:i/2,y:o+40,textAnchor:"middle",fontSize:12,fill:"#333",style:{userSelect:"none"}},u),t.createElement("line",{x1:0,y1:0,x2:0,y2:o,stroke:"#ccc",strokeWidth:1}),M.map((e,n)=>t.createElement("g",{key:"ytick-"+n,transform:`translate(0,${e.pixel})`},t.createElement("line",{x2:-5,stroke:"#ccc",strokeWidth:1}),t.createElement("text",{x:-8,textAnchor:"end",dominantBaseline:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},e.label))),h&&t.createElement("text",{x:15-l.left,y:o/2,textAnchor:"middle",fontSize:12,fill:"#333",transform:`rotate(-90, ${15-l.left}, ${o/2})`,style:{userSelect:"none"}},h)),_,v&&a&&x&&b&&t.createElement(t.Fragment,null,v.top&&t.createElement("g",{transform:"translate(0, 0)"},t.createElement(yt,{orient:"top",config:ft(v.top),values:x,scale:a.x,size:l.top,length:i})),v.bottom&&t.createElement("g",{transform:`translate(0, ${o})`},t.createElement(yt,{orient:"bottom",config:ft(v.bottom),values:x,scale:a.x,size:l.bottom,length:i})),v.left&&t.createElement("g",{transform:"translate(0, 0)"},t.createElement(yt,{orient:"left",config:ft(v.left),values:b,scale:a.y,size:l.left,length:o})),v.right&&t.createElement("g",{transform:`translate(${i}, 0)`},t.createElement(yt,{orient:"right",config:ft(v.right),values:b,scale:a.y,size:l.right,length:o}))),m,E),g&&t.createElement("text",{x:r/2,y:20,textAnchor:"middle",fontSize:14,fontWeight:"bold",fill:"#333",style:{userSelect:"none"}},"string"==typeof g?g:null),p&&t.createElement("g",{transform:`translate(${r-l.right+10}, ${l.top})`},"object"==typeof(W=p)&&null!==W&&!t.isValidElement(W)&&"legendGroups"in W?t.createElement(dt,{legendGroups:p.legendGroups,title:"",width:100}):p)):null;var W}function mt(t,e,n){let i=n;for(const n of e)"lesser"===n.thresholdType?n.value>t&&(i=n.color):t>n.value&&(i=n.color);return i}const vt=(t,e,n,i)=>{var o;const r=e.filter(t=>"area"===t.type);for(const e of r){if(2>e.topPath.length)continue;t.beginPath();const[n,i]=e.topPath[0];t.moveTo(n,i);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 r=null!==(o=e.style.fillOpacity)&&void 0!==o?o:.7;if(t.globalAlpha=r,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}},xt=(t,e,n,i)=>{var o;const r=e.filter(t=>"point"===t.type);for(const e of r){t.beginPath(),t.arc(e.x,e.y,e.r,0,2*Math.PI);const n=null!==(o=e.style.opacity)&&void 0!==o?o: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}},bt=(t,e,n,i)=>{const o=e.filter(t=>"rect"===t.type);for(const e of o)null!=e.style.opacity&&(t.globalAlpha=e.style.opacity),e.style.icon?kt(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 kt(t,e){const n=e.style.icon,i=e.style.iconPadding||2,o=Math.min(e.w,e.w)-i;if(0>=o)return;const r=e.h>e.w;if(t.save(),t.beginPath(),t.rect(e.x,e.y,e.w,e.h),t.clip(),r){const r=o+i,s=e.x+(e.w-o)/2;for(let i=e.y+e.h-o;i>=e.y-o;i-=r)t.drawImage(n,s,i,o,o)}else{const r=o+i,s=e.y+(e.h-o)/2;for(let i=e.x;e.x+e.w>i;i+=r)t.drawImage(n,i,s,o,o)}t.restore()}const wt={line:[vt,(t,e,n,i)=>{const o=e.filter(t=>"line"===t.type);for(const r of o){if(2>r.path.length)continue;const s=r.style.stroke||"#007bff",l=r.style.strokeWidth||2,a=r.colorThresholds,c=r.rawValues;if(t.setLineDash(r.style.strokeDasharray?r.style.strokeDasharray.split(/[\s,]+/).map(Number):[]),null!=r.style.opacity&&(t.globalAlpha=r.style.opacity),t.lineWidth=l,a&&0!==a.length&&c&&c.length===r.path.length){let u=null,h=null,d=null,f=null,y=!1;function g(e,n,i){t.beginPath(),t.strokeStyle=e,t.moveTo(n,i),y=!0}function p(){y&&(t.stroke(),y=!1)}for(let m=0;r.path.length>m;m++){const[v,x]=r.path[m],b=c[m],k=mt(b,a,s);if(null!==u&&null!==f&&null!==d){if(k===f)t.lineTo(v,x);else{const w=[];for(const A of a){const E=A.value;(d>E||E>b)&&(E>d||b>E)||d===E||b===E||w.push({t:(E-d)/(b-d)})}w.sort((t,e)=>t.t-e.t);for(const S of w){const M=u+(v-u)*S.t,_=h+(x-h)*S.t,W=mt(d+(b-d)*Math.min(S.t+1e-4,1),a,s);t.lineTo(M,_),p(),g(W,M,_)}t.lineTo(v,x)}u=v,h=x,d=b,f=k}else g(k,v,x),u=v,h=x,d=b,f=k}p()}else{t.beginPath(),t.strokeStyle=s;const[N,P]=r.path[0];t.moveTo(N,P);for(let z=1;r.path.length>z;z++)t.lineTo(r.path[z][0],r.path[z][1]);t.stroke()}if(r.style.fill&&r.style.fillOpacity&&r.style.fillOpacity>0){t.beginPath(),t.globalAlpha=r.style.fillOpacity,t.fillStyle=r.style.fill;const[T,$]=r.path[0];t.moveTo(T,$);for(let D=1;r.path.length>D;D++)t.lineTo(r.path[D][0],r.path[D][1]);const O=r.path[0][0];t.lineTo(r.path[r.path.length-1][0],i.height),t.lineTo(O,i.height),t.closePath(),t.fill()}t.globalAlpha=1,t.setLineDash([])}}],area:[vt],stackedarea:[vt],scatter:[xt],bubble:[xt],heatmap:[(t,e,n,i)=>{const o=e.filter(t=>"heatcell"===t.type);for(const e of o){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:[bt],swarm:[xt],waterfall:[(t,e,n,i)=>{var o,r;bt(t,e);const s=e.filter(t=>"rect"===t.type);if(s.length>=2){t.save(),t.strokeStyle="#999",t.lineWidth=1,t.setLineDash([]);for(let e=0;s.length-1>e;e++){const i=s[e],l=s[e+1];if(!(null===(o=i.datum)||void 0===o?void 0:o.cumEnd)||!(null===(r=l.datum)||void 0===r?void 0:r.baseline))continue;const a=n.y(i.datum.cumEnd),c=i.x+i.w,u=l.x;t.beginPath(),t.moveTo(c,a),t.lineTo(u,a),t.stroke()}t.restore()}}],candlestick:[(t,e,n,i)=>{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 i=Math.min(e.openY,e.closeY),o=Math.abs(e.openY-e.closeY),r=e.isUp?e.upColor:e.downColor;t.fillStyle=r,t.fillRect(e.x-e.bodyWidth/2,i,e.bodyWidth,Math.max(o,1)),t.strokeStyle=r,t.lineWidth=1,t.strokeRect(e.x-e.bodyWidth/2,i,e.bodyWidth,Math.max(o,1))}}]},At={top:20,right:20,bottom:30,left:40},Et={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"},St={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 Mt({hover:e}){const n=t=>Number.isInteger(t)?t+"":t.toFixed(2);return t.createElement("div",{className:"semiotic-tooltip",style:St},t.createElement("div",{style:{fontWeight:600,marginBottom:2}},n(e.value)),t.createElement("div",{style:{opacity:.7,fontSize:11}},n(e.time)))}function _t({width:e,height:n,totalWidth:o,totalHeight:r,margin:l,dimension:a,scales:c,onBrush:u}){const h=i(null),p=i(null);return s(()=>{if(!h.current)return;const t=g(h.current).select(".brush-g"),i="x"===a?d():"y"===a?f():y();return i.extent([[0,0],[e,n]]),i.on("brush end",t=>{if(!c)return;if(!t.selection)return void u(null);let i,o;if("x"===a){const[e,r]=t.selection;i=[c.x.invert(e),c.x.invert(r)],o=[c.y.invert(n),c.y.invert(0)]}else if("y"===a){const[n,r]=t.selection;i=[c.x.invert(0),c.x.invert(e)],o=[c.y.invert(r),c.y.invert(n)]}else{const[[e,n],[r,s]]=t.selection;i=[c.x.invert(e),c.x.invert(r)],o=[c.y.invert(s),c.y.invert(n)]}u({x:i,y:o})}),t.call(i),p.current=i,t.select(".selection").attr("fill","steelblue").attr("fill-opacity",.15).attr("stroke","steelblue").attr("stroke-width",1),()=>{i.on("brush end",null),p.current=null}},[e,n,a,c,u]),t.createElement("svg",{ref:h,width:o,height:r,style:{position:"absolute",top:0,left:0,pointerEvents:"all"}},t.createElement("g",{className:"brush-g",transform:`translate(${l.left},${l.top})`}))}const Wt=n(function(n,a){var c;const{chartType:u,runtimeMode:h,data:d,xAccessor:f,yAccessor:y,colorAccessor:g,sizeAccessor:p,groupAccessor:m,lineDataAccessor:v,normalize:x,binSize:b,valueAccessor:k,arrowOfTime:w="right",windowMode:A="sliding",windowSize:E=200,timeAccessor:S,xExtent:M,yExtent:_,extentPadding:W=.1,sizeRange:N,size:P=[500,300],margin:z,className:T,background:$,lineStyle:O,pointStyle:D,areaStyle:C,swarmStyle:Y,barColors:B,colorScheme:L,boundsAccessor:F,boundsStyle:X,openAccessor:R,highAccessor:j,lowAccessor:I,closeAccessor:G,candlestickStyle:V,showAxes:q=!0,xLabel:Z,yLabel:K,xFormat:Q,yFormat:U,tickFormatTime:J,tickFormatValue:tt,hoverAnnotation:et,tooltipContent:ct,customHoverBehavior:ut,enableHover:ht,annotations:dt,svgAnnotationRules:ft,showGrid:yt,legend:gt,backgroundGraphics:mt,foregroundGraphics:vt,title:xt,categoryAccessor:bt,brush:kt,onBrush:St,decay:Wt,pulse:Nt,transition:Pt,staleness:zt,heatmapAggregation:Tt,heatmapXBins:$t,heatmapYBins:Ot,marginalGraphics:Dt}=n,Ct=Object.assign(Object.assign({},At),z);if(Dt){const t=60;Dt.top&&t>Ct.top&&(Ct.top=t),Dt.bottom&&t>Ct.bottom&&(Ct.bottom=t),Dt.left&&t>Ct.left&&(Ct.left=t),Dt.right&&t>Ct.right&&(Ct.right=t)}const Yt=P[0]-Ct.left-Ct.right,Bt=P[1]-Ct.top-Ct.bottom,Lt=null!=et?et:ht,Ft=i(null),Xt=i(0),Rt=i(!1),[jt,It]=o(0),[Ht,Gt]=o(null),Vt=i(null),[qt,Zt]=o(null),[Kt,Qt]=o(!1),[Ut,Jt]=o([]),[te,ee]=o([]),ne=i(()=>{}),ie="streaming"===h||["bar","swarm","waterfall"].includes(u),oe=e(()=>({chartType:u,runtimeMode:ie?"streaming":"bounded",windowSize:E,windowMode:A,arrowOfTime:ie?w:"right",extentPadding:W,xAccessor:ie?void 0:f,yAccessor:ie?void 0:y,timeAccessor:ie?S:void 0,valueAccessor:k,colorAccessor:g,sizeAccessor:p,groupAccessor:m,categoryAccessor:bt,lineDataAccessor:v,xExtent:M,yExtent:_,sizeRange:N,binSize:b,normalize:x,boundsAccessor:F,boundsStyle:X,openAccessor:R,highAccessor:j,lowAccessor:I,closeAccessor:G,candlestickStyle:V,lineStyle:O,pointStyle:D,areaStyle:C,swarmStyle:Y,colorScheme:L,barColors:B,annotations:dt,decay:Wt,pulse:Nt,transition:Pt,staleness:zt,heatmapAggregation:Tt,heatmapXBins:$t,heatmapYBins:Ot}),[u,E,A,w,W,f,y,S,k,g,p,m,bt,v,M,_,N,b,x,F,X,R,j,I,G,V,O,D,C,Y,L,B,dt,Wt,Nt,Pt,zt,Tt,$t,Ot,ie]),re=i(null);re.current||(re.current=new nt(oe));const se=r(()=>{Xt.current||(Xt.current=requestAnimationFrame(()=>ne.current()))},[]);s(()=>{var t;null===(t=re.current)||void 0===t||t.updateConfig(oe),Rt.current=!0,se()},[oe,se]);const le=i(null);le.current||(le.current=new H(t=>{const e=re.current;e&&e.ingest(t)&&(Rt.current=!0,se())}));const ae=r(t=>{var e;null===(e=le.current)||void 0===e||e.push(t)},[]),ce=r(t=>{var e;null===(e=le.current)||void 0===e||e.pushMany(t)},[]),ue=r(()=>{var t,e;null===(t=le.current)||void 0===t||t.clear(),null===(e=re.current)||void 0===e||e.clear(),Rt.current=!0,se()},[se]);l(a,()=>({push:ae,pushMany:ce,clear:ue,getData:()=>{var t,e;return null!==(e=null===(t=re.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]},getScales:()=>{var t,e;return null!==(e=null===(t=re.current)||void 0===t?void 0:t.scales)&&void 0!==e?e:null},getExtents:()=>{var t,e;return null!==(e=null===(t=re.current)||void 0===t?void 0:t.getExtents())&&void 0!==e?e:null}}),[ae,ce,ue]),s(()=>{var t;d&&(null===(t=le.current)||void 0===t||t.setBoundedData(d))},[d]);const he=i(()=>{}),de=i(()=>{});he.current=t=>{if(!Lt)return;const e=Ft.current;if(!e)return;const n=e.getBoundingClientRect(),i=t.clientX-n.left-Ct.left,o=t.clientY-n.top-Ct.top;if(0>i||i>Yt||0>o||o>Bt)return void(Vt.current&&(Vt.current=null,Zt(null),ut&&ut(null),se()));const r=re.current;if(!r||0===r.scene.length)return;const s=function(t,e,n,i=30){let o=null;for(const r of t){let t=null;switch(r.type){case"point":t=it(r,e,n);break;case"line":t=ot(r,e,n);break;case"rect":t=rt(r,e,n);break;case"heatcell":t=st(r,e,n);break;case"area":if(!1===r.interactive)break;t=at(r,e,n);break;case"candlestick":t=lt(r,e,n)}t&&i>t.distance&&(o&&t.distance>=o.distance||(o=t))}return o}(r.scene,i,o);if(!s)return void(Vt.current&&(Vt.current=null,Zt(null),ut&&ut(null),se()));const l={data:s.datum,time:s.x,value:s.y,x:s.x,y:s.y};Vt.current=l,Zt(l),ut&&ut(l),se()},de.current=()=>{Vt.current&&(Vt.current=null,Zt(null),ut&&ut(null),se())};const fe=r(t=>he.current(t),[]),ye=r(()=>de.current(),[]);ne.current=()=>{var t,e;Xt.current=0;const n=Ft.current;if(!n)return;const i=n.getContext("2d");if(!i)return;const o=re.current;if(!o)return;const r="undefined"!=typeof performance?performance.now():Date.now(),s=o.advanceTransition(r);s||o.computeScene({width:Yt,height:Bt});const l="undefined"!=typeof window&&window.devicePixelRatio||1;n.width=P[0]*l,n.height=P[1]*l,n.style.width=P[0]+"px",n.style.height=P[1]+"px",i.scale(l,l),i.translate(Ct.left,Ct.top),i.clearRect(-Ct.left,-Ct.top,P[0],P[1]);const a=function(t){if(!t)return Et;const e=getComputedStyle(t),n=e.getPropertyValue("--text-secondary").trim(),i=e.getPropertyValue("--text-primary").trim(),o=e.getPropertyValue("--surface-3").trim(),r=e.getPropertyValue("--surface-0").trim();return n||i?{axisStroke:o||Et.axisStroke,tickText:n||Et.tickText,crosshair:n?n+"66":Et.crosshair,hoverFill:r?r+"4D":Et.hoverFill,hoverStroke:n?n+"99":Et.hoverStroke,pointRing:r||Et.pointRing}:Et}(n),c=null!==(t=null==zt?void 0:zt.threshold)&&void 0!==t?t:5e3,h=zt&&o.lastIngestTime>0&&r-o.lastIngestTime>c;h&&(i.globalAlpha=null!==(e=null==zt?void 0:zt.dimOpacity)&&void 0!==e?e:.5),$&&(i.fillStyle=$,i.fillRect(0,0,Yt,Bt));const d=wt[u];if(d&&o.scales)for(const t of d)t(i,o.scene,o.scales,{width:Yt,height:Bt});h&&(i.globalAlpha=1),Lt&&Vt.current&&o.scales&&function(t,e,n,i,o,r,s){if(!1===o.crosshair)return;t.save();const l="object"==typeof o.crosshair?o.crosshair:{};t.strokeStyle=l.stroke||s.crosshair,t.lineWidth=l.strokeWidth||1,t.setLineDash(l.strokeDasharray?l.strokeDasharray.split(/[\s,]+/).map(Number):[4,4]),t.beginPath(),t.moveTo(e.x,0),t.lineTo(e.x,i),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=s.pointRing,t.lineWidth=2,t.stroke()}(i,Vt.current,Yt,Bt,"object"==typeof Lt?Lt:{},0,a);const g=Rt.current;if(Rt.current=!1,g&&o.scales&&(Gt(o.scales),Dt)){const t=o.getData(),e="function"==typeof f?f:t=>t[f||"x"],n="function"==typeof y?y:t=>t[y||"y"];Jt(t.map(t=>e(t)).filter(t=>"number"==typeof t&&isFinite(t))),ee(t.map(t=>n(t)).filter(t=>"number"==typeof t&&isFinite(t)))}g&&dt&&dt.length>0&&ft&&It(t=>t+1),(null==zt?void 0:zt.showBadge)&&Qt(!!h),(s||o.hasActivePulses)&&(Xt.current=requestAnimationFrame(()=>ne.current()))},s(()=>(se(),()=>{Xt.current&&cancelAnimationFrame(Xt.current)}),[se]),s(()=>{Rt.current=!0,se()},[u,Yt,Bt,q,$,O,se]),s(()=>{if(!zt)return;const t=setInterval(()=>{var t;const e=re.current;if(!e||0===e.lastIngestTime)return;const n="undefined"!=typeof performance?performance.now():Date.now(),i=null!==(t=zt.threshold)&&void 0!==t?t:5e3,o=n-e.lastIngestTime>i;o!==Kt&&(Qt(o),Rt.current=!0,se())},1e3);return()=>clearInterval(t)},[zt,Kt,se]);const ge=Lt&&qt?ct?ct(qt):t.createElement(Mt,{hover:qt}):null,pe=ge?t.createElement("div",{className:"stream-frame-tooltip",style:{position:"absolute",left:Ct.left+qt.x,top:Ct.top+qt.y,transform:`translate(${qt.x>.7*Yt?"calc(-100% - 12px)":"12px"}, ${.3*Bt>qt.y?"4px":"calc(-100% - 4px)"})`,pointerEvents:"none",zIndex:1}},ge):null;return t.createElement("div",{className:"stream-xy-frame"+(T?" "+T:""),style:{position:"relative",width:P[0],height:P[1]},onMouseMove:Lt?fe:void 0,onMouseLeave:Lt?ye:void 0},mt&&t.createElement("svg",{style:{position:"absolute",left:0,top:0,width:P[0],height:P[1],pointerEvents:"none"}},mt),t.createElement("canvas",{ref:Ft,style:{position:"absolute",left:0,top:0}}),t.createElement(pt,{width:Yt,height:Bt,totalWidth:P[0],totalHeight:P[1],margin:Ct,scales:Ht,showAxes:q,xLabel:Z,yLabel:K,xFormat:Q||J,yFormat:U||tt,showGrid:yt,title:xt,legend:gt,foregroundGraphics:vt,marginalGraphics:Dt,xValues:Ut,yValues:te,annotations:dt,svgAnnotationRules:ft,annotationFrame:jt}),(kt||St)&&t.createElement(_t,{width:Yt,height:Bt,totalWidth:P[0],totalHeight:P[1],margin:Ct,dimension:null!==(c=null==kt?void 0:kt.dimension)&&void 0!==c?c:"xy",scales:Ht,onBrush:null!=St?St:()=>{}}),(null==zt?void 0:zt.showBadge)&&t.createElement("div",{className:"stream-staleness-badge",style:Object.assign(Object.assign({position:"absolute"},"top-left"===zt.badgePosition?{top:4,left:4}:"bottom-left"===zt.badgePosition?{bottom:4,left:4}:"bottom-right"===zt.badgePosition?{bottom:4,right:4}:{top:4,right:4}),{padding:"2px 8px",borderRadius:4,fontSize:11,fontWeight:600,pointerEvents:"none",background:Kt?"#dc3545":"#28a745",color:"white"})},Kt?"STALE":"LIVE"),pe)});Wt.displayName="StreamXYFrame";const Nt={weightChange:.1,newEdge:.5,newNode:1,threshold:3,transitionDuration:500},Pt={radius:3,opacity:.7,speedMultiplier:1,maxPerEdge:50,spawnRate:.1};class zt{constructor(t){this.capacity=t,this.particles=Array(t);for(let e=0;t>e;e++)this.particles[e]={t:0,offset:0,edgeIndex:0,active:!1,x:0,y:0}}spawn(t){for(let e=0;this.capacity>e;e++){const n=this.particles[e];if(!n.active)return n.active=!0,n.t=0,n.offset=Math.random()-.5,n.edgeIndex=t,n.x=0,n.y=0,n}return null}step(t,e,n){for(let i=0;this.capacity>i;i++){const o=this.particles[i];if(!o.active)continue;const r=n[o.edgeIndex];if(!r||!r.bezier){o.active=!1;continue}if(o.t+=t*e,o.t>=1){o.active=!1;continue}const s=Tt(r.bezier,o.t,o.offset);o.x=s.x,o.y=s.y}}countForEdge(t){let e=0;for(let n=0;this.capacity>n;n++)this.particles[n].active&&this.particles[n].edgeIndex===t&&e++;return e}clear(){for(let t=0;this.capacity>t;t++)this.particles[t].active=!1}resize(t){if(this.capacity>=t)return;const e=this.particles;this.particles=Array(t);for(let n=0;t>n;n++)this.particles[n]=e.length>n?e[n]:{t:0,offset:0,edgeIndex:0,active:!1,x:0,y:0};this.capacity=t}}function Tt(t,e,n){if(t.circular&&t.segments)return function(t,e,n,i){const o=t.length,r=e*o,s=Math.min(Math.floor(r),o-1),l=r-s,[a,c,u,h]=t[s],d=$t(a,c,u,h,l),f=h.x-a.x,y=h.y-a.y,g=Math.sqrt(f*f+y*y);if(g>.001){const t=f/g;d.x+=-y/g*n*i*2,d.y+=t*n*i*2}return d}(t.segments,e,n,t.halfWidth);if(!t.points)return{x:0,y:0};const[i,o,r,s]=t.points,l=$t(i,o,r,s,e),a=s.x-i.x,c=s.y-i.y,u=Math.sqrt(a*a+c*c);if(u>.001){const e=a/u;l.x+=-c/u*n*t.halfWidth*2,l.y+=e*n*t.halfWidth*2}return l}function $t(t,e,n,i,o){const r=1-o,s=r*r,l=s*r,a=o*o,c=a*o;return{x:l*t.x+3*s*o*e.x+3*r*a*n.x+c*i.x,y:l*t.y+3*s*o*e.y+3*r*a*n.y+c*i.y}}const Ot=(t=1)=>(e,n)=>{const i=e[e.length-1];return i&&Math.round(i.x/t)===Math.round(n.x/t)&&Math.round(i.y/t)===Math.round(n.y/t)||e.push(n),e},Dt=t=>{let e,n,i,o,r,s,l,a,c;return"down"===t.direction?(e=t.y0-t.sankeyWidth/2,n=t.y1-t.sankeyWidth/2,i=t.y1+t.sankeyWidth/2,o=t.y0+t.sankeyWidth/2,r=t.source.y1,s=t.target.y0,l=b(r,s),a=l(.5),c=l(.5),`M${e},${r}C${e},${a} ${n},${c} ${n},${s}L${i},${s}C${i},${c} ${o},${a} ${o},${r}Z`):(e=t.source.x1,n=t.target.x0,l=b(e,n),i=l(.5),o=l(.5),r=t.y0-t.sankeyWidth/2,s=t.y1-t.sankeyWidth/2,a=t.y1+t.sankeyWidth/2,c=t.y0+t.sankeyWidth/2,`M${e},${r}C${i},${r} ${o},${s} ${n},${s}L${n},${a}C${o},${a} ${i},${c} ${e},${c}Z`)};function Ct(t){const e=function(){const t=_();let e=function(t){return t.x},n=function(t){return t.y},i=function(t){return t.r},o=W;function r(r){if(r.multiple){const s=i,a=r.multiple.reduce((t,e)=>t+e.weight,0);i=()=>a;let c=l(r.points).filter(t=>"forward"===t.direction).reduce(Ot(),[]);const u=[];return r.multiple.forEach((t,e)=>{i=()=>t.weight;const n=l(c);u.push(n);const o=r.multiple[e+1];if(o){const t=n.reverse().filter(t=>"back"===t.direction).reduce(Ot(),[]);i=()=>o.weight;const e=l(t);c=e.reverse().filter(t=>"back"===t.direction).reduce(Ot(),[])}}),i=s,u.map(i=>t.x(e).y(n).curve(o)(i))}const s=l(r).reduce(Ot(),[]);return t.x(e).y(n).curve(o)(s)}return r.x=function(t){return arguments.length?(e=t,r):e},r.y=function(t){return arguments.length?(n=t,r):n},r.r=function(t){return arguments.length?(i=t,r):i},r.interpolate=function(t){return arguments.length?(o=t,r):o},r;function s(t){const o=n(t.target)-n(t.source),r=e(t.target)-e(t.source),s=Math.atan2(r,o)+Math.PI/2,l=s+.5*Math.PI,a=s+.5*Math.PI;return{x1:e(t.source)+i(t.source)*Math.cos(l),y1:n(t.source)-i(t.source)*Math.sin(l),x2:e(t.target)+i(t.target)*Math.cos(a),y2:n(t.target)-i(t.target)*Math.sin(a)}}function l(t){const e=[];let n=0,i={x1:0,y1:0,x2:0,y2:0};for(;t.length>n;){if(n!==t.length-1&&(i=s({source:t[n],target:t[n+1]}),e.push({x:i.x1,y:i.y1,direction:"forward"},{x:i.x2,y:i.y2,direction:"forward"}),e.length>3)){const t=e.length-1,n={a:e[t-3],b:e[t-2]},i={a:e[t-1],b:e[t]},o=a(n.a.x,n.a.y,n.b.x,n.b.y,i.a.x,i.a.y,i.b.x,i.b.y);!0===o.found&&(n.b.x=o.x,n.b.y=o.y,i.a.x=o.x,i.a.y=o.y)}n++}for(n--;n>=0;){if(0!==n&&(i=s({source:t[n],target:t[n-1]}),e.push({x:i.x1,y:i.y1,direction:"back"},{x:i.x2,y:i.y2,direction:"back"}),e.length>3)){const t=e.length-1,n={a:e[t-3],b:e[t-2]},i={a:e[t-1],b:e[t]},o=a(n.a.x,n.a.y,n.b.x,n.b.y,i.a.x,i.a.y,i.b.x,i.b.y);!0===o.found&&(n.b.x=o.x,n.b.y=o.y,i.a.x=o.x,i.a.y=o.y)}n--}return e}function a(t,e,n,i,o,r,s,l){let a,c;const u={x:null,y:null,found:!1},h=(l-r)*(n-t)-(s-o)*(i-e);if(0===h)return u;a=e-r,c=t-o;const d=(n-t)*a-(i-e)*c;return a=((s-o)*a-(l-r)*c)/h,c=d/h,u.x=t+a*(n-t),u.y=e+a*(i-e),a>0&&1>a&&c>0&&1>c&&(u.found=!0),u}}();return e.x(t=>t.x),e.y(t=>t.y),e.r(()=>t.sankeyWidth/2),e("down"===t.direction?[{x:t.circularPathData.sourceY,y:t.circularPathData.sourceX},{x:t.circularPathData.sourceY,y:t.circularPathData.leftFullExtent},{x:t.circularPathData.verticalFullExtent,y:t.circularPathData.leftFullExtent},{x:t.circularPathData.verticalFullExtent,y:t.circularPathData.rightFullExtent},{x:t.circularPathData.targetY,y:t.circularPathData.rightFullExtent},{x:t.circularPathData.targetY,y:t.circularPathData.targetX}]:[{x:t.circularPathData.sourceX,y:t.circularPathData.sourceY},{x:t.circularPathData.leftFullExtent,y:t.circularPathData.sourceY},{x:t.circularPathData.leftFullExtent,y:t.circularPathData.verticalFullExtent},{x:t.circularPathData.rightFullExtent,y:t.circularPathData.verticalFullExtent},{x:t.circularPathData.rightFullExtent,y:t.circularPathData.targetY},{x:t.circularPathData.targetX,y:t.circularPathData.targetY}])}const Yt={left:S,right:E,center:A,justify:w},Bt={supportsStreaming:!0,hierarchical:!1,computeLayout(t,e,n,i){var o,r,s,l;if(0===t.length)return;const a="vertical"===n.orientation?"down":"right",c=n.nodeAlign||"justify",u=null!==(o=n.nodeWidth)&&void 0!==o?o:15,h=null!==(r=n.nodePaddingRatio)&&void 0!==r?r:.05,d=null!==(s=n.iterations)&&void 0!==s?s:100,f=t.map(t=>Object.assign({},t)),y=e.map(t=>Object.assign(Object.assign({},t),{source:"string"==typeof t.source?t.source:t.source.id,target:"string"==typeof t.target?t.target:t.target.id}));let g;g="down"===a?[[0,0],[i[1],i[0]]]:[[0,0],[i[0],i[1]]];const p=k().extent(g).links(y).nodes(f).nodeAlign(Yt[c]||w).nodeId(t=>t.id).nodeWidth(u).iterations(d);p.nodePaddingRatio&&p.nodePaddingRatio(h),p();for(const e of f){const n=t.find(t=>t.id===e.id);n&&(n.x0=e.x0,n.x1=e.x1,n.y0=e.y0,n.y1=e.y1,n.value=e.value,n.depth=e.depth,n.sourceLinks=e.sourceLinks,n.targetLinks=e.targetLinks,n.width=e.x1-e.x0,n.height=e.y1-e.y0,n.x=e.x0+(e.x1-e.x0)/2,n.y=e.y0+(e.y1-e.y0)/2)}for(const n of y){const i=n.source,o=n.target,r="object"==typeof i&&null!==i?i.id:i+"",s="object"==typeof o&&null!==o?o.id:o+"",c=e.find(t=>("string"==typeof t.source?t.source:t.source.id)===r&&("string"==typeof t.target?t.target:t.target.id)===s);if(c){c.y0=n.y0,c.y1=n.y1,c.sankeyWidth=null!==(l=n.width)&&void 0!==l?l:0,c.circular=!!n.circular,c.circularPathData=n.circularPathData,c.direction=a;const e=t.find(t=>t.id===r),i=t.find(t=>t.id===s);e&&(c.source=e),i&&(c.target=i)}}},buildScene(t,e,n,i){var o,r;const s="vertical"===n.orientation?"down":"right",l=n.nodeStyle,a=n.edgeStyle,c=null!==(o=n.edgeOpacity)&&void 0!==o?o:.5,u=n.edgeColorBy||"source",h=Array.isArray(n.colorScheme)?n.colorScheme:M,d=new Map;t.forEach((t,e)=>{d.set(t.id,h[e%h.length])});const f=[],y=[],g=[];for(const e of t){const t=e.x1-e.x0,n=e.y1-e.y0;if(0>=t||0>=n)continue;const i=l?l(e):{},o={fill:i.fill||d.get(e.id)||"#4d430c",stroke:i.stroke,strokeWidth:i.strokeWidth,opacity:i.opacity};f.push({type:"rect",x:e.x0,y:e.y0,w:t,h:n,style:o,datum:e,id:e.id,label:e.id})}const p=[...e].sort((t,e)=>(e.sankeyWidth||0)-(t.sankeyWidth||0));for(const t of p){if(!t.sankeyWidth||0>=t.sankeyWidth)continue;const e="object"==typeof t.source?t.source:null,n="object"==typeof t.target?t.target:null;if(!e||!n)continue;let i;i=t.circular&&t.circularPathData?Ct(t):Dt(t);let o="#999";a?o=a(t).fill||o:"target"===u&&n?o=d.get(n.id)||o:e&&(o=d.get(e.id)||o);const s=a?a(t):{},l={fill:o,fillOpacity:null!==(r=s.fillOpacity)&&void 0!==r?r:c,stroke:s.stroke||"none",strokeWidth:s.strokeWidth,opacity:s.opacity};y.push({type:"bezier",pathD:i,bezierCache:t.bezier,style:l,datum:t})}if(!1!==n.showLabels){const e=(m=n.nodeLabel)?"function"==typeof m?m:t=>t[m]||t.id:null;for(const n of t){const t=n.x1-n.x0,o=n.y1-n.y0;if(0>=t||0>=o)continue;const r=e?e(n):n.id;if(!r)continue;let l,a,c;"down"===s?(l=n.x0+t/2,a=n.y1+14,c="middle"):(i[0]/2>n.x0+t/2?(l=n.x0-6,c="end"):(l=n.x1+6,c="start"),a=n.y0+o/2),g.push({x:l,y:a,text:r+"",anchor:c,baseline:"middle",fontSize:11})}}var m;return{sceneNodes:f,sceneEdges:y,labels:g}}},Lt={supportsStreaming:!1,hierarchical:!1,computeLayout(t,e,n,i){var o,r;if(0===t.length)return;const s=null!==(o=n.iterations)&&void 0!==o?o:Math.max(50,Math.min(300,Math.floor(300-2*(t.length-30)))),l=null!==(r=n.forceStrength)&&void 0!==r?r:.1,a=i[0]/2,c=i[1]/2;for(let e=0;t.length>e;e++){const n=t[e];if(null==n.x||null==n.y||0===n.x&&0===n.y){const t=10*Math.sqrt(e+.5),i=2.399963229728653*e;n.x=a+t*Math.cos(i),n.y=c+t*Math.sin(i)}}const u=Xt(n.nodeSize,n.nodeSizeRange,t),h=P().strength(t=>Math.min(2.5,t.weight?t.weight*l:l)).id(t=>t.id),d=i[1]/i[0],f=z().force("charge",T().strength(t=>-25*(t=>u(t))(t))).force("x",$(i[0]/2).strength(.1*d)).force("y",O(i[1]/2).strength(.1));if(f.nodes(t),e.length>0){const t=e.map(t=>Object.assign(Object.assign({},t),{source:"string"==typeof t.source?t.source:t.source.id,target:"string"==typeof t.target?t.target:t.target.id}));f.force("link",h),f.force("link").links(t)}.1>f.alpha()&&f.alpha(1),f.stop();for(let t=0;s>t;++t)f.tick();for(const n of e){if("string"==typeof n.source){const e=t.find(t=>t.id===n.source);e&&(n.source=e)}if("string"==typeof n.target){const e=t.find(t=>t.id===n.target);e&&(n.target=e)}}},buildScene(t,e,n,i){var o,r,s;const l=n.nodeStyle,a=n.edgeStyle,c=Xt(n.nodeSize,n.nodeSizeRange,t),u=Array.isArray(n.colorScheme)?n.colorScheme:M,h=new Map;t.forEach((t,e)=>{h.set(t.id,u[e%u.length])});const d=[],f=[],y=[];for(const e of t){if(null==e.x||null==e.y)continue;const t=c(e),n=l?l(e):{},i={fill:n.fill||h.get(e.id)||"#007bff",stroke:n.stroke||"#fff",strokeWidth:null!==(o=n.strokeWidth)&&void 0!==o?o:2,opacity:n.opacity};d.push({type:"circle",cx:e.x,cy:e.y,r:t,style:i,datum:e,id:e.id,label:e.id})}for(const n of e){const e="object"==typeof n.source?n.source:Ft(t,n.source),i="object"==typeof n.target?n.target:Ft(t,n.target);if(!e||!i)continue;if(null==e.x||null==e.y)continue;if(null==i.x||null==i.y)continue;const o=a?a(n):{},l={stroke:o.stroke||"#999",strokeWidth:null!==(r=o.strokeWidth)&&void 0!==r?r:1,opacity:null!==(s=o.opacity)&&void 0!==s?s:.6};f.push({type:"line",x1:e.x,y1:e.y,x2:i.x,y2:i.y,style:l,datum:n})}if(!1!==n.showLabels){const e=(g=n.nodeLabel)?"function"==typeof g?g:t=>t[g]||t.id:null;for(const n of t){if(null==n.x||null==n.y)continue;const t=e?e(n):n.id;if(!t)continue;const i=c(n);y.push({x:n.x,y:n.y-i-4,text:t+"",anchor:"middle",baseline:"auto",fontSize:11})}}var g;return{sceneNodes:d,sceneEdges:f,labels:y}}};function Ft(t,e){return t.find(t=>t.id===e)}function Xt(t,e,n){var i,o;if(null==t)return()=>8;if("number"==typeof t)return()=>t;if("function"==typeof t)return e=>t(e)||8;const r=e||[5,20],s=n.map(e=>{var n;return null===(n=e.data)||void 0===n?void 0:n[t]}).filter(t=>null!=t&&"number"==typeof t);if(0===s.length)return()=>r[0];const l=null!==(i=v(s))&&void 0!==i?i:0,a=null!==(o=x(s))&&void 0!==o?o:1;if(l===a)return()=>(r[0]+r[1])/2;const c=p().domain([l,a]).range(r).clamp(!0);return e=>{var n;const i=null===(n=e.data)||void 0===n?void 0:n[t];return null==i||"number"!=typeof i?r[0]:c(i)}}const Rt=M,jt={supportsStreaming:!1,hierarchical:!1,computeLayout(t,e,n,i){if(0===t.length)return;const{padAngle:o=.01,groupWidth:r=20,sortGroups:s}=n,l=Math.min(i[0],i[1])/2,a=l-r,c=i[0]/2,u=i[1]/2,h=(d=n.valueAccessor)?"function"==typeof d?d:t=>{var e;return null!==(e=t[d])&&void 0!==e?e:1}:t=>{var e;return null!==(e=t.value)&&void 0!==e?e:1};var d;const f=new Map;for(let e=0;t.length>e;e++)f.set(t[e].id,e);const y=t.length,g=Array.from({length:y},()=>Array.from({length:y},()=>0));for(const t of e){const e="string"==typeof t.target?t.target:t.target.id,n=f.get("string"==typeof t.source?t.source:t.source.id),i=f.get(e);if(void 0===n||void 0===i)continue;const o=h(t);g[n][i]=o}const p=C().padAngle(o);s&&p.sortGroups(s);const m=p(g),v=m.groups,x=N().innerRadius(a).outerRadius(l);for(const e of v){const n=t[e.index],i=x.centroid(e);n.x=i[0]+c,n.y=i[1]+u,n.arcData={startAngle:e.startAngle,endAngle:e.endAngle}}for(const n of e){const e="string"==typeof n.source?n.source:n.source.id,i="string"==typeof n.target?n.target:n.target.id,o=t.find(t=>t.id===e),r=t.find(t=>t.id===i);o&&(n.source=o),r&&(n.target=r)}for(const n of m){const i=t[n.source.index].id,o=t[n.target.index].id,r=e.find(t=>{const e="string"==typeof t.source?t.source:t.source.id,n="string"==typeof t.target?t.target:t.target.id;return e===i&&n===o||e===o&&n===i});r&&(r.chordData=n)}},buildScene(t,e,n,i){var o,r;const{groupWidth:s=20,edgeOpacity:l=.5}=n,a=Math.min(i[0],i[1])/2,c=a-s,u=i[0]/2,h=i[1]/2,d=n.nodeStyle,f=n.edgeStyle,y=n.edgeColorBy||"source",g=Array.isArray(n.colorScheme)?n.colorScheme:Rt,p=new Map;t.forEach((t,e)=>{p.set(t.id,g[e%g.length])});const m=D().radius(c),v=[],x=[],b=[];for(let e=0;t.length>e;e++){const n=t[e],i=n.arcData;if(!i)continue;let r;r=d?d(n).fill||p.get(n.id)||g[e%g.length]:p.get(n.id)||g[e%g.length];const s=d?d(n):{},l={fill:r,stroke:s.stroke||"black",strokeWidth:null!==(o=s.strokeWidth)&&void 0!==o?o:1,opacity:s.opacity};v.push({type:"arc",cx:u,cy:h,innerR:c,outerR:a,startAngle:i.startAngle-Math.PI/2,endAngle:i.endAngle-Math.PI/2,style:l,datum:n,id:n.id,label:n.id})}for(const t of e){const e=t.chordData;if(!e)continue;const n=m({source:Object.assign(Object.assign({},e.source),{startAngle:e.source.startAngle-Math.PI/2,endAngle:e.source.endAngle-Math.PI/2}),target:Object.assign(Object.assign({},e.target),{startAngle:e.target.startAngle-Math.PI/2,endAngle:e.target.endAngle-Math.PI/2})});if(!n)continue;const i=It(n,u,h);let o="#999";if(f)o=f(t).fill||o;else{const e="object"==typeof t.source?t.source:null,n="object"==typeof t.target?t.target:null;"target"===y&&n?o=p.get(n.id)||o:e&&(o=p.get(e.id)||o)}const s=f?f(t):{},a={fill:o,fillOpacity:null!==(r=s.fillOpacity)&&void 0!==r?r:l,stroke:s.stroke||"none",strokeWidth:s.strokeWidth,opacity:s.opacity};x.push({type:"ribbon",pathD:i,style:a,datum:t})}if(!1!==n.showLabels){const e=(k=n.nodeLabel)?"function"==typeof k?k:t=>t[k]||t.id:null,i=a+12;for(const n of t){const t=n.arcData;if(!t)continue;const o=e?e(n):n.id;if(!o)continue;const r=(t.startAngle+t.endAngle)/2,s=r-Math.PI/2;b.push({x:u+Math.cos(s)*i,y:h+Math.sin(s)*i,text:o+"",anchor:r>Math.PI?"end":"start",baseline:"middle",fontSize:11})}}var k;return{sceneNodes:v,sceneEdges:x,labels:b}}};function It(t,e,n){const i=t.match(/[a-zA-Z]|[-+]?\d*\.?\d+(?:[eE][-+]?\d+)?/g);if(!i)return t;const o=[];let r=0;for(;i.length>r;){const t=i[r];if("M"===t||"L"===t)for(o.push(t),r++;i.length>r&&!isNaN(Number(i[r]));)o.push(Number(i[r])+e+""),r++,i.length>r&&!isNaN(Number(i[r]))&&(o.push(Number(i[r])+n+""),r++);else if("C"===t)for(o.push(t),r++;i.length>r&&!isNaN(Number(i[r]));)for(let t=0;3>t&&i.length>r&&!isNaN(Number(i[r]));t++)o.push(Number(i[r])+e+""),r++,i.length>r&&!isNaN(Number(i[r]))&&(o.push(Number(i[r])+n+""),r++);else if("Q"===t)for(o.push(t),r++;i.length>r&&!isNaN(Number(i[r]));)for(let t=0;2>t&&i.length>r&&!isNaN(Number(i[r]));t++)o.push(Number(i[r])+e+""),r++,i.length>r&&!isNaN(Number(i[r]))&&(o.push(Number(i[r])+n+""),r++);else if("A"===t)for(o.push(t),r++;i.length>r&&!isNaN(Number(i[r]));)o.push(i[r++]),i.length>r&&o.push(i[r++]),i.length>r&&o.push(i[r++]),i.length>r&&o.push(i[r++]),i.length>r&&o.push(i[r++]),i.length>r&&(o.push(Number(i[r])+e+""),r++),i.length>r&&(o.push(Number(i[r])+n+""),r++);else"Z"===t||"z"===t?(o.push(t),r++):(o.push(i[r]),r++)}return o.join(" ")}const Ht={supportsStreaming:!1,hierarchical:!0,computeLayout(t,e,n,i){var o;const r=n.__hierarchyRoot;if(!r)return;const s=n.chartType,l=(a=n.childrenAccessor)?"function"==typeof a?a:t=>t[a]:void 0;var a;const c=n.hierarchySum||(t=>{var e;return null!==(e=t.value)&&void 0!==e?e:0}),u=Y(r,l);u.sum(c),u.sort((t,e)=>{var n,i;return(null!==(n=e.value)&&void 0!==n?n:0)-(null!==(i=t.value)&&void 0!==i?i:0)});const[h,d]=i;switch(s){case"tree":!function(t,e,n,i){const o=e.treeOrientation||"vertical",r=j();r.size("horizontal"===o?[i,n]:"radial"===o?[2*Math.PI,Math.min(n,i)/2*.8]:[n,i]),r(t)}(u,n,h,d);break;case"cluster":!function(t,e,n,i){const o=e.treeOrientation||"vertical",r=R();r.size("horizontal"===o?[i,n]:"radial"===o?[2*Math.PI,Math.min(n,i)/2*.8]:[n,i]),r(t)}(u,n,h,d);break;case"treemap":!function(t,e,n,i){var o,r;const s=null!==(o=e.padding)&&void 0!==o?o:4,l=null!==(r=e.paddingTop)&&void 0!==r?r:0,a=F().size([n,i]).tile(X).padding(s);l>0&&a.paddingTop(l),a(t)}(u,n,h,d);break;case"circlepack":!function(t,e,n,i){var o;const r=null!==(o=e.padding)&&void 0!==o?o:4;L().size([n,i]).padding(r)(t)}(u,n,h,d);break;case"partition":!function(t,e,n,i){var o;B().size([n,i]).padding(null!==(o=e.padding)&&void 0!==o?o:1)(t)}(u,n,h,d)}const f=u.descendants();t.length=0,e.length=0;const y=new Map;for(let e=0;f.length>e;e++){const i=f[e],r={id:Kt(i,n,e),x:0,y:0,x0:0,x1:0,y0:0,y1:0,width:0,height:0,value:null!==(o=i.value)&&void 0!==o?o:0,depth:i.depth,data:i.data,createdByFrame:!0};"tree"===s||"cluster"===s?Gt(r,i,n):"treemap"===s||"partition"===s?Vt(r,i):"circlepack"===s&&qt(r,i),r.__hierarchyNode=i,t.push(r),y.set(i,r)}if("tree"===s||"cluster"===s)for(const t of f)if(t.parent){const n=y.get(t.parent),i=y.get(t);n&&i&&e.push({source:n,target:i,value:1,y0:0,y1:0,sankeyWidth:0,data:{depth:t.depth}})}},buildScene(t,e,n,i){const o=n.nodeStyle||(()=>({})),r=n.edgeStyle||(()=>({}));switch(n.chartType){case"tree":case"cluster":return function(t,e,n,i,o,r){var s,l,a,c,u;const h=[],d=[],f=[],y=n.treeOrientation||"vertical",g="radial"===y,p=i[0]/2,m=i[1]/2,v="number"==typeof(x=n.nodeSize)?x:5;var x;for(const e of t){let t=e.x,n=e.y;g&&(t+=p,n+=m);const i=o(e),r={fill:i.fill||"#4d430c",stroke:i.stroke||"#fff",strokeWidth:null!==(s=i.strokeWidth)&&void 0!==s?s:1,opacity:i.opacity};h.push({type:"circle",cx:t,cy:n,r:v,style:r,datum:e,id:e.id,label:e.id,depth:e.depth})}const b=null!==(l=n.edgeOpacity)&&void 0!==l?l:.5;for(const t of e){const e="object"==typeof t.source?t.source:null,n="object"==typeof t.target?t.target:null;if(!e||!n)continue;let i=e.x,o=e.y,s=n.x,l=n.y;g&&(i+=p,o+=m,s+=p,l+=m);const u=Zt(i,o,s,l,y),h=r(t),f={fill:"none",stroke:h.stroke||"#999",strokeWidth:null!==(a=h.strokeWidth)&&void 0!==a?a:1.5,opacity:null!==(c=h.opacity)&&void 0!==c?c:b};d.push({type:"curved",pathD:u,style:f,datum:t})}if(!1!==n.showLabels){const e=Qt(n.nodeLabel);for(const n of t){const t=e?e(n):n.id;if(!t)continue;let i,o,r,s=n.x,l=n.y;if(g&&(s+=p,l+=m),g){const t=s-p,e=l-m,n=Math.sqrt(t*t+e*e);n>0?(i=s+t/n*10,o=l+e/n*10,r=0>t?"end":"start"):(i=s,o=l-12,r="middle")}else"horizontal"===y?((null===(u=n.data)||void 0===u?void 0:u.children)&&0!==n.data.children.length?(i=s-v-6,r="end"):(i=s+v+6,r="start"),o=l):(i=s,o=l+v+14,r="middle");f.push({x:i,y:o,text:t+"",anchor:r,baseline:"middle",fontSize:11})}}return{sceneNodes:h,sceneEdges:d,labels:f}}(t,e,n,i,o,r);case"treemap":case"partition":return function(t,e,n,i){var o,r;const s=[],l=[],a=["#e8d5b7","#b8d4e3","#d4e3b8","#e3c4d4","#d4d4e3","#e3d4b8","#b8e3d4","#e3b8b8"];for(const n of t){const t=n.x1-n.x0,r=n.y1-n.y0;if(0>=t||0>=r)continue;const l=i(n);let c=l.fill||"#4d430c";e.colorByDepth&&void 0!==n.depth&&(c=a[n.depth%a.length]);const u={fill:c,stroke:l.stroke||"#fff",strokeWidth:null!==(o=l.strokeWidth)&&void 0!==o?o:1,opacity:l.opacity};s.push({type:"rect",x:n.x0,y:n.y0,w:t,h:r,style:u,datum:n,id:n.id,label:n.id,depth:n.depth})}if(!1!==e.showLabels){const n=Qt(e.nodeLabel);for(const i of t){const t=i.x1-i.x0,o=i.y1-i.y0;if(0>=t||0>=o)continue;if((null===(r=i.data)||void 0===r?void 0:r.children)&&i.data.children.length>0&&"partition"!==e.chartType)continue;const s=n?n(i):i.id;s&&(30>t||16>o||l.push({x:i.x0+t/2,y:i.y0+o/2,text:s+"",anchor:"middle",baseline:"middle",fontSize:Math.min(11,Math.max(8,Math.min(t,o)/6))}))}}return{sceneNodes:s,sceneEdges:[],labels:l}}(t,n,0,o);case"circlepack":return function(t,e,n,i){var o,r,s,l,a;const c=[],u=[],h=["#e8d5b7","#b8d4e3","#d4e3b8","#e3c4d4","#d4d4e3","#e3d4b8","#b8e3d4","#e3b8b8"];for(const n of t){const t=null!==(o=n.__radius)&&void 0!==o?o:5;if(0>=t)continue;const l=i(n);let a=l.fill||"#4d430c";e.colorByDepth&&void 0!==n.depth&&(a=h[n.depth%h.length]);const u={fill:a,stroke:l.stroke||"#fff",strokeWidth:null!==(r=l.strokeWidth)&&void 0!==r?r:1,opacity:null!==(s=l.opacity)&&void 0!==s?s:.7};c.push({type:"circle",cx:n.x,cy:n.y,r:t,style:u,datum:n,id:n.id,label:n.id,depth:n.depth})}if(!1!==e.showLabels){const n=Qt(e.nodeLabel);for(const e of t){const t=null!==(l=e.__radius)&&void 0!==l?l:5,i=n?n(e):e.id;if(!i)continue;if(15>t)continue;const o=!((null===(a=e.data)||void 0===a?void 0:a.children)&&e.data.children.length>0);u.push({x:e.x,y:o?e.y:e.y-t+14,text:i+"",anchor:"middle",baseline:o?"middle":"hanging",fontSize:Math.min(11,Math.max(8,t/3)),fill:o?void 0:"#000",stroke:o?void 0:"#fff",strokeWidth:o?void 0:3,paintOrder:o?void 0:"stroke"})}}return{sceneNodes:c,sceneEdges:[],labels:u}}(t,n,0,o);default:return{sceneNodes:[],sceneEdges:[],labels:[]}}}};function Gt(t,e,n){const i=n.treeOrientation||"vertical";if("radial"===i){const n=e.x,i=e.y;t.x=i*Math.cos(n-Math.PI/2),t.y=i*Math.sin(n-Math.PI/2)}else"horizontal"===i?(t.x=e.y,t.y=e.x):(t.x=e.x,t.y=e.y);t.x0=t.x-5,t.x1=t.x+5,t.y0=t.y-5,t.y1=t.y+5,t.width=10,t.height=10}function Vt(t,e){t.x0=e.x0,t.x1=e.x1,t.y0=e.y0,t.y1=e.y1,t.x=(e.x0+e.x1)/2,t.y=(e.y0+e.y1)/2,t.width=e.x1-e.x0,t.height=e.y1-e.y0}function qt(t,e){var n;const i=null!==(n=e.r)&&void 0!==n?n:0;t.x=e.x,t.y=e.y,t.x0=e.x-i,t.x1=e.x+i,t.y0=e.y-i,t.y1=e.y+i,t.width=2*i,t.height=2*i,t.__radius=i}function Zt(t,e,n,i,o){if("horizontal"===o){const o=(t+n)/2;return`M ${t},${e} C ${o},${e} ${o},${i} ${n},${i}`}if("radial"===o){const o=(t+n)/2;return`M ${t},${e} Q ${o},${e} ${o},${(e+i)/2} T ${n},${i}`}{const o=(e+i)/2;return`M ${t},${e} C ${t},${o} ${n},${o} ${n},${i}`}}function Kt(t,e,n){const i=e.nodeIDAccessor;return"function"==typeof i?i(t.data)+"":"string"==typeof i&&void 0!==t.data[i]?t.data[i]+"":void 0!==t.data.name?t.data.name+"":void 0!==t.data.id?t.data.id+"":"node-"+n}function Qt(t){return t?"function"==typeof t?t:e=>{var n;return(null===(n=e.data)||void 0===n?void 0:n[t])||e[t]||e.id}:null}const Ut={sankey:Bt,force:Lt,chord:jt,tree:Ht,cluster:Ht,treemap:Ht,circlepack:Ht,partition:Ht};function Jt(t){return Ut[t]}class te{constructor(t){this.nodes=new Map,this.edges=new Map,this.tension=0,this.layoutVersion=0,this.sceneNodes=[],this.sceneEdges=[],this.labels=[],this.particlePool=null,this.transition=null,this.config=t,this.tensionConfig=Object.assign(Object.assign({},Nt),t.tensionConfig),"sankey"===t.chartType&&t.showParticles&&(this.particlePool=new zt(2e3))}updateConfig(t){this.config=t,this.tensionConfig=Object.assign(Object.assign({},Nt),t.tensionConfig),"sankey"===t.chartType&&t.showParticles?this.particlePool||(this.particlePool=new zt(2e3)):this.particlePool=null}ingestHierarchy(t,e){this.nodes.clear(),this.edges.clear(),this.config.__hierarchyRoot=t,this.runLayout(e)}ingestBounded(t,e,n){const{nodeIDAccessor:i="id",sourceAccessor:o="source",targetAccessor:r="target",valueAccessor:s="value"}=this.config,l="function"==typeof i?i:t=>t[i],a="function"==typeof o?o:t=>t[o],c="function"==typeof r?r:t=>t[r],u="function"==typeof s?s:t=>{var e;return null!==(e=t[s])&&void 0!==e?e:1};this.nodes.clear(),this.edges.clear();for(const e of t){const t=l(e)+"";this.nodes.set(t,Object.assign(Object.assign({},ee(t)),{data:e}))}for(const t of e){const e=a(t)+"",n=c(t)+"",i=Number(u(t))||1;this.nodes.has(e)||this.nodes.set(e,Object.assign(Object.assign({},ee(e)),{data:t})),this.nodes.has(n)||this.nodes.set(n,Object.assign(Object.assign({},ee(n)),{data:t})),this.edges.set(`${e}\0${n}`,{source:e,target:n,value:i,y0:0,y1:0,sankeyWidth:0,data:t})}this.runLayout(n)}edgeKey(t,e){return`${t}\0${e}`}ingestEdge(t){const{source:e,target:n,value:i}=t,o=0===this.nodes.size;let r=!1;this.nodes.has(e)||(this.nodes.set(e,ee(e)),this.tension+=this.tensionConfig.newNode,r=!0),this.nodes.has(n)||(this.nodes.set(n,ee(n)),this.tension+=this.tensionConfig.newNode,r=!0);const s=this.edgeKey(e,n),l=this.edges.get(s);return l?(l.value+=i,this.tension+=this.tensionConfig.weightChange):(this.edges.set(s,{source:e,target:n,value:i,y0:0,y1:0,sankeyWidth:0}),this.tension+=this.tensionConfig.newEdge,r=!0),o||r||this.tension>=this.tensionConfig.threshold}runLayout(t){const e=Jt(this.config.chartType);if(!e)return;let n=Array.from(this.nodes.values()),i=Array.from(this.edges.values());if(0!==n.length||e.hierarchical){if(this.prepareForRelayout(),e.computeLayout(n,i,this.config,t),e.hierarchical&&n.length>0){this.nodes.clear(),this.edges.clear();for(const t of n)this.nodes.set(t.id,t);for(const t of i)this.edges.set(`${"string"==typeof t.source?t.source:t.source.id}\0${"string"==typeof t.target?t.target:t.target.id}`,t)}this.finalizeLayout(),this.saveTargetPositions(),n.some(t=>void 0!==t._prevX0&&(0!==t._prevX0||0!==t._prevX1||0!==t._prevY0||0!==t._prevY1))&&this.tensionConfig.transitionDuration>0&&(this.restorePreviousPositions(),this.transition={startTime:performance.now(),duration:this.tensionConfig.transitionDuration}),this.layoutVersion++}}buildScene(t){const e=Jt(this.config.chartType);if(!e)return;const n=Array.from(this.nodes.values()),i=Array.from(this.edges.values()),{sceneNodes:o,sceneEdges:r,labels:s}=e.buildScene(n,i,this.config,t);this.sceneNodes=o,this.sceneEdges=r,this.labels=s}advanceTransition(t){if(!this.transition)return!1;const e=Math.min((t-this.transition.startTime)/this.transition.duration,1),n=1-Math.pow(1-e,3);for(const t of this.nodes.values())void 0===t._targetX0||void 0===t._prevX0||0===t._prevX0&&0===t._prevX1||(t.x0=t._prevX0+(t._targetX0-t._prevX0)*n,t.x1=t._prevX1+(t._targetX1-t._prevX1)*n,t.y0=t._prevY0+(t._targetY0-t._prevY0)*n,t.y1=t._prevY1+(t._targetY1-t._prevY1)*n);for(const t of this.edges.values())void 0!==t._targetY0&&void 0!==t._prevY0&&void 0!==t._prevSankeyWidth&&t._prevSankeyWidth>0&&(t.y0=t._prevY0+(t._targetY0-t._prevY0)*n,t.y1=t._prevY1+(t._targetY1-t._prevY1)*n,t.sankeyWidth=t._prevSankeyWidth+(t._targetSankeyWidth-t._prevSankeyWidth)*n);return this.rebuildAllBeziers(),1>e||(this.snapToTargets(),this.transition=null,!1)}prepareForRelayout(){for(const t of this.nodes.values())t._prevX0=t.x0,t._prevX1=t.x1,t._prevY0=t.y0,t._prevY1=t.y1;for(const t of this.edges.values())t._prevY0=t.y0,t._prevY1=t.y1,t._prevSankeyWidth=t.sankeyWidth}finalizeLayout(){const t="vertical"===this.config.orientation?"down":"right";for(const t of this.nodes.values())if(0!==t.x0||0!==t.x1||0!==t.y0||0!==t.y1)t.width=t.x1-t.x0,t.height=t.y1-t.y0,t.x=t.x0+t.width/2,t.y=t.y0+t.height/2;else{const e=5;t.x0=t.x-e,t.x1=t.x+e,t.y0=t.y-e,t.y1=t.y+e,t.width=2*e,t.height=2*e}for(const e of this.edges.values())e.direction=t,this.updateEdgeBezier(e);this.tension=0}saveTargetPositions(){for(const t of this.nodes.values())t._targetX0=t.x0,t._targetX1=t.x1,t._targetY0=t.y0,t._targetY1=t.y1;for(const t of this.edges.values())t._targetY0=t.y0,t._targetY1=t.y1,t._targetSankeyWidth=t.sankeyWidth}restorePreviousPositions(){for(const t of this.nodes.values())void 0===t._prevX0||0===t._prevX0&&0===t._prevX1||(t.x0=t._prevX0,t.x1=t._prevX1,t.y0=t._prevY0,t.y1=t._prevY1);for(const t of this.edges.values())void 0!==t._prevY0&&void 0!==t._prevSankeyWidth&&t._prevSankeyWidth>0&&(t.y0=t._prevY0,t.y1=t._prevY1,t.sankeyWidth=t._prevSankeyWidth);this.rebuildAllBeziers()}snapToTargets(){for(const t of this.nodes.values())void 0!==t._targetX0&&(t.x0=t._targetX0,t.x1=t._targetX1,t.y0=t._targetY0,t.y1=t._targetY1);for(const t of this.edges.values())void 0!==t._targetY0&&(t.y0=t._targetY0,t.y1=t._targetY1,t.sankeyWidth=t._targetSankeyWidth);this.rebuildAllBeziers()}updateEdgeBezier(t){const e="string"==typeof t.source?this.nodes.get(t.source):t.source,n="string"==typeof t.target?this.nodes.get(t.target):t.target;e&&n&&(t.bezier=t.circular&&t.circularPathData?this.buildCircularBezier(t):this.buildStandardBezier(t,e,n))}buildStandardBezier(t,e,n){const i=(t.sankeyWidth||1)/2;if("down"===t.direction){const o=e.y1,r=n.y0,s=b(o,r);return{circular:!1,points:[{x:t.y0,y:o},{x:t.y0,y:s(.5)},{x:t.y1,y:s(.5)},{x:t.y1,y:r}],halfWidth:i}}const o=e.x1,r=n.x0,s=b(o,r);return{circular:!1,points:[{x:o,y:t.y0},{x:s(.5),y:t.y0},{x:s(.5),y:t.y1},{x:r,y:t.y1}],halfWidth:i}}buildCircularBezier(t){const e=(t.sankeyWidth||1)/2,n=t.circularPathData;let i;i="down"===t.direction?[{x:n.sourceY,y:n.sourceX},{x:n.sourceY,y:n.leftFullExtent},{x:n.verticalFullExtent,y:n.leftFullExtent},{x:n.verticalFullExtent,y:n.rightFullExtent},{x:n.targetY,y:n.rightFullExtent},{x:n.targetY,y:n.targetX}]:[{x:n.sourceX,y:n.sourceY},{x:n.leftFullExtent,y:n.sourceY},{x:n.leftFullExtent,y:n.verticalFullExtent},{x:n.rightFullExtent,y:n.verticalFullExtent},{x:n.rightFullExtent,y:n.targetY},{x:n.targetX,y:n.targetY}];const o=[];for(let t=0;i.length-1>t;t++){const e=i[t],n=i[t+1],r=n.x-e.x,s=n.y-e.y;o.push([e,{x:e.x+r/3,y:e.y+s/3},{x:e.x+2*r/3,y:e.y+2*s/3},n])}return{circular:!0,segments:o,halfWidth:e}}rebuildAllBeziers(){for(const t of this.nodes.values())t.width=t.x1-t.x0,t.height=t.y1-t.y0,t.x=t.x0+t.width/2,t.y=t.y0+t.height/2;for(const t of this.edges.values())this.updateEdgeBezier(t)}getLayoutData(){return{nodes:Array.from(this.nodes.values()),edges:Array.from(this.edges.values())}}clear(){this.nodes.clear(),this.edges.clear(),this.tension=0,this.layoutVersion=0,this.sceneNodes=[],this.sceneEdges=[],this.labels=[],this.transition=null,this.particlePool&&this.particlePool.clear()}}function ee(t){return{id:t,x0:0,x1:0,y0:0,y1:0,x:0,y:0,width:0,height:0,value:0,createdByFrame:!0}}function ne(t,e,n){switch(t.type){case"circle":return function(t,e,n){const i=e-t.cx,o=n-t.cy,r=Math.sqrt(i*i+o*o);return r>Math.max(t.r,5)+5?null:{type:"node",datum:t.datum,x:t.cx,y:t.cy,distance:r}}(t,e,n);case"rect":return function(t,e,n){return t.x>e||e>t.x+t.w||t.y>n||n>t.y+t.h?null:{type:"node",datum:t.datum,x:t.x+t.w/2,y:t.y+t.h/2,distance:0}}(t,e,n);case"arc":return function(t,e,n){const i=e-t.cx,o=n-t.cy,r=Math.sqrt(i*i+o*o);if(t.innerR-2>r||r>t.outerR+2)return null;let s=Math.atan2(o,i);0>s&&(s+=2*Math.PI);let l,a=t.startAngle,c=t.endAngle;if(0>a&&(a+=2*Math.PI),0>c&&(c+=2*Math.PI),l=a>c?s>=a||c>=s:s>=a&&c>=s,l){const e=(t.startAngle+t.endAngle)/2,n=(t.innerR+t.outerR)/2;return{type:"node",datum:t.datum,x:t.cx+n*Math.cos(e),y:t.cy+n*Math.sin(e),distance:0}}return null}(t,e,n);default:return null}}function ie(t,e,n){switch(t.type){case"bezier":return function(t,e,n){var i,o;if(!t.pathD)return null;try{const r=new Path2D(t.pathD),s=document.createElement("canvas").getContext("2d");if(!s)return null;if(s.isPointInPath(r,e,n)){const r="object"==typeof(null===(i=t.datum)||void 0===i?void 0:i.source)?t.datum.source:null,s="object"==typeof(null===(o=t.datum)||void 0===o?void 0:o.target)?t.datum.target:null;return{type:"edge",datum:t.datum,x:r&&s?(r.x1+s.x0)/2:e,y:t.datum?(t.datum.y0+t.datum.y1)/2:n,distance:0}}}catch(t){}return null}(t,e,n);case"line":return function(t,e,n){const i=t.x2-t.x1,o=t.y2-t.y1,r=i*i+o*o;if(0===r)return null;let s=((e-t.x1)*i+(n-t.y1)*o)/r;s=Math.max(0,Math.min(1,s));const l=t.x1+s*i,a=t.y1+s*o,c=Math.sqrt(Math.pow(e-l,2)+Math.pow(n-a,2));return c>5?null:{type:"edge",datum:t.datum,x:l,y:a,distance:c}}(t,e,n);case"ribbon":case"curved":return function(t,e,n){if(!t.pathD)return null;try{const i=new Path2D(t.pathD),o=document.createElement("canvas").getContext("2d");if(!o)return null;if(o.isPointInPath(i,e,n))return{type:"edge",datum:t.datum,x:e,y:n,distance:0}}catch(t){}return null}(t,e,n);default:return null}}function oe(e){const{width:n,height:i,totalWidth:o,totalHeight:r,margin:s,labels:l,title:a,legend:c,foregroundGraphics:u,annotations:h,svgAnnotationRules:d}=e;return t.createElement("svg",{width:o,height:r,style:{position:"absolute",top:0,left:0,pointerEvents:"none"}},t.createElement("g",{transform:`translate(${s.left},${s.top})`},l.map((e,n)=>t.createElement("text",{key:"label-"+n,x:e.x,y:e.y,textAnchor:e.anchor||"start",dominantBaseline:e.baseline||"middle",fontSize:e.fontSize||11,fontWeight:e.fontWeight,fill:e.fill||"currentColor",stroke:e.stroke,strokeWidth:e.strokeWidth,paintOrder:e.paintOrder,style:{pointerEvents:"none"}},e.text)),h&&d&&h.map((e,o)=>{const r=d(e,o,{width:n,height:i});return r?t.createElement(t.Fragment,{key:"annotation-"+o},r):null}),u),a&&"string"==typeof a?t.createElement("text",{x:o/2,y:16,textAnchor:"middle",fontSize:14,fontWeight:600,fill:"currentColor"},a):a?t.createElement("foreignObject",{x:0,y:0,width:o,height:s.top},a):null,c&&"object"==typeof c&&"legendGroups"in c?t.createElement("g",{transform:`translate(${o-s.right+10},${s.top})`},c.legendGroups.map((e,n)=>{var i;return t.createElement("g",{key:"legend-group-"+n},null===(i=e.items)||void 0===i?void 0:i.map((e,n)=>t.createElement("g",{key:"legend-item-"+n,transform:`translate(0,${20*n})`},t.createElement("rect",{x:0,y:0,width:12,height:12,fill:e.color,rx:2}),t.createElement("text",{x:18,y:10,fontSize:11,fill:"currentColor"},e.label))))})):c?t.createElement("g",{transform:`translate(${o-s.right+10},${s.top})`},c):null)}function re(t,e){var n,i,o,r;if(!e.pathD)return;t.save();const s=new Path2D(e.pathD);e.style.fill&&"none"!==e.style.fill&&(t.fillStyle=e.style.fill,t.globalAlpha=null!==(i=null!==(n=e.style.fillOpacity)&&void 0!==n?n:e.style.opacity)&&void 0!==i?i:.5,t.fill(s)),e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=null!==(o=e.style.strokeWidth)&&void 0!==o?o:.5,t.globalAlpha=.5*(null!==(r=e.style.opacity)&&void 0!==r?r:1),t.stroke(s)),t.restore()}function se(t,e){var n;t.save(),t.strokeStyle=e.style.stroke||"#999",t.lineWidth=null!==(n=e.style.strokeWidth)&&void 0!==n?n:1,void 0!==e.style.opacity&&(t.globalAlpha=e.style.opacity),e.style.strokeDasharray&&t.setLineDash(e.style.strokeDasharray.split(/[\s,]+/).map(Number)),t.beginPath(),t.moveTo(e.x1,e.y1),t.lineTo(e.x2,e.y2),t.stroke(),t.restore()}function le(t,e){var n,i,o,r;if(!e.pathD)return;t.save();const s=new Path2D(e.pathD);e.style.fill&&"none"!==e.style.fill&&(t.fillStyle=e.style.fill,t.globalAlpha=null!==(i=null!==(n=e.style.fillOpacity)&&void 0!==n?n:e.style.opacity)&&void 0!==i?i:.5,t.fill(s)),e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=null!==(o=e.style.strokeWidth)&&void 0!==o?o:.5,t.globalAlpha=.3*(null!==(r=e.style.opacity)&&void 0!==r?r:1),t.stroke(s)),t.restore()}function ae(t,e){var n,i;if(!e.pathD)return;t.save();const o=new Path2D(e.pathD);t.strokeStyle=e.style.stroke||"#999",t.lineWidth=null!==(n=e.style.strokeWidth)&&void 0!==n?n:1,void 0!==e.style.opacity&&(t.globalAlpha=e.style.opacity),t.stroke(o),e.style.fill&&"none"!==e.style.fill&&(t.fillStyle=e.style.fill,t.globalAlpha=null!==(i=e.style.fillOpacity)&&void 0!==i?i:.1,t.fill(o)),t.restore()}oe.displayName="NetworkSVGOverlay";const ce=M,ue={top:20,right:80,bottom:20,left:80},he={top:40,right:40,bottom:40,left:40},de=new Set(["chord","force","circlepack"]),fe=[800,600],ye={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 ge({data:e}){var n,i,o,r,s,l;if("edge"===e.type){const n=e.data;return t.createElement("div",{className:"semiotic-tooltip",style:ye},t.createElement("div",{style:{fontWeight:600}},"object"==typeof n.source?n.source.id:n.source," → ","object"==typeof n.target?n.target.id:n.target),null!=n.value&&t.createElement("div",{style:{marginTop:4,opacity:.8}},"Value:"," ","number"==typeof n.value?n.value.toLocaleString():n.value+""))}const a=e.data,c=null==a?void 0:a.__hierarchyNode;if(c){const e=[];let s=c;for(;s;){const t=null!==(r=null!==(i=null===(n=s.data)||void 0===n?void 0:n.name)&&void 0!==i?i:null===(o=s.data)||void 0===o?void 0:o.id)&&void 0!==r?r:a.id;null!=t&&e.unshift(t+""),s=s.parent}e.length>1&&e.shift();const l=e.length-1;return t.createElement("div",{className:"semiotic-tooltip",style:ye},t.createElement("div",null,e.map((e,n)=>t.createElement("span",{key:n},n>0&&t.createElement("span",{style:{margin:"0 3px",opacity:.5}}," → "),n===l?t.createElement("strong",null,e):t.createElement("span",{style:{opacity:.7}},e)))),null!=a.value&&a.value>0&&t.createElement("div",{style:{marginTop:4,opacity:.8}},"number"==typeof a.value?a.value.toLocaleString():a.value+""))}const u=((null===(s=a.sourceLinks)||void 0===s?void 0:s.length)||0)+((null===(l=a.targetLinks)||void 0===l?void 0:l.length)||0),h=(a.sourceLinks||[]).reduce((t,e)=>t+(e.value||0),0)+(a.targetLinks||[]).reduce((t,e)=>t+(e.value||0),0);return t.createElement("div",{className:"semiotic-tooltip",style:ye},t.createElement("div",{style:{fontWeight:600}},a.id),null!=a.value&&a.value>0&&t.createElement("div",{style:{marginTop:4,opacity:.8}},"Total:"," ","number"==typeof a.value?a.value.toLocaleString():a.value+""),u>0&&t.createElement("div",{style:{marginTop:4,opacity:.8}},"Connections: ",u,h!==u&&` (weighted: ${h.toLocaleString()})`))}const pe=n(function(n,a){const{chartType:c,nodes:u,edges:h,data:d,initialEdges:f,nodeIDAccessor:y="id",sourceAccessor:g="source",targetAccessor:p="target",valueAccessor:m="value",childrenAccessor:v,hierarchySum:x,orientation:b="horizontal",nodeAlign:k="justify",nodePaddingRatio:w=.05,nodeWidth:A=15,iterations:E=300,forceStrength:S=.1,padAngle:M=.01,groupWidth:_=20,sortGroups:W,edgeSort:N,treeOrientation:P="vertical",edgeType:z="curve",padding:T,paddingTop:$,tensionConfig:O,showParticles:D=!1,particleStyle:C,nodeStyle:Y,edgeStyle:B,colorBy:L,colorScheme:F="category10",edgeColorBy:X="source",edgeOpacity:R=.5,colorByDepth:j=!1,nodeSize:I=8,nodeSizeRange:H=[5,20],nodeLabel:G,showLabels:V=!0,size:q=fe,margin:Z,className:K,background:Q,enableHover:U=!0,tooltipContent:J,onTopologyChange:tt,annotations:et,svgAnnotationRules:nt,legend:it,title:ot,foregroundGraphics:rt,backgroundGraphics:st}=n,lt=de.has(c)?he:ue,at=Object.assign(Object.assign({},lt),Z),ct=q[0]-at.left-at.right,ut=q[1]-at.top-at.bottom,ht=e(()=>Object.assign(Object.assign({},Nt),O),[O]),dt=e(()=>Object.assign(Object.assign({},Pt),C),[C]),ft=e(()=>({chartType:c,nodeIDAccessor:y,sourceAccessor:g,targetAccessor:p,valueAccessor:m,childrenAccessor:v,hierarchySum:x,orientation:b,nodeAlign:k,nodePaddingRatio:w,nodeWidth:A,iterations:E,forceStrength:S,padAngle:M,groupWidth:_,sortGroups:W,edgeSort:N,treeOrientation:P,edgeType:z,padding:T,paddingTop:$,tensionConfig:ht,showParticles:D,particleStyle:dt,nodeStyle:Y,edgeStyle:B,nodeLabel:G,showLabels:V,colorBy:L,colorScheme:F,edgeColorBy:X,edgeOpacity:R,colorByDepth:j,nodeSize:I,nodeSizeRange:H}),[c,y,g,p,m,v,x,b,k,w,A,E,S,M,_,W,N,P,z,T,$,ht,D,dt,Y,B,G,V,L,F,X,R,j,I,H]),yt=i(null),gt=i(0),pt=i(0),mt=i(!0),vt=i(()=>{}),xt=i(null);xt.current||(xt.current=new te(ft));const[bt,kt]=o(null),[wt,At]=o(0),[Et,St]=o(0),Mt=i(null),_t=i(new Map),Wt=i(0),zt=r(t=>{if("function"==typeof L)return L(t);if("string"==typeof L&&t.data){const e=t.data[L];if(void 0!==e){if(!_t.current.has(e+"")){const t=Array.isArray(F)?F:ce;_t.current.set(e+"",t[Wt.current++%t.length])}return _t.current.get(e+"")}}if(!_t.current.has(t.id)){const e=Array.isArray(F)?F:ce;_t.current.set(t.id,e[Wt.current++%e.length])}return _t.current.get(t.id)},[L,F]);r(t=>{if("function"==typeof X)return X(t);const e="object"==typeof t.source?t.source:null,n="object"==typeof t.target?t.target:null;return"target"===X&&n?zt(n):e?zt(e):"#999"},[X,zt]);const Tt=r(t=>{const e="object"==typeof t.source?t.source:null,n="object"==typeof t.target?t.target:null;return"target"===(dt.colorBy||"source")&&n?zt(n):e?zt(e):"#999"},[dt.colorBy,zt]),$t="sankey"===c&&D,Ot=r(()=>{gt.current&&!$t||gt.current||(gt.current=requestAnimationFrame(()=>vt.current()))},[$t]);s(()=>{var t;null===(t=xt.current)||void 0===t||t.updateConfig(ft),mt.current=!0,Ot()},[ft,Ot]);const Dt=r(()=>{const t=xt.current;if(t&&(t.runLayout([ct,ut]),t.buildScene([ct,ut]),mt.current=!0,At(t.layoutVersion),tt)){const{nodes:e,edges:n}=t.getLayoutData();tt(e,n)}},[ct,ut,tt]),Ct=r(t=>{const e=xt.current;e&&(e.ingestEdge(t)&&Dt(),Ot())},[Dt,Ot]),Yt=r(t=>{const e=xt.current;if(!e)return;let n=!1;for(const i of t)e.ingestEdge(i)&&(n=!0);n&&Dt(),Ot()},[Dt,Ot]),Bt=r(()=>{var t;null===(t=xt.current)||void 0===t||t.clear(),_t.current.clear(),Wt.current=0,At(0),kt(null),Mt.current=null,mt.current=!0,Ot()},[Ot]),Lt=r(()=>{const t=xt.current;t&&(t.tension+=999,Dt(),Ot())},[Dt,Ot]);l(a,()=>({push:Ct,pushMany:Yt,clear:Bt,getTopology:()=>{var t,e;return null!==(e=null===(t=xt.current)||void 0===t?void 0:t.getLayoutData())&&void 0!==e?e:{nodes:[],edges:[]}},relayout:Lt,getTension:()=>{var t,e;return null!==(e=null===(t=xt.current)||void 0===t?void 0:t.tension)&&void 0!==e?e:0}}),[Ct,Yt,Bt,Lt]);const Ft=["tree","cluster","treemap","circlepack","partition"].includes(c),Xt=Ft?d||(Array.isArray(h)?void 0:h):void 0;s(()=>{const t=xt.current;if(t)if(Ft&&Xt)t.ingestHierarchy(Xt,[ct,ut]),t.buildScene([ct,ut]),mt.current=!0,Ot();else{const e=u||[],n=Array.isArray(h)?h:[];if(0===e.length&&0===n.length)return;t.ingestBounded(e,n,[ct,ut]),t.buildScene([ct,ut]),mt.current=!0,Ot()}},[u,h,d,Xt,Ft,ct,ut,ft,Ot]),s(()=>{f&&f.length>0&&Yt(f)},[]);const Rt=i(()=>{}),jt=i(()=>{});Rt.current=t=>{if(!U)return;const e=yt.current;if(!e)return;const n=e.getBoundingClientRect(),i=t.clientX-n.left-at.left,o=t.clientY-n.top-at.top;if(0>i||i>ct||0>o||o>ut)return void(Mt.current&&(Mt.current=null,kt(null),Ot()));const r=xt.current;if(!r)return;const s=function(t,e,n,i,o=30){let r=null,s=o,l=1/0;for(const e of t){const t=ne(e,n,i);if(t)if("rect"===e.type){const n=e.w*e.h;l>n&&(r=t,l=n)}else s>t.distance&&(r=t,s=t.distance)}if(r)return r;for(const t of e){const e=ie(t,n,i);e&&s>e.distance&&(r=e,s=e.distance)}return r}(r.sceneNodes,r.sceneEdges,i,o);if(!s)return void(Mt.current&&(Mt.current=null,kt(null),Ot()));const l={type:s.type,data:s.datum,x:s.x,y:s.y};Mt.current=l,kt(l),Ot()},jt.current=()=>{Mt.current&&(Mt.current=null,kt(null),Ot())};const It=r(t=>Rt.current(t),[]),Ht=r(()=>jt.current(),[]);vt.current=()=>{var t;gt.current=0;const e=yt.current;if(!e)return;const n=e.getContext("2d");if(!n)return;const i=xt.current;if(!i)return;const o=performance.now(),r=pt.current?Math.min((o-pt.current)/1e3,.1):.016;pt.current=o;const s=i.advanceTransition(o);(s||mt.current)&&i.buildScene([ct,ut]);const l="undefined"!=typeof window&&window.devicePixelRatio||1;if(e.width=q[0]*l,e.height=q[1]*l,e.style.width=q[0]+"px",e.style.height=q[1]+"px",n.scale(l,l),n.translate(at.left,at.top),n.clearRect(-at.left,-at.top,q[0],q[1]),Q&&(n.fillStyle=Q,n.fillRect(0,0,ct,ut)),function(t,e){for(const n of e)switch(n.type){case"bezier":re(t,n);break;case"line":se(t,n);break;case"ribbon":le(t,n);break;case"curved":ae(t,n)}}(n,i.sceneEdges),function(t,e){var n,i,o;for(const r of e){if("rect"!==r.type)continue;const e=r;e.w>0&&e.h>0&&(t.save(),void 0!==e.style.opacity&&(t.globalAlpha=e.style.opacity),e.style.fill&&(t.fillStyle=e.style.fill,void 0!==e.style.fillOpacity&&(t.globalAlpha=(null!==(n=e.style.opacity)&&void 0!==n?n:1)*e.style.fillOpacity),t.fillRect(e.x,e.y,e.w,e.h)),e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=null!==(i=e.style.strokeWidth)&&void 0!==i?i:1,t.globalAlpha=null!==(o=e.style.opacity)&&void 0!==o?o:1,t.strokeRect(e.x,e.y,e.w,e.h)),t.restore())}}(n,i.sceneNodes),function(t,e){var n,i,o;for(const r of e){if("circle"!==r.type)continue;const e=r;e.r>0&&(t.save(),void 0!==e.style.opacity&&(t.globalAlpha=e.style.opacity),t.beginPath(),t.arc(e.cx,e.cy,e.r,0,2*Math.PI),e.style.fill&&(t.fillStyle=e.style.fill,void 0!==e.style.fillOpacity&&(t.globalAlpha=(null!==(n=e.style.opacity)&&void 0!==n?n:1)*e.style.fillOpacity),t.fill()),e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=null!==(i=e.style.strokeWidth)&&void 0!==i?i:1,t.globalAlpha=null!==(o=e.style.opacity)&&void 0!==o?o:1,t.stroke()),t.restore())}}(n,i.sceneNodes),function(t,e){var n,i,o;for(const r of e){if("arc"!==r.type)continue;const e=r;t.save(),void 0!==e.style.opacity&&(t.globalAlpha=e.style.opacity),t.beginPath(),t.arc(e.cx,e.cy,e.outerR,e.startAngle,e.endAngle),t.arc(e.cx,e.cy,e.innerR,e.endAngle,e.startAngle,!0),t.closePath(),e.style.fill&&(t.fillStyle=e.style.fill,void 0!==e.style.fillOpacity&&(t.globalAlpha=(null!==(n=e.style.opacity)&&void 0!==n?n:1)*e.style.fillOpacity),t.fill()),e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=null!==(i=e.style.strokeWidth)&&void 0!==i?i:1,t.globalAlpha=null!==(o=e.style.opacity)&&void 0!==o?o:1,t.stroke()),t.restore()}}(n,i.sceneNodes),D&&i.particlePool){const e=Array.from(i.edges.values());if(e.length>0){!function(t,e,n,i){var o,r;const s=null!==(o=i.spawnRate)&&void 0!==o?o:Pt.spawnRate,l=null!==(r=i.maxPerEdge)&&void 0!==r?r:Pt.maxPerEdge;for(let i=0;e.length>i;i++){const o=e[i];if(!o.bezier)continue;if(t.countForEdge(i)>=l)continue;const r=o.value*s*n,a=Math.floor(r),c=r-a;let u=a;Math.random()<c&&u++;for(let e=0;u>e&&t.countForEdge(i)<l;e++)t.spawn(i)}}(i.particlePool,e,r,dt);const o=.5*(null!==(t=dt.speedMultiplier)&&void 0!==t?t:1);i.particlePool.step(r,o,e),function(t,e,n,i,o){var r,s;const l=null!==(r=i.radius)&&void 0!==r?r:Pt.radius,a=null!==(s=i.opacity)&&void 0!==s?s:Pt.opacity;t.globalAlpha=a;for(let r=0;e.particles.length>r;r++){const s=e.particles[r];if(!s.active)continue;const a=n[s.edgeIndex];if(a){if("function"==typeof i.color){const e="object"==typeof a.source?a.source:null;t.fillStyle=e?i.color(a,e):"#666"}else t.fillStyle=i.color&&"inherit"!==i.color?i.color:o(a);t.beginPath(),t.arc(s.x,s.y,l,0,2*Math.PI),t.fill()}}t.globalAlpha=1}(n,i.particlePool,e,dt,Tt)}}const a=mt.current;mt.current=!1,(a||s)&&St(t=>t+1),($t||s)&&(gt.current=requestAnimationFrame(()=>vt.current()))},s(()=>(Ot(),()=>{gt.current&&cancelAnimationFrame(gt.current)}),[Ot]),s(()=>{mt.current=!0,Ot()},[c,ct,ut,Q,Ot]);const Gt=U&&bt?t.createElement("div",{className:"stream-network-tooltip",style:{position:"absolute",left:at.left+bt.x,top:at.top+bt.y,transform:`translate(${bt.x>.6*ct?"calc(-100% - 12px)":"12px"}, ${.3*ut>bt.y?"4px":"calc(-100% - 4px)"})`,pointerEvents:"none",zIndex:2}},J?J(bt):t.createElement(ge,{data:bt})):null,Vt=xt.current;return t.createElement("div",{className:"stream-network-frame"+(K?" "+K:""),style:{position:"relative",width:q[0],height:q[1]},onMouseMove:U?It:void 0,onMouseLeave:U?Ht:void 0},st&&t.createElement("svg",{style:{position:"absolute",top:0,left:0,width:q[0],height:q[1],pointerEvents:"none"}},t.createElement("g",{transform:`translate(${at.left},${at.top})`},st)),t.createElement("canvas",{ref:yt,style:{position:"absolute",top:0,left:0}}),t.createElement(oe,{width:ct,height:ut,totalWidth:q[0],totalHeight:q[1],margin:at,labels:(null==Vt?void 0:Vt.labels)||[],title:ot,legend:it,foregroundGraphics:rt,annotations:et,svgAnnotationRules:nt,annotationFrame:Et}),Gt)});function me(t,e){return t?!0===t?{name:"hover",fields:[]}:"string"==typeof t?{name:t,fields:[]}:{name:t.name||"hover",fields:t.fields}:null}function ve(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)}}}function xe(t){const e=[];for(const[n,i]of Object.entries(t.fields))if("point"===i.type)e.push(t=>i.values.has(t[n]));else{const[t,o]=i.range;e.push(e=>{const i=e[n];return i>=t&&o>=i})}return t=>e.every(e=>e(t))}function be(t,e){let n=t.get(e);return n||(n={name:e,resolution:"union",clauses:new Map},t.set(e,n)),n}pe.displayName="StreamNetworkFrame";const[ke,we]=function(n){let i=a(null),r=ve(n);return[function({children:o}){let r=e(()=>ve(n),[]);return t.createElement(i.Provider,{value:r,children:o})},t=>{var e;let n=null!==(e=c(i))&&void 0!==e?e:r;return function(t,e){const[n,i]=o(e);return u(()=>t(()=>i(e)),[t]),n}(n.subscribe,()=>t(n.getState()))}]}(t=>({selections:new Map,setClause(e,n){t(t=>{const i=new Map(t.selections),o=be(i,e),r=new Map(o.clauses);return r.set(n.clientId,n),i.set(e,Object.assign(Object.assign({},o),{clauses:r})),{selections:i}})},clearClause(e,n){t(t=>{const i=t.selections.get(e);if(!i)return{};const o=new Map(t.selections),r=new Map(i.clauses);return r.delete(n),o.set(e,Object.assign(Object.assign({},i),{clauses:r})),{selections:o}})},setResolution(e,n){t(t=>{const i=new Map(t.selections),o=be(i,e);return i.set(e,Object.assign(Object.assign({},o),{resolution:n})),{selections:i}})},clearSelection(e){t(t=>{const n=new Map(t.selections),i=n.get(e);return i&&n.set(e,Object.assign(Object.assign({},i),{clauses:new Map})),{selections:n}})}}));function Ae(t){const n=t.name||"hover",{fields:i}=t,{predicate:o,isActive:s,selectPoints:l,clear:a}=function(t){const n=h(),i=t.clientId||n,{name:o}=t,s=we(t=>t.selections.get(o)),l=we(t=>t.setClause),a=we(t=>t.clearClause),c=e(()=>!!s&&s.clauses.size>0,[s]);return{predicate:e(()=>s&&0!==s.clauses.size?function(t,e){const n=[];for(const[i,o]of t.clauses)"crossfilter"===t.resolution&&i===e||n.push(xe(o));return 0===n.length?()=>!0:"intersect"===t.resolution?t=>n.every(e=>e(t)):t=>n.some(e=>e(t))}(s,i):()=>!0,[s,i]),isActive:c,selectPoints:r(t=>{const e={};for(const[n,i]of Object.entries(t))e[n]={type:"point",values:new Set(i)};l(o,{clientId:i,type:"point",fields:e})},[i,o,l]),selectInterval:r(t=>{const e={};for(const[n,i]of Object.entries(t))e[n]={type:"interval",range:i};l(o,{clientId:i,type:"interval",fields:e})},[i,o,l]),clear:r(()=>{a(o,i)},[a,o,i]),clientId:i}}({name:n});return{onHover:r(t=>{if(!t)return void a();const e={};for(const n of i){const i=t[n];void 0!==i&&(e[n]=[i])}Object.keys(e).length>0&&l(e)},[i,l,a]),predicate:o,isActive:s}}const Ee=n(function(e,n){const{size:o,width:s,height:a,margin:c,className:u,arrowOfTime:h="right",windowMode:d="sliding",windowSize:f=200,data:y,timeAccessor:g,valueAccessor:p,timeExtent:m,valueExtent:v,extentPadding:x,stroke:b="#007bff",strokeWidth:k=2,strokeDasharray:w,showAxes:A=!0,background:E,enableHover:S,tooltipContent:M,tooltip:_,onHover:W,annotations:N,svgAnnotationRules:P,tickFormatTime:z,tickFormatValue:T,decay:$,pulse:O,staleness:D,transition:C,linkedHover:Y}=e,B=null!=s&&null!=a?[s,a]:o||[500,300],L=null!=M?M:_,F=i(null),X=me(Y),R=Ae({name:(null==X?void 0:X.name)||"hover",fields:(null==X?void 0:X.fields)||[]}),j=r(t=>{W&&W(t),Y&&R.onHover(t?t.data||t:null)},[W,Y,R]);return l(n,()=>({push:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.push(t)},pushMany:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.pushMany(t)},clear:()=>{var t;return null===(t=F.current)||void 0===t?void 0:t.clear()},getData:()=>{var t,e;return null!==(e=null===(t=F.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]}})),t.createElement(Wt,{ref:F,chartType:"line",runtimeMode:"streaming",size:B,margin:c,className:u,arrowOfTime:h,windowMode:d,windowSize:f,data:y,timeAccessor:g,valueAccessor:p,xExtent:m,yExtent:v,extentPadding:x,lineStyle:{stroke:b,strokeWidth:k,strokeDasharray:w},showAxes:A,background:E,hoverAnnotation:S,tooltipContent:L,customHoverBehavior:j,annotations:N,svgAnnotationRules:P,tickFormatTime:z,tickFormatValue:T,decay:$,pulse:O,staleness:D,transition:C})});Ee.displayName="RealtimeLineChart";const Se=n(function(e,n){const{binSize:o,size:s,width:a,height:c,margin:u,className:h,arrowOfTime:d="right",windowMode:f="sliding",windowSize:y=200,data:g,timeAccessor:p,valueAccessor:m,timeExtent:v,valueExtent:x,extentPadding:b,categoryAccessor:k,colors:w,fill:A,stroke:E,strokeWidth:S,gap:M,showAxes:_=!0,background:W,enableHover:N,tooltipContent:P,tooltip:z,onHover:T,annotations:$,svgAnnotationRules:O,tickFormatTime:D,tickFormatValue:C,linkedHover:Y}=e,B=null!=a&&null!=c?[a,c]:s||[500,300],L=null!=P?P:z,F=i(null),X=me(Y),R=Ae({name:(null==X?void 0:X.name)||"hover",fields:(null==X?void 0:X.fields)||[]}),j=r(t=>{T&&T(t),Y&&R.onHover(t?t.data||t:null)},[T,Y,R]);l(n,()=>({push:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.push(t)},pushMany:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.pushMany(t)},clear:()=>{var t;return null===(t=F.current)||void 0===t?void 0:t.clear()},getData:()=>{var t,e;return null!==(e=null===(t=F.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]}}));const I={};return null!=A&&(I.fill=A),null!=E&&(I.stroke=E),null!=S&&(I.strokeWidth=S),null!=M&&(I.gap=M),t.createElement(Wt,{ref:F,chartType:"bar",runtimeMode:"streaming",size:B,margin:u,className:h,arrowOfTime:d,windowMode:f,windowSize:y,data:g,timeAccessor:p,valueAccessor:m,xExtent:v,yExtent:x,extentPadding:b,binSize:o,categoryAccessor:k,barColors:w,barStyle:I,showAxes:_,background:W,hoverAnnotation:N,tooltipContent:L,customHoverBehavior:j,annotations:$,svgAnnotationRules:O,tickFormatTime:D,tickFormatValue:C})});Se.displayName="RealtimeTemporalHistogram";const Me=Se,_e=n(function(e,n){const{size:o,width:s,height:a,margin:c,className:u,arrowOfTime:h="right",windowMode:d="sliding",windowSize:f=200,data:y,timeAccessor:g,valueAccessor:p,timeExtent:m,valueExtent:v,extentPadding:x,categoryAccessor:b,colors:k,radius:w,fill:A,opacity:E,stroke:S,strokeWidth:M,showAxes:_=!0,background:W,enableHover:N,tooltipContent:P,tooltip:z,onHover:T,annotations:$,svgAnnotationRules:O,tickFormatTime:D,tickFormatValue:C,linkedHover:Y}=e,B=null!=s&&null!=a?[s,a]:o||[500,300],L=null!=P?P:z,F=i(null),X=me(Y),R=Ae({name:(null==X?void 0:X.name)||"hover",fields:(null==X?void 0:X.fields)||[]}),j=r(t=>{T&&T(t),Y&&R.onHover(t?t.data||t:null)},[T,Y,R]);l(n,()=>({push:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.push(t)},pushMany:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.pushMany(t)},clear:()=>{var t;return null===(t=F.current)||void 0===t?void 0:t.clear()},getData:()=>{var t,e;return null!==(e=null===(t=F.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]}}));const I={};return null!=w&&(I.radius=w),null!=A&&(I.fill=A),null!=E&&(I.opacity=E),null!=S&&(I.stroke=S),null!=M&&(I.strokeWidth=M),t.createElement(Wt,{ref:F,chartType:"swarm",runtimeMode:"streaming",size:B,margin:c,className:u,arrowOfTime:h,windowMode:d,windowSize:f,data:y,timeAccessor:g,valueAccessor:p,xExtent:m,yExtent:v,extentPadding:x,categoryAccessor:b,barColors:k,swarmStyle:I,showAxes:_,background:W,hoverAnnotation:N,tooltipContent:L,customHoverBehavior:j,annotations:$,svgAnnotationRules:O,tickFormatTime:D,tickFormatValue:C})});_e.displayName="RealtimeSwarmChart";const We=n(function(e,n){const{size:o,width:s,height:a,margin:c,className:u,arrowOfTime:h="right",windowMode:d="sliding",windowSize:f=200,data:y,timeAccessor:g,valueAccessor:p,timeExtent:m,valueExtent:v,extentPadding:x,positiveColor:b,negativeColor:k,connectorStroke:w,connectorWidth:A,gap:E,stroke:S,strokeWidth:M,showAxes:_=!0,background:W,enableHover:N,tooltipContent:P,tooltip:z,onHover:T,annotations:$,svgAnnotationRules:O,tickFormatTime:D,tickFormatValue:C,linkedHover:Y}=e,B=null!=s&&null!=a?[s,a]:o||[500,300],L=null!=P?P:z,F=i(null),X=me(Y),R=Ae({name:(null==X?void 0:X.name)||"hover",fields:(null==X?void 0:X.fields)||[]}),j=r(t=>{T&&T(t),Y&&R.onHover(t?t.data||t:null)},[T,Y,R]);l(n,()=>({push:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.push(t)},pushMany:t=>{var e;return null===(e=F.current)||void 0===e?void 0:e.pushMany(t)},clear:()=>{var t;return null===(t=F.current)||void 0===t?void 0:t.clear()},getData:()=>{var t,e;return null!==(e=null===(t=F.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]}}));const I={};return null!=b&&(I.positiveColor=b),null!=k&&(I.negativeColor=k),null!=w&&(I.connectorStroke=w),null!=A&&(I.connectorWidth=A),null!=E&&(I.gap=E),null!=S&&(I.stroke=S),null!=M&&(I.strokeWidth=M),t.createElement(Wt,{ref:F,chartType:"waterfall",runtimeMode:"streaming",size:B,margin:c,className:u,arrowOfTime:h,windowMode:d,windowSize:f,data:y,timeAccessor:g,valueAccessor:p,xExtent:m,yExtent:v,extentPadding:x,waterfallStyle:I,showAxes:_,background:W,hoverAnnotation:N,tooltipContent:L,customHoverBehavior:j,annotations:$,svgAnnotationRules:O,tickFormatTime:D,tickFormatValue:C})});We.displayName="RealtimeWaterfallChart";const Ne=n(function(e,n){const{size:o,width:r,height:s,margin:a,className:c,arrowOfTime:u="right",windowMode:h="sliding",windowSize:d=200,data:f,timeAccessor:y,valueAccessor:g,categoryAccessor:p,timeExtent:m,valueExtent:v,extentPadding:x,heatmapXBins:b=20,heatmapYBins:k=20,aggregation:w="count",showAxes:A=!0,background:E,enableHover:S,tooltipContent:M,tooltip:_,onHover:W,annotations:N,svgAnnotationRules:P,tickFormatTime:z,tickFormatValue:T,decay:$,pulse:O,staleness:D}=e,C=null!=r&&null!=s?[r,s]:o||[500,300],Y=null!=M?M:_,B=i(null);return l(n,()=>({push:t=>{var e;return null===(e=B.current)||void 0===e?void 0:e.push(t)},pushMany:t=>{var e;return null===(e=B.current)||void 0===e?void 0:e.pushMany(t)},clear:()=>{var t;return null===(t=B.current)||void 0===t?void 0:t.clear()},getData:()=>{var t,e;return null!==(e=null===(t=B.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]}})),t.createElement(Wt,{ref:B,chartType:"heatmap",runtimeMode:"streaming",size:C,margin:a,className:c,arrowOfTime:u,windowMode:h,windowSize:d,data:f,timeAccessor:y,valueAccessor:g,categoryAccessor:p,xExtent:m,yExtent:v,extentPadding:x,heatmapXBins:b,heatmapYBins:k,heatmapAggregation:w,showAxes:A,background:E,hoverAnnotation:S,tooltipContent:Y,customHoverBehavior:W,annotations:N,svgAnnotationRules:P,tickFormatTime:z,tickFormatValue:T,decay:$,pulse:O,staleness:D})});Ne.displayName="RealtimeHeatmap";export{V as IncrementalExtent,Ne as RealtimeHeatmap,Me as RealtimeHistogram,Ee as RealtimeLineChart,_e as RealtimeSwarmChart,We as RealtimeWaterfallChart,G as RingBuffer,pe as StreamNetworkFrame,Wt as StreamXYFrame};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export { LineChart } from "./charts/xy/LineChart";
|
|
2
|
+
export { AreaChart } from "./charts/xy/AreaChart";
|
|
3
|
+
export { StackedAreaChart } from "./charts/xy/StackedAreaChart";
|
|
4
|
+
export { Scatterplot } from "./charts/xy/Scatterplot";
|
|
5
|
+
export { BubbleChart } from "./charts/xy/BubbleChart";
|
|
6
|
+
export { Heatmap } from "./charts/xy/Heatmap";
|
|
7
|
+
export { ScatterplotMatrix } from "./charts/xy/ScatterplotMatrix";
|
|
8
|
+
export { LinkedCharts } from "./LinkedCharts";
|
|
9
|
+
export { useSelection, useLinkedHover, useBrushSelection, useFilteredData } from "./LinkedCharts";
|
|
10
|
+
export { BarChart } from "./charts/ordinal/BarChart";
|
|
11
|
+
export { StackedBarChart } from "./charts/ordinal/StackedBarChart";
|
|
12
|
+
export { GroupedBarChart } from "./charts/ordinal/GroupedBarChart";
|
|
13
|
+
export { SwarmPlot } from "./charts/ordinal/SwarmPlot";
|
|
14
|
+
export { BoxPlot } from "./charts/ordinal/BoxPlot";
|
|
15
|
+
export { Histogram } from "./charts/ordinal/Histogram";
|
|
16
|
+
export { ViolinPlot } from "./charts/ordinal/ViolinPlot";
|
|
17
|
+
export { DotPlot } from "./charts/ordinal/DotPlot";
|
|
18
|
+
export { PieChart } from "./charts/ordinal/PieChart";
|
|
19
|
+
export { DonutChart } from "./charts/ordinal/DonutChart";
|
|
20
|
+
export { ForceDirectedGraph } from "./charts/network/ForceDirectedGraph";
|
|
21
|
+
export { ChordDiagram } from "./charts/network/ChordDiagram";
|
|
22
|
+
export { SankeyDiagram } from "./charts/network/SankeyDiagram";
|
|
23
|
+
export { TreeDiagram } from "./charts/network/TreeDiagram";
|
|
24
|
+
export { Treemap } from "./charts/network/Treemap";
|
|
25
|
+
export { CirclePack } from "./charts/network/CirclePack";
|
|
26
|
+
export { RealtimeLineChart } from "./charts/realtime/RealtimeLineChart";
|
|
27
|
+
export { RealtimeHistogram } from "./charts/realtime/RealtimeHistogram";
|
|
28
|
+
export { RealtimeSwarmChart } from "./charts/realtime/RealtimeSwarmChart";
|
|
29
|
+
export { RealtimeWaterfallChart } from "./charts/realtime/RealtimeWaterfallChart";
|
|
30
|
+
export { RealtimeHeatmap } from "./charts/realtime/RealtimeHeatmap";
|
|
31
|
+
export { TooltipProvider } from "./store/TooltipStore";
|
|
32
|
+
export { MultiLineTooltip } from "./Tooltip/Tooltip";
|
|
33
|
+
export { ThemeProvider, useTheme } from "./ThemeProvider";
|
|
34
|
+
export { exportChart } from "./export/exportChart";
|
|
35
|
+
export { validateProps } from "./charts/shared/validateProps";
|
|
36
|
+
export type { ValidationResult } from "./charts/shared/validateProps";
|