@visactor/vchart-extension 2.1.0-alpha.2 → 2.1.0-alpha.20

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 (223) hide show
  1. package/build/index.js +2393 -0
  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 +1 -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 +2 -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 +1 -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 +2 -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/storyline/index.d.ts +4 -0
  39. package/cjs/charts/storyline/index.js +22 -0
  40. package/cjs/charts/storyline/index.js.map +1 -0
  41. package/cjs/charts/storyline/interface.d.ts +69 -0
  42. package/cjs/charts/storyline/interface.js +6 -0
  43. package/cjs/charts/storyline/interface.js.map +1 -0
  44. package/cjs/charts/storyline/layout.d.ts +58 -0
  45. package/cjs/charts/storyline/layout.js +214 -0
  46. package/cjs/charts/storyline/layout.js.map +1 -0
  47. package/cjs/charts/storyline/layouts/arc.d.ts +5 -0
  48. package/cjs/charts/storyline/layouts/arc.js +327 -0
  49. package/cjs/charts/storyline/layouts/arc.js.map +1 -0
  50. package/cjs/charts/storyline/layouts/clock.d.ts +5 -0
  51. package/cjs/charts/storyline/layouts/clock.js +248 -0
  52. package/cjs/charts/storyline/layouts/clock.js.map +1 -0
  53. package/cjs/charts/storyline/layouts/common.d.ts +98 -0
  54. package/cjs/charts/storyline/layouts/common.js +293 -0
  55. package/cjs/charts/storyline/layouts/common.js.map +1 -0
  56. package/cjs/charts/storyline/layouts/default.d.ts +4 -0
  57. package/cjs/charts/storyline/layouts/default.js +183 -0
  58. package/cjs/charts/storyline/layouts/default.js.map +1 -0
  59. package/cjs/charts/storyline/layouts/ladder.d.ts +5 -0
  60. package/cjs/charts/storyline/layouts/ladder.js +207 -0
  61. package/cjs/charts/storyline/layouts/ladder.js.map +1 -0
  62. package/cjs/charts/storyline/layouts/landscape.d.ts +4 -0
  63. package/cjs/charts/storyline/layouts/landscape.js +258 -0
  64. package/cjs/charts/storyline/layouts/landscape.js.map +1 -0
  65. package/cjs/charts/storyline/layouts/portrait.d.ts +11 -0
  66. package/cjs/charts/storyline/layouts/portrait.js +270 -0
  67. package/cjs/charts/storyline/layouts/portrait.js.map +1 -0
  68. package/cjs/charts/storyline/layouts/wing.d.ts +4 -0
  69. package/cjs/charts/storyline/layouts/wing.js +272 -0
  70. package/cjs/charts/storyline/layouts/wing.js.map +1 -0
  71. package/cjs/charts/storyline/storyline-transformer.d.ts +4 -0
  72. package/cjs/charts/storyline/storyline-transformer.js +91 -0
  73. package/cjs/charts/storyline/storyline-transformer.js.map +1 -0
  74. package/cjs/charts/storyline/storyline.d.ts +16 -0
  75. package/cjs/charts/storyline/storyline.js +36 -0
  76. package/cjs/charts/storyline/storyline.js.map +1 -0
  77. package/cjs/components/bar-link/bar-link.js +1 -1
  78. package/cjs/components/bar-link/constant.js +1 -1
  79. package/cjs/components/bar-link/index.js +1 -1
  80. package/cjs/components/bar-link/type.js +1 -1
  81. package/cjs/components/bar-link/util.js +1 -1
  82. package/cjs/components/bar-regression-line/index.js +1 -1
  83. package/cjs/components/bar-regression-line/type.js +1 -1
  84. package/cjs/components/extension-mark-sync-state/extension-mark-sync-state.js +1 -1
  85. package/cjs/components/extension-mark-sync-state/index.js +1 -1
  86. package/cjs/components/extension-mark-sync-state/type.js +1 -1
  87. package/cjs/components/histogram-regression-line/index.js +1 -1
  88. package/cjs/components/histogram-regression-line/type.js +1 -2
  89. package/cjs/components/map-label/index.js +1 -1
  90. package/cjs/components/map-label/layout.js +1 -1
  91. package/cjs/components/map-label/map-label-transformer.js +1 -1
  92. package/cjs/components/map-label/map-label.js +1 -1
  93. package/cjs/components/map-label/theme.js +1 -1
  94. package/cjs/components/map-label/type.js +1 -1
  95. package/cjs/components/regression-line/index.js +1 -1
  96. package/cjs/components/regression-line/regression-line.js +1 -1
  97. package/cjs/components/regression-line/type.js +1 -1
  98. package/cjs/components/scatter-regression-line/index.js +1 -1
  99. package/cjs/components/scatter-regression-line/type.js +1 -1
  100. package/cjs/components/series-break/constant.js +1 -1
  101. package/cjs/components/series-break/index.js +1 -1
  102. package/cjs/components/series-break/series-break.js +1 -1
  103. package/cjs/components/series-break/type.js +1 -1
  104. package/cjs/components/series-break/util.js +1 -2
  105. package/cjs/components/series-label/constant.js +1 -1
  106. package/cjs/components/series-label/index.js +1 -1
  107. package/cjs/components/series-label/series-label.js +1 -1
  108. package/cjs/components/series-label/type.js +1 -1
  109. package/cjs/components/series-label/util.js +1 -1
  110. package/cjs/index.d.ts +1 -0
  111. package/cjs/index.js +5 -5
  112. package/cjs/index.js.map +1 -1
  113. package/esm/charts/axis-3d/index.js +1 -2
  114. package/esm/charts/axis-3d/linear-axis.js +2 -1
  115. package/esm/charts/bar-3d/chart-spec-transformer.js +1 -1
  116. package/esm/charts/bar-3d/chart.js +1 -1
  117. package/esm/charts/bar-3d/constant.js +1 -1
  118. package/esm/charts/bar-3d/index.js +1 -1
  119. package/esm/charts/bar-3d/interface.js +1 -1
  120. package/esm/charts/bar-3d/series-spec-transformer.js +1 -1
  121. package/esm/charts/bar-3d/series.js +1 -1
  122. package/esm/charts/bar-3d/theme.js +1 -1
  123. package/esm/charts/candlestick/candlestick-transformer.js +1 -1
  124. package/esm/charts/candlestick/candlestick.js +2 -1
  125. package/esm/charts/candlestick/index.js +1 -1
  126. package/esm/charts/candlestick/interface.js +1 -1
  127. package/esm/charts/candlestick/util.js +1 -1
  128. package/esm/charts/combination-candlestick/combination-candlestick-transformer.js +1 -1
  129. package/esm/charts/combination-candlestick/combination-candlestick.js +1 -1
  130. package/esm/charts/combination-candlestick/constant.js +1 -1
  131. package/esm/charts/combination-candlestick/index.js +1 -1
  132. package/esm/charts/combination-candlestick/interface.js +1 -1
  133. package/esm/charts/conversion-funnel/arrow-data-transform.js +1 -1
  134. package/esm/charts/conversion-funnel/constants.js +1 -1
  135. package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +1 -1
  136. package/esm/charts/conversion-funnel/conversion-funnel.js +1 -1
  137. package/esm/charts/conversion-funnel/index.js +1 -1
  138. package/esm/charts/conversion-funnel/interface.js +1 -1
  139. package/esm/charts/conversion-funnel/util.js +1 -1
  140. package/esm/charts/funnel-3d/chart.js +2 -1
  141. package/esm/charts/funnel-3d/constant.js +1 -1
  142. package/esm/charts/funnel-3d/index.js +1 -1
  143. package/esm/charts/funnel-3d/interface.js +1 -1
  144. package/esm/charts/funnel-3d/series-spec-transformer.js +1 -1
  145. package/esm/charts/funnel-3d/series.js +1 -1
  146. package/esm/charts/funnel-3d/theme.js +1 -1
  147. package/esm/charts/histogram-3d/chart.js +1 -1
  148. package/esm/charts/storyline/index.d.ts +4 -0
  149. package/esm/charts/storyline/index.js +8 -0
  150. package/esm/charts/storyline/index.js.map +1 -0
  151. package/esm/charts/storyline/interface.d.ts +69 -0
  152. package/esm/charts/storyline/interface.js +2 -0
  153. package/esm/charts/storyline/interface.js.map +1 -0
  154. package/esm/charts/storyline/layout.d.ts +58 -0
  155. package/esm/charts/storyline/layout.js +204 -0
  156. package/esm/charts/storyline/layout.js.map +1 -0
  157. package/esm/charts/storyline/layouts/arc.d.ts +5 -0
  158. package/esm/charts/storyline/layouts/arc.js +320 -0
  159. package/esm/charts/storyline/layouts/arc.js.map +1 -0
  160. package/esm/charts/storyline/layouts/clock.d.ts +5 -0
  161. package/esm/charts/storyline/layouts/clock.js +242 -0
  162. package/esm/charts/storyline/layouts/clock.js.map +1 -0
  163. package/esm/charts/storyline/layouts/common.d.ts +98 -0
  164. package/esm/charts/storyline/layouts/common.js +258 -0
  165. package/esm/charts/storyline/layouts/common.js.map +1 -0
  166. package/esm/charts/storyline/layouts/default.d.ts +4 -0
  167. package/esm/charts/storyline/layouts/default.js +176 -0
  168. package/esm/charts/storyline/layouts/default.js.map +1 -0
  169. package/esm/charts/storyline/layouts/ladder.d.ts +5 -0
  170. package/esm/charts/storyline/layouts/ladder.js +198 -0
  171. package/esm/charts/storyline/layouts/ladder.js.map +1 -0
  172. package/esm/charts/storyline/layouts/landscape.d.ts +4 -0
  173. package/esm/charts/storyline/layouts/landscape.js +254 -0
  174. package/esm/charts/storyline/layouts/landscape.js.map +1 -0
  175. package/esm/charts/storyline/layouts/portrait.d.ts +11 -0
  176. package/esm/charts/storyline/layouts/portrait.js +274 -0
  177. package/esm/charts/storyline/layouts/portrait.js.map +1 -0
  178. package/esm/charts/storyline/layouts/wing.d.ts +4 -0
  179. package/esm/charts/storyline/layouts/wing.js +268 -0
  180. package/esm/charts/storyline/layouts/wing.js.map +1 -0
  181. package/esm/charts/storyline/storyline-transformer.d.ts +4 -0
  182. package/esm/charts/storyline/storyline-transformer.js +88 -0
  183. package/esm/charts/storyline/storyline-transformer.js.map +1 -0
  184. package/esm/charts/storyline/storyline.d.ts +16 -0
  185. package/esm/charts/storyline/storyline.js +29 -0
  186. package/esm/charts/storyline/storyline.js.map +1 -0
  187. package/esm/components/bar-link/bar-link.js +1 -1
  188. package/esm/components/bar-link/constant.js +1 -1
  189. package/esm/components/bar-link/index.js +1 -1
  190. package/esm/components/bar-link/type.js +1 -1
  191. package/esm/components/bar-link/util.js +1 -1
  192. package/esm/components/bar-regression-line/index.js +1 -1
  193. package/esm/components/bar-regression-line/type.js +1 -1
  194. package/esm/components/extension-mark-sync-state/extension-mark-sync-state.js +1 -1
  195. package/esm/components/extension-mark-sync-state/index.js +1 -1
  196. package/esm/components/extension-mark-sync-state/type.js +1 -1
  197. package/esm/components/histogram-regression-line/index.js +1 -1
  198. package/esm/components/histogram-regression-line/type.js +1 -2
  199. package/esm/components/map-label/index.js +1 -1
  200. package/esm/components/map-label/layout.js +1 -1
  201. package/esm/components/map-label/map-label-transformer.js +1 -1
  202. package/esm/components/map-label/map-label.js +1 -1
  203. package/esm/components/map-label/theme.js +1 -1
  204. package/esm/components/map-label/type.js +1 -1
  205. package/esm/components/regression-line/index.js +1 -1
  206. package/esm/components/regression-line/regression-line.js +1 -1
  207. package/esm/components/regression-line/type.js +1 -1
  208. package/esm/components/scatter-regression-line/index.js +1 -1
  209. package/esm/components/scatter-regression-line/type.js +1 -1
  210. package/esm/components/series-break/constant.js +1 -1
  211. package/esm/components/series-break/index.js +1 -1
  212. package/esm/components/series-break/series-break.js +1 -1
  213. package/esm/components/series-break/type.js +1 -1
  214. package/esm/components/series-break/util.js +1 -2
  215. package/esm/components/series-label/constant.js +1 -1
  216. package/esm/components/series-label/index.js +1 -1
  217. package/esm/components/series-label/series-label.js +1 -1
  218. package/esm/components/series-label/type.js +1 -1
  219. package/esm/components/series-label/util.js +1 -1
  220. package/esm/index.d.ts +1 -0
  221. package/esm/index.js +2 -0
  222. package/esm/index.js.map +1 -1
  223. package/package.json +8 -8
