@semcore/d3-chart 1.5.3 → 1.6.0

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 (120) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/lib/cjs/Area.js +15 -13
  3. package/lib/cjs/Area.js.map +1 -1
  4. package/lib/cjs/Axis.js +12 -12
  5. package/lib/cjs/Bar.js +11 -14
  6. package/lib/cjs/Bar.js.map +1 -1
  7. package/lib/cjs/Bubble.js +272 -0
  8. package/lib/cjs/Bubble.js.map +1 -0
  9. package/lib/cjs/Donut.js +77 -64
  10. package/lib/cjs/Donut.js.map +1 -1
  11. package/lib/cjs/Dots.js +8 -7
  12. package/lib/cjs/Dots.js.map +1 -1
  13. package/lib/cjs/GroupBar.js +8 -7
  14. package/lib/cjs/GroupBar.js.map +1 -1
  15. package/lib/cjs/HorizontalBar.js +11 -14
  16. package/lib/cjs/HorizontalBar.js.map +1 -1
  17. package/lib/cjs/Hover.js +3 -3
  18. package/lib/cjs/Line.js +14 -12
  19. package/lib/cjs/Line.js.map +1 -1
  20. package/lib/cjs/ScatterPlot.js +220 -0
  21. package/lib/cjs/ScatterPlot.js.map +1 -0
  22. package/lib/cjs/StackBar.js +39 -14
  23. package/lib/cjs/StackBar.js.map +1 -1
  24. package/lib/cjs/StackedArea.js +11 -9
  25. package/lib/cjs/StackedArea.js.map +1 -1
  26. package/lib/cjs/Tooltip.js +11 -11
  27. package/lib/cjs/Tooltip.js.map +1 -1
  28. package/lib/cjs/Venn.js +8 -8
  29. package/lib/cjs/Venn.js.map +1 -1
  30. package/lib/cjs/color.js +32 -30
  31. package/lib/cjs/color.js.map +1 -1
  32. package/lib/cjs/index.js +16 -0
  33. package/lib/cjs/index.js.map +1 -1
  34. package/lib/cjs/style/area.shadow.css +12 -2
  35. package/lib/cjs/style/bar.shadow.css +7 -2
  36. package/lib/cjs/style/bubble.shadow.css +45 -0
  37. package/lib/cjs/style/donut.shadow.css +15 -0
  38. package/lib/cjs/style/dot.shadow.css +6 -1
  39. package/lib/cjs/style/line.shadow.css +6 -1
  40. package/lib/cjs/style/scatterplot.shadow.css +27 -0
  41. package/lib/cjs/style/tooltip.shadow.css +7 -2
  42. package/lib/cjs/style/var.css +32 -0
  43. package/lib/cjs/style/venn.shadow.css +7 -1
  44. package/lib/es6/Area.js +15 -13
  45. package/lib/es6/Area.js.map +1 -1
  46. package/lib/es6/Axis.js +12 -12
  47. package/lib/es6/Bar.js +11 -14
  48. package/lib/es6/Bar.js.map +1 -1
  49. package/lib/es6/Bubble.js +255 -0
  50. package/lib/es6/Bubble.js.map +1 -0
  51. package/lib/es6/Donut.js +77 -64
  52. package/lib/es6/Donut.js.map +1 -1
  53. package/lib/es6/Dots.js +8 -7
  54. package/lib/es6/Dots.js.map +1 -1
  55. package/lib/es6/GroupBar.js +8 -7
  56. package/lib/es6/GroupBar.js.map +1 -1
  57. package/lib/es6/HorizontalBar.js +11 -14
  58. package/lib/es6/HorizontalBar.js.map +1 -1
  59. package/lib/es6/Hover.js +3 -3
  60. package/lib/es6/Line.js +14 -12
  61. package/lib/es6/Line.js.map +1 -1
  62. package/lib/es6/ScatterPlot.js +205 -0
  63. package/lib/es6/ScatterPlot.js.map +1 -0
  64. package/lib/es6/StackBar.js +39 -14
  65. package/lib/es6/StackBar.js.map +1 -1
  66. package/lib/es6/StackedArea.js +11 -9
  67. package/lib/es6/StackedArea.js.map +1 -1
  68. package/lib/es6/Tooltip.js +10 -10
  69. package/lib/es6/Tooltip.js.map +1 -1
  70. package/lib/es6/Venn.js +8 -8
  71. package/lib/es6/Venn.js.map +1 -1
  72. package/lib/es6/color.js +33 -31
  73. package/lib/es6/color.js.map +1 -1
  74. package/lib/es6/index.js +2 -0
  75. package/lib/es6/index.js.map +1 -1
  76. package/lib/es6/style/area.shadow.css +12 -2
  77. package/lib/es6/style/bar.shadow.css +7 -2
  78. package/lib/es6/style/bubble.shadow.css +45 -0
  79. package/lib/es6/style/donut.shadow.css +15 -0
  80. package/lib/es6/style/dot.shadow.css +6 -1
  81. package/lib/es6/style/line.shadow.css +6 -1
  82. package/lib/es6/style/scatterplot.shadow.css +27 -0
  83. package/lib/es6/style/tooltip.shadow.css +7 -2
  84. package/lib/es6/style/var.css +32 -0
  85. package/lib/es6/style/venn.shadow.css +7 -1
  86. package/lib/types/Bar.d.ts +1 -1
  87. package/lib/types/Bubble.d.ts +27 -0
  88. package/lib/types/HorizontalBar.d.ts +1 -1
  89. package/lib/types/ScatterPlot.d.ts +27 -0
  90. package/lib/types/index.d.ts +6 -0
  91. package/package.json +1 -1
  92. package/src/Area.js +2 -3
  93. package/src/Bar.js +6 -8
  94. package/src/Bubble.js +189 -0
  95. package/src/Donut.js +8 -7
  96. package/src/GroupBar.js +6 -2
  97. package/src/HorizontalBar.js +5 -8
  98. package/src/Line.js +2 -3
  99. package/src/ScatterPlot.js +130 -0
  100. package/src/StackBar.js +24 -7
  101. package/src/StackedArea.js +3 -2
  102. package/src/Tooltip.js +2 -2
  103. package/src/Venn.js +1 -1
  104. package/src/color.js +6 -32
  105. package/src/index.js +2 -0
  106. package/src/style/area.shadow.css +12 -2
  107. package/src/style/bar.shadow.css +7 -2
  108. package/src/style/bubble.shadow.css +45 -0
  109. package/src/style/donut.shadow.css +15 -0
  110. package/src/style/dot.shadow.css +6 -1
  111. package/src/style/line.shadow.css +6 -1
  112. package/src/style/scatterplot.shadow.css +27 -0
  113. package/src/style/tooltip.shadow.css +7 -2
  114. package/src/style/var.css +32 -0
  115. package/src/style/venn.shadow.css +7 -1
  116. package/src/types/Bar.d.ts +1 -1
  117. package/src/types/Bubble.d.ts +27 -0
  118. package/src/types/HorizontalBar.d.ts +1 -1
  119. package/src/types/ScatterPlot.d.ts +27 -0
  120. package/src/types/index.d.ts +6 -0
