@semcore/d3-chart 2.8.13 → 2.8.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,18 @@
2
2
 
3
3
  CHANGELOG.md standards are inspired by [keepachangelog.com](https://keepachangelog.com/en/1.0.0/).
4
4
 
5
+ ## [2.8.15] - 2023-02-21
6
+
7
+ ### Changed
8
+
9
+ - Version patch update due to children dependencies update (`@semcore/animation` [1.9.0 ~> 1.9.1], `@semcore/utils` [3.47.0 ~> 3.47.1]).
10
+
11
+ ## [2.8.14] - 2023-02-11
12
+
13
+ ### Fixed
14
+
15
+ - Added check for the presence of DON at start of animation for `RadialTree`.
16
+
5
17
  ## [2.8.13] - 2023-02-10
6
18
 
7
19
  ### Fixed
package/lib/cjs/Area.js CHANGED
@@ -48,19 +48,19 @@ var style = (
48
48
  /*__reshadow_css_start__*/
49
49
  _core.sstyled.insert(
50
50
  /*__inner_css_start__*/
51
- ".___SArea_fmx1t_gg_{fill:var(--intergalactic-chart-palette-order-1,#2bb3ff);fill-opacity:.2}.___SArea_fmx1t_gg_.__color_fmx1t_gg_{fill:var(--color_fmx1t)}.___SArea_fmx1t_gg_.__transparent_fmx1t_gg_{opacity:.3}.___SAreaLine_fmx1t_gg_{stroke:var(--intergalactic-chart-palette-order-1,#2bb3ff);stroke-width:3;fill:transparent}.___SAreaLine_fmx1t_gg_.__color_fmx1t_gg_{stroke:var(--color_fmx1t)}.___SAreaLine_fmx1t_gg_.__transparent_fmx1t_gg_{opacity:.3}.___SArea_fmx1t_gg_,.___SAreaLine_fmx1t_gg_{transition-property:d;transition-duration:var(--duration_fmx1t);transition-timing-function:ease-in-out}.___SNull_fmx1t_gg_{fill:transparent;stroke:var(--intergalactic-chart-grid-x-axis,#c4c7cf);stroke-dasharray:4}.___SNull_fmx1t_gg_.__hide_fmx1t_gg_{display:none}"
51
+ ".___SArea_a91lr_gg_{fill:var(--intergalactic-chart-palette-order-1, #2bb3ff);fill-opacity:.2}.___SArea_a91lr_gg_.__color_a91lr_gg_{fill:var(--color_a91lr)}.___SArea_a91lr_gg_.__transparent_a91lr_gg_{opacity:.3}.___SAreaLine_a91lr_gg_{stroke:var(--intergalactic-chart-palette-order-1, #2bb3ff);stroke-width:3;fill:transparent}.___SAreaLine_a91lr_gg_.__color_a91lr_gg_{stroke:var(--color_a91lr)}.___SAreaLine_a91lr_gg_.__transparent_a91lr_gg_{opacity:.3}.___SAreaLine_a91lr_gg_,.___SArea_a91lr_gg_{transition-property:d;transition-duration:var(--duration_a91lr);transition-timing-function:ease-in-out}.___SNull_a91lr_gg_{fill:transparent;stroke:var(--intergalactic-chart-grid-x-axis, #c4c7cf);stroke-dasharray:4}.___SNull_a91lr_gg_.__hide_a91lr_gg_{display:none}"
52
52
  /*__inner_css_end__*/
53
- , "fmx1t_gg_")
53
+ , "a91lr_gg_")
54
54
  /*__reshadow_css_end__*/
55
55
  , {
56
- "__SArea": "___SArea_fmx1t_gg_",
57
- "_color": "__color_fmx1t_gg_",
58
- "--color": "--color_fmx1t",
59
- "_transparent": "__transparent_fmx1t_gg_",
60
- "__SAreaLine": "___SAreaLine_fmx1t_gg_",
61
- "--duration": "--duration_fmx1t",
62
- "__SNull": "___SNull_fmx1t_gg_",
63
- "_hide": "__hide_fmx1t_gg_"
56
+ "__SArea": "___SArea_a91lr_gg_",
57
+ "_color": "__color_a91lr_gg_",
58
+ "--color": "--color_a91lr",
59
+ "_transparent": "__transparent_a91lr_gg_",
60
+ "__SAreaLine": "___SAreaLine_a91lr_gg_",
61
+ "--duration": "--duration_a91lr",
62
+ "__SNull": "___SNull_a91lr_gg_",
63
+ "_hide": "__hide_a91lr_gg_"
64
64
  });
65
65
 
66
66
  var AreaRoot = /*#__PURE__*/function (_Component) {
package/lib/cjs/Axis.js CHANGED
@@ -44,23 +44,23 @@ var style = (
44
44
  /*__reshadow_css_start__*/
45
45
  _core.sstyled.insert(
46
46
  /*__inner_css_start__*/
47
- ".___SAxis_4ac3b_gg_{stroke:var(--intergalactic-chart-grid-x-axis,#c4c7cf)}.___SAxis_4ac3b_gg_.__hide_4ac3b_gg_{display:none}.___STick_4ac3b_gg_{font-size:var(--intergalactic-fs-100,12px);fill:var(--intergalactic-chart-grid-text-label,#6c6e79)}.___STick_4ac3b_gg_.__hide_4ac3b_gg_{display:none}.___SGrid_4ac3b_gg_{fill:transparent;stroke:var(--intergalactic-border-secondary,#e0e1e9)}.___STitle_4ac3b_gg_{font-size:var(--intergalactic-fs-100,12px);fill:var(--intergalactic-text-hint,#6c6e79);transform-origin:var(--transform-origin_4ac3b)}.___STitle_4ac3b_gg_._position_top_4ac3b_gg_{text-anchor:middle}.___STitle_4ac3b_gg_._position_bottom_4ac3b_gg_{text-anchor:middle;alignment-baseline:hanging}.___STitle_4ac3b_gg_._position_right_4ac3b_gg_{transform:rotate(-90deg);alignment-baseline:middle;text-anchor:middle}.___STitle_4ac3b_gg_._position_left_4ac3b_gg_{transform:rotate(-90deg);text-anchor:middle;alignment-baseline:middle}.___STick_4ac3b_gg_._position_top_4ac3b_gg_{transform:translateY(-12px);text-anchor:middle}.___STick_4ac3b_gg_._position_bottom_4ac3b_gg_{transform:translateY(12px);text-anchor:middle;alignment-baseline:hanging}.___STick_4ac3b_gg_._position_right_4ac3b_gg_{transform:translateX(16px);text-anchor:start;alignment-baseline:middle}.___STick_4ac3b_gg_._position_left_4ac3b_gg_{transform:translateX(-16px);text-anchor:end;alignment-baseline:middle}.___STick_4ac3b_gg_._position_custom_0_4ac3b_gg_{transform:translateY(12px);text-anchor:middle;alignment-baseline:hanging}.___STick_4ac3b_gg_._position_custom_1_4ac3b_gg_{transform:translateX(-16px);text-anchor:end;alignment-baseline:middle}"
47
+ ".___SAxis_ku036_gg_{stroke:var(--intergalactic-chart-grid-x-axis, #c4c7cf)}.___SAxis_ku036_gg_.__hide_ku036_gg_,.___STick_ku036_gg_.__hide_ku036_gg_{display:none}.___STick_ku036_gg_{font-size:var(--intergalactic-fs-100, 12px);fill:var(--intergalactic-chart-grid-text-label, #6c6e79)}.___SGrid_ku036_gg_{fill:transparent;stroke:var(--intergalactic-border-secondary, #e0e1e9)}.___STitle_ku036_gg_{font-size:var(--intergalactic-fs-100, 12px);fill:var(--intergalactic-text-hint, #6c6e79);transform-origin:var(--transform-origin_ku036)}.___STitle_ku036_gg_._position_top_ku036_gg_{text-anchor:middle}.___STitle_ku036_gg_._position_bottom_ku036_gg_{text-anchor:middle;alignment-baseline:hanging}.___STitle_ku036_gg_._position_left_ku036_gg_,.___STitle_ku036_gg_._position_right_ku036_gg_{transform:rotate(-90deg);text-anchor:middle;alignment-baseline:middle}.___STick_ku036_gg_._position_top_ku036_gg_{transform:translateY(-12px);text-anchor:middle}.___STick_ku036_gg_._position_bottom_ku036_gg_{transform:translateY(12px);text-anchor:middle;alignment-baseline:hanging}.___STick_ku036_gg_._position_right_ku036_gg_{transform:translateX(16px);text-anchor:start;alignment-baseline:middle}.___STick_ku036_gg_._position_left_ku036_gg_{transform:translateX(-16px);text-anchor:end;alignment-baseline:middle}.___STick_ku036_gg_._position_custom_0_ku036_gg_{transform:translateY(12px);text-anchor:middle;alignment-baseline:hanging}.___STick_ku036_gg_._position_custom_1_ku036_gg_{transform:translateX(-16px);text-anchor:end;alignment-baseline:middle}"
48
48
  /*__inner_css_end__*/
49
- , "4ac3b_gg_")
49
+ , "ku036_gg_")
50
50
  /*__reshadow_css_end__*/
51
51
  , {
52
- "__SAxis": "___SAxis_4ac3b_gg_",
53
- "_hide": "__hide_4ac3b_gg_",
54
- "__STick": "___STick_4ac3b_gg_",
55
- "__SGrid": "___SGrid_4ac3b_gg_",
56
- "__STitle": "___STitle_4ac3b_gg_",
57
- "--transform-origin": "--transform-origin_4ac3b",
58
- "_position_top": "_position_top_4ac3b_gg_",
59
- "_position_bottom": "_position_bottom_4ac3b_gg_",
60
- "_position_right": "_position_right_4ac3b_gg_",
61
- "_position_left": "_position_left_4ac3b_gg_",
62
- "_position_custom_0": "_position_custom_0_4ac3b_gg_",
63
- "_position_custom_1": "_position_custom_1_4ac3b_gg_"
52
+ "__SAxis": "___SAxis_ku036_gg_",
53
+ "_hide": "__hide_ku036_gg_",
54
+ "__STick": "___STick_ku036_gg_",
55
+ "__SGrid": "___SGrid_ku036_gg_",
56
+ "__STitle": "___STitle_ku036_gg_",
57
+ "--transform-origin": "--transform-origin_ku036",
58
+ "_position_top": "_position_top_ku036_gg_",
59
+ "_position_bottom": "_position_bottom_ku036_gg_",
60
+ "_position_right": "_position_right_ku036_gg_",
61
+ "_position_left": "_position_left_ku036_gg_",
62
+ "_position_custom_0": "_position_custom_0_ku036_gg_",
63
+ "_position_custom_1": "_position_custom_1_ku036_gg_"
64
64
  });
65
65
  var CUSTOM_0 = Symbol('custom_0');
66
66
  var CUSTOM_1 = Symbol('custom_1');
