react-native-chart-kit 7.0.0-next.0 → 7.0.0-next.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/README.md +17 -0
- package/dist/v2/core/data/index.d.ts +3 -0
- package/dist/v2/core/data/index.d.ts.map +1 -0
- package/dist/v2/core/data/index.js +1 -0
- package/dist/v2/core/data/normalize.d.ts +8 -0
- package/dist/v2/core/data/normalize.d.ts.map +1 -0
- package/dist/v2/core/data/normalize.js +229 -0
- package/dist/v2/core/data/normalizeValues.d.ts +16 -0
- package/dist/v2/core/data/normalizeValues.d.ts.map +1 -0
- package/dist/v2/core/data/normalizeValues.js +96 -0
- package/dist/v2/core/data/types.d.ts +161 -0
- package/dist/v2/core/data/types.d.ts.map +1 -0
- package/dist/v2/core/data/types.js +1 -0
- package/dist/v2/core/geometry/areaPath.d.ts +3 -0
- package/dist/v2/core/geometry/areaPath.d.ts.map +1 -0
- package/dist/v2/core/geometry/areaPath.js +36 -0
- package/dist/v2/core/geometry/barRects.d.ts +44 -0
- package/dist/v2/core/geometry/barRects.d.ts.map +1 -0
- package/dist/v2/core/geometry/barRects.js +201 -0
- package/dist/v2/core/geometry/contributionHeatmap.d.ts +49 -0
- package/dist/v2/core/geometry/contributionHeatmap.d.ts.map +1 -0
- package/dist/v2/core/geometry/contributionHeatmap.js +107 -0
- package/dist/v2/core/geometry/horizontalBarRects.d.ts +27 -0
- package/dist/v2/core/geometry/horizontalBarRects.d.ts.map +1 -0
- package/dist/v2/core/geometry/horizontalBarRects.js +202 -0
- package/dist/v2/core/geometry/index.d.ts +12 -0
- package/dist/v2/core/geometry/index.d.ts.map +1 -0
- package/dist/v2/core/geometry/index.js +11 -0
- package/dist/v2/core/geometry/lineDecimation.d.ts +8 -0
- package/dist/v2/core/geometry/lineDecimation.d.ts.map +1 -0
- package/dist/v2/core/geometry/lineDecimation.js +110 -0
- package/dist/v2/core/geometry/linePath.d.ts +5 -0
- package/dist/v2/core/geometry/linePath.d.ts.map +1 -0
- package/dist/v2/core/geometry/linePath.js +98 -0
- package/dist/v2/core/geometry/lineSeries.d.ts +29 -0
- package/dist/v2/core/geometry/lineSeries.d.ts.map +1 -0
- package/dist/v2/core/geometry/lineSeries.js +51 -0
- package/dist/v2/core/geometry/path.d.ts +6 -0
- package/dist/v2/core/geometry/path.d.ts.map +1 -0
- package/dist/v2/core/geometry/path.js +24 -0
- package/dist/v2/core/geometry/pieArcs.d.ts +29 -0
- package/dist/v2/core/geometry/pieArcs.d.ts.map +1 -0
- package/dist/v2/core/geometry/pieArcs.js +142 -0
- package/dist/v2/core/geometry/progressRings.d.ts +30 -0
- package/dist/v2/core/geometry/progressRings.d.ts.map +1 -0
- package/dist/v2/core/geometry/progressRings.js +104 -0
- package/dist/v2/core/geometry/types.d.ts +32 -0
- package/dist/v2/core/geometry/types.d.ts.map +1 -0
- package/dist/v2/core/geometry/types.js +1 -0
- package/dist/v2/core/index.d.ts +6 -0
- package/dist/v2/core/index.d.ts.map +1 -0
- package/dist/v2/core/index.js +6 -0
- package/dist/v2/core/interaction/index.d.ts +5 -0
- package/dist/v2/core/interaction/index.d.ts.map +1 -0
- package/dist/v2/core/interaction/index.js +2 -0
- package/dist/v2/core/interaction/viewport.d.ts +71 -0
- package/dist/v2/core/interaction/viewport.d.ts.map +1 -0
- package/dist/v2/core/interaction/viewport.js +216 -0
- package/dist/v2/core/interaction/viewportTransform.d.ts +17 -0
- package/dist/v2/core/interaction/viewportTransform.d.ts.map +1 -0
- package/dist/v2/core/interaction/viewportTransform.js +70 -0
- package/dist/v2/core/layout/autoPadding.d.ts +3 -0
- package/dist/v2/core/layout/autoPadding.d.ts.map +1 -0
- package/dist/v2/core/layout/autoPadding.js +33 -0
- package/dist/v2/core/layout/chartBox.d.ts +5 -0
- package/dist/v2/core/layout/chartBox.d.ts.map +1 -0
- package/dist/v2/core/layout/chartBox.js +22 -0
- package/dist/v2/core/layout/debugLayout.d.ts +3 -0
- package/dist/v2/core/layout/debugLayout.d.ts.map +1 -0
- package/dist/v2/core/layout/debugLayout.js +20 -0
- package/dist/v2/core/layout/index.d.ts +8 -0
- package/dist/v2/core/layout/index.d.ts.map +1 -0
- package/dist/v2/core/layout/index.js +6 -0
- package/dist/v2/core/layout/labelCollision.d.ts +3 -0
- package/dist/v2/core/layout/labelCollision.d.ts.map +1 -0
- package/dist/v2/core/layout/labelCollision.js +90 -0
- package/dist/v2/core/layout/legendLayout.d.ts +3 -0
- package/dist/v2/core/layout/legendLayout.d.ts.map +1 -0
- package/dist/v2/core/layout/legendLayout.js +39 -0
- package/dist/v2/core/layout/tooltipPlacement.d.ts +3 -0
- package/dist/v2/core/layout/tooltipPlacement.d.ts.map +1 -0
- package/dist/v2/core/layout/tooltipPlacement.js +76 -0
- package/dist/v2/core/layout/types.d.ts +114 -0
- package/dist/v2/core/layout/types.d.ts.map +1 -0
- package/dist/v2/core/layout/types.js +1 -0
- package/dist/v2/core/scales/band.d.ts +15 -0
- package/dist/v2/core/scales/band.d.ts.map +1 -0
- package/dist/v2/core/scales/band.js +34 -0
- package/dist/v2/core/scales/domain.d.ts +6 -0
- package/dist/v2/core/scales/domain.d.ts.map +1 -0
- package/dist/v2/core/scales/domain.js +109 -0
- package/dist/v2/core/scales/index.d.ts +7 -0
- package/dist/v2/core/scales/index.d.ts.map +1 -0
- package/dist/v2/core/scales/index.js +5 -0
- package/dist/v2/core/scales/linear.d.ts +8 -0
- package/dist/v2/core/scales/linear.d.ts.map +1 -0
- package/dist/v2/core/scales/linear.js +22 -0
- package/dist/v2/core/scales/ticks.d.ts +4 -0
- package/dist/v2/core/scales/ticks.d.ts.map +1 -0
- package/dist/v2/core/scales/ticks.js +111 -0
- package/dist/v2/core/scales/time.d.ts +8 -0
- package/dist/v2/core/scales/time.d.ts.map +1 -0
- package/dist/v2/core/scales/time.js +23 -0
- package/dist/v2/core/scales/types.d.ts +46 -0
- package/dist/v2/core/scales/types.d.ts.map +1 -0
- package/dist/v2/core/scales/types.js +1 -0
- package/dist/v2/index.d.ts +1 -0
- package/dist/v2/index.js +1 -0
- package/dist/v2/react-native/charts/bar/BarChart.d.ts +6 -0
- package/dist/v2/react-native/charts/bar/BarChart.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/BarChart.js +198 -0
- package/dist/v2/react-native/charts/bar/BarChartSurface.d.ts +36 -0
- package/dist/v2/react-native/charts/bar/BarChartSurface.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/BarChartSurface.js +126 -0
- package/dist/v2/react-native/charts/bar/StackedBarChart.d.ts +4 -0
- package/dist/v2/react-native/charts/bar/StackedBarChart.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/StackedBarChart.js +9 -0
- package/dist/v2/react-native/charts/bar/accessibility.d.ts +31 -0
- package/dist/v2/react-native/charts/bar/accessibility.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/accessibility.js +87 -0
- package/dist/v2/react-native/charts/bar/interaction.d.ts +18 -0
- package/dist/v2/react-native/charts/bar/interaction.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/interaction.js +62 -0
- package/dist/v2/react-native/charts/bar/model.d.ts +3 -0
- package/dist/v2/react-native/charts/bar/model.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/model.js +326 -0
- package/dist/v2/react-native/charts/bar/modelUtils.d.ts +27 -0
- package/dist/v2/react-native/charts/bar/modelUtils.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/modelUtils.js +58 -0
- package/dist/v2/react-native/charts/bar/options.d.ts +7 -0
- package/dist/v2/react-native/charts/bar/options.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/options.js +49 -0
- package/dist/v2/react-native/charts/bar/rendererSafety.d.ts +12 -0
- package/dist/v2/react-native/charts/bar/rendererSafety.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/rendererSafety.js +31 -0
- package/dist/v2/react-native/charts/bar/selectionAnimation.d.ts +42 -0
- package/dist/v2/react-native/charts/bar/selectionAnimation.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/selectionAnimation.js +158 -0
- package/dist/v2/react-native/charts/bar/stackedCompat.d.ts +55 -0
- package/dist/v2/react-native/charts/bar/stackedCompat.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/stackedCompat.js +105 -0
- package/dist/v2/react-native/charts/bar/tooltip.d.ts +11 -0
- package/dist/v2/react-native/charts/bar/tooltip.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/tooltip.js +15 -0
- package/dist/v2/react-native/charts/bar/tooltipModel.d.ts +33 -0
- package/dist/v2/react-native/charts/bar/tooltipModel.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/tooltipModel.js +40 -0
- package/dist/v2/react-native/charts/bar/tooltipPlacement.d.ts +9 -0
- package/dist/v2/react-native/charts/bar/tooltipPlacement.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/tooltipPlacement.js +9 -0
- package/dist/v2/react-native/charts/bar/types.d.ts +211 -0
- package/dist/v2/react-native/charts/bar/types.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/types.js +1 -0
- package/dist/v2/react-native/charts/bar/useAnimatedTooltipModel.d.ts +10 -0
- package/dist/v2/react-native/charts/bar/useAnimatedTooltipModel.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/useAnimatedTooltipModel.js +87 -0
- package/dist/v2/react-native/charts/bar/viewport.d.ts +20 -0
- package/dist/v2/react-native/charts/bar/viewport.d.ts.map +1 -0
- package/dist/v2/react-native/charts/bar/viewport.js +47 -0
- package/dist/v2/react-native/charts/contribution/ContributionGraph.d.ts +13 -0
- package/dist/v2/react-native/charts/contribution/ContributionGraph.d.ts.map +1 -0
- package/dist/v2/react-native/charts/contribution/ContributionGraph.js +65 -0
- package/dist/v2/react-native/charts/contribution/accessibility.d.ts +25 -0
- package/dist/v2/react-native/charts/contribution/accessibility.d.ts.map +1 -0
- package/dist/v2/react-native/charts/contribution/accessibility.js +50 -0
- package/dist/v2/react-native/charts/contribution/model.d.ts +17 -0
- package/dist/v2/react-native/charts/contribution/model.d.ts.map +1 -0
- package/dist/v2/react-native/charts/contribution/model.js +102 -0
- package/dist/v2/react-native/charts/contribution/types.d.ts +50 -0
- package/dist/v2/react-native/charts/contribution/types.d.ts.map +1 -0
- package/dist/v2/react-native/charts/contribution/types.js +1 -0
- package/dist/v2/react-native/charts/line/AreaChart.d.ts +3 -0
- package/dist/v2/react-native/charts/line/AreaChart.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/AreaChart.js +3 -0
- package/dist/v2/react-native/charts/line/ChartSurface.d.ts +16 -0
- package/dist/v2/react-native/charts/line/ChartSurface.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/ChartSurface.js +151 -0
- package/dist/v2/react-native/charts/line/LineChart.d.ts +6 -0
- package/dist/v2/react-native/charts/line/LineChart.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/LineChart.js +294 -0
- package/dist/v2/react-native/charts/line/StickyYAxis.d.ts +15 -0
- package/dist/v2/react-native/charts/line/StickyYAxis.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/StickyYAxis.js +26 -0
- package/dist/v2/react-native/charts/line/accessibility.d.ts +34 -0
- package/dist/v2/react-native/charts/line/accessibility.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/accessibility.js +103 -0
- package/dist/v2/react-native/charts/line/axisLabels.d.ts +37 -0
- package/dist/v2/react-native/charts/line/axisLabels.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/axisLabels.js +55 -0
- package/dist/v2/react-native/charts/line/debugLayout.d.ts +26 -0
- package/dist/v2/react-native/charts/line/debugLayout.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/debugLayout.js +77 -0
- package/dist/v2/react-native/charts/line/debugOverlay.d.ts +9 -0
- package/dist/v2/react-native/charts/line/debugOverlay.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/debugOverlay.js +30 -0
- package/dist/v2/react-native/charts/line/defaultTooltip.d.ts +3 -0
- package/dist/v2/react-native/charts/line/defaultTooltip.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/defaultTooltip.js +17 -0
- package/dist/v2/react-native/charts/line/interaction.d.ts +82 -0
- package/dist/v2/react-native/charts/line/interaction.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/interaction.js +94 -0
- package/dist/v2/react-native/charts/line/legend.d.ts +35 -0
- package/dist/v2/react-native/charts/line/legend.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/legend.js +95 -0
- package/dist/v2/react-native/charts/line/markers.d.ts +11 -0
- package/dist/v2/react-native/charts/line/markers.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/markers.js +52 -0
- package/dist/v2/react-native/charts/line/options.d.ts +172 -0
- package/dist/v2/react-native/charts/line/options.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/options.js +168 -0
- package/dist/v2/react-native/charts/line/outsidePressSurfaces.d.ts +15 -0
- package/dist/v2/react-native/charts/line/outsidePressSurfaces.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/outsidePressSurfaces.js +37 -0
- package/dist/v2/react-native/charts/line/overviewProps.d.ts +45 -0
- package/dist/v2/react-native/charts/line/overviewProps.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/overviewProps.js +4 -0
- package/dist/v2/react-native/charts/line/rangeSelector.d.ts +19 -0
- package/dist/v2/react-native/charts/line/rangeSelector.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/rangeSelector.js +176 -0
- package/dist/v2/react-native/charts/line/rangeSelectorConfig.d.ts +38 -0
- package/dist/v2/react-native/charts/line/rangeSelectorConfig.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/rangeSelectorConfig.js +41 -0
- package/dist/v2/react-native/charts/line/referenceLabelPlacement.d.ts +21 -0
- package/dist/v2/react-native/charts/line/referenceLabelPlacement.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/referenceLabelPlacement.js +113 -0
- package/dist/v2/react-native/charts/line/references.d.ts +62 -0
- package/dist/v2/react-native/charts/line/references.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/references.js +156 -0
- package/dist/v2/react-native/charts/line/renderer.d.ts +4 -0
- package/dist/v2/react-native/charts/line/renderer.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/renderer.js +23 -0
- package/dist/v2/react-native/charts/line/responders.d.ts +13 -0
- package/dist/v2/react-native/charts/line/responders.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/responders.js +59 -0
- package/dist/v2/react-native/charts/line/selection.d.ts +31 -0
- package/dist/v2/react-native/charts/line/selection.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/selection.js +26 -0
- package/dist/v2/react-native/charts/line/seriesInput.d.ts +4 -0
- package/dist/v2/react-native/charts/line/seriesInput.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/seriesInput.js +13 -0
- package/dist/v2/react-native/charts/line/seriesStyles.d.ts +20 -0
- package/dist/v2/react-native/charts/line/seriesStyles.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/seriesStyles.js +33 -0
- package/dist/v2/react-native/charts/line/stickyYAxisLayout.d.ts +6 -0
- package/dist/v2/react-native/charts/line/stickyYAxisLayout.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/stickyYAxisLayout.js +2 -0
- package/dist/v2/react-native/charts/line/text.d.ts +7 -0
- package/dist/v2/react-native/charts/line/text.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/text.js +7 -0
- package/dist/v2/react-native/charts/line/thresholdRendering.d.ts +28 -0
- package/dist/v2/react-native/charts/line/thresholdRendering.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/thresholdRendering.js +145 -0
- package/dist/v2/react-native/charts/line/tooltip.d.ts +70 -0
- package/dist/v2/react-native/charts/line/tooltip.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/tooltip.js +87 -0
- package/dist/v2/react-native/charts/line/types.d.ts +371 -0
- package/dist/v2/react-native/charts/line/types.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/types.js +1 -0
- package/dist/v2/react-native/charts/line/useAnimatedTooltipModel.d.ts +13 -0
- package/dist/v2/react-native/charts/line/useAnimatedTooltipModel.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/useAnimatedTooltipModel.js +84 -0
- package/dist/v2/react-native/charts/line/useAnimatedYAxisLabels.d.ts +5 -0
- package/dist/v2/react-native/charts/line/useAnimatedYAxisLabels.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/useAnimatedYAxisLabels.js +141 -0
- package/dist/v2/react-native/charts/line/useChartModel.d.ts +103 -0
- package/dist/v2/react-native/charts/line/useChartModel.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/useChartModel.js +367 -0
- package/dist/v2/react-native/charts/line/useDebugLayout.d.ts +16 -0
- package/dist/v2/react-native/charts/line/useDebugLayout.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/useDebugLayout.js +35 -0
- package/dist/v2/react-native/charts/line/utils.d.ts +10 -0
- package/dist/v2/react-native/charts/line/utils.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/utils.js +40 -0
- package/dist/v2/react-native/charts/line/viewportInteraction.d.ts +3 -0
- package/dist/v2/react-native/charts/line/viewportInteraction.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/viewportInteraction.js +1 -0
- package/dist/v2/react-native/charts/line/viewportInteractionConfig.d.ts +3 -0
- package/dist/v2/react-native/charts/line/viewportInteractionConfig.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/viewportInteractionConfig.js +1 -0
- package/dist/v2/react-native/charts/line/viewportPinchZoom.d.ts +2 -0
- package/dist/v2/react-native/charts/line/viewportPinchZoom.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/viewportPinchZoom.js +1 -0
- package/dist/v2/react-native/charts/line/xLabelCandidates.d.ts +13 -0
- package/dist/v2/react-native/charts/line/xLabelCandidates.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/xLabelCandidates.js +23 -0
- package/dist/v2/react-native/charts/line/xLabels.d.ts +39 -0
- package/dist/v2/react-native/charts/line/xLabels.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/xLabels.js +289 -0
- package/dist/v2/react-native/charts/line/xScale.d.ts +6 -0
- package/dist/v2/react-native/charts/line/xScale.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/xScale.js +25 -0
- package/dist/v2/react-native/charts/line/yAxisModel.d.ts +29 -0
- package/dist/v2/react-native/charts/line/yAxisModel.d.ts.map +1 -0
- package/dist/v2/react-native/charts/line/yAxisModel.js +39 -0
- package/dist/v2/react-native/charts/pie/PieChart.d.ts +7 -0
- package/dist/v2/react-native/charts/pie/PieChart.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/PieChart.js +244 -0
- package/dist/v2/react-native/charts/pie/accessibility.d.ts +28 -0
- package/dist/v2/react-native/charts/pie/accessibility.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/accessibility.js +49 -0
- package/dist/v2/react-native/charts/pie/activeSlice.d.ts +15 -0
- package/dist/v2/react-native/charts/pie/activeSlice.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/activeSlice.js +26 -0
- package/dist/v2/react-native/charts/pie/arcLabels.d.ts +32 -0
- package/dist/v2/react-native/charts/pie/arcLabels.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/arcLabels.js +191 -0
- package/dist/v2/react-native/charts/pie/interaction.d.ts +26 -0
- package/dist/v2/react-native/charts/pie/interaction.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/interaction.js +66 -0
- package/dist/v2/react-native/charts/pie/model.d.ts +15 -0
- package/dist/v2/react-native/charts/pie/model.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/model.js +157 -0
- package/dist/v2/react-native/charts/pie/selectionAnimation.d.ts +33 -0
- package/dist/v2/react-native/charts/pie/selectionAnimation.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/selectionAnimation.js +121 -0
- package/dist/v2/react-native/charts/pie/sliceSeparator.d.ts +7 -0
- package/dist/v2/react-native/charts/pie/sliceSeparator.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/sliceSeparator.js +26 -0
- package/dist/v2/react-native/charts/pie/slices.d.ts +20 -0
- package/dist/v2/react-native/charts/pie/slices.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/slices.js +54 -0
- package/dist/v2/react-native/charts/pie/types.d.ts +165 -0
- package/dist/v2/react-native/charts/pie/types.d.ts.map +1 -0
- package/dist/v2/react-native/charts/pie/types.js +1 -0
- package/dist/v2/react-native/charts/progress/ProgressChart.d.ts +7 -0
- package/dist/v2/react-native/charts/progress/ProgressChart.d.ts.map +1 -0
- package/dist/v2/react-native/charts/progress/ProgressChart.js +111 -0
- package/dist/v2/react-native/charts/progress/accessibility.d.ts +26 -0
- package/dist/v2/react-native/charts/progress/accessibility.d.ts.map +1 -0
- package/dist/v2/react-native/charts/progress/accessibility.js +71 -0
- package/dist/v2/react-native/charts/progress/animation.d.ts +36 -0
- package/dist/v2/react-native/charts/progress/animation.d.ts.map +1 -0
- package/dist/v2/react-native/charts/progress/animation.js +103 -0
- package/dist/v2/react-native/charts/progress/model.d.ts +14 -0
- package/dist/v2/react-native/charts/progress/model.d.ts.map +1 -0
- package/dist/v2/react-native/charts/progress/model.js +133 -0
- package/dist/v2/react-native/charts/progress/types.d.ts +72 -0
- package/dist/v2/react-native/charts/progress/types.d.ts.map +1 -0
- package/dist/v2/react-native/charts/progress/types.js +1 -0
- package/dist/v2/react-native/index.d.ts +24 -0
- package/dist/v2/react-native/index.d.ts.map +1 -0
- package/dist/v2/react-native/index.js +14 -0
- package/dist/v2/react-native/selection/ChartSelectionProvider.d.ts +27 -0
- package/dist/v2/react-native/selection/ChartSelectionProvider.d.ts.map +1 -0
- package/dist/v2/react-native/selection/ChartSelectionProvider.js +92 -0
- package/dist/v2/react-native/selection/index.d.ts +2 -0
- package/dist/v2/react-native/selection/index.d.ts.map +1 -0
- package/dist/v2/react-native/selection/index.js +1 -0
- package/dist/v2/react-native/selection/scope.d.ts +16 -0
- package/dist/v2/react-native/selection/scope.d.ts.map +1 -0
- package/dist/v2/react-native/selection/scope.js +18 -0
- package/dist/v2/react-native/theme/index.d.ts +4 -0
- package/dist/v2/react-native/theme/index.d.ts.map +1 -0
- package/dist/v2/react-native/theme/index.js +2 -0
- package/dist/v2/react-native/theme/presets.d.ts +84 -0
- package/dist/v2/react-native/theme/presets.d.ts.map +1 -0
- package/dist/v2/react-native/theme/presets.js +298 -0
- package/dist/v2/react-native/theme/provider.d.ts +20 -0
- package/dist/v2/react-native/theme/provider.d.ts.map +1 -0
- package/dist/v2/react-native/theme/provider.js +27 -0
- package/dist/v2/react-native/viewport/bounds.d.ts +7 -0
- package/dist/v2/react-native/viewport/bounds.d.ts.map +1 -0
- package/dist/v2/react-native/viewport/bounds.js +7 -0
- package/dist/v2/react-native/viewport/config.d.ts +13 -0
- package/dist/v2/react-native/viewport/config.d.ts.map +1 -0
- package/dist/v2/react-native/viewport/config.js +64 -0
- package/dist/v2/react-native/viewport/pan.d.ts +23 -0
- package/dist/v2/react-native/viewport/pan.d.ts.map +1 -0
- package/dist/v2/react-native/viewport/pan.js +110 -0
- package/dist/v2/react-native/viewport/panResponder.d.ts +14 -0
- package/dist/v2/react-native/viewport/panResponder.d.ts.map +1 -0
- package/dist/v2/react-native/viewport/panResponder.js +115 -0
- package/dist/v2/react-native/viewport/pinchZoom.d.ts +17 -0
- package/dist/v2/react-native/viewport/pinchZoom.d.ts.map +1 -0
- package/dist/v2/react-native/viewport/pinchZoom.js +131 -0
- package/dist/v2/react-native/viewport/types.d.ts +55 -0
- package/dist/v2/react-native/viewport/types.d.ts.map +1 -0
- package/dist/v2/react-native/viewport/types.js +1 -0
- package/dist/v2/svg-renderer/capabilities.d.ts +3 -0
- package/dist/v2/svg-renderer/capabilities.d.ts.map +1 -0
- package/dist/v2/svg-renderer/capabilities.js +12 -0
- package/dist/v2/svg-renderer/clipPath.d.ts +4 -0
- package/dist/v2/svg-renderer/clipPath.d.ts.map +1 -0
- package/dist/v2/svg-renderer/clipPath.js +35 -0
- package/dist/v2/svg-renderer/defs.d.ts +6 -0
- package/dist/v2/svg-renderer/defs.d.ts.map +1 -0
- package/dist/v2/svg-renderer/defs.js +18 -0
- package/dist/v2/svg-renderer/ensureConsole.d.ts +4 -0
- package/dist/v2/svg-renderer/ensureConsole.d.ts.map +1 -0
- package/dist/v2/svg-renderer/ensureConsole.js +54 -0
- package/dist/v2/svg-renderer/hitRegions.d.ts +3 -0
- package/dist/v2/svg-renderer/hitRegions.d.ts.map +1 -0
- package/dist/v2/svg-renderer/hitRegions.js +6 -0
- package/dist/v2/svg-renderer/index.d.ts +14 -0
- package/dist/v2/svg-renderer/index.d.ts.map +1 -0
- package/dist/v2/svg-renderer/index.js +13 -0
- package/dist/v2/svg-renderer/layerOrder.d.ts +19 -0
- package/dist/v2/svg-renderer/layerOrder.d.ts.map +1 -0
- package/dist/v2/svg-renderer/layerOrder.js +18 -0
- package/dist/v2/svg-renderer/layers.d.ts +3 -0
- package/dist/v2/svg-renderer/layers.d.ts.map +1 -0
- package/dist/v2/svg-renderer/layers.js +4 -0
- package/dist/v2/svg-renderer/primitives.d.ts +12 -0
- package/dist/v2/svg-renderer/primitives.d.ts.map +1 -0
- package/dist/v2/svg-renderer/primitives.js +13 -0
- package/dist/v2/svg-renderer/renderer.d.ts +4 -0
- package/dist/v2/svg-renderer/renderer.d.ts.map +1 -0
- package/dist/v2/svg-renderer/renderer.js +24 -0
- package/dist/v2/svg-renderer/symbolGeometry.d.ts +6 -0
- package/dist/v2/svg-renderer/symbolGeometry.d.ts.map +1 -0
- package/dist/v2/svg-renderer/symbolGeometry.js +10 -0
- package/dist/v2/svg-renderer/symbols.d.ts +3 -0
- package/dist/v2/svg-renderer/symbols.d.ts.map +1 -0
- package/dist/v2/svg-renderer/symbols.js +23 -0
- package/dist/v2/svg-renderer/testIds.d.ts +2 -0
- package/dist/v2/svg-renderer/testIds.d.ts.map +1 -0
- package/dist/v2/svg-renderer/testIds.js +10 -0
- package/dist/v2/svg-renderer/textMeasurement.d.ts +4 -0
- package/dist/v2/svg-renderer/textMeasurement.d.ts.map +1 -0
- package/dist/v2/svg-renderer/textMeasurement.js +37 -0
- package/dist/v2/svg-renderer/types.d.ts +134 -0
- package/dist/v2/svg-renderer/types.d.ts.map +1 -0
- package/dist/v2/svg-renderer/types.js +1 -0
- package/package.json +46 -47
- package/v2/index.d.ts +1 -0
- package/v2/index.js +1 -0
- package/v2/package.json +6 -0
- package/scripts/chartkit-codemod.mjs +0 -256
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
const isFiniteGeometryPoint = (point) => {
|
|
2
|
+
return point.defined && Number.isFinite(point.x) && Number.isFinite(point.y);
|
|
3
|
+
};
|
|
4
|
+
const appendUniquePoint = (points, point) => {
|
|
5
|
+
if (points[points.length - 1] !== point) {
|
|
6
|
+
points.push(point);
|
|
7
|
+
}
|
|
8
|
+
};
|
|
9
|
+
export const splitLinePathSegments = (points, connectNulls = false) => {
|
|
10
|
+
if (connectNulls) {
|
|
11
|
+
return [points.filter(isFiniteGeometryPoint)];
|
|
12
|
+
}
|
|
13
|
+
const segments = [];
|
|
14
|
+
let current = [];
|
|
15
|
+
points.forEach((point) => {
|
|
16
|
+
if (isFiniteGeometryPoint(point)) {
|
|
17
|
+
current.push(point);
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
if (current.length > 0) {
|
|
21
|
+
segments.push(current);
|
|
22
|
+
current = [];
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
if (current.length > 0) {
|
|
26
|
+
segments.push(current);
|
|
27
|
+
}
|
|
28
|
+
return segments;
|
|
29
|
+
};
|
|
30
|
+
const getSegmentMinimumBudget = (segment) => {
|
|
31
|
+
return segment.length > 1 ? 2 : segment.length;
|
|
32
|
+
};
|
|
33
|
+
const decimateMinMaxSegment = (segment, maxPoints) => {
|
|
34
|
+
if (segment.length <= maxPoints) {
|
|
35
|
+
return segment;
|
|
36
|
+
}
|
|
37
|
+
if (maxPoints <= 1) {
|
|
38
|
+
return segment.slice(0, 1);
|
|
39
|
+
}
|
|
40
|
+
const first = segment[0];
|
|
41
|
+
const last = segment[segment.length - 1];
|
|
42
|
+
const interior = segment.slice(1, -1);
|
|
43
|
+
const selected = [first];
|
|
44
|
+
const interiorBudget = Math.max(0, maxPoints - 2);
|
|
45
|
+
const bucketCount = Math.max(1, Math.ceil(interiorBudget / 2));
|
|
46
|
+
const bucketSize = interior.length / bucketCount;
|
|
47
|
+
for (let bucketIndex = 0; bucketIndex < bucketCount; bucketIndex++) {
|
|
48
|
+
const bucketStart = Math.floor(bucketIndex * bucketSize);
|
|
49
|
+
const bucketEnd = bucketIndex === bucketCount - 1
|
|
50
|
+
? interior.length
|
|
51
|
+
: Math.floor((bucketIndex + 1) * bucketSize);
|
|
52
|
+
const bucket = interior.slice(bucketStart, bucketEnd);
|
|
53
|
+
if (bucket.length === 0) {
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
let minIndex = 0;
|
|
57
|
+
let maxIndex = 0;
|
|
58
|
+
bucket.forEach((point, index) => {
|
|
59
|
+
if (point.y < bucket[minIndex].y) {
|
|
60
|
+
minIndex = index;
|
|
61
|
+
}
|
|
62
|
+
if (point.y > bucket[maxIndex].y) {
|
|
63
|
+
maxIndex = index;
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
const extrema = minIndex <= maxIndex
|
|
67
|
+
? [bucket[minIndex], bucket[maxIndex]]
|
|
68
|
+
: [bucket[maxIndex], bucket[minIndex]];
|
|
69
|
+
for (const point of extrema) {
|
|
70
|
+
if (selected.length >= maxPoints - 1) {
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
appendUniquePoint(selected, point);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
appendUniquePoint(selected, last);
|
|
77
|
+
return selected;
|
|
78
|
+
};
|
|
79
|
+
const allocateSegmentBudgets = (segments, maxPoints) => {
|
|
80
|
+
const minimumRequired = segments.reduce((sum, segment) => sum + getSegmentMinimumBudget(segment), 0);
|
|
81
|
+
const effectiveMaxPoints = Math.max(maxPoints, minimumRequired);
|
|
82
|
+
let remainingBudget = effectiveMaxPoints;
|
|
83
|
+
let remainingPoints = segments.reduce((sum, segment) => sum + segment.length, 0);
|
|
84
|
+
return segments.map((segment, index) => {
|
|
85
|
+
if (index === segments.length - 1) {
|
|
86
|
+
return Math.min(segment.length, remainingBudget);
|
|
87
|
+
}
|
|
88
|
+
const minimumBudget = getSegmentMinimumBudget(segment);
|
|
89
|
+
const proportionalBudget = Math.round((segment.length / remainingPoints) * remainingBudget);
|
|
90
|
+
const budget = Math.min(segment.length, Math.max(minimumBudget, proportionalBudget));
|
|
91
|
+
remainingBudget -= budget;
|
|
92
|
+
remainingPoints -= segment.length;
|
|
93
|
+
return budget;
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
export const getDecimatedLinePathSegments = ({ connectNulls = false, decimation, points }) => {
|
|
97
|
+
const segments = splitLinePathSegments(points, connectNulls).filter((segment) => segment.length > 0);
|
|
98
|
+
if (!decimation ||
|
|
99
|
+
!Number.isFinite(decimation.maxPoints) ||
|
|
100
|
+
decimation.maxPoints <= 0) {
|
|
101
|
+
return segments;
|
|
102
|
+
}
|
|
103
|
+
const totalPointCount = segments.reduce((sum, segment) => sum + segment.length, 0);
|
|
104
|
+
const maxPoints = Math.floor(decimation.maxPoints);
|
|
105
|
+
if (totalPointCount <= maxPoints) {
|
|
106
|
+
return segments;
|
|
107
|
+
}
|
|
108
|
+
const budgets = allocateSegmentBudgets(segments, maxPoints);
|
|
109
|
+
return segments.map((segment, index) => decimateMinMaxSegment(segment, budgets[index] ?? segment.length));
|
|
110
|
+
};
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { BuildLinePathOptions, GeometryPoint, LinePathModel } from "./types";
|
|
2
|
+
export declare const splitDefinedSegments: <TPoint extends GeometryPoint = GeometryPoint>(points: TPoint[], connectNulls?: boolean) => TPoint[][];
|
|
3
|
+
export declare const buildLineSegmentPath: <TPoint extends GeometryPoint>(points: TPoint[], curve?: BuildLinePathOptions<TPoint>["curve"]) => string;
|
|
4
|
+
export declare const buildLinePath: <TPoint extends GeometryPoint = GeometryPoint>({ points, curve, connectNulls, decimation }: BuildLinePathOptions<TPoint>) => LinePathModel<TPoint>;
|
|
5
|
+
//# sourceMappingURL=linePath.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linePath.d.ts","sourceRoot":"","sources":["../../src/geometry/linePath.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EACV,oBAAoB,EACpB,aAAa,EAEb,aAAa,EACd,MAAM,SAAS,CAAC;AAEjB,eAAO,MAAM,oBAAoB,GAC/B,MAAM,SAAS,aAAa,GAAG,aAAa,EAE5C,QAAQ,MAAM,EAAE,EAChB,sBAAoB,KACnB,MAAM,EAAE,EAAiD,CAAC;AAgH7D,eAAO,MAAM,oBAAoB,GAAI,MAAM,SAAS,aAAa,EAC/D,QAAQ,MAAM,EAAE,EAChB,QAAO,oBAAoB,CAAC,MAAM,CAAC,CAAC,OAAO,CAAY,WAexD,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,MAAM,SAAS,aAAa,GAAG,aAAa,EAAE,6CAKzE,oBAAoB,CAAC,MAAM,CAAC,KAAG,aAAa,CAAC,MAAM,CAcrD,CAAC"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { cubicCommand, horizontalCommand, pointCommand, verticalCommand } from "./path";
|
|
2
|
+
import { getDecimatedLinePathSegments, splitLinePathSegments } from "./lineDecimation";
|
|
3
|
+
export const splitDefinedSegments = (points, connectNulls = false) => splitLinePathSegments(points, connectNulls);
|
|
4
|
+
const buildLinearSegmentPath = (points) => {
|
|
5
|
+
return points
|
|
6
|
+
.map((point, index) => pointCommand(index === 0 ? "M" : "L", point.x, point.y))
|
|
7
|
+
.join(" ");
|
|
8
|
+
};
|
|
9
|
+
const buildStepSegmentPath = (points) => {
|
|
10
|
+
if (points.length === 0) {
|
|
11
|
+
return "";
|
|
12
|
+
}
|
|
13
|
+
const first = points[0];
|
|
14
|
+
if (!first) {
|
|
15
|
+
return "";
|
|
16
|
+
}
|
|
17
|
+
const rest = points.slice(1);
|
|
18
|
+
let path = pointCommand("M", first.x, first.y);
|
|
19
|
+
let previous = first;
|
|
20
|
+
rest.forEach((point) => {
|
|
21
|
+
const midpoint = previous.x + (point.x - previous.x) / 2;
|
|
22
|
+
path = [
|
|
23
|
+
path,
|
|
24
|
+
horizontalCommand(midpoint),
|
|
25
|
+
verticalCommand(point.y),
|
|
26
|
+
horizontalCommand(point.x)
|
|
27
|
+
].join(" ");
|
|
28
|
+
previous = point;
|
|
29
|
+
});
|
|
30
|
+
return path;
|
|
31
|
+
};
|
|
32
|
+
const isStrictlyIncreasingX = (points) => {
|
|
33
|
+
return points.every((point, index) => {
|
|
34
|
+
return index === 0 || point.x > points[index - 1].x;
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
const buildMonotoneSegmentPath = (points) => {
|
|
38
|
+
if (points.length < 3 || !isStrictlyIncreasingX(points)) {
|
|
39
|
+
return buildLinearSegmentPath(points);
|
|
40
|
+
}
|
|
41
|
+
const slopes = points.slice(0, -1).map((point, index) => {
|
|
42
|
+
const next = points[index + 1];
|
|
43
|
+
return (next.y - point.y) / (next.x - point.x);
|
|
44
|
+
});
|
|
45
|
+
const tangents = points.map((_, index) => {
|
|
46
|
+
if (index === 0) {
|
|
47
|
+
return slopes[0];
|
|
48
|
+
}
|
|
49
|
+
if (index === points.length - 1) {
|
|
50
|
+
return slopes[slopes.length - 1];
|
|
51
|
+
}
|
|
52
|
+
const previousSlope = slopes[index - 1];
|
|
53
|
+
const nextSlope = slopes[index];
|
|
54
|
+
if (previousSlope * nextSlope <= 0) {
|
|
55
|
+
return 0;
|
|
56
|
+
}
|
|
57
|
+
const sign = Math.sign(previousSlope);
|
|
58
|
+
return (sign *
|
|
59
|
+
Math.min(Math.abs(previousSlope), Math.abs(nextSlope), Math.abs((previousSlope + nextSlope) / 2)));
|
|
60
|
+
});
|
|
61
|
+
let path = pointCommand("M", points[0].x, points[0].y);
|
|
62
|
+
for (let index = 0; index < points.length - 1; index++) {
|
|
63
|
+
const point = points[index];
|
|
64
|
+
const next = points[index + 1];
|
|
65
|
+
const deltaX = next.x - point.x;
|
|
66
|
+
path = [
|
|
67
|
+
path,
|
|
68
|
+
cubicCommand(point.x + deltaX / 3, point.y + (tangents[index] * deltaX) / 3, next.x - deltaX / 3, next.y - (tangents[index + 1] * deltaX) / 3, next.x, next.y)
|
|
69
|
+
].join(" ");
|
|
70
|
+
}
|
|
71
|
+
return path;
|
|
72
|
+
};
|
|
73
|
+
export const buildLineSegmentPath = (points, curve = "linear") => {
|
|
74
|
+
if (points.length === 0) {
|
|
75
|
+
return "";
|
|
76
|
+
}
|
|
77
|
+
if (curve === "step") {
|
|
78
|
+
return buildStepSegmentPath(points);
|
|
79
|
+
}
|
|
80
|
+
if (curve === "monotone") {
|
|
81
|
+
return buildMonotoneSegmentPath(points);
|
|
82
|
+
}
|
|
83
|
+
return buildLinearSegmentPath(points);
|
|
84
|
+
};
|
|
85
|
+
export const buildLinePath = ({ points, curve = "linear", connectNulls = false, decimation }) => {
|
|
86
|
+
const segments = getDecimatedLinePathSegments({
|
|
87
|
+
points,
|
|
88
|
+
connectNulls,
|
|
89
|
+
decimation
|
|
90
|
+
}).map((segment) => ({
|
|
91
|
+
points: segment,
|
|
92
|
+
path: buildLineSegmentPath(segment, curve)
|
|
93
|
+
}));
|
|
94
|
+
return {
|
|
95
|
+
segments,
|
|
96
|
+
path: segments.map((segment) => segment.path).join(" ")
|
|
97
|
+
};
|
|
98
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { ChartXValue, NormalizedDataPoint, NormalizedSeries } from "../data";
|
|
2
|
+
import type { BuildAreaPathOptions, GeometryPoint, LineCurve, LinePathModel } from "./types";
|
|
3
|
+
export type ProjectedLinePoint<TData = unknown> = GeometryPoint<TData> & {
|
|
4
|
+
dataIndex: number;
|
|
5
|
+
seriesKey: string;
|
|
6
|
+
xValue: ChartXValue;
|
|
7
|
+
};
|
|
8
|
+
export type ProjectScale<TData = unknown> = (value: ChartXValue, point: NormalizedDataPoint<TData>) => number | undefined;
|
|
9
|
+
export type ProjectValueScale<TData = unknown> = (value: number, point: NormalizedDataPoint<TData>) => number | undefined;
|
|
10
|
+
export type BuildLineSeriesGeometryOptions<TData = unknown> = {
|
|
11
|
+
series: NormalizedSeries<TData>;
|
|
12
|
+
xScale: ProjectScale<TData>;
|
|
13
|
+
yScale: ProjectValueScale<TData>;
|
|
14
|
+
curve?: LineCurve;
|
|
15
|
+
connectNulls?: boolean;
|
|
16
|
+
dataIndexOffset?: number;
|
|
17
|
+
pathDecimation?: BuildAreaPathOptions<ProjectedLinePoint<TData>>["decimation"];
|
|
18
|
+
areaBaselineY?: BuildAreaPathOptions<ProjectedLinePoint<TData>>["baselineY"];
|
|
19
|
+
};
|
|
20
|
+
export type LineSeriesGeometry<TData = unknown> = {
|
|
21
|
+
key: string;
|
|
22
|
+
label: string;
|
|
23
|
+
color?: string;
|
|
24
|
+
points: Array<ProjectedLinePoint<TData>>;
|
|
25
|
+
line: LinePathModel<ProjectedLinePoint<TData>>;
|
|
26
|
+
area?: LinePathModel<ProjectedLinePoint<TData>>;
|
|
27
|
+
};
|
|
28
|
+
export declare const buildLineSeriesGeometry: <TData = unknown>({ series, xScale, yScale, curve, connectNulls, dataIndexOffset, pathDecimation, areaBaselineY }: BuildLineSeriesGeometryOptions<TData>) => LineSeriesGeometry<TData>;
|
|
29
|
+
//# sourceMappingURL=lineSeries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lineSeries.d.ts","sourceRoot":"","sources":["../../src/geometry/lineSeries.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,mBAAmB,EACnB,gBAAgB,EACjB,MAAM,SAAS,CAAC;AAGjB,OAAO,KAAK,EACV,oBAAoB,EACpB,aAAa,EACb,SAAS,EACT,aAAa,EACd,MAAM,SAAS,CAAC;AAEjB,MAAM,MAAM,kBAAkB,CAAC,KAAK,GAAG,OAAO,IAAI,aAAa,CAAC,KAAK,CAAC,GAAG;IACvE,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,YAAY,CAAC,KAAK,GAAG,OAAO,IAAI,CAC1C,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAC9B,MAAM,GAAG,SAAS,CAAC;AAExB,MAAM,MAAM,iBAAiB,CAAC,KAAK,GAAG,OAAO,IAAI,CAC/C,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAC9B,MAAM,GAAG,SAAS,CAAC;AAExB,MAAM,MAAM,8BAA8B,CAAC,KAAK,GAAG,OAAO,IAAI;IAC5D,MAAM,EAAE,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAChC,MAAM,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;IAC5B,MAAM,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,oBAAoB,CACnC,kBAAkB,CAAC,KAAK,CAAC,CAC1B,CAAC,YAAY,CAAC,CAAC;IAChB,aAAa,CAAC,EAAE,oBAAoB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;CAC9E,CAAC;AAEF,MAAM,MAAM,kBAAkB,CAAC,KAAK,GAAG,OAAO,IAAI;IAChD,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;IACzC,IAAI,EAAE,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;IAC/C,IAAI,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;CACjD,CAAC;AAkCF,eAAO,MAAM,uBAAuB,GAAI,KAAK,GAAG,OAAO,EAAE,iGAStD,8BAA8B,CAAC,KAAK,CAAC,KAAG,kBAAkB,CAAC,KAAK,CAgClE,CAAC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { buildAreaPath } from "./areaPath";
|
|
2
|
+
import { buildLinePath } from "./linePath";
|
|
3
|
+
const isFinitePosition = (value) => {
|
|
4
|
+
return typeof value === "number" && Number.isFinite(value);
|
|
5
|
+
};
|
|
6
|
+
const projectPoint = (series, point, xScale, yScale, dataIndexOffset) => {
|
|
7
|
+
const projectedX = xScale(point.x, point);
|
|
8
|
+
const projectedY = point.value === null ? undefined : yScale(point.value, point);
|
|
9
|
+
const defined = point.defined &&
|
|
10
|
+
isFinitePosition(projectedX) &&
|
|
11
|
+
isFinitePosition(projectedY);
|
|
12
|
+
return {
|
|
13
|
+
index: point.index + dataIndexOffset,
|
|
14
|
+
dataIndex: point.index + dataIndexOffset,
|
|
15
|
+
seriesKey: series.key,
|
|
16
|
+
xValue: point.x,
|
|
17
|
+
x: projectedX ?? 0,
|
|
18
|
+
y: projectedY ?? 0,
|
|
19
|
+
value: point.value,
|
|
20
|
+
defined,
|
|
21
|
+
raw: point.raw
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
export const buildLineSeriesGeometry = ({ series, xScale, yScale, curve = "linear", connectNulls = false, dataIndexOffset = 0, pathDecimation, areaBaselineY }) => {
|
|
25
|
+
const points = series.points.map((point) => projectPoint(series, point, xScale, yScale, dataIndexOffset));
|
|
26
|
+
const line = buildLinePath({
|
|
27
|
+
points,
|
|
28
|
+
curve,
|
|
29
|
+
connectNulls,
|
|
30
|
+
decimation: pathDecimation
|
|
31
|
+
});
|
|
32
|
+
const geometry = {
|
|
33
|
+
key: series.key,
|
|
34
|
+
label: series.label,
|
|
35
|
+
points,
|
|
36
|
+
line
|
|
37
|
+
};
|
|
38
|
+
if (series.color !== undefined) {
|
|
39
|
+
geometry.color = series.color;
|
|
40
|
+
}
|
|
41
|
+
if (areaBaselineY !== undefined) {
|
|
42
|
+
geometry.area = buildAreaPath({
|
|
43
|
+
points,
|
|
44
|
+
curve,
|
|
45
|
+
connectNulls,
|
|
46
|
+
decimation: pathDecimation,
|
|
47
|
+
baselineY: areaBaselineY
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
return geometry;
|
|
51
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const formatPathNumber: (value: number) => string;
|
|
2
|
+
export declare const pointCommand: (command: "M" | "L", x: number, y: number) => string;
|
|
3
|
+
export declare const cubicCommand: (c1x: number, c1y: number, c2x: number, c2y: number, x: number, y: number) => string;
|
|
4
|
+
export declare const horizontalCommand: (x: number) => string;
|
|
5
|
+
export declare const verticalCommand: (y: number) => string;
|
|
6
|
+
//# sourceMappingURL=path.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"path.d.ts","sourceRoot":"","sources":["../../src/geometry/path.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,gBAAgB,GAAI,OAAO,MAAM,KAAG,MAQhD,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,SAAS,GAAG,GAAG,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,MAAM,WAEpE,CAAC;AAEF,eAAO,MAAM,YAAY,GACvB,KAAK,MAAM,EACX,KAAK,MAAM,EACX,KAAK,MAAM,EACX,KAAK,MAAM,EACX,GAAG,MAAM,EACT,GAAG,MAAM,WAWV,CAAC;AAEF,eAAO,MAAM,iBAAiB,GAAI,GAAG,MAAM,WAA+B,CAAC;AAE3E,eAAO,MAAM,eAAe,GAAI,GAAG,MAAM,WAA+B,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
const DECIMAL_PLACES = 6;
|
|
2
|
+
export const formatPathNumber = (value) => {
|
|
3
|
+
const rounded = Number(value.toFixed(DECIMAL_PLACES));
|
|
4
|
+
if (Object.is(rounded, -0)) {
|
|
5
|
+
return "0";
|
|
6
|
+
}
|
|
7
|
+
return String(rounded);
|
|
8
|
+
};
|
|
9
|
+
export const pointCommand = (command, x, y) => {
|
|
10
|
+
return `${command} ${formatPathNumber(x)} ${formatPathNumber(y)}`;
|
|
11
|
+
};
|
|
12
|
+
export const cubicCommand = (c1x, c1y, c2x, c2y, x, y) => {
|
|
13
|
+
return [
|
|
14
|
+
"C",
|
|
15
|
+
formatPathNumber(c1x),
|
|
16
|
+
formatPathNumber(c1y),
|
|
17
|
+
formatPathNumber(c2x),
|
|
18
|
+
formatPathNumber(c2y),
|
|
19
|
+
formatPathNumber(x),
|
|
20
|
+
formatPathNumber(y)
|
|
21
|
+
].join(" ");
|
|
22
|
+
};
|
|
23
|
+
export const horizontalCommand = (x) => `H ${formatPathNumber(x)}`;
|
|
24
|
+
export const verticalCommand = (y) => `V ${formatPathNumber(y)}`;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { NormalizedPieSlice } from "../data";
|
|
2
|
+
export type PieArcPoint = {
|
|
3
|
+
x: number;
|
|
4
|
+
y: number;
|
|
5
|
+
};
|
|
6
|
+
export type PieArcModel<TData = unknown> = {
|
|
7
|
+
index: number;
|
|
8
|
+
label: string;
|
|
9
|
+
value: number | null;
|
|
10
|
+
percentage: number;
|
|
11
|
+
startAngle: number;
|
|
12
|
+
endAngle: number;
|
|
13
|
+
color?: string;
|
|
14
|
+
centroid: PieArcPoint;
|
|
15
|
+
defined: boolean;
|
|
16
|
+
path: string;
|
|
17
|
+
raw?: TData;
|
|
18
|
+
};
|
|
19
|
+
export type BuildPieArcsOptions<TData = unknown> = {
|
|
20
|
+
slices: Array<NormalizedPieSlice<TData>>;
|
|
21
|
+
centerX: number;
|
|
22
|
+
centerY: number;
|
|
23
|
+
radius: number;
|
|
24
|
+
innerRadius?: number | undefined;
|
|
25
|
+
startAngle?: number | undefined;
|
|
26
|
+
endAngle?: number | undefined;
|
|
27
|
+
};
|
|
28
|
+
export declare const buildPieArcs: <TData = unknown>({ slices, centerX, centerY, radius, innerRadius, startAngle, endAngle }: BuildPieArcsOptions<TData>) => Array<PieArcModel<TData>>;
|
|
29
|
+
//# sourceMappingURL=pieArcs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pieArcs.d.ts","sourceRoot":"","sources":["../../src/geometry/pieArcs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAElD,MAAM,MAAM,WAAW,GAAG;IACxB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAEF,MAAM,MAAM,WAAW,CAAC,KAAK,GAAG,OAAO,IAAI;IACzC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,WAAW,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,KAAK,CAAC;CACb,CAAC;AAEF,MAAM,MAAM,mBAAmB,CAAC,KAAK,GAAG,OAAO,IAAI;IACjD,MAAM,EAAE,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;IACzC,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACjC,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAChC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC/B,CAAC;AAiJF,eAAO,MAAM,YAAY,GAAI,KAAK,GAAG,OAAO,EAAE,yEAQ3C,mBAAmB,CAAC,KAAK,CAAC,KAAG,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,CAoEvD,CAAC"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
const fullCircle = Math.PI * 2;
|
|
2
|
+
const defaultStartAngle = -Math.PI / 2;
|
|
3
|
+
const clamp = (value, min, max) => {
|
|
4
|
+
if (max < min) {
|
|
5
|
+
return min;
|
|
6
|
+
}
|
|
7
|
+
return Math.min(Math.max(value, min), max);
|
|
8
|
+
};
|
|
9
|
+
const isFinitePositive = (value) => Number.isFinite(value) && value > 0;
|
|
10
|
+
const polarToCartesian = ({ angle, centerX, centerY, radius }) => ({
|
|
11
|
+
x: centerX + radius * Math.cos(angle),
|
|
12
|
+
y: centerY + radius * Math.sin(angle)
|
|
13
|
+
});
|
|
14
|
+
const formatNumber = (value) => Number.isInteger(value) ? String(value) : Number(value.toFixed(4)).toString();
|
|
15
|
+
const moveTo = (point) => `M ${formatNumber(point.x)} ${formatNumber(point.y)}`;
|
|
16
|
+
const lineTo = (point) => `L ${formatNumber(point.x)} ${formatNumber(point.y)}`;
|
|
17
|
+
const arcTo = ({ end, largeArc, radius, sweep }) => `A ${formatNumber(radius)} ${formatNumber(radius)} 0 ${largeArc} ${sweep} ${formatNumber(end.x)} ${formatNumber(end.y)}`;
|
|
18
|
+
const getArcPath = ({ centerX, centerY, endAngle, innerRadius, radius, startAngle }) => {
|
|
19
|
+
const span = Math.max(0, endAngle - startAngle);
|
|
20
|
+
const isFullCircle = span >= fullCircle - 0.0001;
|
|
21
|
+
const outerStart = polarToCartesian({
|
|
22
|
+
angle: startAngle,
|
|
23
|
+
centerX,
|
|
24
|
+
centerY,
|
|
25
|
+
radius
|
|
26
|
+
});
|
|
27
|
+
const outerEnd = polarToCartesian({
|
|
28
|
+
angle: isFullCircle ? startAngle + Math.PI : endAngle,
|
|
29
|
+
centerX,
|
|
30
|
+
centerY,
|
|
31
|
+
radius
|
|
32
|
+
});
|
|
33
|
+
const largeArc = span > Math.PI ? 1 : 0;
|
|
34
|
+
if (innerRadius <= 0) {
|
|
35
|
+
const center = { x: centerX, y: centerY };
|
|
36
|
+
if (isFullCircle) {
|
|
37
|
+
return [
|
|
38
|
+
moveTo(center),
|
|
39
|
+
lineTo(outerStart),
|
|
40
|
+
arcTo({ end: outerEnd, largeArc: 1, radius, sweep: 1 }),
|
|
41
|
+
arcTo({ end: outerStart, largeArc: 1, radius, sweep: 1 }),
|
|
42
|
+
"Z"
|
|
43
|
+
].join(" ");
|
|
44
|
+
}
|
|
45
|
+
return [
|
|
46
|
+
moveTo(center),
|
|
47
|
+
lineTo(outerStart),
|
|
48
|
+
arcTo({
|
|
49
|
+
end: outerEnd,
|
|
50
|
+
largeArc,
|
|
51
|
+
radius,
|
|
52
|
+
sweep: 1
|
|
53
|
+
}),
|
|
54
|
+
"Z"
|
|
55
|
+
].join(" ");
|
|
56
|
+
}
|
|
57
|
+
const innerStart = polarToCartesian({
|
|
58
|
+
angle: startAngle,
|
|
59
|
+
centerX,
|
|
60
|
+
centerY,
|
|
61
|
+
radius: innerRadius
|
|
62
|
+
});
|
|
63
|
+
const innerEnd = polarToCartesian({
|
|
64
|
+
angle: isFullCircle ? startAngle + Math.PI : endAngle,
|
|
65
|
+
centerX,
|
|
66
|
+
centerY,
|
|
67
|
+
radius: innerRadius
|
|
68
|
+
});
|
|
69
|
+
if (isFullCircle) {
|
|
70
|
+
return [
|
|
71
|
+
moveTo(outerStart),
|
|
72
|
+
arcTo({ end: outerEnd, largeArc: 1, radius, sweep: 1 }),
|
|
73
|
+
arcTo({ end: outerStart, largeArc: 1, radius, sweep: 1 }),
|
|
74
|
+
lineTo(innerStart),
|
|
75
|
+
arcTo({ end: innerEnd, largeArc: 1, radius: innerRadius, sweep: 0 }),
|
|
76
|
+
arcTo({ end: innerStart, largeArc: 1, radius: innerRadius, sweep: 0 }),
|
|
77
|
+
"Z"
|
|
78
|
+
].join(" ");
|
|
79
|
+
}
|
|
80
|
+
return [
|
|
81
|
+
moveTo(outerStart),
|
|
82
|
+
arcTo({ end: outerEnd, largeArc, radius, sweep: 1 }),
|
|
83
|
+
lineTo(innerEnd),
|
|
84
|
+
arcTo({ end: innerStart, largeArc, radius: innerRadius, sweep: 0 }),
|
|
85
|
+
"Z"
|
|
86
|
+
].join(" ");
|
|
87
|
+
};
|
|
88
|
+
export const buildPieArcs = ({ slices, centerX, centerY, radius, innerRadius = 0, startAngle = defaultStartAngle, endAngle = startAngle + fullCircle }) => {
|
|
89
|
+
const safeRadius = isFinitePositive(radius) ? radius : 0;
|
|
90
|
+
const safeInnerRadius = clamp(Number.isFinite(innerRadius) ? innerRadius : 0, 0, safeRadius);
|
|
91
|
+
const safeStartAngle = Number.isFinite(startAngle)
|
|
92
|
+
? startAngle
|
|
93
|
+
: defaultStartAngle;
|
|
94
|
+
const safeEndAngle = Number.isFinite(endAngle) && endAngle > safeStartAngle
|
|
95
|
+
? endAngle
|
|
96
|
+
: safeStartAngle + fullCircle;
|
|
97
|
+
const total = slices.reduce((sum, slice) => slice.defined && isFinitePositive(slice.value ?? 0)
|
|
98
|
+
? sum + (slice.value ?? 0)
|
|
99
|
+
: sum, 0);
|
|
100
|
+
let cursor = safeStartAngle;
|
|
101
|
+
return slices.map((slice) => {
|
|
102
|
+
const value = slice.defined && isFinitePositive(slice.value ?? 0)
|
|
103
|
+
? (slice.value ?? 0)
|
|
104
|
+
: null;
|
|
105
|
+
const percentage = total > 0 && value !== null ? value / total : 0;
|
|
106
|
+
const span = (safeEndAngle - safeStartAngle) * percentage;
|
|
107
|
+
const arcStartAngle = cursor;
|
|
108
|
+
const arcEndAngle = cursor + span;
|
|
109
|
+
const centroidAngle = arcStartAngle + span / 2;
|
|
110
|
+
const centroidRadius = (safeInnerRadius + safeRadius) / 2;
|
|
111
|
+
const centroid = polarToCartesian({
|
|
112
|
+
angle: centroidAngle,
|
|
113
|
+
centerX,
|
|
114
|
+
centerY,
|
|
115
|
+
radius: centroidRadius
|
|
116
|
+
});
|
|
117
|
+
const path = safeRadius > 0 && span > 0
|
|
118
|
+
? getArcPath({
|
|
119
|
+
centerX,
|
|
120
|
+
centerY,
|
|
121
|
+
endAngle: arcEndAngle,
|
|
122
|
+
innerRadius: safeInnerRadius,
|
|
123
|
+
radius: safeRadius,
|
|
124
|
+
startAngle: arcStartAngle
|
|
125
|
+
})
|
|
126
|
+
: "";
|
|
127
|
+
cursor = arcEndAngle;
|
|
128
|
+
return {
|
|
129
|
+
index: slice.index,
|
|
130
|
+
label: slice.label,
|
|
131
|
+
value,
|
|
132
|
+
percentage,
|
|
133
|
+
startAngle: arcStartAngle,
|
|
134
|
+
endAngle: arcEndAngle,
|
|
135
|
+
...(slice.color !== undefined ? { color: slice.color } : {}),
|
|
136
|
+
centroid,
|
|
137
|
+
defined: path.length > 0,
|
|
138
|
+
path,
|
|
139
|
+
raw: slice.raw
|
|
140
|
+
};
|
|
141
|
+
});
|
|
142
|
+
};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { NormalizedProgressRing } from "../data";
|
|
2
|
+
export type ProgressRingPoint = {
|
|
3
|
+
x: number;
|
|
4
|
+
y: number;
|
|
5
|
+
};
|
|
6
|
+
export type ProgressRingModel = {
|
|
7
|
+
index: number;
|
|
8
|
+
label?: string;
|
|
9
|
+
value: number | null;
|
|
10
|
+
clampedValue: number;
|
|
11
|
+
defined: boolean;
|
|
12
|
+
color?: string;
|
|
13
|
+
radius: number;
|
|
14
|
+
strokeWidth: number;
|
|
15
|
+
startAngle: number;
|
|
16
|
+
endAngle: number;
|
|
17
|
+
backgroundPath: string;
|
|
18
|
+
path: string;
|
|
19
|
+
};
|
|
20
|
+
export type BuildProgressRingsOptions = {
|
|
21
|
+
rings: NormalizedProgressRing[];
|
|
22
|
+
centerX: number;
|
|
23
|
+
centerY: number;
|
|
24
|
+
maxRadius: number;
|
|
25
|
+
strokeWidth: number;
|
|
26
|
+
ringGap?: number | undefined;
|
|
27
|
+
startAngle?: number | undefined;
|
|
28
|
+
};
|
|
29
|
+
export declare const buildProgressRings: ({ rings, centerX, centerY, maxRadius, strokeWidth, ringGap, startAngle }: BuildProgressRingsOptions) => ProgressRingModel[];
|
|
30
|
+
//# sourceMappingURL=progressRings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progressRings.d.ts","sourceRoot":"","sources":["../../src/geometry/progressRings.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;AAEtD,MAAM,MAAM,iBAAiB,GAAG;IAC9B,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,cAAc,EAAE,MAAM,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,KAAK,EAAE,sBAAsB,EAAE,CAAC;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CACjC,CAAC;AA2GF,eAAO,MAAM,kBAAkB,GAAI,0EAQhC,yBAAyB,KAAG,iBAAiB,EA0D/C,CAAC"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
const fullCircle = Math.PI * 2;
|
|
2
|
+
const defaultStartAngle = -Math.PI / 2;
|
|
3
|
+
const clamp = (value, min, max) => {
|
|
4
|
+
if (max < min) {
|
|
5
|
+
return min;
|
|
6
|
+
}
|
|
7
|
+
return Math.min(Math.max(value, min), max);
|
|
8
|
+
};
|
|
9
|
+
const formatNumber = (value) => Number.isInteger(value) ? String(value) : Number(value.toFixed(4)).toString();
|
|
10
|
+
const polarToCartesian = ({ angle, centerX, centerY, radius }) => ({
|
|
11
|
+
x: centerX + radius * Math.cos(angle),
|
|
12
|
+
y: centerY + radius * Math.sin(angle)
|
|
13
|
+
});
|
|
14
|
+
const moveTo = (point) => `M ${formatNumber(point.x)} ${formatNumber(point.y)}`;
|
|
15
|
+
const arcTo = ({ end, largeArc, radius, sweep }) => `A ${formatNumber(radius)} ${formatNumber(radius)} 0 ${largeArc} ${sweep} ${formatNumber(end.x)} ${formatNumber(end.y)}`;
|
|
16
|
+
const buildArcStrokePath = ({ centerX, centerY, endAngle, radius, startAngle }) => {
|
|
17
|
+
const span = Math.max(0, endAngle - startAngle);
|
|
18
|
+
if (radius <= 0 || span <= 0) {
|
|
19
|
+
return "";
|
|
20
|
+
}
|
|
21
|
+
const isFullCircle = span >= fullCircle - 0.0001;
|
|
22
|
+
const start = polarToCartesian({
|
|
23
|
+
angle: startAngle,
|
|
24
|
+
centerX,
|
|
25
|
+
centerY,
|
|
26
|
+
radius
|
|
27
|
+
});
|
|
28
|
+
const mid = polarToCartesian({
|
|
29
|
+
angle: startAngle + Math.PI,
|
|
30
|
+
centerX,
|
|
31
|
+
centerY,
|
|
32
|
+
radius
|
|
33
|
+
});
|
|
34
|
+
const end = polarToCartesian({
|
|
35
|
+
angle: isFullCircle ? startAngle + fullCircle : endAngle,
|
|
36
|
+
centerX,
|
|
37
|
+
centerY,
|
|
38
|
+
radius
|
|
39
|
+
});
|
|
40
|
+
if (isFullCircle) {
|
|
41
|
+
return [
|
|
42
|
+
moveTo(start),
|
|
43
|
+
arcTo({ end: mid, largeArc: 1, radius, sweep: 1 }),
|
|
44
|
+
arcTo({ end: start, largeArc: 1, radius, sweep: 1 })
|
|
45
|
+
].join(" ");
|
|
46
|
+
}
|
|
47
|
+
return [
|
|
48
|
+
moveTo(start),
|
|
49
|
+
arcTo({
|
|
50
|
+
end,
|
|
51
|
+
largeArc: span > Math.PI ? 1 : 0,
|
|
52
|
+
radius,
|
|
53
|
+
sweep: 1
|
|
54
|
+
})
|
|
55
|
+
].join(" ");
|
|
56
|
+
};
|
|
57
|
+
export const buildProgressRings = ({ rings, centerX, centerY, maxRadius, strokeWidth, ringGap = 8, startAngle = defaultStartAngle }) => {
|
|
58
|
+
const safeMaxRadius = Number.isFinite(maxRadius) && maxRadius > 0 ? maxRadius : 0;
|
|
59
|
+
const safeStrokeWidth = Number.isFinite(strokeWidth) && strokeWidth > 0 ? strokeWidth : 0;
|
|
60
|
+
const safeRingGap = Number.isFinite(ringGap) && ringGap > 0 ? ringGap : 0;
|
|
61
|
+
const safeStartAngle = Number.isFinite(startAngle)
|
|
62
|
+
? startAngle
|
|
63
|
+
: defaultStartAngle;
|
|
64
|
+
return rings.map((ring, index) => {
|
|
65
|
+
const radius = Math.max(0, safeMaxRadius - index * (safeStrokeWidth + safeRingGap));
|
|
66
|
+
const value = ring.defined ? ring.value : null;
|
|
67
|
+
const clampedValue = value !== null && Number.isFinite(value) ? clamp(value, 0, 1) : 0;
|
|
68
|
+
const endAngle = safeStartAngle + fullCircle * clampedValue;
|
|
69
|
+
const backgroundPath = buildArcStrokePath({
|
|
70
|
+
centerX,
|
|
71
|
+
centerY,
|
|
72
|
+
endAngle: safeStartAngle + fullCircle,
|
|
73
|
+
radius,
|
|
74
|
+
startAngle: safeStartAngle
|
|
75
|
+
});
|
|
76
|
+
const path = buildArcStrokePath({
|
|
77
|
+
centerX,
|
|
78
|
+
centerY,
|
|
79
|
+
endAngle,
|
|
80
|
+
radius,
|
|
81
|
+
startAngle: safeStartAngle
|
|
82
|
+
});
|
|
83
|
+
const defined = ring.defined && safeStrokeWidth > 0 && radius > 0 && path.length > 0;
|
|
84
|
+
const model = {
|
|
85
|
+
index: ring.index,
|
|
86
|
+
value,
|
|
87
|
+
clampedValue,
|
|
88
|
+
defined,
|
|
89
|
+
radius,
|
|
90
|
+
strokeWidth: safeStrokeWidth,
|
|
91
|
+
startAngle: safeStartAngle,
|
|
92
|
+
endAngle,
|
|
93
|
+
backgroundPath,
|
|
94
|
+
path
|
|
95
|
+
};
|
|
96
|
+
if (ring.label !== undefined) {
|
|
97
|
+
model.label = ring.label;
|
|
98
|
+
}
|
|
99
|
+
if (ring.color !== undefined) {
|
|
100
|
+
model.color = ring.color;
|
|
101
|
+
}
|
|
102
|
+
return model;
|
|
103
|
+
});
|
|
104
|
+
};
|