@visactor/vchart-extension 2.1.0-alpha.17 → 2.1.0-alpha.18

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 (227) hide show
  1. package/build/index.js +0 -2148
  2. package/build/index.min.js +2 -2
  3. package/cjs/charts/axis-3d/index.js +1 -2
  4. package/cjs/charts/axis-3d/linear-axis.js +2 -1
  5. package/cjs/charts/bar-3d/chart-spec-transformer.js +1 -1
  6. package/cjs/charts/bar-3d/chart.js +1 -1
  7. package/cjs/charts/bar-3d/constant.js +1 -1
  8. package/cjs/charts/bar-3d/index.js +1 -1
  9. package/cjs/charts/bar-3d/interface.js +2 -1
  10. package/cjs/charts/bar-3d/series-spec-transformer.js +1 -1
  11. package/cjs/charts/bar-3d/series.js +1 -1
  12. package/cjs/charts/bar-3d/theme.js +1 -1
  13. package/cjs/charts/candlestick/candlestick-transformer.js +1 -1
  14. package/cjs/charts/candlestick/candlestick.js +1 -1
  15. package/cjs/charts/candlestick/index.js +1 -1
  16. package/cjs/charts/candlestick/interface.js +1 -1
  17. package/cjs/charts/candlestick/util.js +1 -1
  18. package/cjs/charts/combination-candlestick/combination-candlestick-transformer.js +1 -1
  19. package/cjs/charts/combination-candlestick/combination-candlestick.js +1 -1
  20. package/cjs/charts/combination-candlestick/constant.js +1 -1
  21. package/cjs/charts/combination-candlestick/index.js +1 -1
  22. package/cjs/charts/combination-candlestick/interface.js +1 -1
  23. package/cjs/charts/conversion-funnel/arrow-data-transform.js +2 -1
  24. package/cjs/charts/conversion-funnel/constants.js +1 -1
  25. package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js +1 -1
  26. package/cjs/charts/conversion-funnel/conversion-funnel.js +1 -1
  27. package/cjs/charts/conversion-funnel/index.js +1 -1
  28. package/cjs/charts/conversion-funnel/interface.js +1 -1
  29. package/cjs/charts/conversion-funnel/util.js +1 -1
  30. package/cjs/charts/funnel-3d/chart.js +1 -1
  31. package/cjs/charts/funnel-3d/constant.js +1 -1
  32. package/cjs/charts/funnel-3d/index.js +1 -1
  33. package/cjs/charts/funnel-3d/interface.js +1 -1
  34. package/cjs/charts/funnel-3d/series-spec-transformer.js +1 -1
  35. package/cjs/charts/funnel-3d/series.js +1 -1
  36. package/cjs/charts/funnel-3d/theme.js +1 -1
  37. package/cjs/charts/histogram-3d/chart.js +1 -1
  38. package/cjs/charts/image-cloud/series/image-cloud.d.ts +1 -1
  39. package/cjs/components/bar-link/bar-link.js +1 -1
  40. package/cjs/components/bar-link/constant.js +1 -1
  41. package/cjs/components/bar-link/index.js +1 -1
  42. package/cjs/components/bar-link/type.js +1 -1
  43. package/cjs/components/bar-link/util.js +1 -1
  44. package/cjs/components/bar-regression-line/index.js +1 -1
  45. package/cjs/components/bar-regression-line/type.js +1 -1
  46. package/cjs/components/extension-mark-sync-state/extension-mark-sync-state.js +1 -1
  47. package/cjs/components/extension-mark-sync-state/index.js +1 -1
  48. package/cjs/components/extension-mark-sync-state/type.js +1 -1
  49. package/cjs/components/histogram-regression-line/index.js +1 -1
  50. package/cjs/components/histogram-regression-line/type.js +1 -1
  51. package/cjs/components/map-label/index.js +1 -1
  52. package/cjs/components/map-label/layout.js +1 -1
  53. package/cjs/components/map-label/map-label-transformer.js +1 -2
  54. package/cjs/components/map-label/map-label.d.ts +1 -1
  55. package/cjs/components/map-label/map-label.js +1 -1
  56. package/cjs/components/map-label/theme.js +1 -1
  57. package/cjs/components/map-label/type.js +1 -1
  58. package/cjs/components/regression-line/index.js +1 -1
  59. package/cjs/components/regression-line/regression-line.js +1 -1
  60. package/cjs/components/regression-line/type.js +1 -1
  61. package/cjs/components/scatter-regression-line/index.js +1 -1
  62. package/cjs/components/scatter-regression-line/type.js +1 -1
  63. package/cjs/components/series-break/constant.js +1 -1
  64. package/cjs/components/series-break/index.js +1 -1
  65. package/cjs/components/series-break/series-break.js +1 -1
  66. package/cjs/components/series-break/type.js +1 -1
  67. package/cjs/components/series-break/util.js +1 -2
  68. package/cjs/components/series-label/constant.js +1 -1
  69. package/cjs/components/series-label/index.js +1 -1
  70. package/cjs/components/series-label/series-label.js +1 -1
  71. package/cjs/components/series-label/type.js +1 -1
  72. package/cjs/components/series-label/util.js +1 -1
  73. package/cjs/index.d.ts +0 -1
  74. package/cjs/index.js +5 -5
  75. package/cjs/index.js.map +1 -1
  76. package/esm/charts/axis-3d/index.js +1 -2
  77. package/esm/charts/axis-3d/linear-axis.js +2 -1
  78. package/esm/charts/bar-3d/chart-spec-transformer.js +1 -1
  79. package/esm/charts/bar-3d/chart.js +1 -1
  80. package/esm/charts/bar-3d/constant.js +1 -1
  81. package/esm/charts/bar-3d/index.js +1 -1
  82. package/esm/charts/bar-3d/interface.js +2 -1
  83. package/esm/charts/bar-3d/series-spec-transformer.js +1 -1
  84. package/esm/charts/bar-3d/series.js +1 -1
  85. package/esm/charts/bar-3d/theme.js +1 -1
  86. package/esm/charts/candlestick/candlestick-transformer.js +1 -1
  87. package/esm/charts/candlestick/candlestick.js +1 -1
  88. package/esm/charts/candlestick/index.js +1 -1
  89. package/esm/charts/candlestick/interface.js +1 -1
  90. package/esm/charts/candlestick/util.js +1 -1
  91. package/esm/charts/combination-candlestick/combination-candlestick-transformer.js +1 -1
  92. package/esm/charts/combination-candlestick/combination-candlestick.js +1 -1
  93. package/esm/charts/combination-candlestick/constant.js +1 -1
  94. package/esm/charts/combination-candlestick/index.js +1 -1
  95. package/esm/charts/combination-candlestick/interface.js +1 -1
  96. package/esm/charts/conversion-funnel/arrow-data-transform.js +2 -1
  97. package/esm/charts/conversion-funnel/constants.js +1 -1
  98. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +1 -1
  99. package/esm/charts/conversion-funnel/conversion-funnel.js +1 -1
  100. package/esm/charts/conversion-funnel/index.js +1 -1
  101. package/esm/charts/conversion-funnel/interface.js +1 -1
  102. package/esm/charts/conversion-funnel/util.js +1 -1
  103. package/esm/charts/funnel-3d/chart.js +1 -1
  104. package/esm/charts/funnel-3d/constant.js +1 -1
  105. package/esm/charts/funnel-3d/index.js +1 -1
  106. package/esm/charts/funnel-3d/interface.js +1 -1
  107. package/esm/charts/funnel-3d/series-spec-transformer.js +1 -1
  108. package/esm/charts/funnel-3d/series.js +1 -1
  109. package/esm/charts/funnel-3d/theme.js +1 -1
  110. package/esm/charts/histogram-3d/chart.js +1 -1
  111. package/esm/charts/image-cloud/series/image-cloud.d.ts +1 -1
  112. package/esm/components/bar-link/bar-link.js +1 -1
  113. package/esm/components/bar-link/constant.js +1 -1
  114. package/esm/components/bar-link/index.js +1 -1
  115. package/esm/components/bar-link/type.js +1 -1
  116. package/esm/components/bar-link/util.js +1 -1
  117. package/esm/components/bar-regression-line/index.js +1 -1
  118. package/esm/components/bar-regression-line/type.js +1 -1
  119. package/esm/components/extension-mark-sync-state/extension-mark-sync-state.js +1 -1
  120. package/esm/components/extension-mark-sync-state/index.js +1 -1
  121. package/esm/components/extension-mark-sync-state/type.js +1 -1
  122. package/esm/components/histogram-regression-line/index.js +1 -1
  123. package/esm/components/histogram-regression-line/type.js +1 -1
  124. package/esm/components/map-label/index.js +1 -1
  125. package/esm/components/map-label/layout.js +1 -1
  126. package/esm/components/map-label/map-label-transformer.js +1 -2
  127. package/esm/components/map-label/map-label.d.ts +1 -1
  128. package/esm/components/map-label/map-label.js +1 -1
  129. package/esm/components/map-label/theme.js +1 -1
  130. package/esm/components/map-label/type.js +1 -1
  131. package/esm/components/regression-line/index.js +1 -1
  132. package/esm/components/regression-line/regression-line.js +1 -1
  133. package/esm/components/regression-line/type.js +1 -1
  134. package/esm/components/scatter-regression-line/index.js +1 -1
  135. package/esm/components/scatter-regression-line/type.js +1 -1
  136. package/esm/components/series-break/constant.js +1 -1
  137. package/esm/components/series-break/index.js +1 -1
  138. package/esm/components/series-break/series-break.js +1 -1
  139. package/esm/components/series-break/type.js +1 -1
  140. package/esm/components/series-break/util.js +1 -2
  141. package/esm/components/series-label/constant.js +1 -1
  142. package/esm/components/series-label/index.js +1 -1
  143. package/esm/components/series-label/series-label.js +1 -1
  144. package/esm/components/series-label/type.js +1 -1
  145. package/esm/components/series-label/util.js +1 -1
  146. package/esm/index.d.ts +0 -1
  147. package/esm/index.js +0 -2
  148. package/esm/index.js.map +1 -1
  149. package/package.json +7 -7
  150. package/cjs/charts/storyline/index.d.ts +0 -4
  151. package/cjs/charts/storyline/index.js +0 -22
  152. package/cjs/charts/storyline/index.js.map +0 -1
  153. package/cjs/charts/storyline/interface.d.ts +0 -67
  154. package/cjs/charts/storyline/interface.js +0 -6
  155. package/cjs/charts/storyline/interface.js.map +0 -1
  156. package/cjs/charts/storyline/layout.d.ts +0 -53
  157. package/cjs/charts/storyline/layout.js +0 -208
  158. package/cjs/charts/storyline/layout.js.map +0 -1
  159. package/cjs/charts/storyline/layouts/arc.d.ts +0 -5
  160. package/cjs/charts/storyline/layouts/arc.js +0 -295
  161. package/cjs/charts/storyline/layouts/arc.js.map +0 -1
  162. package/cjs/charts/storyline/layouts/clock.d.ts +0 -5
  163. package/cjs/charts/storyline/layouts/clock.js +0 -246
  164. package/cjs/charts/storyline/layouts/clock.js.map +0 -1
  165. package/cjs/charts/storyline/layouts/common.d.ts +0 -89
  166. package/cjs/charts/storyline/layouts/common.js +0 -291
  167. package/cjs/charts/storyline/layouts/common.js.map +0 -1
  168. package/cjs/charts/storyline/layouts/default.d.ts +0 -4
  169. package/cjs/charts/storyline/layouts/default.js +0 -181
  170. package/cjs/charts/storyline/layouts/default.js.map +0 -1
  171. package/cjs/charts/storyline/layouts/ladder.d.ts +0 -5
  172. package/cjs/charts/storyline/layouts/ladder.js +0 -205
  173. package/cjs/charts/storyline/layouts/ladder.js.map +0 -1
  174. package/cjs/charts/storyline/layouts/landscape.d.ts +0 -4
  175. package/cjs/charts/storyline/layouts/landscape.js +0 -256
  176. package/cjs/charts/storyline/layouts/landscape.js.map +0 -1
  177. package/cjs/charts/storyline/layouts/portrait.d.ts +0 -4
  178. package/cjs/charts/storyline/layouts/portrait.js +0 -215
  179. package/cjs/charts/storyline/layouts/portrait.js.map +0 -1
  180. package/cjs/charts/storyline/layouts/wing.d.ts +0 -4
  181. package/cjs/charts/storyline/layouts/wing.js +0 -215
  182. package/cjs/charts/storyline/layouts/wing.js.map +0 -1
  183. package/cjs/charts/storyline/storyline-transformer.d.ts +0 -4
  184. package/cjs/charts/storyline/storyline-transformer.js +0 -78
  185. package/cjs/charts/storyline/storyline-transformer.js.map +0 -1
  186. package/cjs/charts/storyline/storyline.d.ts +0 -16
  187. package/cjs/charts/storyline/storyline.js +0 -36
  188. package/cjs/charts/storyline/storyline.js.map +0 -1
  189. package/esm/charts/storyline/index.d.ts +0 -4
  190. package/esm/charts/storyline/index.js +0 -8
  191. package/esm/charts/storyline/index.js.map +0 -1
  192. package/esm/charts/storyline/interface.d.ts +0 -67
  193. package/esm/charts/storyline/interface.js +0 -2
  194. package/esm/charts/storyline/interface.js.map +0 -1
  195. package/esm/charts/storyline/layout.d.ts +0 -53
  196. package/esm/charts/storyline/layout.js +0 -198
  197. package/esm/charts/storyline/layout.js.map +0 -1
  198. package/esm/charts/storyline/layouts/arc.d.ts +0 -5
  199. package/esm/charts/storyline/layouts/arc.js +0 -286
  200. package/esm/charts/storyline/layouts/arc.js.map +0 -1
  201. package/esm/charts/storyline/layouts/clock.d.ts +0 -5
  202. package/esm/charts/storyline/layouts/clock.js +0 -240
  203. package/esm/charts/storyline/layouts/clock.js.map +0 -1
  204. package/esm/charts/storyline/layouts/common.d.ts +0 -89
  205. package/esm/charts/storyline/layouts/common.js +0 -257
  206. package/esm/charts/storyline/layouts/common.js.map +0 -1
  207. package/esm/charts/storyline/layouts/default.d.ts +0 -4
  208. package/esm/charts/storyline/layouts/default.js +0 -174
  209. package/esm/charts/storyline/layouts/default.js.map +0 -1
  210. package/esm/charts/storyline/layouts/ladder.d.ts +0 -5
  211. package/esm/charts/storyline/layouts/ladder.js +0 -196
  212. package/esm/charts/storyline/layouts/ladder.js.map +0 -1
  213. package/esm/charts/storyline/layouts/landscape.d.ts +0 -4
  214. package/esm/charts/storyline/layouts/landscape.js +0 -252
  215. package/esm/charts/storyline/layouts/landscape.js.map +0 -1
  216. package/esm/charts/storyline/layouts/portrait.d.ts +0 -4
  217. package/esm/charts/storyline/layouts/portrait.js +0 -212
  218. package/esm/charts/storyline/layouts/portrait.js.map +0 -1
  219. package/esm/charts/storyline/layouts/wing.d.ts +0 -4
  220. package/esm/charts/storyline/layouts/wing.js +0 -210
  221. package/esm/charts/storyline/layouts/wing.js.map +0 -1
  222. package/esm/charts/storyline/storyline-transformer.d.ts +0 -4
  223. package/esm/charts/storyline/storyline-transformer.js +0 -76
  224. package/esm/charts/storyline/storyline-transformer.js.map +0 -1
  225. package/esm/charts/storyline/storyline.d.ts +0 -16
  226. package/esm/charts/storyline/storyline.js +0 -29
  227. package/esm/charts/storyline/storyline.js.map +0 -1