package/lib/cjs/Bar.js CHANGED
@@ -44,18 +44,18 @@ var style = (
44
44
  /*__reshadow_css_start__*/
45
45
  _core.sstyled.insert(
46
46
  /*__inner_css_start__*/
47
- ".___SBar_d7dcc_gg_{fill:var(--intergalactic-chart-palette-order-1,#2bb3ff);transition-property:height,width,y;transition-duration:var(--duration_d7dcc);transition-timing-function:ease-in-out}.___SBar_d7dcc_gg_.__color_d7dcc_gg_{fill:var(--color_d7dcc)}.___SBar_d7dcc_gg_.__hide_d7dcc_gg_{display:none}.___SBar_d7dcc_gg_.__transparent_d7dcc_gg_{opacity:.3}.___SBackground_d7dcc_gg_{fill:var(--intergalactic-chart-palette-order-other-data,#c4c7cf)}"
47
+ ".___SBar_1oi7e_gg_{fill:var(--intergalactic-chart-palette-order-1, #2bb3ff);transition-property:height,width,y;transition-duration:var(--duration_1oi7e);transition-timing-function:ease-in-out}.___SBar_1oi7e_gg_.__color_1oi7e_gg_{fill:var(--color_1oi7e)}.___SBar_1oi7e_gg_.__hide_1oi7e_gg_{display:none}.___SBar_1oi7e_gg_.__transparent_1oi7e_gg_{opacity:.3}.___SBackground_1oi7e_gg_{fill:var(--intergalactic-chart-palette-order-other-data, #c4c7cf)}"
48
48
  /*__inner_css_end__*/
49
- , "d7dcc_gg_")
49
+ , "1oi7e_gg_")
50
50
  /*__reshadow_css_end__*/
51
51
  , {
52
- "__SBar": "___SBar_d7dcc_gg_",
53
- "--duration": "--duration_d7dcc",
54
- "_color": "__color_d7dcc_gg_",
55
- "--color": "--color_d7dcc",
56
- "_hide": "__hide_d7dcc_gg_",
57
- "_transparent": "__transparent_d7dcc_gg_",
58
- "__SBackground": "___SBackground_d7dcc_gg_"
52
+ "__SBar": "___SBar_1oi7e_gg_",
53
+ "--duration": "--duration_1oi7e",
54
+ "_color": "__color_1oi7e_gg_",
55
+ "--color": "--color_1oi7e",
56
+ "_hide": "__hide_1oi7e_gg_",
57
+ "_transparent": "__transparent_1oi7e_gg_",
58
+ "__SBackground": "___SBackground_1oi7e_gg_"
59
59
  });
60
60
 
61
61
  var calcPartBarY = function calcPartBarY(y, minHeight, height) {
package/lib/cjs/Bubble.js CHANGED
@@ -56,20 +56,20 @@ var style = (
56
56
  /*__reshadow_css_start__*/
57
57
  _core.sstyled.insert(
58
58
  /*__inner_css_start__*/
59
- ".___SBubble_1232x_gg_{fill:var(--intergalactic-chart-palette-order-1,#2bb3ff);stroke:var(--intergalactic-chart-grid-border,#fff);stroke-width:2px;transition-property:cx,cy;transition-duration:var(--duration_1232x);transition-timing-function:ease-in-out;opacity:.5}@media (hover: hover){.___SBubble_1232x_gg_:hover{opacity:.8}}.___SBubble_1232x_gg_.__color_1232x_gg_{fill:var(--color_1232x)}.___SBubble_1232x_gg_.__transparent_1232x_gg_{opacity:.3}.___SCenter_1232x_gg_{text-anchor:middle;font-size:calc(var(--intergalactic-fs-100, 12px) - 1px);stroke:var(--intergalactic-chart-palette-order-1,#2bb3ff)}.___SCenter_1232x_gg_.__color_1232x_gg_{stroke:var(--color_1232x)}.___SCenter_1232x_gg_.__transparent_1232x_gg_{opacity:.3}.___SLabel_1232x_gg_{fill:var(--intergalactic-chart-palette-order-1,#2bb3ff)}.___SLabel_1232x_gg_._position_right_1232x_gg_{text-anchor:end}.___SLabel_1232x_gg_._position_left_1232x_gg_{text-anchor:start}.___SLabel_1232x_gg_.__color_1232x_gg_{fill:var(--color_1232x)}.___SLabel_1232x_gg_.__transparent_1232x_gg_{opacity:.3}"
59
+ ".___SBubble_c970p_gg_{fill:var(--intergalactic-chart-palette-order-1, #2bb3ff);stroke:var(--intergalactic-chart-grid-border, #ffffff);stroke-width:2px;transition-property:cx,cy;transition-duration:var(--duration_c970p);transition-timing-function:ease-in-out;opacity:.5}@media (hover:hover){.___SBubble_c970p_gg_:hover{opacity:.8}}.___SBubble_c970p_gg_.__color_c970p_gg_{fill:var(--color_c970p)}.___SBubble_c970p_gg_.__transparent_c970p_gg_{opacity:.3}.___SCenter_c970p_gg_{text-anchor:middle;font-size:calc(var(--intergalactic-fs-100, 12px) - 1px);stroke:var(--intergalactic-chart-palette-order-1, #2bb3ff)}.___SCenter_c970p_gg_.__color_c970p_gg_{stroke:var(--color_c970p)}.___SCenter_c970p_gg_.__transparent_c970p_gg_{opacity:.3}.___SLabel_c970p_gg_{fill:var(--intergalactic-chart-palette-order-1, #2bb3ff)}.___SLabel_c970p_gg_._position_right_c970p_gg_{text-anchor:end}.___SLabel_c970p_gg_._position_left_c970p_gg_{text-anchor:start}.___SLabel_c970p_gg_.__color_c970p_gg_{fill:var(--color_c970p)}.___SLabel_c970p_gg_.__transparent_c970p_gg_{opacity:.3}"
60
60
  /*__inner_css_end__*/
61
- , "1232x_gg_")
61
+ , "c970p_gg_")
62
62
  /*__reshadow_css_end__*/
63
63
  , {
64
- "__SBubble": "___SBubble_1232x_gg_",
65
- "--duration": "--duration_1232x",
66
- "_color": "__color_1232x_gg_",
67
- "--color": "--color_1232x",
68
- "_transparent": "__transparent_1232x_gg_",
69
- "__SCenter": "___SCenter_1232x_gg_",
70
- "__SLabel": "___SLabel_1232x_gg_",
71
- "_position_right": "_position_right_1232x_gg_",
72
- "_position_left": "_position_left_1232x_gg_"
64
+ "__SBubble": "___SBubble_c970p_gg_",
65
+ "--duration": "--duration_c970p",
66
+ "_color": "__color_c970p_gg_",
67
+ "--color": "--color_c970p",
68
+ "_transparent": "__transparent_c970p_gg_",
69
+ "__SCenter": "___SCenter_c970p_gg_",
70
+ "__SLabel": "___SLabel_c970p_gg_",
71
+ "_position_right": "_position_right_c970p_gg_",
72
+ "_position_left": "_position_left_c970p_gg_"
73
73
  });
74
74
 
75
75
  var BubbleRoot = /*#__PURE__*/function (_Component) {
package/lib/cjs/Donut.js CHANGED
@@ -62,17 +62,17 @@ var style = (
62
62
  /*__reshadow_css_start__*/
63
63
  _core.sstyled.insert(
64
64
  /*__inner_css_start__*/
65
- ".___SPie_x3d7r_gg_{stroke:var(--intergalactic-chart-grid-border,#fff);fill:var(--intergalactic-chart-palette-order-1,#2bb3ff)}.___SPie_x3d7r_gg_.__color_x3d7r_gg_{fill:var(--color_x3d7r)}.___SPie_x3d7r_gg_.__transparent_x3d7r_gg_{opacity:.3}.___SEmptyData_x3d7r_gg_{fill:var(--intergalactic-chart-palette-order-null,#e0e1e9)}.___SEmptyData_x3d7r_gg_.__color_x3d7r_gg_{fill:var(--color_x3d7r)}.___SLabel_x3d7r_gg_{text-anchor:middle;vertical-anchor:middle}"
65
+ ".___SPie_1qugl_gg_{stroke:var(--intergalactic-chart-grid-border, #ffffff);fill:var(--intergalactic-chart-palette-order-1, #2bb3ff)}.___SPie_1qugl_gg_.__color_1qugl_gg_{fill:var(--color_1qugl)}.___SPie_1qugl_gg_.__transparent_1qugl_gg_{opacity:.3}.___SEmptyData_1qugl_gg_{fill:var(--intergalactic-chart-palette-order-null, #e0e1e9)}.___SEmptyData_1qugl_gg_.__color_1qugl_gg_{fill:var(--color_1qugl)}.___SLabel_1qugl_gg_{text-anchor:middle;vertical-anchor:middle}"
66
66
  /*__inner_css_end__*/
67
- , "x3d7r_gg_")
67
+ , "1qugl_gg_")
68
68
  /*__reshadow_css_end__*/
69
69
  , {
70
- "__SPie": "___SPie_x3d7r_gg_",
71
- "_color": "__color_x3d7r_gg_",
72
- "--color": "--color_x3d7r",
73
- "_transparent": "__transparent_x3d7r_gg_",
74
- "__SEmptyData": "___SEmptyData_x3d7r_gg_",
75
- "__SLabel": "___SLabel_x3d7r_gg_"
70
+ "__SPie": "___SPie_1qugl_gg_",
71
+ "_color": "__color_1qugl_gg_",
72
+ "--color": "--color_1qugl",
73
+ "_transparent": "__transparent_1qugl_gg_",
74
+ "__SEmptyData": "___SEmptyData_1qugl_gg_",
75
+ "__SLabel": "___SLabel_1qugl_gg_"
76
76
  });
77
77
  var DEFAULT_INSTANCE = Symbol('DEFAULT_INSTANCE');
78
78
 
package/lib/cjs/Dots.js CHANGED
@@ -32,19 +32,19 @@ var style = (
32
32
  /*__reshadow_css_start__*/
33
33
  _core.sstyled.insert(
34
34
  /*__inner_css_start__*/
35
- ".___SDots_p2et5_gg_ .___SDot_p2et5_gg_{transition-duration:var(--duration_p2et5)}.___SDot_p2et5_gg_{stroke-width:2px;stroke:var(--intergalactic-chart-grid-border,#fff);r:6px;fill:var(--intergalactic-chart-palette-order-1,#2bb3ff);transition-property:cx,cy;transition-timing-function:ease-in-out}.___SDot_p2et5_gg_.__hide_p2et5_gg_{display:none}.___SDot_p2et5_gg_.__active_p2et5_gg_{r:8px}.___SDot_p2et5_gg_.__color_p2et5_gg_{fill:var(--color_p2et5)}.___SDot_p2et5_gg_.__transparent_p2et5_gg_{opacity:.3}"
35
+ ".___SDots_103gh_gg_ .___SDot_103gh_gg_{transition-duration:var(--duration_103gh)}.___SDot_103gh_gg_{stroke-width:2px;stroke:var(--intergalactic-chart-grid-border, #ffffff);r:6px;fill:var(--intergalactic-chart-palette-order-1, #2bb3ff);transition-property:cx,cy;transition-timing-function:ease-in-out}.___SDot_103gh_gg_.__hide_103gh_gg_{display:none}.___SDot_103gh_gg_.__active_103gh_gg_{r:8px}.___SDot_103gh_gg_.__color_103gh_gg_{fill:var(--color_103gh)}.___SDot_103gh_gg_.__transparent_103gh_gg_{opacity:.3}"
36
36
  /*__inner_css_end__*/
37
- , "p2et5_gg_")
37
+ , "103gh_gg_")
38
38
  /*__reshadow_css_end__*/