package/lib/es6/Bar.js CHANGED
@@ -24,16 +24,17 @@ var style = (
24
24
  /*__reshadow_css_start__*/
25
25
  _sstyled.insert(
26
26
  /*__inner_css_start__*/
27
- ".___SBar_17amb_gg_{fill:var(--color_10kcl1b);transition-property:height,width,y;transition-duration:var(--duration_10kcl1b);transition-timing-function:ease-in-out}.___SBar_17amb_gg_.__hide_17amb_gg_{display:none}.___SBackground_17amb_gg_{fill:#e4ecf1}"
27
+ ".___SBar_16vhi_gg_{fill:#50aef4;transition-property:height,width,y;transition-duration:var(--duration_6qtpvs);transition-timing-function:ease-in-out}.___SBar_16vhi_gg_.__color_16vhi_gg_{fill:var(--color_6qtpvs)}.___SBar_16vhi_gg_.__hide_16vhi_gg_{display:none}.___SBackground_16vhi_gg_{fill:#e4ecf1}"
28
28
  /*__inner_css_end__*/
29
- , "10kcl1b_gg_")
29
+ , "6qtpvs_gg_")
30
30
  /*__reshadow_css_end__*/
31
31
  , {
32
- "__SBar": "___SBar_17amb_gg_",
33
- "--color": "--color_10kcl1b",
34
- "--duration": "--duration_10kcl1b",
35
- "_hide": "__hide_17amb_gg_",
36
- "__SBackground": "___SBackground_17amb_gg_"
32
+ "__SBar": "___SBar_16vhi_gg_",
33
+ "--duration": "--duration_6qtpvs",
34
+ "_color": "__color_16vhi_gg_",
35
+ "--color": "--color_6qtpvs",
36
+ "_hide": "__hide_16vhi_gg_",
37
+ "__SBackground": "___SBackground_16vhi_gg_"
37
38
  });
38
39
 
