@visactor/vchart 1.13.9-alpha.1 → 1.13.9-alpha.11

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.
Files changed (128) hide show
  1. package/build/es5/index.js +1 -1
  2. package/build/index.es.js +335 -337
  3. package/build/index.js +335 -336
  4. package/build/index.min.js +1 -1
  5. package/build/tsconfig.tsbuildinfo +1 -1
  6. package/cjs/chart/base/base-chart.d.ts +8 -1
  7. package/cjs/chart/base/base-chart.js +33 -20
  8. package/cjs/chart/base/base-chart.js.map +1 -1
  9. package/cjs/chart/index.d.ts +1 -1
  10. package/cjs/chart/index.js.map +1 -1
  11. package/cjs/chart/interface/chart.d.ts +8 -1
  12. package/cjs/chart/interface/chart.js.map +1 -1
  13. package/cjs/chart/pictogram/interface.d.ts +1 -1
  14. package/cjs/chart/pictogram/interface.js.map +1 -1
  15. package/cjs/chart/sankey/sankey.js +21 -21
  16. package/cjs/chart/sankey/sankey.js.map +1 -1
  17. package/cjs/compile/mark/compilable-mark.d.ts +1 -0
  18. package/cjs/compile/mark/compilable-mark.js +3 -0
  19. package/cjs/compile/mark/compilable-mark.js.map +1 -1
  20. package/cjs/component/axis/base-axis.js +7 -2
  21. package/cjs/component/axis/base-axis.js.map +1 -1
  22. package/cjs/component/axis/interface/spec.d.ts +7 -2
  23. package/cjs/component/axis/interface/spec.js.map +1 -1
  24. package/cjs/component/data-zoom/data-zoom/interface.d.ts +2 -3
  25. package/cjs/component/data-zoom/data-zoom/interface.js.map +1 -1
  26. package/cjs/component/marker/mark-area/base-mark-area.js +17 -27
  27. package/cjs/component/marker/mark-area/base-mark-area.js.map +1 -1
  28. package/cjs/component/marker/mark-area/interface/theme.d.ts +3 -4
  29. package/cjs/component/marker/mark-area/interface/theme.js.map +1 -1
  30. package/cjs/component/marker/mark-line/base-mark-line.js +20 -31
  31. package/cjs/component/marker/mark-line/base-mark-line.js.map +1 -1
  32. package/cjs/component/marker/mark-line/cartesian-mark-line.js +19 -23
  33. package/cjs/component/marker/mark-line/cartesian-mark-line.js.map +1 -1
  34. package/cjs/component/marker/mark-line/interface/theme.d.ts +3 -4
  35. package/cjs/component/marker/mark-line/interface/theme.js.map +1 -1
  36. package/cjs/component/marker/mark-point/cartesian-mark-point.js +3 -1
  37. package/cjs/component/marker/mark-point/cartesian-mark-point.js.map +1 -1
  38. package/cjs/component/marker/utils.d.ts +12 -0
  39. package/cjs/component/marker/utils.js +22 -7
  40. package/cjs/component/marker/utils.js.map +1 -1
  41. package/cjs/constant/funnel.js +1 -2
  42. package/cjs/constant/sunburst.js +2 -1
  43. package/cjs/core/index.d.ts +1 -1
  44. package/cjs/core/index.js +1 -1
  45. package/cjs/core/index.js.map +1 -1
  46. package/cjs/core/interface.js +1 -2
  47. package/cjs/core/vchart.js +2 -1
  48. package/cjs/data/transforms/pictogram.d.ts +1 -9
  49. package/cjs/data/transforms/pictogram.js +3 -3
  50. package/cjs/data/transforms/pictogram.js.map +1 -1
  51. package/cjs/data/transforms/pie.js +1 -1
  52. package/cjs/data/transforms/pie.js.map +1 -1
  53. package/cjs/index-harmony-simple.js.map +1 -1
  54. package/cjs/index.d.ts +1 -0
  55. package/cjs/index.js +8 -7
  56. package/cjs/index.js.map +1 -1
  57. package/cjs/model/base-model.d.ts +1 -0
  58. package/cjs/model/base-model.js +6 -0
  59. package/cjs/model/base-model.js.map +1 -1
  60. package/cjs/series/bar/bar.js.map +1 -1
  61. package/cjs/series/pictogram/tooltip-helper.d.ts +2 -2
  62. package/cjs/series/pictogram/tooltip-helper.js.map +1 -1
  63. package/cjs/series/pie/pie.js +3 -3
  64. package/cjs/series/pie/pie.js.map +1 -1
  65. package/cjs/typings/visual.d.ts +1 -1
  66. package/cjs/typings/visual.js.map +1 -1
  67. package/esm/chart/base/base-chart.d.ts +8 -1
  68. package/esm/chart/base/base-chart.js +33 -20
  69. package/esm/chart/base/base-chart.js.map +1 -1
  70. package/esm/chart/index.d.ts +1 -1
  71. package/esm/chart/index.js.map +1 -1
  72. package/esm/chart/interface/chart.d.ts +8 -1
  73. package/esm/chart/interface/chart.js.map +1 -1
  74. package/esm/chart/pictogram/interface.d.ts +1 -1
  75. package/esm/chart/pictogram/interface.js.map +1 -1
  76. package/esm/chart/sankey/sankey.js +22 -22
  77. package/esm/chart/sankey/sankey.js.map +1 -1
  78. package/esm/compile/mark/compilable-mark.d.ts +1 -0
  79. package/esm/compile/mark/compilable-mark.js +3 -0
  80. package/esm/compile/mark/compilable-mark.js.map +1 -1
  81. package/esm/component/axis/base-axis.js +7 -2
  82. package/esm/component/axis/base-axis.js.map +1 -1
  83. package/esm/component/axis/interface/spec.d.ts +7 -2
  84. package/esm/component/axis/interface/spec.js.map +1 -1
  85. package/esm/component/data-zoom/data-zoom/interface.d.ts +2 -3
  86. package/esm/component/data-zoom/data-zoom/interface.js.map +1 -1
  87. package/esm/component/marker/mark-area/base-mark-area.js +16 -27
  88. package/esm/component/marker/mark-area/base-mark-area.js.map +1 -1
  89. package/esm/component/marker/mark-area/interface/theme.d.ts +3 -4
  90. package/esm/component/marker/mark-area/interface/theme.js.map +1 -1
  91. package/esm/component/marker/mark-line/base-mark-line.js +19 -30
  92. package/esm/component/marker/mark-line/base-mark-line.js.map +1 -1
  93. package/esm/component/marker/mark-line/cartesian-mark-line.js +19 -23
  94. package/esm/component/marker/mark-line/cartesian-mark-line.js.map +1 -1
  95. package/esm/component/marker/mark-line/interface/theme.d.ts +3 -4
  96. package/esm/component/marker/mark-line/interface/theme.js.map +1 -1
  97. package/esm/component/marker/mark-point/cartesian-mark-point.js +1 -1
  98. package/esm/component/marker/mark-point/cartesian-mark-point.js.map +1 -1
  99. package/esm/component/marker/utils.d.ts +12 -0
  100. package/esm/component/marker/utils.js +19 -4
  101. package/esm/component/marker/utils.js.map +1 -1
  102. package/esm/constant/funnel.js +1 -2
  103. package/esm/constant/sunburst.js +2 -1
  104. package/esm/core/index.d.ts +1 -1
  105. package/esm/core/index.js +1 -1
  106. package/esm/core/index.js.map +1 -1
  107. package/esm/core/interface.js +1 -2
  108. package/esm/core/vchart.js +2 -1
  109. package/esm/data/transforms/pictogram.d.ts +1 -9
  110. package/esm/data/transforms/pictogram.js +3 -3
  111. package/esm/data/transforms/pictogram.js.map +1 -1
  112. package/esm/data/transforms/pie.js +1 -1
  113. package/esm/data/transforms/pie.js.map +1 -1
  114. package/esm/index-harmony-simple.js.map +1 -1
  115. package/esm/index.d.ts +1 -0
  116. package/esm/index.js +2 -0
  117. package/esm/index.js.map +1 -1
  118. package/esm/model/base-model.d.ts +1 -0
  119. package/esm/model/base-model.js +6 -0
  120. package/esm/model/base-model.js.map +1 -1
  121. package/esm/series/bar/bar.js.map +1 -1
  122. package/esm/series/pictogram/tooltip-helper.d.ts +2 -2
  123. package/esm/series/pictogram/tooltip-helper.js.map +1 -1
  124. package/esm/series/pie/pie.js +4 -4
  125. package/esm/series/pie/pie.js.map +1 -1
  126. package/esm/typings/visual.d.ts +1 -1
  127. package/esm/typings/visual.js.map +1 -1
  128. package/package.json +7 -7
package/build/index.es.js CHANGED
@@ -39824,26 +39824,17 @@ function commonLineClipIn(line, label, duration, delay, easing) {
39824
39824
  l.animate().wait(delay + startSymbolDuration + index * stepDuration).to({
39825
39825
  clipRange: 1
39826
39826
  }, stepDuration, easing);
39827
- }), graphicFadeIn(line.endSymbol, delay + startSymbolDuration + lineDuration, endSymbolDuration, easing), array(label).forEach(labelNode => {
39828
- const delayTime = delay + startSymbolDuration + lineDuration + endSymbolDuration;
39829
- graphicFadeIn(labelNode.getTextShape(), delayTime, labelDuration, easing), graphicFadeIn(labelNode.getBgRect(), delayTime, labelDuration, easing);
39830
- });
39827
+ }), graphicFadeIn(line.endSymbol, delay + startSymbolDuration + lineDuration, endSymbolDuration, easing), graphicFadeIn(label.getTextShape(), delay + startSymbolDuration + lineDuration + endSymbolDuration, labelDuration, easing), graphicFadeIn(label.getBgRect(), delay + startSymbolDuration + lineDuration + endSymbolDuration, labelDuration, easing);
39831
39828
  }
39832
39829
 
39833
39830
  function commonLineFadeIn(line, label, duration, delay, easing) {
39834
- segmentFadeIn(line, delay, duration, easing), array(label).forEach(labelNode => {
39835
- tagFadeIn(labelNode, delay, duration, easing);
39836
- });
39831
+ segmentFadeIn(line, delay, duration, easing), tagFadeIn(label, delay, duration, easing);
39837
39832
  }
39838
39833
  function areaFadeIn(area, label, duration, delay, easing) {
39839
- graphicFadeIn(area, delay, duration, easing), array(label).forEach(labelNode => {
39840
- tagFadeIn(labelNode, delay, duration, easing);
39841
- });
39834
+ graphicFadeIn(area, delay, duration, easing), tagFadeIn(label, delay, duration, easing);
39842
39835
  }
39843
39836
  function arcAreaFadeIn(area, label, duration, delay, easing) {
39844
- graphicFadeIn(area, delay, duration, easing), array(label).forEach(labelNode => {
39845
- tagFadeIn(labelNode, delay, duration, easing);
39846
- });
39837
+ graphicFadeIn(area, delay, duration, easing), tagFadeIn(label, delay, duration, easing);
39847
39838
  }