39
39
  , {
40
- "__SDots": "___SDots_p2et5_gg_",
41
- "__SDot": "___SDot_p2et5_gg_",
42
- "--duration": "--duration_p2et5",
43
- "_hide": "__hide_p2et5_gg_",
44
- "_active": "__active_p2et5_gg_",
45
- "_color": "__color_p2et5_gg_",
46
- "--color": "--color_p2et5",
47
- "_transparent": "__transparent_p2et5_gg_"
40
+ "__SDots": "___SDots_103gh_gg_",
41
+ "__SDot": "___SDot_103gh_gg_",
42
+ "--duration": "--duration_103gh",
43
+ "_hide": "__hide_103gh_gg_",
44
+ "_active": "__active_103gh_gg_",
45
+ "_color": "__color_103gh_gg_",
46
+ "--color": "--color_103gh",
47
+ "_transparent": "__transparent_103gh_gg_"
48
48
  });
49
49
  var EXCLUDE_PROPS = ['data', 'scale', 'value', 'display'];
50
50
 
@@ -42,18 +42,18 @@ var style = (
42
42
  /*__reshadow_css_start__*/
43
43
  _core.sstyled.insert(
44
44
  /*__inner_css_start__*/
45
- ".___SBar_d7dcc_gg_{fill:var(--intergalactic-chart-palette-order-1,#2bb3ff);transition-property:height,width,y;transition-duration:var(--duration_d7dcc);transition-timing-function:ease-in-out}.___SBar_d7dcc_gg_.__color_d7dcc_gg_{fill:var(--color_d7dcc)}.___SBar_d7dcc_gg_.__hide_d7dcc_gg_{display:none}.___SBar_d7dcc_gg_.__transparent_d7dcc_gg_{opacity:.3}.___SBackground_d7dcc_gg_{fill:var(--intergalactic-chart-palette-order-other-data,#c4c7cf)}"
45
+ ".___SBar_1oi7e_gg_{fill:var(--intergalactic-chart-palette-order-1, #2bb3ff);transition-property:height,width,y;transition-duration:var(--duration_1oi7e);transition-timing-function:ease-in-out}.___SBar_1oi7e_gg_.__color_1oi7e_gg_{fill:var(--color_1oi7e)}.___SBar_1oi7e_gg_.__hide_1oi7e_gg_{display:none}.___SBar_1oi7e_gg_.__transparent_1oi7e_gg_{opacity:.3}.___SBackground_1oi7e_gg_{fill:var(--intergalactic-chart-palette-order-other-data, #c4c7cf)}"
46
46
  /*__inner_css_end__*/
47
- , "d7dcc_gg_")
47
+ , "1oi7e_gg_")
48
48
  /*__reshadow_css_end__*/
49
49
  , {
50
- "__SBar": "___SBar_d7dcc_gg_",
51
- "--duration": "--duration_d7dcc",
52
- "_color": "__color_d7dcc_gg_",
53
- "--color": "--color_d7dcc",
54
- "_hide": "__hide_d7dcc_gg_",
55
- "_transparent": "__transparent_d7dcc_gg_",
56
- "__SBackground": "___SBackground_d7dcc_gg_"
50
+ "__SBar": "___SBar_1oi7e_gg_",
51
+ "--duration": "--duration_1oi7e",
52
+ "_color": "__color_1oi7e_gg_",
53
+ "--color": "--color_1oi7e",
54
+ "_hide": "__hide_1oi7e_gg_",
55
+ "_transparent": "__transparent_1oi7e_gg_",
56
+ "__SBackground": "___SBackground_1oi7e_gg_"
57
57
  });
58
58
 
59
59
  var HorizontalBarRoot = /*#__PURE__*/function (_Component) {
package/lib/cjs/Hover.js CHANGED
@@ -44,13 +44,13 @@ var style = (
44
44
  /*__reshadow_css_start__*/
45
45
  _core.sstyled.insert(
46
46
  /*__inner_css_start__*/
47
- ".___SHoverLine_1gzs0_gg_{stroke:var(--intergalactic-chart-grid-x-axis,#c4c7cf)}.___SHoverRect_1gzs0_gg_{fill:var(--intergalactic-chart-grid-bar-chart-hover,rgba(196,199,207,.3))}"
47
+ ".___SHoverLine_15icr_gg_{stroke:var(--intergalactic-chart-grid-x-axis, #c4c7cf)}.___SHoverRect_15icr_gg_{fill:var(--intergalactic-chart-grid-bar-chart-hover, rgba(196, 199, 207, 0.3))}"
48
48
  /*__inner_css_end__*/
49
- , "1gzs0_gg_")
49
+ , "15icr_gg_")
50
50
  /*__reshadow_css_end__*/
51
51
  , {
52
- "__SHoverLine": "___SHoverLine_1gzs0_gg_",
53
- "__SHoverRect": "___SHoverRect_1gzs0_gg_"
52
+ "__SHoverLine": "___SHoverLine_15icr_gg_",
53
+ "__SHoverRect": "___SHoverRect_15icr_gg_"
54
54
  });
55
55
 
56
56
  var Hover = /*#__PURE__*/function (_Component) {
package/lib/cjs/Line.js CHANGED
@@ -46,18 +46,18 @@ var style = (
46
46
  /*__reshadow_css_start__*/
47
47
  _core.sstyled.insert(
48
48
  /*__inner_css_start__*/
49
- ".___SLine_p2sqa_gg_{fill:transparent;stroke-width:3;stroke:var(--intergalactic-chart-palette-order-1,#2bb3ff);transition-property:d;transition-duration:var(--duration_p2sqa);transition-timing-function:ease-in-out}.___SLine_p2sqa_gg_.__color_p2sqa_gg_{stroke:var(--color_p2sqa)}.___SLine_p2sqa_gg_.__hide_p2sqa_gg_{display:none}.___SLine_p2sqa_gg_.__transparent_p2sqa_gg_{opacity:.3}.___SNull_p2sqa_gg_{fill:transparent;stroke:var(-intergalactic-border-primary);stroke-dasharray:4}.___SNull_p2sqa_gg_.__hide_p2sqa_gg_{display:none}"
49
+ ".___SLine_1lorh_gg_{fill:transparent;stroke-width:3;stroke:var(--intergalactic-chart-palette-order-1, #2bb3ff);transition-property:d;transition-duration:var(--duration_1lorh);transition-timing-function:ease-in-out}.___SLine_1lorh_gg_.__color_1lorh_gg_{stroke:var(--color_1lorh)}.___SLine_1lorh_gg_.__hide_1lorh_gg_{display:none}.___SLine_1lorh_gg_.__transparent_1lorh_gg_{opacity:.3}.___SNull_1lorh_gg_{fill:transparent;stroke:var(-intergalactic-border-primary);stroke-dasharray:4}.___SNull_1lorh_gg_.__hide_1lorh_gg_{display:none}"
50
50
  /*__inner_css_end__*/
51
- , "p2sqa_gg_")
51
+ , "1lorh_gg_")
52
52
  /*__reshadow_css_end__*/
53
53
  , {
54
- "__SLine": "___SLine_p2sqa_gg_",
55
- "--duration": "--duration_p2sqa",
56
- "_color": "__color_p2sqa_gg_",
57
- "--color": "--color_p2sqa",
58
- "_hide": "__hide_p2sqa_gg_",
59
- "_transparent": "__transparent_p2sqa_gg_",
60
- "__SNull": "___SNull_p2sqa_gg_"
54
+ "__SLine": "___SLine_1lorh_gg_",
55
+ "--duration": "--duration_1lorh",
56
+ "_color": "__color_1lorh_gg_",
57
+ "--color": "--color_1lorh",
58
+ "_hide": "__hide_1lorh_gg_",
59
+ "_transparent": "__transparent_1lorh_gg_",
60
+ "__SNull": "___SNull_1lorh_gg_"
61
61
  });
62
62
 
63
63
  var LineRoot = /*#__PURE__*/function (_Component) {
package/lib/cjs/Plot.js CHANGED
@@ -58,13 +58,13 @@ var style = (
58
58
  /*__reshadow_css_start__*/
59
59
  _core.sstyled.insert(
60
60
  /*__inner_css_start__*/
61
- ".___SPlot_1dh83_gg_{overflow:hidden}.___SPlot_1dh83_gg_:active,.___SPlot_1dh83_gg_:focus{outline:0;text-decoration:none}foreignObject[data-aria-only]{pointer-events:none}.___SPlot_1dh83_gg_.__keyboardFocused_1dh83_gg_{border:1px solid var(--intergalactic-chart-palette-order-9,#008ff8);box-shadow:var(--intergalactic-keyboard-focus,0 0 0 3px rgba(0,143,248,.3))}"
61
+ ".___SPlot_3byiw_gg_{overflow:hidden}.___SPlot_3byiw_gg_:active,.___SPlot_3byiw_gg_:focus{outline:0;text-decoration:none}foreignObject[data-aria-only]{pointer-events:none}.___SPlot_3byiw_gg_.__keyboardFocused_3byiw_gg_{border:1px solid var(--intergalactic-chart-palette-order-9, #008ff8);box-shadow:var(--intergalactic-keyboard-focus, 0px 0px 0px 3px rgba(0, 143, 248, 0.3))}"
62
62
  /*__inner_css_end__*/
63
- , "1dh83_gg_")
63
+ , "3byiw_gg_")
64
64
  /*__reshadow_css_end__*/
65
65
  , {
66
- "__SPlot": "___SPlot_1dh83_gg_",
67
- "_keyboardFocused": "__keyboardFocused_1dh83_gg_"
66
+ "__SPlot": "___SPlot_3byiw_gg_",
67
+ "_keyboardFocused": "__keyboardFocused_3byiw_gg_"
68
68
  });
69
69
 
