@visactor/vchart 1.3.0 → 1.3.1-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/es5/index.js +1 -1
- package/build/index.js +21773 -22380
- package/build/index.min.js +1 -1
- package/build/tsconfig.tsbuildinfo +1 -1
- package/cjs/animation/utils.d.ts +1 -1
- package/cjs/animation/utils.js.map +1 -1
- package/cjs/chart/area/area.js +1 -1
- package/cjs/chart/area/area.js.map +1 -1
- package/cjs/chart/bar/bar-3d.js +1 -1
- package/cjs/chart/bar/bar-3d.js.map +1 -1
- package/cjs/chart/bar/bar.js +1 -1
- package/cjs/chart/bar/bar.js.map +1 -1
- package/cjs/chart/base-chart.js +2 -1
- package/cjs/chart/base-chart.js.map +1 -1
- package/cjs/chart/histogram/histogram-3d.js +1 -1
- package/cjs/chart/histogram/histogram-3d.js.map +1 -1
- package/cjs/chart/histogram/histogram.js +1 -1
- package/cjs/chart/histogram/histogram.js.map +1 -1
- package/cjs/chart/interface/chart.d.ts +1 -1
- package/cjs/chart/interface/chart.js.map +1 -1
- package/cjs/chart/map/map.js +1 -1
- package/cjs/chart/map/map.js.map +1 -1
- package/cjs/chart/pie/pie-3d.js +1 -1
- package/cjs/chart/pie/pie-3d.js.map +1 -1
- package/cjs/chart/pie/pie.js +1 -1
- package/cjs/chart/pie/pie.js.map +1 -1
- package/cjs/chart/radar/radar.js +1 -1
- package/cjs/chart/radar/radar.js.map +1 -1
- package/cjs/chart/rose/rose.js +1 -1
- package/cjs/chart/rose/rose.js.map +1 -1
- package/cjs/chart/scatter/scatter.js +1 -1
- package/cjs/chart/scatter/scatter.js.map +1 -1
- package/cjs/chart/sequence/sequence.js +1 -1
- package/cjs/chart/sequence/sequence.js.map +1 -1
- package/cjs/component/axis/base-axis.js +5 -5
- package/cjs/component/axis/base-axis.js.map +1 -1
- package/cjs/component/base/base-component.d.ts +0 -1
- package/cjs/component/base/base-component.js +2 -6
- package/cjs/component/base/base-component.js.map +1 -1
- package/cjs/component/data-zoom/data-zoom/data-zoom.d.ts +1 -0
- package/cjs/component/data-zoom/data-zoom/data-zoom.js +15 -0
- package/cjs/component/data-zoom/data-zoom/data-zoom.js.map +1 -1
- package/cjs/component/legend/base-legend.d.ts +3 -0
- package/cjs/component/legend/base-legend.js +25 -4
- package/cjs/component/legend/base-legend.js.map +1 -1
- package/cjs/component/legend/discrete/legend.js +13 -4
- package/cjs/component/legend/discrete/legend.js.map +1 -1
- package/cjs/component/tooltip/handler/utils/common.js +1 -1
- package/cjs/component/tooltip/handler/utils/common.js.map +1 -1
- package/cjs/component/tooltip/handler/utils/style.js.map +1 -1
- package/cjs/component/tooltip/interface/common.d.ts +1 -1
- package/cjs/component/tooltip/interface/common.js.map +1 -1
- package/cjs/component/tooltip/interface/theme.d.ts +1 -1
- package/cjs/component/tooltip/interface/theme.js.map +1 -1
- package/cjs/component/tooltip/tooltip.js +2 -1
- package/cjs/component/tooltip/tooltip.js.map +1 -1
- package/cjs/core/index.d.ts +1 -1
- package/cjs/core/index.js +2 -2
- package/cjs/core/index.js.map +1 -1
- package/cjs/core/vchart.js +4 -3
- package/cjs/core/vchart.js.map +1 -1
- package/cjs/data/initialize.d.ts +1 -1
- package/cjs/data/initialize.js +1 -1
- package/cjs/data/initialize.js.map +1 -1
- package/cjs/data/transforms/pie.js +17 -5
- package/cjs/data/transforms/pie.js.map +1 -1
- package/cjs/event/events/dimension/base.d.ts +1 -1
- package/cjs/event/events/dimension/base.js +1 -1
- package/cjs/event/events/dimension/base.js.map +1 -1
- package/cjs/layout/base-layout.d.ts +1 -1
- package/cjs/layout/base-layout.js.map +1 -1
- package/cjs/layout/grid-layout/grid-layout.d.ts +1 -1
- package/cjs/layout/grid-layout/grid-layout.js.map +1 -1
- package/cjs/layout/interface.d.ts +1 -1
- package/cjs/layout/interface.js.map +1 -1
- package/cjs/layout/layout3d/index.d.ts +1 -1
- package/cjs/layout/layout3d/index.js.map +1 -1
- package/cjs/mark/image.d.ts +1 -1
- package/cjs/mark/image.js.map +1 -1
- package/cjs/model/base-model.d.ts +3 -1
- package/cjs/model/base-model.js +14 -4
- package/cjs/model/base-model.js.map +1 -1
- package/cjs/plugin/components/axis-sync-plugin/axis-sync.js +1 -1
- package/cjs/plugin/components/axis-sync-plugin/axis-sync.js.map +1 -1
- package/cjs/series/area/area.js +7 -8
- package/cjs/series/area/area.js.map +1 -1
- package/cjs/series/area/constant.d.ts +1 -1
- package/cjs/series/area/constant.js +4 -4
- package/cjs/series/area/constant.js.map +1 -1
- package/cjs/series/area/interface.d.ts +1 -1
- package/cjs/series/area/interface.js.map +1 -1
- package/cjs/series/bar/bar-3d.d.ts +1 -1
- package/cjs/series/bar/bar-3d.js +3 -3
- package/cjs/series/bar/bar-3d.js.map +1 -1
- package/cjs/series/bar/bar.d.ts +1 -1
- package/cjs/series/bar/bar.js +3 -3
- package/cjs/series/bar/bar.js.map +1 -1
- package/cjs/series/bar/constant.d.ts +1 -1
- package/cjs/series/bar/constant.js +5 -5
- package/cjs/series/bar/constant.js.map +1 -1
- package/cjs/series/bar/interface.d.ts +1 -1
- package/cjs/series/bar/interface.js.map +1 -1
- package/cjs/series/base/base-series.js +1 -1
- package/cjs/series/base/base-series.js.map +1 -1
- package/cjs/series/base/constant.d.ts +1 -1
- package/cjs/series/base/constant.js +3 -3
- package/cjs/series/base/constant.js.map +1 -1
- package/cjs/series/box-plot/box-plot.d.ts +1 -1
- package/cjs/series/box-plot/box-plot.js +4 -4
- package/cjs/series/box-plot/box-plot.js.map +1 -1
- package/cjs/series/box-plot/constant.d.ts +1 -1
- package/cjs/series/box-plot/constant.js +5 -5
- package/cjs/series/box-plot/constant.js.map +1 -1
- package/cjs/series/box-plot/interface.d.ts +1 -1
- package/cjs/series/box-plot/interface.js.map +1 -1
- package/cjs/series/cartesian/cartesian.d.ts +2 -1
- package/cjs/series/cartesian/cartesian.js +2 -2
- package/cjs/series/cartesian/cartesian.js.map +1 -1
- package/cjs/series/circle-packing/constant.d.ts +1 -1
- package/cjs/series/circle-packing/constant.js +3 -3
- package/cjs/series/circle-packing/constant.js.map +1 -1
- package/cjs/series/circle-packing/interface.d.ts +1 -1
- package/cjs/series/circle-packing/interface.js.map +1 -1
- package/cjs/series/dot/constant.d.ts +1 -1
- package/cjs/series/dot/constant.js +15 -15
- package/cjs/series/dot/constant.js.map +1 -1
- package/cjs/series/dot/interface.d.ts +1 -1
- package/cjs/series/dot/interface.js.map +1 -1
- package/cjs/series/funnel/constant.d.ts +1 -1
- package/cjs/series/funnel/constant.js +21 -21
- package/cjs/series/funnel/constant.js.map +1 -1
- package/cjs/series/funnel/funnel-3d.d.ts +1 -1
- package/cjs/series/funnel/funnel-3d.js +4 -4
- package/cjs/series/funnel/funnel-3d.js.map +1 -1
- package/cjs/series/funnel/funnel.d.ts +1 -1
- package/cjs/series/funnel/funnel.js +7 -7
- package/cjs/series/funnel/funnel.js.map +1 -1
- package/cjs/series/funnel/interface.d.ts +1 -1
- package/cjs/series/funnel/interface.js.map +1 -1
- package/cjs/series/funnel/tooltip-helper.js +4 -4
- package/cjs/series/funnel/tooltip-helper.js.map +1 -1
- package/cjs/series/gauge/constant.d.ts +1 -1
- package/cjs/series/gauge/constant.js +11 -11
- package/cjs/series/gauge/constant.js.map +1 -1
- package/cjs/series/gauge/gauge-pointer.d.ts +1 -1
- package/cjs/series/gauge/gauge-pointer.js +4 -4
- package/cjs/series/gauge/gauge-pointer.js.map +1 -1
- package/cjs/series/gauge/gauge.d.ts +1 -1
- package/cjs/series/gauge/gauge.js +4 -4
- package/cjs/series/gauge/gauge.js.map +1 -1
- package/cjs/series/gauge/interface.d.ts +1 -1
- package/cjs/series/gauge/interface.js.map +1 -1
- package/cjs/series/heatmap/constant.d.ts +1 -1
- package/cjs/series/heatmap/constant.js +5 -5
- package/cjs/series/heatmap/constant.js.map +1 -1
- package/cjs/series/heatmap/heatmap.d.ts +1 -1
- package/cjs/series/heatmap/heatmap.js +4 -4
- package/cjs/series/heatmap/heatmap.js.map +1 -1
- package/cjs/series/heatmap/interface.d.ts +1 -1
- package/cjs/series/heatmap/interface.js.map +1 -1
- package/cjs/series/interface/common.d.ts +1 -50
- package/cjs/series/interface/common.js +1 -24
- package/cjs/series/interface/common.js.map +1 -1
- package/cjs/series/interface/type.d.ts +51 -0
- package/cjs/series/interface/type.js +26 -3
- package/cjs/series/interface/type.js.map +1 -1
- package/cjs/series/line/constant.js +2 -2
- package/cjs/series/line/constant.js.map +1 -1
- package/cjs/series/line/interface.d.ts +1 -1
- package/cjs/series/line/interface.js.map +1 -1
- package/cjs/series/line/line.js +5 -6
- package/cjs/series/line/line.js.map +1 -1
- package/cjs/series/link/constant.d.ts +1 -1
- package/cjs/series/link/constant.js +7 -7
- package/cjs/series/link/constant.js.map +1 -1
- package/cjs/series/link/interface.d.ts +1 -1
- package/cjs/series/link/interface.js.map +1 -1
- package/cjs/series/map/constant.d.ts +1 -1
- package/cjs/series/map/constant.js +3 -3
- package/cjs/series/map/constant.js.map +1 -1
- package/cjs/series/map/map.d.ts +1 -1
- package/cjs/series/map/map.js +5 -7
- package/cjs/series/map/map.js.map +1 -1
- package/cjs/series/mixin/constant.d.ts +2 -0
- package/cjs/series/mixin/constant.js +19 -0
- package/cjs/series/mixin/constant.js.map +1 -0
- package/cjs/series/mixin/line-mixin.d.ts +2 -3
- package/cjs/series/mixin/line-mixin.js +6 -15
- package/cjs/series/mixin/line-mixin.js.map +1 -1
- package/cjs/series/pie/constant.d.ts +1 -1
- package/cjs/series/pie/constant.js +9 -9
- package/cjs/series/pie/constant.js.map +1 -1
- package/cjs/series/pie/interface.d.ts +1 -1
- package/cjs/series/pie/interface.js.map +1 -1
- package/cjs/series/pie/pie-3d.d.ts +1 -2
- package/cjs/series/pie/pie-3d.js +2 -2
- package/cjs/series/pie/pie-3d.js.map +1 -1
- package/cjs/series/pie/pie.d.ts +1 -2
- package/cjs/series/pie/pie.js +7 -13
- package/cjs/series/pie/pie.js.map +1 -1
- package/cjs/series/progress/circular/circular.d.ts +1 -1
- package/cjs/series/progress/circular/circular.js +5 -5
- package/cjs/series/progress/circular/circular.js.map +1 -1
- package/cjs/series/progress/circular/constant.d.ts +1 -1
- package/cjs/series/progress/circular/constant.js +5 -5
- package/cjs/series/progress/circular/constant.js.map +1 -1
- package/cjs/series/progress/circular/interface.d.ts +1 -1
- package/cjs/series/progress/circular/interface.js.map +1 -1
- package/cjs/series/progress/linear/constant.d.ts +1 -1
- package/cjs/series/progress/linear/constant.js +7 -7
- package/cjs/series/progress/linear/constant.js.map +1 -1
- package/cjs/series/progress/linear/interface.d.ts +1 -1
- package/cjs/series/progress/linear/interface.js.map +1 -1
- package/cjs/series/progress/linear/linear.d.ts +1 -1
- package/cjs/series/progress/linear/linear.js +5 -5
- package/cjs/series/progress/linear/linear.js.map +1 -1
- package/cjs/series/radar/constant.d.ts +1 -1
- package/cjs/series/radar/constant.js +4 -4
- package/cjs/series/radar/constant.js.map +1 -1
- package/cjs/series/radar/interface.d.ts +1 -1
- package/cjs/series/radar/interface.js.map +1 -1
- package/cjs/series/radar/radar.d.ts +1 -1
- package/cjs/series/radar/radar.js +4 -4
- package/cjs/series/radar/radar.js.map +1 -1
- package/cjs/series/range-column/constant.d.ts +1 -1
- package/cjs/series/range-column/constant.js +9 -9
- package/cjs/series/range-column/constant.js.map +1 -1
- package/cjs/series/range-column/interface.d.ts +1 -1
- package/cjs/series/range-column/interface.js.map +1 -1
- package/cjs/series/range-column/range-column.d.ts +1 -1
- package/cjs/series/range-column/range-column.js +9 -9
- package/cjs/series/range-column/range-column.js.map +1 -1
- package/cjs/series/rose/constant.d.ts +1 -1
- package/cjs/series/rose/constant.js +3 -3
- package/cjs/series/rose/constant.js.map +1 -1
- package/cjs/series/rose/interface.d.ts +1 -1
- package/cjs/series/rose/interface.js.map +1 -1
- package/cjs/series/rose/rose.d.ts +1 -1
- package/cjs/series/rose/rose.js +5 -6
- package/cjs/series/rose/rose.js.map +1 -1
- package/cjs/series/sankey/constant.d.ts +1 -1
- package/cjs/series/sankey/constant.js +5 -5
- package/cjs/series/sankey/constant.js.map +1 -1
- package/cjs/series/sankey/interface.d.ts +1 -1
- package/cjs/series/sankey/interface.js.map +1 -1
- package/cjs/series/sankey/sankey.d.ts +1 -1
- package/cjs/series/sankey/sankey.js +6 -7
- package/cjs/series/sankey/sankey.js.map +1 -1
- package/cjs/series/scatter/constant.d.ts +1 -1
- package/cjs/series/scatter/constant.js +3 -3
- package/cjs/series/scatter/constant.js.map +1 -1
- package/cjs/series/scatter/interface.d.ts +1 -1
- package/cjs/series/scatter/interface.js.map +1 -1
- package/cjs/series/scatter/scatter.d.ts +1 -1
- package/cjs/series/scatter/scatter.js +4 -4
- package/cjs/series/scatter/scatter.js.map +1 -1
- package/cjs/series/sunburst/constant.d.ts +1 -1
- package/cjs/series/sunburst/constant.js +3 -3
- package/cjs/series/sunburst/constant.js.map +1 -1
- package/cjs/series/sunburst/interface.d.ts +1 -1
- package/cjs/series/sunburst/interface.js.map +1 -1
- package/cjs/series/treemap/constant.d.ts +1 -1
- package/cjs/series/treemap/constant.js +7 -7
- package/cjs/series/treemap/constant.js.map +1 -1
- package/cjs/series/treemap/interface.d.ts +1 -1
- package/cjs/series/treemap/interface.js.map +1 -1
- package/cjs/series/util/utils.d.ts +1 -1
- package/cjs/series/util/utils.js.map +1 -1
- package/cjs/series/waterfall/constant.d.ts +1 -1
- package/cjs/series/waterfall/constant.js +5 -5
- package/cjs/series/waterfall/constant.js.map +1 -1
- package/cjs/series/waterfall/interface.d.ts +1 -1
- package/cjs/series/waterfall/interface.js.map +1 -1
- package/cjs/series/waterfall/waterfall.d.ts +1 -1
- package/cjs/series/waterfall/waterfall.js +5 -5
- package/cjs/series/waterfall/waterfall.js.map +1 -1
- package/cjs/series/word-cloud/base.js +2 -2
- package/cjs/series/word-cloud/base.js.map +1 -1
- package/cjs/series/word-cloud/constant.d.ts +1 -1
- package/cjs/series/word-cloud/constant.js +5 -5
- package/cjs/series/word-cloud/constant.js.map +1 -1
- package/cjs/series/word-cloud/interface.d.ts +1 -1
- package/cjs/series/word-cloud/interface.js.map +1 -1
- package/cjs/series/word-cloud/word-cloud-3d.d.ts +1 -1
- package/cjs/series/word-cloud/word-cloud-3d.js +5 -5
- package/cjs/series/word-cloud/word-cloud-3d.js.map +1 -1
- package/cjs/theme/builtin/common/component/data-zoom.js +36 -36
- package/cjs/theme/builtin/common/component/data-zoom.js.map +1 -1
- package/cjs/theme/builtin/common/component/legend/size-legend.js +4 -4
- package/cjs/theme/builtin/common/component/legend/size-legend.js.map +1 -1
- package/cjs/theme/builtin/common/component/poptip.js.map +1 -1
- package/cjs/theme/builtin/common/component/title.js.map +1 -1
- package/cjs/theme/builtin/common/constants.js +6 -6
- package/cjs/theme/builtin/common/constants.js.map +1 -1
- package/cjs/theme/builtin/common/legacy/index.d.ts +1 -0
- package/cjs/theme/builtin/common/legacy/index.js +21 -0
- package/cjs/theme/builtin/common/legacy/index.js.map +1 -0
- package/cjs/theme/builtin/common/legacy/legend/color-legend.d.ts +2 -0
- package/cjs/theme/builtin/common/legacy/legend/color-legend.js +43 -0
- package/cjs/theme/builtin/common/legacy/legend/color-legend.js.map +1 -0
- package/cjs/theme/builtin/common/legacy/legend/continuous.d.ts +2 -0
- package/cjs/theme/builtin/common/legacy/legend/continuous.js +60 -0
- package/cjs/theme/builtin/common/legacy/legend/continuous.js.map +1 -0
- package/cjs/theme/builtin/common/legacy/legend/index.d.ts +2 -0
- package/cjs/theme/builtin/common/legacy/legend/index.js +24 -0
- package/cjs/theme/builtin/common/legacy/legend/index.js.map +1 -0
- package/cjs/theme/builtin/common/legacy/legend/size-legend.d.ts +2 -0
- package/cjs/theme/builtin/common/legacy/legend/size-legend.js +56 -0
- package/cjs/theme/builtin/common/legacy/legend/size-legend.js.map +1 -0
- package/cjs/theme/builtin/common/series/treemap.js +1 -1
- package/cjs/theme/builtin/common/series/treemap.js.map +1 -1
- package/cjs/theme/builtin/dark/index.js +13 -1
- package/cjs/theme/builtin/dark/index.js.map +1 -1
- package/cjs/theme/builtin/index.d.ts +3 -0
- package/cjs/theme/builtin/index.js +10 -3
- package/cjs/theme/builtin/index.js.map +1 -1
- package/cjs/theme/interface.d.ts +6 -6
- package/cjs/theme/interface.js.map +1 -1
- package/cjs/theme/theme-manager.d.ts +1 -1
- package/cjs/theme/theme-manager.js +3 -7
- package/cjs/theme/theme-manager.js.map +1 -1
- package/cjs/typings/spec/common.d.ts +1 -1
- package/cjs/typings/spec/common.js.map +1 -1
- package/cjs/typings/visual.d.ts +1 -1
- package/cjs/typings/visual.js.map +1 -1
- package/cjs/util/image.d.ts +1 -1
- package/cjs/util/image.js.map +1 -1
- package/cjs/util/spec/preprocess.d.ts +2 -2
- package/cjs/util/spec/preprocess.js +10 -5
- package/cjs/util/spec/preprocess.js.map +1 -1
- package/cjs/util/text.d.ts +2 -2
- package/cjs/util/text.js.map +1 -1
- package/esm/animation/utils.d.ts +1 -1
- package/esm/animation/utils.js.map +1 -1
- package/esm/chart/area/area.js +1 -1
- package/esm/chart/area/area.js.map +1 -1
- package/esm/chart/bar/bar-3d.js +1 -1
- package/esm/chart/bar/bar-3d.js.map +1 -1
- package/esm/chart/bar/bar.js +1 -1
- package/esm/chart/bar/bar.js.map +1 -1
- package/esm/chart/base-chart.js +2 -1
- package/esm/chart/base-chart.js.map +1 -1
- package/esm/chart/histogram/histogram-3d.js +1 -1
- package/esm/chart/histogram/histogram-3d.js.map +1 -1
- package/esm/chart/histogram/histogram.js +1 -1
- package/esm/chart/histogram/histogram.js.map +1 -1
- package/esm/chart/interface/chart.d.ts +1 -1
- package/esm/chart/interface/chart.js.map +1 -1
- package/esm/chart/map/map.js +1 -1
- package/esm/chart/map/map.js.map +1 -1
- package/esm/chart/pie/pie-3d.js +1 -1
- package/esm/chart/pie/pie-3d.js.map +1 -1
- package/esm/chart/pie/pie.js +1 -1
- package/esm/chart/pie/pie.js.map +1 -1
- package/esm/chart/radar/radar.js +1 -1
- package/esm/chart/radar/radar.js.map +1 -1
- package/esm/chart/rose/rose.js +1 -1
- package/esm/chart/rose/rose.js.map +1 -1
- package/esm/chart/scatter/scatter.js +1 -1
- package/esm/chart/scatter/scatter.js.map +1 -1
- package/esm/chart/sequence/sequence.js +2 -2
- package/esm/chart/sequence/sequence.js.map +1 -1
- package/esm/component/axis/base-axis.js +5 -5
- package/esm/component/axis/base-axis.js.map +1 -1
- package/esm/component/base/base-component.d.ts +0 -1
- package/esm/component/base/base-component.js +1 -7
- package/esm/component/base/base-component.js.map +1 -1
- package/esm/component/data-zoom/data-zoom/data-zoom.d.ts +1 -0
- package/esm/component/data-zoom/data-zoom/data-zoom.js +15 -0
- package/esm/component/data-zoom/data-zoom/data-zoom.js.map +1 -1
- package/esm/component/legend/base-legend.d.ts +3 -0
- package/esm/component/legend/base-legend.js +24 -4
- package/esm/component/legend/base-legend.js.map +1 -1
- package/esm/component/legend/discrete/legend.js +13 -4
- package/esm/component/legend/discrete/legend.js.map +1 -1
- package/esm/component/tooltip/handler/utils/common.js +1 -1
- package/esm/component/tooltip/handler/utils/common.js.map +1 -1
- package/esm/component/tooltip/handler/utils/style.js.map +1 -1
- package/esm/component/tooltip/interface/common.d.ts +1 -1
- package/esm/component/tooltip/interface/common.js.map +1 -1
- package/esm/component/tooltip/interface/theme.d.ts +1 -1
- package/esm/component/tooltip/interface/theme.js.map +1 -1
- package/esm/component/tooltip/tooltip.js +1 -1
- package/esm/component/tooltip/tooltip.js.map +1 -1
- package/esm/core/index.d.ts +1 -1
- package/esm/core/index.js +2 -2
- package/esm/core/index.js.map +1 -1
- package/esm/core/vchart.js +3 -3
- package/esm/core/vchart.js.map +1 -1
- package/esm/data/initialize.d.ts +1 -1
- package/esm/data/initialize.js +1 -1
- package/esm/data/initialize.js.map +1 -1
- package/esm/data/transforms/pie.js +15 -5
- package/esm/data/transforms/pie.js.map +1 -1
- package/esm/event/events/dimension/base.d.ts +1 -1
- package/esm/event/events/dimension/base.js +1 -1
- package/esm/event/events/dimension/base.js.map +1 -1
- package/esm/layout/base-layout.d.ts +1 -1
- package/esm/layout/base-layout.js.map +1 -1
- package/esm/layout/grid-layout/grid-layout.d.ts +1 -1
- package/esm/layout/grid-layout/grid-layout.js.map +1 -1
- package/esm/layout/interface.d.ts +1 -1
- package/esm/layout/interface.js.map +1 -1
- package/esm/layout/layout3d/index.d.ts +1 -1
- package/esm/layout/layout3d/index.js.map +1 -1
- package/esm/mark/image.d.ts +1 -1
- package/esm/mark/image.js.map +1 -1
- package/esm/model/base-model.d.ts +3 -1
- package/esm/model/base-model.js +14 -5
- package/esm/model/base-model.js.map +1 -1
- package/esm/plugin/components/axis-sync-plugin/axis-sync.js +1 -1
- package/esm/plugin/components/axis-sync-plugin/axis-sync.js.map +1 -1
- package/esm/series/area/area.js +1 -1
- package/esm/series/area/area.js.map +1 -1
- package/esm/series/area/constant.d.ts +1 -1
- package/esm/series/area/constant.js +2 -2
- package/esm/series/area/constant.js.map +1 -1
- package/esm/series/area/interface.d.ts +1 -1
- package/esm/series/area/interface.js.map +1 -1
- package/esm/series/bar/bar-3d.d.ts +1 -1
- package/esm/series/bar/bar-3d.js +1 -1
- package/esm/series/bar/bar-3d.js.map +1 -1
- package/esm/series/bar/bar.d.ts +1 -1
- package/esm/series/bar/bar.js +1 -1
- package/esm/series/bar/bar.js.map +1 -1
- package/esm/series/bar/constant.d.ts +1 -1
- package/esm/series/bar/constant.js +1 -1
- package/esm/series/bar/constant.js.map +1 -1
- package/esm/series/bar/interface.d.ts +1 -1
- package/esm/series/bar/interface.js.map +1 -1
- package/esm/series/base/base-series.js +1 -1
- package/esm/series/base/base-series.js.map +1 -1
- package/esm/series/base/constant.d.ts +1 -1
- package/esm/series/base/constant.js +1 -1
- package/esm/series/base/constant.js.map +1 -1
- package/esm/series/box-plot/box-plot.d.ts +1 -1
- package/esm/series/box-plot/box-plot.js +1 -1
- package/esm/series/box-plot/box-plot.js.map +1 -1
- package/esm/series/box-plot/constant.d.ts +1 -1
- package/esm/series/box-plot/constant.js +1 -1
- package/esm/series/box-plot/constant.js.map +1 -1
- package/esm/series/box-plot/interface.d.ts +1 -1
- package/esm/series/box-plot/interface.js.map +1 -1
- package/esm/series/cartesian/cartesian.d.ts +2 -1
- package/esm/series/cartesian/cartesian.js +2 -2
- package/esm/series/cartesian/cartesian.js.map +1 -1
- package/esm/series/circle-packing/constant.d.ts +1 -1
- package/esm/series/circle-packing/constant.js +1 -1
- package/esm/series/circle-packing/constant.js.map +1 -1
- package/esm/series/circle-packing/interface.d.ts +1 -1
- package/esm/series/circle-packing/interface.js.map +1 -1
- package/esm/series/dot/constant.d.ts +1 -1
- package/esm/series/dot/constant.js +1 -1
- package/esm/series/dot/constant.js.map +1 -1
- package/esm/series/dot/interface.d.ts +1 -1
- package/esm/series/dot/interface.js.map +1 -1
- package/esm/series/funnel/constant.d.ts +1 -1
- package/esm/series/funnel/constant.js +1 -1
- package/esm/series/funnel/constant.js.map +1 -1
- package/esm/series/funnel/funnel-3d.d.ts +1 -1
- package/esm/series/funnel/funnel-3d.js +1 -1
- package/esm/series/funnel/funnel-3d.js.map +1 -1
- package/esm/series/funnel/funnel.d.ts +1 -1
- package/esm/series/funnel/funnel.js +1 -1
- package/esm/series/funnel/funnel.js.map +1 -1
- package/esm/series/funnel/interface.d.ts +1 -1
- package/esm/series/funnel/interface.js.map +1 -1
- package/esm/series/funnel/tooltip-helper.js +1 -1
- package/esm/series/funnel/tooltip-helper.js.map +1 -1
- package/esm/series/gauge/constant.d.ts +1 -1
- package/esm/series/gauge/constant.js +1 -1
- package/esm/series/gauge/constant.js.map +1 -1
- package/esm/series/gauge/gauge-pointer.d.ts +1 -1
- package/esm/series/gauge/gauge-pointer.js +1 -1
- package/esm/series/gauge/gauge-pointer.js.map +1 -1
- package/esm/series/gauge/gauge.d.ts +1 -1
- package/esm/series/gauge/gauge.js +1 -1
- package/esm/series/gauge/gauge.js.map +1 -1
- package/esm/series/gauge/interface.d.ts +1 -1
- package/esm/series/gauge/interface.js.map +1 -1
- package/esm/series/heatmap/constant.d.ts +1 -1
- package/esm/series/heatmap/constant.js +1 -1
- package/esm/series/heatmap/constant.js.map +1 -1
- package/esm/series/heatmap/heatmap.d.ts +1 -1
- package/esm/series/heatmap/heatmap.js +1 -1
- package/esm/series/heatmap/heatmap.js.map +1 -1
- package/esm/series/heatmap/interface.d.ts +1 -1
- package/esm/series/heatmap/interface.js.map +1 -1
- package/esm/series/interface/common.d.ts +1 -50
- package/esm/series/interface/common.js +1 -24
- package/esm/series/interface/common.js.map +1 -1
- package/esm/series/interface/type.d.ts +51 -0
- package/esm/series/interface/type.js +27 -0
- package/esm/series/interface/type.js.map +1 -1
- package/esm/series/line/constant.js +1 -1
- package/esm/series/line/constant.js.map +1 -1
- package/esm/series/line/interface.d.ts +1 -1
- package/esm/series/line/interface.js.map +1 -1
- package/esm/series/line/line.js +1 -1
- package/esm/series/line/line.js.map +1 -1
- package/esm/series/link/constant.d.ts +1 -1
- package/esm/series/link/constant.js +1 -1
- package/esm/series/link/constant.js.map +1 -1
- package/esm/series/link/interface.d.ts +1 -1
- package/esm/series/link/interface.js.map +1 -1
- package/esm/series/map/constant.d.ts +1 -1
- package/esm/series/map/constant.js +1 -1
- package/esm/series/map/constant.js.map +1 -1
- package/esm/series/map/map.d.ts +1 -1
- package/esm/series/map/map.js +1 -1
- package/esm/series/map/map.js.map +1 -1
- package/esm/series/mixin/constant.d.ts +2 -0
- package/esm/series/mixin/constant.js +15 -0
- package/esm/series/mixin/constant.js.map +1 -0
- package/esm/series/mixin/line-mixin.d.ts +2 -3
- package/esm/series/mixin/line-mixin.js +4 -15
- package/esm/series/mixin/line-mixin.js.map +1 -1
- package/esm/series/pie/constant.d.ts +1 -1
- package/esm/series/pie/constant.js +1 -1
- package/esm/series/pie/constant.js.map +1 -1
- package/esm/series/pie/interface.d.ts +1 -1
- package/esm/series/pie/interface.js.map +1 -1
- package/esm/series/pie/pie-3d.d.ts +1 -2
- package/esm/series/pie/pie-3d.js +1 -3
- package/esm/series/pie/pie-3d.js.map +1 -1
- package/esm/series/pie/pie.d.ts +1 -2
- package/esm/series/pie/pie.js +3 -13
- package/esm/series/pie/pie.js.map +1 -1
- package/esm/series/progress/circular/circular.d.ts +1 -1
- package/esm/series/progress/circular/circular.js +1 -1
- package/esm/series/progress/circular/circular.js.map +1 -1
- package/esm/series/progress/circular/constant.d.ts +1 -1
- package/esm/series/progress/circular/constant.js +1 -1
- package/esm/series/progress/circular/constant.js.map +1 -1
- package/esm/series/progress/circular/interface.d.ts +1 -1
- package/esm/series/progress/circular/interface.js.map +1 -1
- package/esm/series/progress/linear/constant.d.ts +1 -1
- package/esm/series/progress/linear/constant.js +1 -1
- package/esm/series/progress/linear/constant.js.map +1 -1
- package/esm/series/progress/linear/interface.d.ts +1 -1
- package/esm/series/progress/linear/interface.js.map +1 -1
- package/esm/series/progress/linear/linear.d.ts +1 -1
- package/esm/series/progress/linear/linear.js +1 -1
- package/esm/series/progress/linear/linear.js.map +1 -1
- package/esm/series/radar/constant.d.ts +1 -1
- package/esm/series/radar/constant.js +2 -2
- package/esm/series/radar/constant.js.map +1 -1
- package/esm/series/radar/interface.d.ts +1 -1
- package/esm/series/radar/interface.js.map +1 -1
- package/esm/series/radar/radar.d.ts +1 -1
- package/esm/series/radar/radar.js +1 -1
- package/esm/series/radar/radar.js.map +1 -1
- package/esm/series/range-column/constant.d.ts +1 -1
- package/esm/series/range-column/constant.js +1 -1
- package/esm/series/range-column/constant.js.map +1 -1
- package/esm/series/range-column/interface.d.ts +1 -1
- package/esm/series/range-column/interface.js.map +1 -1
- package/esm/series/range-column/range-column.d.ts +1 -1
- package/esm/series/range-column/range-column.js +1 -1
- package/esm/series/range-column/range-column.js.map +1 -1
- package/esm/series/rose/constant.d.ts +1 -1
- package/esm/series/rose/constant.js +1 -1
- package/esm/series/rose/constant.js.map +1 -1
- package/esm/series/rose/interface.d.ts +1 -1
- package/esm/series/rose/interface.js.map +1 -1
- package/esm/series/rose/rose.d.ts +1 -1
- package/esm/series/rose/rose.js +1 -1
- package/esm/series/rose/rose.js.map +1 -1
- package/esm/series/sankey/constant.d.ts +1 -1
- package/esm/series/sankey/constant.js +1 -1
- package/esm/series/sankey/constant.js.map +1 -1
- package/esm/series/sankey/interface.d.ts +1 -1
- package/esm/series/sankey/interface.js.map +1 -1
- package/esm/series/sankey/sankey.d.ts +1 -1
- package/esm/series/sankey/sankey.js +1 -1
- package/esm/series/sankey/sankey.js.map +1 -1
- package/esm/series/scatter/constant.d.ts +1 -1
- package/esm/series/scatter/constant.js +1 -1
- package/esm/series/scatter/constant.js.map +1 -1
- package/esm/series/scatter/interface.d.ts +1 -1
- package/esm/series/scatter/interface.js.map +1 -1
- package/esm/series/scatter/scatter.d.ts +1 -1
- package/esm/series/scatter/scatter.js +1 -1
- package/esm/series/scatter/scatter.js.map +1 -1
- package/esm/series/sunburst/constant.d.ts +1 -1
- package/esm/series/sunburst/constant.js +1 -1
- package/esm/series/sunburst/constant.js.map +1 -1
- package/esm/series/sunburst/interface.d.ts +1 -1
- package/esm/series/sunburst/interface.js.map +1 -1
- package/esm/series/treemap/constant.d.ts +1 -1
- package/esm/series/treemap/constant.js +1 -1
- package/esm/series/treemap/constant.js.map +1 -1
- package/esm/series/treemap/interface.d.ts +1 -1
- package/esm/series/treemap/interface.js.map +1 -1
- package/esm/series/util/utils.d.ts +1 -1
- package/esm/series/util/utils.js.map +1 -1
- package/esm/series/waterfall/constant.d.ts +1 -1
- package/esm/series/waterfall/constant.js +1 -1
- package/esm/series/waterfall/constant.js.map +1 -1
- package/esm/series/waterfall/interface.d.ts +1 -1
- package/esm/series/waterfall/interface.js.map +1 -1
- package/esm/series/waterfall/waterfall.d.ts +1 -1
- package/esm/series/waterfall/waterfall.js +1 -1
- package/esm/series/waterfall/waterfall.js.map +1 -1
- package/esm/series/word-cloud/base.js +1 -1
- package/esm/series/word-cloud/base.js.map +1 -1
- package/esm/series/word-cloud/constant.d.ts +1 -1
- package/esm/series/word-cloud/constant.js +1 -1
- package/esm/series/word-cloud/constant.js.map +1 -1
- package/esm/series/word-cloud/interface.d.ts +1 -1
- package/esm/series/word-cloud/interface.js.map +1 -1
- package/esm/series/word-cloud/word-cloud-3d.d.ts +1 -1
- package/esm/series/word-cloud/word-cloud-3d.js +1 -1
- package/esm/series/word-cloud/word-cloud-3d.js.map +1 -1
- package/esm/theme/builtin/common/component/data-zoom.js +36 -36
- package/esm/theme/builtin/common/component/data-zoom.js.map +1 -1
- package/esm/theme/builtin/common/component/legend/size-legend.js +4 -4
- package/esm/theme/builtin/common/component/legend/size-legend.js.map +1 -1
- package/esm/theme/builtin/common/component/poptip.js.map +1 -1
- package/esm/theme/builtin/common/component/title.js.map +1 -1
- package/esm/theme/builtin/common/constants.js +6 -6
- package/esm/theme/builtin/common/constants.js.map +1 -1
- package/esm/theme/builtin/common/legacy/index.d.ts +1 -0
- package/esm/theme/builtin/common/legacy/index.js +2 -0
- package/esm/theme/builtin/common/legacy/index.js.map +1 -0
- package/esm/theme/builtin/common/legacy/legend/color-legend.d.ts +2 -0
- package/esm/theme/builtin/common/legacy/legend/color-legend.js +39 -0
- package/esm/theme/builtin/common/legacy/legend/color-legend.js.map +1 -0
- package/esm/theme/builtin/common/legacy/legend/continuous.d.ts +2 -0
- package/esm/theme/builtin/common/legacy/legend/continuous.js +54 -0
- package/esm/theme/builtin/common/legacy/legend/continuous.js.map +1 -0
- package/esm/theme/builtin/common/legacy/legend/index.d.ts +2 -0
- package/esm/theme/builtin/common/legacy/legend/index.js +4 -0
- package/esm/theme/builtin/common/legacy/legend/index.js.map +1 -0
- package/esm/theme/builtin/common/legacy/legend/size-legend.d.ts +2 -0
- package/esm/theme/builtin/common/legacy/legend/size-legend.js +54 -0
- package/esm/theme/builtin/common/legacy/legend/size-legend.js.map +1 -0
- package/esm/theme/builtin/common/series/treemap.js +1 -1
- package/esm/theme/builtin/common/series/treemap.js.map +1 -1
- package/esm/theme/builtin/dark/index.js +13 -1
- package/esm/theme/builtin/dark/index.js.map +1 -1
- package/esm/theme/builtin/index.d.ts +3 -0
- package/esm/theme/builtin/index.js +12 -0
- package/esm/theme/builtin/index.js.map +1 -1
- package/esm/theme/interface.d.ts +6 -6
- package/esm/theme/interface.js.map +1 -1
- package/esm/theme/theme-manager.d.ts +1 -1
- package/esm/theme/theme-manager.js +3 -9
- package/esm/theme/theme-manager.js.map +1 -1
- package/esm/typings/spec/common.d.ts +1 -1
- package/esm/typings/spec/common.js.map +1 -1
- package/esm/typings/visual.d.ts +1 -1
- package/esm/typings/visual.js.map +1 -1
- package/esm/util/image.d.ts +1 -1
- package/esm/util/image.js.map +1 -1
- package/esm/util/spec/preprocess.d.ts +2 -2
- package/esm/util/spec/preprocess.js +11 -4
- package/esm/util/spec/preprocess.js.map +1 -1
- package/esm/util/text.d.ts +2 -2
- package/esm/util/text.js.map +1 -1
- package/package.json +13 -12
- package/cjs/layout/label/arc-label.d.ts +0 -42
- package/cjs/layout/label/arc-label.js +0 -416
- package/cjs/layout/label/arc-label.js.map +0 -1
- package/esm/layout/label/arc-label.d.ts +0 -42
- package/esm/layout/label/arc-label.js +0 -401
- package/esm/layout/label/arc-label.js.map +0 -1
package/esm/util/image.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/util/image.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAKhC,MAAM,UAAU,UAAU,CAAC,OAAe,QAAQ,EAAE,GAAW;IAC7D,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IACzC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACtC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,IAAI,MAAM,CAAC,CAAC;IAC7C,IAAI,CAAC,aAAa,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,CAAkB;IAEzD,OAAO,IAAI,OAAO,CAAC,CAAC,CAAsB,EAAE,EAAE;QAC5C,CAAC,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE;YAChC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;gBACnB,CAAC,CAAC,MAAM,CAAC,MAAgB,CAAC,CAAC;YAC7B,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAgB,gBAAgB,CAAC,CAAsC,EAAE,GAAqB;;;QAClG,IAAI,CAAC,CAAC,EAAE;YACN,OAAO,EAAE,CAAC;SACX;QACD,IAAI;YACF,IAAI,eAAe,KAAK,SAAS,IAAI,CAAC,YAAY,eAAe,EAAE;gBACjE,OAAO,wBAAwB,CAAC,CAAC,CAAC,CAAC;aACpC;SACF;QAAC,OAAO,MAAM,EAAE;YACf,CAAC,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,mCAAI,KAAK,CAAC,CAAC,4BAA4B,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;SAC1E;QACD,OAA2B,CAAE,CAAC,SAAS,EAAE,CAAC;;CAC3C","file":"image.js","sourcesContent":["import type { utilFunctionCtx } from '
|
|
1
|
+
{"version":3,"sources":["../src/util/image.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAKhC,MAAM,UAAU,UAAU,CAAC,OAAe,QAAQ,EAAE,GAAW;IAC7D,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IACzC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACtC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,IAAI,MAAM,CAAC,CAAC;IAC7C,IAAI,CAAC,aAAa,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,CAAkB;IAEzD,OAAO,IAAI,OAAO,CAAC,CAAC,CAAsB,EAAE,EAAE;QAC5C,CAAC,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE;YAChC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;gBACnB,CAAC,CAAC,MAAM,CAAC,MAAgB,CAAC,CAAC;YAC7B,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAgB,gBAAgB,CAAC,CAAsC,EAAE,GAAqB;;;QAClG,IAAI,CAAC,CAAC,EAAE;YACN,OAAO,EAAE,CAAC;SACX;QACD,IAAI;YACF,IAAI,eAAe,KAAK,SAAS,IAAI,CAAC,YAAY,eAAe,EAAE;gBACjE,OAAO,wBAAwB,CAAC,CAAC,CAAC,CAAC;aACpC;SACF;QAAC,OAAO,MAAM,EAAE;YACf,CAAC,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,mCAAI,KAAK,CAAC,CAAC,4BAA4B,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;SAC1E;QACD,OAA2B,CAAE,CAAC,SAAS,EAAE,CAAC;;CAC3C","file":"image.js","sourcesContent":["import type { utilFunctionCtx } from '../typings/params';\nimport { error } from './debug';\n/**\n * @description 图片导出相关接口\n */\n\nexport function URLToImage(name: string = 'vchart', url: string) {\n const link = document.createElement('a');\n link.setAttribute('href', url);\n link.setAttribute('target', '_blank');\n link.setAttribute('download', `${name}.png`);\n link.dispatchEvent(new MouseEvent('click'));\n}\n\nexport function OffscreenCanvasToDataURL(c: OffscreenCanvas) {\n // eslint-disable-next-line promise/param-names\n return new Promise((r: (s: string) => void) => {\n c.convertToBlob().then((b: any) => {\n const reader = new FileReader();\n reader.readAsDataURL(b);\n reader.onload = () => {\n r(reader.result as string);\n };\n });\n });\n}\n\nexport async function getCanvasDataURL(c: HTMLCanvasElement | OffscreenCanvas, ctx?: utilFunctionCtx) {\n if (!c) {\n return '';\n }\n try {\n if (OffscreenCanvas !== undefined && c instanceof OffscreenCanvas) {\n return OffscreenCanvasToDataURL(c);\n }\n } catch (_error) {\n (ctx?.onError ?? error)(`getCanvasDataURL error : ${_error.toString()}`);\n }\n return (<HTMLCanvasElement>c).toDataURL();\n}\n"]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import type
|
|
1
|
+
import { type SeriesTypeEnum } from '../../series/interface';
|
|
2
2
|
import type { IThemeColorScheme } from '../../theme/color-scheme/interface';
|
|
3
|
-
export declare function preprocessSpecOrTheme(obj: any, colorScheme?: IThemeColorScheme, seriesType?: SeriesTypeEnum): any;
|
|
3
|
+
export declare function preprocessSpecOrTheme(type: 'spec' | 'theme' | 'markSpec', obj: any, colorScheme?: IThemeColorScheme, seriesType?: SeriesTypeEnum): any;
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import { isArray, isFunction, isObject } from "@visactor/vutils";
|
|
1
|
+
import { isArray, isFunction, isObject, isString, isValid, isValidNumber } from "@visactor/vutils";
|
|
2
|
+
|
|
3
|
+
import { seriesMarkNameSet } from "../../series/interface";
|
|
2
4
|
|
|
3
5
|
import { isDataView, isHTMLElement } from "./common";
|
|
4
6
|
|
|
@@ -6,14 +8,19 @@ import { getActualColor, isColorKey } from "../../theme/color-scheme/util";
|
|
|
6
8
|
|
|
7
9
|
import { normalizeLayoutPaddingSpec } from "../space";
|
|
8
10
|
|
|
9
|
-
export function preprocessSpecOrTheme(obj, colorScheme, seriesType) {
|
|
10
|
-
if (isArray(obj)) return obj.map((element => isObject(element) && !isFunction(element) ? preprocessSpecOrTheme(element, colorScheme, seriesType) : element));
|
|
11
|
+
export function preprocessSpecOrTheme(type, obj, colorScheme, seriesType) {
|
|
12
|
+
if (isArray(obj)) return obj.map((element => isObject(element) && !isFunction(element) ? preprocessSpecOrTheme(type, element, colorScheme, seriesType) : element));
|
|
11
13
|
const newObj = {};
|
|
12
14
|
return Object.keys(obj).forEach((key => {
|
|
13
15
|
const value = obj[key];
|
|
14
16
|
if (key.includes("data")) newObj[key] = value; else if (isObject(value)) {
|
|
15
17
|
if (isFunction(value) || isDataView(value) || isHTMLElement(value)) return void (newObj[key] = value);
|
|
16
|
-
isColorKey(value) ? newObj[key] = getActualColor(value, colorScheme, seriesType) : newObj[key] =
|
|
18
|
+
isColorKey(value) ? newObj[key] = getActualColor(value, colorScheme, seriesType) : newObj[key] = preprocessSpecOrTheme(seriesMarkNameSet.has(key) ? "markSpec" : type, value, colorScheme, seriesType);
|
|
19
|
+
} else if ("markSpec" !== type && "padding" === key) newObj[key] = normalizeLayoutPaddingSpec(value); else if ("theme" !== type && "lineHeight" === key && isString(value) && "%" === value[value.length - 1]) {
|
|
20
|
+
if (isValid(obj.fontSize)) {
|
|
21
|
+
const scale = Number.parseFloat(value.substring(0, value.length - 1)) / 100, newValue = obj.fontSize * scale;
|
|
22
|
+
isValidNumber(newValue) && (newObj[key] = newValue);
|
|
23
|
+
}
|
|
17
24
|
} else newObj[key] = value;
|
|
18
25
|
})), newObj;
|
|
19
26
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/util/spec/preprocess.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"sources":["../src/util/spec/preprocess.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAuB,MAAM,wBAAwB,CAAC;AAEhF,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3E,OAAO,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAC;AAUtD,MAAM,UAAU,qBAAqB,CACnC,IAAmC,EACnC,GAAQ,EACR,WAA+B,EAC/B,UAA2B;IAE3B,IAAI,OAAO,CAAC,GAAG,CAAC,EAAE;QAChB,OAAO,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YACvB,IAAI,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;gBAC7C,OAAO,qBAAqB,CAAC,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;aACtE;YACD,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,CAAC;KACJ;IAED,MAAM,MAAM,GAAG,EAAE,CAAC;IAClB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC7B,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;QAEvB,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;YACxB,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YACpB,OAAO;SACR;QACD,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;YAEnB,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE;gBAClE,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;gBACpB,OAAO;aACR;YACD,IAAI,UAAU,CAAC,KAAK,CAAC,EAAE;gBAErB,MAAM,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;aAC9D;iBAAM;gBACL,MAAM,CAAC,GAAG,CAAC,GAAG,qBAAqB,CACjC,iBAAiB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,EAC9C,KAAK,EACL,WAAW,EACX,UAAU,CACX,CAAC;aACH;SACF;aAAM,IAAI,IAAI,KAAK,UAAU,IAAI,GAAG,KAAK,SAAS,EAAE;YAEnD,MAAM,CAAC,GAAG,CAAC,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;SACjD;aAAM,IAAI,IAAI,KAAK,OAAO,IAAI,GAAG,KAAK,YAAY,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,EAAE;YACzG,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;gBAGzB,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;gBAC5E,MAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACtC,IAAI,aAAa,CAAC,QAAQ,CAAC,EAAE;oBAC3B,MAAM,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC;iBACxB;aACF;SAEF;aAAM;YACL,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;SACrB;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAChB,CAAC","file":"preprocess.js","sourcesContent":["import { isArray, isFunction, isObject, isString, isValid, isValidNumber } from '@visactor/vutils';\nimport { seriesMarkNameSet, type SeriesTypeEnum } from '../../series/interface';\nimport type { IThemeColorScheme } from '../../theme/color-scheme/interface';\nimport { isDataView, isHTMLElement } from './common';\nimport { getActualColor, isColorKey } from '../../theme/color-scheme/util';\nimport { normalizeLayoutPaddingSpec } from '../space';\n\n/**\n * 对 spec 或者类 spec 配置(如 theme)进行预处理,如进行语义化颜色的转换等\n * @param type 需要转换的对象类型(spec 或者 theme)\n * @param obj 需要转换的对象\n * @param colorScheme 主题色板\n * @param seriesType 当前系列类型\n * @returns\n */\nexport function preprocessSpecOrTheme(\n type: 'spec' | 'theme' | 'markSpec',\n obj: any,\n colorScheme?: IThemeColorScheme,\n seriesType?: SeriesTypeEnum\n): any {\n if (isArray(obj)) {\n return obj.map(element => {\n if (isObject(element) && !isFunction(element)) {\n return preprocessSpecOrTheme(type, element, colorScheme, seriesType);\n }\n return element;\n });\n }\n\n const newObj = {};\n Object.keys(obj).forEach(key => {\n const value = obj[key];\n // 绕过数据\n if (key.includes('data')) {\n newObj[key] = value;\n return;\n }\n if (isObject(value)) {\n // 绕过不可深拷贝的对象\n if (isFunction(value) || isDataView(value) || isHTMLElement(value)) {\n newObj[key] = value;\n return;\n }\n if (isColorKey(value)) {\n // 查询、替换语义化颜色\n newObj[key] = getActualColor(value, colorScheme, seriesType);\n } else {\n newObj[key] = preprocessSpecOrTheme(\n seriesMarkNameSet.has(key) ? 'markSpec' : type,\n value,\n colorScheme,\n seriesType\n );\n }\n } else if (type !== 'markSpec' && key === 'padding') {\n // 标准化 padding\n newObj[key] = normalizeLayoutPaddingSpec(value);\n } else if (type !== 'theme' && key === 'lineHeight' && isString(value) && value[value.length - 1] === '%') {\n if (isValid(obj.fontSize)) {\n // 处理 lineHeight 的比例值\n // FIXME: vrender 支持行高字符串后删掉这段逻辑\n const scale = Number.parseFloat(value.substring(0, value.length - 1)) / 100;\n const newValue = obj.fontSize * scale;\n if (isValidNumber(newValue)) {\n newObj[key] = newValue;\n }\n }\n // 如果 spec 同级里没有 fontSize 配置,lineHeight 比例值失效\n } else {\n newObj[key] = value;\n }\n });\n\n return newObj;\n}\n"]}
|
package/esm/util/text.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import type { ITextMeasureOption } from '@visactor/vutils';
|
|
2
2
|
import { TextMeasure } from '@visactor/vutils';
|
|
3
|
-
import type { ITextMarkSpec } from '../typings';
|
|
4
|
-
export declare const initTextMeasure: (textSpec?: Partial<ITextMarkSpec>, option?: Partial<ITextMeasureOption>, useNaiveCanvas?: boolean) => TextMeasure<ITextMarkSpec
|
|
3
|
+
import type { AdaptiveSpec, ITextMarkSpec } from '../typings';
|
|
4
|
+
export declare const initTextMeasure: (textSpec?: Partial<ITextMarkSpec>, option?: Partial<ITextMeasureOption>, useNaiveCanvas?: boolean) => TextMeasure<AdaptiveSpec<ITextMarkSpec, 'lineHeight'>>;
|
package/esm/util/text.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/util/text.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAEpE,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,QAAiC,EACjC,MAAoC,EACpC,cAAwB,
|
|
1
|
+
{"version":3,"sources":["../src/util/text.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAEpE,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,QAAiC,EACjC,MAAoC,EACpC,cAAwB,EACgC,EAAE;IAE1D,OAAO,IAAI,WAAW,iBAElB,iBAAiB,EAAE;YACjB,UAAU,EAAE,eAAe,CAAC,iBAAiB;YAC7C,QAAQ,EAAE,eAAe,CAAC,eAAe;SAC1C,EACD,aAAa,EAAE,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa,EACzD,cAAc,EAAE,cAAc,GAAG,WAAW,CAAC,iBAAiB,GAAG,WAAW,CAAC,iBAAiB,CAAC,WAAW,EAAE,IACzG,CAAC,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,EAAE,CAAC,GAEnB,QAAQ,CACT,CAAC;AACJ,CAAC,CAAC","file":"text.js","sourcesContent":["import type { ITextMeasureOption } from '@visactor/vutils';\n// eslint-disable-next-line no-duplicate-imports\nimport { TextMeasure } from '@visactor/vutils';\nimport { getTextBounds } from '@visactor/vrender';\nimport type { AdaptiveSpec, ITextMarkSpec } from '../typings';\nimport { THEME_CONSTANTS } from '../theme/builtin/common/constants';\n\nexport const initTextMeasure = (\n textSpec?: Partial<ITextMarkSpec>,\n option?: Partial<ITextMeasureOption>,\n useNaiveCanvas?: boolean\n): TextMeasure<AdaptiveSpec<ITextMarkSpec, 'lineHeight'>> => {\n // FIXME: vrender 支持行高字符串后删除 AdaptiveSpec 范型\n return new TextMeasure<AdaptiveSpec<ITextMarkSpec, 'lineHeight'>>(\n {\n defaultFontParams: {\n fontFamily: THEME_CONSTANTS.defaultFontFamily,\n fontSize: THEME_CONSTANTS.defaultFontSize\n },\n getTextBounds: useNaiveCanvas ? undefined : getTextBounds,\n specialCharSet: '-/: .,@%\\'\"~' + TextMeasure.ALPHABET_CHAR_SET + TextMeasure.ALPHABET_CHAR_SET.toUpperCase(),\n ...(option ?? {})\n },\n textSpec\n );\n};\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@visactor/vchart",
|
|
3
|
-
"version": "1.3.
|
|
3
|
+
"version": "1.3.1-beta.1",
|
|
4
4
|
"description": "charts lib based @visactor/VGrammar",
|
|
5
5
|
"main": "cjs/index.js",
|
|
6
6
|
"module": "esm/index.js",
|
|
@@ -79,16 +79,16 @@
|
|
|
79
79
|
"@internal/ts-config": "0.0.1"
|
|
80
80
|
},
|
|
81
81
|
"dependencies": {
|
|
82
|
-
"@visactor/vutils": "~0.15.
|
|
83
|
-
"@visactor/vdataset": "~0.15.
|
|
84
|
-
"@visactor/vscale": "~0.15.
|
|
85
|
-
"@visactor/vgrammar": "~0.6.
|
|
86
|
-
"@visactor/vgrammar-projection": "~0.6.
|
|
87
|
-
"@visactor/vgrammar-wordcloud": "~0.6.
|
|
88
|
-
"@visactor/vgrammar-wordcloud-shape": "~0.6.
|
|
89
|
-
"@visactor/vgrammar-hierarchy": "~0.6.
|
|
90
|
-
"@visactor/vgrammar-sankey": "~0.6.
|
|
91
|
-
"@visactor/vgrammar-util": "~0.6.
|
|
82
|
+
"@visactor/vutils": "~0.15.10",
|
|
83
|
+
"@visactor/vdataset": "~0.15.10",
|
|
84
|
+
"@visactor/vscale": "~0.15.10",
|
|
85
|
+
"@visactor/vgrammar": "~0.6.6",
|
|
86
|
+
"@visactor/vgrammar-projection": "~0.6.6",
|
|
87
|
+
"@visactor/vgrammar-wordcloud": "~0.6.6",
|
|
88
|
+
"@visactor/vgrammar-wordcloud-shape": "~0.6.6",
|
|
89
|
+
"@visactor/vgrammar-hierarchy": "~0.6.6",
|
|
90
|
+
"@visactor/vgrammar-sankey": "~0.6.6",
|
|
91
|
+
"@visactor/vgrammar-util": "~0.6.6",
|
|
92
92
|
"@visactor/vrender": "~0.14.7",
|
|
93
93
|
"@visactor/vrender-components": "~0.14.7"
|
|
94
94
|
},
|
|
@@ -118,6 +118,7 @@
|
|
|
118
118
|
"test-live": "npm run test-watch __tests__/unit/",
|
|
119
119
|
"test-watch": "DEBUG_MODE=1 jest --watch",
|
|
120
120
|
"ci": "ts-node --transpileOnly --skipProject ./scripts/trigger-test.ts",
|
|
121
|
-
"build:es": "bundle --clean -f es --ignorePostTasks"
|
|
121
|
+
"build:es": "bundle --clean -f es --ignorePostTasks",
|
|
122
|
+
"export:theme": "ts-node scripts/export-theme.ts"
|
|
122
123
|
}
|
|
123
124
|
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import type { DataView } from '@visactor/vdataset';
|
|
2
|
-
import type { IArcSeries } from '../../series/interface';
|
|
3
|
-
export interface IArcLabelOpt {
|
|
4
|
-
series: IArcSeries;
|
|
5
|
-
}
|
|
6
|
-
export declare const arcLabel: (data: Array<DataView>, op: IArcLabelOpt) => any[];
|
|
7
|
-
export declare class ArcLabelLayout {
|
|
8
|
-
private _series;
|
|
9
|
-
private _data;
|
|
10
|
-
private _ellipsisWidth;
|
|
11
|
-
private _arcLeft;
|
|
12
|
-
private _arcRight;
|
|
13
|
-
private _textMeasure;
|
|
14
|
-
constructor(series: IArcSeries, data: Array<DataView>);
|
|
15
|
-
updateLabels(): any[];
|
|
16
|
-
private _setArcs;
|
|
17
|
-
private _getArc;
|
|
18
|
-
private _clearArcs;
|
|
19
|
-
private _setLabelData;
|
|
20
|
-
private _layoutLabels;
|
|
21
|
-
private _layoutInsideLabels;
|
|
22
|
-
private _layoutOutsideLabels;
|
|
23
|
-
private _coverLabels;
|
|
24
|
-
private _computeLayoutRadius;
|
|
25
|
-
private _computePointB;
|
|
26
|
-
private _computeX;
|
|
27
|
-
private _computeAlignOffset;
|
|
28
|
-
private _adjustY;
|
|
29
|
-
private _checkYRange;
|
|
30
|
-
private _computeYRange;
|
|
31
|
-
private _storeY;
|
|
32
|
-
private _restoreY;
|
|
33
|
-
private _findNeighborIndex;
|
|
34
|
-
private _twoWayShift;
|
|
35
|
-
private _shiftY;
|
|
36
|
-
private _findNextVisibleIndex;
|
|
37
|
-
private _computeAlign;
|
|
38
|
-
private _getFormatLabelText;
|
|
39
|
-
private _getMeasureSpec;
|
|
40
|
-
private _measureTextSize;
|
|
41
|
-
private _getPlotLayout;
|
|
42
|
-
}
|
|
@@ -1,416 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: !0
|
|
5
|
-
}), exports.ArcLabelLayout = exports.arcLabel = void 0;
|
|
6
|
-
|
|
7
|
-
const util_1 = require("../../util"), constant_1 = require("../../constant"), mark_1 = require("../../compile/mark"), arcLabel = (data, op) => {
|
|
8
|
-
const latestData = data[0].latestData;
|
|
9
|
-
return new ArcLabelLayout(op.series, latestData).updateLabels();
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
exports.arcLabel = arcLabel;
|
|
13
|
-
|
|
14
|
-
class ArcInfo {
|
|
15
|
-
constructor(refDatum, center, outerCenter, quadrant, radian, middleAngle, k) {
|
|
16
|
-
this.refDatum = refDatum, this.center = center, this.outerCenter = outerCenter,
|
|
17
|
-
this.quadrant = quadrant, this.radian = radian, this.middleAngle = middleAngle,
|
|
18
|
-
this.k = k, this.labelVisible = !0, this.labelLimit = 0;
|
|
19
|
-
}
|
|
20
|
-
getLabelBounds() {
|
|
21
|
-
return this.labelPosition && this.labelSize ? {
|
|
22
|
-
x1: this.labelPosition.x - this.labelSize.width / 2,
|
|
23
|
-
y1: this.labelPosition.y - this.labelSize.height / 2,
|
|
24
|
-
x2: this.labelPosition.x + this.labelSize.width / 2,
|
|
25
|
-
y2: this.labelPosition.y + this.labelSize.height / 2
|
|
26
|
-
} : {
|
|
27
|
-
x1: 0,
|
|
28
|
-
x2: 0,
|
|
29
|
-
y1: 0,
|
|
30
|
-
y2: 0
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
class ArcLabelLayout {
|
|
36
|
-
constructor(series, data) {
|
|
37
|
-
this._ellipsisWidth = 0, this._arcLeft = new Map, this._arcRight = new Map, this._series = series,
|
|
38
|
-
this._data = data, this._textMeasure = (0, util_1.initTextMeasure)(this._getMeasureSpec());
|
|
39
|
-
}
|
|
40
|
-
updateLabels() {
|
|
41
|
-
const labelConfig = this._series.getLabelConfig();
|
|
42
|
-
return (null == labelConfig ? void 0 : labelConfig.visible) ? (this._setArcs(),
|
|
43
|
-
this._layoutLabels(), this._setLabelData()) : null;
|
|
44
|
-
}
|
|
45
|
-
_setArcs() {
|
|
46
|
-
var _a, _b, _c;
|
|
47
|
-
const valueField = this._series.getRadiusField()[0], radiusRatio = this._series.getRadius(), labelConfig = this._series.getLabelConfig(), line1MinLength = labelConfig.line.line1MinLength;
|
|
48
|
-
if (null == labelConfig ? void 0 : labelConfig.visible) {
|
|
49
|
-
this._clearArcs();
|
|
50
|
-
const radius = this._series.computeRadius(radiusRatio), center = this._series.center, data = null === (_c = null === (_b = (_a = this._series).getViewData) || void 0 === _b ? void 0 : _b.call(_a)) || void 0 === _c ? void 0 : _c.latestData;
|
|
51
|
-
let values;
|
|
52
|
-
if (data.length <= 1) values = data.slice(); else switch (null == labelConfig ? void 0 : labelConfig.showRule) {
|
|
53
|
-
case "headAndTail":
|
|
54
|
-
values = [ data[0], data[data.length - 1] ];
|
|
55
|
-
break;
|
|
56
|
-
|
|
57
|
-
case "max":
|
|
58
|
-
values = [ data.reduce(((max, value) => max[valueField] > value[valueField] ? max : value), data[0]) ];
|
|
59
|
-
break;
|
|
60
|
-
|
|
61
|
-
case "min":
|
|
62
|
-
values = [ data.reduce(((min, value) => min[valueField] < value[valueField] ? min : value), data[0]) ];
|
|
63
|
-
break;
|
|
64
|
-
|
|
65
|
-
case "minAndMax":
|
|
66
|
-
values = [ data.reduce(((max, value) => max[valueField] > value[valueField] ? max : value), data[0]), data.reduce(((min, value) => min[valueField] < value[valueField] ? min : value), data[0]) ];
|
|
67
|
-
break;
|
|
68
|
-
|
|
69
|
-
default:
|
|
70
|
-
values = data.slice();
|
|
71
|
-
}
|
|
72
|
-
this._ellipsisWidth = this._measureTextSize("...").width;
|
|
73
|
-
for (const item of values) {
|
|
74
|
-
const arcMiddle = (0, util_1.circlePoint)(center.x, center.y, radius * item[constant_1.ARC_K], item[constant_1.ARC_MIDDLE_ANGLE]), outerArcMiddle = (0,
|
|
75
|
-
util_1.circlePoint)(center.x, center.y, radius + line1MinLength, item[constant_1.ARC_MIDDLE_ANGLE]), arc = new ArcInfo(item, arcMiddle, outerArcMiddle, item[constant_1.ARC_QUADRANT], item[constant_1.ARC_RADIAN], item[constant_1.ARC_MIDDLE_ANGLE], item[constant_1.ARC_K]), text = this._getFormatLabelText(item);
|
|
76
|
-
arc.labelSize = this._measureTextSize(text), (0, util_1.isQuadrantRight)(arc.quadrant) ? this._arcRight.set(arc.refDatum, arc) : (0,
|
|
77
|
-
util_1.isQuadrantLeft)(arc.quadrant) && this._arcLeft.set(arc.refDatum, arc);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
_getArc(datum) {
|
|
82
|
-
return this._arcLeft.get(datum) || this._arcRight.get(datum);
|
|
83
|
-
}
|
|
84
|
-
_clearArcs() {
|
|
85
|
-
this._arcLeft.clear(), this._arcRight.clear();
|
|
86
|
-
}
|
|
87
|
-
_setLabelData() {
|
|
88
|
-
const labelConfig = this._series.getLabelConfig(), center = this._series.center;
|
|
89
|
-
return this._data.map((v => {
|
|
90
|
-
const arc = this._getArc(v), value = Object.assign({}, v);
|
|
91
|
-
if (!arc) return value[constant_1.DEFAULT_LABEL_VISIBLE] = !1, value;
|
|
92
|
-
const {labelPosition: labelPosition, labelLimit: labelLimit, labelSize: labelSize, pointB: pointB, pointC: pointC} = arc;
|
|
93
|
-
if ("inside" !== (null == labelConfig ? void 0 : labelConfig.position)) {
|
|
94
|
-
const hoverLineA = (0, util_1.circlePoint)(center.x, center.y, this._series.computeDatumRadius(value, mark_1.STATE_VALUE_ENUM.STATE_HOVER), arc.middleAngle), selectedLineA = (0,
|
|
95
|
-
util_1.circlePoint)(center.x, center.y, this._series.computeDatumRadius(value, mark_1.STATE_VALUE_ENUM.STATE_SELECTED), arc.middleAngle), pointA = (0,
|
|
96
|
-
util_1.circlePoint)(center.x, center.y, this._series.computeDatumRadius(value, mark_1.STATE_VALUE_ENUM.STATE_NORMAL), arc.middleAngle);
|
|
97
|
-
value[constant_1.ARC_LABEL_POINT_AX] = pointA.x, value[constant_1.ARC_LABEL_POINT_AY] = pointA.y,
|
|
98
|
-
value[constant_1.ARC_LABEL_HOVER_AX] = hoverLineA.x, value[constant_1.ARC_LABEL_HOVER_AY] = hoverLineA.y,
|
|
99
|
-
value[constant_1.ARC_LABEL_SELECTED_AX] = selectedLineA.x, value[constant_1.ARC_LABEL_SELECTED_AY] = selectedLineA.y,
|
|
100
|
-
value[constant_1.ARC_LABEL_POINT_BX] = pointB.x, value[constant_1.ARC_LABEL_POINT_BY] = pointB.y,
|
|
101
|
-
value[constant_1.ARC_LABEL_POINT_CX] = pointC.x, value[constant_1.ARC_LABEL_POINT_CY] = pointC.y,
|
|
102
|
-
value[constant_1.DEFAULT_LABEL_Y] = labelPosition.y - labelSize.height / 2;
|
|
103
|
-
} else value[constant_1.DEFAULT_LABEL_Y] = labelPosition.y;
|
|
104
|
-
return value[constant_1.DEFAULT_LABEL_ALIGN] = this._computeAlign(arc), value[constant_1.DEFAULT_LABEL_LIMIT] = Math.max(labelLimit, 0),
|
|
105
|
-
value[constant_1.DEFAULT_LABEL_VISIBLE] = arc.labelVisible && !(0, util_1.isNil)(arc.labelText),
|
|
106
|
-
value[constant_1.DEFAULT_LABEL_X] = labelPosition.x, value[constant_1.DEFAULT_LABEL_TEXT] = arc.labelText,
|
|
107
|
-
value;
|
|
108
|
-
}));
|
|
109
|
-
}
|
|
110
|
-
_layoutLabels() {
|
|
111
|
-
const labelConfig = this._series.getLabelConfig(), leftArcs = Array.from(this._arcLeft.values()), rightArcs = Array.from(this._arcRight.values());
|
|
112
|
-
"inside" === (null == labelConfig ? void 0 : labelConfig.position) ? (this._layoutInsideLabels(rightArcs),
|
|
113
|
-
this._layoutInsideLabels(leftArcs)) : (this._layoutOutsideLabels(rightArcs), this._layoutOutsideLabels(leftArcs));
|
|
114
|
-
}
|
|
115
|
-
_layoutInsideLabels(arcs) {
|
|
116
|
-
const center = this._series.center, innerRadiusRatio = this._series.getInnerRadius(), outerRadiusRatio = this._series.getRadius(), labelConfig = this._series.getLabelConfig(), spaceWidth = labelConfig.spaceWidth;
|
|
117
|
-
arcs.forEach((arc => {
|
|
118
|
-
const {labelSize: labelSize, radian: radian} = arc, innerRadius = this._series.computeRadius(innerRadiusRatio, 1), outerRadius = this._series.computeRadius(outerRadiusRatio);
|
|
119
|
-
let limit;
|
|
120
|
-
if (radian < (0, util_1.connectLineRadian)(outerRadius, labelSize.height)) limit = 0; else {
|
|
121
|
-
let minRadius;
|
|
122
|
-
minRadius = radian >= Math.PI ? innerRadius : Math.max(innerRadius, labelSize.height / 2 / Math.tan(radian / 2)),
|
|
123
|
-
limit = outerRadius - minRadius - spaceWidth;
|
|
124
|
-
}
|
|
125
|
-
!0 !== (null == labelConfig ? void 0 : labelConfig.rotate) && (limit = outerRadius - spaceWidth);
|
|
126
|
-
const text = this._getFormatLabelText(arc.refDatum, limit);
|
|
127
|
-
arc.labelText = text;
|
|
128
|
-
const labelWidth = Math.min(limit, this._measureTextSize(text).width), align = this._computeAlign(arc), labelRadius = outerRadius - spaceWidth - ("left" === align ? labelWidth : "right" === align ? 0 : labelWidth / 2);
|
|
129
|
-
arc.labelPosition = (0, util_1.circlePoint)(center.x, center.y, labelRadius, arc.middleAngle),
|
|
130
|
-
arc.labelLimit = labelWidth, (0, util_1.isGreater)(labelWidth, 0) || (arc.labelVisible = !1);
|
|
131
|
-
}));
|
|
132
|
-
}
|
|
133
|
-
_layoutOutsideLabels(arcs) {
|
|
134
|
-
var _a;
|
|
135
|
-
const {height: height} = this._getPlotLayout(), labelConfig = this._series.getLabelConfig(), line2MinLength = labelConfig.line.line2MinLength, labelLayout = labelConfig.layout, spaceWidth = labelConfig.spaceWidth;
|
|
136
|
-
if (arcs.forEach((arc => {
|
|
137
|
-
const direction = (0, util_1.isQuadrantLeft)(arc.quadrant) ? -1 : 1;
|
|
138
|
-
arc.labelPosition = {
|
|
139
|
-
x: arc.outerCenter.x + direction * (arc.labelSize.width / 2 + line2MinLength + spaceWidth),
|
|
140
|
-
y: arc.outerCenter.y
|
|
141
|
-
};
|
|
142
|
-
})), arcs.sort(((a, b) => a.labelPosition.y - b.labelPosition.y)), !1 !== labelConfig.coverEnable || "none" === labelLayout.strategy) {
|
|
143
|
-
for (const arc of arcs) {
|
|
144
|
-
const {labelPosition: labelPosition, labelSize: labelSize} = arc;
|
|
145
|
-
arc.labelLimit = labelSize.width, arc.pointB = (0, util_1.isQuadrantLeft)(arc.quadrant) ? {
|
|
146
|
-
x: labelPosition.x + labelSize.width / 2 + line2MinLength + spaceWidth,
|
|
147
|
-
y: labelPosition.y
|
|
148
|
-
} : {
|
|
149
|
-
x: labelPosition.x - labelSize.width / 2 - line2MinLength - spaceWidth,
|
|
150
|
-
y: labelPosition.y
|
|
151
|
-
}, this._computeX(arc);
|
|
152
|
-
}
|
|
153
|
-
!1 === labelConfig.coverEnable && "none" === labelLayout.strategy && this._coverLabels(arcs);
|
|
154
|
-
} else {
|
|
155
|
-
const maxLabels = height / ((null === (_a = labelConfig.style) || void 0 === _a ? void 0 : _a.fontSize) || 16);
|
|
156
|
-
this._adjustY(arcs, maxLabels);
|
|
157
|
-
const {minY: minY, maxY: maxY} = arcs.reduce(((yInfo, arc) => {
|
|
158
|
-
const {y1: y1, y2: y2} = arc.getLabelBounds();
|
|
159
|
-
return yInfo.minY = Math.max(0, Math.min(y1, yInfo.minY)), yInfo.maxY = Math.min(height, Math.max(y2, yInfo.maxY)),
|
|
160
|
-
yInfo;
|
|
161
|
-
}), {
|
|
162
|
-
minY: 1 / 0,
|
|
163
|
-
maxY: -1 / 0
|
|
164
|
-
}), halfY = Math.max(Math.abs(height / 2 - minY), Math.abs(maxY - height / 2)), r = this._computeLayoutRadius(halfY);
|
|
165
|
-
for (const arc of arcs) this._computePointB(arc, r), this._computeX(arc);
|
|
166
|
-
}
|
|
167
|
-
const {width: width} = this._getPlotLayout();
|
|
168
|
-
arcs.forEach((arc => {
|
|
169
|
-
arc.labelVisible && ((0, util_1.isLess)(arc.pointB.x, line2MinLength + spaceWidth) || (0,
|
|
170
|
-
util_1.isGreater)(arc.pointB.x, width - line2MinLength - spaceWidth)) && (arc.labelVisible = !1);
|
|
171
|
-
}));
|
|
172
|
-
}
|
|
173
|
-
_coverLabels(arcs) {
|
|
174
|
-
if (arcs.length <= 1) return;
|
|
175
|
-
let lastBounds = arcs[0].getLabelBounds();
|
|
176
|
-
for (let i = 1; i < arcs.length; i++) {
|
|
177
|
-
const bounds = arcs[i].getLabelBounds();
|
|
178
|
-
(0, util_1.checkBoundsOverlap)(lastBounds, bounds) ? arcs[i].labelVisible = !1 : lastBounds = bounds;
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
_computeLayoutRadius(halfYLength) {
|
|
182
|
-
const labelConfig = this._series.getLabelConfig(), layoutArcGap = labelConfig.layoutArcGap, line1MinLength = labelConfig.line.line1MinLength, radiusRatio = this._series.getRadius(), radius = this._series.computeRadius(radiusRatio), outerR = Math.max(radius + line1MinLength, this._series.computeDatumRadius(null)), a = outerR - layoutArcGap;
|
|
183
|
-
return Math.max((a ** 2 + halfYLength ** 2) / (2 * a), outerR);
|
|
184
|
-
}
|
|
185
|
-
_computePointB(arc, r) {
|
|
186
|
-
const radiusRatio = this._series.getRadius(), labelConfig = this._series.getLabelConfig(), line1MinLength = labelConfig.line.line1MinLength;
|
|
187
|
-
if ("none" === labelConfig.layout.strategy) arc.pointB = {
|
|
188
|
-
x: arc.outerCenter.x,
|
|
189
|
-
y: arc.outerCenter.y
|
|
190
|
-
}; else {
|
|
191
|
-
const center = this._series.center, radius = this._series.computeRadius(radiusRatio), {labelPosition: labelPosition, quadrant: quadrant} = arc, rd = r - Math.max(radius + line1MinLength, this._series.computeDatumRadius(null)), x = Math.sqrt(r ** 2 - Math.abs(center.y - labelPosition.y) ** 2) - rd;
|
|
192
|
-
(0, util_1.isValidNumber)(x) ? arc.pointB = {
|
|
193
|
-
x: center.x + x * ((0, util_1.isQuadrantLeft)(quadrant) ? -1 : 1),
|
|
194
|
-
y: labelPosition.y
|
|
195
|
-
} : arc.pointB = {
|
|
196
|
-
x: NaN,
|
|
197
|
-
y: NaN
|
|
198
|
-
};
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
_computeX(arc) {
|
|
202
|
-
var _a;
|
|
203
|
-
const center = this._series.center, plotLayout = this._getPlotLayout(), radiusRatio = this._series.getRadius(), labelConfig = this._series.getLabelConfig(), line1MinLength = labelConfig.line.line1MinLength, line2MinLength = labelConfig.line.line2MinLength, labelLayoutAlign = null === (_a = labelConfig.layout) || void 0 === _a ? void 0 : _a.align, spaceWidth = labelConfig.spaceWidth, align = this._computeAlign(arc), {labelPosition: labelPosition, quadrant: quadrant, pointB: pointB} = arc;
|
|
204
|
-
(0, util_1.isValidNumber)(pointB.x * pointB.y) || (arc.pointC = {
|
|
205
|
-
x: NaN,
|
|
206
|
-
y: NaN
|
|
207
|
-
}, labelPosition.x = NaN, arc.labelLimit = 0);
|
|
208
|
-
const radius = this._series.computeRadius(radiusRatio), flag = (0, util_1.isQuadrantLeft)(quadrant) ? -1 : 1;
|
|
209
|
-
let cx = 0;
|
|
210
|
-
let limit = (flag > 0 ? plotLayout.width - pointB.x : pointB.x) - line2MinLength - spaceWidth;
|
|
211
|
-
"labelLine" === labelLayoutAlign && (cx = (radius + line1MinLength + line2MinLength) * flag + center.x,
|
|
212
|
-
limit = (flag > 0 ? plotLayout.width - cx : cx) - spaceWidth);
|
|
213
|
-
const text = this._getFormatLabelText(arc.refDatum, limit);
|
|
214
|
-
arc.labelText = text;
|
|
215
|
-
let labelWidth = Math.min(limit, this._measureTextSize(text).width);
|
|
216
|
-
switch (labelLayoutAlign) {
|
|
217
|
-
case "labelLine":
|
|
218
|
-
break;
|
|
219
|
-
|
|
220
|
-
case "edge":
|
|
221
|
-
cx = flag > 0 ? plotLayout.width - labelWidth - spaceWidth : labelWidth + spaceWidth;
|
|
222
|
-
break;
|
|
223
|
-
|
|
224
|
-
default:
|
|
225
|
-
cx = pointB.x + flag * line2MinLength;
|
|
226
|
-
}
|
|
227
|
-
if (labelWidth = Math.max(this._ellipsisWidth, labelWidth), arc.pointC = {
|
|
228
|
-
x: cx,
|
|
229
|
-
y: labelPosition.y
|
|
230
|
-
}, "edge" === labelLayoutAlign) {
|
|
231
|
-
const alignOffset = this._computeAlignOffset(align, labelWidth, -flag);
|
|
232
|
-
labelPosition.x = flag > 0 ? plotLayout.width + alignOffset : alignOffset;
|
|
233
|
-
} else {
|
|
234
|
-
const alignOffset = this._computeAlignOffset(align, labelWidth, flag);
|
|
235
|
-
labelPosition.x = cx + alignOffset + flag * spaceWidth;
|
|
236
|
-
}
|
|
237
|
-
arc.labelLimit = labelWidth;
|
|
238
|
-
}
|
|
239
|
-
_computeAlignOffset(align, labelWidth, alignFlag) {
|
|
240
|
-
switch (align) {
|
|
241
|
-
case "left":
|
|
242
|
-
return alignFlag < 0 ? -labelWidth : 0;
|
|
243
|
-
|
|
244
|
-
case "right":
|
|
245
|
-
return alignFlag < 0 ? 0 : labelWidth;
|
|
246
|
-
|
|
247
|
-
default:
|
|
248
|
-
return labelWidth / 2 * alignFlag;
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
_adjustY(arcs, maxLabels) {
|
|
252
|
-
const plotRect = this._getPlotLayout(), labelLayout = this._series.getLabelConfig().layout;
|
|
253
|
-
if ("vertical" === labelLayout.strategy) {
|
|
254
|
-
let delta, lastY = 0;
|
|
255
|
-
const len = arcs.length;
|
|
256
|
-
if (len <= 0) return;
|
|
257
|
-
for (let i = 0; i < len; i++) {
|
|
258
|
-
const {y1: y1} = arcs[i].getLabelBounds();
|
|
259
|
-
if (delta = y1 - lastY, (0, util_1.isLess)(delta, 0)) {
|
|
260
|
-
const index = this._shiftY(arcs, i, len - 1, -delta);
|
|
261
|
-
this._shiftY(arcs, index, 0, delta / 2);
|
|
262
|
-
}
|
|
263
|
-
const {y2: y2} = arcs[i].getLabelBounds();
|
|
264
|
-
lastY = y2;
|
|
265
|
-
}
|
|
266
|
-
const {y1: firstY1} = arcs[0].getLabelBounds();
|
|
267
|
-
delta = firstY1 - 0, (0, util_1.isLess)(delta, 0) && this._shiftY(arcs, 0, len - 1, -delta);
|
|
268
|
-
for (let i = arcs.length - 1; i >= 0 && arcs[i].getLabelBounds().y2 > plotRect.height; i--) arcs[i].labelVisible = !1;
|
|
269
|
-
} else if ("none" !== labelLayout.strategy) {
|
|
270
|
-
const priorityArcs = arcs.map(((arc, i) => ({
|
|
271
|
-
arc: arc,
|
|
272
|
-
originIndex: i,
|
|
273
|
-
priorityIndex: 0
|
|
274
|
-
})));
|
|
275
|
-
priorityArcs.sort(((a, b) => b.arc.radian - a.arc.radian)), priorityArcs.forEach(((priorityArc, i) => {
|
|
276
|
-
priorityArc.priorityIndex = i, priorityArc.arc.labelVisible = !1;
|
|
277
|
-
}));
|
|
278
|
-
let topLabelIndex = 1 / 0, bottomLabelIndex = -1 / 0;
|
|
279
|
-
for (let i = 0; i < maxLabels && i < arcs.length; i++) {
|
|
280
|
-
this._storeY(arcs);
|
|
281
|
-
const arc = priorityArcs[i].arc;
|
|
282
|
-
this._computeYRange(arc), arc.labelVisible = !0;
|
|
283
|
-
const curY = arc.labelPosition.y, {lastIndex: lastIndex, nextIndex: nextIndex} = this._findNeighborIndex(arcs, priorityArcs[i]), lastArc = arcs[lastIndex], nextArc = arcs[nextIndex];
|
|
284
|
-
if (-1 === lastIndex && -1 !== nextIndex) {
|
|
285
|
-
const nextY = nextArc.labelPosition.y;
|
|
286
|
-
curY > nextY ? arc.labelPosition.y = nextY - nextArc.labelSize.height / 2 - arc.labelSize.height / 2 : this._twoWayShift(arcs, arc, nextArc, nextIndex);
|
|
287
|
-
} else if (-1 !== lastIndex && -1 === nextIndex) {
|
|
288
|
-
const lastY = lastArc.labelPosition.y;
|
|
289
|
-
curY < lastY ? arc.labelPosition.y = lastY + lastArc.labelSize.height / 2 + arc.labelSize.height / 2 : this._twoWayShift(arcs, lastArc, arc, priorityArcs[i].originIndex);
|
|
290
|
-
} else if (-1 !== lastIndex && -1 !== nextIndex) {
|
|
291
|
-
const lastY = lastArc.labelPosition.y, nextY = nextArc.labelPosition.y;
|
|
292
|
-
curY > nextY ? (arc.labelPosition.y = nextY - nextArc.labelSize.height / 2 - arc.labelSize.height / 2,
|
|
293
|
-
this._twoWayShift(arcs, lastArc, arc, priorityArcs[i].originIndex)) : curY < lastY ? (arc.labelPosition.y = lastY + lastArc.labelSize.height / 2 + arc.labelSize.height / 2,
|
|
294
|
-
this._twoWayShift(arcs, arc, nextArc, nextIndex)) : (this._twoWayShift(arcs, lastArc, arc, priorityArcs[i].originIndex),
|
|
295
|
-
this._twoWayShift(arcs, arc, nextArc, nextIndex));
|
|
296
|
-
}
|
|
297
|
-
const nextTopIndex = Math.min(topLabelIndex, priorityArcs[i].originIndex), nextBottomIndex = Math.max(bottomLabelIndex, priorityArcs[i].originIndex);
|
|
298
|
-
let delta;
|
|
299
|
-
if (delta = arcs[nextBottomIndex].getLabelBounds().y2 - plotRect.height, (0, util_1.isGreater)(delta, 0) && this._shiftY(arcs, nextBottomIndex, 0, -delta),
|
|
300
|
-
delta = arcs[nextTopIndex].getLabelBounds().y1 - 0, (0, util_1.isLess)(delta, 0) && this._shiftY(arcs, nextTopIndex, arcs.length - 1, -delta),
|
|
301
|
-
delta = arcs[nextBottomIndex].getLabelBounds().y2 - plotRect.height, (0, util_1.isGreater)(delta, 0)) {
|
|
302
|
-
arc.labelVisible = !1, this._restoreY(arcs);
|
|
303
|
-
break;
|
|
304
|
-
}
|
|
305
|
-
labelLayout.tangentConstraint && !this._checkYRange(arcs) ? (arc.labelVisible = !1,
|
|
306
|
-
this._restoreY(arcs)) : (topLabelIndex = nextTopIndex, bottomLabelIndex = nextBottomIndex);
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
_checkYRange(arcs) {
|
|
311
|
-
for (const arc of arcs) {
|
|
312
|
-
const {labelYRange: labelYRange, labelPosition: labelPosition} = arc;
|
|
313
|
-
if (arc.labelVisible && labelYRange && ((0, util_1.isLess)(labelPosition.y, labelYRange[0]) || (0,
|
|
314
|
-
util_1.isGreater)(labelPosition.y, labelYRange[1]))) return !1;
|
|
315
|
-
}
|
|
316
|
-
return !0;
|
|
317
|
-
}
|
|
318
|
-
_computeYRange(arc) {
|
|
319
|
-
const plotRect = this._getPlotLayout(), radiusRatio = this._series.getRadius(), line1MinLength = this._series.getLabelConfig().line.line1MinLength, {width: width, height: height} = plotRect, radius = this._series.computeRadius(radiusRatio), r = this._computeLayoutRadius(height / 2), cx = Math.abs(arc.center.x - width / 2), cy = arc.center.y - height / 2;
|
|
320
|
-
let a, b, c;
|
|
321
|
-
if ((0, util_1.isClose)(width / 2, cx)) a = 0, b = 1, c = -cy; else if ((0, util_1.isClose)(height / 2, cy)) a = 1,
|
|
322
|
-
b = 0, c = -cx; else {
|
|
323
|
-
const k = -1 / (cy / cx);
|
|
324
|
-
a = k, b = -1, c = cy - k * cx;
|
|
325
|
-
}
|
|
326
|
-
const points = (0, util_1.lineCirclePoints)(a, b, c, line1MinLength + radius - r, 0, r);
|
|
327
|
-
if (points.length < 2) return;
|
|
328
|
-
let min, max;
|
|
329
|
-
points[0].x > points[1].x && points.reverse(), points[0].x < 0 ? (0, util_1.isClose)(points[0].y, points[1].y) ? Math.abs(arc.middleAngle) < Math.PI / 2 ? (min = 0,
|
|
330
|
-
max = points[1].y + height / 2) : (min = points[1].y + height / 2, max = height) : points[0].y < points[1].y ? (min = 0,
|
|
331
|
-
max = points[1].y + height / 2) : (min = points[1].y + height / 2, max = plotRect.height) : (min = Math.min(points[0].y, points[1].y) + height / 2,
|
|
332
|
-
max = Math.max(points[0].y, points[1].y) + height / 2), arc.labelYRange = [ min, max ];
|
|
333
|
-
}
|
|
334
|
-
_storeY(arcs) {
|
|
335
|
-
for (const arc of arcs) arc.labelVisible && (arc.lastLabelY = arc.labelPosition.y);
|
|
336
|
-
}
|
|
337
|
-
_restoreY(arcs) {
|
|
338
|
-
for (const arc of arcs) arc.labelVisible && (arc.labelPosition.y = arc.lastLabelY);
|
|
339
|
-
}
|
|
340
|
-
_findNeighborIndex(arcs, priorityArc) {
|
|
341
|
-
const index = priorityArc.originIndex;
|
|
342
|
-
let lastIndex = -1, nextIndex = -1;
|
|
343
|
-
for (let i = index - 1; i >= 0; i--) if (arcs[i].labelVisible) {
|
|
344
|
-
lastIndex = i;
|
|
345
|
-
break;
|
|
346
|
-
}
|
|
347
|
-
for (let i = index + 1; i < arcs.length; i++) if (arcs[i].labelVisible) {
|
|
348
|
-
nextIndex = i;
|
|
349
|
-
break;
|
|
350
|
-
}
|
|
351
|
-
return {
|
|
352
|
-
lastIndex: lastIndex,
|
|
353
|
-
nextIndex: nextIndex
|
|
354
|
-
};
|
|
355
|
-
}
|
|
356
|
-
_twoWayShift(arcs, lastArc, nextArc, nextIndex) {
|
|
357
|
-
const delta = nextArc.getLabelBounds().y1 - lastArc.getLabelBounds().y2;
|
|
358
|
-
if ((0, util_1.isLess)(delta, 0)) {
|
|
359
|
-
const i = this._shiftY(arcs, nextIndex, arcs.length - 1, -delta);
|
|
360
|
-
this._shiftY(arcs, i, 0, delta / 2);
|
|
361
|
-
}
|
|
362
|
-
}
|
|
363
|
-
_shiftY(arcs, start, end, delta) {
|
|
364
|
-
const direction = start < end ? 1 : -1;
|
|
365
|
-
let index = start;
|
|
366
|
-
for (;-1 !== index; ) {
|
|
367
|
-
arcs[index].labelPosition.y += delta;
|
|
368
|
-
const nextIndex = this._findNextVisibleIndex(arcs, index, end, direction);
|
|
369
|
-
if (nextIndex >= 0 && nextIndex < arcs.length) {
|
|
370
|
-
const {y1: curY1, y2: curY2} = arcs[index].getLabelBounds(), {y1: nextY1, y2: nextY2} = arcs[nextIndex].getLabelBounds();
|
|
371
|
-
if (direction > 0 && curY2 < nextY1 || direction < 0 && curY1 > nextY2) return index;
|
|
372
|
-
}
|
|
373
|
-
index = nextIndex;
|
|
374
|
-
}
|
|
375
|
-
return end;
|
|
376
|
-
}
|
|
377
|
-
_findNextVisibleIndex(arcs, start, end, direction) {
|
|
378
|
-
const diff = (end - start) * direction;
|
|
379
|
-
for (let i = 1; i <= diff; i++) {
|
|
380
|
-
const index = start + i * direction;
|
|
381
|
-
if (arcs[index].labelVisible) return index;
|
|
382
|
-
}
|
|
383
|
-
return -1;
|
|
384
|
-
}
|
|
385
|
-
_computeAlign(arc) {
|
|
386
|
-
var _a, _b, _c, _d, _e, _f;
|
|
387
|
-
const labelConfig = this._series.getLabelConfig(), textAlign = null !== (_b = null === (_a = labelConfig.style) || void 0 === _a ? void 0 : _a.textAlign) && void 0 !== _b ? _b : null === (_c = labelConfig.style) || void 0 === _c ? void 0 : _c.align, layoutAlign = null !== (_e = null === (_d = labelConfig.layout) || void 0 === _d ? void 0 : _d.textAlign) && void 0 !== _e ? _e : null === (_f = labelConfig.layout) || void 0 === _f ? void 0 : _f.align;
|
|
388
|
-
return "inside" !== labelConfig.position ? (0, util_1.isNil)(textAlign) || "auto" === textAlign ? "edge" === layoutAlign ? (0,
|
|
389
|
-
util_1.isQuadrantLeft)(arc.quadrant) ? "left" : "right" : (0, util_1.isQuadrantLeft)(arc.quadrant) ? "right" : "left" : textAlign : (0,
|
|
390
|
-
util_1.isNil)(textAlign) || "auto" === textAlign ? "center" : textAlign;
|
|
391
|
-
}
|
|
392
|
-
_getFormatLabelText(value, limit) {
|
|
393
|
-
var _a;
|
|
394
|
-
const textSpec = null === (_a = this._series.getLabelConfig().style) || void 0 === _a ? void 0 : _a.text, seriesField = this._series.getSeriesField(), angleField = this._series.getAngleField()[0], isInvalidLabel = (0,
|
|
395
|
-
util_1.isNil)(seriesField) || (0, util_1.isNil)(value[seriesField]) || (0, util_1.isNil)(value[angleField]);
|
|
396
|
-
return (0, util_1.isFunction)(textSpec) ? isInvalidLabel ? null : textSpec.call(null, value, {}) : isInvalidLabel ? null : value[seriesField];
|
|
397
|
-
}
|
|
398
|
-
_getMeasureSpec() {
|
|
399
|
-
return Object.assign(Object.assign({}, this._series.getLabelConfig().style), {
|
|
400
|
-
textAlign: "center"
|
|
401
|
-
});
|
|
402
|
-
}
|
|
403
|
-
_measureTextSize(text) {
|
|
404
|
-
const size = this._textMeasure.quickMeasure(text);
|
|
405
|
-
return {
|
|
406
|
-
width: Math.ceil(size.width) + 1,
|
|
407
|
-
height: size.height
|
|
408
|
-
};
|
|
409
|
-
}
|
|
410
|
-
_getPlotLayout() {
|
|
411
|
-
return this._series.getRegion().getLayoutRect();
|
|
412
|
-
}
|
|
413
|
-
}
|
|
414
|
-
|
|
415
|
-
exports.ArcLabelLayout = ArcLabelLayout;
|
|
416
|
-
//# sourceMappingURL=arc-label.js.map
|