39848
39839
  function pointFadeIn(itemLine, decorativeLine, item, duration, delay, easing) {
39849
39840
  var _a;
@@ -39851,19 +39842,13 @@ function pointFadeIn(itemLine, decorativeLine, item, duration, delay, easing) {
39851
39842
  }
39852
39843
 
39853
39844
  function commonLineFadeOut(line, label, duration, delay, easing) {
39854
- segmentFadeOut(line, delay, duration, easing), array(label).forEach(labelNode => {
39855
- tagFadeOut(labelNode, delay, duration, easing);
39856
- });
39845
+ segmentFadeOut(line, delay, duration, easing), tagFadeOut(label, delay, duration, easing);
39857
39846
  }
39858
39847
  function areaFadeOut(area, label, duration, delay, easing) {
39859
- graphicFadeOut(area, delay, duration, easing), array(label).forEach(labelNode => {
39860
- tagFadeOut(labelNode, delay, duration, easing);
39861
- });
39848
+ graphicFadeOut(area, delay, duration, easing), tagFadeOut(label, delay, duration, easing);
39862
39849
  }
39863
39850
  function arcAreaFadeOut(area, label, duration, delay, easing) {
39864
- graphicFadeOut(area, delay, duration, easing), array(label).forEach(labelNode => {
39865
- tagFadeOut(labelNode, delay, duration, easing);
39866
- });
39851
+ graphicFadeOut(area, delay, duration, easing), tagFadeOut(label, delay, duration, easing);
39867
39852
  }
39868
39853
  function pointFadeOut(itemLine, decorativeLine, item, duration, delay, easing) {
39869
39854
  var _a;
@@ -40035,57 +40020,6 @@ const DefaultExitMarkerAnimation = {
40035
40020
  delay: 0
40036
40021
  };
40037
40022
 
40038
- class MarkLabelMixin {
40039
- getLabel() {
40040
- return this._label;
40041
- }
40042
- _addMarkLabels(container, labelName, defaultLabelAttrs) {
40043
- const {
40044
- label: label,
40045
- state: state
40046
- } = this.attribute,
40047
- labelStates = array(null == state ? void 0 : state.label),
40048
- labelBackgroundStates = array(null == state ? void 0 : state.labelBackground),
40049
- labelShapes = array(label).map((labelAttrs, index) => {
40050
- var _a, _b;
40051
- const finalLabelAttrs = merge$1({}, defaultLabelAttrs, labelAttrs),
40052
- markLabel = new Tag(Object.assign(Object.assign({}, finalLabelAttrs), {
40053
- state: {
40054
- panel: merge$1({}, DEFAULT_STATES$2, null !== (_a = labelBackgroundStates[index]) && void 0 !== _a ? _a : last(labelBackgroundStates)),
40055
- text: merge$1({}, DEFAULT_STATES$2, null !== (_b = labelStates[index]) && void 0 !== _b ? _b : last(labelStates))
40056
- }
40057
- }));
40058
- return markLabel.name = labelName, container.add(markLabel), this.setLabelPos(markLabel, finalLabelAttrs), markLabel;
40059
- });
40060
- this._label = 1 === array(labelShapes).length ? labelShapes[0] : labelShapes;
40061
- }
40062
- _updateMarkLabels(defaultLabelAttrs) {
40063
- const {
40064
- label: label,
40065
- state: state
40066
- } = this.attribute,
40067
- labelShapes = array(this._label),
40068
- labelStates = array(null == state ? void 0 : state.label),
40069
- labelBackgroundStates = array(null == state ? void 0 : state.labelBackground);
40070
- if (labelShapes.length) {
40071
- const labels = array(label);
40072
- labelShapes.forEach((labelItem, index) => {
40073
- var _a, _b;
40074
- const finalLabelAttrs = merge$1({}, defaultLabelAttrs, labels[index]);
40075
- labelItem.setAttributes(Object.assign(Object.assign({
40076
- dx: 0,
40077
- dy: 0
40078
- }, finalLabelAttrs), {
40079
- state: {
40080
- panel: merge$1({}, DEFAULT_STATES$2, null !== (_a = labelBackgroundStates[index]) && void 0 !== _a ? _a : last(labelBackgroundStates)),
40081
- text: merge$1({}, DEFAULT_STATES$2, null !== (_b = labelStates[index]) && void 0 !== _b ? _b : last(labelStates))
40082
- }
40083
- })), this.setLabelPos(labelItem, finalLabelAttrs);
40084
- });
40085
- }
40086
- }
40087
- }
40088
-
40089
40023
  class MarkCommonLine extends Marker {
40090
40024
  constructor() {
40091
40025
  super(...arguments), this.name = "markCommonLine", this.defaultUpdateAnimation = DefaultUpdateMarkLineAnimation, this.defaultExitAnimation = DefaultExitMarkerAnimation;
@@ -40093,20 +40027,24 @@ class MarkCommonLine extends Marker {
40093
40027
  getLine() {
40094
40028
  return this._line;
40095
40029
  }
40096
- setLabelPos(labelNode, labelAttrs) {
40030
+ getLabel() {
40031
+ return this._label;
40032
+ }
40033
+ setLabelPos() {
40097
40034
  const {
40035
+ label = {},
40098
40036
  limitRect: limitRect
40099
40037
  } = this.attribute,
40100
40038
  {
40101
40039
  position: position,
40102
40040
  confine: confine,
40103
40041
  autoRotate: autoRotate
40104
- } = labelAttrs,
40105
- labelPoint = this.getPointAttrByPosition(position, labelAttrs),
40042
+ } = label,
40043
+ labelPoint = this.getPointAttrByPosition(position),
40106
40044
  labelAngle = position.toString().toLocaleLowerCase().includes("start") ? this._line.getStartAngle() || 0 : this._line.getEndAngle() || 0;
40107
- if (labelNode.setAttributes(Object.assign(Object.assign({}, labelPoint.position), {
40108
- angle: autoRotate ? this.getRotateByAngle(labelPoint.angle, labelAttrs) : 0,
40109
- textStyle: Object.assign(Object.assign({}, this.getTextStyle(position, labelAngle, autoRotate)), labelAttrs.textStyle)
40045
+ if (this._label.setAttributes(Object.assign(Object.assign({}, labelPoint.position), {
40046
+ angle: autoRotate ? this.getRotateByAngle(labelPoint.angle) : 0,
40047
+ textStyle: Object.assign(Object.assign({}, this.getTextStyle(position, labelAngle, autoRotate)), label.textStyle)
40110
40048
  })), limitRect && confine) {
40111
40049
  const {
40112
40050
  x: x,
@@ -40114,7 +40052,7 @@ class MarkCommonLine extends Marker {
40114
40052
  width: width,
40115
40053
  height: height
40116
40054
  } = limitRect;
40117
- limitShapeInBounds(labelNode, {
40055
+ limitShapeInBounds(this._label, {
40118
40056
  x1: x,
40119
40057
  y1: y,
40120
40058
  x2: x + width,
@@ -40123,14 +40061,36 @@ class MarkCommonLine extends Marker {
40123
40061
  }
40124
40062
  }
40125
40063
  initMarker(container) {
40126
- const line = this.createSegment();
40127
- line.name = "mark-common-line-line", this._line = line, container.add(line), this.addMarkLineLabels(container);
40064
+ const {
40065
+ label: label,
40066
+ state: state
40067
+ } = this.attribute,
40068
+ line = this.createSegment();
40069
+ line.name = "mark-common-line-line", this._line = line, container.add(line);
40070
+ const markLabel = new Tag(Object.assign(Object.assign({}, label), {
40071
+ state: {
40072
+ panel: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.labelBackground),
40073
+ text: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.label)
40074
+ }
40075
+ }));
40076
+ markLabel.name = "mark-common-line-label", this._label = markLabel, container.add(markLabel), this.setLabelPos();
40128
40077
  }
40129
40078
  updateMarker() {
40130
- this.setLineAttributes(), this.updateMarkLineLabels();
40079
+ const {
40080
+ label: label,
40081
+ state: state
40082
+ } = this.attribute;
40083
+ this.setLineAttributes(), this._label && (this._label.setAttributes(Object.assign(Object.assign({
40084
+ dx: 0,
40085
+ dy: 0
40086
+ }, label), {
40087
+ state: {
40088
+ panel: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.labelBackground),
40089
+ text: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.label)
40090
+ }
40091
+ })), this.setLabelPos());
40131
40092
  }
40132
40093
  }
40133
- mixin(MarkCommonLine, MarkLabelMixin);
40134
40094
 
40135
40095
  const FUZZY_EQUAL_DELTA = .001;
40136
40096
  const DEFAULT_MARK_LINE_THEME = {
@@ -40319,7 +40279,6 @@ const DEFAULT_MARK_ARC_LINE_THEME = {
40319
40279
  lineWidth: 0
40320
40280
  },
40321
40281
  label: {
40322
- autoRotate: !0,
40323
40282
  position: IMarkCommonArcLabelPosition.arcOuterMiddle,
40324
40283
  refX: 0,
40325
40284
  refY: 0,
@@ -40374,7 +40333,6 @@ const DEFAULT_MARK_AREA_THEME = {
40374
40333
  const DEFAULT_MARK_ARC_AREA_THEME = {
40375
40334
  interactive: !0,
40376
40335
  label: {
40377
- autoRotate: !0,
40378
40336
  position: IMarkCommonArcLabelPosition.arcOuterMiddle,
40379
40337
  textStyle: {
40380
40338
  fill: "#fff",
@@ -40630,12 +40588,15 @@ class MarkLine extends MarkCommonLine {
40630
40588
  constructor(attributes, options) {
40631
40589
  super((null == options ? void 0 : options.skipDefault) ? attributes : merge$1({}, MarkLine.defaultAttributes, attributes)), this.name = "markLine";
40632
40590
  }
40633
- getPointAttrByPosition(position, labelAttrs) {
40591
+ getPointAttrByPosition(position) {
40634
40592
  var _a;
40635
40593
  const {
40594
+ label = {}
40595
+ } = this.attribute,
40596
+ {
40636
40597
  refX = 0,
40637
40598
  refY = 0
40638
- } = labelAttrs,
40599
+ } = label,
40639
40600
  points = this._line.getMainSegmentPoints(),
40640
40601
  lineEndAngle = null !== (_a = this._line.getEndAngle()) && void 0 !== _a ? _a : 0,
40641
40602
  labelAngle = (lineEndAngle),
@@ -40661,9 +40622,9 @@ class MarkLine extends MarkCommonLine {
40661
40622
  angle: labelAngle
40662
40623
  };
40663
40624
  }
40664
- getRotateByAngle(angle, labelAttrs) {
40625
+ getRotateByAngle(angle) {
40665
40626
  var _a;
40666
- return (isPostiveXAxis(angle) ? angle : angle - Math.PI) + (null !== (_a = labelAttrs.refAngle) && void 0 !== _a ? _a : 0);
40627
+ return (isPostiveXAxis(angle) ? angle : angle - Math.PI) + (null !== (_a = this.attribute.label.refAngle) && void 0 !== _a ? _a : 0);
40667
40628
  }
40668
40629
  getTextStyle(position, labelAngle, autoRotate) {
40669
40630
  return fuzzyEqualNumber(Math.abs(labelAngle), Math.PI / 2, FUZZY_EQUAL_DELTA) || fuzzyEqualNumber(Math.abs(labelAngle), 3 * Math.PI / 2, FUZZY_EQUAL_DELTA) ? getTextAlignAttrOfVerticalDir(autoRotate, labelAngle, position) : isPostiveXAxis(labelAngle) ? DEFAULT_CARTESIAN_MARK_LINE_TEXT_STYLE_MAP.postiveXAxis[position] : DEFAULT_CARTESIAN_MARK_LINE_TEXT_STYLE_MAP.negativeXAxis[position];
@@ -40729,12 +40690,6 @@ class MarkLine extends MarkCommonLine {
40729
40690
  });else if (!isValidNumber$1(point.x) || !isValidNumber$1(point.y)) return void (validFlag = !1);
40730
40691
  }), validFlag;
40731
40692
  }
40732
- addMarkLineLabels(container) {
40733
- this._addMarkLabels(container, "mark-common-line-label", MarkLine.defaultAttributes.label);
40734
- }
40735
- updateMarkLineLabels() {
40736
- this._updateMarkLabels(MarkLine.defaultAttributes.label);
40737
- }
40738
40693
  }
40739
40694
  MarkLine.defaultAttributes = DEFAULT_MARK_LINE_THEME;
40740
40695
 
@@ -40749,6 +40704,9 @@ class MarkArea extends Marker {
40749
40704
  getArea() {
40750
40705
  return this._area;
40751
40706
  }
40707
+ getLabel() {
40708
+ return this._label;
40709
+ }
40752
40710
  constructor(attributes, options) {
40753
40711
  super((null == options ? void 0 : options.skipDefault) ? attributes : merge$1({}, MarkArea.defaultAttributes, attributes)), this.name = "markArea", this.defaultUpdateAnimation = DefaultUpdateMarkAreaAnimation, this.defaultExitAnimation = DefaultExitMarkerAnimation;
40754
40712
  }
@@ -40765,21 +40723,24 @@ class MarkArea extends Marker {
40765
40723
  };
40766
40724
  return (position.includes("left") || position.includes("Left")) && (result.x = x1), (position.includes("right") || position.includes("Right")) && (result.x = x2), (position.includes("top") || position.includes("Top")) && (result.y = y1), (position.includes("bottom") || position.includes("Bottom")) && (result.y = y2), result;
40767
40725
  }
40768
- setLabelPos(labelNode, labelAttrs) {
40726
+ setLabelPos() {
40769
40727
  var _a;
40770
- if (this._area) {
40771
- const labelPosition = null !== (_a = labelAttrs.position) && void 0 !== _a ? _a : "middle",
40728
+ if (this._label && this._area) {
40729
+ const {
40730
+ label = {}
40731
+ } = this.attribute,
40732
+ labelPosition = null !== (_a = label.position) && void 0 !== _a ? _a : "middle",
40772
40733
  labelPoint = this.getPointAttrByPosition(labelPosition);
40773
- if (labelNode.setAttributes(Object.assign(Object.assign({}, labelPoint), {
40774
- textStyle: Object.assign(Object.assign({}, DEFAULT_CARTESIAN_MARK_AREA_TEXT_STYLE_MAP[labelPosition]), labelAttrs.textStyle)
40775
- })), this.attribute.limitRect && labelAttrs.confine) {
40734
+ if (this._label.setAttributes(Object.assign(Object.assign({}, labelPoint), {
40735
+ textStyle: Object.assign(Object.assign({}, DEFAULT_CARTESIAN_MARK_AREA_TEXT_STYLE_MAP[labelPosition]), label.textStyle)
40736
+ })), this.attribute.limitRect && label.confine) {
40776
40737
  const {
40777
40738
  x: x,
40778
40739
  y: y,
40779
40740
  width: width,
40780
40741
  height: height
40781
40742
  } = this.attribute.limitRect;
40782
- limitShapeInBounds(labelNode, {
40743
+ limitShapeInBounds(this._label, {
40783
40744
  x1: x,
40784
40745
  y1: y,
40785
40746
  x2: x + width,
@@ -40791,23 +40752,40 @@ class MarkArea extends Marker {
40791
40752
  initMarker(container) {
40792
40753
  const {
40793
40754
  points: points,
40755
+ label: label,
40794
40756
  areaStyle: areaStyle,
40795
40757
  state: state
40796
40758
  } = this.attribute,
40797
40759
  area = graphicCreator.polygon(Object.assign({
40798
40760
  points: points
40799
40761
  }, areaStyle));
40800
- area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area), area.name = "mark-area-polygon", this._area = area, container.add(area), this._addMarkLabels(container, "mark-area-label", MarkArea.defaultAttributes.label);
40762
+ area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area), area.name = "mark-area-polygon", this._area = area, container.add(area);
40763
+ const markLabel = new Tag(Object.assign(Object.assign({}, label), {
40764
+ state: {
40765
+ panel: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.labelBackground),
40766
+ text: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.label)
40767
+ }
40768
+ }));
40769
+ markLabel.name = "mark-area-label", this._label = markLabel, container.add(markLabel), this.setLabelPos();
40801
40770
  }
40802
40771
  updateMarker() {
40803
40772
  const {
40804
40773
  points: points,
40774
+ label: label,
40805
40775
  areaStyle: areaStyle,
40806
40776
  state: state
40807
40777
  } = this.attribute;
40808
40778
  this._area && (this._area.setAttributes(Object.assign({
40809
40779
  points: points
40810
- }, areaStyle)), this._area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area)), this._updateMarkLabels(MarkArea.defaultAttributes.label);
40780
+ }, areaStyle)), this._area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area)), this._label && this._label.setAttributes(Object.assign(Object.assign({
40781
+ dx: 0,
40782
+ dy: 0
40783
+ }, label), {
40784
+ state: {
40785
+ panel: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.labelBackground),
40786
+ text: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.label)
40787
+ }
40788
+ })), this.setLabelPos();
40811
40789
  }
40812
40790
  isValidPoints() {
40813
40791
  const {
@@ -40820,7 +40798,7 @@ class MarkArea extends Marker {
40820
40798
  }), validFlag;
40821
40799
  }
40822
40800
  }
40823
- MarkArea.defaultAttributes = DEFAULT_MARK_AREA_THEME, mixin(MarkArea, MarkLabelMixin);
40801
+ MarkArea.defaultAttributes = DEFAULT_MARK_AREA_THEME;
40824
40802
 
40825
40803
  loadMarkArcLineComponent();
40826
40804
  function registerMarkArcLineAnimate() {
@@ -40831,19 +40809,24 @@ class MarkArcLine extends MarkCommonLine {
40831
40809
  MarkArcLine._animate && this._animationConfig && MarkArcLine._animate(this._line, this._label, this._animationConfig, state);
40832
40810
  }
40833
40811
  constructor(attributes, options) {
40834
- super((null == options ? void 0 : options.skipDefault) ? attributes : merge$1({}, MarkArcLine.defaultAttributes, attributes)), this.name = "markArcLine";
40812
+ super((null == options ? void 0 : options.skipDefault) ? attributes : merge$1({}, MarkArcLine.defaultAttributes, attributes, {
40813
+ label: {
40814
+ autoRotate: !0
40815
+ }
40816
+ })), this.name = "markArcLine";
40835
40817
  }
40836
- getPointAttrByPosition(direction, labelAttrs) {
40818
+ getPointAttrByPosition(direction) {
40837
40819
  const {
40838
40820
  center: center,
40839
40821
  radius: radius,
40840
40822
  startAngle: startAngle,
40841
- endAngle: endAngle
40823
+ endAngle: endAngle,
40824
+ label: label
40842
40825
  } = this.attribute,
40843
40826
  {
40844
40827
  refX = 0,
40845
40828
  refY = 0
40846
- } = labelAttrs;
40829
+ } = label;
40847
40830
  let angle;
40848
40831
  switch (direction) {
40849
40832
  case IMarkCommonArcLabelPosition.arcInnerStart:
@@ -40873,9 +40856,9 @@ class MarkArcLine extends MarkCommonLine {
40873
40856
  getTextStyle(position) {
40874
40857
  return DEFAULT_POLAR_MARKER_TEXT_STYLE_MAP[position];
40875
40858
  }
40876
- getRotateByAngle(angle, labelAttrs) {
40859
+ getRotateByAngle(angle) {
40877
40860
  var _a;
40878
- return angle - Math.PI / 2 + (null !== (_a = labelAttrs.refAngle) && void 0 !== _a ? _a : 0);
40861
+ return angle - Math.PI / 2 + (null !== (_a = this.attribute.label.refAngle) && void 0 !== _a ? _a : 0);
40879
40862
  }
40880
40863
  createSegment() {
40881
40864
  const {
@@ -40932,12 +40915,6 @@ class MarkArcLine extends MarkCommonLine {
40932
40915
  isValidPoints() {
40933
40916
  return !0;
40934
40917
  }
40935
- addMarkLineLabels(container) {
40936
- this._addMarkLabels(container, "mark-common-line-label", MarkArcLine.defaultAttributes.label);
40937
- }
40938
- updateMarkLineLabels() {
40939
- this._updateMarkLabels(MarkArcLine.defaultAttributes.label);
40940
- }
40941
40918
  }
40942
40919
  MarkArcLine.defaultAttributes = DEFAULT_MARK_ARC_LINE_THEME;
40943
40920
 
@@ -40952,21 +40929,29 @@ class MarkArcArea extends Marker {
40952
40929
  getArea() {
40953
40930
  return this._area;
40954
40931
  }
40932
+ getLabel() {
40933
+ return this._label;
40934
+ }
40955
40935
  constructor(attributes, options) {
40956
- super((null == options ? void 0 : options.skipDefault) ? attributes : merge$1({}, MarkArcArea.defaultAttributes, attributes)), this.name = "markArcArea", this.defaultUpdateAnimation = DefaultUpdateMarkAreaAnimation, this.defaultExitAnimation = DefaultExitMarkerAnimation;
40936
+ super((null == options ? void 0 : options.skipDefault) ? attributes : merge$1({}, MarkArcArea.defaultAttributes, attributes, {
40937
+ label: {
40938
+ autoRotate: !0
40939
+ }
40940
+ })), this.name = "markArcArea", this.defaultUpdateAnimation = DefaultUpdateMarkAreaAnimation, this.defaultExitAnimation = DefaultExitMarkerAnimation;
40957
40941
  }
40958
- getPointAttrByPosition(position, labelAttrs) {
40942
+ getPointAttrByPosition(position) {
40959
40943
  const {
40960
40944
  center: center,
40961
40945
  innerRadius: innerRadius,
40962
40946
  outerRadius: outerRadius,
40963
40947
  startAngle: startAngle,
40964
- endAngle: endAngle
40948
+ endAngle: endAngle,
40949
+ label: label
40965
40950
  } = this.attribute,
40966
40951
  {
40967
40952
  refX = 0,
40968
40953
  refY = 0
40969
- } = labelAttrs;
40954
+ } = label;
40970
40955
  let radius, angle;
40971
40956
  switch (position) {
40972
40957
  case IMarkCommonArcLabelPosition.center:
@@ -41001,25 +40986,28 @@ class MarkArcArea extends Marker {
41001
40986
  angle: angle
41002
40987
  };
41003
40988
  }
41004
- setLabelPos(labelNode, labelAttrs) {
40989
+ setLabelPos() {
41005
40990
  var _a;
41006
- if (this._area) {
40991
+ if (this._label && this._area) {
41007
40992
  const {
40993
+ label = {}
40994
+ } = this.attribute,
40995
+ {
41008
40996
  position: labelPosition = "arcInnerMiddle",
41009
40997
  autoRotate: autoRotate
41010
- } = labelAttrs,
41011
- labelAttr = this.getPointAttrByPosition(labelPosition, labelAttrs);
41012
- if (labelNode.setAttributes(Object.assign(Object.assign({}, labelAttr.position), {
41013
- angle: autoRotate ? labelAttr.angle - Math.PI / 2 + (null !== (_a = labelAttrs.refAngle) && void 0 !== _a ? _a : 0) : 0,
41014
- textStyle: Object.assign(Object.assign({}, DEFAULT_POLAR_MARKER_TEXT_STYLE_MAP[labelPosition]), labelAttrs.textStyle)
41015
- })), this.attribute.limitRect && labelAttrs.confine) {
40998
+ } = label,
40999
+ labelAttr = this.getPointAttrByPosition(labelPosition);
41000
+ if (this._label.setAttributes(Object.assign(Object.assign({}, labelAttr.position), {
41001
+ angle: autoRotate ? labelAttr.angle - Math.PI / 2 + (null !== (_a = label.refAngle) && void 0 !== _a ? _a : 0) : 0,
41002
+ textStyle: Object.assign(Object.assign({}, DEFAULT_POLAR_MARKER_TEXT_STYLE_MAP[labelPosition]), label.textStyle)
41003
+ })), this.attribute.limitRect && label.confine) {
41016
41004
  const {
41017
41005
  x: x,
41018
41006
  y: y,
41019
41007
  width: width,
41020
41008
  height: height
41021
41009
  } = this.attribute.limitRect;
41022
- limitShapeInBounds(labelNode, {
41010
+ limitShapeInBounds(this._label, {
41023
41011
  x1: x,
41024
41012
  y1: y,
41025
41013
  x2: x + width,
@@ -41036,6 +41024,7 @@ class MarkArcArea extends Marker {
41036
41024
  startAngle: startAngle,
41037
41025
  endAngle: endAngle,
41038
41026
  areaStyle: areaStyle,
41027
+ label: label,
41039
41028
  state: state
41040
41029
  } = this.attribute,
41041
41030
  area = graphicCreator.arc(Object.assign({
@@ -41046,7 +41035,14 @@ class MarkArcArea extends Marker {
41046
41035
  startAngle: startAngle,
41047
41036
  endAngle: endAngle
41048
41037
  }, areaStyle));
41049
- area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area), area.name = "polar-mark-area-area", this._area = area, container.add(area), this._addMarkLabels(container, "mark-area-label", MarkArcArea.defaultAttributes.label);
41038
+ area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area), area.name = "polar-mark-area-area", this._area = area, container.add(area);
41039
+ const markLabel = new Tag(Object.assign(Object.assign({}, label), {
41040
+ state: {
41041
+ panel: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.labelBackground),
41042
+ text: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.label)
41043
+ }
41044
+ }));
41045
+ markLabel.name = "mark-area-label", this._label = markLabel, container.add(markLabel), this.setLabelPos();
41050
41046
  }
41051
41047
  updateMarker() {
41052
41048
  const {
@@ -41066,13 +41062,21 @@ class MarkArcArea extends Marker {
41066
41062
  outerRadius: outerRadius,
41067
41063
  startAngle: startAngle,
41068
41064
  endAngle: endAngle
41069
- }, areaStyle)), this._area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area)), this._updateMarkLabels(MarkArcArea.defaultAttributes.label);
41065
+ }, areaStyle)), this._area.states = merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.area)), this._label && (this._label.setAttributes(Object.assign(Object.assign({
41066
+ dx: 0,
41067
+ dy: 0
41068
+ }, label), {
41069
+ state: {
41070
+ panel: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.labelBackground),
41071
+ text: merge$1({}, DEFAULT_STATES$2, null == state ? void 0 : state.label)
41072
+ }
41073
+ })), this.setLabelPos());
41070
41074
  }
41071
41075
  isValidPoints() {
41072
41076
  return !0;
41073
41077
  }
41074
41078
  }
41075
- MarkArcArea.defaultAttributes = DEFAULT_MARK_ARC_AREA_THEME, mixin(MarkArcArea, MarkLabelMixin);
41079
+ MarkArcArea.defaultAttributes = DEFAULT_MARK_ARC_AREA_THEME;
41076
41080
 
41077
41081
  loadMarkPointComponent();
41078
41082
  function registerMarkPointAnimate() {
@@ -59551,6 +59555,9 @@ class BaseModel extends CompilableBase {
59551
59555
  }
59552
59556
  beforeRelease() {
59553
59557
  }
59558
+ clear() {
59559
+ this.getMarks().forEach(m => { var _a; return (_a = m.clear) === null || _a === void 0 ? void 0 : _a.call(m); });
59560
+ }
59554
59561
  release() {
59555
59562
  var _a;
59556
59563
  this._releaseEvent();
@@ -61703,6 +61710,9 @@ class CompilableMark extends GrammarItem {
61703
61710
  }
61704
61711
  return undefined;
61705
61712
  }
61713
+ clear() {
61714
+ this._event.off(HOOK_EVENT.AFTER_DO_RENDER);
61715
+ }
61706
61716
  release() {
61707
61717
  super.release();
61708
61718
  this.state.release();
@@ -63652,7 +63662,7 @@ const registerVChartCore = () => {
63652
63662
  };
63653
63663
  registerVChartCore();
63654
63664
 
63655
- const version = "1.13.9-alpha.1";
63665
+ const version = "1.13.9-alpha.11";
63656
63666
 
63657
63667
  const addVChartProperty = (data, op) => {
63658
63668
  const context = op.beforeCall();
@@ -67799,6 +67809,9 @@ class AxisComponent extends BaseComponent {
67799
67809
  if (spec.label.state) {
67800
67810
  axisAttrs.label.state = transformAxisLabelStateStyle(spec.label.state);
67801
67811
  }
67812
+ if (isFunction$1(spec.label.dataFilter)) {
67813
+ axisAttrs.label.dataFilter = (data, layer) => spec.label.dataFilter(data, layer, { vchart: this._option.globalInstance });
67814
+ }
67802
67815
  }
67803
67816
  else {
67804
67817
  axisAttrs.label = {
@@ -67811,7 +67824,9 @@ class AxisComponent extends BaseComponent {
67811
67824
  length: spec.tick.tickSize,
67812
67825
  inside: spec.tick.inside,
67813
67826
  alignWithLabel: spec.tick.alignWithLabel,
67814
- dataFilter: spec.tick.dataFilter
67827
+ dataFilter: isFunction$1(spec.tick.dataFilter)
67828
+ ? (data) => spec.tick.dataFilter(data, { vchart: this._option.globalInstance })
67829
+ : undefined
67815
67830
  };
67816
67831
  if (spec.tick.style) {
67817
67832
  axisAttrs.tick.style = isFunction$1(spec.tick.style)
@@ -71064,58 +71079,83 @@ class BaseChart extends CompilableBase {
71064
71079
  }
71065
71080
  });
71066
71081
  }
71067
- _setStateInDatum(stateKey, checkReverse, datum, filter, region) {
71082
+ filterGraphicsByDatum(datum, opt = {}) {
71083
+ var _a;
71068
71084
  datum = datum ? array(datum) : null;
71069
71085
  const keys = !datum ? null : Object.keys(datum[0]);
71070
- this.getRegionsInQuerier(region).forEach(r => {
71071
- if (!datum) {
71072
- r.interaction.clearEventElement(stateKey, true);
71073
- return;
71074
- }
71075
- r.getSeries().forEach(s => {
71076
- s.getMarks().forEach(m => {
71077
- if (!m.getProduct()) {
71078
- return;
71079
- }
71080
- if (!filter || (isFunction$1(filter) && filter(s, m))) {
71081
- const isCollect = m.getProduct().isCollectionMark();
71082
- const elements = m.getProduct().elements;
71083
- let pickElements = [];
71084
- if (isCollect) {
71085
- pickElements = elements.filter(e => {
71086
- const elDatum = e.getDatum();
71087
- datum.every((d, index) => keys.every(k => d[k] == elDatum[index][k]));
71088
- });
71086
+ const allElements = [];
71087
+ const getDatumOfElement = (_a = opt.getDatum) !== null && _a !== void 0 ? _a : ((el) => el.getDatum());
71088
+ this.getRegionsInQuerier(opt.region).forEach(r => {
71089
+ const pickElements = [];
71090
+ datum &&
71091
+ r.getSeries().forEach(s => {
71092
+ s.getMarks().forEach(m => {
71093
+ if (!m.getProduct()) {
71094
+ return;
71089
71095
  }
71090
- else {
71091
- if (datum.length > 1) {
71092
- const datumTemp = datum.slice();
71093
- pickElements = elements.filter(e => {
71094
- if (datumTemp.length === 0) {
71095
- return false;
71096
- }
71097
- const elDatum = e.getDatum();
71098
- const index = datumTemp.findIndex(d => keys.every(k => d[k] == elDatum[k]));
71099
- if (index >= 0) {
71100
- datumTemp.splice(index, 1);
71101
- return true;
71096
+ if (!opt.filter || (isFunction$1(opt.filter) && opt.filter(s, m))) {
71097
+ const isCollect = m.getProduct().isCollectionMark();
71098
+ const elements = m.getProduct().elements;
71099
+ if (isCollect) {
71100
+ elements.filter(e => {
71101
+ const elDatum = getDatumOfElement(e, m, s, r);
71102
+ const isPick = elDatum && datum.every((d, index) => keys.every(k => d[k] == elDatum[index][k]));
71103
+ if (isPick) {
71104
+ pickElements.push(e);
71105
+ allElements.push(e);
71106
+ opt.callback && opt.callback(e, m, s, r);
71102
71107
  }
71103
- return false;
71104
71108
  });
71105
71109
  }
71106
71110
  else {
71107
- const el = elements.find(e => keys.every(k => datum[0][k] == e.getDatum()[k]));
71108
- el && (pickElements = [el]);
71111
+ if (datum.length > 1) {
71112
+ const datumTemp = datum.slice();
71113
+ elements.forEach(e => {
71114
+ const elDatum = getDatumOfElement(e, m, s, r);
71115
+ const index = elDatum && datumTemp.findIndex(d => keys.every(k => d[k] == elDatum[k]));
71116
+ if (index >= 0) {
71117
+ datumTemp.splice(index, 1);
71118
+ pickElements.push(e);
71119
+ allElements.push(e);
71120
+ opt.callback && opt.callback(e, m, s, r);
71121
+ }
71122
+ });
71123
+ }
71124
+ else {
71125
+ const el = elements.find(e => {
71126
+ const elDatum = getDatumOfElement(e, m, s, r);
71127
+ return elDatum && keys.every(k => datum[0][k] == elDatum[k]);
71128
+ });
71129
+ if (el) {
71130
+ pickElements.push(el);
71131
+ allElements.push(el);
71132
+ opt.callback && opt.callback(el, m, s, r);
71133
+ }
71134
+ }
71109
71135
  }
71110
71136
  }
71111
- pickElements.forEach(element => {
71112
- r.interaction.startInteraction(stateKey, element);
71113
- });
71114
- }
71137
+ });
71115
71138
  });
71116
- });
71117
- if (checkReverse) {
71118
- r.interaction.reverseEventElement(stateKey);
71139
+ opt.regionCallback && opt.regionCallback(pickElements, r);
71140
+ });
71141
+ return allElements;
71142
+ }
71143
+ _setStateInDatum(stateKey, checkReverse, datum, filter, region) {
71144
+ this.filterGraphicsByDatum(datum, {
71145
+ filter,
71146
+ region,
71147
+ regionCallback: (elements, r) => {
71148
+ if (!datum) {
71149
+ r.interaction.clearEventElement(stateKey, true);
71150
+ }
71151
+ else if (elements.length) {
71152
+ elements.forEach(e => {
71153
+ r.interaction.startInteraction(stateKey, e);
71154
+ });
71155
+ if (checkReverse) {
71156
+ r.interaction.reverseEventElement(stateKey);
71157
+ }
71158
+ }
71119
71159
  }
71120
71160
  });
71121
71161
  }
@@ -72715,9 +72755,7 @@ class BarSeries extends CartesianSeries {
72715
72755
  else if (domainMin > 0) {
72716
72756
  return scale.scale(domainMin);
72717
72757
  }
72718
- else {
72719
- return scale.scale(0);
72720
- }
72758
+ return scale.scale(0);
72721
72759
  }
72722
72760
  }
72723
72761
  };
@@ -76925,7 +76963,7 @@ const pie = (originData, op) => {
76925
76963
  return data;
76926
76964
  }
76927
76965
  if (!showAllZero && showEmptyCircle && isDataEmpty(data, angleField, supportNegative)) {
76928
- return data;
76966
+ return [];
76929
76967
  }
76930
76968
  const appendArcInfo = (data, startAngle, angle) => {
76931
76969
  data[asStartAngle] = startAngle;
@@ -77414,6 +77452,7 @@ class BasePieSeries extends PolarSeries {
77414
77452
  }, {
77415
77453
  dataView: false
77416
77454
  });
77455
+ this._emptyArcMark.setDepend(this._pieMark);
77417
77456
  }
77418
77457
  }
77419
77458
  startAngleScale(datum) {
@@ -77449,8 +77488,8 @@ class BasePieSeries extends PolarSeries {
77449
77488
  const emptyPieMark = this._emptyArcMark;
77450
77489
  if (emptyPieMark) {
77451
77490
  this.setMarkStyle(emptyPieMark, Object.assign(Object.assign({}, initialStyle), { visible: () => {
77452
- const angleField = this.getAngleField()[0];
77453
- return isDataEmpty(this.getViewData().latestData, angleField, this._supportNegative);
77491
+ const data = this.getViewData().latestData;
77492
+ return !data || !data.length;
77454
77493
  } }), 'normal', AttributeLevel.Series);
77455
77494
  }
77456
77495
  }
@@ -89889,21 +89928,21 @@ function isValidStrokeOrFill(attr) {
89889
89928
  return isValid$1(attr) && attr !== 'none' && !((_a = attr.includes) === null || _a === void 0 ? void 0 : _a.call(attr, 'url'));
89890
89929
  }
89891
89930
  const getLineWidth = (attributes) => {
89892
- const strokeWidth = parseFloat(attributes['strokeWidth']);
89931
+ const strokeWidth = parseFloat(attributes.strokeWidth);
89893
89932
  if (!isNaN(strokeWidth)) {
89894
89933
  return strokeWidth;
89895
89934
  }
89896
- const stroke = attributes['stroke'];
89935
+ const stroke = attributes.stroke;
89897
89936
  return stroke && isValidStrokeOrFill(stroke) ? 1 : 0;
89898
89937
  };
89899
89938
  const getFill = (attributes, defaultFill) => {
89900
89939
  var _a;
89901
- const fill = (_a = attributes['fill']) !== null && _a !== void 0 ? _a : defaultFill;
89940
+ const fill = (_a = attributes.fill) !== null && _a !== void 0 ? _a : defaultFill;
89902
89941
  return fill && isValidStrokeOrFill(fill) ? fill : undefined;
89903
89942
  };
89904
89943
  const getStroke = (attributes, defaultStroke) => {
89905
89944
  var _a;
89906
- const stroke = (_a = attributes['stroke']) !== null && _a !== void 0 ? _a : defaultStroke;
89945
+ const stroke = (_a = attributes.stroke) !== null && _a !== void 0 ? _a : defaultStroke;
89907
89946
  return stroke && isValidStrokeOrFill(stroke) ? stroke : false;
89908
89947
  };
89909
89948
  const commonAttributes = (attributes) => {
@@ -89912,7 +89951,7 @@ const commonAttributes = (attributes) => {
89912
89951
  const graphicAttributeTransform = {
89913
89952
  group: (attributes) => {
89914
89953
  const common = commonAttributes(attributes);
89915
- return Object.assign(Object.assign({}, common), { visibleAll: common['visible'] !== false });
89954
+ return Object.assign(Object.assign({}, common), { visibleAll: common.visible !== false });
89916
89955
  },
89917
89956
  rule: (attributes) => {
89918
89957
  return Object.assign(Object.assign({}, commonAttributes(attributes)), { x: parseFloat(attributes.x1), y: parseFloat(attributes.y1), x1: parseFloat(attributes.x2), y1: parseFloat(attributes.y2) });
@@ -89963,7 +90002,7 @@ const pictogram = (data) => {
89963
90002
  el._uniqueId = `${el.id}-${index}`;
89964
90003
  el.data = undefined;
89965
90004
  const { graphicType: type, transform } = el;
89966
- let finalAttributes = {
90005
+ const finalAttributes = {
89967
90006
  visible: el.attributes.visibility !== 'hidden' && el.attributes.visibility !== 'collapse'
89968
90007
  };
89969
90008
  if (el.graphicType === 'text') {
@@ -89998,7 +90037,7 @@ const pictogram = (data) => {
89998
90037
  return result;
89999
90038
  });
90000
90039
  if (children && children.length) {
90001
- let startX = (_b = (_a = texts[i]._textGroupStyle) === null || _a === void 0 ? void 0 : _a.x) !== null && _b !== void 0 ? _b : 0;
90040
+ const startX = (_b = (_a = texts[i]._textGroupStyle) === null || _a === void 0 ? void 0 : _a.x) !== null && _b !== void 0 ? _b : 0;
90002
90041
  let curX = startX;
90003
90042
  for (let j = 0; j < children.length; j++) {
90004
90043
  const currentChild = children[j];
@@ -91974,49 +92013,40 @@ class SankeyChart extends BaseChart {
91974
92013
  }
91975
92014
  _setStateInDatum(stateKey, checkReverse, datum, filter, region) {
91976
92015
  const activeDatum = isArray$1(datum) ? datum[0] : datum;
91977
- const keys = !activeDatum ? null : Object.keys(activeDatum);
91978
- this.getRegionsInQuerier(region).forEach(r => {
91979
- if (!activeDatum) {
91980
- r.interaction.clearEventElement(stateKey, true);
91981
- return;
91982
- }
91983
- let hasPick = false;
91984
- r.getSeries().forEach(s => {
91985
- var _a, _b;
91986
- let activeNodeOrLink = null;
91987
- s.getMarksWithoutRoot().forEach(m => {
91988
- if (m.type === 'text') {
91989
- return;
91990
- }
91991
- let pickElement = null;
91992
- const mark = m.getProduct();
91993
- if (!mark) {
91994
- return;
91995
- }
91996
- if (!filter || (isFunction$1(filter) && filter(s, m))) {
91997
- pickElement = mark.elements.find((e) => keys.every(k => {
91998
- var _a;
91999
- let datum = (_a = e.getDatum()) === null || _a === void 0 ? void 0 : _a.datum;
92000
- if (isArray$1(datum)) {
92001
- datum = datum[0];
92002
- }
92003
- return activeDatum[k] == (datum === null || datum === void 0 ? void 0 : datum[k]);
92004
- }));
92005
- }
92006
- if (pickElement) {
92007
- hasPick = true;
92008
- r.interaction.startInteraction(stateKey, pickElement);
92009
- if (mark.id().includes('node') || mark.id().includes('link')) {
92010
- activeNodeOrLink = pickElement;
92011
- }
92016
+ const markFilter = (series, mark) => {
92017
+ return mark.type !== 'text' && mark.getProduct() && (!filter || filter(series, mark));
92018
+ };
92019
+ this.filterGraphicsByDatum(activeDatum, {
92020
+ filter: markFilter,
92021
+ region,
92022
+ getDatum: e => {
92023
+ var _a;
92024
+ let d = (_a = e.getDatum()) === null || _a === void 0 ? void 0 : _a.datum;
92025
+ if (isArray$1(d)) {
92026
+ d = d[0];
92027
+ }
92028
+ return d;
92029
+ },
92030
+ callback: (element, mark, s, r) => {
92031
+ var _a, _b, _c;
92032
+ const id = (_a = mark.getProduct()) === null || _a === void 0 ? void 0 : _a.id();
92033
+ if (id && (id.includes('node') || id.includes('link'))) {
92034
+ (_c = (_b = s)._handleEmphasisElement) === null || _c === void 0 ? void 0 : _c.call(_b, { item: element });
92035
+ }
92036
+ },
92037
+ regionCallback: (elements, r) => {
92038
+ if (!activeDatum) {
92039
+ r.interaction.clearEventElement(stateKey, true);
92040
+ return;
92041
+ }
92042
+ else if (elements.length) {
92043
+ elements.forEach(e => {
92044
+ r.interaction.startInteraction(stateKey, e);
92045
+ });
92046
+ if (checkReverse) {
92047
+ r.interaction.reverseEventElement(stateKey);
92012
92048
  }
92013
- });
92014
- if (activeNodeOrLink) {
92015
- (_b = (_a = s)._handleEmphasisElement) === null || _b === void 0 ? void 0 : _b.call(_a, { item: activeNodeOrLink });
92016
92049
  }
92017
- });
92018
- if (checkReverse && hasPick) {
92019
- r.interaction.reverseEventElement(stateKey);
92020
92050
  }
92021
92051
  });
92022
92052
  }
@@ -97471,17 +97501,22 @@ function computeOffsetFromRegion(point, offset, region) {
97471
97501
  }
97472
97502
  return offset;
97473
97503
  }
97504
+ function getProcessInfo(spec) {
97505
+ return {
97506
+ isXProcess: isValid$1(spec.x),
97507
+ isYProcess: isValid$1(spec.y),
97508
+ isX1Process: isValid$1(spec.x1),
97509
+ isY1Process: isValid$1(spec.y1),
97510
+ isAngleProcess: isValid$1(spec.angle),
97511
+ isRadiusProcess: isValid$1(spec.radius),
97512
+ isAngle1Process: isValid$1(spec.angle1),
97513
+ isRadius1Process: isValid$1(spec.radius1),
97514
+ isCoordinatesProcess: isValid$1(spec.coordinates),
97515
+ isValidProcess: isValid$1(spec.process)
97516
+ };
97517
+ }
97474
97518
  function getMarkLineProcessInfo(spec) {
97475
- const isXProcess = 'x' in spec;
97476
- const isYProcess = 'y' in spec;
97477
- const isX1Process = 'x1' in spec;
97478
- const isY1Process = 'y1' in spec;
97479
- const isAngleProcess = 'angle' in spec;
97480
- const isRadiusProcess = 'radius' in spec;
97481
- const isAngle1Process = 'angle1' in spec;
97482
- const isRadius1Process = 'radius1' in spec;
97483
- const isCoordinatesProcess = 'coordinates' in spec;
97484
- const isValidProcess = 'process' in spec;
97519
+ const { isXProcess, isYProcess, isX1Process, isY1Process, isAngleProcess, isRadiusProcess, isAngle1Process, isRadius1Process, isCoordinatesProcess, isValidProcess } = getProcessInfo(spec);
97485
97520
  return {
97486
97521
  doXProcess: isXProcess && !isYProcess && !isY1Process,
97487
97522
  doXYY1Process: isXProcess && isYProcess && isY1Process,
@@ -97497,15 +97532,7 @@ function getMarkLineProcessInfo(spec) {
97497
97532
  };
97498
97533
  }
97499
97534
  function getMarkAreaProcessInfo(spec) {
97500
- const isXProcess = 'x' in spec;
97501
- const isX1Process = 'x1' in spec;
97502
- const isYProcess = 'y' in spec;
97503
- const isY1Process = 'y1' in spec;
97504
- const isAngleProcess = 'angle' in spec;
97505
- const isRadiusProcess = 'radius' in spec;
97506
- const isAngle1Process = 'angle1' in spec;
97507
- const isRadius1Process = 'radius1' in spec;
97508
- const isCoordinatesProcess = 'coordinates' in spec;
97535
+ const { isXProcess, isYProcess, isX1Process, isY1Process, isAngleProcess, isRadiusProcess, isAngle1Process, isRadius1Process, isCoordinatesProcess } = getProcessInfo(spec);
97509
97536
  return {
97510
97537
  doXProcess: isXProcess && isX1Process && !isYProcess && !isY1Process,
97511
97538
  doYProcess: isYProcess && isY1Process && !isXProcess && !isX1Process,
@@ -98023,14 +98050,13 @@ class BaseMarkLine extends BaseMarker {
98023
98050
  return 'cartesian';
98024
98051
  }
98025
98052
  _createMarkerComponent() {
98026
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
98027
- const { startSymbol = {}, endSymbol = {} } = this._spec;
98028
- const label = array((_a = this._spec.label) !== null && _a !== void 0 ? _a : {});
98053
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
98054
+ const { label = {}, startSymbol = {}, endSymbol = {} } = this._spec;
98029
98055
  const markLineAttrs = {
98030
98056
  zIndex: this.layoutZIndex,
98031
- interactive: (_b = this._spec.interactive) !== null && _b !== void 0 ? _b : true,
98032
- hover: (_c = this._spec.interactive) !== null && _c !== void 0 ? _c : true,
98033
- select: (_d = this._spec.interactive) !== null && _d !== void 0 ? _d : true,
98057
+ interactive: (_a = this._spec.interactive) !== null && _a !== void 0 ? _a : true,
98058
+ hover: (_b = this._spec.interactive) !== null && _b !== void 0 ? _b : true,
98059
+ select: (_c = this._spec.interactive) !== null && _c !== void 0 ? _c : true,
98034
98060
  points: [
98035
98061
  { x: 0, y: 0 },
98036
98062
  { x: 0, y: 0 }
@@ -98042,25 +98068,17 @@ class BaseMarkLine extends BaseMarker {
98042
98068
  radius: 0,
98043
98069
  startAngle: 0,
98044
98070
  endAngle: 0,
98045
- lineStyle: transformStyle(transformToGraphic((_e = this._spec.line) === null || _e === void 0 ? void 0 : _e.style), this._markerData, this._markAttributeContext),
98046
- clipInRange: (_f = this._spec.clip) !== null && _f !== void 0 ? _f : false,
98047
- label: label.map(labelItem => {
98048
- return transformLabelAttributes(labelItem, this._markerData, this._markAttributeContext);
98049
- }),
98071
+ lineStyle: transformStyle(transformToGraphic((_d = this._spec.line) === null || _d === void 0 ? void 0 : _d.style), this._markerData, this._markAttributeContext),
98072
+ clipInRange: (_e = this._spec.clip) !== null && _e !== void 0 ? _e : false,
98073
+ label: transformLabelAttributes(label, this._markerData, this._markAttributeContext),
98050
98074
  state: {
98051
- line: transformState((_h = (_g = this._spec.line) === null || _g === void 0 ? void 0 : _g.state) !== null && _h !== void 0 ? _h : {}, this._markerData, this._markAttributeContext),
98052
- lineStartSymbol: transformState((_k = (_j = this._spec.startSymbol) === null || _j === void 0 ? void 0 : _j.state) !== null && _k !== void 0 ? _k : {}, this._markerData, this._markAttributeContext),
98053
- lineEndSymbol: transformState((_m = (_l = this._spec.endSymbol) === null || _l === void 0 ? void 0 : _l.state) !== null && _m !== void 0 ? _m : {}, this._markerData, this._markAttributeContext),
98054
- label: label.map(labelItem => {
98055
- var _a;
98056
- return transformState((_a = labelItem.state) !== null && _a !== void 0 ? _a : {}, this._markerData, this._markAttributeContext);
98057
- }),
98058
- labelBackground: label.map(labelItem => {
98059
- var _a, _b;
98060
- return transformState((_b = (_a = labelItem.labelBackground) === null || _a === void 0 ? void 0 : _a.state) !== null && _b !== void 0 ? _b : {}, this._markerData, this._markAttributeContext);
98061
- })
98075
+ line: transformState((_g = (_f = this._spec.line) === null || _f === void 0 ? void 0 : _f.state) !== null && _g !== void 0 ? _g : {}, this._markerData, this._markAttributeContext),
98076
+ lineStartSymbol: transformState((_j = (_h = this._spec.startSymbol) === null || _h === void 0 ? void 0 : _h.state) !== null && _j !== void 0 ? _j : {}, this._markerData, this._markAttributeContext),
98077
+ lineEndSymbol: transformState((_l = (_k = this._spec.endSymbol) === null || _k === void 0 ? void 0 : _k.state) !== null && _l !== void 0 ? _l : {}, this._markerData, this._markAttributeContext),
98078
+ label: transformState((_p = (_o = (_m = this._spec) === null || _m === void 0 ? void 0 : _m.label) === null || _o === void 0 ? void 0 : _o.state) !== null && _p !== void 0 ? _p : {}, this._markerData, this._markAttributeContext),
98079
+ labelBackground: transformState((_t = (_s = (_r = (_q = this._spec) === null || _q === void 0 ? void 0 : _q.label) === null || _r === void 0 ? void 0 : _r.labelBackground) === null || _s === void 0 ? void 0 : _s.state) !== null && _t !== void 0 ? _t : {}, this._markerData, this._markAttributeContext)
98062
98080
  },
98063
- animation: (_o = this._spec.animation) !== null && _o !== void 0 ? _o : false,
98081
+ animation: (_u = this._spec.animation) !== null && _u !== void 0 ? _u : false,
98064
98082
  animationEnter: this._spec.animationEnter,
98065
98083
  animationExit: this._spec.animationExit,
98066
98084
  animationUpdate: this._spec.animationUpdate
@@ -98085,7 +98103,7 @@ class BaseMarkLine extends BaseMarker {
98085
98103
  return markLine;
98086
98104
  }
98087
98105
  _getUpdateMarkerAttrs() {
98088
- var _a, _b;
98106
+ var _a, _b, _c, _d;
98089
98107
  const spec = this._spec;
98090
98108
  const data = this._markerData;
98091
98109
  const startRelativeSeries = this._startRelativeSeries;
@@ -98095,7 +98113,7 @@ class BaseMarkLine extends BaseMarker {
98095
98113
  const seriesData = relativeSeries.getViewData().latestData;
98096
98114
  const dataPoints = data.latestData[0] && data.latestData[0].latestData ? data.latestData[0].latestData : data.latestData;
98097
98115
  let limitRect;
98098
- if (spec.clip || array(spec.label).some(labelCfg => labelCfg === null || labelCfg === void 0 ? void 0 : labelCfg.confine)) {
98116
+ if (spec.clip || ((_a = spec.label) === null || _a === void 0 ? void 0 : _a.confine)) {
98099
98117
  const { minX, maxX, minY, maxY } = computeClipRange([
98100
98118
  startRelativeSeries.getRegion(),
98101
98119
  endRelativeSeries.getRegion(),
@@ -98108,13 +98126,10 @@ class BaseMarkLine extends BaseMarker {
98108
98126
  height: maxY - minY
98109
98127
  };
98110
98128
  }
98111
- const markerComponentAttr = (_b = (_a = this._markerComponent) === null || _a === void 0 ? void 0 : _a.attribute) !== null && _b !== void 0 ? _b : {};
98112
- const prevLabelAttrs = array(markerComponentAttr.label);
98113
- const specLabels = array(this._spec.label);
98114
- const labelAttrs = prevLabelAttrs.map((prevLabel, index) => {
98115
- const specLabel = specLabels[index] || {};
98116
- return Object.assign(Object.assign({}, prevLabel), { text: specLabel.formatMethod ? specLabel.formatMethod(dataPoints, seriesData) : prevLabel === null || prevLabel === void 0 ? void 0 : prevLabel.text });
98117
- });
98129
+ const markerComponentAttr = (_c = (_b = this._markerComponent) === null || _b === void 0 ? void 0 : _b.attribute) !== null && _c !== void 0 ? _c : {};
98130
+ const labelAttrs = Object.assign(Object.assign({}, markerComponentAttr.label), { text: this._spec.label.formatMethod
98131
+ ? this._spec.label.formatMethod(dataPoints, seriesData)
98132
+ : (_d = markerComponentAttr.label) === null || _d === void 0 ? void 0 : _d.text });
98118
98133
  return Object.assign(Object.assign({}, pointsAttr), { label: labelAttrs, limitRect, dx: this._layoutOffsetX, dy: this._layoutOffsetY });
98119
98134
  }
98120
98135
  _markerLayout() {
@@ -98216,7 +98231,7 @@ class CartesianMarkLine extends BaseMarkLine {
98216
98231
  return { points };
98217
98232
  }
98218
98233
  _markerLayout() {
98219
- var _a, _b, _c, _d, _e;
98234
+ var _a, _b, _c, _d, _e, _f, _g, _h;
98220
98235
  const updateAttrs = this._getUpdateMarkerAttrs();
98221
98236
  if (this._spec.type === 'type-step') {
98222
98237
  const startRelativeSeries = this._startRelativeSeries;
@@ -98243,7 +98258,7 @@ class CartesianMarkLine extends BaseMarkLine {
98243
98258
  else {
98244
98259
  expandDistanceValue = expandDistance;
98245
98260
  }
98246
- const { points, limitRect } = updateAttrs;
98261
+ const { points, label, limitRect } = updateAttrs;
98247
98262
  const joinPoints = getInsertPoints(points[0], points[1], connectDirection, expandDistanceValue);
98248
98263
  let labelPositionAttrs;
98249
98264
  if (multiSegment && isValid$1(mainSegmentIndex)) {
@@ -98257,10 +98272,20 @@ class CartesianMarkLine extends BaseMarkLine {
98257
98272
  else {
98258
98273
  labelPositionAttrs = Object.assign(Object.assign({ position: 'start', autoRotate: false }, getTextOffset(points[0], points[1], connectDirection, expandDistanceValue)), { refX: 0, refY: 0 });
98259
98274
  }
98260
- const markerComponentAttr = (_b = (_a = this._markerComponent) === null || _a === void 0 ? void 0 : _a.attribute) !== null && _b !== void 0 ? _b : {};
98261
- const prevLabelAttrs = array(markerComponentAttr.label);
98262
- const label = array((_c = updateAttrs.label) !== null && _c !== void 0 ? _c : {});
98263
- (_d = this._markerComponent) === null || _d === void 0 ? void 0 : _d.setAttributes({
98275
+ if (isValidNumber$1((_a = this._spec.label) === null || _a === void 0 ? void 0 : _a.refX)) {
98276
+ labelPositionAttrs.refX += this._spec.label.refX;
98277
+ }
98278
+ if (isValidNumber$1((_b = this._spec.label) === null || _b === void 0 ? void 0 : _b.refY)) {
98279
+ labelPositionAttrs.refY += this._spec.label.refY;
98280
+ }
98281
+ if (isValidNumber$1((_c = this._spec.label) === null || _c === void 0 ? void 0 : _c.dx)) {
98282
+ labelPositionAttrs.dx = (labelPositionAttrs.dx || 0) + this._spec.label.dx;
98283
+ }
98284
+ if (isValidNumber$1((_d = this._spec.label) === null || _d === void 0 ? void 0 : _d.dy)) {
98285
+ labelPositionAttrs.dy = (labelPositionAttrs.dy || 0) + this._spec.label.dy;
98286
+ }
98287
+ const markerComponentAttr = (_f = (_e = this._markerComponent) === null || _e === void 0 ? void 0 : _e.attribute) !== null && _f !== void 0 ? _f : {};
98288
+ (_g = this._markerComponent) === null || _g === void 0 ? void 0 : _g.setAttributes({
98264
98289
  points: multiSegment
98265
98290
  ? [
98266
98291
  [joinPoints[0], joinPoints[1]],
@@ -98268,22 +98293,7 @@ class CartesianMarkLine extends BaseMarkLine {
98268
98293
  [joinPoints[2], joinPoints[3]]
98269
98294
  ]
98270
98295
  : joinPoints,
98271
- label: label.map((labelItem, index) => {
98272
- var _a;
98273
- if (isValidNumber$1(labelItem === null || labelItem === void 0 ? void 0 : labelItem.refX)) {
98274
- labelPositionAttrs.refX += labelItem.refX;
98275
- }
98276
- if (isValidNumber$1(labelItem === null || labelItem === void 0 ? void 0 : labelItem.refY)) {
98277
- labelPositionAttrs.refY += labelItem.refY;
98278
- }
98279
- if (isValidNumber$1(labelItem === null || labelItem === void 0 ? void 0 : labelItem.dx)) {
98280
- labelPositionAttrs.dx = (labelPositionAttrs.dx || 0) + labelItem.dx;
98281
- }
98282
- if (isValidNumber$1(labelItem === null || labelItem === void 0 ? void 0 : labelItem.dy)) {
98283
- labelPositionAttrs.dy = (labelPositionAttrs.dy || 0) + labelItem.dy;
98284
- }
98285
- return Object.assign(Object.assign(Object.assign({}, labelItem), labelPositionAttrs), { textStyle: Object.assign(Object.assign({}, (_a = prevLabelAttrs[index]) === null || _a === void 0 ? void 0 : _a.textStyle), { textAlign: 'center', textBaseline: 'middle' }) });
98286
- }),
98296
+ label: Object.assign(Object.assign(Object.assign({}, label), labelPositionAttrs), { textStyle: Object.assign(Object.assign({}, markerComponentAttr.label.textStyle), { textAlign: 'center', textBaseline: 'middle' }) }),
98287
98297
  limitRect,
98288
98298
  multiSegment,
98289
98299
  mainSegmentIndex,
@@ -98292,7 +98302,7 @@ class CartesianMarkLine extends BaseMarkLine {
98292
98302
  });
98293
98303
  }
98294
98304
  else {
98295
- (_e = this._markerComponent) === null || _e === void 0 ? void 0 : _e.setAttributes(updateAttrs);
98305
+ (_h = this._markerComponent) === null || _h === void 0 ? void 0 : _h.setAttributes(updateAttrs);
98296
98306
  }
98297
98307
  }
98298
98308
  _computeOptions() {
@@ -98356,15 +98366,15 @@ class CartesianMarkLine extends BaseMarkLine {
98356
98366
  type: 'markerAggregation',
98357
98367
  options
98358
98368
  });
98359
- if (spec.process && 'x' in spec.process) {
98369
+ if (spec.process && isValid$1(spec.process.x)) {
98360
98370
  options = [this._processSpecByDims([{ dim: 'x', specValue: spec.process.x }])];
98361
98371
  needAggr = true;
98362
98372
  }
98363
- if (spec.process && 'y' in spec.process) {
98373
+ if (spec.process && isValid$1(spec.process.y)) {
98364
98374
  options = options = [this._processSpecByDims([{ dim: 'y', specValue: spec.process.y }])];
98365
98375
  needAggr = true;
98366
98376
  }
98367
- if (spec.process && 'xy' in spec.process) {
98377
+ if (spec.process && isValid$1(spec.process.xy)) {
98368
98378
  const { xField, yField } = relativeSeries.getSpec();
98369
98379
  options = {
98370
98380
  fieldX: xField,
@@ -98646,8 +98656,8 @@ class BaseMarkArea extends BaseMarker {
98646
98656
  return 'cartesian';
98647
98657
  }
98648
98658
  _createMarkerComponent() {
98649
- var _a, _b, _c, _d, _e, _f, _g, _h;
98650
- const label = array((_a = this._spec.label) !== null && _a !== void 0 ? _a : {});
98659
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
98660
+ const label = (_a = this._spec.label) !== null && _a !== void 0 ? _a : {};
98651
98661
  const markAreaAttrs = {
98652
98662
  zIndex: this.layoutZIndex,
98653
98663
  interactive: (_b = this._spec.interactive) !== null && _b !== void 0 ? _b : true,
@@ -98669,20 +98679,13 @@ class BaseMarkArea extends BaseMarker {
98669
98679
  endAngle: 0,
98670
98680
  areaStyle: transformStyle(transformToGraphic((_e = this._spec.area) === null || _e === void 0 ? void 0 : _e.style), this._markerData, this._markAttributeContext),
98671
98681
  clipInRange: (_f = this._spec.clip) !== null && _f !== void 0 ? _f : false,
98672
- label: label.map((labelItem) => {
98673
- return transformLabelAttributes(labelItem, this._markerData, this._markAttributeContext);
98674
- }),
98682
+ label: transformLabelAttributes(label, this._markerData, this._markAttributeContext),
98675
98683
  state: {
98676
98684
  area: transformState((_g = this._spec.area) === null || _g === void 0 ? void 0 : _g.state, this._markerData, this._markAttributeContext),
98677
- label: label.map((labelItem) => {
98678
- return transformState(labelItem.state, this._markerData, this._markAttributeContext);
98679
- }),
98680
- labelBackground: label.map((labelItem) => {
98681
- var _a;
98682
- return transformState((_a = labelItem.labelBackground) === null || _a === void 0 ? void 0 : _a.state, this._markerData, this._markAttributeContext);
98683
- })
98685
+ label: transformState((_h = this._spec.label) === null || _h === void 0 ? void 0 : _h.state, this._markerData, this._markAttributeContext),
98686
+ labelBackground: transformState((_l = (_k = (_j = this._spec) === null || _j === void 0 ? void 0 : _j.label) === null || _k === void 0 ? void 0 : _k.labelBackground) === null || _l === void 0 ? void 0 : _l.state, this._markerData, this._markAttributeContext)
98684
98687
  },
98685
- animation: (_h = this._spec.animation) !== null && _h !== void 0 ? _h : false,
98688
+ animation: (_m = this._spec.animation) !== null && _m !== void 0 ? _m : false,
98686
98689
  animationEnter: this._spec.animationEnter,
98687
98690
  animationExit: this._spec.animationExit,
98688
98691
  animationUpdate: this._spec.animationUpdate
@@ -98691,7 +98694,7 @@ class BaseMarkArea extends BaseMarker {
98691
98694
  return markArea;
98692
98695
  }
98693
98696
  _markerLayout() {
98694
- var _a;
98697
+ var _a, _b, _c, _d;
98695
98698
  const spec = this._spec;
98696
98699
  const data = this._markerData;
98697
98700
  const startRelativeSeries = this._startRelativeSeries;
@@ -98705,7 +98708,7 @@ class BaseMarkArea extends BaseMarker {
98705
98708
  : data.latestData
98706
98709
  : seriesData;
98707
98710
  let limitRect;
98708
- if (spec.clip || array(spec.label).some(labelCfg => labelCfg === null || labelCfg === void 0 ? void 0 : labelCfg.confine)) {
98711
+ if (spec.clip || ((_a = spec.label) === null || _a === void 0 ? void 0 : _a.confine)) {
98709
98712
  const { minX, maxX, minY, maxY } = computeClipRange([
98710
98713
  startRelativeSeries.getRegion(),
98711
98714
  endRelativeSeries.getRegion(),
@@ -98719,15 +98722,10 @@ class BaseMarkArea extends BaseMarker {
98719
98722
  };
98720
98723
  }
98721
98724
  if (this._markerComponent) {
98722
- const prevLabelAttrs = array((_a = this._markerComponent.attribute) === null || _a === void 0 ? void 0 : _a.label);
98723
- const specLabels = array(this._spec.label);
98724
- this._markerComponent.setAttributes(Object.assign(Object.assign({}, pointsAttr), { label: prevLabelAttrs.map((prevLabel, index) => {
98725
- const specLabel = specLabels[index] || {};
98726
- return Object.assign(Object.assign({}, prevLabel), { text: specLabel.formatMethod
98727
- ?
98728
- specLabel.formatMethod(dataPoints, seriesData)
98729
- : prevLabel === null || prevLabel === void 0 ? void 0 : prevLabel.text });
98730
- }), limitRect, dx: this._layoutOffsetX, dy: this._layoutOffsetY }));
98725
+ this._markerComponent.setAttributes(Object.assign(Object.assign({}, pointsAttr), { label: Object.assign(Object.assign({}, (_b = this._markerComponent.attribute) === null || _b === void 0 ? void 0 : _b.label), { text: this._spec.label.formatMethod
98726
+ ?
98727
+ this._spec.label.formatMethod(dataPoints, seriesData)
98728
+ : (_d = (_c = this._markerComponent.attribute) === null || _c === void 0 ? void 0 : _c.label) === null || _d === void 0 ? void 0 : _d.text }), limitRect, dx: this._layoutOffsetX, dy: this._layoutOffsetY }));
98731
98729
  }
98732
98730
  }
98733
98731
  _initDataView() {
@@ -99956,9 +99954,9 @@ class CartesianMarkPoint extends BaseMarkPoint {
99956
99954
  const spec = this._spec;
99957
99955
  const data = this._markerData;
99958
99956
  const relativeSeries = this._relativeSeries;
99959
- const isXYLayout = 'x' in spec && 'y' in spec;
99960
- const isCoordinateLayout = 'coordinate' in spec;
99961
- const isPositionLayout = 'position' in spec;
99957
+ const isXYLayout = isValid$1(spec.x) && isValid$1(spec.y);
99958
+ const isCoordinateLayout = isValid$1(spec.coordinate);
99959
+ const isPositionLayout = isValid$1(spec.position);
99962
99960
  const autoRange = (_a = spec === null || spec === void 0 ? void 0 : spec.autoRange) !== null && _a !== void 0 ? _a : false;
99963
99961
  let point;
99964
99962
  if (isXYLayout) {
@@ -103799,4 +103797,4 @@ const registerMediaQuery = () => {
103799
103797
  registerChartPlugin(MediaQuery);
103800
103798
  };
103801
103799
 
103802
- export { Arc3dMark, ArcMark, AreaChart, AreaMark, AreaSeries, AxisSyncPlugin, Bar3dChart, Bar3dSeries, BarChart, BarSeries, BaseChart, BaseChartSpecTransformer, BaseMark, BaseSeries, BoxPlotChart, BoxPlotSeries, Brush, CanvasTooltipHandler, CartesianAxis, CartesianBandAxis, CartesianCrossHair, CartesianLinearAxis, CartesianLogAxis, CartesianMarkArea, CartesianMarkLine, CartesianMarkPoint, CartesianSeries, CartesianSymlogAxis, CartesianTimeAxis, CirclePackingChart, CirclePackingSeries, CircularProgressChart, CircularProgressSeries, CommonChart, CommonChartSpecTransformer, ComponentMark, ComposedEventMapper, ContinuousLegend, CorrelationChart, CorrelationSeries, CustomMark, DEFAULT_CHART_HEIGHT, DEFAULT_CHART_WIDTH, DEFAULT_DATA_INDEX, DEFAULT_DATA_KEY, DEFAULT_DATA_SERIES_FIELD, DEFAULT_MEASURE_CANVAS_ID, DEFAULT_SERIES_STYLE_NAME, DataZoom, DimensionClickEvent, DimensionEventEnum, DimensionHoverEvent, DiscreteLegend, DomTooltipHandler, DotSeries, Event$1 as Event, Factory$1 as Factory, FormatterPlugin, Funnel3dChart, Funnel3dSeries, FunnelChart, FunnelSeries, GaugeChart, GaugePointerSeries, GaugeSeries, GeoCoordinate, GeoMarkPoint, GridLayout, GroupMark, HeatmapChart, HeatmapSeries, Histogram3dChart, HistogramChart, ImageMark, Indicator, Label, Layout$1 as Layout, Layout3d, LineChart, LineMark, LineSeries, LinearProgressChart, LinearProgressSeries, LinkSeries, LiquidChart, LiquidSeries, MOSAIC_CAT_END_PERCENT, MOSAIC_CAT_START_PERCENT, MOSAIC_VALUE_END_PERCENT, MOSAIC_VALUE_START_PERCENT, MapChart, MapLabelComponent, MapSeries, MediaQuery, MosaicChart, MosaicSeries, PREFIX, PathMark, PictogramChart, PictogramSeries, Pie3dChart, Pie3dSeries, PieChart, PieSeries, Player, PolarAxis, PolarBandAxis, PolarCrossHair, PolarLinearAxis, PolarMarkArea, PolarMarkLine, PolarMarkPoint, PolarSeries, PolygonMark, ProgressLikeSeries, Pyramid3dMark, RadarChart, RadarSeries, RangeAreaChart, RangeAreaSeries, RangeColumn3dChart, RangeColumn3dSeries, RangeColumnChart, RangeColumnSeries, Rect3dMark, RectMark, RenderModeEnum, RippleMark, RoseChart, RoseLikeSeries, RoseSeries, RuleMark, SEGMENT_FIELD_END, SEGMENT_FIELD_START, STACK_FIELD_END, STACK_FIELD_END_OffsetSilhouette, STACK_FIELD_END_PERCENT, STACK_FIELD_KEY, STACK_FIELD_START, STACK_FIELD_START_OffsetSilhouette, STACK_FIELD_START_PERCENT, STACK_FIELD_TOTAL, STACK_FIELD_TOTAL_BOTTOM, STACK_FIELD_TOTAL_PERCENT, STACK_FIELD_TOTAL_TOP, SankeyChart, SankeySeries, ScatterChart, ScatterSeries, ScrollBar, SequenceChart, SeriesMarkNameEnum, SeriesTypeEnum, SeriesTypeForThemeEnum, SunburstChart, SunburstSeries, SymbolMark, TextMark, ThemeManager$1 as ThemeManager, Title, Tooltip, TooltipResult, TotalLabel, TreemapChart, TreemapSeries, VChart, VennChart, VennSeries, WaterfallChart, WaterfallSeries, WordCloud3dChart, WordCloud3dSeries, WordCloudChart, WordCloudSeries, alternatingWave, builtinThemes, centerToCorner, columnCenterToEdge, columnEdgeToCenter, columnLeftToRight, columnRightToLeft, computeActualDataScheme, cornerToCenter, createArc, createArea, createGroup, createLine, createRect, createRichText, createSymbol, createText, darkTheme$1 as darkTheme, dataScheme, VChart as default, defaultThemeName, diagonalCenterToEdge, diagonalTopLeftToBottomRight, functionTransform, getActualColor, getCartesianDimensionInfo, getColorSchemeBySeries, getDataScheme, getFieldAlias, getMergedTheme, getPolarDimensionInfo, getRegionStackGroup, getTheme, hasThemeMerged, isColorKey, isProgressiveDataColorScheme, isTokenKey, lightTheme, mergeFields, particleEffect, pulseWave, queryColorFromColorScheme, queryToken, randomOpacity, register3DPlugin, registerAllEnv, registerAllMarks, registerAnimate, registerArc3dMark, registerArcMark, registerAreaChart, registerAreaMark, registerAreaSeries, registerBar3dChart, registerBar3dSeries, registerBarChart, registerBarSeries, registerBoxplotChart, registerBoxplotSeries, registerBrowserEnv, registerBrush, registerCanvasTooltipHandler, registerCartesianBandAxis, registerCartesianCrossHair, registerCartesianLinearAxis, registerCartesianLogAxis, registerCartesianSymlogAxis, registerCartesianTimeAxis, registerChartPlugin, registerCirclePackingChart, registerCirclePackingSeries, registerCircularProgressChart, registerCircularProgressSeries, registerCommonChart, registerComponentMark, registerContinuousLegend, registerCorrelationChart, registerCustomMark, registerDataZoom, registerDiscreteLegend, registerDomTooltipHandler, registerDotSeries, registerDragPlugin, registerFormatPlugin, registerFunnel3dChart, registerFunnel3dSeries, registerFunnelChart, registerFunnelSeries, registerGaugeChart, registerGaugePointerSeries, registerGaugeSeries, registerGeoCoordinate, registerGeoMarkPoint, registerGesturePlugin, registerGridLayout, registerGroupMark, registerHarmonyEnv, registerHeatmapChart, registerHeatmapSeries, registerHistogram3dChart, registerHistogramChart, registerHtmlAttributePlugin, registerImageMark, registerIndicator, registerLabel, registerLarkEnv, registerLayout3d, registerLineChart, registerLineMark, registerLineSeries, registerLinearProgressChart, registerLinearProgressSeries, registerLinkSeries, registerLiquidChart, registerLiquidSeries, registerLynxEnv, registerMapChart, registerMapLabel, registerMapSeries, registerMarkArea, registerMarkLine, registerMarkPoint, registerMediaQuery, registerMorph, registerMosaicChart, registerMosaicSeries, registerNodeEnv, registerPathMark, registerPictogramChart, registerPictogramSeries, registerPie3dChart, registerPie3dSeries, registerPieChart, registerPieSeries, registerPlayer, registerPolarBandAxis, registerPolarCrossHair, registerPolarLinearAxis, registerPolarMarkArea, registerPolarMarkLine, registerPolarMarkPoint, registerPolygonMark, registerPoptip, registerPyramid3dMark, registerRadarChart, registerRadarSeries, registerRangeAreaChart, registerRangeAreaSeries, registerRangeColumn3dChart, registerRangeColumn3dSeries, registerRangeColumnChart, registerRangeColumnSeries, registerReactAttributePlugin, registerRect3dMark, registerRectMark, registerRippleMark, registerRoseChart, registerRoseSeries, registerRuleMark, registerSankeyChart, registerSankeySeries, registerScatterChart, registerScatterSeries, registerScrollBar, registerSequenceChart, registerSunBurstSeries, registerSunburstChart, registerSymbolMark, registerTTEnv, registerTaroEnv, registerTextMark, registerTheme, registerTitle, registerTooltip, registerTotalLabel, registerTreemapChart, registerTreemapSeries, registerVennChart, registerVennSeries, registerWXEnv, registerWaterfallChart, registerWaterfallSeries, registerWordCloud3dChart, registerWordCloud3dSeries, registerWordCloudChart, registerWordCloudSeries, registerWordCloudShapeChart, removeTheme, rippleEffect, rotationScan, rowBottomToTop, rowCenterToEdge, rowEdgeToCenter, rowTopToBottom, snakeWave, sortStackValueGroup, specTransform, spiralEffect, stack, stackGroup, stackMosaic, stackMosaicTotal, stackOffsetSilhouette, stackTotal, themeExist, themes, token, transformColorSchemeToStandardStruct, version, vglobal };
103800
+ export { Arc3dMark, ArcMark, AreaChart, AreaMark, AreaSeries, AxisSyncPlugin, Bar3dChart, Bar3dSeries, BarChart, BarSeries, BaseChart, BaseChartSpecTransformer, BaseMark, BaseSeries, BoxPlotChart, BoxPlotSeries, Brush, CanvasTooltipHandler, CartesianAxis, CartesianBandAxis, CartesianChartSpecTransformer, CartesianCrossHair, CartesianLinearAxis, CartesianLogAxis, CartesianMarkArea, CartesianMarkLine, CartesianMarkPoint, CartesianSeries, CartesianSymlogAxis, CartesianTimeAxis, CirclePackingChart, CirclePackingSeries, CircularProgressChart, CircularProgressSeries, CommonChart, CommonChartSpecTransformer, ComponentMark, ComposedEventMapper, ContinuousLegend, CorrelationChart, CorrelationSeries, CustomMark, DEFAULT_CHART_HEIGHT, DEFAULT_CHART_WIDTH, DEFAULT_DATA_INDEX, DEFAULT_DATA_KEY, DEFAULT_DATA_SERIES_FIELD, DEFAULT_MEASURE_CANVAS_ID, DEFAULT_SERIES_STYLE_NAME, DataZoom, DimensionClickEvent, DimensionEventEnum, DimensionHoverEvent, DiscreteLegend, DomTooltipHandler, DotSeries, Event$1 as Event, Factory$1 as Factory, FormatterPlugin, Funnel3dChart, Funnel3dSeries, FunnelChart, FunnelSeries, GaugeChart, GaugePointerSeries, GaugeSeries, GeoCoordinate, GeoMarkPoint, GridLayout, GroupMark, HeatmapChart, HeatmapSeries, Histogram3dChart, HistogramChart, ImageMark, Indicator, Label, Layout$1 as Layout, Layout3d, LineChart, LineMark, LineSeries, LinearProgressChart, LinearProgressSeries, LinkSeries, LiquidChart, LiquidSeries, MOSAIC_CAT_END_PERCENT, MOSAIC_CAT_START_PERCENT, MOSAIC_VALUE_END_PERCENT, MOSAIC_VALUE_START_PERCENT, MapChart, MapLabelComponent, MapSeries, MediaQuery, MosaicChart, MosaicSeries, PREFIX, PathMark, PictogramChart, PictogramSeries, Pie3dChart, Pie3dSeries, PieChart, PieSeries, Player, PolarAxis, PolarBandAxis, PolarCrossHair, PolarLinearAxis, PolarMarkArea, PolarMarkLine, PolarMarkPoint, PolarSeries, PolygonMark, ProgressLikeSeries, Pyramid3dMark, RadarChart, RadarSeries, RangeAreaChart, RangeAreaSeries, RangeColumn3dChart, RangeColumn3dSeries, RangeColumnChart, RangeColumnSeries, Rect3dMark, RectMark, RenderModeEnum, RippleMark, RoseChart, RoseLikeSeries, RoseSeries, RuleMark, SEGMENT_FIELD_END, SEGMENT_FIELD_START, STACK_FIELD_END, STACK_FIELD_END_OffsetSilhouette, STACK_FIELD_END_PERCENT, STACK_FIELD_KEY, STACK_FIELD_START, STACK_FIELD_START_OffsetSilhouette, STACK_FIELD_START_PERCENT, STACK_FIELD_TOTAL, STACK_FIELD_TOTAL_BOTTOM, STACK_FIELD_TOTAL_PERCENT, STACK_FIELD_TOTAL_TOP, SankeyChart, SankeySeries, ScatterChart, ScatterSeries, ScrollBar, SequenceChart, SeriesMarkNameEnum, SeriesTypeEnum, SeriesTypeForThemeEnum, SunburstChart, SunburstSeries, SymbolMark, TextMark, ThemeManager$1 as ThemeManager, Title, Tooltip, TooltipResult, TotalLabel, TreemapChart, TreemapSeries, VChart, VennChart, VennSeries, WaterfallChart, WaterfallSeries, WordCloud3dChart, WordCloud3dSeries, WordCloudChart, WordCloudSeries, alternatingWave, builtinThemes, centerToCorner, columnCenterToEdge, columnEdgeToCenter, columnLeftToRight, columnRightToLeft, computeActualDataScheme, cornerToCenter, createArc, createArea, createGroup, createLine, createRect, createRichText, createSymbol, createText, darkTheme$1 as darkTheme, dataScheme, VChart as default, defaultThemeName, diagonalCenterToEdge, diagonalTopLeftToBottomRight, functionTransform, getActualColor, getCartesianDimensionInfo, getColorSchemeBySeries, getDataScheme, getFieldAlias, getMergedTheme, getPolarDimensionInfo, getRegionStackGroup, getTheme, hasThemeMerged, isColorKey, isProgressiveDataColorScheme, isTokenKey, lightTheme, mergeFields, particleEffect, pulseWave, queryColorFromColorScheme, queryToken, randomOpacity, register3DPlugin, registerAllEnv, registerAllMarks, registerAnimate, registerArc3dMark, registerArcMark, registerAreaChart, registerAreaMark, registerAreaSeries, registerBar3dChart, registerBar3dSeries, registerBarChart, registerBarSeries, registerBoxplotChart, registerBoxplotSeries, registerBrowserEnv, registerBrush, registerCanvasTooltipHandler, registerCartesianBandAxis, registerCartesianCrossHair, registerCartesianLinearAxis, registerCartesianLogAxis, registerCartesianSymlogAxis, registerCartesianTimeAxis, registerChartPlugin, registerCirclePackingChart, registerCirclePackingSeries, registerCircularProgressChart, registerCircularProgressSeries, registerCommonChart, registerComponentMark, registerContinuousLegend, registerCorrelationChart, registerCustomMark, registerDataZoom, registerDiscreteLegend, registerDomTooltipHandler, registerDotSeries, registerDragPlugin, registerFormatPlugin, registerFunnel3dChart, registerFunnel3dSeries, registerFunnelChart, registerFunnelSeries, registerGaugeChart, registerGaugePointerSeries, registerGaugeSeries, registerGeoCoordinate, registerGeoMarkPoint, registerGesturePlugin, registerGridLayout, registerGroupMark, registerHarmonyEnv, registerHeatmapChart, registerHeatmapSeries, registerHistogram3dChart, registerHistogramChart, registerHtmlAttributePlugin, registerImageMark, registerIndicator, registerLabel, registerLarkEnv, registerLayout3d, registerLineChart, registerLineMark, registerLineSeries, registerLinearProgressChart, registerLinearProgressSeries, registerLinkSeries, registerLiquidChart, registerLiquidSeries, registerLynxEnv, registerMapChart, registerMapLabel, registerMapSeries, registerMarkArea, registerMarkLine, registerMarkPoint, registerMediaQuery, registerMorph, registerMosaicChart, registerMosaicSeries, registerNodeEnv, registerPathMark, registerPictogramChart, registerPictogramSeries, registerPie3dChart, registerPie3dSeries, registerPieChart, registerPieSeries, registerPlayer, registerPolarBandAxis, registerPolarCrossHair, registerPolarLinearAxis, registerPolarMarkArea, registerPolarMarkLine, registerPolarMarkPoint, registerPolygonMark, registerPoptip, registerPyramid3dMark, registerRadarChart, registerRadarSeries, registerRangeAreaChart, registerRangeAreaSeries, registerRangeColumn3dChart, registerRangeColumn3dSeries, registerRangeColumnChart, registerRangeColumnSeries, registerReactAttributePlugin, registerRect3dMark, registerRectMark, registerRippleMark, registerRoseChart, registerRoseSeries, registerRuleMark, registerSankeyChart, registerSankeySeries, registerScatterChart, registerScatterSeries, registerScrollBar, registerSequenceChart, registerSunBurstSeries, registerSunburstChart, registerSymbolMark, registerTTEnv, registerTaroEnv, registerTextMark, registerTheme, registerTitle, registerTooltip, registerTotalLabel, registerTreemapChart, registerTreemapSeries, registerVennChart, registerVennSeries, registerWXEnv, registerWaterfallChart, registerWaterfallSeries, registerWordCloud3dChart, registerWordCloud3dSeries, registerWordCloudChart, registerWordCloudSeries, registerWordCloudShapeChart, removeTheme, rippleEffect, rotationScan, rowBottomToTop, rowCenterToEdge, rowEdgeToCenter, rowTopToBottom, snakeWave, sortStackValueGroup, specTransform, spiralEffect, stack, stackGroup, stackMosaic, stackMosaicTotal, stackOffsetSilhouette, stackTotal, themeExist, themes, token, transformColorSchemeToStandardStruct, version, vglobal };