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
|
+
"use strict";const t=require("react"),e=require("d3-scale"),n=require("d3-array"),o=require("labella"),a=require("regression"),s=require("d3-shape"),i=require("d3-contour"),r=require("d3-hexbin"),l=require("d3-scale-chromatic");function c(t){return t&&t.__esModule?t:{default:t}}function u(t){if(t&&t.__esModule)return t;const e=Object.create(null);if(t)for(const n in t)if("default"!==n){const o=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,o.get?o:{enumerable:!0,get:function(){return t[n]}})}return e.default=t,Object.freeze(e)}const d=u(t),h=c(o),p=c(a),f=5e3;class m{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,f),bounded:!0,totalSize:t.length});let e=f;const n=()=>{if(e>=t.length)return;if(t!==this.lastBoundedData)return;const o=Math.min(e+f,t.length);this.callback({inserts:t.slice(e,o),bounded:!1}),e=o,this.chunkTimer=t.length>e?requestAnimationFrame(n):0};this.chunkTimer=requestAnimationFrame(n)}push(t){this.callback({inserts:[t],bounded:!1})}pushMany(t){0!==t.length&&this.callback({inserts:t,bounded:!1})}clear(){this.chunkTimer&&(cancelAnimationFrame(this.chunkTimer),this.chunkTimer=0),this.lastBoundedData=null}}class y{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 g{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 x(t,e){if("function"==typeof t)return e=>+t(e);const n=t||e;return t=>+t[n]}function v(t,e){return"function"==typeof t?t:t?e=>e[t]+"":e?t=>t[e]+"":void 0}function b(t,e,n,o,a,s,i){return{type:"rect",x:t,y:e,w:n,h:o,style:a,datum:s,group:i}}function M(t,e){const{columns:n,config:o,resolvePieceStyle:a}=t,s=[],i=Math.min(e.width,e.height)/2-4,r="donut"===o.chartType?o.innerRadius||60:0,l=-Math.PI/2+(o.startAngle||0)*Math.PI/180,c=2*Math.PI;for(const t of Object.values(n)){const e=l+t.pctStart*c,n=l+(t.pctStart+t.pct)*c,o=a(t.pieceData[0],t.name);s.push({type:"wedge",cx:0,cy:0,innerRadius:r,outerRadius:i,startAngle:e,endAngle:n,style:o,datum:t.pieceData,category:t.name})}return s}const E={bar:function(t,e){const{scales:n,columns:o,config:a,getR:s,getStack:i,resolvePieceStyle:r}=t,{r:l,projection:c}=n,u=[],d="vertical"===c,h="horizontal"===c,p=a.normalize;for(const t of Object.values(o)){const e=new Map;for(const n of t.pieceData){const t=i?i(n):"_default";e.has(t)||e.set(t,{total:0,pieces:[]});const o=e.get(t);o.total+=s(n),o.pieces.push(n)}let n=0;if(p)for(const t of e.values())n+=Math.abs(t.total);let o=0,a=0;for(const[s,c]of e){let e=c.total;p&&n>0&&(e/=n);const f=r(c.pieces[0],i?s:t.name),m=Object.assign(Object.assign({},c.pieces[0]),{__aggregateValue:c.total,__pieceCount:c.pieces.length,category:t.name});if(d){const n=l(0>e?a:o+e),i=0>e?l(a+e)-l(a):l(o)-l(o+e);u.push(b(t.x,n,t.width,Math.abs(i),f,m,s)),0>e?a+=e:o+=e}else if(h){const n=l(0>e?a+e:o),i=0>e?l(a)-l(a+e):l(o+e)-l(o);u.push(b(n,t.x,Math.abs(i),t.width,f,m,s)),0>e?a+=e:o+=e}}}return u},clusterbar:function(t,e){const{scales:n,columns:o,getR:a,getGroup:s,resolvePieceStyle:i}=t,{r:r,projection:l}=n,c=[],u="vertical"===l,d=[],h=new Set;for(const t of Object.values(o))for(const e of t.pieceData){const t=s?s(e):"_default";h.has(t)||(h.add(t),d.push(t))}const p=d.length||1;for(const t of Object.values(o)){const e=t.width/p,n=new Map;for(const e of t.pieceData){const t=s?s(e):"_default";n.has(t)||n.set(t,[]),n.get(t).push(e)}for(let o=0;d.length>o;o++){const s=n.get(d[o])||[];for(const n of s){const s=a(n),l=i(n,t.name);if(u){const a=t.x+o*e,i=r(0),u=r(s);c.push(b(a,Math.min(i,u),e,Math.abs(i-u),l,n,d[o]))}else{const a=t.x+o*e,i=r(0),u=r(s);c.push(b(Math.min(i,u),a,Math.abs(u-i),e,l,n,d[o]))}}}}return c},point:function(t,e){var n,o;const{scales:a,columns:s,getR:i,multiScales:r,resolvePieceStyle:l}=t,{r:c,projection:u}=a,d=[],h="vertical"===u,p="radial"===u,f=r.length>0,m=2*Math.PI,y=-Math.PI/2;for(const t of Object.values(s))for(const e of t.pieceData){const a=null!==(n=e.__rIndex)&&void 0!==n?n:0,s=null!==(o=e.__rValue)&&void 0!==o?o:i(e),u=f&&r[a]||c,g=l(e,t.name),x=g.r||5;let v,b;if(p){const e=y+(t.pctStart+t.pct/2)*m,n=u(s);v=Math.cos(e)*n,b=Math.sin(e)*n}else h?(v=t.middle,b=u(s)):(v=u(s),b=t.middle);d.push({type:"point",x:v,y:b,r:x,style:g,datum:e})}return d},swarm:function(t,e){const{scales:n,columns:o,getR:a,resolvePieceStyle:s}=t,{r:i,projection:r}=n,l=[],c="vertical"===r;for(const t of Object.values(o)){const e=t.width/2;for(let n=0;t.pieceData.length>n;n++){const o=t.pieceData[n],r=a(o),u=s(o,t.name),d=u.r||4,h=(7919*n%100/100-.5)*e*.8,p=c?t.middle+h:i(r),f=c?i(r):t.middle+h;l.push({type:"point",x:p,y:f,r:d,style:u,datum:o})}}return l},pie:M,donut:M,boxplot:function(t,e){var o,a,s,i,r;const{scales:l,columns:c,config:u,getR:d,resolveSummaryStyle:h}=t,{r:p,projection:f}=l,m=[],y="vertical"===f,g=!1!==u.showOutliers;for(const t of Object.values(c)){const e=t.pieceData.map(t=>d(t)).filter(t=>null!=t&&!isNaN(t)).sort((t,e)=>t-e);if(0===e.length)continue;const l=e[0],c=e[e.length-1],u=null!==(o=n.quantile(e,.25))&&void 0!==o?o:l,f=null!==(a=n.quantile(e,.5))&&void 0!==a?a:(l+c)/2,x=null!==(s=n.quantile(e,.75))&&void 0!==s?s:c,v=x-u,b=u-1.5*v,M=x+1.5*v,E=null!==(i=e.find(t=>t>=b))&&void 0!==i?i:l,k=null!==(r=[...e].reverse().find(t=>M>=t))&&void 0!==r?r:c,w=h(t.pieceData[0],t.name),A=[];if(g)for(const e of t.pieceData){const n=d(e);if(b>n||n>M){const o=y?t.middle:p(n),a=y?p(n):t.middle;A.push({px:o,py:a,value:n,datum:e})}}if(m.push({type:"boxplot",x:y?t.middle:0,y:y?0:t.middle,projection:y?"vertical":"horizontal",columnWidth:.6*t.width,minPos:p(E),q1Pos:p(u),medianPos:p(f),q3Pos:p(x),maxPos:p(k),stats:{min:E,q1:u,median:f,q3:x,max:k},style:w,datum:t.pieceData,category:t.name,outliers:A}),g)for(const t of A)m.push({type:"point",x:t.px,y:t.py,r:3,style:{fill:w.fill||"#999",opacity:.6},datum:t.datum})}return m},violin:function(t,e){var o,a,s;const{scales:i,columns:r,config:l,getR:c,resolveSummaryStyle:u}=t,{r:d,projection:h}=i,p=[],f="vertical"===h,m=l.bins||20,y=!1!==l.showIQR;for(const t of Object.values(r)){const e=t.pieceData.map(t=>c(t)).filter(t=>null!=t&&!isNaN(t)).sort((t,e)=>t-e);if(2>e.length)continue;const i=e[0],r=e[e.length-1],l=(r-i)/m||1,h=Array(m).fill(0);for(const t of e)h[Math.min(Math.floor((t-i)/l),m-1)]++;const g=Math.max(...h,1),x=t.width/2*.9;let v="";if(f){for(let e=0;m>e;e++){const n=d(i+(e+.5)*l),o=h[e]/g*x;v+=0===e?`M ${t.middle+o} ${n}`:` L ${t.middle+o} ${n}`}for(let e=m-1;e>=0;e--){const n=d(i+(e+.5)*l);v+=` L ${t.middle-h[e]/g*x} ${n}`}v+=" Z"}else{for(let e=0;m>e;e++){const n=d(i+(e+.5)*l),o=h[e]/g*x;v+=0===e?`M ${n} ${t.middle-o}`:` L ${n} ${t.middle-o}`}for(let e=m-1;e>=0;e--)v+=` L ${d(i+(e+.5)*l)} ${t.middle+h[e]/g*x}`;v+=" Z"}const b=u(t.pieceData[0],t.name);let M;if(y&&e.length>=4){const t=null!==(o=n.quantile(e,.25))&&void 0!==o?o:i,l=null!==(a=n.quantile(e,.5))&&void 0!==a?a:(i+r)/2,c=null!==(s=n.quantile(e,.75))&&void 0!==s?s:r;M={q1Pos:d(t),medianPos:d(l),q3Pos:d(c)}}const E=f?{x:t.x,y:Math.min(d(r),d(i)),width:t.width,height:Math.abs(d(r)-d(i))}:{x:Math.min(d(i),d(r)),y:t.x,width:Math.abs(d(r)-d(i)),height:t.width};p.push({type:"violin",pathString:v,translateX:0,translateY:0,bounds:E,iqrLine:M,style:b,datum:t.pieceData,category:t.name})}return p},histogram:function(t,e){const{scales:n,columns:o,config:a,getR:s,resolveSummaryStyle:i}=t,{r:r}=n,l=[],c=a.bins||25,u=a.normalize;for(const t of Object.values(o)){const e=t.pieceData.map(t=>s(t)).filter(t=>null!=t&&!isNaN(t));if(0===e.length)continue;const n=Math.min(...e),o=(Math.max(...e)-n)/c||1,a=Array(c).fill(0);for(const t of e)a[Math.min(Math.floor((t-n)/o),c-1)]++;const d=e.length,h=Math.max(...a,1),p=i(t.pieceData[0],t.name);for(let e=0;c>e;e++){if(0===a[e])continue;const s=(u?a[e]/d:a[e]/h)*t.width*.9,i=r(n+e*o),c=r(n+(e+1)*o);l.push(b(Math.min(i,c),t.x+t.width-s,Math.abs(c-i),s,p,{bin:e,count:a[e],range:[n+e*o,n+(e+1)*o],category:t.name},t.name))}}return l},ridgeline:function(t,e){var n;const{scales:o,columns:a,config:s,getR:i,resolveSummaryStyle:r}=t,{r:l,projection:c}=o,u=[],d=s.bins||20,h="horizontal"===c,p=s.amplitude||1.5;for(const t of Object.values(a)){const e=t.pieceData.map(t=>i(t)).filter(t=>null!=t&&!isNaN(t)).sort((t,e)=>t-e);if(2>e.length)continue;const o=e[0],a=e[e.length-1],s=(a-o)/d||1,c=Array(d).fill(0);for(const t of e)c[Math.min(Math.floor((t-o)/s),d-1)]++;const f=Math.max(...c,1),m=r(t.pieceData[0],t.name),y=t.width*p;let g="";if(h){const e=t.x+t.width;g=`M ${l(o)} ${e}`;for(let t=0;d>t;t++)g+=` L ${l(o+(t+.5)*s)} ${e-c[t]/f*y}`;g+=` L ${l(a)} ${e} Z`}else{const e=t.x;g=`M ${e} ${l(o)}`;for(let t=0;d>t;t++){const n=l(o+(t+.5)*s);g+=` L ${e+c[t]/f*y} ${n}`}g+=` L ${e} ${l(a)} Z`}const x=h?{x:Math.min(l(o),l(a)),y:t.x,width:Math.abs(l(a)-l(o)),height:t.width}:{x:t.x,y:Math.min(l(a),l(o)),width:t.width,height:Math.abs(l(a)-l(o))};u.push({type:"violin",pathString:g,translateX:0,translateY:0,bounds:x,style:Object.assign(Object.assign({},m),{fillOpacity:null!==(n=m.fillOpacity)&&void 0!==n?n:.5}),datum:t.pieceData,category:t.name})}return u},timeline:function(t,e){const{scales:n,columns:o,getRawRange:a,resolvePieceStyle:s}=t,{r:i,projection:r}=n,l=[],c="horizontal"===r;for(const t of Object.values(o))for(const e of t.pieceData){const n=a(e);if(!n)continue;const[o,r]=n,u=s(e,t.name);if(c){const n=i(Math.min(o,r)),a=i(Math.max(o,r));l.push(b(n,t.x,a-n,t.width,u,e,t.name))}else{const n=i(Math.max(o,r)),a=i(Math.min(o,r));l.push(b(t.x,n,t.width,a-n,u,e,t.name))}}return l}};class k{constructor(t){this.rExtent=new g,this.rExtents=[],this.rAccessors=[],this.categories=new Set,this._colorSchemeMap=null,this._colorSchemeIndex=0,this.timestampBuffer=null,this.activeTransition=null,this.prevPositionMap=new Map,this.lastIngestTime=0,this.scales=null,this.multiScales=[],this.scene=[],this.columns={},this.version=0,this.config=t,this.buffer=new y(t.windowSize),this.getO=v(t.oAccessor||t.categoryAccessor,"category");const e="streaming"===t.runtimeMode,n=t.rAccessor;Array.isArray(n)?(this.rAccessors=n.map(t=>x(t,"value")),this.getR=this.rAccessors[0],this.rExtents=n.map(()=>new g)):(this.getR=x(e&&(t.timeAccessor||t.valueAccessor)&&t.valueAccessor||n,"value"),this.rAccessors=[this.getR],this.rExtents=[this.rExtent]),this.getStack=v(t.stackBy),this.getGroup=v(t.groupBy),this.getColor=v(t.colorAccessor),this.getConnector=v(t.connectorAccessor),t.pulse&&(this.timestampBuffer=new y(t.windowSize))}ingest(t){const e="undefined"!=typeof performance?performance.now():Date.now();if(this.lastIngestTime=e,t.bounded){this.buffer.clear(),this.rExtent.clear(),this.categories.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.categories.add(this.getO(n)),this.pushValueExtent(n)}else for(const n of t.inserts){const t=this.buffer.push(n);this.timestampBuffer&&this.timestampBuffer.push(e),this.categories.add(this.getO(n)),this.pushValueExtent(n),null!=t&&this.evictValueExtent(t)}return!0}pushValueExtent(t){if("timeline"===this.config.chartType){const e=this.getRawRange(t);e&&(this.rExtent.push(e[0]),this.rExtent.push(e[1]))}else if(this.rAccessors.length>1){for(let e=0;this.rAccessors.length>e;e++)this.rExtents[e].push(this.rAccessors[e](t));this.rExtent.push(this.getR(t))}else this.rExtent.push(this.getR(t))}evictValueExtent(t){if("timeline"===this.config.chartType){const e=this.getRawRange(t);e&&(this.rExtent.evict(e[0]),this.rExtent.evict(e[1]))}else if(this.rAccessors.length>1){for(let e=0;this.rAccessors.length>e;e++)this.rExtents[e].evict(this.rAccessors[e](t));this.rExtent.evict(this.getR(t))}else this.rExtent.evict(this.getR(t))}getRawRange(t){const e=this.config.rAccessor;if(!e)return null;const n="function"==typeof e?e(t):t[e];return Array.isArray(n)&&n.length>=2?[+n[0],+n[1]]:null}computeScene(t){const{config:n,buffer:o}=this;if(0===o.size)return this.scales=null,this.scene=[],this.columns={},void this.version++;this.rExtent.dirty&&this.rExtent.recalculate(o,this.getR);const a=o.toArray(),s=n.projection||"vertical",i=n.oExtent||this.resolveCategories(a),r=this.computeValueDomain(a,i),l="horizontal"===s,c=null!=n.barPadding?n.barPadding/("vertical"===s?t.width:t.height):.1;let u,d;if("radial"===s){u=e.scaleBand().domain(i).range([0,1]).padding(0);const o=Math.min(t.width,t.height)/2,a=n.innerRadius||0;d=e.scaleLinear().domain(r).range([a,o])}else l?(u=e.scaleBand().domain(i).range([0,t.height]).padding(c),d=e.scaleLinear().domain(r).range([0,t.width])):(u=e.scaleBand().domain(i).range([0,t.width]).padding(c),d=e.scaleLinear().domain(r).range([t.height,0]));this.scales={o:u,r:d,projection:s},this.multiScales=this.rAccessors.length>1&&n.multiAxis?this.rAccessors.map((a,s)=>{const i=this.rExtents[s];i.dirty&&i.recalculate(o,a);let[r,c]=i.extent;r===1/0&&(r=0,c=1);const u=c-r,d=u>0?u*(n.extentPadding||.05):1;return r-=d,c+=d,r>0&&(r=0),l?e.scaleLinear().domain([r,c]).range([0,t.width]):e.scaleLinear().domain([r,c]).range([t.height,0])}):[];let h=a;this.rAccessors.length>1&&(h=a.flatMap(t=>this.rAccessors.map((e,n)=>Object.assign(Object.assign({},t),{__rIndex:n,__rValue:e(t),__rName:this.resolveRAccessorName(n)})))),this.columns=this.buildColumns(h,i,u,s,t),this.config.transition&&this.scene.length>0&&this.snapshotPositions(),this.scene=this.buildSceneNodes(h,t),this.config.decay&&this.applyDecay(this.scene,a),this.config.pulse&&this.applyPulse(this.scene,a),this.config.transition&&this.prevPositionMap.size>0&&this.startTransition(),this.version++}resolveRAccessorName(t){const e=Array.isArray(this.config.rAccessor)?this.config.rAccessor[t]:this.config.rAccessor;return"string"==typeof e?e:"value"+t}resolveCategories(t){const e=Array.from(this.categories),n=this.config.oSort;if("streaming"===this.config.runtimeMode&&void 0===n)return e;if(!1===n)return e;if("function"==typeof n)return e.sort(n);const o=new Map;for(const e of t){const t=this.getO(e);o.set(t,(o.get(t)||0)+Math.abs(this.getR(e)))}return e.sort("asc"===n?(t,e)=>(o.get(t)||0)-(o.get(e)||0):(t,e)=>(o.get(e)||0)-(o.get(t)||0))}computeValueDomain(t,e){var n,o;const a=this.config.chartType,s=this.config.extentPadding||.05;if("radial"===this.config.projection&&("pie"===a||"donut"===a))return[0,1];let i=0,r=0;if("bar"===a&&this.getStack){const e=new Map,n=new Map;for(const o of t){const t=this.getO(o),a=this.getR(o);0>a?n.set(t,(n.get(t)||0)+a):e.set(t,(e.get(t)||0)+a)}for(const t of e.values())t>r&&(r=t);for(const t of n.values())i>t&&(i=t)}else if("bar"===a){const e=new Map;for(const n of t){const t=this.getO(n),o=this.getR(n);e.set(t,(e.get(t)||0)+o)}for(const t of e.values())t>r&&(r=t),i>t&&(i=t)}else if("clusterbar"===a)for(const e of t){const t=this.getR(e);t>r&&(r=t),i>t&&(i=t)}else{const t=this.rExtent.extent[0],e=this.rExtent.extent[1];t!==1/0&&(i=t),e!==-1/0&&(r=e)}this.config.rExtent&&(null!=this.config.rExtent[0]&&(i=this.config.rExtent[0]),null!=this.config.rExtent[1]&&(r=this.config.rExtent[1]));const l=r-i,c=l>0?l*s:1;return(null===(n=this.config.rExtent)||void 0===n?void 0:n[0])||(i-=c),(null===(o=this.config.rExtent)||void 0===o?void 0:o[1])||(r+=c),"bar"!==a&&"clusterbar"!==a||(i>0&&(i=0),0>r&&(r=0)),[i,r]}buildColumns(t,e,n,o,a){var s;const i={},r=new Map;for(const e of t){const t=this.getO(e);r.has(t)||r.set(t,[]),r.get(t).push(e)}let l=0;if("radial"===o)for(const e of t)l+=Math.abs(this.getR(e));const c=this.config.dynamicColumnWidth;let u=null;if(c&&"radial"!==o){u=new Map;let t=0;for(const n of e){const e=r.get(n)||[];let o;o="string"==typeof c?e.reduce((t,e)=>t+(Number(e[c])||0),0):c(e),u.set(n,o),t+=o}const s=("horizontal"===o?a.height:a.width)-n.padding()*n.step()*e.length;if(t>0)for(const[e,n]of u)u.set(e,n/t*s)}let d=0,h=0;for(const t of e){const e=r.get(t)||[],o=e.reduce((t,e)=>t+Math.abs(this.getR(e)),0),a=l>0?o/l:0;let c,p;u?(c=h,p=u.get(t)||n.bandwidth(),h+=p+n.padding()*n.step()):(c=null!==(s=n(t))&&void 0!==s?s:0,p=n.bandwidth()),i[t]={name:t,x:c,y:0,width:p,middle:c+p/2,padding:n.padding()*n.step(),pieceData:e,pct:a,pctStart:d},d+=a}return i}getSceneContext(){return{scales:this.scales,columns:this.columns,config:this.config,getR:this.getR,getStack:this.getStack,getGroup:this.getGroup,getColor:this.getColor,getConnector:this.getConnector,getO:this.getO,multiScales:this.multiScales,rAccessors:this.rAccessors,resolvePieceStyle:(t,e)=>this.resolvePieceStyle(t,e),resolveSummaryStyle:(t,e)=>this.resolveSummaryStyle(t,e),getRawRange:t=>this.getRawRange(t)}}buildSceneNodes(t,e){if(!this.scales)return[];const n=this.getSceneContext(),o=E[this.config.chartType];let a=o?o(n,e):[];if(this.getConnector&&this.scales){const t=function(t,e){const{scales:n,config:o,getConnector:a,getO:s}=t;if(!a||!n)return[];const i=[],{projection:r}=n,l=new Map;for(const t of e){if("point"!==t.type&&"rect"!==t.type)continue;const e=t.datum;if(!e)continue;const n=a(e);if(!n)continue;let o,i;"point"===t.type?(o=t.x,i=t.y):(o=t.x+t.w/2,i=t.y+("vertical"===r?0:t.h/2)),l.has(n)||l.set(n,[]),l.get(n).push({x:o,y:i,datum:e,category:s(e)})}const c=n.o.domain(),u=o.connectorStyle;for(const[t,e]of l)if(e.length>=2){e.sort((t,e)=>c.indexOf(t.category)-c.indexOf(e.category));for(let n=0;e.length-1>n;n++){const o=e[n],a=e[n+1],s="function"==typeof u?u(o.datum):u||{stroke:"#999",strokeWidth:1,opacity:.5};i.push({type:"connector",x1:o.x,y1:o.y,x2:a.x,y2:a.y,style:s,datum:o.datum,group:t})}}return i}(n,a);a=[...t,...a]}return a}resolvePieceStyle(t,e){return"function"==typeof this.config.pieceStyle?this.config.pieceStyle(t,e):this.config.pieceStyle&&"object"==typeof this.config.pieceStyle?this.config.pieceStyle:this.config.barColors&&e?{fill:this.config.barColors[e]||"#007bff"}:e?{fill:this.getColorFromScheme(e)}:{fill:"#007bff"}}getColorFromScheme(t){this._colorSchemeMap||(this._colorSchemeMap=new Map);const e=this._colorSchemeMap.get(t);if(e)return e;const n=Array.isArray(this.config.colorScheme)?this.config.colorScheme:["#4e79a7","#f28e2b","#e15759","#76b7b2","#59a14f","#edc948","#b07aa1","#ff9da7","#9c755f","#bab0ac"],o=n[this._colorSchemeIndex%n.length];return this._colorSchemeIndex++,this._colorSchemeMap.set(t,o),o}resolveSummaryStyle(t,e){return"function"==typeof this.config.summaryStyle?this.config.summaryStyle(t,e):this.config.summaryStyle&&"object"==typeof this.config.summaryStyle?this.config.summaryStyle:{fill:"#007bff",fillOpacity:.6,stroke:"#007bff",strokeWidth:1}}computeDecayOpacity(t,e){var n,o,a;const s=this.config.decay;if(!s||1>=e)return 1;const i=null!==(n=s.minOpacity)&&void 0!==n?n:.1,r=e-1-t;switch(s.type){case"linear":return i+(1-r/(e-1))*(1-i);case"exponential":{const t=null!==(o=s.halfLife)&&void 0!==o?o:e/2;return i+Math.pow(.5,r/t)*(1-i)}case"step":return(null!==(a=s.stepThreshold)&&void 0!==a?a:.5*e)>r?1:i;default:return 1}}applyDecay(t,e){var n,o;if(!this.config.decay)return;const a=e.length;if(1>=a)return;const s=new Map;for(let t=0;e.length>t;t++)s.set(e[t],t);for(const e of t){if("connector"===e.type||"violin"===e.type||"boxplot"===e.type||"wedge"===e.type)continue;const t=s.get(e.datum);if(null==t)continue;const i=this.computeDecayOpacity(t,a),r=null!==(o=null===(n=e.style)||void 0===n?void 0:n.opacity)&&void 0!==o?o:1;e.style=Object.assign(Object.assign({},e.style),{opacity:r*i})}}applyPulse(t,e){var n,o;if(!this.config.pulse||!this.timestampBuffer)return;const a="undefined"!=typeof performance?performance.now():Date.now(),s=null!==(n=this.config.pulse.duration)&&void 0!==n?n:500,i=null!==(o=this.config.pulse.color)&&void 0!==o?o:"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("connector"===e.type||"violin"===e.type||"boxplot"===e.type||"wedge"===e.type)continue;const t=r.get(e.datum);if(null==t)continue;const n=this.timestampBuffer.get(t);if(null==n)continue;const o=a-n;s>o&&(e._pulseIntensity=1-o/s,e._pulseColor=i)}}get hasActivePulses(){var t;if(!this.config.pulse||!this.timestampBuffer||0===this.timestampBuffer.size)return!1;const e="undefined"!=typeof performance?performance.now():Date.now(),n=null!==(t=this.config.pulse.duration)&&void 0!==t?t:500,o=this.timestampBuffer.peek();return null!=o&&n>e-o}snapshotPositions(){var t,e;this.prevPositionMap.clear();for(let n=0;this.scene.length>n;n++){const o=this.scene[n];if("point"===o.type)this.prevPositionMap.set("p:"+n,{x:o.x,y:o.y,r:o.r});else if("rect"===o.type){const a=`r:${o.group||""}:${null!==(e=null===(t=o.datum)||void 0===t?void 0:t.category)&&void 0!==e?e:n}`;this.prevPositionMap.set(a,{x:o.x,y:o.y,w:o.w,h:o.h})}}}startTransition(){var t,e,n,o,a;if(!this.config.transition||0===this.prevPositionMap.size)return;const s=null!==(t=this.config.transition.duration)&&void 0!==t?t:300;let i=!1;for(let t=0;this.scene.length>t;t++){const s=this.scene[t];let r=null;if("point"===s.type?r="p:"+t:"rect"===s.type&&(r=`r:${s.group||""}:${null!==(n=null===(e=s.datum)||void 0===e?void 0:e.category)&&void 0!==n?n:t}`),!r)continue;const l=this.prevPositionMap.get(r);l&&("point"===s.type?l.x===s.x&&l.y===s.y||(s._targetX=s.x,s._targetY=s.y,s.x=l.x,s.y=l.y,i=!0):"rect"===s.type&&(l.x===s.x&&l.y===s.y&&l.w===s.w&&l.h===s.h||(s._targetX=s.x,s._targetY=s.y,s._targetW=s.w,s._targetH=s.h,s.x=l.x,s.y=l.y,s.w=null!==(o=l.w)&&void 0!==o?o:s.w,s.h=null!==(a=l.h)&&void 0!==a?a:s.h,i=!0)))}i&&(this.activeTransition={startTime:"undefined"!=typeof performance?performance.now():Date.now(),duration:s})}advanceTransition(t){var e,n,o;if(!this.activeTransition)return!1;const a=Math.min((t-this.activeTransition.startTime)/this.activeTransition.duration,1),s="linear"===(null===(e=this.config.transition)||void 0===e?void 0:e.easing)?a:1-Math.pow(1-a,3);for(const t of this.scene)if("point"===t.type){if(void 0===t._targetX)continue;const e=this.prevPositionMap.get("p:0");if(!e)continue;t.x=e.x+(t._targetX-e.x)*s,t.y=e.y+(t._targetY-e.y)*s}else if("rect"===t.type){if(void 0===t._targetX)continue;const e=`r:${t.group||""}:${null!==(o=null===(n=t.datum)||void 0===n?void 0:n.category)&&void 0!==o?o:0}`,a=this.prevPositionMap.get(e);if(!a)continue;t.x=a.x+(t._targetX-a.x)*s,t.y=a.y+(t._targetY-a.y)*s,void 0!==a.w&&(t.w=a.w+(t._targetW-a.w)*s,t.h=a.h+(t._targetH-a.h)*s)}if(a>=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,t._targetX=void 0,t._targetY=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}return this.activeTransition=null,!1}return!0}getData(){return this.buffer.toArray()}clear(){this.buffer.clear(),this.rExtent.clear(),this.categories.clear(),this.timestampBuffer&&this.timestampBuffer.clear(),this.prevPositionMap.clear(),this.activeTransition=null,this.lastIngestTime=0,this.scales=null,this.scene=[],this.columns={},this.version++}get size(){return this.buffer.size}getOAccessor(){return this.getO}getRAccessor(){return this.getR}updateConfig(t){t.colorScheme!==this.config.colorScheme&&(this._colorSchemeMap=null,this._colorSchemeIndex=0),Object.assign(this.config,t)}}function w(t,e,n){return t.x>e||e>t.x+t.w||t.y>n||n>t.y+t.h?null:{datum:t.datum,x:t.x+t.w/2,y:t.y,distance:0,category:t.group}}function A(t,e,n){const o=e-t.x,a=n-t.y,s=Math.sqrt(o*o+a*a);return s>Math.max(t.r,5)?null:{datum:t.datum,x:t.x,y:t.y,distance:s}}function S(t,e,n){const o=e-t.cx,a=n-t.cy,s=Math.sqrt(o*o+a*a);if(t.innerRadius>s||s>t.outerRadius)return null;let i=Math.atan2(a,o);0>i&&(i+=2*Math.PI);let r=t.startAngle%(2*Math.PI),l=t.endAngle%(2*Math.PI);if(0>r&&(r+=2*Math.PI),0>l&&(l+=2*Math.PI),!(r>l?i>=r||l>=i:i>=r&&l>=i))return null;const c=(t.startAngle+t.endAngle)/2,u=(t.innerRadius+t.outerRadius)/2;return{datum:t.datum,x:t.cx+Math.cos(c)*u,y:t.cy+Math.sin(c)*u,distance:0,category:t.category}}function P(t,e,n){const o=t.columnWidth/2;if("vertical"===t.projection){if(!(t.x-o>e||e>t.x+o||Math.min(t.minPos,t.maxPos)>n||n>Math.max(t.minPos,t.maxPos)))return{datum:t.datum,x:t.x,y:t.medianPos,distance:0,category:t.category}}else{const a=t.y-o,s=t.y+o;if(!(Math.min(t.minPos,t.maxPos)>e||e>Math.max(t.minPos,t.maxPos)||a>n||n>s))return{datum:t.datum,x:t.medianPos,y:t.y,distance:0,category:t.category}}return null}function j(t,e,n){if(!t.bounds)return null;const{x:o,y:a,width:s,height:i}=t.bounds;return o>e||e>o+s||a>n||n>a+i?null:{datum:t.datum,x:o+s/2,y:a+i/2,distance:0,category:t.category}}const $={fill:t=>d.createElement("rect",{style:t,width:20,height:20}),line:t=>d.createElement("line",{style:t,x1:0,y1:0,x2:20,y2:20})};function O(t,e,n,o){let a;return a="function"==typeof n?n(t):(0,$[n])(o(t,e)),a}function _(t){const{legendGroups:e,customClickBehavior:n,title:o="Legend",width:a=100,height:s=20,orientation:i="vertical"}=t,r="vertical"===i?(({legendGroups:t,width:e,customClickBehavior:n})=>{let o=30;const a=[];return t.forEach((t,s)=>{o+=5,a.push(d.createElement("line",{key:"legend-top-line legend-symbol-"+s,stroke:"gray",x1:0,y1:o,x2:e,y2:o})),o+=10,t.label&&(o+=20,a.push(d.createElement("text",{key:"legend-text-"+s,y:o,className:"legend-group-label"},t.label)),o+=10),a.push(d.createElement("g",{key:"legend-group-"+s,className:"legend-item",transform:`translate(0,${o})`},((t,e)=>{const{type:n="fill",styleFn:o,items:a}=t,s=[];let i=0;return a.forEach((t,a)=>{const r=O(t,a,n,o);s.push(d.createElement("g",{key:"legend-item-"+a,transform:`translate(0,${i})`,onClick:e?()=>e(t):void 0,style:{cursor:e?"pointer":"default"}},r,d.createElement("text",{y:15,x:30},t.label))),i+=25}),s})(t,n))),o+=25*t.items.length+10}),a})({legendGroups:e,width:a,customClickBehavior:n}):(({legendGroups:t,title:e,height:n,customClickBehavior:o})=>{let a=0;const s=[],i=!1===e?10:40;return t.forEach((e,r)=>{e.label&&(s.push(d.createElement("text",{key:"legend-text-"+r,transform:`translate(${a},${i}) rotate(90)`,textAnchor:"start",className:"legend-group-label"},e.label)),a+=20);const l=((t,e)=>{const{type:n="fill",styleFn:o,items:a}=t,s=[];let i=0;return a.forEach((t,a)=>{const r=O(t,a,n,o);s.push(d.createElement("g",{key:"legend-item-"+a,transform:`translate(${i},0)`,onClick:e?()=>e(t):void 0,style:{cursor:e?"pointer":"default"}},r,d.createElement("text",{y:15,x:25},t.label))),i+=35,i+=8*t.label.length}),{items:s,offset:i}})(e,o);s.push(d.createElement("g",{key:"legend-group-"+r,className:"legend-item",transform:`translate(${a},${i})`},l.items)),a+=l.offset+5,t[r+1]&&s.push(d.createElement("line",{key:"legend-top-line legend-symbol-"+r,stroke:"gray",x1:a,y1:i-10,x2:a,y2:n+i+10})),a+=15}),d.createElement("g",null,!1!==e&&d.createElement("line",{x1:0,x2:a+10,y1:i-10,y2:i-10,stroke:"gray",className:"title-neatline"}),s)})({legendGroups:e,title:o,height:s,customClickBehavior:n});return d.createElement("g",null,void 0!==o&&d.createElement("text",{className:"legend-title",y:20,x:"horizontal"===i?0:a/2,textAnchor:"horizontal"===i?"start":"middle"},o),r)}function D(t){return Math.round(100*t)/100+""}function C(e){const{width:n,height:o,totalWidth:a,totalHeight:s,margin:i,scales:r,showAxes:l,oLabel:c,rLabel:u,oFormat:h,rFormat:p,showGrid:f,title:m,legend:y,foregroundGraphics:g,annotations:x,svgAnnotationRules:v,annotationFrame:b,children:M}=e,E="radial"===(null==r?void 0:r.projection),k="horizontal"===(null==r?void 0:r.projection),w=t.useMemo(()=>l&&r&&!E?r.o.domain().map(t=>{var e;return{value:t,pixel:(null!==(e=r.o(t))&&void 0!==e?e:0)+r.o.bandwidth()/2,label:h?h(t):t}}):[],[l,r,h,E]),A=t.useMemo(()=>l&&r&&!E?r.r.ticks(5).map(t=>({value:t,pixel:r.r(t),label:(p||D)(t)})):[],[l,r,p,E]),S=t.useMemo(()=>x&&0!==x.length&&v?x.map((t,e)=>v(t,e,{scales:r?{time:r.r,value:r.r}:null,timeAxis:"x",width:n,height:o})).filter(Boolean):null,[x,v,n,o,b]);return l||m||y||g||S&&S.length>0||f||M?d.createElement("svg",{width:a,height:s,style:{position:"absolute",top:0,left:0,pointerEvents:"none"}},d.createElement("g",{transform:`translate(${i.left},${i.top})`},f&&r&&!E&&d.createElement("g",{className:"ordinal-grid"},A.map((t,e)=>d.createElement("line",{key:"grid-"+e,x1:k?t.pixel:0,y1:k?0:t.pixel,x2:k?t.pixel:n,y2:k?o:t.pixel,stroke:"#e0e0e0",strokeWidth:1}))),l&&r&&!E&&d.createElement("g",{className:"ordinal-axes"},k?d.createElement(d.Fragment,null,d.createElement("line",{x1:0,y1:0,x2:0,y2:o,stroke:"#ccc",strokeWidth:1}),w.map((t,e)=>d.createElement("g",{key:"cat-"+e,transform:`translate(0,${t.pixel})`},d.createElement("line",{x2:-5,stroke:"#ccc",strokeWidth:1}),d.createElement("text",{x:-8,textAnchor:"end",dominantBaseline:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},t.label))),c&&d.createElement("text",{x:15-i.left,y:o/2,textAnchor:"middle",fontSize:12,fill:"#333",transform:`rotate(-90, ${15-i.left}, ${o/2})`,style:{userSelect:"none"}},c),d.createElement("line",{x1:0,y1:o,x2:n,y2:o,stroke:"#ccc",strokeWidth:1}),A.map((t,e)=>d.createElement("g",{key:"val-"+e,transform:`translate(${t.pixel},${o})`},d.createElement("line",{y2:5,stroke:"#ccc",strokeWidth:1}),d.createElement("text",{y:18,textAnchor:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},t.label))),u&&d.createElement("text",{x:n/2,y:o+40,textAnchor:"middle",fontSize:12,fill:"#333",style:{userSelect:"none"}},u)):d.createElement(d.Fragment,null,d.createElement("line",{x1:0,y1:o,x2:n,y2:o,stroke:"#ccc",strokeWidth:1}),w.map((t,e)=>d.createElement("g",{key:"cat-"+e,transform:`translate(${t.pixel},${o})`},d.createElement("line",{y2:5,stroke:"#ccc",strokeWidth:1}),d.createElement("text",{y:18,textAnchor:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},t.label))),c&&d.createElement("text",{x:n/2,y:o+40,textAnchor:"middle",fontSize:12,fill:"#333",style:{userSelect:"none"}},c),d.createElement("line",{x1:0,y1:0,x2:0,y2:o,stroke:"#ccc",strokeWidth:1}),A.map((t,e)=>d.createElement("g",{key:"val-"+e,transform:`translate(0,${t.pixel})`},d.createElement("line",{x2:-5,stroke:"#ccc",strokeWidth:1}),d.createElement("text",{x:-8,textAnchor:"end",dominantBaseline:"middle",fontSize:10,fill:"#666",style:{userSelect:"none"}},t.label))),u&&d.createElement("text",{x:15-i.left,y:o/2,textAnchor:"middle",fontSize:12,fill:"#333",transform:`rotate(-90, ${15-i.left}, ${o/2})`,style:{userSelect:"none"}},u))),S,g,M),m&&d.createElement("text",{x:a/2,y:20,textAnchor:"middle",fontSize:14,fontWeight:"bold",fill:"#333",style:{userSelect:"none"}},"string"==typeof m?m:null),y&&d.createElement("g",{transform:`translate(${a-i.right+10}, ${i.top})`},"object"==typeof(P=y)&&null!==P&&!d.isValidElement(P)&&"legendGroups"in P?d.createElement(_,{legendGroups:y.legendGroups,title:"",width:100}):y)):null;var P}const N=(t,e,n,o)=>{const a=e.filter(t=>"rect"===t.type);for(const e of a)null!=e.style.opacity&&(t.globalAlpha=e.style.opacity),e.style.icon?T(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 T(t,e){const n=e.style.icon,o=e.style.iconPadding||2,a=Math.min(e.w,e.w)-o;if(0>=a)return;const s=e.h>e.w;if(t.save(),t.beginPath(),t.rect(e.x,e.y,e.w,e.h),t.clip(),s){const s=a+o,i=e.x+(e.w-a)/2;for(let o=e.y+e.h-a;o>=e.y-a;o-=s)t.drawImage(n,i,o,a,a)}else{const s=a+o,i=e.y+(e.h-a)/2;for(let o=e.x;e.x+e.w>o;o+=s)t.drawImage(n,o,i,a,a)}t.restore()}const R=(t,e,n,o)=>{var a;const s=e.filter(t=>"point"===t.type);for(const e of s){t.beginPath(),t.arc(e.x,e.y,e.r,0,2*Math.PI);const n=null!==(a=e.style.opacity)&&void 0!==a?a: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}},z=(t,e,n,o)=>{const a=e.filter(t=>"wedge"===t.type);for(const e of a)t.beginPath(),e.innerRadius>0?(t.arc(e.cx,e.cy,e.outerRadius,e.startAngle,e.endAngle),t.arc(e.cx,e.cy,e.innerRadius,e.endAngle,e.startAngle,!0)):(t.moveTo(e.cx,e.cy),t.arc(e.cx,e.cy,e.outerRadius,e.startAngle,e.endAngle)),t.closePath(),null!=e.style.opacity&&(t.globalAlpha=e.style.opacity),null!=e.style.fillOpacity&&(t.globalAlpha=e.style.fillOpacity),t.fillStyle=e.style.fill||"#007bff",t.fill(),e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=e.style.strokeWidth||1,t.stroke()),t.globalAlpha=1},B=(t,e,n,o)=>{var a,s;const i=e.filter(t=>"violin"===t.type);for(const e of i){t.save(),(e.translateX||e.translateY)&&t.translate(e.translateX,e.translateY);const n=new Path2D(e.pathString);t.globalAlpha=null!==(s=null!==(a=e.style.fillOpacity)&&void 0!==a?a:e.style.opacity)&&void 0!==s?s:.6,t.fillStyle=e.style.fill||"#007bff",t.fill(n),t.globalAlpha=1,e.style.stroke&&"none"!==e.style.stroke&&(t.strokeStyle=e.style.stroke,t.lineWidth=e.style.strokeWidth||1,t.stroke(n)),e.iqrLine&&(t.strokeStyle="#333",t.lineWidth=2,t.globalAlpha=.8,t.beginPath(),t.moveTo(0,e.iqrLine.q1Pos),t.lineTo(0,e.iqrLine.q3Pos),t.stroke(),t.beginPath(),t.arc(0,e.iqrLine.medianPos,3,0,2*Math.PI),t.fillStyle="#fff",t.fill(),t.strokeStyle="#333",t.lineWidth=1,t.stroke(),t.globalAlpha=1),t.restore()}},L=(t,e,n,o)=>{var a,s,i;const r=e.filter(t=>"connector"===t.type);if(0===r.length)return;const l=new Map;for(const t of r){const e=t.group||"_default";l.has(e)||l.set(e,[]),l.get(e).push(t)}for(const[,e]of l){if(0===e.length)continue;const n=e[0].style;if(n.fill&&"none"!==n.fill){t.beginPath(),t.moveTo(e[0].x1,e[0].y1);for(const n of e)t.lineTo(n.x2,n.y2);t.closePath(),t.globalAlpha=null!==(s=null!==(a=n.fillOpacity)&&void 0!==a?a:n.opacity)&&void 0!==s?s:.3,t.fillStyle=n.fill,t.fill(),t.globalAlpha=1}for(const n of e)t.beginPath(),t.moveTo(n.x1,n.y1),t.lineTo(n.x2,n.y2),t.strokeStyle=n.style.stroke||n.style.fill||"#999",t.lineWidth=n.style.strokeWidth||1,t.globalAlpha=null!==(i=n.style.opacity)&&void 0!==i?i:.5,t.stroke(),t.globalAlpha=1}},F=t=>[L,...t],I={bar:F([N]),clusterbar:F([N]),point:F([R]),swarm:F([R]),pie:[z],donut:[z],boxplot:F([(t,e,n,o)=>{var a,s;const i=e.filter(t=>"boxplot"===t.type);for(const e of i){const n=e.columnWidth/2,o="vertical"===e.projection,i=e.style.fill||"#007bff",r=e.style.stroke||"#333",l=e.style.strokeWidth||1,c=null!==(s=null!==(a=e.style.fillOpacity)&&void 0!==a?a:e.style.opacity)&&void 0!==s?s:.6;if(t.save(),t.strokeStyle=r,t.lineWidth=l,t.beginPath(),o?(t.moveTo(e.x,e.minPos),t.lineTo(e.x,e.maxPos)):(t.moveTo(e.minPos,e.y),t.lineTo(e.maxPos,e.y)),t.stroke(),t.beginPath(),o?(t.moveTo(e.x-.4*n,e.minPos),t.lineTo(e.x+.4*n,e.minPos),t.moveTo(e.x-.4*n,e.maxPos),t.lineTo(e.x+.4*n,e.maxPos)):(t.moveTo(e.minPos,e.y-.4*n),t.lineTo(e.minPos,e.y+.4*n),t.moveTo(e.maxPos,e.y-.4*n),t.lineTo(e.maxPos,e.y+.4*n)),t.stroke(),t.globalAlpha=c,t.fillStyle=i,o){const o=Math.min(e.q1Pos,e.q3Pos),a=Math.abs(e.q3Pos-e.q1Pos);t.fillRect(e.x-n,o,e.columnWidth,a),t.globalAlpha=1,t.strokeRect(e.x-n,o,e.columnWidth,a)}else{const o=Math.min(e.q1Pos,e.q3Pos),a=Math.abs(e.q3Pos-e.q1Pos);t.fillRect(o,e.y-n,a,e.columnWidth),t.globalAlpha=1,t.strokeRect(o,e.y-n,a,e.columnWidth)}t.strokeStyle="#fff",t.lineWidth=2,t.beginPath(),o?(t.moveTo(e.x-n,e.medianPos),t.lineTo(e.x+n,e.medianPos)):(t.moveTo(e.medianPos,e.y-n),t.lineTo(e.medianPos,e.y+n)),t.stroke(),t.restore()}},R]),violin:F([B]),histogram:F([N]),ridgeline:F([B]),timeline:F([N])},W={top:50,right:40,bottom:60,left:70},q={background:"rgba(0, 0, 0, 0.85)",color:"white",padding:"6px 10px",borderRadius:"4px",fontSize:"13px",lineHeight:"1.4",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.15)",pointerEvents:"none",whiteSpace:"nowrap"};function V({hover:t}){var e,n,o,a;const s=t.data||{};if(Array.isArray(s)){const t=(null===(e=s[0])||void 0===e?void 0:e.category)||"",n=s.length;return d.createElement("div",{className:"semiotic-tooltip",style:q},t&&d.createElement("div",{style:{fontWeight:"bold"}},t+""),d.createElement("div",null,n," items"))}if(null!=s.bin&&null!=s.count){const t=s.range||[];return d.createElement("div",{className:"semiotic-tooltip",style:q},s.category&&d.createElement("div",{style:{fontWeight:"bold"}},s.category+""),d.createElement("div",null,"Count: ",s.count),2===t.length&&d.createElement("div",{style:{opacity:.8}},Number(t[0]).toFixed(1)," – ",Number(t[1]).toFixed(1)))}const i=s.category||s.name||s.group||s.__rName||"",r=null!==(a=null!==(o=null!==(n=s.value)&&void 0!==n?n:s.__rValue)&&void 0!==o?o:s.pct)&&void 0!==a?a:"";if(!i&&""===r){const t=Object.entries(s).filter(([t])=>!t.startsWith("_")&&"data"!==t);return d.createElement("div",{className:"semiotic-tooltip",style:q},t.map(([t,e])=>d.createElement("div",{key:t},d.createElement("span",{style:{opacity:.7}},t,":")," ","number"==typeof e?e.toLocaleString():e+"")))}return d.createElement("div",{className:"semiotic-tooltip",style:q},i&&d.createElement("div",{style:{fontWeight:"bold"}},i+""),""!==r&&d.createElement("div",null,"number"==typeof r?r.toLocaleString():r+""))}const H=t.forwardRef(function(e,n){const{chartType:o,runtimeMode:a,data:s,oAccessor:i="category",rAccessor:r="value",colorAccessor:l,stackBy:c,groupBy:u,multiAxis:h,timeAccessor:p,valueAccessor:f,categoryAccessor:y,projection:g="vertical",size:x=[600,400],margin:v,barPadding:b,innerRadius:M,normalize:E,startAngle:$,dynamicColumnWidth:O,bins:_,showOutliers:D,showIQR:N,amplitude:T,connectorAccessor:R,connectorStyle:z,rExtent:B,oExtent:L,extentPadding:F=.05,oSort:q,windowMode:H="sliding",windowSize:G=200,pieceStyle:X,summaryStyle:Y,colorScheme:K,barColors:Q,showAxes:Z=!0,oLabel:J,rLabel:U,oFormat:tt,rFormat:et,enableHover:nt=!0,hoverAnnotation:ot,tooltipContent:at,customHoverBehavior:st,annotations:it,svgAnnotationRules:rt,showGrid:lt=!1,legend:ct,backgroundGraphics:ut,foregroundGraphics:dt,title:ht,className:pt,background:ft,centerContent:mt,decay:yt,pulse:gt,transition:xt,staleness:vt}=e,bt=t.useMemo(()=>Object.assign(Object.assign({},W),v),[v]),Mt=x[0]-bt.left-bt.right,Et=x[1]-bt.top-bt.bottom,kt=t.useRef(null),wt=t.useRef(!0),At=t.useRef(0),St=t.useRef(null),Pt=t.useRef(()=>{}),[jt,$t]=t.useState(null),[Ot,_t]=t.useState(null),[Dt,Ct]=t.useState(0),[Nt,Tt]=t.useState(!1),Rt=nt||ot,zt="streaming"===a,Bt=t.useMemo(()=>({chartType:o,runtimeMode:zt?"streaming":"bounded",windowSize:G,windowMode:H,extentPadding:F,projection:g,oAccessor:zt?void 0:i,rAccessor:zt?void 0:r,colorAccessor:l,stackBy:c,groupBy:u,multiAxis:h,timeAccessor:zt?p:void 0,valueAccessor:zt?f||("string"==typeof r||"function"==typeof r?r:void 0):void 0,categoryAccessor:zt?y||i:void 0,rExtent:B,oExtent:L,barPadding:b,innerRadius:M,normalize:E,startAngle:$,dynamicColumnWidth:O,bins:_,showOutliers:D,showIQR:N,amplitude:T,connectorAccessor:R,connectorStyle:z,oSort:q,pieceStyle:X,summaryStyle:Y,colorScheme:K,barColors:Q,decay:yt,pulse:gt,transition:xt,staleness:vt}),[o,G,H,F,g,i,r,l,c,u,h,p,f,y,B,L,b,M,E,$,O,_,D,N,T,R,z,q,X,Y,K,Q,yt,gt,xt,vt,zt]),Lt=t.useRef(null);Lt.current||(Lt.current=new k(Bt));const Ft=t.useCallback(()=>{At.current||(At.current=requestAnimationFrame(()=>Pt.current()))},[]);t.useEffect(()=>{var t;null===(t=Lt.current)||void 0===t||t.updateConfig(Bt),wt.current=!0,Ft()},[Bt,Ft]);const It=t.useRef(null);It.current||(It.current=new m(t=>{const e=Lt.current;e&&e.ingest(t)&&(wt.current=!0,Ft())}));const Wt=t.useCallback(t=>{var e;null===(e=It.current)||void 0===e||e.push(t)},[]),qt=t.useCallback(t=>{var e;null===(e=It.current)||void 0===e||e.pushMany(t)},[]),Vt=t.useCallback(()=>{var t,e;null===(t=It.current)||void 0===t||t.clear(),null===(e=Lt.current)||void 0===e||e.clear(),wt.current=!0,Ft()},[Ft]);t.useImperativeHandle(n,()=>({push:Wt,pushMany:qt,clear:Vt,getData:()=>{var t,e;return null!==(e=null===(t=Lt.current)||void 0===t?void 0:t.getData())&&void 0!==e?e:[]},getScales:()=>{var t,e;return null!==(e=null===(t=Lt.current)||void 0===t?void 0:t.scales)&&void 0!==e?e:null}}),[Wt,qt,Vt]),t.useEffect(()=>{var t;s&&(null===(t=It.current)||void 0===t||t.setBoundedData(s))},[s]);const Ht=t.useRef(()=>{}),Gt=t.useRef(()=>{});Ht.current=t=>{if(!Rt)return;const e=kt.current;if(!e)return;const n=e.getBoundingClientRect(),o=t.clientX-n.left-bt.left,a=t.clientY-n.top-bt.top;if(0>o||o>Mt||0>a||a>Et)return void(St.current&&(St.current=null,$t(null),st&&st(null),Ft()));const s=Lt.current;if(!s||0===s.scene.length)return;const i="radial"===g,r=function(t,e,n,o=30){let a=null;for(const s of t){let t=null;switch(s.type){case"rect":t=w(s,e,n);break;case"point":t=A(s,e,n);break;case"wedge":t=S(s,e,n);break;case"boxplot":t=P(s,e,n);break;case"violin":t=j(s,e,n)}t&&o>t.distance&&(a&&t.distance>=a.distance||(a=t))}return a}(s.scene,i?o-Mt/2:o,i?a-Et/2:a);if(!r)return void(St.current&&(St.current=null,$t(null),st&&st(null),Ft()));const l={data:r.datum,time:r.x,value:r.y,x:r.x,y:r.y};St.current=l,$t(l),st&&st(l),Ft()},Gt.current=()=>{St.current&&(St.current=null,$t(null),st&&st(null),Ft())};const Xt=t.useCallback(t=>Ht.current(t),[]),Yt=t.useCallback(()=>Gt.current(),[]);Pt.current=()=>{var t,e;At.current=0;const n=kt.current;if(!n)return;const a=n.getContext("2d");if(!a)return;const s=Lt.current;if(!s)return;const i="undefined"!=typeof performance?performance.now():Date.now(),r=s.advanceTransition(i),l=wt.current;l&&!r&&(s.computeScene({width:Mt,height:Et}),wt.current=!1);const c="undefined"!=typeof window&&window.devicePixelRatio||1;n.width=x[0]*c,n.height=x[1]*c,n.style.width=x[0]+"px",n.style.height=x[1]+"px",a.scale(c,c),a.clearRect(0,0,x[0],x[1]);const u=null!==(t=null==vt?void 0:vt.threshold)&&void 0!==t?t:5e3,d=vt&&s.lastIngestTime>0&&i-s.lastIngestTime>u;d&&(a.globalAlpha=null!==(e=null==vt?void 0:vt.dimOpacity)&&void 0!==e?e:.5),ft&&(a.fillStyle=ft,a.fillRect(0,0,x[0],x[1]));const h="radial"===g;h?(a.save(),a.translate(bt.left+Mt/2,bt.top+Et/2)):a.translate(bt.left,bt.top);const p=I[o]||[],f={width:Mt,height:Et};for(const t of p)t(a,s.scene,s.scales,f);h&&a.restore(),d&&(a.globalAlpha=1),l&&s.scales&&(_t(s.scales),Ct(t=>t+1)),(null==vt?void 0:vt.showBadge)&&Tt(!!d),(r||s.hasActivePulses)&&(At.current=requestAnimationFrame(()=>Pt.current()))},t.useEffect(()=>(Ft(),()=>{At.current&&cancelAnimationFrame(At.current)}),[Ft]),t.useEffect(()=>{wt.current=!0,Ft()},[o,Mt,Et,Z,ft,Ft]),t.useEffect(()=>{if(!vt)return;const t=setInterval(()=>{var t;const e=Lt.current;if(!e||0===e.lastIngestTime)return;const n="undefined"!=typeof performance?performance.now():Date.now(),o=null!==(t=vt.threshold)&&void 0!==t?t:5e3,a=n-e.lastIngestTime>o;a!==Nt&&(Tt(a),wt.current=!0,Ft())},1e3);return()=>clearInterval(t)},[vt,Nt,Ft]);const Kt=Rt&&jt?at?at(jt):d.createElement(V,{hover:jt}):null,Qt="radial"===g,Zt=jt?Qt?jt.x+Mt/2:jt.x:0,Jt=jt?Qt?jt.y+Et/2:jt.y:0,Ut=Kt?d.createElement("div",{className:"stream-ordinal-tooltip",style:{position:"absolute",left:bt.left+Zt,top:bt.top+Jt,transform:`translate(${Zt>.7*Mt?"calc(-100% - 12px)":"12px"}, ${.3*Et>Jt?"4px":"calc(-100% - 4px)"})`,pointerEvents:"none",zIndex:1}},Kt):null;return d.createElement("div",{className:"stream-ordinal-frame"+(pt?" "+pt:""),style:{position:"relative",width:x[0],height:x[1]},onMouseMove:Rt?Xt:void 0,onMouseLeave:Rt?Yt:void 0},ut&&d.createElement("svg",{style:{position:"absolute",top:0,left:0,width:x[0],height:x[1],pointerEvents:"none"}},d.createElement("g",{transform:`translate(${bt.left},${bt.top})`},ut)),d.createElement("canvas",{ref:kt,style:{position:"absolute",top:0,left:0,width:x[0],height:x[1]}}),d.createElement(C,{width:Mt,height:Et,totalWidth:x[0],totalHeight:x[1],margin:bt,scales:Ot,showAxes:Z,oLabel:J,rLabel:U,oFormat:tt,rFormat:et,showGrid:lt,title:ht,legend:ct,foregroundGraphics:dt,annotations:it,svgAnnotationRules:rt,annotationFrame:Dt}),mt&&"radial"===g&&d.createElement("div",{style:{position:"absolute",left:bt.left+Mt/2,top:bt.top+Et/2,transform:"translate(-50%, -50%)",pointerEvents:"none",textAlign:"center"}},mt),(null==vt?void 0:vt.showBadge)&&d.createElement("div",{className:"stream-staleness-badge",style:Object.assign(Object.assign({position:"absolute"},"top-left"===vt.badgePosition?{top:4,left:4}:"bottom-left"===vt.badgePosition?{bottom:4,left:4}:"bottom-right"===vt.badgePosition?{bottom:4,right:4}:{top:4,right:4}),{padding:"2px 8px",borderRadius:4,fontSize:11,fontWeight:600,pointerEvents:"none",background:Nt?"#dc3545":"#28a745",color:"white"})},Nt?"STALE":"LIVE"),Ut)});H.displayName="StreamOrdinalFrame";const G=({xy:t,orient:e,i:n,className:o="",jaggedBase:a})=>{let s=`M${t.x1},${t.y1}L${t.x2},${t.y2}`;return a&&0===n&&(s=((t,e)=>{let n="";const{x1:o,x2:a,y1:s,y2:i}=e;if("left"===t||"right"===t){const e=Math.abs(a-o);n=((t,e,n,o)=>{const a=t/e;let s=0,i="M0,"+n;const r="right"===o?-1:1;for(;t>=s;)i+=`L${s},${n}`,t>s&&(i+=`L${s+a/2},${n+10*r}`),s+=a;return i})(e,Math.ceil(e/40),"right"===t?0:s,t)}else{const e=Math.abs(i-s);n=((t,e,n,o)=>{const a=t/e;let s=0,i=`M${n},0`;const r="bottom"===o?-1:1;for(;t>=s;)i+=`L${n},${s}`,t>s&&(i+=`L${n+10*r},${s+a/2}`),s+=a;return i})(e,Math.ceil(e/40),o,t)}return n})(e,t)),d.createElement("path",{key:n,fill:"none",stroke:"currentColor",strokeWidth:"1px",d:s,className:`tick-line tick ${e} ${o}`})};function X(t,e,n){const o=Math.abs(n.range()[1]-n.range()[0]);return t||(e||(e=Math.max(1,Math.floor(o/40))),t=n.ticks&&n.ticks(e)||n.domain()),t}function Y({t:t,o:e,w:n}){return"contour"!==t&&"boxplot"!==t||"left"!==e&&"right"!==e?0:n/2}function K({t:t,o:e,w:n}){return"contour"!==t&&"boxplot"!==t||"top"!==e&&"bottom"!==e?0:n/2}function Q(t){const{translation:e,orient:n,decoratedSummaryType:o,summaryWidth:a,renderedSummary:s,points:i}=t;return d.default.createElement("g",{className:"marginal-graphics",transform:`translate(${e[n]})`},d.default.createElement("g",{transform:`translate(${Y({t:o.type,o:n,w:a})},${K({t:o.type,o:n,w:a})})`},s),i)}function Z(t){const{className:e,translation:n,position:o,rotation:a,labelName:s,anchorMod:i}=t;return d.default.createElement("g",{className:"axis-title "+e,transform:`translate(${[n[0]+o[0],n[1]+o[1]]}) rotate(${a})`},d.default.isValidElement(s)?s:d.default.createElement("text",{textAnchor:i},s))}function J(t){if(null==t)return"";if("number"!=typeof t)return t+"";if(!isFinite(t))return t+"";if(0===t)return"0";const e=parseFloat(t.toPrecision(12)),n=Math.abs(e);return 1e9>n?1e6>n?1e4>n?Number.isInteger(e)?e+"":parseFloat(e.toPrecision(6))+"":parseFloat((e/1e3).toPrecision(3))+"K":parseFloat((e/1e6).toPrecision(3))+"M":parseFloat((e/1e9).toPrecision(3))+"B"}function U(t,e){var n={};for(var o in t)Object.prototype.hasOwnProperty.call(t,o)&&0>e.indexOf(o)&&(n[o]=t[o]);if(null!=t&&"function"==typeof Object.getOwnPropertySymbols){var a=0;for(o=Object.getOwnPropertySymbols(t);o.length>a;a++)0>e.indexOf(o[a])&&Object.prototype.propertyIsEnumerable.call(t,o[a])&&(n[o[a]]=t[o[a]])}return n}"function"==typeof SuppressedError&&SuppressedError;function tt(t,e=120,n=8){if(!t)return[];const o=Math.max(1,Math.floor(e/n)),a=t.split(/\s+/),s=[];let i="";for(const t of a)i&&i.length+1+t.length>o?(s.push(i),i=t):i=i?`${i} ${t}`:t;return i&&s.push(i),s}function et(t,e,n,o){return"curly"===t?o?`M0,0 C${.6*n},0 ${.4*n},${e/2} ${n},${e/2} C${.4*n},${e/2} ${.6*n},${e} 0,${e}`:`M0,0 C0,${.6*n} ${e/2},${.4*n} ${e/2},${n} C${e/2},${.4*n} ${e},${.6*n} ${e},0`:o?`M0,0 L${n},0 L${n},${e} L0,${e}`:`M0,0 L0,${n} L${e},${n} L${e},0`}function nt(t){const{x:e=0,y:n=0,dx:o,dy:a,nx:s,ny:i,note:r,connector:l,subject:c,type:u,color:h,className:p,disable:f,events:m={},"data-testid":y}=t,g=new Set(Array.isArray(f)?f:[]);let x=o||0,v=a||0;null!=s&&(x=s-e),null!=i&&(v=i-n);const b="string"==typeof u?u:"label";if("bracket"===b&&c&&0===x&&0===v)if(void 0!==c.width){x=c.width/2;const t=c.depth||30;v=t+(0>t?-5:5)}else if(void 0!==c.height){const t=c.depth||30;x=t+(0>t?-5:5),v=c.height/2}return d.createElement("g",Object.assign({className:("annotation "+(p||"")).trim(),transform:`translate(${e},${n})`,"data-testid":y},m),!g.has("connector")&&function(t,e,n,o,a,s){const i=[];let r=0,l=0;if("callout-circle"!==a&&"label"!==a||!(null==s?void 0:s.radius)){if("callout-rect"===a&&s){const n=s.width||0,o=s.height||0;if(n>0||o>0){const a=n/2,s=o/2,i=t-a,c=e-s;if(0!==i||0!==c){const t=Math.abs(i),e=Math.abs(c),u=n/2,d=o/2,h=t*d>e*u?u/t:d/e;r=a+i*h,l=s+c*h}}}else if("bracket"===a&&s){const t=s.width,e=s.height,n=s.depth||30;void 0!==t?(r=t/2,l=n):void 0!==e&&(r=n,l=e/2)}}else{const n=(s.radius||0)+(s.radiusPadding||0);if(n>0&&(0!==t||0!==e)){const o=Math.atan2(e,t);r=Math.cos(o)*n,l=Math.sin(o)*n}}if(Math.sqrt(Math.pow(t-r,2)+Math.pow(e-l,2))>.5&&(i.push(d.createElement("line",{key:"connector-line",x1:r,y1:l,x2:t,y2:e,stroke:o||"currentColor"})),"arrow"===(null==n?void 0:n.end))){const n=10,a=16/180*Math.PI,s=Math.atan2(e-l,t-r);i.push(d.createElement("path",{key:"connector-arrow",d:`M${r},${l}L${r+n*Math.cos(s+a)},${l+n*Math.sin(s+a)}L${r+n*Math.cos(s-a)},${l+n*Math.sin(s-a)}Z`,fill:o||"currentColor",stroke:"none"}))}return d.createElement("g",{className:"annotation-connector"},i)}(x,v,l,h,b,c),!g.has("subject")&&function(t,e,n,o,a){var s;const i=[];switch(t){case"callout-circle":{const t=((null==e?void 0:e.radius)||0)+((null==e?void 0:e.radiusPadding)||0);t>0&&i.push(d.createElement("circle",{key:"subject-circle",r:t,fill:"none",stroke:n||"currentColor"}));break}case"callout-rect":{const t=(null==e?void 0:e.width)||0,o=(null==e?void 0:e.height)||0;(t>0||o>0)&&i.push(d.createElement("rect",{key:"subject-rect",width:t,height:o,fill:"none",stroke:n||"currentColor"}));break}case"callout-custom":(null==e?void 0:e.custom)&&i.push(...Array.isArray(e.custom)?e.custom:[e.custom]);break;case"xy-threshold":{const t=o||0,s=a||0;if(void 0!==(null==e?void 0:e.x)){const o=(e.x||0)-t;i.push(d.createElement("line",{key:"threshold-line",x1:o,y1:(e.y1||0)-s,x2:o,y2:(e.y2||0)-s,stroke:n||"currentColor",strokeDasharray:"5,5"}))}else if(void 0!==(null==e?void 0:e.y)){const o=(e.y||0)-s;i.push(d.createElement("line",{key:"threshold-line",x1:(e.x1||0)-t,y1:o,x2:(e.x2||0)-t,y2:o,stroke:n||"currentColor",strokeDasharray:"5,5"}))}else void 0!==(null==e?void 0:e.x1)||void 0!==(null==e?void 0:e.x2)?i.push(d.createElement("line",{key:"threshold-line",x1:(e.x1||0)-t,y1:0,x2:(e.x2||0)-t,y2:0,stroke:n||"currentColor",strokeDasharray:"5,5"})):void 0===(null==e?void 0:e.y1)&&void 0===(null==e?void 0:e.y2)||i.push(d.createElement("line",{key:"threshold-line",x1:0,y1:(e.y1||0)-s,x2:0,y2:(e.y2||0)-s,stroke:n||"currentColor",strokeDasharray:"5,5"}));break}case"bracket":{const t=null!==(s=null==e?void 0:e.width)&&void 0!==s?s:null==e?void 0:e.height;void 0!==t&&i.push(d.createElement("path",{key:"bracket-path",d:et((null==e?void 0:e.type)||"curly",t,(null==e?void 0:e.depth)||30,void 0===(null==e?void 0:e.width)),fill:"none",stroke:n||"currentColor"}));break}}return d.createElement("g",{className:"annotation-subject"},i)}(b,c,h,e,n),!g.has("note")&&function(t,e,n,o){if(!t)return d.createElement("g",{className:"annotation-note"});const{label:a,title:s,orientation:i,align:r,wrap:l=120,noWrap:c}=t;if(!a&&!s)return d.createElement("g",{className:"annotation-note"});let u=i;u||(u=Math.abs(e)>Math.abs(n)?"leftRight":"topBottom");let h=r;h&&"dynamic"!==h||(h="topBottom"===u?0>e?"right":"left":0>n?"bottom":"top");let p="start";"topBottom"===u?"right"===h?p="end":"middle"===h&&(p="middle"):p=0>e?"end":"start";const f=16,m=s?c?[s]:tt(s,l):[],y=a?c?[a]:tt(a,l):[],g="leftRight"===u?"end"===p?-4:4:0;let x=0;const v=[];m.length>0&&(v.push(d.createElement("text",{key:"annotation-note-title",className:"annotation-note-title",fill:o||void 0,textAnchor:p,fontWeight:"bold"},m.map((t,e)=>d.createElement("tspan",{key:e,x:g,dy:0===e?0:f},t)))),x=m.length*f),y.length>0&&v.push(d.createElement("text",{key:"annotation-note-label",className:"annotation-note-label",fill:o||void 0,textAnchor:p,y:x},y.map((t,e)=>d.createElement("tspan",{key:e,x:g,dy:f},t))));let b=null;if((s||a)&&(0!==e||0!==n))if("topBottom"===u){const t=Math.min(l,120);let e=0,n=t;"end"===p?(e=-t,n=0):"middle"===p&&(e=-t/2,n=t/2),b=d.createElement("line",{className:"note-line",x1:e,x2:n,y1:0,y2:0,stroke:o||"currentColor"})}else{const t=(m.length+y.length)*f+(y.length>0?f:0);let e=0,n=t;"bottom"===h?(e=-t,n=0):"middle"===h&&(e=-t/2,n=t/2),b=d.createElement("line",{className:"note-line",x1:0,x2:0,y1:e,y2:n,stroke:o||"currentColor"})}const M=(m.length+y.length)*f+(y.length>0?f:0);let E=0;return"topBottom"===u?0>n&&(E=-M):"leftRight"===u&&("middle"===h?E=-M/2:("bottom"===h||0>n)&&(E=-M)),d.createElement("g",{className:"annotation-note",transform:`translate(${e},${n})`},d.createElement("g",{className:"annotation-note-content",transform:0!==E?`translate(0,${E})`:void 0},v),b)}(r,x,v,h))}function ot(t){const{noteData:e}=t,{screenCoordinates:n}=e,o="string"==typeof e.type?e.type:"label",a=e.eventListeners||e.events||{};if(e.coordinates&&n){const t=e.nx||n[0][0]+e.dx,a=e.ny||n[0][1]+e.dy,s=n.map((n,s)=>{const i=Object.assign({},e,{note:0===s?e.note:{label:""},x:n[0],y:n[1],nx:t,ny:a});return d.createElement(nt,Object.assign({"data-testid":"semiotic-annotation",key:"multi-annotation-"+s},i,{type:o}))});return d.createElement("g",null,s)}const s=e.note||{title:"none",label:e.label};return d.createElement(nt,Object.assign({"data-testid":"semiotic-annotation",key:`${s.label}-${s.title}-${e.i}`,events:a},e,{type:o}))}const at=(t,e,n,o)=>{const a=(t.note.label||t.note.title).length;return[Math.min(t.note.wrap||120,a*e)+2*o,Math.ceil(a*e/120)*n+2*o]};function st(e){let n=t.createContext(null),o=it(e);return[function({children:o}){let a=t.useMemo(()=>it(e),[]);return d.createElement(n.Provider,{value:a,children:o})},e=>{var a;let s=null!==(a=t.useContext(n))&&void 0!==a?a:o;return function(e,n){const[o,a]=t.useState(n);return t.useLayoutEffect(()=>e(()=>a(n)),[e]),o}(s.subscribe,()=>e(s.getState()))}]}function it(t){let e=new EventTarget,n=t(function(t){n=Object.assign(n,t(n)),e.dispatchEvent(new CustomEvent("update"))});return{getState:()=>n,subscribe:function(t){return e.addEventListener("update",t),()=>e.removeEventListener("update",t)}}}let[rt,lt]=st(t=>({tooltip:null,changeTooltip(e){t(()=>({tooltip:e}))}}));function ct(t,e,n){return"number"==typeof n?n:e&&e.find(e=>e.props.orient===t)?50:10}const ut=(t,e,n)=>`${t.map(dt).join(",")}${JSON.stringify(e)}${n.join(",")}`;function dt(t){if(!t||!t.props||!t.props.noteData)return"";const{note:e={}}=t.props.noteData,{label:n,title:o}=e;return`${t.props.noteData.id||`${t.props.noteData.x}-${t.props.noteData.y}`}-${n}=${o}`}function ht(t,e=8,n){const{noteWidth:o=n}=t;let a=o;"number"==typeof o&&(a=()=>o);const s=t.note&&t.note.wrap||120,i=t.note.label||t.note.label||"";return o&&a(t)||(d.default.isValidElement(t.note)?100:Math.min(s,i.length*e))}function pt(t,e=8,n=20,o){const{noteHeight:a=o}=t;let s=a;"number"==typeof a&&(s=()=>a);const i=t.note&&t.note.wrap||120,r=t.note.label||t.note.title||"";return a&&s(t)||(d.default.isValidElement(t.note)?30:Math.ceil(r.length*e/i)*n+(t.note.label&&t.note.title?n:0))}const ft=(t,e)=>e.map((e,n)=>t.svgAnnotationRule(e,n,t)).filter(t=>null!=t),mt=(t,e)=>{let n=e.adjustedAnnotations,o=e.adjustedAnnotationsKey,a=e.adjustableAnnotations,s=e.fixedAnnotations,i=[],r=[];const l=e.adjustedAnnotationsKey,c=e.adjustedAnnotationsDataVersion,{annotations:u,annotationHandling:p=!1,size:f,svgAnnotationRule:m,htmlAnnotationRule:y}=t,g="object"==typeof p?p:{layout:{type:p},dataVersion:""},{dataVersion:x=""}=g;if(m){const e=ft(t,u);o=ut(e,g,f),!1===p&&(n=a),n=n.length!==a.length||l!==o||c!==x?((t,e,n)=>{const{layout:o={type:!1,noteHeight:void 0,noteWidth:void 0}}=e;if(!1===o.type)return t;const{noteWidth:a,noteHeight:s}=o;let{margin:i={top:0,bottom:0,left:0,right:0}}=n;const{size:r,axes:l=[]}=n;if(i="number"==typeof i?{top:i,left:i,right:i,bottom:i}:i,"bump"===o.type)return function(t,e,n,o,a){const{padding:s=1,characterWidth:i=8,lineHeight:r=20,iterations:l=500,pointSizeFunction:c=o,labelSizeFunction:u=a||at}=e,d=t.map((t,e)=>{const n=(t.props.noteData.x[0]||t.props.noteData.x)+(void 0!==t.props.noteData.dx?t.props.noteData.dx:-10*(e%3-1)),o=(t.props.noteData.y[0]||t.props.noteData.y)+(void 0!==t.props.noteData.dy?t.props.noteData.dy:10*(e%3-1)),[a,l]=u(t.props.noteData,i,r,s);return{x:n,y:o,above:t.props.noteData.y>o,left:t.props.noteData.x>n,width:a,height:l,type:"label",name:"",originalNote:t}}),h=t.map(t=>({x:t.props.noteData.x,y:t.props.noteData.y,fx:t.props.noteData.x,fy:t.props.noteData.y,r:c&&c(t.props.noteData)||5,type:"point",originalNote:t})),p=function(){let t,e=[],n=[],o=1,a=1,s={start:t=>{},width:t=>{},height:t=>{},label:t=>{},anchor:t=>{},alt_energy:t=>{},alt_schedule:t=>{}},i=!1;const r=function(t){let o=e.length,a=0,s=e[t].x-n[t].x,i=n[t].y-e[t].y,r=Math.sqrt(s*s+i*i);r>0&&(a+=.2*r),s/=r,i/=r,a+=s>0&&i>0?0:0>s&&i>0?3:0>s&&0>i?6:9;let l,c,d,h,p,f,m,y=e[t].x,g=e[t].y-e[t].height+2,x=e[t].x+e[t].width,v=e[t].y+2;for(let s=0;o>s;s++)s!==t&&(u(n[t].x,e[t].x,n[s].x,e[s].x,n[t].y,e[t].y,n[s].y,e[s].y)&&(a+=1),l=e[s].x,d=e[s].y-e[s].height+2,c=e[s].x+e[s].width,h=e[s].y+2,p=Math.max(0,Math.min(c,x)-Math.max(l,y)),f=Math.max(0,Math.min(h,v)-Math.max(d,g)),m=p*f,a+=30*m),l=n[s].x-n[s].r,d=n[s].y-n[s].r,c=n[s].x+n[s].r,h=n[s].y+n[s].r,p=Math.max(0,Math.min(c,x)-Math.max(l,y)),f=Math.max(0,Math.min(h,v)-Math.max(d,g)),m=p*f,a+=30*m;return a},l=function(s){let l,c,u=Math.floor(Math.random()*e.length),d=e[u].x,h=e[u].y;l=i?t(u,e,n):r(u),e[u].x+=5*(Math.random()-.5),e[u].y+=5*(Math.random()-.5),e[u].x>o&&(e[u].x=d),0>e[u].x&&(e[u].x=d),e[u].y>a&&(e[u].y=h),0>e[u].y&&(e[u].y=h),c=i?t(u,e,n):r(u);let p=c-l;Math.random()<Math.exp(-p/s)||(e[u].x=d,e[u].y=h)},c=function(s){let l,c=Math.floor(Math.random()*e.length),u=e[c].x,d=e[c].y;l=i?t(c,e,n):r(c);let h=.5*(Math.random()-.5),p=Math.sin(h),f=Math.cos(h);e[c].x-=n[c].x,e[c].y-=n[c].y;let m,y=e[c].x*p+e[c].y*f;e[c].x=e[c].x*f-e[c].y*p+n[c].x,e[c].y=y+n[c].y,e[c].x>o&&(e[c].x=u),0>e[c].x&&(e[c].x=u),e[c].y>a&&(e[c].y=d),0>e[c].y&&(e[c].y=d),m=i?t(c,e,n):r(c);let g=m-l;Math.random()<Math.exp(-g/s)||(e[c].x=u,e[c].y=d)},u=function(t,e,n,o,a,s,i,r){let l,c,u,d,h;return u=(r-i)*(e-t)-(o-n)*(s-a),d=(o-n)*(a-i)-(r-i)*(t-n),h=(e-t)*(a-i)-(s-a)*(t-n),l=d/u,c=h/u,!(0>l||l>1||0>c||c>1)},d=function(t,e,n){return t-e/n};return s.start=function(t){let n=e.length,o=1;for(let e=0;t>e;e++){for(let t=0;n>t;t++).5>Math.random()?l(o):c(o);o=d(o,1,t)}},s.width=function(t){return arguments.length?(o=t,s):o},s.height=function(t){return arguments.length?(a=t,s):a},s.label=function(t){return arguments.length?(e=t,s):e},s.anchor=function(t){return arguments.length?(n=t,s):n},s.alt_energy=function(e){return arguments.length?(t=e,i=!0,s):r},s.alt_schedule=function(t){return arguments.length?s:d},s}();return p.label(d),p.anchor(h),p.width(n[0]),p.height(n[1]),p.start(l),d.forEach(t=>{if("label"===t.type){const e=function(t,e,n){return t.y>e.y?[e.x+e.width/2+n/2,e.y-e.height+n/2]:[e.x+e.width/2,e.y]}(t.originalNote.props.noteData,t,s);t.originalNote.props.noteData.nx=e[0],t.originalNote.props.noteData.ny=e[1]}}),t}(t,o,r,n.pointSizeFunction,n.labelSizeFunction);if("marginalia"===o.type){const{marginOffset:e,orient:n="nearest",characterWidth:c=8,lineHeight:u=20,padding:p=2,axisMarginOverride:f={}}=o,m="nearest"===n?["left","right","top","bottom"]:Array.isArray(n)?n:[n],y=m.find(t=>"left"===t),g=m.find(t=>"right"===t),x=m.find(t=>"top"===t),v=m.find(t=>"bottom"===t),b=[],M=[],E=[],k=[];for(const e of t){const t=e.props.noteData,n=t.x[0]||t.x,o=t.y[0]||t.y,a=y?n:1/0,s=g?r[0]-n:1/0,i=x?o:1/0,l=Math.min(a,s,i,v?r[1]-o:1/0);a===l?b.push(e):s===l?M.push(e):i===l?E.push(e):k.push(e)}const w=new h.default.Force({minPos:void 0!==f.top?0+f.top:0-i.top,maxPos:void 0!==f.bottom?r[1]-f.bottom:v?r[1]:r[1]+i.bottom}).nodes(b.map(t=>new h.default.Node(t.props.noteData.y[0]||t.props.noteData.y,pt(t.props.noteData,c,u,a)+p))).compute(),A=new h.default.Force({minPos:void 0!==f.top?0+f.top:x?0:0-i.top,maxPos:void 0!==f.bottom?r[1]-f.bottom:r[1]+i.bottom}).nodes(M.map(t=>new h.default.Node(t.props.noteData.y[0]||t.props.noteData.y,pt(t.props.noteData,c,u,a)+p))).compute(),S=new h.default.Force({minPos:void 0!==f.left?0+f.left:y?0:0-i.left,maxPos:void 0!==f.right?r[0]-f.right:r[0]+i.right}).nodes(E.map(t=>new h.default.Node(t.props.noteData.x[0]||t.props.noteData.x,ht(t.props.noteData,c,s)+p))).compute(),P=new h.default.Force({minPos:void 0!==f.left?0+f.left:0-i.left,maxPos:void 0!==f.right?r[0]-f.right:g?r[0]:r[0]+i.right}).nodes(k.map(t=>new h.default.Node(t.props.noteData.x[0]||t.props.noteData.x,ht(t.props.noteData,c,s)+p))).compute(),j=Math.max(...k.map(t=>pt(t.props.noteData,c,u,a)+p)),$=Math.max(...E.map(t=>pt(t.props.noteData,c,u,a)+p)),O=Math.max(...b.map(t=>ht(t.props.noteData,c,s)+p)),_=Math.max(...M.map(t=>ht(t.props.noteData,c,s)+p)),D=w.nodes(),C=A.nodes(),N=S.nodes(),T=P.nodes();return b.forEach((t,n)=>{const o=0-D[n].layerIndex*O-ct("left",l,e),a=D[n].currentPos;t.props.noteData.nx=o,t.props.noteData.ny=a,t.props.noteData.note&&!d.isValidElement(t)&&(t.props.noteData.note.orientation=t.props.noteData.note.orientation||"leftRight",t.props.noteData.note.align=t.props.noteData.note.align||"right")}),M.forEach((t,n)=>{const o=r[0]+C[n].layerIndex*_+ct("right",l,e),a=C[n].currentPos;t.props.noteData.nx=o,t.props.noteData.ny=a,t.props.noteData.note&&!d.isValidElement(t)&&(t.props.noteData.note.orientation=t.props.noteData.note.orientation||"leftRight",t.props.noteData.note.align=t.props.noteData.note.align||"left")}),E.forEach((t,n)=>{const o=N[n].currentPos,a=0-N[n].layerIndex*$-ct("top",l,e);t.props.noteData.nx=o,t.props.noteData.ny=a}),k.forEach((t,n)=>{const o=T[n].currentPos,a=r[1]+T[n].layerIndex*j+ct("bottom",l,e);t.props.noteData.nx=o,t.props.noteData.ny=a}),t}return t})(a,g,t):a.map((t,e)=>{const o=Object.assign(Object.assign({},n[e].props.noteData),t.props.noteData);return d.createElement(ot,{key:t.key,noteData:o})}),i=[...n,...s]}return y&&(r=((t,e)=>e.map((e,n)=>t.htmlAnnotationRule(e,n,t)).filter(t=>null!=t))(t,u)),{svgAnnotations:i,htmlAnnotations:r,adjustedAnnotations:n,adjustedAnnotationsKey:o,adjustedAnnotationsDataVersion:x}},yt=t=>t instanceof Date?t.getTime():t,gt=({type:t="stackedarea",data:e,xProp:o,yProp:a,yPropMiddle:s,sort:i,yPropTop:r,yPropBottom:l})=>{const c=new Map,u=e.map(()=>0);let d=0;for(const t of e){t.__lineIndex=d;for(const e of t.data){const t=yt(e[o]);u[d]+=e[a],c.has(t)||c.set(t,[]),c.get(t)[d]=e}d++}let h=(t,e)=>u[e.key]-u[t.key];"stackedpercent-invert"!==t&&"stackedarea-invert"!==t||(h=(t,e)=>u[t.key]-u[e.key]),null!==(i=void 0===i?h:i)&&(e=e.sort(i));const p=e.map(t=>t.__lineIndex);for(const[,e]of c){let o=0,i=0;const c=n.sum(e,t=>(null==t?void 0:t[a])>0?t[a]:0),u=n.sum(e,t=>0>(null==t?void 0:t[a])?t[a]:0);for(const n of p){const d=e[n];if(d)if(0>d[a]){if("linepercent"===t||"stackedpercent"===t||"stackedpercent-invert"===t){const e=d[a]/u;if(d.percent=e,"linepercent"===t)d[l]=d[l]=d[r]=d[s]=e;else{const t=0>u?e:0;d[l]=0===u?0:-o/u,d[r]=d[l]-t,d[s]=d[l]-t/2}}else d[l]=o,d[r]=o+d[a],d[s]=o+d[a]/2;o+=d[a]}else{if("linepercent"===t||"stackedpercent"===t||"stackedpercent-invert"===t){const e=d[a]/c;if(d.percent=e,"linepercent"===t)d[l]=d[r]=d[s]=e;else{const t=c>0?e:0;d[l]=0===c?0:i/c,d[r]=d[l]+t,d[s]=d[l]+t/2}}else d[l]=i,d[r]=i+d[a],d[s]=i+d[a]/2;i+=d[a]}}}return e},xt=({data:t,y1:e,x1:n,yPropTop:o,yPropMiddle:a,yPropBottom:s,xPropTop:i,xPropMiddle:r,xPropBottom:l})=>{if(e)for(const n of t)for(const t of n.data)t[s]=e(t),t[a]=t[o];if(n)for(const e of t)for(const t of e.data)t[l]=n(t),t[r]=(t[l]+t[i])/2;return t},vt=({data:t,y1:e,yPropTop:n,yPropMiddle:o,yPropBottom:a,type:s="cumulative"})=>{for(const i of t){let t=0;const r="cumulative-reverse"===s?i.data.reverse():i.data;for(const s of r)t+=s[n],s[a]=s[n]=s[o]=t,e&&(s[a]=e(s),s[o]=s[a]+s[n]/2)}return t},bt=({type:t="bumpline",data:e,xProp:n,yProp:o,yPropMiddle:a,yPropTop:s,yPropBottom:i})=>{const r=new Map;for(const t of e)for(const e of t.data){const t=yt(e[n]);r.has(t)||r.set(t,[]),r.get(t).push(e)}let l=(t,e)=>t[o]>e[o]?1:-1;"bumparea-invert"!==t&&"bumpline-invert"!==t||(l=(t,e)=>e[o]>t[o]?1:-1);for(const[,e]of r){let n=0,r=0;e.sort(l);let c=1;for(const l of e)"bumparea"===t||"bumparea-invert"===t?0>l[o]?(l[s]=n+l[o],l[a]=n+l[o]/2,l[i]=n,n+=l[o]):(l[s]=r+l[o],l[a]=r+l[o]/2,l[i]=r,r+=l[o]):(l[o]=c,l[s]=c,l[i]=c),c++}return e},Mt="x",Et="y",kt="yMiddle",wt="yTop",At="yBottom",St="xMiddle",Pt="xTop",jt="xBottom",$t=(t,e,n,o)=>[...t.map((t,o)=>[t[0],t[1]+n(e[o])]),...t.map((t,n)=>[t[0],t[1]-o(e[n])]).reverse()],Ot=t=>t&&t.extent||Array.isArray(t)&&t||[],_t=()=>!0,Dt={top:wt,bottom:At,orphan:Et},Ct={top:Pt,bottom:jt,orphan:Mt},Nt={stackedarea:gt,"stackedarea-invert":gt,stackedpercent:gt,"stackedpercent-invert":gt,linepercent:gt,difference:({data:t,yProp:e,yPropTop:n,yPropBottom:o})=>(t.forEach((a,s)=>{a.data.forEach((a,i)=>{const r=0===s?1:0;a[e]>t[r].data[i][e]?(a[o]=t[r].data[i][e],a[n]=a[e]):(a[n]=a[e],a[o]=a[e])})}),t),bumparea:bt,bumpline:bt,"bumparea-invert":bt,line:xt,area:xt,cumulative:vt,"cumulative-reverse":vt};function Tt(t,e){const n=[];for(const t of e)n.push(Object.assign({},t));for(const e of t)e.parentSummary||n.push(e);return n}const Rt={category10:l.schemeCategory10,tableau10:l.schemeTableau10,set3:l.schemeSet3,blues:l.interpolateBlues,reds:l.interpolateReds,greens:l.interpolateGreens,oranges:l.interpolateOranges,purples:l.interpolatePurples,viridis:l.interpolateViridis,plasma:l.interpolatePlasma},zt=l.schemeCategory10;function Bt(t,e,n){if("function"==typeof e)return e(t);const o=t[e];return n?n(o):zt[Math.abs(function(t){let e=0;for(let n=0;t.length>n;n++)e=(e<<5)-e+t.charCodeAt(n),e&=e;return Math.abs(e)}(o+""))%zt.length]}const Lt="#007bff";function Ft(n,o,a="category10"){return t.useMemo(()=>{if(o&&"function"!=typeof o)return function(t,n,o="category10"){const a=Array.from(new Set(t.map(t=>t[n]))),s=a.every(t=>"number"==typeof t||!isNaN(Number(t)));if(Array.isArray(o))return e.scaleOrdinal().domain(a).range(o).unknown("#999");const i=Rt[o]||Rt.category10;if(s&&"function"==typeof i)return t=>i(Number(t)/Math.max(...a.map(Number)));{const t=Array.isArray(i)?i:zt;return e.scaleOrdinal().domain(a).range(t).unknown("#999")}}(n,o,a)},[n,o,a])}function It({data:t,colorBy:e,colorScale:n,getColor:o,strokeColor:a,strokeWidth:s}){return{legendGroups:[{styleFn:t=>{const e={fill:t.color,stroke:t.color};return void 0!==a&&(e.stroke=a),void 0!==s&&(e.strokeWidth=s),e},type:"fill",items:Array.from(new Set(t.map(t=>"function"==typeof e?e(t):t[e]))).map(a=>{const s=t.find("function"==typeof e?t=>e(t)===a:t=>t[e]===a),i=s?o(s,e,n):n?n(a):"#000000";return{label:a+"",color:i}}),label:""}]}}const Wt={background:"rgba(0, 0, 0, 0.85)",color:"white",padding:"8px 12px",borderRadius:"4px",fontSize:"14px",lineHeight:"1.5",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.15)",pointerEvents:"none",maxWidth:"300px",wordWrap:"break-word"};function qt(t,e){return"function"==typeof e?e(t):t[e]}function Vt(t,e){return e?e(t):null==t?"":"number"==typeof t?t.toLocaleString():t instanceof Date?t.toLocaleDateString():"object"==typeof t&&null!==t?void 0!==t.id?t.id+"":void 0!==t.name?t.name+"":JSON.stringify(t):t+""}function Ht(t){return!0===t||("function"==typeof t?t:!1!==t&&void 0!==t&&("object"!=typeof t||null===t||!("fields"in t)&&!("title"in t)||function(t={}){const{fields:e,title:n,format:o,style:a={},className:s=""}=t;return t=>{if(!t||"object"!=typeof t)return null;let i;const r=[];if(n){const e=qt(t,n);i=Vt(e,o)}if(e&&e.length>0)e.forEach(e=>{let n,a,s;"string"==typeof e?(n=e,a=e,s=o):(n=e.label,a=e.accessor||e.key||"",s=e.format||o);const i=qt(t,a);r.push({label:n,value:Vt(i,s)})});else if(!n){const e=["value","y","name","id","label"];for(const n of e)if(void 0!==t[n]){i=Vt(t[n],o);break}if(!i){const e=Object.keys(t).filter(t=>!t.startsWith("_"));e.length>0&&(i=Vt(t[e[0]],o))}}const l=Object.assign(Object.assign({},Wt),a);return d.createElement("div",{className:("semiotic-tooltip "+s).trim(),style:l},i&&d.createElement("div",{style:{fontWeight:r.length>0?"bold":"normal"}},i),r.map((t,e)=>d.createElement("div",{key:e,style:{marginTop:0===e&&i?"4px":0}},t.label&&d.createElement("span",null,t.label,": "),t.value)))}}(t)))}function Gt({componentName:t,message:e,width:n,height:o}){return d.createElement("div",{role:"alert",style:{width:n,height:Math.max(o,120),display:"flex",alignItems:"center",justifyContent:"center",border:"1px dashed rgba(128, 128, 128, 0.4)",borderRadius:8,background:"rgba(128, 128, 128, 0.04)",padding:24,boxSizing:"border-box"}},d.createElement("div",{style:{textAlign:"center",maxWidth:400}},d.createElement("div",{style:{fontSize:13,fontWeight:600,color:"rgba(128, 128, 128, 0.7)",marginBottom:6,fontFamily:"monospace"}},t),d.createElement("div",{style:{fontSize:14,color:"rgba(128, 128, 128, 0.9)",lineHeight:1.5}},e)))}function Xt({data:t,accessors:e,requiredProps:n}){if(n)for(const[t,e]of Object.entries(n))if(null==e)return t+" is required. Provide a field name or function.";if(!t||!Array.isArray(t)||0===t.length)return"No data provided. Pass a non-empty array to the data prop.";if(e){const n=t[0];if(n&&"object"==typeof n)for(const[t,o]of Object.entries(e))if(o&&"string"==typeof o&&!(o in n))return`${t} "${o}" not found in data. Available fields: ${Object.keys(n).join(", ")}.`}return null}function Yt(t,e){return t?!0===t?{name:"hover",fields:e||[]}:"string"==typeof t?{name:t,fields:e||[]}:{name:t.name||"hover",fields:t.fields}:null}function Kt(t,e,n){return e?o=>{var a,s;const i=Object.assign({},t(o));return e.isActive&&(e.predicate(o)?(null==n?void 0:n.selectedStyle)&&Object.assign(i,n.selectedStyle):(i.fillOpacity=null!==(a=null==n?void 0:n.unselectedOpacity)&&void 0!==a?a:.2,i.strokeOpacity=null!==(s=null==n?void 0:n.unselectedOpacity)&&void 0!==s?s:.2,(null==n?void 0:n.unselectedStyle)&&Object.assign(i,n.unselectedStyle))),i}:t}function Qt(t){const e=[];for(const[n,o]of Object.entries(t.fields))if("point"===o.type)e.push(t=>o.values.has(t[n]));else{const[t,a]=o.range;e.push(e=>{const o=e[n];return o>=t&&a>=o})}return t=>e.every(e=>e(t))}function Zt(t,e){let n=t.get(e);return n||(n={name:e,resolution:"union",clauses:new Map},t.set(e,n)),n}const[Jt,Ut]=st(t=>({selections:new Map,setClause(e,n){t(t=>{const o=new Map(t.selections),a=Zt(o,e),s=new Map(a.clauses);return s.set(n.clientId,n),o.set(e,Object.assign(Object.assign({},a),{clauses:s})),{selections:o}})},clearClause(e,n){t(t=>{const o=t.selections.get(e);if(!o)return{};const a=new Map(t.selections),s=new Map(o.clauses);return s.delete(n),a.set(e,Object.assign(Object.assign({},o),{clauses:s})),{selections:a}})},setResolution(e,n){t(t=>{const o=new Map(t.selections),a=Zt(o,e);return o.set(e,Object.assign(Object.assign({},a),{resolution:n})),{selections:o}})},clearSelection(e){t(t=>{const n=new Map(t.selections),o=n.get(e);return o&&n.set(e,Object.assign(Object.assign({},o),{clauses:new Map})),{selections:n}})}}));function te(e){const n=t.useId(),o=e.clientId||n,{name:a}=e,s=Ut(t=>t.selections.get(a)),i=Ut(t=>t.setClause),r=Ut(t=>t.clearClause),l=t.useMemo(()=>!!s&&s.clauses.size>0,[s]);return{predicate:t.useMemo(()=>s&&0!==s.clauses.size?function(t,e){const n=[];for(const[o,a]of t.clauses)"crossfilter"===t.resolution&&o===e||n.push(Qt(a));return 0===n.length?()=>!0:"intersect"===t.resolution?t=>n.every(e=>e(t)):t=>n.some(e=>e(t))}(s,o):()=>!0,[s,o]),isActive:l,selectPoints:t.useCallback(t=>{const e={};for(const[n,o]of Object.entries(t))e[n]={type:"point",values:new Set(o)};i(a,{clientId:o,type:"point",fields:e})},[o,a,i]),selectInterval:t.useCallback(t=>{const e={};for(const[n,o]of Object.entries(t))e[n]={type:"interval",range:o};i(a,{clientId:o,type:"interval",fields:e})},[o,a,i]),clear:t.useCallback(()=>{r(a,o)},[r,a,o]),clientId:o}}function ee(e){const n=e.name||"hover",{fields:o}=e,{predicate:a,isActive:s,selectPoints:i,clear:r}=te({name:n});return{onHover:t.useCallback(t=>{if(!t)return void r();const e={};for(const n of o){const o=t[n];void 0!==o&&(e[n]=[o])}Object.keys(e).length>0&&i(e)},[o,i,r]),predicate:a,isActive:s}}function ne(e){const{data:n,width:o=600,height:a=400,margin:s,className:i,title:r,categoryAccessor:l="category",valueAccessor:c="value",bins:u=25,relative:h=!1,categoryLabel:p,valueLabel:f,valueFormat:m,colorBy:y,colorScheme:g="category10",categoryPadding:x=20,enableHover:v=!0,showGrid:b=!1,showLegend:M,tooltip:E,frameProps:k={},selection:w,linkedHover:A}=e,S=n||[],P=Yt(A,y?["string"==typeof y?y:""]:["string"==typeof l?l:""]),j=te({name:(null==w?void 0:w.name)||"__unused__"}),$=ee({name:(null==P?void 0:P.name)||"hover",fields:(null==P?void 0:P.fields)||[]}),O=w?{isActive:j.isActive,predicate:j.predicate}:null,_=Ft(S,y,g),D=t.useMemo(()=>t=>{const e=y?Bt(t,y,_):Lt;return{fill:e,stroke:e,fillOpacity:.8}},[y,_]),C=t.useMemo(()=>Kt(D,O,w),[D,O,w]),N=void 0!==M?M:!!y,T=t.useMemo(()=>{if(N&&y)return It({data:S,colorBy:y,colorScale:_,getColor:Bt})},[N,y,S,_]),R=t.useMemo(()=>{const t=Object.assign({top:50,bottom:60,left:70,right:40},s);return T&&120>t.right&&(t.right=120),t},[s,T]),z=t.useCallback(t=>{A&&$.onHover(t)},[A,$]),B=t.useMemo(()=>t=>{const e=t.data||t,n=e.category||t.category||"",o=e.count,a=e.range;return d.createElement("div",{className:"semiotic-tooltip",style:Wt},n&&d.createElement("div",{style:{fontWeight:"bold"}},n+""),null!=o&&d.createElement("div",null,"Count: ",o),a&&2===a.length&&d.createElement("div",{style:{opacity:.8}},Number(a[0]).toFixed(1)," – ",Number(a[1]).toFixed(1)))},[]),L=Xt({componentName:"Histogram",data:S,accessors:{categoryAccessor:l,valueAccessor:c}});if(L)return d.createElement(Gt,{componentName:"Histogram",message:L,width:o,height:a});const F=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({chartType:"histogram",data:S,oAccessor:l,rAccessor:c,projection:"horizontal",summaryStyle:C,bins:u,normalize:h,size:[o,a],margin:R,barPadding:x,enableHover:v,showAxes:!0,oLabel:p,rLabel:f,rFormat:m,showGrid:b},T&&{legend:T}),r&&{title:r}),i&&{className:i}),{tooltipContent:E?Ht(E):B}),A&&{customHoverBehavior:z}),k);return d.createElement(H,Object.assign({},F))}function oe(e){const{data:n,width:o=600,height:a=400,margin:s,className:i,title:r,categoryAccessor:l="category",valueAccessor:c="value",orientation:u="vertical",bins:h=25,showIQR:p=!0,categoryLabel:f,valueLabel:m,valueFormat:y,colorBy:g,colorScheme:x="category10",categoryPadding:v=20,enableHover:b=!0,showGrid:M=!1,showLegend:E,tooltip:k,frameProps:w={},selection:A,linkedHover:S}=e,P=n||[],j=Yt(S,g?["string"==typeof g?g:""]:["string"==typeof l?l:""]),$=te({name:(null==A?void 0:A.name)||"__unused__"}),O=ee({name:(null==j?void 0:j.name)||"hover",fields:(null==j?void 0:j.fields)||[]}),_=A?{isActive:$.isActive,predicate:$.predicate}:null,D=Ft(P,g,x),C=t.useMemo(()=>t=>{const e=g?Bt(t,g,D):Lt;return{fill:e,stroke:e,fillOpacity:.6}},[g,D]),N=t.useMemo(()=>Kt(C,_,A),[C,_,A]),T=void 0!==E?E:!!g,R=t.useMemo(()=>{if(T&&g)return It({data:P,colorBy:g,colorScale:D,getColor:Bt})},[T,g,P,D]),z=t.useMemo(()=>{const t=Object.assign({top:50,bottom:60,left:70,right:40},s);return R&&120>t.right&&(t.right=120),t},[s,R]),B=t.useCallback(t=>{S&&O.onHover(t)},[S,O]),L=t.useMemo(()=>t=>{const e=t.data||t,n=e.category||t.category||"",o=(Array.isArray(e)?e:[]).map(t=>{const e="function"==typeof c?c(t):t[c];return Number(e)}).filter(t=>!isNaN(t)).sort((t,e)=>t-e),a=o.length,s=a>0?o[Math.floor(a/2)]:null;return d.createElement("div",{className:"semiotic-tooltip",style:Wt},n&&d.createElement("div",{style:{fontWeight:"bold"}},n+""),a>0&&d.createElement("div",null,"n = ",a),null!=s&&d.createElement("div",null,"Median: ",s.toLocaleString()))},[c]),F=Xt({componentName:"ViolinPlot",data:P,accessors:{categoryAccessor:l,valueAccessor:c}});if(F)return d.createElement(Gt,{componentName:"ViolinPlot",message:F,width:o,height:a});const I=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({chartType:"violin",data:P,oAccessor:l,rAccessor:c,projection:"horizontal"===u?"horizontal":"vertical",summaryStyle:N,bins:h,showIQR:p,size:[o,a],margin:z,barPadding:v,enableHover:b,showAxes:!0,oLabel:f,rLabel:m,rFormat:y,showGrid:M},R&&{legend:R}),r&&{title:r}),i&&{className:i}),{tooltipContent:k?Ht(k):L}),S&&{customHoverBehavior:B}),w);return d.createElement(H,Object.assign({},I))}ne.displayName="Histogram",oe.displayName="ViolinPlot",exports.Annotation=ot,exports.AnnotationLayer=function(e){const{legendSettings:n,margin:o,size:a,annotations:s,annotationHandling:i}=e,r=lt(t=>t.tooltip);let l=null!=r?s.concat(r):s,c=lt(t=>t.changeTooltip);const u=Object.assign(Object.assign({},e),{annotations:l,voronoiHover:t=>{c(t)}}),h="object"==typeof i?i:{layout:{type:i},dataVersion:""},{dataVersion:p=""}=h,[f,m]=t.useState([]),[y,g]=t.useState([]),[x,v]=t.useState([]),[b,M]=t.useState(""),[E,k]=t.useState(p),w=ft(u,l),A=w.filter(t=>t.props&&t.props.noteData&&!t.props.noteData.fixedPosition),S=ut(A,h,a);let P;if(t.useEffect(()=>{const t=w.filter(t=>!t.props||!t.props.noteData||t.props.noteData.fixedPosition),e=mt(u,{adjustedAnnotations:f,adjustedAnnotationsKey:b,adjustedAnnotationsDataVersion:E,adjustableAnnotations:A,fixedAnnotations:t});m(e.adjustedAnnotations),M(e.adjustedAnnotationsKey),k(e.adjustedAnnotationsDataVersion),g(e.svgAnnotations),v(e.htmlAnnotations)},[S,p,l.length,l.map(t=>function(t){const e=new Set;return JSON.stringify(t,(t,n)=>e.has(n)?"...":"object"==typeof n?(e.add(n),"note"===t?`${n.label}-${n.title}`:"connector"===t?`${n.end}-${n.type}`:"subject"===t?""+n.radius:"object"==typeof n.column?`${n.column.x}-${n.column.y}-${n.column.name}`:n.voronoiX||n.voronoiY||n.x||n.y||n.dx||n.dy||n.label||n.type||n.key||n.hierarchicalID||n.id||n.name?`${n.voronoiX}-${n.voronoiY}-${n.dx}-${n.dy}-${n.x}-${n.y}-${n.label}-${n.type}-${n.key}-${n.hierarchicalID}-${n.id}-${n.name}`:"..."):n)}(t)).join("-")]),n){const t={left:[15,15],right:[a[0]+15,15]},{position:e="right",title:o="Legend"}=n;P=d.createElement("g",{transform:`translate(${t[e].join(",")})`},d.createElement(_,Object.assign({},n,{title:o,position:e})))}return 0!==l.length||n?d.createElement("div",{className:"annotation-layer",style:{position:"absolute",pointerEvents:"none",background:"none"}},d.createElement("svg",{className:"annotation-layer-svg",height:a[1],width:a[0],style:{background:"none",pointerEvents:"none",position:"absolute",left:o.left+"px",top:o.top+"px",overflow:"visible"}},d.createElement("g",null,P,y)),d.createElement("div",{className:"annotation-layer-html",style:{background:"none",pointerEvents:"none",position:"absolute",height:a[1]+"px",width:a[0]+"px",left:o.left+"px",top:o.top+"px"}},x)):null},exports.Axis=function(e){const{rotate:n,label:o,dynamicLabelPosition:a,orient:s="left",marginalSummaryType:i,tickFormat:r=(i?()=>"":J),size:l,width:c=l&&l[0]||0,height:u=l&&l[1]||0,className:h,padding:p,tickValues:f,scale:m,ticks:y,footer:g,tickSize:x,tickLineGenerator:v,baseline:b=!0,margin:M={top:0,bottom:0,left:0,right:0},center:E=!1,annotationFunction:k,glyphFunction:w,xyPoints:A}=e,[S,P]=t.useState(0),[j,$]=t.useState(void 0),O=t.useRef(null);t.useEffect(()=>{if(!(null==o?void 0:o.position)&&a){const t=((t,e)=>{const n=t.current;if(!n)return 30;const o="left"===e||"right"===e?"width":"height";return Math.max(...[...n.querySelectorAll(".axis-label")].map(t=>t.getBBox&&t.getBBox()||{height:30,width:30}).map(t=>t[o]))+25})(O,s);t!==j&&$(t)}},[o,a]);let _,{axisParts:D,position:C=[0,0]}=e;if(D||(D=function({renderMode:t=()=>{},padding:e=5,scale:n,ticks:o,tickValues:a=X(void 0,o,n),orient:s="left",size:i,footer:r=!1,tickSize:l=(r?-10:["top","bottom"].find(t=>t===s)?i?i[1]:0:i?i[0]:0),jaggedBase:c}){let u,d,h,p,f,m,y=[],g=0,x=0,v="middle";switch(s){case"top":u="x1",d="x2",h="y1",p="y2",y=[0,l],f="tx",m="ty",g-=20-e;break;case"bottom":u="x1",d="x2",h="y2",p="y1",y=i?[i[1],i[1]-l]:[0,-l],f="tx",m="ty",g+=20+e;break;case"right":u="y2",d="y1",h="x2",p="x1",y=i?[i[0],i[0]-l]:[0,-l],f="ty",m="tx",g+=5+e,x+=5,v="start";break;default:u="y1",d="y2",h="x1",p="x2",y=[0,l],f="ty",m="tx",g-=5+e,x+=5,v="end"}let b=a instanceof Function?a({orient:s}):a;return c&&void 0===b.find(t=>t===n.domain()[0])&&(b=[n.domain()[0],...b]),b.map((e,o)=>{const a=n(e);return{[u]:a,[d]:a,[h]:y[0],[p]:y[1],[f]:a+x,[m]:y[0]+g,defaultAnchor:v,renderMode:t(e,o),value:e}})}({padding:p,tickValues:f,scale:m,ticks:y,orient:s,size:[c,u],footer:g,tickSize:x}),_=d.createElement("g",{className:"axis "+h},(({axisParts:t,orient:e,tickLineGenerator:n=G,className:o,jaggedBase:a,scale:s,showOutboundTickLines:i=!1})=>{const r=t.map((t,i)=>n({xy:t,orient:e,i:i,className:o,jaggedBase:a,scale:s})),l=i?t.map((t,n)=>(({xy:t,orient:e,i:n,className:o=""})=>{let a=`M-4,${t.y1}L${t.x1},${t.y2}`;return"left"===e?a=`M${t.x1-8},${t.y1}L${t.x1},${t.y2}`:"right"===e?a=`M${t.x2},${t.y1}L${t.x2+8},${t.y2}`:"top"===e?a=`M${t.x1},${t.y1-8}L${t.x1},${t.y1}`:"bottom"===e&&(a=`M${t.x1},${t.y2}L${t.x1},${t.y2+8}`),d.createElement("path",{key:n,fill:"none",stroke:"currentColor",strokeWidth:"1px",d:a,className:`outbound-tick-line tick ${e} ${o}`})})({xy:t,orient:e,i:n,className:o})):[];return[...r,l]})({axisParts:D,orient:s,tickLineGenerator:v,className:h,scale:m}))),0===D.length)return null;let N,T,R,z,B=50,L=u,F=-50,I=0,W=0,q=0,V=0,H=u,Y=25,K=-25,tt=18,et=c+25,nt=0,ot=S,at=0,st="y";switch(s){case"right":C=[C[0],C[1]],F=c,V=W=c,at=M.top,et=-c-25,K=5,N=t=>{P(t.nativeEvent.offsetY-at)},!0===E&&(V=W=c/2);break;case"top":C=[C[0],0],B=c,L=50,I=-50,F=0,at=M.left,st="x",V=c,H=0,!0===E&&(H=q=u/2),N=t=>{P(t.nativeEvent.offsetX-at)},Y=S,ot=25,K=0,tt=-10,et=0,nt=u+25;break;case"bottom":C=[C[0],0],B=c,L=50,q=H=I=u,W=F=0,V=c,at=M.left,N=t=>{P(t.nativeEvent.offsetX-at)},Y=S,ot=25,K=0,tt=15,et=0,nt=-u-25,st="x",!0===E&&(H=q=u/2);break;default:C=[C[0],C[1]],at=M.top,!0===E&&(V=W=c/2),N=t=>{P(t.nativeEvent.offsetY-at)}}if(k){const t=function(t,e){return e.tickFormat?e.tickFormat(t):t.toString?""+t:t}(m.invert(S),e),n=w?w({lineHeight:nt,lineWidth:et,value:m.invert(S)}):d.createElement("g",null,d.isValidElement(t)?d.createElement("g",{transform:`translate(${K},${tt})`},t):d.createElement("text",{x:K,y:tt},t),d.createElement("circle",{r:5}),d.createElement("line",{x1:et,y1:nt,style:{stroke:"black"}})),o=S?d.createElement("g",{style:{pointerEvents:"none"},transform:`translate(${Y},${ot})`},n):null;T=d.createElement("g",{className:"annotation-brush",transform:`translate(${F},${I})`},d.createElement("rect",{style:{fillOpacity:0},height:L,width:B,onMouseMove:N,onClick:t=>k({className:"dynamic-axis-annotation",type:st,value:m.invert(S),e:t}),onMouseOut:()=>{P(void 0)}}),o)}if(i&&A){const t=Math.max(M[s]-6,5),e="string"==typeof i?{type:i}:i;void 0!==e.flip||"bottom"!==s&&"right"!==s||(e.flip=!0);const n=e.summaryStyle?()=>e.summaryStyle:()=>({fill:"black",fillOpacity:.5,stroke:"black",strokeDasharray:"0"}),o=e.renderMode?()=>e.renderMode:()=>{},a=e.summaryClass?()=>e.summaryClass:()=>"",r=e.filter||(()=>!0),c=A.filter(t=>void 0!==t.x&&void 0!==t.y&&r(t.data)).map(t=>Object.assign(Object.assign({},t),{xy:{x:"top"===s||"bottom"===s?m(t.x):0,y:"left"===s||"right"===s?m(t.y):0},piece:{scaledVerticalValue:m(t.y),scaledValue:m(t.x)},value:m("top"===s||"bottom"===s?t.y:t.x),scaledValue:m(t.x),scaledVerticalValue:m(t.y)})),u=function(t){const e=[];for(const n of t){const t=[],{elements:o,containerProps:a}=n;if(n.Mark)e.push(n.Mark);else{for(let e=0;o.length>e;e++){const n=o[e],{markType:a,style:s={}}=n,i=U(n,["markType","style"]),r=Object.assign({},i);void 0!==s.fill&&(r.fill=s.fill),void 0!==s.stroke&&(r.stroke=s.stroke),void 0!==s.strokeWidth&&(r.strokeWidth=s.strokeWidth),void 0!==s.opacity&&(r.opacity=s.opacity),void 0!==s.fillOpacity&&(r.fillOpacity=s.fillOpacity),void 0!==s.strokeOpacity&&(r.strokeOpacity=s.strokeOpacity);const l=Object.assign({},s);delete l.fill,delete l.stroke,delete l.strokeWidth,delete l.opacity,delete l.fillOpacity,delete l.strokeOpacity,Object.keys(l).length>0&&(r.style=l),r.key=n.key||e,a&&t.push(d.createElement(a,r))}a?e.push(d.createElement("g",Object.assign({},a),t)):e.push(...t)}}return e}((({data:t,type:e,renderMode:n,eventListenersGenerator:o,styleFn:a,classFn:s,projection:i,adjustedSize:r,margin:l,axisCreator:c})=>{if(e&&e.type)return function({data:t,type:e,renderMode:n,eventListenersGenerator:o,styleFn:a,classFn:s,projection:i,adjustedSize:r,chartSize:l,margin:c,axisCreator:u}){return"function"==typeof e.type?e.type({data:t,type:e,renderMode:n,eventListenersGenerator:o,styleFn:a,classFn:s,projection:i,adjustedSize:r,chartSize:l,margin:c,axisCreator:u}):(console.error(`Invalid summary type: ${e.type} - Must be a function`),{})}({data:t,type:e="string"==typeof e?{type:e}:e,renderMode:n,eventListenersGenerator:o,styleFn:a,classFn:s,projection:i,adjustedSize:r,chartSize:"vertical"===i?r[1]:r[0],margin:l,axisCreator:c})})({data:{column:{middle:t/2,pieceData:c,width:t,xyData:c}},type:e,renderMode:o,eventListenersGenerator:e.eventListenersGenerator||(()=>({})),styleFn:n,classFn:a,projection:"top"===s||"bottom"===s?"horizontal":"vertical",adjustedSize:l,margin:{top:0,bottom:0,left:0,right:0}}).marks);let h;if(!0===e.showPoints){const n=((t,e,n)=>{const o="left"===t||"right"===t?e/2:0,a="bottom"===t||"top"===t?e/2:0;return n.map(t=>[t.xy.x+o,t.xy.y+a])})(s,t,c);h=n.map((t,n)=>d.createElement("circle",{key:"axis-summary-point-"+n,cx:t[0],cy:t[1],r:e.r||3,style:e.pointStyle||{fill:"black",fillOpacity:.1}}))}R=d.createElement(Q,{translation:{left:[2-M.left,0],right:[l[0]+2,0],top:[0,2-M.top],bottom:[0,l[1]+2]},orient:s,decoratedSummaryType:e,summaryWidth:t,renderedSummary:u,points:h})}const it=(({axisParts:t,tickFormat:e,rotate:n=0,center:o=!1,orient:a})=>{const s=t.map((t,n)=>({axisPart:t,i:n,formatted:e(t.value,n)})),i="left"===a||"right"===a;let r=s;if(!n&&s.length>1){const t=8,e=14,n=8,o=t=>"string"==typeof t?t:"number"==typeof t?t+"":null;if("top"===a||"bottom"===a){const e=[...s].sort((t,e)=>t.axisPart.tx-e.axisPart.tx);let a=-1/0;const i=new Set;for(const s of e){const e=o(s.formatted);if(!e){i.add(s.i);continue}const r=e.length*t/2;a+n>s.axisPart.tx-r||(i.add(s.i),a=s.axisPart.tx+r)}r=s.filter(t=>i.has(t.i))}else if(i){const t=[...s].sort((t,e)=>t.axisPart.ty-e.axisPart.ty);let o=-1/0;const a=new Set;for(const s of t)o+e+n>s.axisPart.ty||(a.add(s.i),o=s.axisPart.ty);r=s.filter(t=>a.has(t.i))}}return r.map(({axisPart:t,i:e,formatted:s})=>{("object"!=typeof s||s instanceof Date)&&(s=d.createElement("text",{textAnchor:t.defaultAnchor,className:"axis-label"},s.toString?""+s:s));let i=t.tx,r=t.ty;if(o)switch(a){case"right":i-=(t.x2-t.x1)/2;break;case"left":i+=(t.x2-t.x1)/2;break;case"top":r+=(t.y2-t.y1)/2;break;case"bottom":r-=(t.y2-t.y1)/2}return d.createElement("g",{key:e,pointerEvents:"none",transform:`translate(${i},${r}) rotate(${n})`,className:"axis-label"},s)})})({tickFormat:r,axisParts:D,orient:s,rotate:n,center:E});if(o){const t=o.name||o,e=o.position||{};let n=e.anchor||"middle";const a=o.locationDistance||j,i=e.rotation||{left:-90,right:90,top:0,bottom:0}[s],r={left:{start:[0,l[1]],middle:[0,l[1]/2],end:[0,0],inside:[a||15,0],outside:[-(a||45),0]},right:{start:[l[0]+0,l[1]],middle:[l[0]+0,l[1]/2],end:[l[0]+0,0],inside:[-(a||15),0],outside:[a||45,0]},top:{start:[0,0],middle:[0+l[0]/2,0],end:[0+l[0],0],inside:[0,a||15],outside:[0,-(a||40)]},bottom:{start:[0,l[1]],middle:[0+l[0]/2,l[1]],end:[0+l[0],l[1]],inside:[0,-(a||5)],outside:[0,a||50]}},c=r[s][n],u=r[s][e.location||"outside"];c[0]=c[0]+u[0],c[1]=c[1]+u[1],"start"===n&&"right"===s?n="end":"end"===n&&"right"===s&&(n="start"),z=d.createElement(Z,{className:h,translation:c,position:C,rotation:i,labelName:t,anchorMod:n})}const rt=`${s} axis ${D&&D.length>0&&`from ${r(D[0].value,0)} to ${r(D[D.length-1].value,D.length-1)}`||"without ticks"}`;return d.createElement("g",{className:h,"aria-label":rt,ref:O},T,it,_,!0===b?d.createElement("line",{key:"baseline",className:"axis-baseline "+h,stroke:"black",strokeLinecap:"square",x1:W,x2:V,y1:q,y2:H}):null,z,R)},exports.Histogram=ne,exports.Legend=_,exports.StreamOrdinalFrame=H,exports.ViolinPlot=oe,exports.calculateDataExtent=({lineDataAccessor:t,xAccessor:n,yAccessor:o,summaries:a,points:l,lines:c,lineType:u,showLinePoints:h,showSummaryPoints:f,xExtent:m,yExtent:y,invertX:g,invertY:x,summaryDataAccessor:v,summaryType:b,adjustedSize:M,margin:E,summaryStyleFn:k,summaryClassFn:w,summaryRenderModeFn:A,chartSize:S,filterRenderedLines:P,filterRenderedSummaries:j,filterRenderedPoints:$,defined:O=_t,annotations:_=[]})=>{let D=[],C=[],N=[],T=[],R=[];if(l){n.forEach((t,e)=>{o.forEach((n,o)=>{let a=0;for(const s of l){const i=t(s,a),r=n(s,a),l={x:i,y:r,data:s,xIndex:e,yIndex:o};Array.isArray(r)&&(l[At]=Math.min(...r),l[wt]=Math.max(...r),l[kt]=(l[At]+l[wt])/2),Array.isArray(i)&&(l[jt]=Math.min(...i),l[Pt]=Math.max(...i),l[St]=(l[jt]+l[Pt])/2),N.push(l),a++}})});for(const t of N)D.push(Object.assign(Object.assign({},t),{[Mt]:t[Pt]||t[jt]||t.x,[Et]:t[wt]||t[At]||t.y}))}if(c){C=(({data:t,lineDataAccessor:e,xProp:n,xPropTop:o,xPropBottom:a,yProp:s,yPropTop:i,yPropBottom:r,xAccessor:l,yAccessor:c})=>{Array.isArray(t)||(t=[t]);const u=[];return e.forEach((e,d)=>{l.forEach((l,h)=>{c.forEach((c,p)=>{t.forEach(t=>{const f=Object.assign(Object.assign({},t),{xIndex:h,yIndex:p,lineIndex:d});f.data=e(t).map((t,e)=>{const u={data:t};return u[n]=l(t,e),u[o]=u[n],u[a]=u[n],u[s]=c(t,e),u[i]=u[s],u[r]=u[s],u}),f.key=f.key||u.length,u.push(f)})})})}),u})({data:c,lineDataAccessor:t,xProp:Mt,xPropTop:Pt,xPropBottom:jt,yProp:Et,yPropTop:wt,yPropBottom:At,xAccessor:n,yAccessor:o}),T=function(t,e){return n=>Nt[((t,e)=>!Nt[t]||"difference"===t&&2!==e.length?"line":t)(t.type,n)](Object.assign(Object.assign(Object.assign({},t),e),{data:n}))}(u,{xProp:Mt,yProp:Et,yPropMiddle:kt,yPropTop:wt,yPropBottom:At,xPropMiddle:St,xPropTop:Pt,xPropBottom:jt})(C);for(const t of T)for(let e=0;t.data.length>e;e++){const n=t.data[e];if(!O(Object.assign({},n.data,n),e))continue;const o={parentLine:t,y:n.y,x:n.x,xTop:n.xTop,xMiddle:n.xMiddle,xBottom:n.xBottom,yTop:n.yTop,yMiddle:n.yMiddle,yBottom:n.yBottom,data:n.data};n.percent&&(o.percent=n.percent),D.push(o)}if(h){const t=!0===h?St:Ct[h],e=!0===h?kt:Dt[h];T.forEach(n=>{n.data.filter((t,e)=>{if(O(Object.assign({},t.data,t))){if("orphan"===h){const t=n.data[e-1],o=n.data[e+1];return!(t&&O(Object.assign({},t.data,t))||o&&O(Object.assign({},o.data,o)))}return!0}return!1}).forEach(o=>{N.push(Object.assign(Object.assign({},o),{parentLine:n,[Et]:void 0!==o[e]?o[e]:void 0!==o[kt]?o[kt]:void 0!==o[At]?o[At]:o.y,[Mt]:void 0!==o[t]?o[t]:void 0!==o[St]?o[St]:void 0!==o[jt]?o[jt]:o.y}))})})}}a&&(R=(({data:t,summaryDataAccessor:e,xAccessor:n,yAccessor:o})=>{const a=[];return e.forEach(e=>{n.forEach(n=>{o.forEach(o=>{const s=t=>e(t).map((t,e)=>[n(t,e),o(t,e)]);t.forEach(t=>{a.push(Object.assign(Object.assign({},t),{_baseData:e(t),_xyfCoordinates:s(t)}))})})})}),a})({data:a,summaryDataAccessor:v,xAccessor:n,yAccessor:o}),R.forEach(t=>{const e=t._baseData;t._xyfCoordinates.length>0&&t._xyfCoordinates[0][0][0]?t._xyfCoordinates[0].forEach(n=>{Array.isArray(n)&&n.map((n,o)=>Object.assign({parentSummary:t},e[o],{[Mt]:n[0],[Et]:n[1]})).forEach(t=>{f&&N.push(Object.assign(Object.assign({x:0},t),{[Et]:t[wt]||t[At]||t[Et]})),D.push(Object.assign({x:0,y:0},t))})}):t._xyfCoordinates.length>0&&Array.isArray(t._xyfCoordinates)&&t._xyfCoordinates.map((n,o)=>Object.assign(Object.assign({parentSummary:t},e[o]),{[Mt]:n[0],[Et]:n[1]})).forEach(t=>{f&&N.push(Object.assign(Object.assign({x:0},t),{[Et]:t[wt]||t[At]||t[Et]})),D.push(Object.assign({x:0,y:0},t))})}));let z,B,L,F,I=[],W=[];m&&!Array.isArray(m)&&!0===m.includeAnnotations&&n.forEach(t=>{_.forEach((e,n)=>{const o=t(e,n);isFinite(o)&&I.push({[Mt]:o})})}),y&&!Array.isArray(y)&&!0===y.includeAnnotations&&o.forEach(t=>{_.forEach((e,n)=>{const o=t(e,n);isFinite(o)&&W.push({[Et]:o})})});for(const t of D){const e=void 0===t[jt]?t[Mt]:Math.min(t[Pt],t[jt]),n=void 0===t[Pt]?t[Mt]:Math.max(t[jt],t[Pt]),o=void 0===t[At]?t[Et]:Math.min(t[wt],t[At]),a=void 0===t[wt]?t[Et]:Math.max(t[At],t[wt]);void 0===e||void 0!==z&&e>=z||(z=e),void 0===n||void 0!==B&&B>=n||(B=n),void 0===o||void 0!==L&&o>=L||(L=o),void 0===a||void 0!==F&&F>=a||(F=a)}for(const t of I){const e=t[Mt];void 0===e||void 0!==z&&e>=z||(z=e),void 0===e||void 0!==B&&B>=e||(B=e)}for(const t of W){const e=t[Et];void 0===e||void 0!==L&&e>=L||(L=e),void 0===e||void 0!==F&&F>=e||(F=e)}const q=[z,B],V=[L,F],H=Ot(m),G=Ot(y);let X=[G&&void 0!==G[0]?G[0]:V[0],G&&void 0!==G[1]?G[1]:V[1]],Y=[H&&void 0!==H[0]?H[0]:q[0],H&&void 0!==H[1]?H[1]:q[1]];if(!g||H&&2===H.length||(Y=[Y[1],Y[0]]),"bumpline"!==u.type&&!x||G&&2===G.length||(X=[X[1],X[0]]),b.type&&"contour"===b.type)R=function({summaryType:t,data:n,finalXExtent:o,finalYExtent:a}){let s=[];t.type||(t={type:t});const{resolution:r=500,thresholds:l=10,bandwidth:c=20,neighborhood:u}=t,d=e.scaleLinear().domain(o).rangeRound([0,r]).nice(),h=e.scaleLinear().domain(a).rangeRound([r,0]).nice();return n.forEach(t=>{let e=i.contourDensity().size([r,r]).x(t=>d(t[0])).y(t=>h(t[1])).thresholds(l).bandwidth(c)(t._xyfCoordinates);u&&(e=[e[0]]);const n=Math.max(...e.map(t=>t.value));e.forEach(e=>{e.parentSummary=t,e.bounds=[],e.percent=e.value/n,e.coordinates.forEach(t=>{t.forEach((n,o)=>{t[o]=n.map(t=>[d.invert(t[0]),h.invert(t[1])]),0===o&&e.bounds.push(function(t){let e=[1/0,0],n=[-1/0,0],o=[0,1/0],a=[0,-1/0];return t.forEach(t=>{e=e[0]>t[0]?t:e,n=t[0]>n[0]?t:n,a=t[1]>a[1]?t:a,o=o[1]>t[1]?t:o}),{center:[(e[0]+n[0])/2,(o[1]+a[1])/2],top:o,left:e,right:n,bottom:a}}(t[o]))})})}),s=[...s,...e]}),s}({summaryType:b,data:R,finalXExtent:Y,finalYExtent:X});else if(b.type&&"linebounds"===b.type){if(R=function({summaryType:t,data:e,defined:n}){let o=[];t.type||(t={type:t});const{boundingAccessor:a,topBoundingAccessor:s=a,bottomBoundingAccessor:i=a}=t;return e.forEach(t=>{const e=t._baseData.map(n);let a=[],r=[];const l=[{xyf:r,base:a}];e.forEach((n,o)=>{!0===n?(a.push(t._baseData[o]),r.push(t._xyfCoordinates[o])):e[o+1]&&(a=[],r=[],l.push({xyf:r,base:a}))}),l.forEach(({xyf:e,base:n})=>{const a={data:t,parentSummary:t,_xyfCoordinates:$t(e,n,s,i)};o=[...o,a]})}),o}({summaryType:b,data:R,defined:O}),!G||2!==G.length)for(const t of R)for(const e of t._xyfCoordinates){const t=e[1];void 0!==t&&isFinite(t)&&(X[0]>t&&(X[0]=t),t>X[1]&&(X[1]=t))}}else b.type&&"hexbin"===b.type?(R=function({preprocess:t=!0,processedData:n=!1,summaryType:o,data:a,finalXExtent:s,finalYExtent:i,size:l,xScaleType:c=e.scaleLinear(),yScaleType:u=e.scaleLinear(),margin:h,styleFn:p,classFn:f,renderFn:m,chartSize:y}){let g=s,x=i;if(!g){const t=a.coordinates.map(t=>t.x);g=[Math.min(...t),Math.max(...t)]}if(!x){const t=a.coordinates.map(t=>t.y);x=[Math.min(...t),Math.max(...t)]}if(n&&a)return a.coordinates;let v,b=[];v=o.type?o:{type:v};const{bins:M=.05,cellPx:E,binValue:k=t=>t.length,binMax:w,customMark:A}=v;a.coordinates&&!a._xyfCoordinates&&(a._xyfCoordinates=a.coordinates.map(t=>[t.x,t.y]));const S=Array.isArray(a)?a:[a],P=c.domain(g).range([0,l[0]]),j=u.domain(x).range([0,l[1]]),$=E&&E/2||(M>1?1/M:M)*l[0]/2,O=r.hexbin().x(t=>P(t._xyfPoint[0])).y(t=>j(t._xyfPoint[1])).radius($).size(l);let _;const D=O.centers();return S.forEach(t=>{_=0;const e=O(t._xyfCoordinates.map((e,n)=>Object.assign({_xyfPoint:e},t.coordinates[n]))),n={};e.forEach(t=>{n[`${parseInt(t.x)}-${parseInt(t.y)}`]=!0}),D.forEach(t=>{if(!n[`${parseInt(t[0])}-${parseInt(t[1])}`]){const n=[];n.x=t[0],n.y=t[1],e.push(n)}}),_=Math.max(...e.map(t=>k(t))),w&&w(_);const o=[[0,-1],[.866,-.5],[.866,.5],[0,1],[-.866,.5],[-.866,-.5]],a=P.invert($)-g[0],s=j.invert($)-x[0],i=o.map(t=>[t[0]*a,t[1]*s]),r=e.map(e=>{const n=k(e),a=e.x,s=e.y;e.x=P.invert(e.x),e.y=j.invert(e.y);const r=n/_;return{customMark:A&&d.createElement("g",{transform:`translate(${a},${l[1]-s})`},A({d:Object.assign(Object.assign({},e),{binItems:e,percent:r,value:n,radius:$,hexCoordinates:o.map(t=>[t[0]*$,t[1]*$])}),margin:h,styleFn:p,classFn:f,renderFn:m,chartSize:y,adjustedSize:l})),_xyfCoordinates:i.map(t=>[t[0]+e.x,t[1]+e.y]),value:n,percent:r,data:e,parentSummary:t,centroid:!0}});b=[...b,...r]}),t?(b.forEach(t=>{t.x=t.data.x,t.y=t.data.y}),{type:"hexbin",processedData:!0,coordinates:b,binMax:_}):b}({summaryType:b,data:R[0],processedData:a&&!!a[0].processedData,preprocess:!1,finalXExtent:Y,finalYExtent:X,size:M,margin:E,styleFn:k,classFn:w,renderFn:A,chartSize:S}),D=Tt(D,R)):b.type&&"heatmap"===b.type?(R=function({preprocess:t=!0,processedData:n=!1,summaryType:o,data:a,finalXExtent:s=[Math.min(...a.coordinates.map(t=>t.x)),Math.max(...a.coordinates.map(t=>t.x))],finalYExtent:i=[Math.min(...a.coordinates.map(t=>t.y)),Math.max(...a.coordinates.map(t=>t.y))],size:r,xScaleType:l=e.scaleLinear(),yScaleType:c=e.scaleLinear(),margin:u,styleFn:h,classFn:p,renderFn:f,chartSize:m}){if(n&&a)return a.coordinates;a.coordinates&&!a._xyfCoordinates&&(a._xyfCoordinates=a.coordinates.map(t=>[t.x,t.y]));const y=Array.isArray(a)?a:[a];let g,x=[];g=o.type?o:{type:g};const{binValue:v=t=>t.length,xBins:b=g.yBins||.05,yBins:M=b,xCellPx:E=!g.xBins&&g.xCellPx,yCellPx:k=!g.yBins&&g.yCellPx,customMark:w,binMax:A}=g,S=1>b?b:1/b,P=1>M?M:1/M,j=l.domain(s).range([0,r[0]]),$=c.domain(i).range([r[1],0]),O=[Math.ceil((E&&E/r[0]||S)*r[0]*10)/10,Math.ceil((k&&k/r[1]||P)*r[1]*10)/10];let _=-1/0;return y.forEach(t=>{const e=[],n=[];let o,a;for(let s=0;r[0]>Math.ceil(s);s+=O[0]){const i=j.invert(s),l=j.invert(s+O[0]);a=[],e.push(a);for(let e=0;r[1]>Math.ceil(e);e+=O[1]){const r=$.invert(e),c=$.invert(e+O[1]);o={gx:s,gy:e,gw:O[0],gh:O[1],x:(i+l)/2,y:(r+c)/2,binItems:[],value:0,_xyfCoordinates:[[i,r],[l,r],[l,c],[i,c]],parentSummary:t},a.push(o),n.push(o)}a.push(o)}e.push(a),t._xyfCoordinates.forEach((n,o)=>{const a=j(n[0]),s=$(n[1]),i=Math.floor(a/O[0]),r=Math.floor(s/O[1]);e[i][r]&&e[i][r].binItems.push(t.coordinates[o])}),n.forEach(t=>{t.value=v(t.binItems),_=Math.max(_,t.value)}),n.forEach(t=>{t.percent=t.value/_,t.customMark=w&&d.createElement("g",{transform:`translate(${t.gx},${t.gy})`},w({d:t,margin:u,styleFn:h,classFn:p,renderFn:f,chartSize:m,adjustedSize:r}))}),x=[...x,...n]}),A&&A(_),t?{type:"heatmap",processedData:!0,_baseData:[],_xyfCoordinates:[],data:[],bounds:[],x:0,y:0,coordinates:x,binMax:_}:x}({summaryType:b,data:R[0],processedData:a&&!!a[0].processedData,preprocess:!1,finalXExtent:Y,finalYExtent:X,size:M,margin:E,styleFn:k,classFn:w,renderFn:A,chartSize:S}),D=Tt(D,R)):b.type&&"trendline"===b.type&&(R=function({preprocess:t=!1,summaryType:n,data:o,finalXExtent:a=[Math.min(...o.coordinates.map(t=>t.x)),Math.max(...o.coordinates.map(t=>t.x))],xScaleType:i=e.scaleLinear()}){if(t)return o[0].coordinates;let r,l=[];r=n.type?n:{type:r};const{regressionType:c="linear",order:u=2,precision:d=4,controlPoints:h=20,curve:f=s.curveCardinal}=r;let m=c;a[0]>=0||"logarithmic"!==c&&"power"!==c&&"exponential"!==c||(console.error(`Cannot use this ${c} regressionType type with value range that goes below 0, defaulting to linear`),m="linear"),o.coordinates&&!o._xyfCoordinates&&(o._xyfCoordinates=o.coordinates.map(t=>[t.x,t.y]));const y=Array.isArray(o)?o:[o],g=i.domain([0,1]).range(a);return l=[],y.forEach(t=>{const e=p.default[m](t._xyfCoordinates.map(t=>{let e=t[0],n=t[1];return"number"!=typeof e&&(e=e.getTime()),"number"!=typeof n&&(n=n.getTime()),[e,n]}),{order:u,precision:d}),n=1/h;let o=[0,1];if("linear"!==m){o=[];for(let t=0;1+n>t;t+=n)o.push(t)}const a=[];o.forEach(t=>{a.push(e.predict(g(t)))}),l.push({centroid:!1,customMark:void 0,data:t,parentSummary:t,value:e.string,r2:e.r2,curve:f,_xyfCoordinates:a})}),l}({summaryType:b,data:R[0],preprocess:a&&!!a[0].processedData,finalXExtent:Y}),D=Tt(D,R));return P&&(T=T.filter(P),D=D.filter((t,e)=>!t.parentLine||P(t.parentLine,e,[]))),$&&(D=D.filter($)),j&&(R=R.filter(j),D=D.filter((t,e)=>!t.parentSummary||j(t.parentSummary,e,[]))),{xExtent:Y,yExtent:X,projectedLines:T,projectedPoints:N,projectedSummaries:R,fullDataset:D,calculatedXExtent:q,calculatedYExtent:V}};
|