@@ -0,0 +1,270 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.buildPortraitBlockMark = exports.buildPortraitAxisMark = exports.PORTRAIT_TITLE_TO_CONTENT_GAP = exports.PORTRAIT_CONTENT_LINE_HEIGHT = exports.PORTRAIT_TITLE_LINE_HEIGHT = exports.PORTRAIT_CONTENT_LINES = exports.PORTRAIT_TEXT_GAP_FROM_IMAGE = exports.PORTRAIT_CONTENT_HEIGHT_RATIO = exports.PORTRAIT_IMAGE_HEIGHT_RATIO = void 0;
6
+
7
+ const vchart_1 = require("@visactor/vchart"), common_1 = require("./common"), PORTRAIT_AXIS_WIDTH = 96, PORTRAIT_AXIS_PADDING = 50, PORTRAIT_MARKER_FONT_SIZE = 40, PORTRAIT_MARKER_LINE_HEIGHT = 28, PORTRAIT_MARKER_AXIS_PADDING = 6;
8
+
9
+ exports.PORTRAIT_IMAGE_HEIGHT_RATIO = .6, exports.PORTRAIT_CONTENT_HEIGHT_RATIO = 1;
10
+
11
+ const PORTRAIT_IMAGE_GAP_FROM_AXIS = 24, PORTRAIT_SHADOW_OFFSET_X = 24, PORTRAIT_SHADOW_OFFSET_Y = 16, PORTRAIT_SHADOW_SCALE = 1;
12
+
13
+ exports.PORTRAIT_TEXT_GAP_FROM_IMAGE = 8, exports.PORTRAIT_CONTENT_LINES = 3, exports.PORTRAIT_TITLE_LINE_HEIGHT = 34,
14
+ exports.PORTRAIT_CONTENT_LINE_HEIGHT = 26;
15
+
16
+ const PORTRAIT_CONTENT_FONT_SIZE = 18;
17
+
18
+ exports.PORTRAIT_TITLE_TO_CONTENT_GAP = 4;
19
+
20
+ const getPortraitAxisRect = (spec, ctx) => {
21
+ const blocks = (0, common_1.getLayout)(spec, ctx).blocks;
22
+ if (!blocks.length) return {
23
+ x: 0,
24
+ y: 0,
25
+ width: 0,
26
+ height: 0
27
+ };
28
+ const firstCy = blocks[0].center.y, lastCy = blocks[blocks.length - 1].center.y, top = Math.min(firstCy, lastCy), bottom = Math.max(firstCy, lastCy);
29
+ return {
30
+ x: blocks[0].center.x - 48,
31
+ y: top - 50,
32
+ width: 96,
33
+ height: bottom - top + 100
34
+ };
35
+ }, buildPortraitAxisMark = spec => {
36
+ var _a, _b, _c, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
37
+ const themeColor = (0, common_1.getThemeColor)(spec), lineStyle = null !== (_b = null === (_a = spec.line) || void 0 === _a ? void 0 : _a.style) && void 0 !== _b ? _b : {}, defaultFill = {
38
+ gradient: "linear",
39
+ x0: 0,
40
+ y0: 0,
41
+ x1: 0,
42
+ y1: 1,
43
+ stops: [ {
44
+ offset: 0,
45
+ color: (0, common_1.withAlpha)(themeColor, .2)
46
+ }, {
47
+ offset: 1,
48
+ color: (0, common_1.withAlpha)(themeColor, 1)
49
+ } ]
50
+ }, markerFontSize = Number(null !== (_f = null === (_e = null === (_c = spec.marker) || void 0 === _c ? void 0 : _c.style) || void 0 === _e ? void 0 : _e.fontSize) && void 0 !== _f ? _f : 40), markerLineHeight = Number(null !== (_j = null === (_h = null === (_g = spec.marker) || void 0 === _g ? void 0 : _g.style) || void 0 === _h ? void 0 : _h.lineHeight) && void 0 !== _j ? _j : 28), markerMarks = !1 !== (null === (_k = spec.marker) || void 0 === _k ? void 0 : _k.visible) ? (null !== (_l = spec.data) && void 0 !== _l ? _l : []).map(((block, index) => {
51
+ var _a;
52
+ if (!block.marker) return null;
53
+ const onLeft = index % 2 == 0, markerOffsetX = onLeft ? -42 : 42, markerTextAlign = onLeft ? "left" : "right";
54
+ return Object.assign(Object.assign({
55
+ type: "text",
56
+ textType: "rich",
57
+ name: `storyline-portrait-marker-${index}`,
58
+ interactive: !1
59
+ }, spec.marker), {
60
+ style: Object.assign({
61
+ x: (_d, ctx) => {
62
+ var _a, _b;
63
+ const lb = (0, common_1.getLayout)(spec, ctx).blocks[index];
64
+ return (null !== (_b = null === (_a = null == lb ? void 0 : lb.center) || void 0 === _a ? void 0 : _a.x) && void 0 !== _b ? _b : 0) + markerOffsetX;
65
+ },
66
+ y: (_d, ctx) => {
67
+ var _a, _b;
68
+ const lb = (0, common_1.getLayout)(spec, ctx).blocks[index];
69
+ return null !== (_b = null === (_a = null == lb ? void 0 : lb.center) || void 0 === _a ? void 0 : _a.y) && void 0 !== _b ? _b : 0;
70
+ },
71
+ text: {
72
+ type: "rich",
73
+ text: block.marker.split("").map(((char, i, arr) => ({
74
+ text: char + (i < arr.length - 1 ? "\n" : ""),
75
+ fontSize: markerFontSize,
76
+ lineHeight: markerLineHeight,
77
+ fill: "#fff",
78
+ align: markerTextAlign
79
+ })))
80
+ },
81
+ fontWeight: "bold",
82
+ lineJoin: "round",
83
+ shadowColor: "rgba(0, 0, 0, 0.3)",
84
+ shadowBlur: 8,
85
+ shadowOffsetX: 0,
86
+ shadowOffsetY: 5,
87
+ textAlign: markerTextAlign,
88
+ textBaseline: "middle"
89
+ }, null === (_a = spec.marker) || void 0 === _a ? void 0 : _a.style)
90
+ });
91
+ })).filter(Boolean) : [];
92
+ return {
93
+ type: "group",
94
+ name: "storyline-portrait-axis",
95
+ zIndex: vchart_1.LayoutZIndex.Mark,
96
+ children: [ {
97
+ type: "rect",
98
+ name: "storyline-portrait-axis-rect",
99
+ interactive: !1,
100
+ style: {
101
+ fill: null !== (_m = lineStyle.fill) && void 0 !== _m ? _m : defaultFill,
102
+ stroke: null !== (_o = lineStyle.stroke) && void 0 !== _o && _o,
103
+ lineWidth: null !== (_p = lineStyle.lineWidth) && void 0 !== _p ? _p : 0,
104
+ cornerRadius: null !== (_q = lineStyle.cornerRadius) && void 0 !== _q ? _q : 0,
105
+ x: (_d, ctx) => getPortraitAxisRect(spec, ctx).x,
106
+ y: (_d, ctx) => getPortraitAxisRect(spec, ctx).y,
107
+ width: (_d, ctx) => getPortraitAxisRect(spec, ctx).width,
108
+ height: (_d, ctx) => getPortraitAxisRect(spec, ctx).height
109
+ }
110
+ }, ...markerMarks ]
111
+ };
112
+ };
113
+
114
+ exports.buildPortraitAxisMark = buildPortraitAxisMark;
115
+
116
+ const getPortraitMetrics = (spec, blockWidth, blockHeight, index) => {
117
+ var _a, _b, _c, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s;
118
+ const titleFontSize = Number(null !== (_c = null === (_b = null === (_a = spec.title) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.fontSize) && void 0 !== _c ? _c : 26), titleLineHeight = Number(null !== (_g = null === (_f = null === (_e = spec.title) || void 0 === _e ? void 0 : _e.style) || void 0 === _f ? void 0 : _f.lineHeight) && void 0 !== _g ? _g : Math.max(exports.PORTRAIT_TITLE_LINE_HEIGHT, Math.round(1.35 * titleFontSize))), contentFontSize = Number(null !== (_k = null === (_j = null === (_h = spec.content) || void 0 === _h ? void 0 : _h.style) || void 0 === _j ? void 0 : _j.fontSize) && void 0 !== _k ? _k : 18), contentLineHeight = Number(null !== (_o = null === (_m = null === (_l = spec.content) || void 0 === _l ? void 0 : _l.style) || void 0 === _m ? void 0 : _m.lineHeight) && void 0 !== _o ? _o : exports.PORTRAIT_CONTENT_LINE_HEIGHT), titleToContentGap = exports.PORTRAIT_TITLE_TO_CONTENT_GAP, imageWidth = null !== (_q = null === (_p = spec.image) || void 0 === _p ? void 0 : _p.width) && void 0 !== _q ? _q : Math.max(blockWidth, 80), imageHeight = null !== (_s = null === (_r = spec.image) || void 0 === _r ? void 0 : _r.height) && void 0 !== _s ? _s : Math.round(blockHeight * exports.PORTRAIT_IMAGE_HEIGHT_RATIO), minContentHeight = exports.PORTRAIT_CONTENT_LINES * contentLineHeight, contentHeight = Math.max(minContentHeight, Math.round(blockHeight * exports.PORTRAIT_CONTENT_HEIGHT_RATIO)), textHeight = titleLineHeight + titleToContentGap + contentHeight, onLeft = index % 2 == 0, imageX = onLeft ? -72 - imageWidth : 72, imageY = -imageHeight / 2, textX = imageX, textY = imageY + imageHeight + exports.PORTRAIT_TEXT_GAP_FROM_IMAGE, shadowWidth = 1 * imageWidth, shadowHeight = 1 * imageHeight;
119
+ return {
120
+ onLeft: onLeft,
121
+ titleFontSize: titleFontSize,
122
+ titleLineHeight: titleLineHeight,
123
+ contentFontSize: contentFontSize,
124
+ contentLineHeight: contentLineHeight,
125
+ blockWidth: blockWidth,
126
+ imageBox: {
127
+ x: imageX,
128
+ y: imageY,
129
+ width: imageWidth,
130
+ height: imageHeight
131
+ },
132
+ shadowBox: {
133
+ x: imageX - (shadowWidth - imageWidth) / 2 + (onLeft ? -24 : 24),
134
+ y: imageY - (shadowHeight - imageHeight) / 2 + 16,
135
+ width: shadowWidth,
136
+ height: shadowHeight
137
+ },
138
+ textBox: {
139
+ x: textX,
140
+ y: textY,
141
+ width: imageWidth,
142
+ height: textHeight
143
+ },
144
+ contentBox: {
145
+ x: textX,
146
+ y: textY + titleLineHeight + titleToContentGap,
147
+ width: imageWidth,
148
+ height: contentHeight
149
+ }
150
+ };
151
+ }, buildPortraitBlockMark = (spec, block, index) => {
152
+ var _a, _b, _c, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
153
+ const hasImage = !!block.image, hasSubImage = !!block.subImage, contentText = Array.isArray(block.content) ? block.content : block.content ? [ block.content ] : [], titleFontSize = Number(null !== (_c = null === (_b = null === (_a = spec.title) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.fontSize) && void 0 !== _c ? _c : 26), titleLineHeight = Number(null !== (_g = null === (_f = null === (_e = spec.title) || void 0 === _e ? void 0 : _e.style) || void 0 === _f ? void 0 : _f.lineHeight) && void 0 !== _g ? _g : Math.max(exports.PORTRAIT_TITLE_LINE_HEIGHT, Math.round(1.35 * titleFontSize))), getMetrics = ctx => {
154
+ var _a, _b, _c, _e;
155
+ const lb = (0, common_1.getLayout)(spec, ctx).blocks[index], w = null !== (_a = null == lb ? void 0 : lb.width) && void 0 !== _a ? _a : (0,
156
+ common_1.resolveBlockWidth)(spec, 0), h = null !== (_e = null !== (_b = null == lb ? void 0 : lb.height) && void 0 !== _b ? _b : null === (_c = spec.block) || void 0 === _c ? void 0 : _c.height) && void 0 !== _e ? _e : common_1.DEFAULT_BLOCK_HEIGHT;
157
+ return getPortraitMetrics(spec, w, h, index);
158
+ }, themeColor = (0, common_1.getThemeColor)(spec), blockStyle = null !== (_j = null === (_h = spec.block) || void 0 === _h ? void 0 : _h.style) && void 0 !== _j ? _j : {};
159
+ return {
160
+ type: "group",
161
+ id: `storyline-block-${null !== (_k = block.id) && void 0 !== _k ? _k : index}`,
162
+ name: `storyline-block-${index}`,
163
+ zIndex: vchart_1.LayoutZIndex.Mark + 1,
164
+ style: {
165
+ x: (_d, ctx) => {
166
+ var _a, _b;
167
+ const lb = (0, common_1.getLayout)(spec, ctx).blocks[index];
168
+ return null !== (_b = null === (_a = null == lb ? void 0 : lb.center) || void 0 === _a ? void 0 : _a.x) && void 0 !== _b ? _b : 0;
169
+ },
170
+ y: (_d, ctx) => {
171
+ var _a, _b;
172
+ const lb = (0, common_1.getLayout)(spec, ctx).blocks[index];
173
+ return null !== (_b = null === (_a = null == lb ? void 0 : lb.center) || void 0 === _a ? void 0 : _a.y) && void 0 !== _b ? _b : 0;
174
+ }
175
+ },
176
+ children: [ hasSubImage ? {
177
+ type: "image",
178
+ name: `storyline-block-shadow-image-${index}`,
179
+ interactive: !1,
180
+ style: {
181
+ x: (_d, ctx) => getMetrics(ctx).shadowBox.x,
182
+ y: (_d, ctx) => getMetrics(ctx).shadowBox.y,
183
+ width: (_d, ctx) => getMetrics(ctx).shadowBox.width,
184
+ height: (_d, ctx) => getMetrics(ctx).shadowBox.height,
185
+ image: block.subImage,
186
+ repeatX: "no-repeat",
187
+ repeatY: "no-repeat",
188
+ imageMode: "cover",
189
+ imagePosition: "center"
190
+ }
191
+ } : null, !0 === (null === (_l = spec.image) || void 0 === _l ? void 0 : _l.showBackground) ? {
192
+ type: "rect",
193
+ name: `storyline-block-image-bg-${index}`,
194
+ interactive: !1,
195
+ style: Object.assign({
196
+ x: (_d, ctx) => getMetrics(ctx).imageBox.x,
197
+ y: (_d, ctx) => getMetrics(ctx).imageBox.y,
198
+ width: (_d, ctx) => getMetrics(ctx).imageBox.width,
199
+ height: (_d, ctx) => getMetrics(ctx).imageBox.height,
200
+ cornerRadius: 8,
201
+ fill: "#ffffff",
202
+ stroke: themeColor,
203
+ lineWidth: 2
204
+ }, blockStyle)
205
+ } : null, hasImage ? Object.assign(Object.assign({
206
+ type: "image",
207
+ name: `storyline-block-image-${index}`,
208
+ interactive: !1
209
+ }, (0, common_1.omitImageLayoutSpec)(spec.image)), {
210
+ style: Object.assign({
211
+ x: (_d, ctx) => getMetrics(ctx).imageBox.x,
212
+ y: (_d, ctx) => getMetrics(ctx).imageBox.y,
213
+ width: (_d, ctx) => getMetrics(ctx).imageBox.width,
214
+ height: (_d, ctx) => getMetrics(ctx).imageBox.height,
215
+ image: block.image,
216
+ repeatX: "no-repeat",
217
+ repeatY: "no-repeat",
218
+ imageMode: "cover",
219
+ imagePosition: "center"
220
+ }, null === (_m = spec.image) || void 0 === _m ? void 0 : _m.style)
221
+ }) : null, block.title ? Object.assign(Object.assign({
222
+ type: "text",
223
+ name: `storyline-block-title-${index}`,
224
+ interactive: !1
225
+ }, spec.title), {
226
+ style: Object.assign({
227
+ x: (_d, ctx) => getMetrics(ctx).textBox.x,
228
+ y: (_d, ctx) => getMetrics(ctx).textBox.y,
229
+ text: block.title,
230
+ maxLineWidth: (_d, ctx) => getMetrics(ctx).textBox.width,
231
+ fontSize: titleFontSize,
232
+ lineHeight: titleLineHeight,
233
+ fontWeight: "bold",
234
+ fill: "#1f2430",
235
+ stroke: "#fff",
236
+ lineWidth: 5,
237
+ lineJoin: "round",
238
+ textAlign: "left",
239
+ textBaseline: "top"
240
+ }, null === (_o = spec.title) || void 0 === _o ? void 0 : _o.style)
241
+ }) : null, contentText.length ? Object.assign(Object.assign({
242
+ type: "text",
243
+ name: `storyline-block-content-${index}`,
244
+ interactive: !1
245
+ }, spec.content), {
246
+ textType: "rich",
247
+ style: Object.assign({
248
+ x: (_d, ctx) => getMetrics(ctx).contentBox.x,
249
+ y: (_d, ctx) => getMetrics(ctx).contentBox.y,
250
+ width: (_d, ctx) => getMetrics(ctx).contentBox.width,
251
+ height: (_d, ctx) => getMetrics(ctx).contentBox.height,
252
+ maxLineWidth: (_d, ctx) => getMetrics(ctx).contentBox.width,
253
+ heightLimit: (_d, ctx) => getMetrics(ctx).contentBox.height,
254
+ text: (0, common_1.buildRichContent)(contentText, spec, {
255
+ fontSize: 18,
256
+ lineHeight: exports.PORTRAIT_CONTENT_LINE_HEIGHT,
257
+ fill: "#596173"
258
+ }),
259
+ textAlign: "left",
260
+ textBaseline: "top",
261
+ wordBreak: "break-word",
262
+ ellipsis: "...",
263
+ fill: "#596173"
264
+ }, null === (_p = spec.content) || void 0 === _p ? void 0 : _p.style)
265
+ }) : null ].filter(Boolean)
266
+ };
267
+ };
268
+
269
+ exports.buildPortraitBlockMark = buildPortraitBlockMark;
270
+ //# sourceMappingURL=portrait.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/storyline/layouts/portrait.ts"],"names":[],"mappings":"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","file":"portrait.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 DEFAULT_BLOCK_HEIGHT,\n buildRichContent,\n getLayout,\n getThemeColor,\n omitImageLayoutSpec,\n resolveBlockWidth,\n withAlpha\n} from './common';\n\n// portrait 布局:中轴 rect + 左右交替的 image + image 下方 title/content\n// 中轴默认加宽,便于在轴上叠放 block.marker 时间节点文字(纵向逐字排列)\nconst PORTRAIT_AXIS_WIDTH = 96;\nconst PORTRAIT_AXIS_PADDING = 50; // 中轴上下两端的留白\n// marker 时间节点文字的默认样式(fontSize 30、白色字、贴轴对应一侧边缘)\nconst PORTRAIT_MARKER_FONT_SIZE = 40;\nconst PORTRAIT_MARKER_LINE_HEIGHT = 28;\nconst PORTRAIT_MARKER_AXIS_PADDING = 6; // marker 距离轴边缘的水平内边距\n// image 默认尺寸的占比规则(基于 region 平均槽位):\n// - image 高度 = slotHeight * 0.6\n// - content 高度 = slotHeight * (0.6 + 0.4)\n// 其中 slotHeight = regionHeight / (blockCount + 1),由 getLayout 计算。\nexport const PORTRAIT_IMAGE_HEIGHT_RATIO = 0.6;\nexport const PORTRAIT_CONTENT_HEIGHT_RATIO = 1;\nconst PORTRAIT_IMAGE_GAP_FROM_AXIS = 24; // image 与中轴之间的水平间距\nconst PORTRAIT_SHADOW_OFFSET_X = 24; // subImage 相对主 image 的水平错位量\nconst PORTRAIT_SHADOW_OFFSET_Y = 16; // subImage 相对主 image 的垂直错位量\nconst PORTRAIT_SHADOW_SCALE = 1; // subImage 与主 image 同尺寸,仅做错位偏移\nexport const PORTRAIT_TEXT_GAP_FROM_IMAGE = 8;\nexport const PORTRAIT_CONTENT_LINES = 3;\nexport const PORTRAIT_TITLE_LINE_HEIGHT = 34;\nexport const PORTRAIT_CONTENT_LINE_HEIGHT = 26;\nconst PORTRAIT_CONTENT_FONT_SIZE = 18;\nexport const PORTRAIT_TITLE_TO_CONTENT_GAP = 4;\n\n/**\n * 获取 portrait 布局的中轴 rect 尺寸:宽度固定,高度贯穿首/尾 block 中心。\n */\nconst getPortraitAxisRect = (spec: IStorylineSpec, ctx: LayoutContext) => {\n const blocks = getLayout(spec, ctx).blocks;\n if (!blocks.length) {\n return { x: 0, y: 0, width: 0, height: 0 };\n }\n const firstCy = blocks[0].center.y;\n const lastCy = blocks[blocks.length - 1].center.y;\n const top = Math.min(firstCy, lastCy);\n const bottom = Math.max(firstCy, lastCy);\n const cx = blocks[0].center.x;\n return {\n x: cx - PORTRAIT_AXIS_WIDTH / 2,\n y: top - PORTRAIT_AXIS_PADDING,\n width: PORTRAIT_AXIS_WIDTH,\n height: bottom - top + PORTRAIT_AXIS_PADDING * 2\n };\n};\n\nexport const buildPortraitAxisMark = (spec: IStorylineSpec): IExtensionGroupMarkSpec => {\n const themeColor = getThemeColor(spec);\n const lineStyle = spec.line?.style ?? {};\n const defaultFill = {\n gradient: 'linear',\n x0: 0,\n y0: 0,\n x1: 0,\n y1: 1,\n stops: [\n { offset: 0, color: withAlpha(themeColor, 0.2) },\n { offset: 1, color: withAlpha(themeColor, 1) }\n ]\n };\n // marker 时间节点文字:垂直方向逐字排列(每字符换行)\n const markerFontSize = Number((spec.marker?.style as any)?.fontSize ?? PORTRAIT_MARKER_FONT_SIZE);\n const markerLineHeight = Number((spec.marker?.style as any)?.lineHeight ?? PORTRAIT_MARKER_LINE_HEIGHT);\n const markerVisible = spec.marker?.visible !== false;\n // 把 \"2012\" 拆成 \"2\\n0\\n1\\n2\",由 text mark 的多行文本能力实现纵向排列\n const splitVertical = (text: string) => text.split('').join('\\n');\n\n const markerMarks = markerVisible\n ? (spec.data ?? [])\n .map((block, index) => {\n if (!block.marker) {\n return null;\n }\n // image 在 block 左侧时(index 偶数),marker 贴轴左边缘 + 左对齐;\n // image 在 block 右侧时(index 奇数),marker 贴轴右边缘 + 右对齐。\n const onLeft = index % 2 === 0;\n const axisHalf = PORTRAIT_AXIS_WIDTH / 2;\n const markerOffsetX = onLeft\n ? -axisHalf + PORTRAIT_MARKER_AXIS_PADDING\n : axisHalf - PORTRAIT_MARKER_AXIS_PADDING;\n const markerTextAlign: 'left' | 'right' = onLeft ? 'left' : 'right';\n return {\n type: 'text',\n textType: 'rich',\n name: `storyline-portrait-marker-${index}`,\n interactive: false,\n ...spec.marker,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => {\n const lb = getLayout(spec, ctx).blocks[index];\n return (lb?.center?.x ?? 0) + markerOffsetX;\n },\n y: (_d: unknown, ctx: LayoutContext) => {\n const lb = getLayout(spec, ctx).blocks[index];\n return lb?.center?.y ?? 0;\n },\n text: {\n type: 'rich',\n text: block.marker.split('').map((char, i, arr) => ({\n text: char + (i < arr.length - 1 ? '\\n' : ''),\n fontSize: markerFontSize,\n lineHeight: markerLineHeight,\n fill: '#fff',\n align: markerTextAlign\n }))\n },\n fontWeight: 'bold',\n lineJoin: 'round',\n shadowColor: 'rgba(0, 0, 0, 0.3)',\n shadowBlur: 8,\n shadowOffsetX: 0,\n shadowOffsetY: 5,\n textAlign: markerTextAlign,\n textBaseline: 'middle',\n ...(spec.marker?.style as any)\n }\n } as ICustomMarkSpec<'text'>;\n })\n .filter(Boolean)\n : [];\n\n return {\n type: 'group' as any,\n name: 'storyline-portrait-axis',\n zIndex: LayoutZIndex.Mark,\n children: [\n {\n type: 'rect',\n name: 'storyline-portrait-axis-rect',\n interactive: false,\n style: {\n fill: (lineStyle as any).fill ?? defaultFill,\n stroke: (lineStyle as any).stroke ?? false,\n lineWidth: (lineStyle as any).lineWidth ?? 0,\n cornerRadius: (lineStyle as any).cornerRadius ?? 0,\n x: (_d: unknown, ctx: LayoutContext) => getPortraitAxisRect(spec, ctx).x,\n y: (_d: unknown, ctx: LayoutContext) => getPortraitAxisRect(spec, ctx).y,\n width: (_d: unknown, ctx: LayoutContext) => getPortraitAxisRect(spec, ctx).width,\n height: (_d: unknown, ctx: LayoutContext) => getPortraitAxisRect(spec, ctx).height\n }\n } as ICustomMarkSpec<'rect'>,\n ...(markerMarks as ICustomMarkSpec<any>[])\n ]\n };\n};\n\nconst getPortraitMetrics = (spec: IStorylineSpec, blockWidth: number, blockHeight: number, index: number) => {\n const titleFontSize = Number((spec.title?.style as any)?.fontSize ?? 26);\n const titleLineHeight = Number(\n (spec.title?.style as any)?.lineHeight ?? Math.max(PORTRAIT_TITLE_LINE_HEIGHT, Math.round(titleFontSize * 1.35))\n );\n const contentFontSize = Number((spec.content?.style as any)?.fontSize ?? PORTRAIT_CONTENT_FONT_SIZE);\n const contentLineHeight = Number((spec.content?.style as any)?.lineHeight ?? PORTRAIT_CONTENT_LINE_HEIGHT);\n const titleToContentGap = PORTRAIT_TITLE_TO_CONTENT_GAP;\n\n // 默认 image 高度 = blockHeight * 0.4(blockHeight = regionHeight / count,由 getLayout 计算);\n // 默认 image 宽度 = blockWidth,让 image 横向自适应单个 block 槽位宽度\n const imageWidth = spec.image?.width ?? Math.max(blockWidth, 80);\n const imageHeight = spec.image?.height ?? Math.round(blockHeight * PORTRAIT_IMAGE_HEIGHT_RATIO);\n const minContentHeight = PORTRAIT_CONTENT_LINES * contentLineHeight;\n // 默认 content 高度 = blockHeight * 0.4\n const contentHeight = Math.max(minContentHeight, Math.round(blockHeight * PORTRAIT_CONTENT_HEIGHT_RATIO));\n\n const textHeight = titleLineHeight + titleToContentGap + contentHeight;\n\n const onLeft = index % 2 === 0;\n\n const axisHalf = PORTRAIT_AXIS_WIDTH / 2;\n const imageX = onLeft\n ? -axisHalf - PORTRAIT_IMAGE_GAP_FROM_AXIS - imageWidth\n : axisHalf + PORTRAIT_IMAGE_GAP_FROM_AXIS;\n const imageY = -imageHeight / 2;\n\n const textX = imageX;\n const textY = imageY + imageHeight + PORTRAIT_TEXT_GAP_FROM_IMAGE;\n const textWidth = imageWidth;\n\n const contentBox = {\n x: textX,\n y: textY + titleLineHeight + titleToContentGap,\n width: textWidth,\n height: contentHeight\n };\n\n const shadowOffsetX = PORTRAIT_SHADOW_OFFSET_X;\n const shadowOffsetY = PORTRAIT_SHADOW_OFFSET_Y;\n const shadowWidth = imageWidth * PORTRAIT_SHADOW_SCALE;\n const shadowHeight = imageHeight * PORTRAIT_SHADOW_SCALE;\n const baseShadowX = imageX - (shadowWidth - imageWidth) / 2;\n const baseShadowY = imageY - (shadowHeight - imageHeight) / 2;\n const shadowBox = {\n x: baseShadowX + (onLeft ? -shadowOffsetX : shadowOffsetX),\n y: baseShadowY + shadowOffsetY,\n width: shadowWidth,\n height: shadowHeight\n };\n\n return {\n onLeft,\n titleFontSize,\n titleLineHeight,\n contentFontSize,\n contentLineHeight,\n blockWidth,\n imageBox: { x: imageX, y: imageY, width: imageWidth, height: imageHeight },\n shadowBox,\n textBox: { x: textX, y: textY, width: textWidth, height: textHeight },\n contentBox\n };\n};\n\nexport const buildPortraitBlockMark = (\n spec: IStorylineSpec,\n block: IStorylineBlock,\n index: number\n): IExtensionGroupMarkSpec => {\n const hasImage = !!block.image;\n const hasSubImage = !!block.subImage;\n const contentText = Array.isArray(block.content) ? block.content : block.content ? [block.content] : [];\n const titleFontSize = Number((spec.title?.style as any)?.fontSize ?? 26);\n const titleLineHeight = Number(\n (spec.title?.style as any)?.lineHeight ?? Math.max(PORTRAIT_TITLE_LINE_HEIGHT, Math.round(titleFontSize * 1.35))\n );\n\n const getMetrics = (ctx: LayoutContext) => {\n const lb = getLayout(spec, ctx).blocks[index];\n const w = lb?.width ?? resolveBlockWidth(spec, 0);\n const h = lb?.height ?? spec.block?.height ?? DEFAULT_BLOCK_HEIGHT;\n return getPortraitMetrics(spec, w, h, index);\n };\n const themeColor = getThemeColor(spec);\n const blockStyle = spec.block?.style ?? {};\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 style: {\n x: (_d: unknown, ctx: LayoutContext) => {\n const lb = getLayout(spec, ctx).blocks[index];\n return lb?.center?.x ?? 0;\n },\n y: (_d: unknown, ctx: LayoutContext) => {\n const lb = getLayout(spec, ctx).blocks[index];\n return lb?.center?.y ?? 0;\n }\n },\n children: [\n hasSubImage\n ? ({\n type: 'image',\n name: `storyline-block-shadow-image-${index}`,\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).shadowBox.x,\n y: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).shadowBox.y,\n width: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).shadowBox.width,\n height: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).shadowBox.height,\n image: block.subImage,\n repeatX: 'no-repeat',\n repeatY: 'no-repeat',\n imageMode: 'cover',\n imagePosition: 'center'\n }\n } as ICustomMarkSpec<'image'>)\n : null,\n spec.image?.showBackground === true\n ? ({\n type: 'rect',\n name: `storyline-block-image-bg-${index}`,\n interactive: false,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.x,\n y: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.y,\n width: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.width,\n height: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.height,\n cornerRadius: 8,\n fill: '#ffffff',\n stroke: themeColor,\n lineWidth: 2,\n ...blockStyle\n }\n } as ICustomMarkSpec<'rect'>)\n : null,\n hasImage\n ? ({\n type: 'image',\n name: `storyline-block-image-${index}`,\n interactive: false,\n ...omitImageLayoutSpec(spec.image),\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.x,\n y: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.y,\n width: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.width,\n height: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).imageBox.height,\n image: block.image,\n repeatX: 'no-repeat',\n repeatY: 'no-repeat',\n imageMode: 'cover',\n imagePosition: 'center',\n ...spec.image?.style\n }\n } as ICustomMarkSpec<'image'>)\n : null,\n block.title\n ? ({\n type: 'text',\n name: `storyline-block-title-${index}`,\n interactive: false,\n ...spec.title,\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).textBox.x,\n y: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).textBox.y,\n text: block.title,\n maxLineWidth: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).textBox.width,\n fontSize: titleFontSize,\n lineHeight: titleLineHeight,\n fontWeight: 'bold',\n fill: '#1f2430',\n stroke: '#fff',\n lineWidth: 5,\n lineJoin: 'round',\n textAlign: 'left',\n textBaseline: 'top',\n ...spec.title?.style\n }\n } as ICustomMarkSpec<'text'>)\n : null,\n contentText.length\n ? ({\n type: 'text',\n name: `storyline-block-content-${index}`,\n interactive: false,\n ...spec.content,\n textType: 'rich',\n style: {\n x: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).contentBox.x,\n y: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).contentBox.y,\n width: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).contentBox.width,\n height: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).contentBox.height,\n maxLineWidth: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).contentBox.width,\n heightLimit: (_d: unknown, ctx: LayoutContext) => getMetrics(ctx).contentBox.height,\n text: buildRichContent(contentText, spec, {\n fontSize: PORTRAIT_CONTENT_FONT_SIZE,\n lineHeight: PORTRAIT_CONTENT_LINE_HEIGHT,\n fill: '#596173'\n }),\n textAlign: 'left',\n textBaseline: 'top',\n wordBreak: 'break-word',\n ellipsis: '...',\n fill: '#596173',\n ...spec.content?.style\n }\n } as ICustomMarkSpec<'text'>)\n : null\n ].filter(Boolean) as ICustomMarkSpec<any>[]\n };\n};\n"]}
@@ -0,0 +1,4 @@
1
+ import type { IExtensionGroupMarkSpec } from '@visactor/vchart';
2
+ import type { IStorylineBlock, IStorylineSpec } from '../interface';
3
+ export declare const buildWingArcMark: (spec: IStorylineSpec) => IExtensionGroupMarkSpec | null;
4
+ export declare const buildWingBlockMark: (spec: IStorylineSpec, block: IStorylineBlock, index: number) => IExtensionGroupMarkSpec;
@@ -0,0 +1,272 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.buildWingBlockMark = exports.buildWingArcMark = void 0;
6
+
7
+ const vchart_1 = require("@visactor/vchart"), common_1 = require("./common"), WING_BLOCK_IMAGE_SIZE = 160, WING_TEXT_GAP_FROM_IMAGE = 14, WING_TITLE_LINE_HEIGHT = 30, WING_TITLE_FONT_SIZE = 22, WING_CONTENT_LINE_HEIGHT = 17, WING_CONTENT_FONT_SIZE = 12, WING_TEXT_BOX_WIDTH = 240, WING_TEXT_BOX_HEIGHT = 110, WING_TITLE_TO_CONTENT_GAP = 4, getWingDirection = spec => {
8
+ var _a;
9
+ return null !== (_a = (0, common_1.normalizeLayout)(spec.layout).direction) && void 0 !== _a ? _a : "left";
10
+ }, getWingArcGeometry = (spec, ctx) => {
11
+ var _a, _b, _c;
12
+ const {width: width, height: height, startX: startX, startY: startY} = (0, common_1.getRegionGeometry)(ctx), innerWidth = Math.max(width, 1), innerHeight = Math.max(height, 1), layoutOpt = (0,
13
+ common_1.normalizeLayout)(spec.layout), direction = getWingDirection(spec), defaultStart = "right" === direction ? 110 : -70, defaultEnd = "right" === direction ? 250 : 70, startAngle = null !== (_a = layoutOpt.startAngle) && void 0 !== _a ? _a : defaultStart, endAngle = null !== (_b = layoutOpt.endAngle) && void 0 !== _b ? _b : defaultEnd, ratio = null !== (_c = layoutOpt.radiusRatio) && void 0 !== _c ? _c : .92, rx = .6 * innerWidth * ratio;
14
+ return {
15
+ cx: "right" === direction ? startX + innerWidth - .1 * rx : startX + .1 * rx,
16
+ cy: startY + innerHeight / 2,
17
+ rx: rx,
18
+ ry: innerHeight / 2 * ratio,
19
+ startAngle: startAngle,
20
+ endAngle: endAngle
21
+ };
22
+ }, getWingBlockCenter = (spec, ctx, index) => {
23
+ var _a, _b;
24
+ const arc = getWingArcGeometry(spec, ctx), count = null !== (_b = null === (_a = spec.data) || void 0 === _a ? void 0 : _a.length) && void 0 !== _b ? _b : 0;
25
+ if (count <= 0) return {
26
+ x: arc.cx,
27
+ y: arc.cy
28
+ };
29
+ const t = 1 === count ? .5 : index / (count - 1), angle = (arc.startAngle + (arc.endAngle - arc.startAngle) * t) / 180 * Math.PI;
30
+ return {
31
+ x: arc.cx + Math.cos(angle) * arc.rx,
32
+ y: arc.cy + Math.sin(angle) * arc.ry
33
+ };
34
+ }, isTextOnLeft = (spec, index) => "right" === getWingDirection(spec) ? index % 2 == 1 : index % 2 == 0, buildWingArcMark = spec => {
35
+ var _a, _b, _c, _e, _f, _g, _h, _j;
36
+ if (!1 === (null === (_a = spec.line) || void 0 === _a ? void 0 : _a.visible)) return null;
37
+ const themeColor = (0, common_1.getThemeColor)(spec), lineStyle = null !== (_c = null === (_b = spec.line) || void 0 === _b ? void 0 : _b.style) && void 0 !== _c ? _c : {}, startWidth = Math.max(Number(null !== (_e = lineStyle.startWidth) && void 0 !== _e ? _e : 50), .5), endWidth = Math.max(Number(null !== (_g = null !== (_f = lineStyle.endWidth) && void 0 !== _f ? _f : lineStyle.lineWidth) && void 0 !== _g ? _g : 350), startWidth);
38
+ return {
39
+ type: "group",
40
+ name: "storyline-wing-arc",
41
+ zIndex: vchart_1.LayoutZIndex.Mark,
42
+ children: [ {
43
+ type: "path",
44
+ name: "storyline-wing-arc-path",
45
+ interactive: !1,
46
+ style: {
47
+ stroke: !1,
48
+ lineWidth: 0,
49
+ fill: null !== (_j = null !== (_h = lineStyle.fill) && void 0 !== _h ? _h : lineStyle.stroke) && void 0 !== _j ? _j : themeColor,
50
+ opacity: .95,
51
+ path: (_d, ctx) => {
52
+ const arc = getWingArcGeometry(spec, ctx), span = arc.endAngle - arc.startAngle, pts = [];
53
+ for (let i = 0; i <= 96; i++) {
54
+ const t = i / 96, angle = (arc.startAngle + span * t) / 180 * Math.PI, cx = arc.cx + Math.cos(angle) * arc.rx, cy = arc.cy + Math.sin(angle) * arc.ry, nxRaw = Math.cos(angle) / arc.rx, nyRaw = Math.sin(angle) / arc.ry, nLen = Math.hypot(nxRaw, nyRaw) || 1;
55
+ pts.push({
56
+ x: cx,
57
+ y: cy,
58
+ nx: nxRaw / nLen,
59
+ ny: nyRaw / nLen,
60
+ w: startWidth + (endWidth - startWidth) * t
61
+ });
62
+ }
63
+ const segments = [];
64
+ for (let i = 0; i < pts.length; i++) {
65
+ const p = pts[i], x = p.x + p.nx * (p.w / 2), y = p.y + p.ny * (p.w / 2);
66
+ segments.push(`${0 === i ? "M" : "L"} ${x.toFixed(2)} ${y.toFixed(2)}`);
67
+ }
68
+ for (let i = pts.length - 1; i >= 0; i--) {
69
+ const p = pts[i], x = p.x - p.nx * (p.w / 2), y = p.y - p.ny * (p.w / 2);
70
+ segments.push(`L ${x.toFixed(2)} ${y.toFixed(2)}`);
71
+ }
72
+ return segments.push("Z"), segments.join(" ");
73
+ }
74
+ }
75
+ } ]
76
+ };
77
+ };
78
+
79
+ exports.buildWingArcMark = buildWingArcMark;
80
+
81
+ const WING_TEXT_IMAGE_GAP = 120, getWingBlockMetrics = (spec, ctx, index) => {
82
+ var _a, _b, _c, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
83
+ const titleFontSize = Number(null !== (_c = null === (_b = null === (_a = spec.title) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.fontSize) && void 0 !== _c ? _c : 22), titleLineHeight = Number(null !== (_g = null === (_f = null === (_e = spec.title) || void 0 === _e ? void 0 : _e.style) || void 0 === _f ? void 0 : _f.lineHeight) && void 0 !== _g ? _g : Math.max(30, Math.round(1.3 * titleFontSize))), contentFontSize = Number(null !== (_k = null === (_j = null === (_h = spec.content) || void 0 === _h ? void 0 : _h.style) || void 0 === _j ? void 0 : _j.fontSize) && void 0 !== _k ? _k : 12), contentLineHeight = Number(null !== (_o = null === (_m = null === (_l = spec.content) || void 0 === _l ? void 0 : _l.style) || void 0 === _m ? void 0 : _m.lineHeight) && void 0 !== _o ? _o : 17), imageWidth = Number(null !== (_q = null === (_p = spec.image) || void 0 === _p ? void 0 : _p.width) && void 0 !== _q ? _q : 160), imageHeight = Number(null !== (_s = null === (_r = spec.image) || void 0 === _r ? void 0 : _r.height) && void 0 !== _s ? _s : 160), imageBox = {
84
+ x: -imageWidth / 2,
85
+ y: -imageHeight / 2,
86
+ width: imageWidth,
87
+ height: imageHeight
88
+ }, direction = getWingDirection(spec), count = null !== (_u = null === (_t = spec.data) || void 0 === _t ? void 0 : _t.length) && void 0 !== _u ? _u : 0;
89
+ let textBox, contentBox, connectorBox, onLeft, verticalAlign;
90
+ if ("right" === direction && count > 0 && index === count - 1 || "left" === direction && 0 === index) {
91
+ const textX = -120, textY = imageHeight / 2 + 120;
92
+ textBox = {
93
+ x: textX,
94
+ y: textY,
95
+ width: 240,
96
+ height: 110
97
+ }, contentBox = {
98
+ x: textX,
99
+ y: textY + titleLineHeight + 4,
100
+ width: 240,
101
+ height: 1e5
102
+ }, connectorBox = {
103
+ x: -1,
104
+ y: imageHeight / 2,
105
+ width: 2,
106
+ height: 120
107
+ }, onLeft = !1, verticalAlign = "below";
108
+ } else {
109
+ const textOnLeft = "right" === direction, textX = textOnLeft ? -imageWidth / 2 - 120 - 240 : imageWidth / 2 + 120, textY = -55;
110
+ textBox = {
111
+ x: textX,
112
+ y: textY,
113
+ width: 240,
114
+ height: 110
115
+ }, contentBox = {
116
+ x: textX,
117
+ y: textY + titleLineHeight + 4,
118
+ width: 240,
119
+ height: 1e5
120
+ };
121
+ const imageEdgeX = textOnLeft ? -imageWidth / 2 : imageWidth / 2, textEdgeX = textOnLeft ? textX + 240 : textX;
122
+ connectorBox = {
123
+ x: Math.min(imageEdgeX, textEdgeX),
124
+ y: 0,
125
+ width: Math.abs(textEdgeX - imageEdgeX),
126
+ height: 2
127
+ }, onLeft = textOnLeft, verticalAlign = null;
128
+ }
129
+ return {
130
+ onLeft: onLeft,
131
+ verticalAlign: verticalAlign,
132
+ titleFontSize: titleFontSize,
133
+ titleLineHeight: titleLineHeight,
134
+ contentFontSize: contentFontSize,
135
+ contentLineHeight: contentLineHeight,
136
+ imageBox: imageBox,
137
+ textBox: textBox,
138
+ contentBox: contentBox,
139
+ connectorBox: connectorBox
140
+ };
141
+ }, buildWingBlockMark = (spec, block, index) => {
142
+ var _a, _b, _c, _e, _f;
143
+ const hasImage = !!block.image, contentText = Array.isArray(block.content) ? block.content : block.content ? [ block.content ] : [], themeColor = (0,
144
+ common_1.getThemeColor)(spec), showBackground = !0 === (null === (_a = spec.image) || void 0 === _a ? void 0 : _a.showBackground);
145
+ return {
146
+ type: "group",
147
+ id: `storyline-block-${null !== (_b = block.id) && void 0 !== _b ? _b : index}`,
148
+ name: `storyline-block-${index}`,
149
+ zIndex: vchart_1.LayoutZIndex.Mark + 1,
150
+ style: {
151
+ x: (_d, ctx) => getWingBlockCenter(spec, ctx, index).x,
152
+ y: (_d, ctx) => getWingBlockCenter(spec, ctx, index).y
153
+ },
154
+ children: [ {
155
+ type: "rect",
156
+ name: `storyline-block-connector-${index}`,
157
+ interactive: !1,
158
+ zIndex: vchart_1.LayoutZIndex.Mark + 2,
159
+ style: {
160
+ x: (_d, ctx) => getWingBlockMetrics(spec, 0, index).connectorBox.x,
161
+ y: (_d, ctx) => getWingBlockMetrics(spec, 0, index).connectorBox.y,
162
+ width: (_d, ctx) => getWingBlockMetrics(spec, 0, index).connectorBox.width,
163
+ height: (_d, ctx) => getWingBlockMetrics(spec, 0, index).connectorBox.height,
164
+ fill: themeColor,
165
+ opacity: .6
166
+ }
167
+ }, showBackground ? {
168
+ type: "symbol",
169
+ name: `storyline-block-image-halo-${index}`,
170
+ interactive: !1,
171
+ style: {
172
+ x: 0,
173
+ y: 0,
174
+ size: (_d, ctx) => Math.max(getWingBlockMetrics(spec, 0, index).imageBox.width, getWingBlockMetrics(spec, 0, index).imageBox.height) + 12,
175
+ symbolType: "circle",
176
+ fill: (0, common_1.withAlpha)(themeColor, .18),
177
+ stroke: themeColor,
178
+ lineWidth: 1.5
179
+ }
180
+ } : null, hasImage ? Object.assign(Object.assign({
181
+ type: "image",
182
+ name: `storyline-block-image-${index}`,
183
+ interactive: !1
184
+ }, (0, common_1.omitImageLayoutSpec)(spec.image)), {
185
+ style: Object.assign({
186
+ x: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.x,
187
+ y: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.y,
188
+ width: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.width,
189
+ height: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.height,
190
+ cornerRadius: (_d, ctx) => Math.min(getWingBlockMetrics(spec, 0, index).imageBox.width, getWingBlockMetrics(spec, 0, index).imageBox.height) / 2,
191
+ image: block.image,
192
+ repeatX: "no-repeat",
193
+ repeatY: "no-repeat",
194
+ imageMode: "cover",
195
+ imagePosition: "center"
196
+ }, null === (_c = spec.image) || void 0 === _c ? void 0 : _c.style)
197
+ }) : {
198
+ type: "rect",
199
+ name: `storyline-block-image-bg-${index}`,
200
+ interactive: !1,
201
+ style: {
202
+ x: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.x,
203
+ y: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.y,
204
+ width: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.width,
205
+ height: (_d, ctx) => getWingBlockMetrics(spec, 0, index).imageBox.height,
206
+ cornerRadius: (_d, ctx) => Math.min(getWingBlockMetrics(spec, 0, index).imageBox.width, getWingBlockMetrics(spec, 0, index).imageBox.height) / 2,
207
+ fill: "#ffffff",
208
+ stroke: themeColor,
209
+ lineWidth: 2
210
+ }
211
+ }, block.title ? Object.assign(Object.assign({
212
+ type: "text",
213
+ name: `storyline-block-title-${index}`,
214
+ interactive: !1,
215
+ zIndex: vchart_1.LayoutZIndex.Mark + 10
216
+ }, spec.title), {
217
+ style: Object.assign({
218
+ x: (_d, ctx) => {
219
+ const m = getWingBlockMetrics(spec, 0, index);
220
+ return m.verticalAlign ? m.textBox.x + m.textBox.width / 2 : m.onLeft ? m.textBox.x + m.textBox.width : m.textBox.x;
221
+ },
222
+ y: (_d, ctx) => getWingBlockMetrics(spec, 0, index).textBox.y,
223
+ text: block.title,
224
+ maxLineWidth: (_d, ctx) => getWingBlockMetrics(spec, 0, index).textBox.width,
225
+ fontSize: (_d, ctx) => getWingBlockMetrics(spec, 0, index).titleFontSize,
226
+ lineHeight: (_d, ctx) => getWingBlockMetrics(spec, 0, index).titleLineHeight,
227
+ fontWeight: "bold",
228
+ fill: themeColor,
229
+ stroke: "#fff",
230
+ lineWidth: 5,
231
+ lineJoin: "round",
232
+ textAlign: (_d, ctx) => {
233
+ const m = getWingBlockMetrics(spec, 0, index);
234
+ return m.verticalAlign ? "center" : m.onLeft ? "right" : "left";
235
+ },
236
+ textBaseline: "top"
237
+ }, null === (_e = spec.title) || void 0 === _e ? void 0 : _e.style)
238
+ }) : null, contentText.length ? Object.assign(Object.assign({
239
+ type: "text",
240
+ name: `storyline-block-content-${index}`,
241
+ interactive: !1,
242
+ zIndex: vchart_1.LayoutZIndex.Mark + 10
243
+ }, spec.content), {
244
+ textType: "rich",
245
+ style: Object.assign({
246
+ x: (_d, ctx) => {
247
+ const m = getWingBlockMetrics(spec, 0, index);
248
+ return m.verticalAlign ? m.contentBox.x + m.contentBox.width / 2 : m.onLeft ? m.contentBox.x + m.contentBox.width : m.contentBox.x;
249
+ },
250
+ y: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentBox.y,
251
+ width: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentBox.width,
252
+ height: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentBox.height,
253
+ maxLineWidth: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentBox.width,
254
+ heightLimit: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentBox.height,
255
+ text: (0, common_1.buildRichContent)(contentText, spec),
256
+ fontSize: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentFontSize,
257
+ lineHeight: (_d, ctx) => getWingBlockMetrics(spec, 0, index).contentLineHeight,
258
+ textAlign: (_d, ctx) => {
259
+ const m = getWingBlockMetrics(spec, 0, index);
260
+ return m.verticalAlign ? "center" : m.onLeft ? "right" : "left";
261
+ },
262
+ textBaseline: "top",
263
+ wordBreak: "break-word",
264
+ ellipsis: "...",
265
+ fill: "#1f2430"
266
+ }, null === (_f = spec.content) || void 0 === _f ? void 0 : _f.style)
267
+ }) : null ].filter(Boolean)
268
+ };
269
+ };
270
+
271
+ exports.buildWingBlockMark = buildWingBlockMark;
272
+ //# sourceMappingURL=wing.js.map