70
70
  var PlotRoot = /*#__PURE__*/function (_Component) {
@@ -41,6 +41,8 @@ var _assignProps = _interopRequireDefault(require("@semcore/utils/lib/assignProp
41
41
 
42
42
  var _getOriginChildren = _interopRequireDefault(require("@semcore/utils/lib/getOriginChildren"));
43
43
 
44
+ var _canUseDOM = _interopRequireDefault(require("@semcore/utils/lib/canUseDOM"));
45
+
44
46
  var _createElement = _interopRequireDefault(require("./createElement"));
45
47
 
46
48
  var _utils = require("./utils");
@@ -60,22 +62,22 @@ var style = (
60
62
  /*__reshadow_css_start__*/
61
63
  _core.sstyled.insert(
62
64
  /*__inner_css_start__*/
63
- ".___SRadian_uqd7d_gg_{cursor:pointer;fill:var(--intergalactic-chart-palette-order-9,#008ff8)}.___SLine_uqd7d_gg_{stroke:var(--intergalactic-chart-palette-order-9,#008ff8)}.___SLine_uqd7d_gg_.__color_uqd7d_gg_{stroke:var(--color_uqd7d)}.___SLine_uqd7d_gg_.__transparent_uqd7d_gg_{opacity:.3}.___SCap_uqd7d_gg_{transition:r .1s}.___SCap_uqd7d_gg_.__transparent_uqd7d_gg_{opacity:.3}.___SIcon_uqd7d_gg_.__transparent_uqd7d_gg_{opacity:.3}.___SLabel_uqd7d_gg_{fill:var(--color_uqd7d);cursor:var(--text-cursor_uqd7d)}.___SLabel_uqd7d_gg_.__transparent_uqd7d_gg_{opacity:.3}@media (hover: hover){.___SRadian_uqd7d_gg_:hover .___SLabel_uqd7d_gg_{fill:var(--color-hovered_uqd7d)}}@media (prefers-reduced-motion){.___SLineCap_uqd7d_gg_{transition:none}}"
65
+ ".___SRadian_1cya8_gg_{cursor:pointer;fill:var(--intergalactic-chart-palette-order-9, #008ff8)}.___SLine_1cya8_gg_{stroke:var(--intergalactic-chart-palette-order-9, #008ff8)}.___SLine_1cya8_gg_.__color_1cya8_gg_{stroke:var(--color_1cya8)}.___SCap_1cya8_gg_.__transparent_1cya8_gg_,.___SIcon_1cya8_gg_.__transparent_1cya8_gg_,.___SLabel_1cya8_gg_.__transparent_1cya8_gg_,.___SLine_1cya8_gg_.__transparent_1cya8_gg_{opacity:.3}.___SCap_1cya8_gg_{transition:r .1s}.___SLabel_1cya8_gg_{fill:var(--color_1cya8);cursor:var(--text-cursor_1cya8)}@media (hover:hover){.___SRadian_1cya8_gg_:hover .___SLabel_1cya8_gg_{fill:var(--color-hovered_1cya8)}}@media (prefers-reduced-motion){.___SLineCap_1cya8_gg_{transition:none}}"
64
66
  /*__inner_css_end__*/
65
- , "uqd7d_gg_")
67
+ , "1cya8_gg_")
66
68
  /*__reshadow_css_end__*/
67
69
  , {
68
- "__SRadian": "___SRadian_uqd7d_gg_",
69
- "__SLine": "___SLine_uqd7d_gg_",
70
- "_color": "__color_uqd7d_gg_",
71
- "--color": "--color_uqd7d",
72
- "_transparent": "__transparent_uqd7d_gg_",
73
- "__SCap": "___SCap_uqd7d_gg_",
74
- "__SIcon": "___SIcon_uqd7d_gg_",
75
- "__SLabel": "___SLabel_uqd7d_gg_",
76
- "--text-cursor": "--text-cursor_uqd7d",
77
- "--color-hovered": "--color-hovered_uqd7d",
78
- "__SLineCap": "___SLineCap_uqd7d_gg_"
70
+ "__SRadian": "___SRadian_1cya8_gg_",
71
+ "__SLine": "___SLine_1cya8_gg_",
72
+ "_color": "__color_1cya8_gg_",
73
+ "--color": "--color_1cya8",
74
+ "_transparent": "__transparent_1cya8_gg_",
75
+ "__SCap": "___SCap_1cya8_gg_",
76
+ "__SIcon": "___SIcon_1cya8_gg_",
77
+ "__SLabel": "___SLabel_1cya8_gg_",
78
+ "--text-cursor": "--text-cursor_1cya8",
79
+ "--color-hovered": "--color-hovered_1cya8",
80
+ "__SLineCap": "___SLineCap_1cya8_gg_"
79
81
  });
80
82
  var baseAngle = -Math.PI / 2; // The top vertical line
81
83
 
@@ -109,6 +111,7 @@ var RadialTreeBase = /*#__PURE__*/function (_Component) {
109
111
  var _this$asProps = this.asProps,
110
112
  duration = _this$asProps.duration,
111
113
  uid = _this$asProps.uid;
114
+ if (!(0, _canUseDOM["default"])()) return;
112
115
  var preferReduceMotion = (_window$matchMedia = window.matchMedia('(prefers-reduced-motion: reduce)')) === null || _window$matchMedia === void 0 ? void 0 : _window$matchMedia.matches;
113
116
  /** using `!(>)` instead of `<=` to get true on NaN and non numbers stuff */
114
117
 
@@ -1 +1 @@
1
- {"version":3,"file":"RadialTree.js","names":["baseAngle","Math","PI","RadialTreeBase","props","handleRadianClick","bind","activeKey","asProps","duration","uid","preferReduceMotion","window","matchMedia","matches","circlesAnimation","transition","selection","selectAll","interrupt","iconsAnimation","linesAnimation","labelsAnimation","circlesNodes","nodes","iconsNodes","linesNodes","labelsNodes","length","attrs","map","node","radianIndex","parseInt","dataset","lineNode","from","cx","x1","baseVal","value","cy","y1","to","attr","_","index","width","height","x","y","x2","y2","prevProps","$rootProps","data","runAppearAnimation","key","event","newKey","handlers","textSize","widths","label","measureText","max","size","center","restRootProps","textWidth","computeTextWidth","radiansCount","onRadianClick","SRadialTree","Element","Children","dataHintsHandler","establishDataType","sstyled","styles","Component","style","uniqueIDEnhancement","angleOffset","centralMargin","labelMargin","iconColor","capSize","iconSize","defaultActiveKey","RadialTreeRadian","renderRadian","computeRadianPosition","xStart","yStart","xLabelCenter","yLabelCenter","strokeWidth","xEnd","yEnd","transparent","color","stroke","isActive","icon","labelAngle","isHorizontal","angle","getRadianKey","baseCapSize","minDemSize","min","topAngle","xCenter","yCenter","start","cos","sin","end","labelCenter","SRadian","children","getOriginChildren","_child","mergedProps","assignProps","describeValueEntity","InteractiveArea","RadialTree","Radian","SRadianList","SInteractiveArea","Line","SLine","Cap","SCap","radius","Icon","SIcon","tag","Label","SLabel","lines","String","split","linesCount","SLabelLine","angleDegs","toFixed","transformOrigin","transform","join","sstyles","sLabelStyles","cn","shade","className","lineText","lineIndex","createElement","Title","STitle","setTitle"],"sources":["../../src/RadialTree.tsx"],"sourcesContent":["import React from 'react';\nimport { transition } from 'd3-transition';\nimport { Component, sstyled, ReturnEl } from '@semcore/core';\nimport uniqueIDEnhancement from '@semcore/utils/lib/uniqueID';\nimport { shade } from '@semcore/utils/lib/color';\nimport assignProps from '@semcore/utils/lib/assignProps';\nimport getOriginChildren from '@semcore/utils/lib/getOriginChildren';\nimport createElement from './createElement';\nimport { measureText } from './utils';\nimport { DataHintsHandler } from './a11y/hints';\n\nimport style from './style/radial-tree.shadow.css';\nimport type { MapProps } from './types';\n\nconst baseAngle = -Math.PI / 2; // The top vertical line\n\ntype RadianData = {\n /**\n * Text label on the end of radian.\n */\n label: string;\n /**\n * Radian key. Radian, which `key` is equal to `activeKey` is displayed as active.\n */\n key: string;\n /**\n * Size of the cap (filled circle on the end of the radian).\n * @default 16\n */\n capSize?: number;\n /**\n * Icon, that displayed in the cap of the active radian (usage example `icon: UserM`).\n */\n icon?: React.FC;\n /**\n * Color of radian's line, cap and label.\n * @default #008FF8\n */\n color?: string;\n /**\n * Color of icon.\n * @default #fff\n */\n iconColor?: string;\n /**\n * Size of icon.\n * @default 16\n */\n iconSize?: number;\n};\n\nexport interface IRadialTreeProps {\n /**\n * List of radians. `{ label: string; key: string; capSize?: number; icon?: React.FC; color?: string; iconColor?: string; iconSize?: number; }`\n */\n data: RadianData[];\n /**\n * Angel (in rads) that rotates chart. 0 means that first radian is exactly on top vertical line.\n * @default 0\n */\n angleOffset?: number;\n /**\n * Duration of appear and update animation.\n * @default 300\n */\n duration?: number;\n /**\n * Gap between the chart center and radians start point.\n * @default 50\n */\n centralMargin?: number;\n /**\n * Gap around text label.\n * @default 2\n */\n labelMargin?: number;\n /**\n * Color of all radian's line, cap and label.\n * @default #008FF8\n */\n color?: string;\n /**\n * Size of the cap (filled circle on the end of the radian).\n * @default 16\n */\n capSize?: number;\n /**\n * Icon, that displayed in the cap of the active radian (usage example `icon: UserM`).\n */\n icon?: React.FC;\n /**\n * Color of icon.\n * @default #fff\n */\n iconColor?: string;\n /**\n * Size of icon.\n * @default 16\n */\n iconSize?: number;\n /**\n * Text size in radians' labels. 1.5x is used as default text size of center text.\n * @default 14\n */\n textSize?: number;\n /**\n * Used to define the active radian in controlled way. Active radian is highligted with inreased cap size.\n */\n activeKey?: string | null;\n /**\n * Default value for `activeKey` property.\n */\n defaultActiveKey?: string | null;\n /** Enables element transparency */\n transparent?: boolean;\n}\n\ntype RootAsProps = IRadialTreeProps & {\n uid: string;\n styles: React.CSSProperties;\n activeKey: string | null;\n Children: React.FC;\n size: [width: number, height: number];\n data: RadianData[];\n duration: number;\n textSize: number;\n capSize: number;\n centralMargin: number;\n labelMargin: number;\n angleOffset: number;\n transparent: boolean;\n $rootProps: RootAsProps;\n dataHintsHandler: DataHintsHandler;\n};\n\nclass RadialTreeBase extends Component<RootAsProps> {\n static displayName = 'RadialTree';\n static style = style;\n static enhance = [uniqueIDEnhancement()];\n\n static defaultProps: Partial<IRadialTreeProps> = {\n angleOffset: 0,\n duration: 300,\n centralMargin: 50,\n labelMargin: 5,\n iconColor: '#fff',\n capSize: 8,\n iconSize: 8,\n textSize: 14,\n defaultActiveKey: null,\n };\n\n Element!: React.FC<{ children?: React.ReactNode; render: string }>;\n\n constructor(props: any) {\n super(props);\n this.handleRadianClick = this.handleRadianClick.bind(this);\n }\n\n uncontrolledProps() {\n return {\n activeKey: null,\n };\n }\n\n runAppearAnimation() {\n const { duration, uid } = this.asProps;\n const preferReduceMotion = window.matchMedia('(prefers-reduced-motion: reduce)')?.matches;\n\n /** using `!(>)` instead of `<=` to get true on NaN and non numbers stuff */\n if (!(duration > 0)) return;\n if (preferReduceMotion) return;\n\n const circlesAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-cap-circle]`).interrupt()\n const iconsAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-cap-icon]`).interrupt()\n const linesAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-line]`).interrupt()\n const labelsAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-label]`).interrupt()\n const circlesNodes = circlesAnimation.nodes() as SVGCircleElement[];\n const iconsNodes = iconsAnimation.nodes() as SVGRectElement[];\n const linesNodes = linesAnimation.nodes() as SVGLineElement[];\n const labelsNodes = linesAnimation.nodes() as SVGTextElement[];\n\n if (circlesNodes.length > 0) {\n const attrs = circlesNodes.map((node) => {\n const radianIndex = parseInt(node.dataset.radianIndex!, 10);\n const lineNode = linesNodes[radianIndex];\n return {\n from: {\n cx: lineNode.x1?.baseVal?.value,\n cy: lineNode.y1?.baseVal?.value,\n },\n to: {\n cx: node.dataset['cx'],\n cy: node.dataset['cy'],\n },\n };\n });\n\n circlesAnimation\n .attr('opacity', 0)\n .attr('cx', (_, index) => attrs[index].from?.cx)\n .attr('cy', (_, index) => attrs[index].from?.cy)\n .transition()\n .duration(duration)\n .attr('opacity', 1)\n .attr('cx', (_, index) => attrs[index].to?.cx)\n .attr('cy', (_, index) => attrs[index].to?.cy);\n }\n if (iconsNodes.length > 0) {\n const attrs = iconsNodes.map((node) => {\n const width = node.width?.baseVal?.value;\n const height = node.height?.baseVal?.value;\n const radianIndex = parseInt(node.dataset.radianIndex!, 10);\n const lineNode = linesNodes[radianIndex];\n return {\n from: {\n x: lineNode.x1?.baseVal?.value - width / 2,\n y: lineNode.y1?.baseVal?.value - height / 2,\n },\n to: {\n x: node.dataset['x'],\n y: node.dataset['y'],\n },\n };\n });\n\n iconsAnimation\n .attr('opacity', 0)\n .attr('x', (_, index) => attrs[index].from?.x)\n .attr('y', (_, index) => attrs[index].from?.y)\n .transition()\n .duration(duration)\n .attr('opacity', 1)\n .attr('x', (_, index) => attrs[index].to?.x)\n .attr('y', (_, index) => attrs[index].to?.y);\n }\n if (linesNodes.length > 0) {\n const attrs = linesNodes.map((node) => {\n return {\n from: {\n x2: node.x1?.baseVal?.value,\n y2: node.y1?.baseVal?.value,\n },\n to: {\n x2: node.dataset['x2'],\n y2: node.dataset['y2'],\n },\n };\n });\n\n linesAnimation\n .attr('opacity', 0)\n .attr('x2', (_, index) => attrs[index].from?.x2)\n .attr('y2', (_, index) => attrs[index].from?.y2)\n .transition()\n .duration(duration)\n .attr('opacity', 1)\n .attr('x2', (_, index) => attrs[index].to?.x2)\n .attr('y2', (_, index) => attrs[index].to?.y2);\n }\n if (labelsNodes.length > 0) {\n labelsAnimation.attr('opacity', 0);\n labelsAnimation.transition().duration(duration).attr('opacity', 1);\n }\n }\n\n componentDidUpdate(prevProps: RootAsProps) {\n if (prevProps.$rootProps.data !== this.asProps.data) {\n this.runAppearAnimation();\n }\n }\n\n componentDidMount() {\n this.runAppearAnimation();\n }\n\n handleRadianClick(key: string) {\n return (event: React.MouseEvent) => {\n const newKey = key !== this.asProps.activeKey ? key : null;\n this.handlers.activeKey(newKey, event);\n };\n }\n\n computeTextWidth() {\n const { data, textSize } = this.asProps;\n const widths = data.map(({ label }) => measureText(label, textSize));\n\n return Math.max(...widths);\n }\n\n getTitleProps() {\n const { uid, size, textSize } = this.asProps;\n\n const [width, height] = size;\n const center = [width / 2, height / 2];\n const [x, y] = center;\n return {\n x,\n y,\n textSize: textSize * 1.5,\n ['data-radial-animation']: `${uid}-label`,\n } as IRadialTreeTitleProps;\n }\n\n getRadianProps() {\n const { data, ...restRootProps } = this.asProps;\n const textWidth = this.computeTextWidth();\n\n return {\n ...restRootProps,\n radiansCount: data.length,\n data,\n textWidth,\n onRadianClick: this.handleRadianClick,\n } as IRadialTreeRadianProps;\n }\n\n render() {\n const SRadialTree = this.Element;\n const { Children } = this.asProps;\n this.asProps.dataHintsHandler.establishDataType('values-set');\n\n return sstyled(this.asProps.styles)(\n <SRadialTree render='g'>\n <Children />\n </SRadialTree>,\n );\n }\n}\n\nexport interface IRadialTreeRadianProps extends IRadialTreeProps {\n radiansCount?: number;\n textWidth?: number;\n onRadianClick?: (key: string) => (event: React.MouseEvent) => void;\n}\n\ntype RadianAsProps = RootAsProps & {\n radiansCount: number;\n textWidth: number;\n onRadianClick: (key: string) => (event: React.MouseEvent) => void;\n};\n\nclass RadialTreeRadian extends Component<RadianAsProps> {\n static displayName = 'RadialTreeRadian';\n static style = style;\n\n static defaultProps: Partial<IRadialTreeRadianProps> = {\n centralMargin: 50,\n labelMargin: 2,\n iconColor: '#fff',\n capSize: 16,\n iconSize: 16,\n textSize: 14,\n };\n Element!: React.FC<{ render: string }>;\n\n constructor(props: any) {\n super(props);\n this.renderRadian = this.renderRadian.bind(this);\n }\n\n getInteractiveAreaProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xStart, yStart, xLabelCenter, yLabelCenter, capSize } = this.computeRadianPosition(\n data,\n index,\n );\n\n return {\n x1: xStart,\n y1: yStart,\n x2: xLabelCenter,\n y2: yLabelCenter,\n strokeWidth: capSize * 3,\n } as IRadialTreeRadianInteractiveAreaProps;\n }\n\n getLineProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xStart, yStart, xEnd, yEnd } = this.computeRadianPosition(data, index);\n const { uid, transparent } = this.asProps;\n const color = data.color ?? this.asProps.color;\n\n return {\n x1: xStart,\n y1: yStart,\n x2: xEnd,\n y2: yEnd,\n stroke: color,\n transparent,\n ['data-x1']: xStart,\n ['data-y1']: yStart,\n ['data-x2']: xEnd,\n ['data-y2']: yEnd,\n ['data-radial-animation']: `${uid}-line`,\n ['data-radian-index']: index,\n } as IRadialTreeRadianLineProps;\n }\n\n getCapProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xEnd, yEnd, capSize } = this.computeRadianPosition(data, index);\n const { uid, transparent } = this.asProps;\n const color = data.color ?? this.asProps.color;\n\n return {\n x: xEnd,\n y: yEnd,\n ['data-cx']: xEnd,\n ['data-cy']: yEnd,\n radius: capSize,\n color,\n transparent,\n ['data-radial-animation']: `${uid}-cap-circle`,\n ['data-radian-index']: index,\n } as IRadialTreeRadianCapProps;\n }\n\n getIconProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xEnd, yEnd, isActive } = this.computeRadianPosition(data, index);\n const { uid } = this.asProps;\n const iconColor = data.iconColor ?? this.asProps.iconColor;\n const iconSize = data.iconSize ?? this.asProps.iconSize;\n const icon = data.icon ?? this.asProps.icon;\n const x = xEnd - iconSize! / 2;\n const y = yEnd - iconSize! / 2;\n return {\n x,\n y,\n ['data-x']: x,\n ['data-y']: y,\n iconSize,\n color: iconColor ?? '#fff',\n ['data-radial-animation']: `${uid}-cap-icon`,\n ['data-radian-index']: index,\n icon,\n isActive,\n } as IRadialTreeRadianIconProps;\n }\n\n getLabelProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xLabelCenter, yLabelCenter, labelAngle, isHorizontal } = this.computeRadianPosition(\n data,\n index,\n );\n const { uid, textSize, transparent } = this.asProps;\n const { label } = data;\n const color = data.color ?? this.asProps.color;\n\n return {\n x: xLabelCenter,\n y: yLabelCenter,\n angle: labelAngle,\n ['data-radial-animation']: `${uid}-label`,\n ['data-radian-index']: index,\n label,\n color,\n isHorizontal,\n textSize,\n transparent,\n } as IRadialTreeRadianLabelProps;\n }\n\n getRadianKey(data: RadianData, index: number) {\n return data.key ?? `radian-${index}`;\n }\n\n computeRadianPosition(data: RadianData, index: number) {\n const { centralMargin, labelMargin, angleOffset, activeKey, size, radiansCount, textWidth } =\n this.asProps;\n const [width, height] = size;\n const key = this.getRadianKey(data, index);\n const isActive = activeKey === key;\n const baseCapSize = data.capSize ?? this.asProps.capSize;\n const capSize = baseCapSize * (isActive ? 1 : 0.5);\n\n const minDemSize = Math.min(width, height) / 2;\n const length = Math.max(\n minDemSize - textWidth - baseCapSize - centralMargin - labelMargin * 2,\n 10,\n );\n\n const angle = baseAngle + angleOffset + (index / radiansCount) * (Math.PI * 2);\n const isHorizontal =\n (angle - baseAngle > (1 / 6) * Math.PI && angle - baseAngle < (5 / 6) * Math.PI) ||\n (angle - baseAngle > (7 / 6) * Math.PI && angle - baseAngle < (11 / 6) * Math.PI);\n const topAngle = -Math.PI / 2;\n const labelAngle = ((angle - topAngle) % Math.PI) + topAngle;\n\n const center = [width / 2, height / 2];\n const [xCenter, yCenter] = center;\n const start = [\n xCenter + Math.cos(angle) * centralMargin,\n yCenter + Math.sin(angle) * centralMargin,\n ];\n const end = [\n xCenter + Math.cos(angle) * (centralMargin + length),\n yCenter + Math.sin(angle) * (centralMargin + length),\n ];\n const [xStart, yStart] = start;\n const [xEnd, yEnd] = end;\n\n const labelCenter = [\n xCenter +\n Math.cos(angle) * (centralMargin + length + baseCapSize + textWidth / 2 + labelMargin),\n yCenter +\n Math.sin(angle) * (centralMargin + length + baseCapSize + textWidth / 2 + labelMargin),\n ];\n const [xLabelCenter, yLabelCenter] = labelCenter;\n\n return {\n xStart,\n yStart,\n xEnd,\n yEnd,\n xLabelCenter,\n yLabelCenter,\n labelAngle,\n isHorizontal,\n capSize,\n isActive,\n };\n }\n\n renderRadian(data: RadianData, index: number) {\n const { styles, Children, onRadianClick } = this.asProps;\n const key = this.getRadianKey(data, index);\n const SRadian = 'g';\n\n let children = getOriginChildren(Children);\n\n if (typeof children === 'function') {\n const _child = this.asProps.children;\n const mergedProps = assignProps(children(this.asProps), this.asProps);\n children = mergedProps.children;\n mergedProps.children = _child;\n }\n\n this.asProps.dataHintsHandler.describeValueEntity(`${index}.${data.label}`, data.label);\n\n // hidden from publicly typed export\n const InteractiveArea = (RadialTree.Radian as any).InteractiveArea;\n\n return sstyled(styles)(\n <SRadian aria-hidden key={key} onClick={onRadianClick(key)}>\n <InteractiveArea />\n {children}\n </SRadian>,\n );\n }\n\n render() {\n const { data } = this.asProps;\n const SRadianList = 'g';\n\n return sstyled(this.asProps.styles)(\n <SRadianList>{data.map((data, index) => this.renderRadian(data, index))}</SRadianList>,\n );\n }\n}\n\nexport interface IRadialTreeRadianInteractiveAreaProps {\n x1?: number;\n y1?: number;\n x2?: number;\n y2?: number;\n strokeWidth?: number;\n}\n\ntype RadialTreeRadianInteractiveAreaAsProps = IRadialTreeRadianInteractiveAreaProps & {\n Element: React.FC<{ render: string } & React.SVGProps<any>>;\n styles: React.CSSProperties;\n};\nconst InteractiveArea: React.FC<RadialTreeRadianInteractiveAreaAsProps> = ({\n Element: SInteractiveArea,\n styles,\n}) => {\n return sstyled(styles)(\n <SInteractiveArea stroke='transparent' render='line' />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianLineProps {\n x1?: number;\n y1?: number;\n x2?: number;\n y2?: number;\n stroke?: string;\n transparent?: boolean;\n ['data-radial-animation']?: `${string}-line`;\n ['data-radian-index']?: number;\n}\n\ntype RadialTreeRadianLineAsProps = IRadialTreeRadianLineProps & {\n Element: React.FC<{ render: string; transparent: boolean } & React.SVGProps<any>>;\n styles: React.CSSProperties;\n};\nconst Line: React.FC<RadialTreeRadianLineAsProps> = ({\n Element: SLine,\n styles,\n stroke,\n transparent,\n}) => {\n return sstyled(styles)(\n <SLine render='line' stroke={stroke} transparent={transparent} />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianCapProps {\n x?: number;\n y?: number;\n radius?: number;\n color?: string;\n transparent?: boolean;\n ['data-radial-animation']?: `${string}-cap-circle`;\n ['data-radian-index']?: number;\n}\n\ntype RadialTreeRadianCapAsProps = IRadialTreeRadianCapProps & {\n Element: React.FC<{ render: string; transparent: boolean } & React.SVGProps<any>>;\n styles: React.CSSProperties;\n};\nconst Cap: React.FC<RadialTreeRadianCapAsProps> = ({\n Element: SCap,\n styles,\n x,\n y,\n radius,\n color,\n transparent,\n}) => {\n return sstyled(styles)(\n <SCap render='circle' cx={x} cy={y} r={radius} fill={color} transparent={transparent} />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianIconProps {\n x?: number;\n y?: number;\n iconSize?: number;\n color?: string;\n ['data-radial-animation']?: `${string}-cap-icon`;\n ['data-radian-index']?: number;\n tag?: React.FC;\n isActive?: boolean;\n transparent?: boolean;\n}\n\ntype RadialTreeRadianIconAsProps = IRadialTreeRadianIconProps & {\n Element: React.FC<{ render: string | React.FC; transparent: boolean } & React.SVGProps<any>>;\n x: number;\n y: number;\n iconSize: number;\n styles: React.CSSProperties;\n};\nconst Icon: React.FC<RadialTreeRadianIconAsProps> = ({\n Element: SIcon,\n styles,\n isActive,\n tag,\n x,\n y,\n iconSize,\n transparent,\n}) => {\n if (!(isActive && tag)) return null;\n const width = iconSize;\n const height = iconSize;\n return sstyled(styles)(\n <SIcon x={x} y={y} width={width} height={height} render={tag} transparent={transparent} />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianLabelProps {\n x?: number;\n y?: number;\n color?: string;\n textSize?: number;\n ['data-radial-animation']?: `${string}-label`;\n ['data-radian-index']?: number;\n label?: string;\n isHorizontal?: boolean;\n angle?: number;\n transparent?: boolean;\n}\n\ntype RadialTreeRadianLabelAsProps = IRadialTreeRadianLabelProps & {\n Element: React.FC<{ render: string } & React.SVGProps<any>>;\n Children: React.FC;\n styles: React.CSSProperties;\n x: number;\n y: number;\n angle: number;\n textSize: number;\n};\nconst Label: React.FC<RadialTreeRadianLabelAsProps> = ({\n Element: SLabel,\n Children,\n styles,\n label,\n color,\n isHorizontal,\n x,\n y,\n textSize,\n angle,\n transparent,\n}) => {\n const lines = String(label).split('\\n');\n const linesCount = lines.length;\n const SLabelLine = 'tspan';\n\n const angleDegs = ((angle / Math.PI) * 180).toFixed(2);\n const transformOrigin = [x.toFixed(2), y.toFixed(2)];\n const transform = `rotate(${[angleDegs, ...transformOrigin].join(', ')})`;\n\n const sstyles = sstyled(styles);\n const sLabelStyles = sstyles.cn('SLabel', {\n color,\n 'color-hovered': shade(color, -0.12),\n 'text-cursor': isHorizontal ? 'text' : 'vertical-text',\n transparent,\n });\n\n return (\n <SLabel\n aria-hidden\n render='text'\n textAnchor='middle'\n dominantBaseline='central'\n className={sLabelStyles.className}\n style={sLabelStyles.style}\n x={x.toFixed(2)}\n y={y.toFixed(2)}\n transform={transform}\n >\n {lines.map((lineText, lineIndex) => (\n <SLabelLine\n x={x}\n y={y + (lineIndex - (linesCount - 1) / 2) * textSize}\n key={`#${lineIndex}-${lineText}`}\n >\n {lineText}\n </SLabelLine>\n ))}\n <Children />\n </SLabel>\n ) as React.ReactElement;\n};\n\nconst Radian = createElement(RadialTreeRadian, {\n InteractiveArea,\n Line,\n Cap,\n Icon,\n Label,\n});\n\nexport interface IRadialTreeTitleProps {\n x?: number;\n y?: number;\n textSize?: number;\n ['data-radial-animation']?: `${string}-label`;\n color?: string;\n}\n\ntype RadialTreeTitleAsProps = IRadialTreeTitleProps & {\n Element: React.FC<{ render: string } & React.SVGProps<any>>;\n Children: React.FC;\n children: React.ReactNode;\n styles: React.CSSProperties;\n dataHintsHandler: DataHintsHandler;\n};\nconst Title: React.FC<RadialTreeTitleAsProps> = ({\n Element: STitle,\n Children,\n children,\n styles,\n textSize,\n color,\n x,\n y,\n dataHintsHandler,\n}) => {\n if (typeof children === 'string') {\n dataHintsHandler.setTitle('vertical', children);\n }\n return sstyled(styles)(\n <STitle\n aria-hidden\n render='text'\n textAnchor='middle'\n dominantBaseline='central'\n fontSize={textSize}\n fill={color}\n x={x}\n y={y}\n >\n <Children />\n </STitle>,\n ) as React.ReactElement;\n};\n\nconst RadialTree = createElement(RadialTreeBase, { Title, Radian }) as (<T>(\n props: MapProps<IRadialTreeProps & T>,\n) => ReturnEl) & {\n Title: <T>(props: MapProps<IRadialTreeTitleProps & T>) => ReturnEl;\n Radian: (<T>(props: MapProps<IRadialTreeRadianProps & T>) => ReturnEl) & {\n Line: <T>(props: MapProps<IRadialTreeRadianLineProps & T>) => ReturnEl;\n Cap: <T>(props: MapProps<IRadialTreeRadianCapProps & T>) => ReturnEl;\n Icon: <T>(props: MapProps<IRadialTreeRadianIconProps & T>) => ReturnEl;\n Label: <T>(props: MapProps<IRadialTreeRadianLabelProps & T>) => ReturnEl;\n };\n};\n\nexport default RadialTree;\n"],"mappings":"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"}
1
+ {"version":3,"file":"RadialTree.js","names":["baseAngle","Math","PI","RadialTreeBase","props","handleRadianClick","bind","activeKey","asProps","duration","uid","canUseDOM","preferReduceMotion","window","matchMedia","matches","circlesAnimation","transition","selection","selectAll","interrupt","iconsAnimation","linesAnimation","labelsAnimation","circlesNodes","nodes","iconsNodes","linesNodes","labelsNodes","length","attrs","map","node","radianIndex","parseInt","dataset","lineNode","from","cx","x1","baseVal","value","cy","y1","to","attr","_","index","width","height","x","y","x2","y2","prevProps","$rootProps","data","runAppearAnimation","key","event","newKey","handlers","textSize","widths","label","measureText","max","size","center","restRootProps","textWidth","computeTextWidth","radiansCount","onRadianClick","SRadialTree","Element","Children","dataHintsHandler","establishDataType","sstyled","styles","Component","style","uniqueIDEnhancement","angleOffset","centralMargin","labelMargin","iconColor","capSize","iconSize","defaultActiveKey","RadialTreeRadian","renderRadian","computeRadianPosition","xStart","yStart","xLabelCenter","yLabelCenter","strokeWidth","xEnd","yEnd","transparent","color","stroke","isActive","icon","labelAngle","isHorizontal","angle","getRadianKey","baseCapSize","minDemSize","min","topAngle","xCenter","yCenter","start","cos","sin","end","labelCenter","SRadian","children","getOriginChildren","_child","mergedProps","assignProps","describeValueEntity","InteractiveArea","RadialTree","Radian","SRadianList","SInteractiveArea","Line","SLine","Cap","SCap","radius","Icon","SIcon","tag","Label","SLabel","lines","String","split","linesCount","SLabelLine","angleDegs","toFixed","transformOrigin","transform","join","sstyles","sLabelStyles","cn","shade","className","lineText","lineIndex","createElement","Title","STitle","setTitle"],"sources":["../../src/RadialTree.tsx"],"sourcesContent":["import React from 'react';\nimport { transition } from 'd3-transition';\nimport { Component, sstyled, ReturnEl } from '@semcore/core';\nimport uniqueIDEnhancement from '@semcore/utils/lib/uniqueID';\nimport { shade } from '@semcore/utils/lib/color';\nimport assignProps from '@semcore/utils/lib/assignProps';\nimport getOriginChildren from '@semcore/utils/lib/getOriginChildren';\nimport canUseDOM from '@semcore/utils/lib/canUseDOM';\nimport createElement from './createElement';\nimport { measureText } from './utils';\nimport { DataHintsHandler } from './a11y/hints';\n\nimport style from './style/radial-tree.shadow.css';\nimport type { MapProps } from './types';\n\nconst baseAngle = -Math.PI / 2; // The top vertical line\n\ntype RadianData = {\n /**\n * Text label on the end of radian.\n */\n label: string;\n /**\n * Radian key. Radian, which `key` is equal to `activeKey` is displayed as active.\n */\n key: string;\n /**\n * Size of the cap (filled circle on the end of the radian).\n * @default 16\n */\n capSize?: number;\n /**\n * Icon, that displayed in the cap of the active radian (usage example `icon: UserM`).\n */\n icon?: React.FC;\n /**\n * Color of radian's line, cap and label.\n * @default #008FF8\n */\n color?: string;\n /**\n * Color of icon.\n * @default #fff\n */\n iconColor?: string;\n /**\n * Size of icon.\n * @default 16\n */\n iconSize?: number;\n};\n\nexport interface IRadialTreeProps {\n /**\n * List of radians. `{ label: string; key: string; capSize?: number; icon?: React.FC; color?: string; iconColor?: string; iconSize?: number; }`\n */\n data: RadianData[];\n /**\n * Angel (in rads) that rotates chart. 0 means that first radian is exactly on top vertical line.\n * @default 0\n */\n angleOffset?: number;\n /**\n * Duration of appear and update animation.\n * @default 300\n */\n duration?: number;\n /**\n * Gap between the chart center and radians start point.\n * @default 50\n */\n centralMargin?: number;\n /**\n * Gap around text label.\n * @default 2\n */\n labelMargin?: number;\n /**\n * Color of all radian's line, cap and label.\n * @default #008FF8\n */\n color?: string;\n /**\n * Size of the cap (filled circle on the end of the radian).\n * @default 16\n */\n capSize?: number;\n /**\n * Icon, that displayed in the cap of the active radian (usage example `icon: UserM`).\n */\n icon?: React.FC;\n /**\n * Color of icon.\n * @default #fff\n */\n iconColor?: string;\n /**\n * Size of icon.\n * @default 16\n */\n iconSize?: number;\n /**\n * Text size in radians' labels. 1.5x is used as default text size of center text.\n * @default 14\n */\n textSize?: number;\n /**\n * Used to define the active radian in controlled way. Active radian is highligted with inreased cap size.\n */\n activeKey?: string | null;\n /**\n * Default value for `activeKey` property.\n */\n defaultActiveKey?: string | null;\n /** Enables element transparency */\n transparent?: boolean;\n}\n\ntype RootAsProps = IRadialTreeProps & {\n uid: string;\n styles: React.CSSProperties;\n activeKey: string | null;\n Children: React.FC;\n size: [width: number, height: number];\n data: RadianData[];\n duration: number;\n textSize: number;\n capSize: number;\n centralMargin: number;\n labelMargin: number;\n angleOffset: number;\n transparent: boolean;\n $rootProps: RootAsProps;\n dataHintsHandler: DataHintsHandler;\n};\n\nclass RadialTreeBase extends Component<RootAsProps> {\n static displayName = 'RadialTree';\n static style = style;\n static enhance = [uniqueIDEnhancement()];\n\n static defaultProps: Partial<IRadialTreeProps> = {\n angleOffset: 0,\n duration: 300,\n centralMargin: 50,\n labelMargin: 5,\n iconColor: '#fff',\n capSize: 8,\n iconSize: 8,\n textSize: 14,\n defaultActiveKey: null,\n };\n\n Element!: React.FC<{ children?: React.ReactNode; render: string }>;\n\n constructor(props: any) {\n super(props);\n this.handleRadianClick = this.handleRadianClick.bind(this);\n }\n\n uncontrolledProps() {\n return {\n activeKey: null,\n };\n }\n\n runAppearAnimation() {\n const { duration, uid } = this.asProps;\n if (!canUseDOM()) return;\n const preferReduceMotion = window.matchMedia('(prefers-reduced-motion: reduce)')?.matches;\n\n /** using `!(>)` instead of `<=` to get true on NaN and non numbers stuff */\n if (!(duration > 0)) return;\n if (preferReduceMotion) return;\n\n const circlesAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-cap-circle]`).interrupt()\n const iconsAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-cap-icon]`).interrupt()\n const linesAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-line]`).interrupt()\n const labelsAnimation = transition()\n .selection()\n .selectAll(`[data-radial-animation=${uid}-label]`).interrupt()\n const circlesNodes = circlesAnimation.nodes() as SVGCircleElement[];\n const iconsNodes = iconsAnimation.nodes() as SVGRectElement[];\n const linesNodes = linesAnimation.nodes() as SVGLineElement[];\n const labelsNodes = linesAnimation.nodes() as SVGTextElement[];\n\n if (circlesNodes.length > 0) {\n const attrs = circlesNodes.map((node) => {\n const radianIndex = parseInt(node.dataset.radianIndex!, 10);\n const lineNode = linesNodes[radianIndex];\n return {\n from: {\n cx: lineNode.x1?.baseVal?.value,\n cy: lineNode.y1?.baseVal?.value,\n },\n to: {\n cx: node.dataset['cx'],\n cy: node.dataset['cy'],\n },\n };\n });\n\n circlesAnimation\n .attr('opacity', 0)\n .attr('cx', (_, index) => attrs[index].from?.cx)\n .attr('cy', (_, index) => attrs[index].from?.cy)\n .transition()\n .duration(duration)\n .attr('opacity', 1)\n .attr('cx', (_, index) => attrs[index].to?.cx)\n .attr('cy', (_, index) => attrs[index].to?.cy);\n }\n if (iconsNodes.length > 0) {\n const attrs = iconsNodes.map((node) => {\n const width = node.width?.baseVal?.value;\n const height = node.height?.baseVal?.value;\n const radianIndex = parseInt(node.dataset.radianIndex!, 10);\n const lineNode = linesNodes[radianIndex];\n return {\n from: {\n x: lineNode.x1?.baseVal?.value - width / 2,\n y: lineNode.y1?.baseVal?.value - height / 2,\n },\n to: {\n x: node.dataset['x'],\n y: node.dataset['y'],\n },\n };\n });\n\n iconsAnimation\n .attr('opacity', 0)\n .attr('x', (_, index) => attrs[index].from?.x)\n .attr('y', (_, index) => attrs[index].from?.y)\n .transition()\n .duration(duration)\n .attr('opacity', 1)\n .attr('x', (_, index) => attrs[index].to?.x)\n .attr('y', (_, index) => attrs[index].to?.y);\n }\n if (linesNodes.length > 0) {\n const attrs = linesNodes.map((node) => {\n return {\n from: {\n x2: node.x1?.baseVal?.value,\n y2: node.y1?.baseVal?.value,\n },\n to: {\n x2: node.dataset['x2'],\n y2: node.dataset['y2'],\n },\n };\n });\n\n linesAnimation\n .attr('opacity', 0)\n .attr('x2', (_, index) => attrs[index].from?.x2)\n .attr('y2', (_, index) => attrs[index].from?.y2)\n .transition()\n .duration(duration)\n .attr('opacity', 1)\n .attr('x2', (_, index) => attrs[index].to?.x2)\n .attr('y2', (_, index) => attrs[index].to?.y2);\n }\n if (labelsNodes.length > 0) {\n labelsAnimation.attr('opacity', 0);\n labelsAnimation.transition().duration(duration).attr('opacity', 1);\n }\n }\n\n componentDidUpdate(prevProps: RootAsProps) {\n if (prevProps.$rootProps.data !== this.asProps.data) {\n this.runAppearAnimation();\n }\n }\n\n componentDidMount() {\n this.runAppearAnimation();\n }\n\n handleRadianClick(key: string) {\n return (event: React.MouseEvent) => {\n const newKey = key !== this.asProps.activeKey ? key : null;\n this.handlers.activeKey(newKey, event);\n };\n }\n\n computeTextWidth() {\n const { data, textSize } = this.asProps;\n const widths = data.map(({ label }) => measureText(label, textSize));\n\n return Math.max(...widths);\n }\n\n getTitleProps() {\n const { uid, size, textSize } = this.asProps;\n\n const [width, height] = size;\n const center = [width / 2, height / 2];\n const [x, y] = center;\n return {\n x,\n y,\n textSize: textSize * 1.5,\n ['data-radial-animation']: `${uid}-label`,\n } as IRadialTreeTitleProps;\n }\n\n getRadianProps() {\n const { data, ...restRootProps } = this.asProps;\n const textWidth = this.computeTextWidth();\n\n return {\n ...restRootProps,\n radiansCount: data.length,\n data,\n textWidth,\n onRadianClick: this.handleRadianClick,\n } as IRadialTreeRadianProps;\n }\n\n render() {\n const SRadialTree = this.Element;\n const { Children } = this.asProps;\n this.asProps.dataHintsHandler.establishDataType('values-set');\n\n return sstyled(this.asProps.styles)(\n <SRadialTree render='g'>\n <Children />\n </SRadialTree>,\n );\n }\n}\n\nexport interface IRadialTreeRadianProps extends IRadialTreeProps {\n radiansCount?: number;\n textWidth?: number;\n onRadianClick?: (key: string) => (event: React.MouseEvent) => void;\n}\n\ntype RadianAsProps = RootAsProps & {\n radiansCount: number;\n textWidth: number;\n onRadianClick: (key: string) => (event: React.MouseEvent) => void;\n};\n\nclass RadialTreeRadian extends Component<RadianAsProps> {\n static displayName = 'RadialTreeRadian';\n static style = style;\n\n static defaultProps: Partial<IRadialTreeRadianProps> = {\n centralMargin: 50,\n labelMargin: 2,\n iconColor: '#fff',\n capSize: 16,\n iconSize: 16,\n textSize: 14,\n };\n Element!: React.FC<{ render: string }>;\n\n constructor(props: any) {\n super(props);\n this.renderRadian = this.renderRadian.bind(this);\n }\n\n getInteractiveAreaProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xStart, yStart, xLabelCenter, yLabelCenter, capSize } = this.computeRadianPosition(\n data,\n index,\n );\n\n return {\n x1: xStart,\n y1: yStart,\n x2: xLabelCenter,\n y2: yLabelCenter,\n strokeWidth: capSize * 3,\n } as IRadialTreeRadianInteractiveAreaProps;\n }\n\n getLineProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xStart, yStart, xEnd, yEnd } = this.computeRadianPosition(data, index);\n const { uid, transparent } = this.asProps;\n const color = data.color ?? this.asProps.color;\n\n return {\n x1: xStart,\n y1: yStart,\n x2: xEnd,\n y2: yEnd,\n stroke: color,\n transparent,\n ['data-x1']: xStart,\n ['data-y1']: yStart,\n ['data-x2']: xEnd,\n ['data-y2']: yEnd,\n ['data-radial-animation']: `${uid}-line`,\n ['data-radian-index']: index,\n } as IRadialTreeRadianLineProps;\n }\n\n getCapProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xEnd, yEnd, capSize } = this.computeRadianPosition(data, index);\n const { uid, transparent } = this.asProps;\n const color = data.color ?? this.asProps.color;\n\n return {\n x: xEnd,\n y: yEnd,\n ['data-cx']: xEnd,\n ['data-cy']: yEnd,\n radius: capSize,\n color,\n transparent,\n ['data-radial-animation']: `${uid}-cap-circle`,\n ['data-radian-index']: index,\n } as IRadialTreeRadianCapProps;\n }\n\n getIconProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xEnd, yEnd, isActive } = this.computeRadianPosition(data, index);\n const { uid } = this.asProps;\n const iconColor = data.iconColor ?? this.asProps.iconColor;\n const iconSize = data.iconSize ?? this.asProps.iconSize;\n const icon = data.icon ?? this.asProps.icon;\n const x = xEnd - iconSize! / 2;\n const y = yEnd - iconSize! / 2;\n return {\n x,\n y,\n ['data-x']: x,\n ['data-y']: y,\n iconSize,\n color: iconColor ?? '#fff',\n ['data-radial-animation']: `${uid}-cap-icon`,\n ['data-radian-index']: index,\n icon,\n isActive,\n } as IRadialTreeRadianIconProps;\n }\n\n getLabelProps({ $rootProps }: { $rootProps: IRadialTreeProps }, index: number) {\n const data = $rootProps.data![index];\n const { xLabelCenter, yLabelCenter, labelAngle, isHorizontal } = this.computeRadianPosition(\n data,\n index,\n );\n const { uid, textSize, transparent } = this.asProps;\n const { label } = data;\n const color = data.color ?? this.asProps.color;\n\n return {\n x: xLabelCenter,\n y: yLabelCenter,\n angle: labelAngle,\n ['data-radial-animation']: `${uid}-label`,\n ['data-radian-index']: index,\n label,\n color,\n isHorizontal,\n textSize,\n transparent,\n } as IRadialTreeRadianLabelProps;\n }\n\n getRadianKey(data: RadianData, index: number) {\n return data.key ?? `radian-${index}`;\n }\n\n computeRadianPosition(data: RadianData, index: number) {\n const { centralMargin, labelMargin, angleOffset, activeKey, size, radiansCount, textWidth } =\n this.asProps;\n const [width, height] = size;\n const key = this.getRadianKey(data, index);\n const isActive = activeKey === key;\n const baseCapSize = data.capSize ?? this.asProps.capSize;\n const capSize = baseCapSize * (isActive ? 1 : 0.5);\n\n const minDemSize = Math.min(width, height) / 2;\n const length = Math.max(\n minDemSize - textWidth - baseCapSize - centralMargin - labelMargin * 2,\n 10,\n );\n\n const angle = baseAngle + angleOffset + (index / radiansCount) * (Math.PI * 2);\n const isHorizontal =\n (angle - baseAngle > (1 / 6) * Math.PI && angle - baseAngle < (5 / 6) * Math.PI) ||\n (angle - baseAngle > (7 / 6) * Math.PI && angle - baseAngle < (11 / 6) * Math.PI);\n const topAngle = -Math.PI / 2;\n const labelAngle = ((angle - topAngle) % Math.PI) + topAngle;\n\n const center = [width / 2, height / 2];\n const [xCenter, yCenter] = center;\n const start = [\n xCenter + Math.cos(angle) * centralMargin,\n yCenter + Math.sin(angle) * centralMargin,\n ];\n const end = [\n xCenter + Math.cos(angle) * (centralMargin + length),\n yCenter + Math.sin(angle) * (centralMargin + length),\n ];\n const [xStart, yStart] = start;\n const [xEnd, yEnd] = end;\n\n const labelCenter = [\n xCenter +\n Math.cos(angle) * (centralMargin + length + baseCapSize + textWidth / 2 + labelMargin),\n yCenter +\n Math.sin(angle) * (centralMargin + length + baseCapSize + textWidth / 2 + labelMargin),\n ];\n const [xLabelCenter, yLabelCenter] = labelCenter;\n\n return {\n xStart,\n yStart,\n xEnd,\n yEnd,\n xLabelCenter,\n yLabelCenter,\n labelAngle,\n isHorizontal,\n capSize,\n isActive,\n };\n }\n\n renderRadian(data: RadianData, index: number) {\n const { styles, Children, onRadianClick } = this.asProps;\n const key = this.getRadianKey(data, index);\n const SRadian = 'g';\n\n let children = getOriginChildren(Children);\n\n if (typeof children === 'function') {\n const _child = this.asProps.children;\n const mergedProps = assignProps(children(this.asProps), this.asProps);\n children = mergedProps.children;\n mergedProps.children = _child;\n }\n\n this.asProps.dataHintsHandler.describeValueEntity(`${index}.${data.label}`, data.label);\n\n // hidden from publicly typed export\n const InteractiveArea = (RadialTree.Radian as any).InteractiveArea;\n\n return sstyled(styles)(\n <SRadian aria-hidden key={key} onClick={onRadianClick(key)}>\n <InteractiveArea />\n {children}\n </SRadian>,\n );\n }\n\n render() {\n const { data } = this.asProps;\n const SRadianList = 'g';\n\n return sstyled(this.asProps.styles)(\n <SRadianList>{data.map((data, index) => this.renderRadian(data, index))}</SRadianList>,\n );\n }\n}\n\nexport interface IRadialTreeRadianInteractiveAreaProps {\n x1?: number;\n y1?: number;\n x2?: number;\n y2?: number;\n strokeWidth?: number;\n}\n\ntype RadialTreeRadianInteractiveAreaAsProps = IRadialTreeRadianInteractiveAreaProps & {\n Element: React.FC<{ render: string } & React.SVGProps<any>>;\n styles: React.CSSProperties;\n};\nconst InteractiveArea: React.FC<RadialTreeRadianInteractiveAreaAsProps> = ({\n Element: SInteractiveArea,\n styles,\n}) => {\n return sstyled(styles)(\n <SInteractiveArea stroke='transparent' render='line' />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianLineProps {\n x1?: number;\n y1?: number;\n x2?: number;\n y2?: number;\n stroke?: string;\n transparent?: boolean;\n ['data-radial-animation']?: `${string}-line`;\n ['data-radian-index']?: number;\n}\n\ntype RadialTreeRadianLineAsProps = IRadialTreeRadianLineProps & {\n Element: React.FC<{ render: string; transparent: boolean } & React.SVGProps<any>>;\n styles: React.CSSProperties;\n};\nconst Line: React.FC<RadialTreeRadianLineAsProps> = ({\n Element: SLine,\n styles,\n stroke,\n transparent,\n}) => {\n return sstyled(styles)(\n <SLine render='line' stroke={stroke} transparent={transparent} />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianCapProps {\n x?: number;\n y?: number;\n radius?: number;\n color?: string;\n transparent?: boolean;\n ['data-radial-animation']?: `${string}-cap-circle`;\n ['data-radian-index']?: number;\n}\n\ntype RadialTreeRadianCapAsProps = IRadialTreeRadianCapProps & {\n Element: React.FC<{ render: string; transparent: boolean } & React.SVGProps<any>>;\n styles: React.CSSProperties;\n};\nconst Cap: React.FC<RadialTreeRadianCapAsProps> = ({\n Element: SCap,\n styles,\n x,\n y,\n radius,\n color,\n transparent,\n}) => {\n return sstyled(styles)(\n <SCap render='circle' cx={x} cy={y} r={radius} fill={color} transparent={transparent} />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianIconProps {\n x?: number;\n y?: number;\n iconSize?: number;\n color?: string;\n ['data-radial-animation']?: `${string}-cap-icon`;\n ['data-radian-index']?: number;\n tag?: React.FC;\n isActive?: boolean;\n transparent?: boolean;\n}\n\ntype RadialTreeRadianIconAsProps = IRadialTreeRadianIconProps & {\n Element: React.FC<{ render: string | React.FC; transparent: boolean } & React.SVGProps<any>>;\n x: number;\n y: number;\n iconSize: number;\n styles: React.CSSProperties;\n};\nconst Icon: React.FC<RadialTreeRadianIconAsProps> = ({\n Element: SIcon,\n styles,\n isActive,\n tag,\n x,\n y,\n iconSize,\n transparent,\n}) => {\n if (!(isActive && tag)) return null;\n const width = iconSize;\n const height = iconSize;\n return sstyled(styles)(\n <SIcon x={x} y={y} width={width} height={height} render={tag} transparent={transparent} />,\n ) as React.ReactElement;\n};\n\nexport interface IRadialTreeRadianLabelProps {\n x?: number;\n y?: number;\n color?: string;\n textSize?: number;\n ['data-radial-animation']?: `${string}-label`;\n ['data-radian-index']?: number;\n label?: string;\n isHorizontal?: boolean;\n angle?: number;\n transparent?: boolean;\n}\n\ntype RadialTreeRadianLabelAsProps = IRadialTreeRadianLabelProps & {\n Element: React.FC<{ render: string } & React.SVGProps<any>>;\n Children: React.FC;\n styles: React.CSSProperties;\n x: number;\n y: number;\n angle: number;\n textSize: number;\n};\nconst Label: React.FC<RadialTreeRadianLabelAsProps> = ({\n Element: SLabel,\n Children,\n styles,\n label,\n color,\n isHorizontal,\n x,\n y,\n textSize,\n angle,\n transparent,\n}) => {\n const lines = String(label).split('\\n');\n const linesCount = lines.length;\n const SLabelLine = 'tspan';\n\n const angleDegs = ((angle / Math.PI) * 180).toFixed(2);\n const transformOrigin = [x.toFixed(2), y.toFixed(2)];\n const transform = `rotate(${[angleDegs, ...transformOrigin].join(', ')})`;\n\n const sstyles = sstyled(styles);\n const sLabelStyles = sstyles.cn('SLabel', {\n color,\n 'color-hovered': shade(color, -0.12),\n 'text-cursor': isHorizontal ? 'text' : 'vertical-text',\n transparent,\n });\n\n return (\n <SLabel\n aria-hidden\n render='text'\n textAnchor='middle'\n dominantBaseline='central'\n className={sLabelStyles.className}\n style={sLabelStyles.style}\n x={x.toFixed(2)}\n y={y.toFixed(2)}\n transform={transform}\n >\n {lines.map((lineText, lineIndex) => (\n <SLabelLine\n x={x}\n y={y + (lineIndex - (linesCount - 1) / 2) * textSize}\n key={`#${lineIndex}-${lineText}`}\n >\n {lineText}\n </SLabelLine>\n ))}\n <Children />\n </SLabel>\n ) as React.ReactElement;\n};\n\nconst Radian = createElement(RadialTreeRadian, {\n InteractiveArea,\n Line,\n Cap,\n Icon,\n Label,\n});\n\nexport interface IRadialTreeTitleProps {\n x?: number;\n y?: number;\n textSize?: number;\n ['data-radial-animation']?: `${string}-label`;\n color?: string;\n}\n\ntype RadialTreeTitleAsProps = IRadialTreeTitleProps & {\n Element: React.FC<{ render: string } & React.SVGProps<any>>;\n Children: React.FC;\n children: React.ReactNode;\n styles: React.CSSProperties;\n dataHintsHandler: DataHintsHandler;\n};\nconst Title: React.FC<RadialTreeTitleAsProps> = ({\n Element: STitle,\n Children,\n children,\n styles,\n textSize,\n color,\n x,\n y,\n dataHintsHandler,\n}) => {\n if (typeof children === 'string') {\n dataHintsHandler.setTitle('vertical', children);\n }\n return sstyled(styles)(\n <STitle\n aria-hidden\n render='text'\n textAnchor='middle'\n dominantBaseline='central'\n fontSize={textSize}\n fill={color}\n x={x}\n y={y}\n >\n <Children />\n </STitle>,\n ) as React.ReactElement;\n};\n\nconst RadialTree = createElement(RadialTreeBase, { Title, Radian }) as (<T>(\n props: MapProps<IRadialTreeProps & T>,\n) => ReturnEl) & {\n Title: <T>(props: MapProps<IRadialTreeTitleProps & T>) => ReturnEl;\n Radian: (<T>(props: MapProps<IRadialTreeRadianProps & T>) => ReturnEl) & {\n Line: <T>(props: MapProps<IRadialTreeRadianLineProps & T>) => ReturnEl;\n Cap: <T>(props: MapProps<IRadialTreeRadianCapProps & T>) => ReturnEl;\n Icon: <T>(props: MapProps<IRadialTreeRadianIconProps & T>) => ReturnEl;\n Label: <T>(props: MapProps<IRadialTreeRadianLabelProps & T>) => ReturnEl;\n };\n};\n\nexport default RadialTree;\n"],"mappings":"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"}