39
40
  var BarRoot = /*#__PURE__*/function (_Component) {
@@ -107,16 +108,13 @@ var BarRoot = /*#__PURE__*/function (_Component) {
107
108
  var barY = yScale(Math.max((_d$y = d[y0]) !== null && _d$y !== void 0 ? _d$y : 0, d[y])) + offset[1];
108
109
  var barX = xScale(d[x]) + offset[0];
109
110
  var height = Math.abs(yScale(d[y]) - Math.min(yScale(yScale.domain()[0]), yScale((_d$y2 = d[y0]) !== null && _d$y2 !== void 0 ? _d$y2 : 0)));
110
- height = isRounded ? height + r : height;
111
111
  var width = widthProps || getBandwidth(xScale);
112
- var isRounded = r !== 0;
113
- var yValue = isRounded ? d[y] > 0 ? barY - r : barY : barY;
114
112
  var dSvg = getRect({
115
113
  x: barX,
116
- y: yValue,
114
+ y: barY,
117
115
  width: width,
118
116
  height: height,
119
- radius: r,
117
+ radius: Array.isArray(r) ? r[i] : r,
120
118
  position: d[y] > 0 ? 'top' : 'bottom'
121
119
  });
122
120
  return _ref = sstyled(styles), /*#__PURE__*/React.createElement(SBar, _ref.cn("SBar", {
@@ -130,7 +128,7 @@ var BarRoot = /*#__PURE__*/function (_Component) {
130
128
  "hide": hide,
131
129
  "color": color,
132
130
  "x": barX,
133
- "y": yValue,
131
+ "y": barY,
134
132
  "width": width,
135
133
  "height": height,
136
134
  "d": dSvg,
@@ -166,7 +164,6 @@ _defineProperty(BarRoot, "style", style);
166
164
  _defineProperty(BarRoot, "enhance", [uniqueIDEnhancement()]);
167
165
 
168
166
  _defineProperty(BarRoot, "defaultProps", {
169
- color: '#50aef4',
170
167
  offset: [0, 0],
171
168
  duration: 500,
172
169
  r: 2
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Bar.js"],"names":["React","transition","Component","sstyled","uniqueIDEnhancement","createElement","ClipPath","getBandwidth","roundedPath","BarRoot","props","index","asProps","x","data","value","duration","uid","selectRect","selection","selectAll","selectRectNode","node","getAttribute","attr","animationBar","d","i","SBar","Element","styles","color","y","y0","scale","hide","offset","r","widthProps","width","xScale","yScale","barY","Math","max","barX","height","abs","min","domain","isRounded","yValue","dSvg","getRect","radius","position","size","map","renderBar","bind","style","Background","SBackground","yRange","range","bandwidth"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { transition } from 'd3-transition';\nimport { Component, sstyled } from '@semcore/core';\nimport uniqueIDEnhancement from '@semcore/utils/lib/uniqueID';\nimport createElement from './createElement';\nimport ClipPath from './ClipPath';\nimport { getBandwidth, roundedPath } from './utils';\n\nimport style from './style/bar.shadow.css';\n\nclass BarRoot extends Component {\n static displayName = 'Bar';\n static style = style;\n static enhance = [uniqueIDEnhancement()];\n\n static defaultProps = {\n color: '#50aef4',\n offset: [0, 0],\n duration: 500,\n r: 2,\n };\n\n getBackgroundProps(props, index) {\n const { x, data } = this.asProps;\n return {\n value: data[index][x],\n };\n }\n\n animationBar() {\n const { duration, uid } = this.asProps;\n const selectRect = transition()\n .selection()\n .selectAll(`#${uid} rect`);\n const selectRectNode = selectRect.node();\n\n if (duration > 0 && selectRectNode && selectRectNode.getAttribute('y') !== '0') {\n selectRect\n .transition()\n .duration(duration)\n .attr('y', 0);\n }\n }\n\n componentDidUpdate() {\n this.animationBar();\n }\n\n componentDidMount() {\n this.animationBar();\n }\n\n renderBar(d, i) {\n const SBar = this.Element;\n const {\n styles,\n color,\n x,\n y,\n y0,\n scale,\n hide,\n offset,\n duration,\n uid,\n r,\n width: widthProps,\n } = this.asProps;\n\n const [xScale, yScale] = scale;\n const barY = yScale(Math.max(d[y0] ?? 0, d[y])) + offset[1];\n const barX = xScale(d[x]) + offset[0];\n let height = Math.abs(yScale(d[y]) - Math.min(yScale(yScale.domain()[0]), yScale(d[y0] ?? 0)));\n height = isRounded ? height + r : height;\n const width = widthProps || getBandwidth(xScale);\n const isRounded = r !== 0;\n const yValue = isRounded ? (d[y] > 0 ? barY - r : barY) : barY;\n const dSvg = getRect({\n x: barX,\n y: yValue,\n width,\n height,\n radius: r,\n position: d[y] > 0 ? 'top' : 'bottom',\n });\n\n return sstyled(styles)(\n <SBar\n key={`bar-${i}`}\n render=\"path\"\n clipPath={`url(#${uid})`}\n __excludeProps={['data', 'scale', 'value']}\n childrenPosition=\"above\"\n value={d}\n index={i}\n hide={hide}\n color={color}\n x={barX}\n y={yValue}\n width={width}\n height={height}\n d={dSvg}\n use:duration={`${duration}ms`}\n />,\n );\n }\n render() {\n const { data, uid, size, duration } = this.asProps;\n return (\n <>\n {data.map(this.renderBar.bind(this))}\n {duration && (\n <ClipPath\n key={`${uid}-animation`}\n id={uid}\n x=\"0\"\n y={size[1]}\n width={size[0]}\n height={`${size[1]}px`}\n />\n )}\n </>\n );\n }\n}\n\nfunction Background(props) {\n const { Element: SBackground, styles, scale, value } = props;\n\n const [xScale, yScale] = scale;\n const yRange = yScale.range();\n\n return sstyled(styles)(\n <SBackground\n render=\"rect\"\n childrenPosition=\"above\"\n width={xScale.bandwidth()}\n height={yRange[0] - yRange[1]}\n x={xScale(value)}\n y={yRange[1]}\n />,\n );\n}\n\nfunction getRect({ x, y, width, height, radius, position }) {\n if (height <= radius) return '';\n if (radius) {\n if (position === 'top')\n return roundedPath(x, y, width, height, radius, true, true, false, false);\n return roundedPath(x, y, width, height, radius, false, false, true, true);\n }\n return roundedPath(x, y, width, height, radius);\n}\n\nexport default createElement(BarRoot, { Background });\n"],"file":"Bar.js"}
1
+ {"version":3,"sources":["../../src/Bar.js"],"names":["React","transition","Component","sstyled","uniqueIDEnhancement","createElement","ClipPath","getBandwidth","roundedPath","BarRoot","props","index","asProps","x","data","value","duration","uid","selectRect","selection","selectAll","selectRectNode","node","getAttribute","attr","animationBar","d","i","SBar","Element","styles","color","y","y0","scale","hide","offset","r","widthProps","width","xScale","yScale","barY","Math","max","barX","height","abs","min","domain","dSvg","getRect","radius","Array","isArray","position","size","map","renderBar","bind","style","Background","SBackground","yRange","range","bandwidth"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { transition } from 'd3-transition';\nimport { Component, sstyled } from '@semcore/core';\nimport uniqueIDEnhancement from '@semcore/utils/lib/uniqueID';\nimport createElement from './createElement';\nimport ClipPath from './ClipPath';\nimport { getBandwidth, roundedPath } from './utils';\n\nimport style from './style/bar.shadow.css';\n\nclass BarRoot extends Component {\n static displayName = 'Bar';\n static style = style;\n static enhance = [uniqueIDEnhancement()];\n\n static defaultProps = {\n offset: [0, 0],\n duration: 500,\n r: 2,\n };\n\n getBackgroundProps(props, index) {\n const { x, data } = this.asProps;\n return {\n value: data[index][x],\n };\n }\n\n animationBar() {\n const { duration, uid } = this.asProps;\n const selectRect = transition()\n .selection()\n .selectAll(`#${uid} rect`);\n const selectRectNode = selectRect.node();\n\n if (duration > 0 && selectRectNode && selectRectNode.getAttribute('y') !== '0') {\n selectRect\n .transition()\n .duration(duration)\n .attr('y', 0);\n }\n }\n\n componentDidUpdate() {\n this.animationBar();\n }\n\n componentDidMount() {\n this.animationBar();\n }\n\n renderBar(d, i) {\n const SBar = this.Element;\n const {\n styles,\n color,\n x,\n y,\n y0,\n scale,\n hide,\n offset,\n duration,\n uid,\n r,\n width: widthProps,\n } = this.asProps;\n\n const [xScale, yScale] = scale;\n const barY = yScale(Math.max(d[y0] ?? 0, d[y])) + offset[1];\n const barX = xScale(d[x]) + offset[0];\n const height = Math.abs(\n yScale(d[y]) - Math.min(yScale(yScale.domain()[0]), yScale(d[y0] ?? 0)),\n );\n const width = widthProps || getBandwidth(xScale);\n const dSvg = getRect({\n x: barX,\n y: barY,\n width,\n height,\n radius: Array.isArray(r) ? r[i] : r,\n position: d[y] > 0 ? 'top' : 'bottom',\n });\n\n return sstyled(styles)(\n <SBar\n key={`bar-${i}`}\n render=\"path\"\n clipPath={`url(#${uid})`}\n __excludeProps={['data', 'scale', 'value']}\n childrenPosition=\"above\"\n value={d}\n index={i}\n hide={hide}\n color={color}\n x={barX}\n y={barY}\n width={width}\n height={height}\n d={dSvg}\n use:duration={`${duration}ms`}\n />,\n );\n }\n render() {\n const { data, uid, size, duration } = this.asProps;\n return (\n <>\n {data.map(this.renderBar.bind(this))}\n {duration && (\n <ClipPath\n key={`${uid}-animation`}\n id={uid}\n x=\"0\"\n y={size[1]}\n width={size[0]}\n height={`${size[1]}px`}\n />\n )}\n </>\n );\n }\n}\n\nfunction Background(props) {\n const { Element: SBackground, styles, scale, value } = props;\n\n const [xScale, yScale] = scale;\n const yRange = yScale.range();\n\n return sstyled(styles)(\n <SBackground\n render=\"rect\"\n childrenPosition=\"above\"\n width={xScale.bandwidth()}\n height={yRange[0] - yRange[1]}\n x={xScale(value)}\n y={yRange[1]}\n />,\n );\n}\n\nfunction getRect({ x, y, width, height, radius, position }) {\n if (height <= radius) return '';\n if (radius) {\n if (position === 'top')\n return roundedPath(x, y, width, height, radius, true, true, false, false);\n return roundedPath(x, y, width, height, radius, false, false, true, true);\n }\n return roundedPath(x, y, width, height, radius);\n}\n\nexport default createElement(BarRoot, { Background });\n"],"file":"Bar.js"}
@@ -0,0 +1,255 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
+ import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
3
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
4
+ import _createClass from "@babel/runtime/helpers/createClass";
5
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
6
+ import _inherits from "@babel/runtime/helpers/inherits";
7
+ import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
8
+ import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
9
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
10
+ import { sstyled as _sstyled } from "@semcore/core";
11
+
12
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
13
+
14
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
15
+
16
+ import React from 'react';
17
+ import { Component, sstyled } from '@semcore/core';
18
+ import canUseDOM from '@semcore/utils/lib/canUseDOM';
19
+ import { CONSTANT } from './utils';
20
+ import createElement from './createElement';
21
+ import uniqueIDEnhancement from '@semcore/utils/lib/uniqueID';
22
+ import { transition } from 'd3-transition';
23
+
24
+ /*__reshadow-styles__:"./style/bubble.shadow.css"*/
25
+ var style = (
26
+ /*__reshadow_css_start__*/
27
+ _sstyled.insert(
28
+ /*__inner_css_start__*/
29
+ ".___SBubble_3y220_gg_{fill:#2bb3ff;stroke:#fff;stroke-width:2px;transition-property:cx,cy;transition-duration:var(--duration_1pe3cbw);transition-timing-function:ease-in-out;opacity:.5}.___SBubble_3y220_gg_:hover{opacity:.8}.___SBubble_3y220_gg_.__color_3y220_gg_{fill:var(--color_1pe3cbw)}.___SCenter_3y220_gg_{text-anchor:middle;font-size:11px;stroke:#2bb3ff}.___SCenter_3y220_gg_.__color_3y220_gg_{stroke:var(--color_1pe3cbw)}.___SLabel_3y220_gg_{fill:#2bb3ff}.___SLabel_3y220_gg_._position_right_3y220_gg_{text-anchor:end}.___SLabel_3y220_gg_._position_left_3y220_gg_{text-anchor:start}.___SLabel_3y220_gg_.__color_3y220_gg_{fill:var(--color_1pe3cbw)}"
30
+ /*__inner_css_end__*/
31
+ , "1pe3cbw_gg_")
32
+ /*__reshadow_css_end__*/
33
+ , {
34
+ "__SBubble": "___SBubble_3y220_gg_",
35
+ "--duration": "--duration_1pe3cbw",
36
+ "_color": "__color_3y220_gg_",
37
+ "--color": "--color_1pe3cbw",
38
+ "__SCenter": "___SCenter_3y220_gg_",
39
+ "__SLabel": "___SLabel_3y220_gg_",
40
+ "_position_right": "_position_right_3y220_gg_",
41
+ "_position_left": "_position_left_3y220_gg_"
42
+ });
43
+ import ClipPath from './ClipPath';
44
+ import { scaleSqrt } from 'd3-scale';
45
+
46
+ var memoize = function memoize(func) {
47
+ var results = {};
48
+ return function (argsKey) {
49
+ if (!results[argsKey]) {
50
+ results[argsKey] = func(argsKey);
51
+ }
52
+
53
+ return results[argsKey];
54
+ };
55
+ };
56
+
57
+ var measureText = memoize(function (text) {
58
+ var span = document.createElement('span');
59
+ span.append(document.createTextNode(text));
60
+ span.style.display = 'inline-block';
61
+ document.body.append(span);
62
+ var textLength = span.offsetWidth;
63
+ span.remove();
64
+ return textLength;
65
+ });
66
+
67
+ var BubbleRoot = /*#__PURE__*/function (_Component) {
68
+ _inherits(BubbleRoot, _Component);
69
+
70
+ var _super = _createSuper(BubbleRoot);
71
+
72
+ function BubbleRoot() {
73
+ var _this;
74
+
75
+ _classCallCheck(this, BubbleRoot);
76
+
77
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
78
+ args[_key] = arguments[_key];
79
+ }
80
+
81
+ _this = _super.call.apply(_super, [this].concat(args));
82
+
83
+ _defineProperty(_assertThisInitialized(_this), "virtualElement", canUseDOM() ? document.createElement('div') : {});
84
+
85
+ _defineProperty(_assertThisInitialized(_this), "bindHandlerTooltip", function (visible, props) {
86
+ return function (_ref2) {
87
+ var x = _ref2.clientX,
88
+ y = _ref2.clientY;
89
+ var eventEmitter = _this.asProps.eventEmitter;
90
+ _this.virtualElement.getBoundingClientRect = _this.generateGetBoundingClientRect(x, y);
91
+ _this.virtualElement[CONSTANT.VIRTUAL_ELEMENT] = true;
92
+ eventEmitter.emit('onTooltipVisible', visible, props, _this.virtualElement);
93
+ };
94
+ });
95
+
96
+ return _this;
97
+ }
98
+
99
+ _createClass(BubbleRoot, [{
100
+ key: "generateGetBoundingClientRect",
101
+ value: function generateGetBoundingClientRect() {
102
+ var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
103
+ var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
104
+ return function () {
105
+ return {
106
+ width: 0,
107
+ height: 0,
108
+ top: y,
109
+ right: x,
110
+ bottom: y,
111
+ left: x
112
+ };
113
+ };
114
+ }
115
+ }, {
116
+ key: "animationCircle",
117
+ value: function animationCircle() {
118
+ var _this$asProps = this.asProps,
119
+ duration = _this$asProps.duration,
120
+ uid = _this$asProps.uid,
121
+ data = _this$asProps.data,
122
+ value = _this$asProps.value;
123
+ var z = scaleSqrt().domain([0, Math.max.apply(Math, _toConsumableArray(data.map(function (el) {
124
+ return el[value];
125
+ })))]).range([5.5, 50.5]);
126
+ var selectRect = transition().selection().selectAll("[id^=".concat(uid).concat(uid, "]")).attr('r', 0);
127
+ var selectRectNode = selectRect.node();
128
+
129
+ if (duration > 0 && selectRectNode) {
130
+ selectRect.transition().duration(duration).attr('r', function (_, ind) {
131
+ return z(data[ind][value]);
132
+ });
133
+ }
134
+ }
135
+ }, {
136
+ key: "componentDidUpdate",
137
+ value: function componentDidUpdate() {
138
+ this.animationCircle();
139
+ }
140
+ }, {
141
+ key: "componentDidMount",
142
+ value: function componentDidMount() {
143
+ this.animationCircle();
144
+ }
145
+ }, {
146
+ key: "renderCircle",
147
+ value: function renderCircle(d, i) {
148
+ var _ref, _d$color;
149
+
150
+ var _this$asProps2 = this.asProps,
151
+ color = _this$asProps2.color,
152
+ scale = _this$asProps2.scale,
153
+ x = _this$asProps2.x,
154
+ y = _this$asProps2.y,
155
+ offset = _this$asProps2.offset,
156
+ styles = _this$asProps2.styles,
157
+ uid = _this$asProps2.uid,
158
+ duration = _this$asProps2.duration,
159
+ value = _this$asProps2.value,
160
+ label = _this$asProps2.label,
161
+ markedCross = _this$asProps2.markedCross,
162
+ size = _this$asProps2.size,
163
+ data = _this$asProps2.data;
164
+
165
+ var _scale = _slicedToArray(scale, 2),
166
+ xScale = _scale[0],
167
+ yScale = _scale[1];
168
+
169
+ var SBubble = this.Element;
170
+ var SCenter = 'text';
171
+ var SLabel = 'text';
172
+ var z = scaleSqrt().domain([0, Math.max.apply(Math, _toConsumableArray(data.map(function (el) {
173
+ return el[value];
174
+ })))]).range([5.5, 50.5]);
175
+ var margin = Math.min(xScale.range()[0], xScale.range()[1]);
176
+ var labelPosition = size[0] - 2 * margin - (xScale(d[x]) + offset[0] + z(d[value])) < measureText(d[label]) ? 'right' : 'left';
177
+ var labelDistance = {
178
+ right: xScale(d[x]) + offset[0] - z(d[value]),
179
+ left: xScale(d[x]) + offset[0] + z(d[value])
180
+ }[labelPosition];
181
+ return _ref = sstyled(styles), /*#__PURE__*/React.createElement("g", _ref.cn("g", {
182
+ "key": "circle(#".concat(i, ")"),
183
+ "onMouseMove": this.bindHandlerTooltip(true, {
184
+ xIndex: i
185
+ }),
186
+ "onMouseLeave": this.bindHandlerTooltip(false, {
187
+ xIndex: i
188
+ })
189
+ }), markedCross && /*#__PURE__*/React.createElement(SCenter, _ref.cn("SCenter", {
190
+ "x": xScale(d[x]) + offset[0],
191
+ "y": yScale(d[y]) + offset[1],
192
+ "dy": ".3em",
193
+ "clipPath": "url(#".concat(uid, ")"),
194
+ "color": (_d$color = d[color]) !== null && _d$color !== void 0 ? _d$color : color
195
+ }), "+"), /*#__PURE__*/React.createElement(SBubble, _ref.cn("SBubble", {
196
+ "id": "".concat(uid).concat(uid),
197
+ "render": "circle",
198
+ "clipPath": "url(#".concat(uid, ")"),
199
+ "cx": xScale(d[x]) + offset[0],
200
+ "cy": yScale(d[y]) + offset[1],
201
+ "color": d[color],
202
+ "r": z(d[value]),
203
+ "use:duration": "".concat(duration, "ms")
204
+ })), d[label] && /*#__PURE__*/React.createElement(SLabel, _ref.cn("SLabel", {
205
+ "x": labelDistance,
206
+ "y": yScale(d[y]) + offset[1],
207
+ "dy": ".3em",
208
+ "clipPath": "url(#".concat(uid, ")"),
209
+ "position": labelPosition,
210
+ "color": d[color]
211
+ }), d[label]));
212
+ }
213
+ }, {
214
+ key: "render",
215
+ value: function render() {
216
+ var _this$asProps3 = this.asProps,
217
+ data = _this$asProps3.data,
218
+ uid = _this$asProps3.uid,
219
+ size = _this$asProps3.size,
220
+ scale = _this$asProps3.scale;
221
+
222
+ var _scale2 = _slicedToArray(scale, 2),
223
+ xScale = _scale2[0],
224
+ yScale = _scale2[1];
225
+
226
+ var marginX = Math.min(xScale.range()[0], xScale.range()[1]);
227
+ var marginY = Math.min(yScale.range()[0], yScale.range()[1]);
228
+ return /*#__PURE__*/React.createElement(React.Fragment, null, data.map(this.renderCircle.bind(this)), data.map(this.animationCircle.bind(this)), /*#__PURE__*/React.createElement(ClipPath, {
229
+ id: uid,
230
+ x: marginX,
231
+ y: marginY,
232
+ width: "".concat(size[0] - 2 * marginX, "px"),
233
+ height: "".concat(size[1] - 2 * marginY, "px")
234
+ }));
235
+ }
236
+ }]);
237
+
238
+ return BubbleRoot;
239
+ }(Component);
240
+
241
+ _defineProperty(BubbleRoot, "displayName", 'Bubble');
242
+
243
+ _defineProperty(BubbleRoot, "style", style);
244
+
245
+ _defineProperty(BubbleRoot, "enhance", [uniqueIDEnhancement()]);
246
+
247
+ _defineProperty(BubbleRoot, "defaultProps", {
248
+ offset: [0, 0],
249
+ duration: 500,
250
+ markedCross: true
251
+ });
252
+
253
+ var Bubble = createElement(BubbleRoot);
254
+ export default Bubble;
255
+ //# sourceMappingURL=Bubble.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Bubble.js"],"names":["React","Component","sstyled","canUseDOM","CONSTANT","createElement","uniqueIDEnhancement","transition","ClipPath","scaleSqrt","memoize","func","results","argsKey","measureText","text","span","document","append","createTextNode","style","display","body","textLength","offsetWidth","remove","BubbleRoot","visible","props","x","clientX","y","clientY","eventEmitter","asProps","virtualElement","getBoundingClientRect","generateGetBoundingClientRect","VIRTUAL_ELEMENT","emit","width","height","top","right","bottom","left","duration","uid","data","value","z","domain","Math","max","map","el","range","selectRect","selection","selectAll","attr","selectRectNode","node","_","ind","animationCircle","d","i","color","scale","offset","styles","label","markedCross","size","xScale","yScale","SBubble","Element","SCenter","SLabel","margin","min","labelPosition","labelDistance","bindHandlerTooltip","xIndex","marginX","marginY","renderCircle","bind","Bubble"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Component, sstyled } from '@semcore/core';\nimport canUseDOM from '@semcore/utils/lib/canUseDOM';\nimport { CONSTANT } from './utils';\nimport createElement from './createElement';\nimport uniqueIDEnhancement from '@semcore/utils/lib/uniqueID';\nimport { transition } from 'd3-transition';\nimport style from './style/bubble.shadow.css';\nimport ClipPath from './ClipPath';\nimport { scaleSqrt } from 'd3-scale';\n\nconst memoize = (func) => {\n const results = {};\n return (argsKey) => {\n if (!results[argsKey]) {\n results[argsKey] = func(argsKey);\n }\n return results[argsKey];\n };\n};\n\nconst measureText = memoize((text) => {\n let span = document.createElement('span');\n span.append(document.createTextNode(text));\n span.style.display = 'inline-block';\n document.body.append(span);\n const textLength = span.offsetWidth;\n span.remove();\n return textLength;\n});\n\nclass BubbleRoot extends Component {\n static displayName = 'Bubble';\n static style = style;\n static enhance = [uniqueIDEnhancement()];\n\n static defaultProps = {\n offset: [0, 0],\n duration: 500,\n markedCross: true,\n };\n\n virtualElement = canUseDOM() ? document.createElement('div') : {};\n\n generateGetBoundingClientRect(x = 0, y = 0) {\n return () => ({ width: 0, height: 0, top: y, right: x, bottom: y, left: x });\n }\n\n bindHandlerTooltip = (visible, props) => ({ clientX: x, clientY: y }) => {\n const { eventEmitter } = this.asProps;\n this.virtualElement.getBoundingClientRect = this.generateGetBoundingClientRect(x, y);\n this.virtualElement[CONSTANT.VIRTUAL_ELEMENT] = true;\n eventEmitter.emit('onTooltipVisible', visible, props, this.virtualElement);\n };\n\n animationCircle() {\n const { duration, uid, data, value } = this.asProps;\n const z = scaleSqrt()\n .domain([0, Math.max(...data.map((el) => el[value]))])\n .range([5.5, 50.5]);\n\n const selectRect = transition()\n .selection()\n .selectAll(`[id^=${uid}${uid}]`)\n .attr('r', 0);\n\n const selectRectNode = selectRect.node();\n if (duration > 0 && selectRectNode) {\n selectRect\n .transition()\n .duration(duration)\n .attr('r', function(_, ind) {\n return z(data[ind][value]);\n });\n }\n }\n\n componentDidUpdate() {\n this.animationCircle();\n }\n\n componentDidMount() {\n this.animationCircle();\n }\n\n renderCircle(d, i) {\n const {\n color,\n scale,\n x,\n y,\n offset,\n styles,\n uid,\n duration,\n value,\n label,\n markedCross,\n size,\n data,\n } = this.asProps;\n const [xScale, yScale] = scale;\n\n const SBubble = this.Element;\n const SCenter = 'text';\n const SLabel = 'text';\n const z = scaleSqrt()\n .domain([0, Math.max(...data.map((el) => el[value]))])\n .range([5.5, 50.5]);\n\n const margin = Math.min(xScale.range()[0], xScale.range()[1]);\n\n const labelPosition =\n size[0] - 2 * margin - (xScale(d[x]) + offset[0] + z(d[value])) < measureText(d[label])\n ? 'right'\n : 'left';\n const labelDistance = {\n right: xScale(d[x]) + offset[0] - z(d[value]),\n left: xScale(d[x]) + offset[0] + z(d[value]),\n }[labelPosition];\n\n return sstyled(styles)(\n <g\n key={`circle(#${i})`}\n onMouseMove={this.bindHandlerTooltip(true, { xIndex: i })}\n onMouseLeave={this.bindHandlerTooltip(false, { xIndex: i })}\n >\n {markedCross && (\n <SCenter\n x={xScale(d[x]) + offset[0]}\n y={yScale(d[y]) + offset[1]}\n dy=\".3em\"\n clipPath={`url(#${uid})`}\n color={d[color] ?? color}\n >\n &#43;\n </SCenter>\n )}\n <SBubble\n id={`${uid}${uid}`}\n render=\"circle\"\n clipPath={`url(#${uid})`}\n cx={xScale(d[x]) + offset[0]}\n cy={yScale(d[y]) + offset[1]}\n color={d[color]}\n r={z(d[value])}\n use:duration={`${duration}ms`}\n />\n {d[label] && (\n <SLabel\n x={labelDistance}\n y={yScale(d[y]) + offset[1]}\n dy=\".3em\"\n clipPath={`url(#${uid})`}\n position={labelPosition}\n color={d[color]}\n >\n {d[label]}\n </SLabel>\n )}\n </g>,\n );\n }\n\n render() {\n const { data, uid, size, scale } = this.asProps;\n const [xScale, yScale] = scale;\n const marginX = Math.min(xScale.range()[0], xScale.range()[1]);\n const marginY = Math.min(yScale.range()[0], yScale.range()[1]);\n\n return (\n <>\n {data.map(this.renderCircle.bind(this))}\n {data.map(this.animationCircle.bind(this))}\n <ClipPath\n id={uid}\n x={marginX}\n y={marginY}\n width={`${size[0] - 2 * marginX}px`}\n height={`${size[1] - 2 * marginY}px`}\n />\n </>\n );\n }\n}\n\nconst Bubble = createElement(BubbleRoot);\n\nexport default Bubble;\n"],"file":"Bubble.js"}
package/lib/es6/Donut.js CHANGED
@@ -28,21 +28,23 @@ var style = (
28
28
  /*__reshadow_css_start__*/
29
29
  _sstyled.insert(
30
30
  /*__inner_css_start__*/
31
- ".___SPie_101rw_gg_{stroke:#fff;fill:var(--color_3mch97)}.___SLabel_101rw_gg_{text-anchor:middle;vertical-anchor:middle}"
31
+ ".___SPie_12973_gg_{stroke:#fff;fill:#50aef4}.___SPie_12973_gg_.__color_12973_gg_{fill:var(--color_40fbm0)}.___SEmptyData_12973_gg_{fill:#e4ecf1}.___SEmptyData_12973_gg_.__color_12973_gg_{fill:var(--color_40fbm0)}.___SLabel_12973_gg_{text-anchor:middle;vertical-anchor:middle}"
32
32
  /*__inner_css_end__*/
33
- , "3mch97_gg_")
33
+ , "40fbm0_gg_")
34
34
  /*__reshadow_css_end__*/
35
35
  , {
36
- "__SPie": "___SPie_101rw_gg_",
37
- "--color": "--color_3mch97",
38
- "__SLabel": "___SLabel_101rw_gg_"
36
+ "__SPie": "___SPie_12973_gg_",
37
+ "_color": "__color_12973_gg_",
38
+ "--color": "--color_40fbm0",
39
+ "__SEmptyData": "___SEmptyData_12973_gg_",
40
+ "__SLabel": "___SLabel_12973_gg_"
39
41
  });
40
42
  var DEFAULT_INSTANCE = Symbol('DEFAULT_INSTANCE');
41
43
 
42
- function animationInitialPie(_ref3) {
43
- var halfsize = _ref3.halfsize,
44
- d3Arc = _ref3.d3Arc,
45
- arcs = _ref3.arcs;
44
+ function animationInitialPie(_ref4) {
45
+ var halfsize = _ref4.halfsize,
46
+ d3Arc = _ref4.d3Arc,
47
+ arcs = _ref4.arcs;
46
48
  return function (_, ind) {
47
49
  var d = arcs[ind];
48
50
  if (!d) return function () {
@@ -58,10 +60,10 @@ function animationInitialPie(_ref3) {
58
60
  };
59
61
  }
60
62
 
61
- function animationUpdatePie(_ref4) {
62
- var halfsize = _ref4.halfsize,
63
- arcs = _ref4.arcs,
64
- d3Arc = _ref4.d3Arc;
63
+ function animationUpdatePie(_ref5) {
64
+ var halfsize = _ref5.halfsize,
65
+ arcs = _ref5.arcs,
66
+ d3Arc = _ref5.d3Arc;
65
67
  return function (_, ind) {
66
68
  var d = arcs[ind];
67
69
 
@@ -82,12 +84,12 @@ function animationUpdatePie(_ref4) {
82
84
  };
83
85
  }
84
86
 
85
- function animationHoverPie(_ref5) {
86
- var d = _ref5.d,
87
- selector = _ref5.selector,
88
- duration = _ref5.duration,
89
- innerRadius = _ref5.innerRadius,
90
- outerRadius = _ref5.outerRadius;
87
+ function animationHoverPie(_ref6) {
88
+ var d = _ref6.d,
89
+ selector = _ref6.selector,
90
+ duration = _ref6.duration,
91
+ innerRadius = _ref6.innerRadius,
92
+ outerRadius = _ref6.outerRadius;
91
93
 
92
94
  if (duration > 0) {
93
95
  transition().selection().select(selector).transition().duration(duration).attrTween('d', function () {
@@ -110,10 +112,10 @@ function animationHoverPie(_ref5) {
110
112
 
111
113
  var increaseFactor = 8;
112
114
 
113
- function getOuterRadius(_ref6) {
114
- var size = _ref6.size,
115
- halfsize = _ref6.halfsize,
116
- outerRadius = _ref6.outerRadius;
115
+ function getOuterRadius(_ref7) {
116
+ var size = _ref7.size,
117
+ halfsize = _ref7.halfsize,
118
+ outerRadius = _ref7.outerRadius;
117
119
 
118
120
  var _size = _slicedToArray(size, 2),
119
121
  width = _size[0],
@@ -142,9 +144,9 @@ var DonutRoot = /*#__PURE__*/function (_Component) {
142
144
  _defineProperty(_assertThisInitialized(_this), "virtualElement", canUseDOM() ? document.createElement('div') : {});
143
145
 
144
146
  _defineProperty(_assertThisInitialized(_this), "bindHandlerTooltip", function (visible, props) {
145
- return function (_ref7) {
146
- var x = _ref7.clientX,
147
- y = _ref7.clientY;
147
+ return function (_ref8) {
148
+ var x = _ref8.clientX,
149
+ y = _ref8.clientY;
148
150
  var eventEmitter = _this.asProps.eventEmitter;
149
151
  _this.virtualElement.getBoundingClientRect = _this.generateGetBoundingClientRect(x, y);
150
152
  _this.virtualElement[CONSTANT.VIRTUAL_ELEMENT] = true;
@@ -196,17 +198,17 @@ var DonutRoot = /*#__PURE__*/function (_Component) {
196
198
 
197
199
  return acc;
198
200
  }, []);
199
- pieData = Object.entries(data).filter(function (_ref8) {
200
- var _ref9 = _slicedToArray(_ref8, 1),
201
- key = _ref9[0];
201
+ pieData = Object.entries(data).filter(function (_ref9) {
202
+ var _ref10 = _slicedToArray(_ref9, 1),
203
+ key = _ref10[0];
202
204
 
203
205
  return keys.includes(key);
204
- }).sort(function (_ref10, _ref11) {
205
- var _ref12 = _slicedToArray(_ref10, 1),
206
- a = _ref12[0];
207
-
206
+ }).sort(function (_ref11, _ref12) {
208
207
  var _ref13 = _slicedToArray(_ref11, 1),
209
- b = _ref13[0];
208
+ a = _ref13[0];
209
+
210
+ var _ref14 = _slicedToArray(_ref12, 1),
211
+ b = _ref14[0];
210
212
 
211
213
  return keys.indexOf(a) > keys.indexOf(b) ? 1 : -1;
212
214
  });
@@ -266,12 +268,7 @@ var DonutRoot = /*#__PURE__*/function (_Component) {
266
268
  value: function getEmptyDataProps() {
267
269
  var d3Arc = this.asProps.d3Arc;
268
270
  return {
269
- data: {
270
- endAngle: Math.PI * 2,
271
- startAngle: 0
272
- },
273
- d3Arc: d3Arc,
274
- color: '#E4ECF1'
271
+ d3Arc: d3Arc
275
272
  };
276
273
  }
277
274
  }, {
@@ -343,21 +340,21 @@ _defineProperty(DonutRoot, "style", style);
343
340
 
344
341
  _defineProperty(DonutRoot, "enhance", [uniqueIDEnhancement()]);
345
342
 
346
- _defineProperty(DonutRoot, "defaultProps", function (_ref16) {
347
- var _ref16$innerRadius = _ref16.innerRadius,
348
- innerRadius = _ref16$innerRadius === void 0 ? 0 : _ref16$innerRadius,
349
- outerRadius = _ref16.outerRadius,
350
- _ref16$halfsize = _ref16.halfsize,
351
- halfsize = _ref16$halfsize === void 0 ? false : _ref16$halfsize,
352
- size = _ref16.$rootProps.size;
343
+ _defineProperty(DonutRoot, "defaultProps", function (_ref18) {
344
+ var _ref18$innerRadius = _ref18.innerRadius,
345
+ innerRadius = _ref18$innerRadius === void 0 ? 0 : _ref18$innerRadius,
346
+ outerRadius = _ref18.outerRadius,
347
+ _ref18$halfsize = _ref18.halfsize,
348
+ halfsize = _ref18$halfsize === void 0 ? false : _ref18$halfsize,
349
+ size = _ref18.$rootProps.size;
353
350
  var d3Arc = arc().outerRadius(getOuterRadius({
354
351
  size: size,
355
352
  halfsize: halfsize,
356
353
  outerRadius: outerRadius
357
354
  })).innerRadius(innerRadius > increaseFactor ? innerRadius - increaseFactor : innerRadius);
358
- var d3Pie = pie().sort(null).value(function (_ref17) {
359
- var _ref18 = _slicedToArray(_ref17, 2),
360
- value = _ref18[1];
355
+ var d3Pie = pie().sort(null).value(function (_ref19) {
356
+ var _ref20 = _slicedToArray(_ref19, 2),
357
+ value = _ref20[1];
361
358
 
362
359
  return value;
363
360
  });
@@ -374,15 +371,14 @@ _defineProperty(DonutRoot, "defaultProps", function (_ref16) {
374
371
  };
375
372
  });
376
373
 
377
- function Pie(_ref14) {
374
+ function Pie(_ref15) {
378
375
  var _ref;
379
376
 
380
- var SPie = _ref14.Element,
381
- styles = _ref14.styles,
382
- d3Arc = _ref14.d3Arc,
383
- data = _ref14.data,
384
- _ref14$color = _ref14.color,
385
- color = _ref14$color === void 0 ? '#50aef4' : _ref14$color;
377
+ var SPie = _ref15.Element,
378
+ styles = _ref15.styles,
379
+ d3Arc = _ref15.d3Arc,
380
+ data = _ref15.data,
381
+ color = _ref15.color;
386
382
  return _ref = sstyled(styles), /*#__PURE__*/React.createElement(SPie, _ref.cn("SPie", {
387
383
  "render": "path",
388
384
  "color": color,
@@ -390,23 +386,40 @@ function Pie(_ref14) {
390
386
  }));
391
387
  }
392
388
 
393
- function Label(_ref15) {
389
+ function EmptyData(_ref16) {
394
390
  var _ref2;
395
391
 
396
- var SLabel = _ref15.Element,
397
- styles = _ref15.styles,
398
- Children = _ref15.Children;
399
- return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(SLabel, _ref2.cn("SLabel", {
392
+ var SEmptyData = _ref16.Element,
393
+ styles = _ref16.styles,
394
+ d3Arc = _ref16.d3Arc,
395
+ color = _ref16.color;
396
+ return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(SEmptyData, _ref2.cn("SEmptyData", {
397
+ "render": "path",
398
+ "color": color,
399
+ "d": d3Arc({
400
+ endAngle: Math.PI * 2,
401
+ startAngle: 0
402
+ })
403
+ }));
404
+ }
405
+
406
+ function Label(_ref17) {
407
+ var _ref3;
408
+
409
+ var SLabel = _ref17.Element,
410
+ styles = _ref17.styles,
411
+ Children = _ref17.Children;
412
+ return _ref3 = sstyled(styles), /*#__PURE__*/React.createElement(SLabel, _ref3.cn("SLabel", {
400
413
  "render": "text",
401
414
  "x": "0",
402
415
  "y": "0"
403
- }), /*#__PURE__*/React.createElement(Children, _ref2.cn("Children", {})));
416
+ }), /*#__PURE__*/React.createElement(Children, _ref3.cn("Children", {})));
404
417
  }
405
418
 
406
419
  var Donut = createElement(DonutRoot, {
407
420
  Pie: Pie,
408
421
  Label: Label,
409
- EmptyData: Pie
422
+ EmptyData: EmptyData
410
423
  });
411
424
  export default Donut;
412
425
  //# sourceMappingURL=Donut.js.map