@@ -1,240 +0,0 @@
1
- import { LayoutZIndex } from "@visactor/vchart";
2
-
3
- import { buildRichContent, getRegionGeometry, getThemeColor, normalizePadding, withAlpha } from "./common";
4
-
5
- const CLOCK_CENTER_RADIUS_RATIO = .5, CLOCK_CENTER_IMAGE_INSET_RATIO = .86, CLOCK_ORBIT_RATIO = .58, CLOCK_DOT_RATIO = .58, CLOCK_TEXT_INNER_RATIO = .7, CLOCK_TEXT_MAX_WIDTH = 200, CLOCK_DOT_DIAMETER_RATIO = .24, CLOCK_LEAD_LINE_GAP = 6, CLOCK_TEXT_GAP_FROM_LEAD = 8, CLOCK_ORBIT_DASH = [ 4, 4 ], CLOCK_TITLE_FONT_SIZE = 18, CLOCK_TITLE_LINE_HEIGHT = 24, CLOCK_CONTENT_FONT_SIZE = 11, CLOCK_CONTENT_LINE_HEIGHT = 15, getClockGeometry = (spec, ctx) => {
6
- var _a, _b, _c;
7
- const {width: width, height: height, startX: startX, startY: startY} = getRegionGeometry(ctx), padding = normalizePadding(null === (_a = spec.block) || void 0 === _a ? void 0 : _a.padding), innerWidth = Math.max(width - padding.left - padding.right, 1), innerHeight = Math.max(height - padding.top - padding.bottom, 1), cx = startX + padding.left + innerWidth / 2, cy = startY + padding.top + innerHeight / 2, R = Math.max(Math.min(innerWidth, innerHeight) / 2, 1), count = null !== (_c = null === (_b = spec.data) || void 0 === _b ? void 0 : _b.length) && void 0 !== _c ? _c : 0;
8
- return {
9
- cx: cx,
10
- cy: cy,
11
- R: R,
12
- count: count,
13
- step: count > 0 ? 2 * Math.PI / count : 0
14
- };
15
- }, getClockBlockAngle = (geom, index) => -Math.PI / 2 + geom.step * (index + .5), polar = (cx, cy, r, angle) => ({
16
- x: cx + Math.cos(angle) * r,
17
- y: cy + Math.sin(angle) * r
18
- }), isOnLeftHalf = angle => Math.cos(angle) < 0;
19
-
20
- export const buildClockCenterImageMark = spec => {
21
- var _a, _b, _c, _e;
22
- if (!1 === (null === (_a = spec.centerImage) || void 0 === _a ? void 0 : _a.visible)) return null;
23
- const themeColor = getThemeColor(spec), hasImage = !!(null === (_b = spec.centerImage) || void 0 === _b ? void 0 : _b.image);
24
- return {
25
- type: "group",
26
- name: "storyline-clock-center",
27
- zIndex: LayoutZIndex.Mark + 2,
28
- children: [ {
29
- type: "symbol",
30
- name: "storyline-clock-center-halo",
31
- interactive: !1,
32
- style: {
33
- x: (_d, ctx) => getClockGeometry(spec, ctx).cx,
34
- y: (_d, ctx) => getClockGeometry(spec, ctx).cy,
35
- size: (_d, ctx) => .5 * getClockGeometry(spec, ctx).R * 2.16,
36
- symbolType: "circle",
37
- fill: withAlpha(themeColor, .28),
38
- stroke: "transparent"
39
- }
40
- }, hasImage ? {
41
- type: "image",
42
- name: "storyline-clock-center-image",
43
- interactive: !1,
44
- style: Object.assign({
45
- x: (_d, ctx) => {
46
- const g = getClockGeometry(spec, ctx);
47
- return g.cx - .5 * g.R * .86;
48
- },
49
- y: (_d, ctx) => {
50
- const g = getClockGeometry(spec, ctx);
51
- return g.cy - .5 * g.R * .86;
52
- },
53
- width: (_d, ctx) => .5 * getClockGeometry(spec, ctx).R * .86 * 2,
54
- height: (_d, ctx) => .5 * getClockGeometry(spec, ctx).R * .86 * 2,
55
- image: null === (_c = spec.centerImage) || void 0 === _c ? void 0 : _c.image,
56
- repeatX: "no-repeat",
57
- repeatY: "no-repeat",
58
- imageMode: "cover",
59
- imagePosition: "center",
60
- anchor: (_d, ctx) => {
61
- const g = getClockGeometry(spec, ctx);
62
- return [ g.cx, g.cy ];
63
- },
64
- dx: (_d, ctx) => {
65
- var _a, _b;
66
- const rectW = .5 * getClockGeometry(spec, ctx).R * .86 * 2, userWidth = null === (_b = null === (_a = spec.centerImage) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.width;
67
- return (rectW - ("number" == typeof userWidth ? userWidth : rectW)) / 2;
68
- },
69
- dy: (_d, ctx) => {
70
- var _a, _b;
71
- const rectH = .5 * getClockGeometry(spec, ctx).R * .86 * 2, userHeight = null === (_b = null === (_a = spec.centerImage) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.height;
72
- return (rectH - ("number" == typeof userHeight ? userHeight : rectH)) / 2;
73
- }
74
- }, null === (_e = spec.centerImage) || void 0 === _e ? void 0 : _e.style)
75
- } : {
76
- type: "symbol",
77
- name: "storyline-clock-center-placeholder",
78
- interactive: !1,
79
- style: {
80
- x: (_d, ctx) => getClockGeometry(spec, ctx).cx,
81
- y: (_d, ctx) => getClockGeometry(spec, ctx).cy,
82
- size: (_d, ctx) => .5 * getClockGeometry(spec, ctx).R * 2,
83
- symbolType: "circle",
84
- fill: "#ffffff",
85
- stroke: themeColor,
86
- lineWidth: 2
87
- }
88
- } ].filter(Boolean)
89
- };
90
- };
91
-
92
- export const buildClockArcMark = spec => {
93
- const themeColor = getThemeColor(spec);
94
- return {
95
- type: "group",
96
- name: "storyline-clock-orbit",
97
- zIndex: LayoutZIndex.Mark,
98
- children: [ {
99
- type: "path",
100
- name: "storyline-clock-orbit-path",
101
- interactive: !1,
102
- style: {
103
- path: (_d, ctx) => {
104
- const g = getClockGeometry(spec, ctx), r = .58 * g.R;
105
- return [ `M ${(g.cx + r).toFixed(2)} ${g.cy.toFixed(2)}`, `A ${r.toFixed(2)} ${r.toFixed(2)} 0 1 1 ${(g.cx - r).toFixed(2)} ${g.cy.toFixed(2)}`, `A ${r.toFixed(2)} ${r.toFixed(2)} 0 1 1 ${(g.cx + r).toFixed(2)} ${g.cy.toFixed(2)}` ].join(" ");
106
- },
107
- stroke: withAlpha(themeColor, .7),
108
- lineWidth: 1,
109
- lineDash: CLOCK_ORBIT_DASH,
110
- fill: "transparent",
111
- fillOpacity: 0
112
- }
113
- } ]
114
- };
115
- };
116
-
117
- const getClockDotCenter = (spec, ctx, index) => {
118
- const g = getClockGeometry(spec, ctx), angle = getClockBlockAngle(g, index), r = .58 * g.R;
119
- return Object.assign(Object.assign({}, polar(g.cx, g.cy, r, angle)), {
120
- diameter: .24 * g.R,
121
- angle: angle
122
- });
123
- }, getClockLeadLine = (spec, ctx, index) => {
124
- const g = getClockGeometry(spec, ctx), angle = getClockBlockAngle(g, index), dotR = .24 * g.R / 2;
125
- return {
126
- start: polar(g.cx, g.cy, .58 * g.R + dotR + 6, angle),
127
- end: polar(g.cx, g.cy, .7 * g.R - 8, angle)
128
- };
129
- }, getClockTextRect = (spec, ctx, index) => {
130
- var _a;
131
- const g = getClockGeometry(spec, ctx), {width: regionWidth, startX: startX} = getRegionGeometry(ctx), padding = normalizePadding(null === (_a = spec.block) || void 0 === _a ? void 0 : _a.padding), angle = getClockBlockAngle(g, index), onLeft = isOnLeftHalf(angle), rInner = .7 * g.R, innerPoint = polar(g.cx, g.cy, rInner, angle), leftEdge = startX + padding.left, rightEdge = startX + regionWidth - padding.right, width = onLeft ? Math.min(Math.max(innerPoint.x - leftEdge, 80), 200) : Math.min(Math.max(rightEdge - innerPoint.x, 80), 200);
132
- return {
133
- x: innerPoint.x,
134
- y: innerPoint.y,
135
- width: width,
136
- onLeft: onLeft,
137
- anchorY: innerPoint.y
138
- };
139
- };
140
-
141
- export const buildClockBlockMark = (spec, block, index) => {
142
- var _a, _b, _c;
143
- const hasImage = !!block.image, themeColor = getThemeColor(spec), contentText = Array.isArray(block.content) ? block.content : block.content ? [ block.content ] : [], children = [ {
144
- type: "path",
145
- name: `storyline-clock-lead-${index}`,
146
- interactive: !1,
147
- style: {
148
- path: (_d, ctx) => {
149
- const {start: start, end: end} = getClockLeadLine(spec, ctx, index);
150
- return `M ${start.x.toFixed(2)} ${start.y.toFixed(2)} L ${end.x.toFixed(2)} ${end.y.toFixed(2)}`;
151
- },
152
- stroke: withAlpha(themeColor, .7),
153
- lineWidth: 1,
154
- lineDash: [ 3, 3 ],
155
- fill: "transparent",
156
- fillOpacity: 0
157
- }
158
- }, hasImage ? {
159
- type: "image",
160
- name: `storyline-clock-dot-${index}`,
161
- interactive: !1,
162
- style: {
163
- x: (_d, ctx) => {
164
- const dot = getClockDotCenter(spec, ctx, index);
165
- return dot.x - dot.diameter / 2;
166
- },
167
- y: (_d, ctx) => {
168
- const dot = getClockDotCenter(spec, ctx, index);
169
- return dot.y - dot.diameter / 2;
170
- },
171
- width: (_d, ctx) => getClockDotCenter(spec, ctx, index).diameter,
172
- height: (_d, ctx) => getClockDotCenter(spec, ctx, index).diameter,
173
- image: block.image,
174
- repeatX: "no-repeat",
175
- repeatY: "no-repeat",
176
- imageMode: "cover",
177
- imagePosition: "center"
178
- }
179
- } : {
180
- type: "symbol",
181
- name: `storyline-clock-dot-${index}`,
182
- interactive: !1,
183
- style: {
184
- x: (_d, ctx) => getClockDotCenter(spec, ctx, index).x,
185
- y: (_d, ctx) => getClockDotCenter(spec, ctx, index).y,
186
- size: (_d, ctx) => getClockDotCenter(spec, ctx, index).diameter,
187
- symbolType: "circle",
188
- fill: themeColor,
189
- stroke: "#ffffff",
190
- lineWidth: 1.5
191
- }
192
- }, block.title ? Object.assign(Object.assign({
193
- type: "text",
194
- name: `storyline-clock-title-${index}`,
195
- interactive: !1
196
- }, spec.title), {
197
- style: Object.assign({
198
- x: (_d, ctx) => getClockTextRect(spec, ctx, index).x,
199
- y: (_d, ctx) => getClockTextRect(spec, ctx, index).anchorY - 24,
200
- text: block.title,
201
- maxLineWidth: (_d, ctx) => getClockTextRect(spec, ctx, index).width,
202
- fontSize: 18,
203
- lineHeight: 24,
204
- fontWeight: "bold",
205
- fill: themeColor,
206
- stroke: "#fff",
207
- lineWidth: 5,
208
- lineJoin: "round",
209
- textAlign: (_d, ctx) => getClockTextRect(spec, ctx, index).onLeft ? "right" : "left",
210
- textBaseline: "top"
211
- }, null === (_a = spec.title) || void 0 === _a ? void 0 : _a.style)
212
- }) : null, contentText.length ? Object.assign(Object.assign({
213
- type: "text",
214
- name: `storyline-clock-content-${index}`,
215
- interactive: !1
216
- }, spec.content), {
217
- textType: "rich",
218
- style: Object.assign({
219
- x: (_d, ctx) => getClockTextRect(spec, ctx, index).x,
220
- y: (_d, ctx) => getClockTextRect(spec, ctx, index).anchorY + 4,
221
- width: (_d, ctx) => getClockTextRect(spec, ctx, index).width,
222
- maxLineWidth: (_d, ctx) => getClockTextRect(spec, ctx, index).width,
223
- text: buildRichContent(contentText, spec),
224
- fontSize: 11,
225
- lineHeight: 15,
226
- fill: "#3a3f4d",
227
- textAlign: (_d, ctx) => getClockTextRect(spec, ctx, index).onLeft ? "right" : "left",
228
- textBaseline: "top",
229
- wordBreak: "break-word"
230
- }, null === (_b = spec.content) || void 0 === _b ? void 0 : _b.style)
231
- }) : null ];
232
- return {
233
- type: "group",
234
- id: `storyline-block-${null !== (_c = block.id) && void 0 !== _c ? _c : index}`,
235
- name: `storyline-block-${index}`,
236
- zIndex: LayoutZIndex.Mark + 1,
237
- children: children.filter(Boolean)
238
- };
239
- };
240
- //# sourceMappingURL=clock.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/charts/storyline/layouts/clock.ts"],"names":[],"mappings":"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","file":"clock.js","sourcesContent":["import type { IExtensionGroupMarkSpec } from '@visactor/vchart';\nimport { LayoutZIndex } from '@visactor/vchart';\nimport type { IStorylineBlock, IStorylineSpec } from '../interface';\nimport {\n type ICustomMarkSpec,\n type LayoutContext,\n buildRichContent,\n getRegionGeometry,\n getThemeColor,\n normalizePadding,\n withAlpha\n} from './common';\n\n/**\n * clock 布局:环绕式时间线(orbit timeline)\n *\n * 视觉结构(参考报刊版式):\n *\n * ┌──────── 外侧文字段(title + content)─────────┐\n * │ │\n * ●●● │ ┌───── 虚线轨道圆环 ─────┐ │\n * 圆形 dot ──────引线──────┤ │\n * │ │ ◎ centerImage │\n * │ │ (大圆人像) │\n * │ └───────────────────────┘\n * └─────────────────────────────────────────────┘\n *\n * - centerImage:圆形大图,位于版面中心\n * - 虚线轨道:紧贴 centerImage 外侧的圆环,提供时间线的视觉骨架\n * - 每个 block 由 1 个圆形小图(dot)压在轨道上,外加一段从 dot 引出的 title + content 文字\n * - block 沿轨道环绕分布(默认 360°);左半圆 block 文字 right-align,右半圆 block 文字 left-align\n */\n\n// ===== 半径配置(按可用半径的比例划分各圈层)=====\nconst CLOCK_CENTER_RADIUS_RATIO = 0.5; // 中心圆半径\nconst CLOCK_CENTER_IMAGE_INSET_RATIO = 0.86; // centerImage 相对中心圆的尺寸比例(留出环形空隙)\nconst CLOCK_ORBIT_RATIO = 0.58; // 虚线轨道半径\nconst CLOCK_DOT_RATIO = 0.58; // 圆形小图(dot)中心所在半径(与轨道重合)\nconst CLOCK_TEXT_INNER_RATIO = 0.7; // block 文字段起始半径\nconst CLOCK_TEXT_MAX_WIDTH = 200; // 文字段最大宽度,避免靠近正上/正下的 block 占满整个画布半宽\n\n// ===== 元素尺寸 =====\nconst CLOCK_DOT_DIAMETER_RATIO = 0.24; // dot 直径相对 R\nconst CLOCK_LEAD_LINE_GAP = 6; // dot 到引线起点的间距 px\nconst CLOCK_TEXT_GAP_FROM_LEAD = 8; // 引线到文字的间距 px\nconst CLOCK_ORBIT_DASH = [4, 4];\n\n// ===== 文字 =====\nconst CLOCK_TITLE_FONT_SIZE = 18;\nconst CLOCK_TITLE_LINE_HEIGHT = 24;\nconst CLOCK_CONTENT_FONT_SIZE = 11;\nconst CLOCK_CONTENT_LINE_HEIGHT = 15;\n\n// ===== 几何 =====\n\ntype ClockGeometry = {\n cx: number;\n cy: number;\n R: number; // 整盘外半径\n count: number;\n step: number;\n};\n\nconst getClockGeometry = (spec: IStorylineSpec, ctx: LayoutContext): ClockGeometry => {\n const { width, height, startX, startY } = getRegionGeometry(ctx);\n const padding = normalizePadding(spec.block?.padding);\n const innerWidth = Math.max(width - padding.left - padding.right, 1);\n const innerHeight = Math.max(height - padding.top - padding.bottom, 1);\n const cx = startX + padding.left + innerWidth / 2;\n const cy = startY + padding.top + innerHeight / 2;\n const R = Math.max(Math.min(innerWidth, innerHeight) / 2, 1);\n const count = spec.data?.length ?? 0;\n const step = count > 0 ? (Math.PI * 2) / count : 0;\n return { cx, cy, R, count, step };\n};\n\n/**\n * 第 index 个 block 在轨道上的角度。\n * - 0° = 正上方(12 点钟)\n * - 顺时针递增\n */\nconst getClockBlockAngle = (geom: ClockGeometry, index: number) => -Math.PI / 2 + geom.step * (index + 0.5);\n\nconst polar = (cx: number, cy: number, r: number, angle: number) => ({\n x: cx + Math.cos(angle) * r,\n y: cy + Math.sin(angle) * r\n});\n\n/**\n * 判断 block 在版面左半边还是右半边。\n * 用于决定 block 文字的对齐方向(左半边 right-align,右半边 left-align)。\n */\nconst isOnLeftHalf = (angle: number) => Math.cos(angle) < 0;\n\n// ===== 中心圆 =====\n\nexport const buildClockCenterImageMark = (spec: IStorylineSpec): IExtensionGroupMarkSpec | null => {\n if (spec.centerImage?.visible === false) {\n return null;\n }\n const themeColor = getThemeColor(spec);\n const hasImage = !!spec.centerImage?.image;\n return {\n type: 'group' as any,\n name: 'storyline-clock-center',\n zIndex: LayoutZIndex.Mark + 2,\n children: [\n // centerImage 背后的高亮光晕(主题色透明色,营造\"焦点\"效果)\n {\n type: 'symbol',\n name: 'storyline-clock-center-halo',\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getClockGeometry(spec, ctx).cx,\n y: (_d: unknown, ctx: LayoutContext) => getClockGeometry(spec, ctx).cy,\n size: (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n return g.R * CLOCK_CENTER_RADIUS_RATIO * 2.16;\n },\n symbolType: 'circle',\n fill: withAlpha(themeColor, 0.28),\n stroke: 'transparent'\n }\n } as ICustomMarkSpec<'symbol'>,\n hasImage\n ? ({\n type: 'image',\n name: 'storyline-clock-center-image',\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n return g.cx - g.R * CLOCK_CENTER_RADIUS_RATIO * CLOCK_CENTER_IMAGE_INSET_RATIO;\n },\n y: (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n return g.cy - g.R * CLOCK_CENTER_RADIUS_RATIO * CLOCK_CENTER_IMAGE_INSET_RATIO;\n },\n width: (_d: unknown, ctx: LayoutContext) =>\n getClockGeometry(spec, ctx).R * CLOCK_CENTER_RADIUS_RATIO * CLOCK_CENTER_IMAGE_INSET_RATIO * 2,\n height: (_d: unknown, ctx: LayoutContext) =>\n getClockGeometry(spec, ctx).R * CLOCK_CENTER_RADIUS_RATIO * CLOCK_CENTER_IMAGE_INSET_RATIO * 2,\n image: spec.centerImage?.image,\n repeatX: 'no-repeat',\n repeatY: 'no-repeat',\n imageMode: 'cover',\n imagePosition: 'center',\n // 默认锚点设为 image 中心,让 scaleX/scaleY 从中心缩放\n anchor: (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n return [g.cx, g.cy];\n },\n // 若用户在 style 里覆盖了 width/height,自动追加 dx/dy 让图片仍以 rect 中心为中心\n dx: (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n const rectW = g.R * CLOCK_CENTER_RADIUS_RATIO * CLOCK_CENTER_IMAGE_INSET_RATIO * 2;\n const userWidth = (spec.centerImage?.style as { width?: number } | undefined)?.width;\n const w = typeof userWidth === 'number' ? userWidth : rectW;\n return (rectW - w) / 2;\n },\n dy: (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n const rectH = g.R * CLOCK_CENTER_RADIUS_RATIO * CLOCK_CENTER_IMAGE_INSET_RATIO * 2;\n const userHeight = (spec.centerImage?.style as { height?: number } | undefined)?.height;\n const h = typeof userHeight === 'number' ? userHeight : rectH;\n return (rectH - h) / 2;\n },\n ...spec.centerImage?.style\n }\n } as ICustomMarkSpec<'image'>)\n : ({\n type: 'symbol',\n name: 'storyline-clock-center-placeholder',\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getClockGeometry(spec, ctx).cx,\n y: (_d: unknown, ctx: LayoutContext) => getClockGeometry(spec, ctx).cy,\n size: (_d: unknown, ctx: LayoutContext) => getClockGeometry(spec, ctx).R * CLOCK_CENTER_RADIUS_RATIO * 2,\n symbolType: 'circle',\n fill: '#ffffff',\n stroke: themeColor,\n lineWidth: 2\n }\n } as ICustomMarkSpec<'symbol'>)\n ].filter(Boolean) as ICustomMarkSpec<any>[]\n };\n};\n\n// ===== 虚线轨道 =====\n\n/**\n * 紧贴 centerImage 外侧的虚线圆环轨道。\n */\nexport const buildClockArcMark = (spec: IStorylineSpec): IExtensionGroupMarkSpec | null => {\n const themeColor = getThemeColor(spec);\n\n const orbitPath = (_d: unknown, ctx: LayoutContext) => {\n const g = getClockGeometry(spec, ctx);\n const r = g.R * CLOCK_ORBIT_RATIO;\n return [\n `M ${(g.cx + r).toFixed(2)} ${g.cy.toFixed(2)}`,\n `A ${r.toFixed(2)} ${r.toFixed(2)} 0 1 1 ${(g.cx - r).toFixed(2)} ${g.cy.toFixed(2)}`,\n `A ${r.toFixed(2)} ${r.toFixed(2)} 0 1 1 ${(g.cx + r).toFixed(2)} ${g.cy.toFixed(2)}`\n ].join(' ');\n };\n\n return {\n type: 'group' as any,\n name: 'storyline-clock-orbit',\n zIndex: LayoutZIndex.Mark,\n children: [\n {\n type: 'path',\n name: 'storyline-clock-orbit-path',\n interactive: false,\n style: {\n path: orbitPath,\n stroke: withAlpha(themeColor, 0.7),\n lineWidth: 1,\n lineDash: CLOCK_ORBIT_DASH,\n fill: 'transparent',\n fillOpacity: 0\n }\n } as ICustomMarkSpec<'path'>\n ]\n };\n};\n\n// ===== block:dot + 引线 + 文字段 =====\n\nconst getClockDotCenter = (spec: IStorylineSpec, ctx: LayoutContext, index: number) => {\n const g = getClockGeometry(spec, ctx);\n const angle = getClockBlockAngle(g, index);\n const r = g.R * CLOCK_DOT_RATIO;\n return { ...polar(g.cx, g.cy, r, angle), diameter: g.R * CLOCK_DOT_DIAMETER_RATIO, angle };\n};\n\n/**\n * 引线(dot 外缘 → 文字段内边)的两个端点。\n */\nconst getClockLeadLine = (spec: IStorylineSpec, ctx: LayoutContext, index: number) => {\n const g = getClockGeometry(spec, ctx);\n const angle = getClockBlockAngle(g, index);\n const dotR = (g.R * CLOCK_DOT_DIAMETER_RATIO) / 2;\n const start = polar(g.cx, g.cy, g.R * CLOCK_DOT_RATIO + dotR + CLOCK_LEAD_LINE_GAP, angle);\n const end = polar(g.cx, g.cy, g.R * CLOCK_TEXT_INNER_RATIO - CLOCK_TEXT_GAP_FROM_LEAD, angle);\n return { start, end };\n};\n\n/**\n * block 文字段的矩形(中心 + 宽高 + 对齐)。\n * 文字段沿水平方向从 dot 一侧外延:\n * - 左半圆:文字右对齐,向左延伸至画布左边界(含 padding)\n * - 右半圆:文字左对齐,向右延伸至画布右边界(含 padding)\n * 这样所有 block 的可用宽度都是一致的\"画布半宽 - 中心圆半径\",避免出现窄文字。\n */\nconst getClockTextRect = (spec: IStorylineSpec, ctx: LayoutContext, index: number) => {\n const g = getClockGeometry(spec, ctx);\n const { width: regionWidth, startX } = getRegionGeometry(ctx);\n const padding = normalizePadding(spec.block?.padding);\n const angle = getClockBlockAngle(g, index);\n const onLeft = isOnLeftHalf(angle);\n // 文字段从 dot 外侧的 inner ring 处开始水平延展\n const rInner = g.R * CLOCK_TEXT_INNER_RATIO;\n const innerPoint = polar(g.cx, g.cy, rInner, angle);\n // 画布水平边界(含 padding)\n const leftEdge = startX + padding.left;\n const rightEdge = startX + regionWidth - padding.right;\n const width = onLeft\n ? Math.min(Math.max(innerPoint.x - leftEdge, 80), CLOCK_TEXT_MAX_WIDTH)\n : Math.min(Math.max(rightEdge - innerPoint.x, 80), CLOCK_TEXT_MAX_WIDTH);\n return { x: innerPoint.x, y: innerPoint.y, width, onLeft, anchorY: innerPoint.y };\n};\n\nexport const buildClockBlockMark = (\n spec: IStorylineSpec,\n block: IStorylineBlock,\n index: number\n): IExtensionGroupMarkSpec => {\n const hasImage = !!block.image;\n const themeColor = getThemeColor(spec);\n const contentText = Array.isArray(block.content) ? block.content : block.content ? [block.content] : [];\n\n const leadPath = (_d: unknown, ctx: LayoutContext) => {\n const { start, end } = getClockLeadLine(spec, ctx, index);\n return `M ${start.x.toFixed(2)} ${start.y.toFixed(2)} L ${end.x.toFixed(2)} ${end.y.toFixed(2)}`;\n };\n\n const children: (ICustomMarkSpec<any> | null)[] = [\n // 引线:从 dot 外缘到文字段内边\n {\n type: 'path',\n name: `storyline-clock-lead-${index}`,\n interactive: false,\n style: {\n path: leadPath,\n stroke: withAlpha(themeColor, 0.7),\n lineWidth: 1,\n lineDash: [3, 3],\n fill: 'transparent',\n fillOpacity: 0\n }\n } as ICustomMarkSpec<'path'>,\n // 圆形小图(dot):压在轨道上,作为时间锚点\n hasImage\n ? ({\n type: 'image',\n name: `storyline-clock-dot-${index}`,\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => {\n const dot = getClockDotCenter(spec, ctx, index);\n return dot.x - dot.diameter / 2;\n },\n y: (_d: unknown, ctx: LayoutContext) => {\n const dot = getClockDotCenter(spec, ctx, index);\n return dot.y - dot.diameter / 2;\n },\n width: (_d: unknown, ctx: LayoutContext) => getClockDotCenter(spec, ctx, index).diameter,\n height: (_d: unknown, ctx: LayoutContext) => getClockDotCenter(spec, ctx, index).diameter,\n image: block.image,\n repeatX: 'no-repeat',\n repeatY: 'no-repeat',\n imageMode: 'cover',\n imagePosition: 'center'\n }\n } as ICustomMarkSpec<'image'>)\n : ({\n type: 'symbol',\n name: `storyline-clock-dot-${index}`,\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getClockDotCenter(spec, ctx, index).x,\n y: (_d: unknown, ctx: LayoutContext) => getClockDotCenter(spec, ctx, index).y,\n size: (_d: unknown, ctx: LayoutContext) => getClockDotCenter(spec, ctx, index).diameter,\n symbolType: 'circle',\n fill: themeColor,\n stroke: '#ffffff',\n lineWidth: 1.5\n }\n } as ICustomMarkSpec<'symbol'>),\n // title:文字段的第一行\n block.title\n ? ({\n type: 'text',\n name: `storyline-clock-title-${index}`,\n interactive: false,\n ...spec.title,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getClockTextRect(spec, ctx, index).x,\n y: (_d: unknown, ctx: LayoutContext) =>\n getClockTextRect(spec, ctx, index).anchorY - CLOCK_TITLE_LINE_HEIGHT,\n text: block.title,\n maxLineWidth: (_d: unknown, ctx: LayoutContext) => getClockTextRect(spec, ctx, index).width,\n fontSize: CLOCK_TITLE_FONT_SIZE,\n lineHeight: CLOCK_TITLE_LINE_HEIGHT,\n fontWeight: 'bold',\n fill: themeColor,\n stroke: '#fff',\n lineWidth: 5,\n lineJoin: 'round',\n textAlign: (_d: unknown, ctx: LayoutContext) =>\n getClockTextRect(spec, ctx, index).onLeft ? 'right' : 'left',\n textBaseline: 'top',\n ...spec.title?.style\n }\n } as ICustomMarkSpec<'text'>)\n : null,\n // content:富文本,title 下方\n contentText.length\n ? ({\n type: 'text',\n name: `storyline-clock-content-${index}`,\n interactive: false,\n ...spec.content,\n textType: 'rich',\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getClockTextRect(spec, ctx, index).x,\n y: (_d: unknown, ctx: LayoutContext) => getClockTextRect(spec, ctx, index).anchorY + 4,\n width: (_d: unknown, ctx: LayoutContext) => getClockTextRect(spec, ctx, index).width,\n maxLineWidth: (_d: unknown, ctx: LayoutContext) => getClockTextRect(spec, ctx, index).width,\n text: buildRichContent(contentText, spec),\n fontSize: CLOCK_CONTENT_FONT_SIZE,\n lineHeight: CLOCK_CONTENT_LINE_HEIGHT,\n fill: '#3a3f4d',\n textAlign: (_d: unknown, ctx: LayoutContext) =>\n getClockTextRect(spec, ctx, index).onLeft ? 'right' : 'left',\n textBaseline: 'top',\n wordBreak: 'break-word',\n ...spec.content?.style\n }\n } as ICustomMarkSpec<'text'>)\n : null\n ];\n\n return {\n type: 'group' as any,\n id: `storyline-block-${block.id ?? index}`,\n name: `storyline-block-${index}`,\n zIndex: LayoutZIndex.Mark + 1,\n children: children.filter(Boolean) as ICustomMarkSpec<any>[]\n };\n};\n"]}
@@ -1,89 +0,0 @@
1
- import type { ICustomMarkSpec } from '@visactor/vchart';
2
- import type { IStorylineBlock, IStorylineSpec, StorylineImagePosition } from '../interface';
3
- import { normalizeLayout, normalizePadding, type StorylineLayoutResult, type StorylinePoint } from '../layout';
4
- export type LayoutContext = {
5
- chart?: {
6
- getAllRegions?: () => {
7
- getLayoutRect?: () => {
8
- width?: number;
9
- height?: number;
10
- };
11
- getLayoutStartPoint?: () => {
12
- x?: number;
13
- y?: number;
14
- };
15
- }[];
16
- getLayoutRect?: () => {
17
- width?: number;
18
- height?: number;
19
- };
20
- };
21
- getLayoutBounds?: () => {
22
- width?: () => number;
23
- height?: () => number;
24
- };
25
- };
26
- export declare const DEFAULT_BLOCK_WIDTH = 180;
27
- export declare const DEFAULT_BLOCK_HEIGHT = 112;
28
- export declare const DEFAULT_BLOCK_WIDTH_RATIO = 0.24;
29
- export declare const DEFAULT_BLOCK_GAP = 36;
30
- export declare const DEFAULT_IMAGE_WIDTH = 48;
31
- export declare const DEFAULT_IMAGE_HEIGHT = 48;
32
- export declare const DEFAULT_IMAGE_GAP = 10;
33
- export declare const DEFAULT_THEME_COLOR = "#e8543d";
34
- export declare const isLandscape: (spec: IStorylineSpec) => boolean;
35
- export declare const isPortrait: (spec: IStorylineSpec) => boolean;
36
- export declare const isClock: (spec: IStorylineSpec) => boolean;
37
- export declare const isArc: (spec: IStorylineSpec) => boolean;
38
- export declare const isWing: (spec: IStorylineSpec) => boolean;
39
- export declare const isLadder: (spec: IStorylineSpec) => boolean;
40
- export declare const getThemeColor: (spec: IStorylineSpec) => string;
41
- export declare const withAlpha: (color: string, alpha: number) => string;
42
- export declare const resolveBlockWidth: (spec: IStorylineSpec, viewWidth: number) => number;
43
- export declare const getRegionGeometry: (ctx: LayoutContext) => {
44
- width: number;
45
- height: number;
46
- startX: number;
47
- startY: number;
48
- };
49
- export declare const getLayout: (spec: IStorylineSpec, ctx: LayoutContext) => StorylineLayoutResult;
50
- export declare const buildRichContent: (contentText: string[], spec: IStorylineSpec) => {
51
- type: "rich";
52
- text: {
53
- text: string;
54
- fontSize: number;
55
- lineHeight: number;
56
- fill: string;
57
- }[];
58
- };
59
- export declare const omitImageLayoutSpec: (imageSpec: IStorylineSpec['image']) => {
60
- showBackground?: boolean;
61
- id?: import("@visactor/vchart").StringOrNumber;
62
- interactive?: boolean;
63
- zIndex?: number;
64
- visible?: boolean;
65
- style?: import("@visactor/vchart").ConvertToMarkStyleSpec<import("@visactor/vchart").IImageMarkSpec>;
66
- state?: import("@visactor/vchart").IMarkStateFullSpec<import("@visactor/vchart").IImageMarkSpec>;
67
- stateSort?: (stateA: string, stateB: string) => number;
68
- support3d?: boolean;
69
- customShape?: (datum: any[], attrs: any, path: import("@visactor/vrender-core").ICustomPath2D) => import("@visactor/vrender-core").ICustomPath2D;
70
- large?: boolean;
71
- largeThreshold?: number;
72
- progressiveStep?: number;
73
- progressiveThreshold?: number;
74
- };
75
- export declare const getImageBox: (position: StorylineImagePosition, blockWidth: number, blockHeight: number, padding: ReturnType<typeof normalizePadding>, width: number, height: number, _gap: number, visible: boolean) => {
76
- x: number;
77
- y: number;
78
- width: number;
79
- height: number;
80
- };
81
- export declare const getTextBox: (position: StorylineImagePosition, blockWidth: number, blockHeight: number, padding: ReturnType<typeof normalizePadding>, imageWidth: number, imageHeight: number, imageGap: number, hasImage: boolean) => {
82
- x: number;
83
- y: number;
84
- width: number;
85
- height: number;
86
- };
87
- export declare const buildSmoothCurvePath: (points: StorylinePoint[]) => string;
88
- export { normalizeLayout, normalizePadding };
89
- export type { IStorylineBlock, ICustomMarkSpec, StorylinePoint };
@@ -1,257 +0,0 @@
1
- var __rest = this && this.__rest || function(s, e) {
2
- var t = {};
3
- for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
4
- if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
5
- var i = 0;
6
- for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
7
- }
8
- return t;
9
- };
10
-
11
- import { computeStorylineLayout, normalizeLayout, normalizePadding } from "../layout";
12
-
13
- export const DEFAULT_BLOCK_WIDTH = 180;
14
-
15
- export const DEFAULT_BLOCK_HEIGHT = 112;
16
-
17
- export const DEFAULT_BLOCK_WIDTH_RATIO = .24;
18
-
19
- export const DEFAULT_BLOCK_GAP = 36;
20
-
21
- export const DEFAULT_IMAGE_WIDTH = 48;
22
-
23
- export const DEFAULT_IMAGE_HEIGHT = 48;
24
-
25
- export const DEFAULT_IMAGE_GAP = 10;
26
-
27
- export const DEFAULT_THEME_COLOR = "#e8543d";
28
-
29
- export const isLandscape = spec => "landscape" === normalizeLayout(spec.layout).type;
30
-
31
- export const isPortrait = spec => "portrait" === normalizeLayout(spec.layout).type;
32
-
33
- export const isClock = spec => "clock" === normalizeLayout(spec.layout).type;
34
-
35
- export const isArc = spec => "arc" === normalizeLayout(spec.layout).type;
36
-
37
- export const isWing = spec => "wing" === normalizeLayout(spec.layout).type;
38
-
39
- export const isLadder = spec => "ladder" === normalizeLayout(spec.layout).type;
40
-
41
- export const getThemeColor = spec => {
42
- var _a;
43
- return null !== (_a = spec.themeColor) && void 0 !== _a ? _a : "#e8543d";
44
- };
45
-
46
- export const withAlpha = (color, alpha) => {
47
- const safeAlpha = Math.max(0, Math.min(1, alpha));
48
- if (!color) return `rgba(0, 0, 0, ${safeAlpha})`;
49
- const trimmed = color.trim();
50
- if (trimmed.startsWith("#")) {
51
- let hex = trimmed.slice(1);
52
- if (3 !== hex.length && 4 !== hex.length || (hex = hex.split("").map((ch => ch + ch)).join("")),
53
- 6 === hex.length || 8 === hex.length) {
54
- return `rgba(${parseInt(hex.slice(0, 2), 16)}, ${parseInt(hex.slice(2, 4), 16)}, ${parseInt(hex.slice(4, 6), 16)}, ${safeAlpha})`;
55
- }
56
- }
57
- const rgbMatch = trimmed.match(/^rgba?\(\s*([\d.]+)\s*,\s*([\d.]+)\s*,\s*([\d.]+)/i);
58
- return rgbMatch ? `rgba(${rgbMatch[1]}, ${rgbMatch[2]}, ${rgbMatch[3]}, ${safeAlpha})` : trimmed;
59
- };
60
-
61
- export const resolveBlockWidth = (spec, viewWidth) => {
62
- var _a, _b, _c, _d, _e, _f, _g;
63
- if (null === (_a = spec.block) || void 0 === _a ? void 0 : _a.width) return spec.block.width;
64
- const ratio = null !== (_c = null === (_b = spec.block) || void 0 === _b ? void 0 : _b.widthRatio) && void 0 !== _c ? _c : .24, minWidth = null !== (_e = null === (_d = spec.block) || void 0 === _d ? void 0 : _d.minWidth) && void 0 !== _e ? _e : 180, maxWidth = null !== (_g = null === (_f = spec.block) || void 0 === _f ? void 0 : _f.maxWidth) && void 0 !== _g ? _g : Math.max(minWidth, 320);
65
- return Math.max(minWidth, Math.min(maxWidth, Math.round(viewWidth * ratio)));
66
- };
67
-
68
- export const getRegionGeometry = ctx => {
69
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
70
- const region = null === (_c = null === (_b = null === (_a = ctx.chart) || void 0 === _a ? void 0 : _a.getAllRegions) || void 0 === _b ? void 0 : _b.call(_a)) || void 0 === _c ? void 0 : _c[0], regionRect = null === (_d = null == region ? void 0 : region.getLayoutRect) || void 0 === _d ? void 0 : _d.call(region), regionStart = null === (_e = null == region ? void 0 : region.getLayoutStartPoint) || void 0 === _e ? void 0 : _e.call(region), chartRect = null === (_g = null === (_f = ctx.chart) || void 0 === _f ? void 0 : _f.getLayoutRect) || void 0 === _g ? void 0 : _g.call(_f), bounds = null === (_h = ctx.getLayoutBounds) || void 0 === _h ? void 0 : _h.call(ctx);
71
- return {
72
- width: Math.max(null !== (_m = null !== (_k = null !== (_j = null == regionRect ? void 0 : regionRect.width) && void 0 !== _j ? _j : null == chartRect ? void 0 : chartRect.width) && void 0 !== _k ? _k : null === (_l = null == bounds ? void 0 : bounds.width) || void 0 === _l ? void 0 : _l.call(bounds)) && void 0 !== _m ? _m : 0, 1),
73
- height: Math.max(null !== (_r = null !== (_p = null !== (_o = null == regionRect ? void 0 : regionRect.height) && void 0 !== _o ? _o : null == chartRect ? void 0 : chartRect.height) && void 0 !== _p ? _p : null === (_q = null == bounds ? void 0 : bounds.height) || void 0 === _q ? void 0 : _q.call(bounds)) && void 0 !== _r ? _r : 0, 1),
74
- startX: null !== (_s = null == regionStart ? void 0 : regionStart.x) && void 0 !== _s ? _s : 0,
75
- startY: null !== (_t = null == regionStart ? void 0 : regionStart.y) && void 0 !== _t ? _t : 0
76
- };
77
- };
78
-
79
- export const getLayout = (spec, ctx) => {
80
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
81
- const {width: width, height: height, startX: startX, startY: startY} = getRegionGeometry(ctx);
82
- let blockWidth = resolveBlockWidth(spec, width), blockHeight = null !== (_b = null === (_a = spec.block) || void 0 === _a ? void 0 : _a.height) && void 0 !== _b ? _b : 112;
83
- if (isLandscape(spec) && !(null === (_c = spec.block) || void 0 === _c ? void 0 : _c.width)) {
84
- const count = null !== (_e = null === (_d = spec.data) || void 0 === _d ? void 0 : _d.length) && void 0 !== _e ? _e : 0;
85
- if (count > 0) {
86
- const padding = normalizePadding(null === (_f = spec.block) || void 0 === _f ? void 0 : _f.padding), LANDSCAPE_IMAGE_MIN_WIDTH = 80, adaptive = (Math.max(width - padding.left - padding.right, 1) - 40 * Math.max(count - 1, 0)) / count;
87
- blockWidth = Math.max(LANDSCAPE_IMAGE_MIN_WIDTH, Math.floor(adaptive));
88
- }
89
- }
90
- if (isPortrait(spec) && !(null === (_g = spec.block) || void 0 === _g ? void 0 : _g.height)) {
91
- const count = null !== (_j = null === (_h = spec.data) || void 0 === _h ? void 0 : _h.length) && void 0 !== _j ? _j : 0;
92
- if (count > 0) {
93
- const padding = normalizePadding(null === (_k = spec.block) || void 0 === _k ? void 0 : _k.padding), innerHeight = Math.max(height - padding.top - padding.bottom, 1);
94
- blockHeight = Math.max(160, Math.floor(innerHeight / count));
95
- }
96
- }
97
- const result = computeStorylineLayout(null !== (_l = spec.data) && void 0 !== _l ? _l : [], {
98
- layout: spec.layout,
99
- viewBox: {
100
- width: width,
101
- height: height
102
- },
103
- block: {
104
- width: blockWidth,
105
- height: blockHeight
106
- },
107
- gap: null !== (_o = null === (_m = spec.block) || void 0 === _m ? void 0 : _m.gap) && void 0 !== _o ? _o : 36,
108
- padding: null === (_p = spec.block) || void 0 === _p ? void 0 : _p.padding,
109
- lineDistance: null === (_q = spec.line) || void 0 === _q ? void 0 : _q.distance
110
- });
111
- return startX || startY ? Object.assign(Object.assign({}, result), {
112
- blocks: result.blocks.map((block => Object.assign(Object.assign({}, block), {
113
- x: block.x + startX,
114
- y: block.y + startY,
115
- center: {
116
- x: block.center.x + startX,
117
- y: block.center.y + startY
118
- }
119
- }))),
120
- links: result.links.map((link => Object.assign(Object.assign({}, link), {
121
- start: {
122
- x: link.start.x + startX,
123
- y: link.start.y + startY
124
- },
125
- end: {
126
- x: link.end.x + startX,
127
- y: link.end.y + startY
128
- },
129
- points: link.points.map((point => ({
130
- x: point.x + startX,
131
- y: point.y + startY
132
- })))
133
- })))
134
- }) : result;
135
- };
136
-
137
- export const buildRichContent = (contentText, spec) => {
138
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
139
- const fontSize = Number(null !== (_c = null === (_b = null === (_a = spec.content) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.fontSize) && void 0 !== _c ? _c : 12), lineHeight = Number(null !== (_f = null === (_e = null === (_d = spec.content) || void 0 === _d ? void 0 : _d.style) || void 0 === _e ? void 0 : _e.lineHeight) && void 0 !== _f ? _f : 18), fill = null !== (_j = null === (_h = null === (_g = spec.content) || void 0 === _g ? void 0 : _g.style) || void 0 === _h ? void 0 : _h.fill) && void 0 !== _j ? _j : "#596173";
140
- return {
141
- type: "rich",
142
- text: contentText.reduce(((result, paragraph, index) => {
143
- const suffix = index === contentText.length - 1 ? "" : "\n";
144
- return result.push({
145
- text: `${paragraph}${suffix}`,
146
- fontSize: fontSize,
147
- lineHeight: lineHeight,
148
- fill: fill
149
- }), result;
150
- }), [])
151
- };
152
- };
153
-
154
- export const omitImageLayoutSpec = imageSpec => {
155
- if (!imageSpec) return {};
156
- const {width: _width, height: _height, position: _position, gap: _gap} = imageSpec;
157
- return __rest(imageSpec, [ "width", "height", "position", "gap" ]);
158
- };
159
-
160
- export const getImageBox = (position, blockWidth, blockHeight, padding, width, height, _gap, visible) => {
161
- if (!visible) return {
162
- x: padding.left,
163
- y: padding.top,
164
- width: 0,
165
- height: 0
166
- };
167
- switch (position) {
168
- case "left":
169
- return {
170
- x: padding.left,
171
- y: (blockHeight - height) / 2,
172
- width: width,
173
- height: height
174
- };
175
-
176
- case "right":
177
- return {
178
- x: blockWidth - padding.right - width,
179
- y: (blockHeight - height) / 2,
180
- width: width,
181
- height: height
182
- };
183
-
184
- case "bottom":
185
- return {
186
- x: (blockWidth - width) / 2,
187
- y: blockHeight - padding.bottom - height,
188
- width: width,
189
- height: height
190
- };
191
-
192
- default:
193
- return {
194
- x: (blockWidth - width) / 2,
195
- y: padding.top,
196
- width: width,
197
- height: height
198
- };
199
- }
200
- };
201
-
202
- export const getTextBox = (position, blockWidth, blockHeight, padding, imageWidth, imageHeight, imageGap, hasImage) => {
203
- if (!hasImage) return {
204
- x: padding.left,
205
- y: padding.top,
206
- width: blockWidth - padding.left - padding.right,
207
- height: blockHeight - padding.top - padding.bottom
208
- };
209
- switch (position) {
210
- case "left":
211
- return {
212
- x: padding.left + imageWidth + imageGap,
213
- y: padding.top,
214
- width: blockWidth - padding.left - padding.right - imageWidth - imageGap,
215
- height: blockHeight - padding.top - padding.bottom
216
- };
217
-
218
- case "right":
219
- return {
220
- x: padding.left,
221
- y: padding.top,
222
- width: blockWidth - padding.left - padding.right - imageWidth - imageGap,
223
- height: blockHeight - padding.top - padding.bottom
224
- };
225
-
226
- case "bottom":
227
- return {
228
- x: padding.left,
229
- y: padding.top,
230
- width: blockWidth - padding.left - padding.right,
231
- height: blockHeight - padding.top - padding.bottom - imageHeight - imageGap
232
- };
233
-
234
- default:
235
- return {
236
- x: padding.left,
237
- y: padding.top + imageHeight + imageGap,
238
- width: blockWidth - padding.left - padding.right,
239
- height: blockHeight - padding.top - padding.bottom - imageHeight - imageGap
240
- };
241
- }
242
- };
243
-
244
- export const buildSmoothCurvePath = points => {
245
- var _a, _b;
246
- if (points.length < 2) return "";
247
- if (2 === points.length) return `M ${points[0].x} ${points[0].y} L ${points[1].x} ${points[1].y}`;
248
- let d = `M ${points[0].x} ${points[0].y}`;
249
- for (let i = 0; i < points.length - 1; i++) {
250
- const p0 = null !== (_a = points[i - 1]) && void 0 !== _a ? _a : points[i], p1 = points[i], p2 = points[i + 1], p3 = null !== (_b = points[i + 2]) && void 0 !== _b ? _b : p2;
251
- d += ` C ${p1.x + (p2.x - p0.x) / 6} ${p1.y + (p2.y - p0.y) / 6}, ${p2.x - (p3.x - p1.x) / 6} ${p2.y - (p3.y - p1.y) / 6}, ${p2.x} ${p2.y}`;
252
- }
253
- return d;
254
- };
255
-
256
- export { normalizeLayout, normalizePadding };
257
- //# sourceMappingURL=common.js.map