@visactor/vchart 1.0.1-alpha.1 → 1.1.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (870) hide show
  1. package/build/index.js +65046 -64871
  2. package/build/index.min.js +2 -2
  3. package/chart.d.ts +1 -1
  4. package/chart.js +1 -1
  5. package/cjs/chart/area/area.d.ts +1 -0
  6. package/cjs/chart/area/area.js +6 -1
  7. package/cjs/chart/area/area.js.map +1 -1
  8. package/cjs/chart/bar/bar-3d.d.ts +7 -0
  9. package/cjs/chart/bar/bar-3d.js +19 -0
  10. package/cjs/chart/bar/bar-3d.js.map +1 -0
  11. package/cjs/chart/bar/bar.d.ts +1 -6
  12. package/cjs/chart/bar/bar.js +7 -11
  13. package/cjs/chart/bar/bar.js.map +1 -1
  14. package/cjs/chart/bar/index.d.ts +1 -0
  15. package/cjs/chart/bar/index.js +2 -1
  16. package/cjs/chart/bar/index.js.map +1 -1
  17. package/cjs/chart/base-chart.d.ts +1 -1
  18. package/cjs/chart/base-chart.js +2 -1
  19. package/cjs/chart/base-chart.js.map +1 -1
  20. package/cjs/chart/box-plot/box-plot.js +4 -2
  21. package/cjs/chart/box-plot/box-plot.js.map +1 -1
  22. package/cjs/chart/circle-packing/circle-packing.js +3 -1
  23. package/cjs/chart/circle-packing/circle-packing.js.map +1 -1
  24. package/cjs/chart/funnel/base.d.ts +9 -0
  25. package/cjs/chart/funnel/base.js +47 -0
  26. package/cjs/chart/funnel/base.js.map +1 -0
  27. package/cjs/chart/funnel/funnel-3d.d.ts +7 -0
  28. package/cjs/chart/funnel/funnel-3d.js +19 -0
  29. package/cjs/chart/funnel/funnel-3d.js.map +1 -0
  30. package/cjs/chart/funnel/funnel.d.ts +1 -16
  31. package/cjs/chart/funnel/funnel.js +4 -48
  32. package/cjs/chart/funnel/funnel.js.map +1 -1
  33. package/cjs/chart/funnel/index.d.ts +1 -0
  34. package/cjs/chart/funnel/index.js +2 -1
  35. package/cjs/chart/funnel/index.js.map +1 -1
  36. package/cjs/chart/gauge/gauge.js +3 -1
  37. package/cjs/chart/gauge/gauge.js.map +1 -1
  38. package/cjs/chart/heatmap/heatmap.js +3 -1
  39. package/cjs/chart/heatmap/heatmap.js.map +1 -1
  40. package/cjs/chart/histogram/base.d.ts +5 -0
  41. package/cjs/chart/histogram/base.js +22 -0
  42. package/cjs/chart/histogram/base.js.map +1 -0
  43. package/cjs/chart/histogram/histogram-3d.d.ts +7 -0
  44. package/cjs/chart/histogram/histogram-3d.js +19 -0
  45. package/cjs/chart/histogram/histogram-3d.js.map +1 -0
  46. package/cjs/chart/histogram/histogram.d.ts +2 -12
  47. package/cjs/chart/histogram/histogram.js +7 -23
  48. package/cjs/chart/histogram/histogram.js.map +1 -1
  49. package/cjs/chart/histogram/index.d.ts +1 -0
  50. package/cjs/chart/histogram/index.js +2 -1
  51. package/cjs/chart/histogram/index.js.map +1 -1
  52. package/cjs/chart/index.d.ts +57 -22
  53. package/cjs/chart/index.js +293 -26
  54. package/cjs/chart/index.js.map +1 -1
  55. package/cjs/chart/line/line.d.ts +1 -0
  56. package/cjs/chart/line/line.js +6 -1
  57. package/cjs/chart/line/line.js.map +1 -1
  58. package/cjs/chart/map/map.js +3 -1
  59. package/cjs/chart/map/map.js.map +1 -1
  60. package/cjs/chart/pie/base.d.ts +5 -0
  61. package/cjs/chart/pie/base.js +26 -0
  62. package/cjs/chart/pie/base.js.map +1 -0
  63. package/cjs/chart/pie/index.d.ts +1 -0
  64. package/cjs/chart/pie/index.js +2 -1
  65. package/cjs/chart/pie/index.js.map +1 -1
  66. package/cjs/chart/pie/pie-3d.d.ts +8 -0
  67. package/cjs/chart/pie/pie-3d.js +24 -0
  68. package/cjs/chart/pie/pie-3d.js.map +1 -0
  69. package/cjs/chart/pie/pie.d.ts +1 -13
  70. package/cjs/chart/pie/pie.js +4 -32
  71. package/cjs/chart/pie/pie.js.map +1 -1
  72. package/cjs/chart/progress/circular/circular.js +3 -1
  73. package/cjs/chart/progress/circular/circular.js.map +1 -1
  74. package/cjs/chart/progress/linear/linear.js +3 -1
  75. package/cjs/chart/progress/linear/linear.js.map +1 -1
  76. package/cjs/chart/radar/radar.js +3 -1
  77. package/cjs/chart/radar/radar.js.map +1 -1
  78. package/cjs/chart/range-area/range-area.d.ts +1 -0
  79. package/cjs/chart/range-area/range-area.js +6 -1
  80. package/cjs/chart/range-area/range-area.js.map +1 -1
  81. package/cjs/chart/range-column/index.d.ts +2 -1
  82. package/cjs/chart/range-column/index.js +2 -1
  83. package/cjs/chart/range-column/index.js.map +1 -1
  84. package/cjs/chart/range-column/{rangeColumn.d.ts → range-column-3d.d.ts} +0 -7
  85. package/cjs/chart/range-column/{rangeColumn.js → range-column-3d.js} +4 -17
  86. package/cjs/chart/range-column/range-column-3d.js.map +1 -0
  87. package/cjs/chart/range-column/range-column.d.ts +9 -0
  88. package/cjs/chart/range-column/range-column.js +28 -0
  89. package/cjs/chart/range-column/range-column.js.map +1 -0
  90. package/cjs/chart/rose/rose.js +3 -1
  91. package/cjs/chart/rose/rose.js.map +1 -1
  92. package/cjs/chart/sankey/sankey.js +3 -1
  93. package/cjs/chart/sankey/sankey.js.map +1 -1
  94. package/cjs/chart/scatter/scatter.js +3 -1
  95. package/cjs/chart/scatter/scatter.js.map +1 -1
  96. package/cjs/chart/sequence/sequence.js +3 -1
  97. package/cjs/chart/sequence/sequence.js.map +1 -1
  98. package/cjs/chart/sunburst/sunburst.js +3 -1
  99. package/cjs/chart/sunburst/sunburst.js.map +1 -1
  100. package/cjs/chart/treemap/treemap.js +3 -1
  101. package/cjs/chart/treemap/treemap.js.map +1 -1
  102. package/cjs/chart/util.d.ts +2 -0
  103. package/cjs/chart/util.js +23 -0
  104. package/cjs/chart/util.js.map +1 -0
  105. package/cjs/chart/waterfall/waterfall.js +4 -2
  106. package/cjs/chart/waterfall/waterfall.js.map +1 -1
  107. package/cjs/chart/word-cloud/base.d.ts +6 -0
  108. package/cjs/chart/word-cloud/base.js +25 -0
  109. package/cjs/chart/word-cloud/base.js.map +1 -0
  110. package/cjs/chart/word-cloud/index.d.ts +1 -0
  111. package/cjs/chart/word-cloud/index.js +2 -1
  112. package/cjs/chart/word-cloud/index.js.map +1 -1
  113. package/cjs/chart/word-cloud/word-cloud-3d.d.ts +9 -0
  114. package/cjs/chart/word-cloud/word-cloud-3d.js +46 -0
  115. package/cjs/chart/word-cloud/word-cloud-3d.js.map +1 -0
  116. package/cjs/chart/word-cloud/word-cloud.d.ts +2 -15
  117. package/cjs/chart/word-cloud/word-cloud.js +4 -53
  118. package/cjs/chart/word-cloud/word-cloud.js.map +1 -1
  119. package/cjs/component/axis/cartesian/axis.js +1 -1
  120. package/cjs/component/axis/cartesian/axis.js.map +1 -1
  121. package/cjs/component/crosshair/base.js +1 -2
  122. package/cjs/component/crosshair/base.js.map +1 -1
  123. package/cjs/component/crosshair/interface/spec.d.ts +1 -1
  124. package/cjs/component/crosshair/interface/spec.js.map +1 -1
  125. package/cjs/component/custom-mark/custom-mark.js.map +1 -1
  126. package/cjs/component/index.d.ts +39 -1
  127. package/cjs/component/index.js +202 -17
  128. package/cjs/component/index.js.map +1 -1
  129. package/cjs/component/legend/base-legend.d.ts +1 -1
  130. package/cjs/component/legend/base-legend.js +7 -3
  131. package/cjs/component/legend/base-legend.js.map +1 -1
  132. package/cjs/component/legend/util.d.ts +3 -3
  133. package/cjs/component/player/utils/transform.js +1 -3
  134. package/cjs/component/player/utils/transform.js.map +1 -1
  135. package/cjs/component/tooltip/handler/base.d.ts +5 -4
  136. package/cjs/component/tooltip/handler/base.js +44 -34
  137. package/cjs/component/tooltip/handler/base.js.map +1 -1
  138. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.d.ts +2 -2
  139. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.js +2 -2
  140. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.js.map +1 -1
  141. package/cjs/component/tooltip/handler/constants.d.ts +4 -0
  142. package/cjs/component/tooltip/handler/constants.js +5 -2
  143. package/cjs/component/tooltip/handler/constants.js.map +1 -1
  144. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.d.ts +6 -2
  145. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.js +20 -13
  146. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.js.map +1 -1
  147. package/cjs/component/tooltip/handler/dom/interface.d.ts +16 -5
  148. package/cjs/component/tooltip/handler/dom/interface.js.map +1 -1
  149. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.d.ts +7 -13
  150. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.js +12 -27
  151. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.js.map +1 -1
  152. package/cjs/component/tooltip/handler/dom/model/content-column-model.d.ts +13 -3
  153. package/cjs/component/tooltip/handler/dom/model/content-column-model.js +46 -26
  154. package/cjs/component/tooltip/handler/dom/model/content-column-model.js.map +1 -1
  155. package/cjs/component/tooltip/handler/dom/model/content-model.d.ts +4 -3
  156. package/cjs/component/tooltip/handler/dom/model/content-model.js +4 -4
  157. package/cjs/component/tooltip/handler/dom/model/content-model.js.map +1 -1
  158. package/cjs/component/tooltip/handler/dom/model/interface.d.ts +4 -0
  159. package/cjs/component/tooltip/handler/dom/model/interface.js.map +1 -1
  160. package/cjs/component/tooltip/handler/dom/model/shape-model.d.ts +5 -5
  161. package/cjs/component/tooltip/handler/dom/model/shape-model.js +4 -4
  162. package/cjs/component/tooltip/handler/dom/model/shape-model.js.map +1 -1
  163. package/cjs/component/tooltip/handler/dom/model/style-constants.d.ts +4 -4
  164. package/cjs/component/tooltip/handler/dom/model/style-constants.js +16 -18
  165. package/cjs/component/tooltip/handler/dom/model/style-constants.js.map +1 -1
  166. package/cjs/component/tooltip/handler/dom/model/text-model.js +1 -0
  167. package/cjs/component/tooltip/handler/dom/model/text-model.js.map +1 -1
  168. package/cjs/component/tooltip/handler/dom/model/title-model.d.ts +3 -2
  169. package/cjs/component/tooltip/handler/dom/model/title-model.js +15 -19
  170. package/cjs/component/tooltip/handler/dom/model/title-model.js.map +1 -1
  171. package/cjs/component/tooltip/handler/dom/model/tooltip-model.d.ts +1 -2
  172. package/cjs/component/tooltip/handler/dom/model/tooltip-model.js +21 -16
  173. package/cjs/component/tooltip/handler/dom/model/tooltip-model.js.map +1 -1
  174. package/cjs/component/tooltip/handler/dom/util.d.ts +5 -0
  175. package/cjs/component/tooltip/handler/dom/{utils/style.js → util.js} +32 -20
  176. package/cjs/component/tooltip/handler/dom/util.js.map +1 -0
  177. package/cjs/component/tooltip/handler/interface/index.d.ts +0 -1
  178. package/cjs/component/tooltip/handler/interface/index.js +1 -1
  179. package/cjs/component/tooltip/handler/interface/index.js.map +1 -1
  180. package/cjs/component/tooltip/handler/utils/attribute.js +12 -8
  181. package/cjs/component/tooltip/handler/utils/attribute.js.map +1 -1
  182. package/cjs/component/tooltip/handler/utils/common.d.ts +6 -2
  183. package/cjs/component/tooltip/handler/utils/common.js +30 -5
  184. package/cjs/component/tooltip/handler/utils/common.js.map +1 -1
  185. package/cjs/component/tooltip/handler/utils/compose.d.ts +3 -2
  186. package/cjs/component/tooltip/handler/utils/compose.js +56 -45
  187. package/cjs/component/tooltip/handler/utils/compose.js.map +1 -1
  188. package/cjs/component/tooltip/handler/utils/get-spec.js +64 -28
  189. package/cjs/component/tooltip/handler/utils/get-spec.js.map +1 -1
  190. package/cjs/component/tooltip/handler/utils/style.d.ts +2 -1
  191. package/cjs/component/tooltip/handler/utils/style.js +4 -4
  192. package/cjs/component/tooltip/handler/utils/style.js.map +1 -1
  193. package/cjs/component/tooltip/tooltip.d.ts +3 -1
  194. package/cjs/component/tooltip/tooltip.js +33 -18
  195. package/cjs/component/tooltip/tooltip.js.map +1 -1
  196. package/cjs/component/tooltip/utils/common.js +4 -2
  197. package/cjs/component/tooltip/utils/common.js.map +1 -1
  198. package/cjs/constant/word-cloud.js +2 -1
  199. package/cjs/core/factory.js +1 -2
  200. package/cjs/{export/core.d.ts → core/index.d.ts} +4 -4
  201. package/cjs/{export/core.js → core/index.js} +5 -5
  202. package/cjs/core/index.js.map +1 -0
  203. package/cjs/core/instance-manager.d.ts +1 -1
  204. package/cjs/core/instance-manager.js +1 -1
  205. package/cjs/core/instance-manager.js.map +1 -1
  206. package/cjs/core/interface.js +1 -1
  207. package/cjs/core/vchart.d.ts +1 -0
  208. package/cjs/core/vchart.js +11 -3
  209. package/cjs/core/vchart.js.map +1 -1
  210. package/cjs/data/initialize.js +2 -1
  211. package/cjs/index.d.ts +6 -6
  212. package/cjs/index.js +4 -4
  213. package/cjs/index.js.map +1 -1
  214. package/cjs/layout/base-layout.d.ts +24 -0
  215. package/cjs/layout/base-layout.js +123 -0
  216. package/cjs/layout/base-layout.js.map +1 -0
  217. package/cjs/layout/grid-layout/grid-layout.d.ts +5 -35
  218. package/cjs/layout/grid-layout/grid-layout.js +2 -1
  219. package/cjs/layout/grid-layout/grid-layout.js.map +1 -1
  220. package/cjs/layout/index.d.ts +6 -24
  221. package/cjs/layout/index.js +25 -115
  222. package/cjs/layout/index.js.map +1 -1
  223. package/cjs/layout/interface.d.ts +31 -3
  224. package/cjs/layout/interface.js.map +1 -1
  225. package/cjs/layout/layout3d/index.d.ts +1 -1
  226. package/cjs/layout/layout3d/index.js +2 -2
  227. package/cjs/layout/layout3d/index.js.map +1 -1
  228. package/cjs/mark/arc-3d.d.ts +9 -0
  229. package/cjs/mark/arc-3d.js +16 -0
  230. package/cjs/mark/arc-3d.js.map +1 -0
  231. package/cjs/mark/arc.d.ts +5 -9
  232. package/cjs/mark/arc.js +12 -22
  233. package/cjs/mark/arc.js.map +1 -1
  234. package/cjs/mark/area.js +1 -1
  235. package/cjs/mark/base/base-line.js +3 -3
  236. package/cjs/mark/base/base-line.js.map +1 -1
  237. package/cjs/mark/base/base-mark.d.ts +7 -0
  238. package/cjs/mark/base/base-mark.js +10 -6
  239. package/cjs/mark/base/base-mark.js.map +1 -1
  240. package/cjs/mark/box-plot.js +1 -1
  241. package/cjs/mark/cell.js +1 -1
  242. package/cjs/mark/index.d.ts +21 -0
  243. package/cjs/{export/mark.js → mark/index.js} +49 -37
  244. package/cjs/mark/index.js.map +1 -0
  245. package/cjs/mark/{linkPath.js → link-path.js} +1 -1
  246. package/cjs/mark/link-path.js.map +1 -0
  247. package/cjs/mark/polygon/base-polygon.d.ts +6 -0
  248. package/cjs/mark/polygon/base-polygon.js +18 -0
  249. package/cjs/mark/polygon/base-polygon.js.map +1 -0
  250. package/cjs/mark/polygon/polygon.d.ts +9 -0
  251. package/cjs/mark/polygon/polygon.js +16 -0
  252. package/cjs/mark/polygon/polygon.js.map +1 -0
  253. package/cjs/mark/polygon/pyramid-3d.d.ts +9 -0
  254. package/cjs/mark/polygon/pyramid-3d.js +16 -0
  255. package/cjs/mark/polygon/pyramid-3d.js.map +1 -0
  256. package/cjs/mark/rect-3d.d.ts +10 -0
  257. package/cjs/mark/rect-3d.js +23 -0
  258. package/cjs/mark/rect-3d.js.map +1 -0
  259. package/cjs/mark/rect.d.ts +1 -7
  260. package/cjs/mark/rect.js +1 -16
  261. package/cjs/mark/rect.js.map +1 -1
  262. package/cjs/mark/utils/common.d.ts +0 -12
  263. package/cjs/mark/utils/common.js +2 -13
  264. package/cjs/mark/utils/common.js.map +1 -1
  265. package/cjs/model/base-model.js +1 -1
  266. package/cjs/model/interface.js +1 -1
  267. package/cjs/model/layout-item.js +1 -1
  268. package/cjs/model/model-state-manager.js +1 -1
  269. package/cjs/model/tooltip-helper.d.ts +3 -4
  270. package/cjs/model/tooltip-helper.js +5 -10
  271. package/cjs/model/tooltip-helper.js.map +1 -1
  272. package/cjs/region/interface.js +1 -1
  273. package/cjs/region/region.js +5 -10
  274. package/cjs/region/region.js.map +1 -1
  275. package/cjs/series/area/area.js +3 -1
  276. package/cjs/series/area/area.js.map +1 -1
  277. package/cjs/series/bar/bar-3d.d.ts +11 -0
  278. package/cjs/series/bar/bar-3d.js +25 -0
  279. package/cjs/series/bar/bar-3d.js.map +1 -0
  280. package/cjs/series/bar/bar.d.ts +0 -7
  281. package/cjs/series/bar/bar.js +3 -18
  282. package/cjs/series/bar/bar.js.map +1 -1
  283. package/cjs/series/base/base-series.js +1 -1
  284. package/cjs/series/base/base-series.js.map +1 -1
  285. package/cjs/series/base/tooltip-helper.d.ts +9 -8
  286. package/cjs/series/base/tooltip-helper.js +23 -12
  287. package/cjs/series/base/tooltip-helper.js.map +1 -1
  288. package/cjs/series/box-plot/box-plot.js +5 -1
  289. package/cjs/series/box-plot/box-plot.js.map +1 -1
  290. package/cjs/series/circle-packing/circle-packing.js +3 -1
  291. package/cjs/series/circle-packing/circle-packing.js.map +1 -1
  292. package/cjs/series/dot/dot.js +3 -1
  293. package/cjs/series/dot/dot.js.map +1 -1
  294. package/cjs/series/dot/tooltip-helper.d.ts +1 -2
  295. package/cjs/series/dot/tooltip-helper.js +6 -5
  296. package/cjs/series/dot/tooltip-helper.js.map +1 -1
  297. package/cjs/series/funnel/funnel-3d.d.ts +18 -0
  298. package/cjs/series/funnel/funnel-3d.js +104 -0
  299. package/cjs/series/funnel/funnel-3d.js.map +1 -0
  300. package/cjs/series/funnel/funnel.d.ts +3 -15
  301. package/cjs/series/funnel/funnel.js +12 -104
  302. package/cjs/series/funnel/funnel.js.map +1 -1
  303. package/cjs/series/funnel/tooltip-helper.d.ts +5 -3
  304. package/cjs/series/funnel/tooltip-helper.js +10 -8
  305. package/cjs/series/funnel/tooltip-helper.js.map +1 -1
  306. package/cjs/series/gauge/gauge-pointer.js +3 -1
  307. package/cjs/series/gauge/gauge-pointer.js.map +1 -1
  308. package/cjs/series/gauge/gauge.js +3 -1
  309. package/cjs/series/gauge/gauge.js.map +1 -1
  310. package/cjs/series/heatmap/heatmap.js +2 -2
  311. package/cjs/series/heatmap/heatmap.js.map +1 -1
  312. package/cjs/series/index.d.ts +66 -0
  313. package/cjs/{export/series.js → series/index.js} +70 -50
  314. package/cjs/series/index.js.map +1 -0
  315. package/cjs/series/interface/series.d.ts +2 -1
  316. package/cjs/series/interface/series.js.map +1 -1
  317. package/cjs/series/interface/tooltip-helper.d.ts +6 -6
  318. package/cjs/series/interface/tooltip-helper.js.map +1 -1
  319. package/cjs/series/line/line.js +3 -1
  320. package/cjs/series/line/line.js.map +1 -1
  321. package/cjs/series/link/link.js +3 -1
  322. package/cjs/series/link/link.js.map +1 -1
  323. package/cjs/series/map/map.js +2 -2
  324. package/cjs/series/map/map.js.map +1 -1
  325. package/cjs/series/pie/pie-3d.d.ts +16 -0
  326. package/cjs/series/pie/pie-3d.js +97 -0
  327. package/cjs/series/pie/pie-3d.js.map +1 -0
  328. package/cjs/series/pie/pie.d.ts +1 -11
  329. package/cjs/series/pie/pie.js +4 -89
  330. package/cjs/series/pie/pie.js.map +1 -1
  331. package/cjs/series/polar/animation.d.ts +1 -1
  332. package/cjs/series/polar/animation.js.map +1 -1
  333. package/cjs/series/progress/circular/circular.js +3 -1
  334. package/cjs/series/progress/circular/circular.js.map +1 -1
  335. package/cjs/series/progress/linear/linear.js +3 -1
  336. package/cjs/series/progress/linear/linear.js.map +1 -1
  337. package/cjs/series/radar/animation.d.ts +1 -1
  338. package/cjs/series/radar/animation.js.map +1 -1
  339. package/cjs/series/radar/radar.js +3 -1
  340. package/cjs/series/radar/radar.js.map +1 -1
  341. package/cjs/series/range-column/rangeColumn-3d.d.ts +10 -0
  342. package/cjs/series/range-column/rangeColumn-3d.js +19 -0
  343. package/cjs/series/range-column/rangeColumn-3d.js.map +1 -0
  344. package/cjs/series/range-column/rangeColumn.d.ts +0 -6
  345. package/cjs/series/range-column/rangeColumn.js +1 -10
  346. package/cjs/series/range-column/rangeColumn.js.map +1 -1
  347. package/cjs/series/rose/rose.js +2 -2
  348. package/cjs/series/rose/rose.js.map +1 -1
  349. package/cjs/series/sankey/sankey.js +2 -1
  350. package/cjs/series/sankey/sankey.js.map +1 -1
  351. package/cjs/series/scatter/scatter.js +3 -1
  352. package/cjs/series/scatter/scatter.js.map +1 -1
  353. package/cjs/series/sunburst/sunburst.js +3 -1
  354. package/cjs/series/sunburst/sunburst.js.map +1 -1
  355. package/cjs/series/treemap/treemap.js +3 -1
  356. package/cjs/series/treemap/treemap.js.map +1 -1
  357. package/cjs/series/waterfall/waterfall.js +2 -2
  358. package/cjs/series/waterfall/waterfall.js.map +1 -1
  359. package/cjs/series/word-cloud/base.d.ts +60 -0
  360. package/cjs/series/word-cloud/base.js +254 -0
  361. package/cjs/series/word-cloud/base.js.map +1 -0
  362. package/cjs/series/word-cloud/word-cloud-3d.d.ts +11 -0
  363. package/cjs/series/word-cloud/word-cloud-3d.js +199 -0
  364. package/cjs/series/word-cloud/word-cloud-3d.js.map +1 -0
  365. package/cjs/series/word-cloud/word-cloud.d.ts +2 -69
  366. package/cjs/series/word-cloud/word-cloud.js +5 -441
  367. package/cjs/series/word-cloud/word-cloud.js.map +1 -1
  368. package/cjs/theme/buildin-theme/index.d.ts +0 -1
  369. package/cjs/theme/buildin-theme/index.js +3 -3
  370. package/cjs/theme/buildin-theme/index.js.map +1 -1
  371. package/cjs/theme/buildin-theme/light/component/crosshair.js +4 -4
  372. package/cjs/theme/buildin-theme/light/component/crosshair.js.map +1 -1
  373. package/cjs/theme/buildin-theme/light/component/tooltip.js +1 -0
  374. package/cjs/theme/buildin-theme/light/component/tooltip.js.map +1 -1
  375. package/cjs/typings/spec/common.d.ts +1 -1
  376. package/cjs/typings/spec/common.js.map +1 -1
  377. package/cjs/typings/tooltip/common.d.ts +7 -1
  378. package/cjs/typings/tooltip/common.js.map +1 -1
  379. package/cjs/typings/tooltip/handler.d.ts +1 -1
  380. package/cjs/typings/tooltip/handler.js.map +1 -1
  381. package/cjs/typings/tooltip/line.d.ts +6 -4
  382. package/cjs/typings/tooltip/line.js.map +1 -1
  383. package/cjs/typings/tooltip/shape.d.ts +3 -3
  384. package/cjs/typings/tooltip/shape.js.map +1 -1
  385. package/cjs/typings/tooltip/tooltip.d.ts +11 -8
  386. package/cjs/typings/tooltip/tooltip.js.map +1 -1
  387. package/cjs/typings/visual.d.ts +4 -11
  388. package/cjs/typings/visual.js.map +1 -1
  389. package/cjs/util/debug.d.ts +3 -3
  390. package/cjs/util/debug.js +11 -20
  391. package/cjs/util/debug.js.map +1 -1
  392. package/cjs/util/index.d.ts +1 -0
  393. package/cjs/util/index.js +2 -1
  394. package/cjs/util/index.js.map +1 -1
  395. package/cjs/util/style.js +3 -7
  396. package/cjs/util/style.js.map +1 -1
  397. package/cjs/vchart-all.d.ts +1 -1
  398. package/cjs/vchart-all.js +3 -5
  399. package/cjs/vchart-all.js.map +1 -1
  400. package/cjs/vchart-simple.d.ts +1 -1
  401. package/cjs/vchart-simple.js +2 -4
  402. package/cjs/vchart-simple.js.map +1 -1
  403. package/component.d.ts +1 -1
  404. package/component.js +1 -1
  405. package/core.d.ts +1 -1
  406. package/core.js +1 -1
  407. package/esm/chart/area/area.d.ts +1 -0
  408. package/esm/chart/area/area.js +11 -0
  409. package/esm/chart/area/area.js.map +1 -1
  410. package/esm/chart/bar/bar-3d.d.ts +7 -0
  411. package/esm/chart/bar/bar-3d.js +20 -0
  412. package/esm/chart/bar/bar-3d.js.map +1 -0
  413. package/esm/chart/bar/bar.d.ts +1 -6
  414. package/esm/chart/bar/bar.js +11 -8
  415. package/esm/chart/bar/bar.js.map +1 -1
  416. package/esm/chart/bar/index.d.ts +1 -0
  417. package/esm/chart/bar/index.js +2 -0
  418. package/esm/chart/bar/index.js.map +1 -1
  419. package/esm/chart/base-chart.d.ts +1 -1
  420. package/esm/chart/base-chart.js +2 -1
  421. package/esm/chart/base-chart.js.map +1 -1
  422. package/esm/chart/box-plot/box-plot.js +9 -1
  423. package/esm/chart/box-plot/box-plot.js.map +1 -1
  424. package/esm/chart/circle-packing/circle-packing.js +6 -0
  425. package/esm/chart/circle-packing/circle-packing.js.map +1 -1
  426. package/esm/chart/funnel/base.d.ts +9 -0
  427. package/esm/chart/funnel/base.js +39 -0
  428. package/esm/chart/funnel/base.js.map +1 -0
  429. package/esm/chart/funnel/funnel-3d.d.ts +7 -0
  430. package/esm/chart/funnel/funnel-3d.js +20 -0
  431. package/esm/chart/funnel/funnel-3d.js.map +1 -0
  432. package/esm/chart/funnel/funnel.d.ts +1 -16
  433. package/esm/chart/funnel/funnel.js +7 -46
  434. package/esm/chart/funnel/funnel.js.map +1 -1
  435. package/esm/chart/funnel/index.d.ts +1 -0
  436. package/esm/chart/funnel/index.js +2 -0
  437. package/esm/chart/funnel/index.js.map +1 -1
  438. package/esm/chart/gauge/gauge.js +6 -0
  439. package/esm/chart/gauge/gauge.js.map +1 -1
  440. package/esm/chart/heatmap/heatmap.js +6 -0
  441. package/esm/chart/heatmap/heatmap.js.map +1 -1
  442. package/esm/chart/histogram/base.d.ts +5 -0
  443. package/esm/chart/histogram/base.js +14 -0
  444. package/esm/chart/histogram/base.js.map +1 -0
  445. package/esm/chart/histogram/histogram-3d.d.ts +7 -0
  446. package/esm/chart/histogram/histogram-3d.js +20 -0
  447. package/esm/chart/histogram/histogram-3d.js.map +1 -0
  448. package/esm/chart/histogram/histogram.d.ts +2 -12
  449. package/esm/chart/histogram/histogram.js +12 -21
  450. package/esm/chart/histogram/histogram.js.map +1 -1
  451. package/esm/chart/histogram/index.d.ts +1 -0
  452. package/esm/chart/histogram/index.js +2 -0
  453. package/esm/chart/histogram/index.js.map +1 -1
  454. package/esm/chart/index.d.ts +57 -22
  455. package/esm/chart/index.js +36 -22
  456. package/esm/chart/index.js.map +1 -1
  457. package/esm/chart/line/line.d.ts +1 -0
  458. package/esm/chart/line/line.js +11 -0
  459. package/esm/chart/line/line.js.map +1 -1
  460. package/esm/chart/map/map.js +6 -0
  461. package/esm/chart/map/map.js.map +1 -1
  462. package/esm/chart/pie/base.d.ts +5 -0
  463. package/esm/chart/pie/base.js +18 -0
  464. package/esm/chart/pie/base.js.map +1 -0
  465. package/esm/chart/pie/index.d.ts +1 -0
  466. package/esm/chart/pie/index.js +2 -0
  467. package/esm/chart/pie/index.js.map +1 -1
  468. package/esm/chart/pie/pie-3d.d.ts +8 -0
  469. package/esm/chart/pie/pie-3d.js +25 -0
  470. package/esm/chart/pie/pie-3d.js.map +1 -0
  471. package/esm/chart/pie/pie.d.ts +1 -13
  472. package/esm/chart/pie/pie.js +6 -29
  473. package/esm/chart/pie/pie.js.map +1 -1
  474. package/esm/chart/progress/circular/circular.js +6 -0
  475. package/esm/chart/progress/circular/circular.js.map +1 -1
  476. package/esm/chart/progress/linear/linear.js +6 -0
  477. package/esm/chart/progress/linear/linear.js.map +1 -1
  478. package/esm/chart/radar/radar.js +6 -0
  479. package/esm/chart/radar/radar.js.map +1 -1
  480. package/esm/chart/range-area/range-area.d.ts +1 -0
  481. package/esm/chart/range-area/range-area.js +11 -0
  482. package/esm/chart/range-area/range-area.js.map +1 -1
  483. package/esm/chart/range-column/index.d.ts +2 -1
  484. package/esm/chart/range-column/index.js +3 -1
  485. package/esm/chart/range-column/index.js.map +1 -1
  486. package/esm/chart/range-column/{rangeColumn.d.ts → range-column-3d.d.ts} +0 -7
  487. package/esm/chart/range-column/{rangeColumn.js → range-column-3d.js} +5 -13
  488. package/esm/chart/range-column/range-column-3d.js.map +1 -0
  489. package/esm/chart/range-column/range-column.d.ts +9 -0
  490. package/esm/chart/range-column/range-column.js +33 -0
  491. package/esm/chart/range-column/range-column.js.map +1 -0
  492. package/esm/chart/rose/rose.js +6 -0
  493. package/esm/chart/rose/rose.js.map +1 -1
  494. package/esm/chart/sankey/sankey.js +6 -0
  495. package/esm/chart/sankey/sankey.js.map +1 -1
  496. package/esm/chart/scatter/scatter.js +6 -0
  497. package/esm/chart/scatter/scatter.js.map +1 -1
  498. package/esm/chart/sequence/sequence.js +6 -0
  499. package/esm/chart/sequence/sequence.js.map +1 -1
  500. package/esm/chart/sunburst/sunburst.js +6 -0
  501. package/esm/chart/sunburst/sunburst.js.map +1 -1
  502. package/esm/chart/treemap/treemap.js +6 -0
  503. package/esm/chart/treemap/treemap.js.map +1 -1
  504. package/esm/chart/util.d.ts +2 -0
  505. package/esm/chart/util.js +16 -0
  506. package/esm/chart/util.js.map +1 -0
  507. package/esm/chart/waterfall/waterfall.js +9 -1
  508. package/esm/chart/waterfall/waterfall.js.map +1 -1
  509. package/esm/chart/word-cloud/base.d.ts +6 -0
  510. package/esm/chart/word-cloud/base.js +21 -0
  511. package/esm/chart/word-cloud/base.js.map +1 -0
  512. package/esm/chart/word-cloud/index.d.ts +1 -0
  513. package/esm/chart/word-cloud/index.js +2 -0
  514. package/esm/chart/word-cloud/index.js.map +1 -1
  515. package/esm/chart/word-cloud/word-cloud-3d.d.ts +9 -0
  516. package/esm/chart/word-cloud/word-cloud-3d.js +47 -0
  517. package/esm/chart/word-cloud/word-cloud-3d.js.map +1 -0
  518. package/esm/chart/word-cloud/word-cloud.d.ts +2 -15
  519. package/esm/chart/word-cloud/word-cloud.js +6 -50
  520. package/esm/chart/word-cloud/word-cloud.js.map +1 -1
  521. package/esm/component/axis/cartesian/axis.js +2 -2
  522. package/esm/component/axis/cartesian/axis.js.map +1 -1
  523. package/esm/component/crosshair/base.js +1 -2
  524. package/esm/component/crosshair/base.js.map +1 -1
  525. package/esm/component/crosshair/interface/spec.d.ts +1 -1
  526. package/esm/component/crosshair/interface/spec.js.map +1 -1
  527. package/esm/component/custom-mark/custom-mark.js.map +1 -1
  528. package/esm/component/index.d.ts +39 -1
  529. package/esm/component/index.js +39 -2
  530. package/esm/component/index.js.map +1 -1
  531. package/esm/component/legend/base-legend.d.ts +1 -1
  532. package/esm/component/legend/base-legend.js +7 -3
  533. package/esm/component/legend/base-legend.js.map +1 -1
  534. package/esm/component/legend/util.d.ts +3 -3
  535. package/esm/component/player/utils/transform.js +1 -3
  536. package/esm/component/player/utils/transform.js.map +1 -1
  537. package/esm/component/tooltip/handler/base.d.ts +5 -4
  538. package/esm/component/tooltip/handler/base.js +45 -35
  539. package/esm/component/tooltip/handler/base.js.map +1 -1
  540. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.d.ts +2 -2
  541. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.js +2 -3
  542. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.js.map +1 -1
  543. package/esm/component/tooltip/handler/constants.d.ts +4 -0
  544. package/esm/component/tooltip/handler/constants.js +9 -0
  545. package/esm/component/tooltip/handler/constants.js.map +1 -1
  546. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.d.ts +6 -2
  547. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.js +20 -12
  548. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.js.map +1 -1
  549. package/esm/component/tooltip/handler/dom/interface.d.ts +16 -5
  550. package/esm/component/tooltip/handler/dom/interface.js.map +1 -1
  551. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.d.ts +7 -13
  552. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.js +11 -29
  553. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.js.map +1 -1
  554. package/esm/component/tooltip/handler/dom/model/content-column-model.d.ts +13 -3
  555. package/esm/component/tooltip/handler/dom/model/content-column-model.js +46 -24
  556. package/esm/component/tooltip/handler/dom/model/content-column-model.js.map +1 -1
  557. package/esm/component/tooltip/handler/dom/model/content-model.d.ts +4 -3
  558. package/esm/component/tooltip/handler/dom/model/content-model.js +5 -5
  559. package/esm/component/tooltip/handler/dom/model/content-model.js.map +1 -1
  560. package/esm/component/tooltip/handler/dom/model/interface.d.ts +4 -0
  561. package/esm/component/tooltip/handler/dom/model/interface.js.map +1 -1
  562. package/esm/component/tooltip/handler/dom/model/shape-model.d.ts +5 -5
  563. package/esm/component/tooltip/handler/dom/model/shape-model.js +4 -4
  564. package/esm/component/tooltip/handler/dom/model/shape-model.js.map +1 -1
  565. package/esm/component/tooltip/handler/dom/model/style-constants.d.ts +4 -4
  566. package/esm/component/tooltip/handler/dom/model/style-constants.js +18 -20
  567. package/esm/component/tooltip/handler/dom/model/style-constants.js.map +1 -1
  568. package/esm/component/tooltip/handler/dom/model/text-model.js +1 -0
  569. package/esm/component/tooltip/handler/dom/model/text-model.js.map +1 -1
  570. package/esm/component/tooltip/handler/dom/model/title-model.d.ts +3 -2
  571. package/esm/component/tooltip/handler/dom/model/title-model.js +15 -19
  572. package/esm/component/tooltip/handler/dom/model/title-model.js.map +1 -1
  573. package/esm/component/tooltip/handler/dom/model/tooltip-model.d.ts +1 -2
  574. package/esm/component/tooltip/handler/dom/model/tooltip-model.js +22 -16
  575. package/esm/component/tooltip/handler/dom/model/tooltip-model.js.map +1 -1
  576. package/esm/component/tooltip/handler/dom/util.d.ts +5 -0
  577. package/esm/component/tooltip/handler/dom/util.js +71 -0
  578. package/esm/component/tooltip/handler/dom/util.js.map +1 -0
  579. package/esm/component/tooltip/handler/interface/index.d.ts +0 -1
  580. package/esm/component/tooltip/handler/interface/index.js +0 -2
  581. package/esm/component/tooltip/handler/interface/index.js.map +1 -1
  582. package/esm/component/tooltip/handler/utils/attribute.js +11 -7
  583. package/esm/component/tooltip/handler/utils/attribute.js.map +1 -1
  584. package/esm/component/tooltip/handler/utils/common.d.ts +6 -2
  585. package/esm/component/tooltip/handler/utils/common.js +25 -2
  586. package/esm/component/tooltip/handler/utils/common.js.map +1 -1
  587. package/esm/component/tooltip/handler/utils/compose.d.ts +3 -2
  588. package/esm/component/tooltip/handler/utils/compose.js +52 -43
  589. package/esm/component/tooltip/handler/utils/compose.js.map +1 -1
  590. package/esm/component/tooltip/handler/utils/get-spec.js +60 -23
  591. package/esm/component/tooltip/handler/utils/get-spec.js.map +1 -1
  592. package/esm/component/tooltip/handler/utils/style.d.ts +2 -1
  593. package/esm/component/tooltip/handler/utils/style.js +4 -4
  594. package/esm/component/tooltip/handler/utils/style.js.map +1 -1
  595. package/esm/component/tooltip/tooltip.d.ts +3 -1
  596. package/esm/component/tooltip/tooltip.js +33 -18
  597. package/esm/component/tooltip/tooltip.js.map +1 -1
  598. package/esm/component/tooltip/utils/common.js +4 -2
  599. package/esm/component/tooltip/utils/common.js.map +1 -1
  600. package/esm/constant/word-cloud.js +2 -1
  601. package/esm/core/factory.js +1 -2
  602. package/esm/{export/core.d.ts → core/index.d.ts} +4 -4
  603. package/esm/{export/core.js → core/index.js} +5 -5
  604. package/esm/core/index.js.map +1 -0
  605. package/esm/core/instance-manager.d.ts +1 -1
  606. package/esm/core/instance-manager.js +1 -1
  607. package/esm/core/instance-manager.js.map +1 -1
  608. package/esm/core/interface.js +1 -1
  609. package/esm/core/vchart.d.ts +1 -0
  610. package/esm/core/vchart.js +10 -3
  611. package/esm/core/vchart.js.map +1 -1
  612. package/esm/data/initialize.js +2 -1
  613. package/esm/index.d.ts +6 -6
  614. package/esm/index.js +6 -6
  615. package/esm/index.js.map +1 -1
  616. package/esm/layout/base-layout.d.ts +24 -0
  617. package/esm/layout/base-layout.js +115 -0
  618. package/esm/layout/base-layout.js.map +1 -0
  619. package/esm/layout/grid-layout/grid-layout.d.ts +5 -35
  620. package/esm/layout/grid-layout/grid-layout.js +2 -1
  621. package/esm/layout/grid-layout/grid-layout.js.map +1 -1
  622. package/esm/layout/index.d.ts +6 -24
  623. package/esm/layout/index.js +8 -115
  624. package/esm/layout/index.js.map +1 -1
  625. package/esm/layout/interface.d.ts +31 -3
  626. package/esm/layout/interface.js.map +1 -1
  627. package/esm/layout/layout3d/index.d.ts +1 -1
  628. package/esm/layout/layout3d/index.js +1 -1
  629. package/esm/layout/layout3d/index.js.map +1 -1
  630. package/esm/mark/arc-3d.d.ts +9 -0
  631. package/esm/mark/arc-3d.js +12 -0
  632. package/esm/mark/arc-3d.js.map +1 -0
  633. package/esm/mark/arc.d.ts +5 -9
  634. package/esm/mark/arc.js +11 -21
  635. package/esm/mark/arc.js.map +1 -1
  636. package/esm/mark/area.js +1 -1
  637. package/esm/mark/base/base-line.js +2 -4
  638. package/esm/mark/base/base-line.js.map +1 -1
  639. package/esm/mark/base/base-mark.d.ts +7 -0
  640. package/esm/mark/base/base-mark.js +9 -7
  641. package/esm/mark/base/base-mark.js.map +1 -1
  642. package/esm/mark/box-plot.js +1 -1
  643. package/esm/mark/cell.js +1 -1
  644. package/esm/mark/index.d.ts +21 -0
  645. package/esm/mark/index.js +40 -0
  646. package/esm/mark/index.js.map +1 -0
  647. package/esm/mark/{linkPath.js → link-path.js} +1 -1
  648. package/esm/mark/link-path.js.map +1 -0
  649. package/esm/mark/polygon/base-polygon.d.ts +6 -0
  650. package/esm/mark/polygon/base-polygon.js +10 -0
  651. package/esm/mark/polygon/base-polygon.js.map +1 -0
  652. package/esm/mark/polygon/polygon.d.ts +9 -0
  653. package/esm/mark/polygon/polygon.js +12 -0
  654. package/esm/mark/polygon/polygon.js.map +1 -0
  655. package/esm/mark/polygon/pyramid-3d.d.ts +9 -0
  656. package/esm/mark/polygon/pyramid-3d.js +12 -0
  657. package/esm/mark/polygon/pyramid-3d.js.map +1 -0
  658. package/esm/mark/rect-3d.d.ts +10 -0
  659. package/esm/mark/rect-3d.js +19 -0
  660. package/esm/mark/rect-3d.js.map +1 -0
  661. package/esm/mark/rect.d.ts +1 -7
  662. package/esm/mark/rect.js +0 -15
  663. package/esm/mark/rect.js.map +1 -1
  664. package/esm/mark/utils/common.d.ts +0 -12
  665. package/esm/mark/utils/common.js +0 -13
  666. package/esm/mark/utils/common.js.map +1 -1
  667. package/esm/model/base-model.js +1 -1
  668. package/esm/model/interface.js +1 -1
  669. package/esm/model/layout-item.js +1 -1
  670. package/esm/model/model-state-manager.js +1 -1
  671. package/esm/model/tooltip-helper.d.ts +3 -4
  672. package/esm/model/tooltip-helper.js +5 -10
  673. package/esm/model/tooltip-helper.js.map +1 -1
  674. package/esm/region/interface.js +1 -1
  675. package/esm/region/region.js +6 -10
  676. package/esm/region/region.js.map +1 -1
  677. package/esm/series/area/area.js +12 -0
  678. package/esm/series/area/area.js.map +1 -1
  679. package/esm/series/bar/bar-3d.d.ts +11 -0
  680. package/esm/series/bar/bar-3d.js +30 -0
  681. package/esm/series/bar/bar-3d.js.map +1 -0
  682. package/esm/series/bar/bar.d.ts +0 -7
  683. package/esm/series/bar/bar.js +8 -14
  684. package/esm/series/bar/bar.js.map +1 -1
  685. package/esm/series/base/base-series.js +1 -1
  686. package/esm/series/base/base-series.js.map +1 -1
  687. package/esm/series/base/tooltip-helper.d.ts +9 -8
  688. package/esm/series/base/tooltip-helper.js +23 -12
  689. package/esm/series/base/tooltip-helper.js.map +1 -1
  690. package/esm/series/box-plot/box-plot.js +8 -0
  691. package/esm/series/box-plot/box-plot.js.map +1 -1
  692. package/esm/series/circle-packing/circle-packing.js +8 -0
  693. package/esm/series/circle-packing/circle-packing.js.map +1 -1
  694. package/esm/series/dot/dot.js +12 -0
  695. package/esm/series/dot/dot.js.map +1 -1
  696. package/esm/series/dot/tooltip-helper.d.ts +1 -2
  697. package/esm/series/dot/tooltip-helper.js +7 -4
  698. package/esm/series/dot/tooltip-helper.js.map +1 -1
  699. package/esm/series/funnel/funnel-3d.d.ts +18 -0
  700. package/esm/series/funnel/funnel-3d.js +113 -0
  701. package/esm/series/funnel/funnel-3d.js.map +1 -0
  702. package/esm/series/funnel/funnel.d.ts +3 -15
  703. package/esm/series/funnel/funnel.js +18 -101
  704. package/esm/series/funnel/funnel.js.map +1 -1
  705. package/esm/series/funnel/tooltip-helper.d.ts +5 -3
  706. package/esm/series/funnel/tooltip-helper.js +11 -7
  707. package/esm/series/funnel/tooltip-helper.js.map +1 -1
  708. package/esm/series/gauge/gauge-pointer.js +8 -0
  709. package/esm/series/gauge/gauge-pointer.js.map +1 -1
  710. package/esm/series/gauge/gauge.js +6 -0
  711. package/esm/series/gauge/gauge.js.map +1 -1
  712. package/esm/series/heatmap/heatmap.js +8 -0
  713. package/esm/series/heatmap/heatmap.js.map +1 -1
  714. package/esm/series/index.d.ts +66 -0
  715. package/esm/series/index.js +70 -0
  716. package/esm/series/index.js.map +1 -0
  717. package/esm/series/interface/series.d.ts +2 -1
  718. package/esm/series/interface/series.js.map +1 -1
  719. package/esm/series/interface/tooltip-helper.d.ts +6 -6
  720. package/esm/series/interface/tooltip-helper.js.map +1 -1
  721. package/esm/series/line/line.js +10 -0
  722. package/esm/series/line/line.js.map +1 -1
  723. package/esm/series/link/link.js +8 -0
  724. package/esm/series/link/link.js.map +1 -1
  725. package/esm/series/map/map.js +7 -1
  726. package/esm/series/map/map.js.map +1 -1
  727. package/esm/series/pie/pie-3d.d.ts +16 -0
  728. package/esm/series/pie/pie-3d.js +107 -0
  729. package/esm/series/pie/pie-3d.js.map +1 -0
  730. package/esm/series/pie/pie.d.ts +1 -11
  731. package/esm/series/pie/pie.js +10 -83
  732. package/esm/series/pie/pie.js.map +1 -1
  733. package/esm/series/polar/animation.d.ts +1 -1
  734. package/esm/series/polar/animation.js.map +1 -1
  735. package/esm/series/progress/circular/circular.js +8 -0
  736. package/esm/series/progress/circular/circular.js.map +1 -1
  737. package/esm/series/progress/linear/linear.js +6 -0
  738. package/esm/series/progress/linear/linear.js.map +1 -1
  739. package/esm/series/radar/animation.d.ts +1 -1
  740. package/esm/series/radar/animation.js.map +1 -1
  741. package/esm/series/radar/radar.js +12 -0
  742. package/esm/series/radar/radar.js.map +1 -1
  743. package/esm/series/range-column/rangeColumn-3d.d.ts +10 -0
  744. package/esm/series/range-column/rangeColumn-3d.js +23 -0
  745. package/esm/series/range-column/rangeColumn-3d.js.map +1 -0
  746. package/esm/series/range-column/rangeColumn.d.ts +0 -6
  747. package/esm/series/range-column/rangeColumn.js +0 -9
  748. package/esm/series/range-column/rangeColumn.js.map +1 -1
  749. package/esm/series/rose/rose.js +8 -0
  750. package/esm/series/rose/rose.js.map +1 -1
  751. package/esm/series/sankey/sankey.js +9 -1
  752. package/esm/series/sankey/sankey.js.map +1 -1
  753. package/esm/series/scatter/scatter.js +8 -0
  754. package/esm/series/scatter/scatter.js.map +1 -1
  755. package/esm/series/sunburst/sunburst.js +8 -0
  756. package/esm/series/sunburst/sunburst.js.map +1 -1
  757. package/esm/series/treemap/treemap.js +8 -0
  758. package/esm/series/treemap/treemap.js.map +1 -1
  759. package/esm/series/waterfall/waterfall.js +6 -0
  760. package/esm/series/waterfall/waterfall.js.map +1 -1
  761. package/esm/series/word-cloud/base.d.ts +60 -0
  762. package/esm/series/word-cloud/base.js +278 -0
  763. package/esm/series/word-cloud/base.js.map +1 -0
  764. package/esm/series/word-cloud/word-cloud-3d.d.ts +11 -0
  765. package/esm/series/word-cloud/word-cloud-3d.js +205 -0
  766. package/esm/series/word-cloud/word-cloud-3d.js.map +1 -0
  767. package/esm/series/word-cloud/word-cloud.d.ts +2 -69
  768. package/esm/series/word-cloud/word-cloud.js +2 -461
  769. package/esm/series/word-cloud/word-cloud.js.map +1 -1
  770. package/esm/theme/buildin-theme/index.d.ts +0 -1
  771. package/esm/theme/buildin-theme/index.js +1 -5
  772. package/esm/theme/buildin-theme/index.js.map +1 -1
  773. package/esm/theme/buildin-theme/light/component/crosshair.js +4 -4
  774. package/esm/theme/buildin-theme/light/component/crosshair.js.map +1 -1
  775. package/esm/theme/buildin-theme/light/component/tooltip.js +1 -0
  776. package/esm/theme/buildin-theme/light/component/tooltip.js.map +1 -1
  777. package/esm/typings/spec/common.d.ts +1 -1
  778. package/esm/typings/spec/common.js.map +1 -1
  779. package/esm/typings/tooltip/common.d.ts +7 -1
  780. package/esm/typings/tooltip/common.js.map +1 -1
  781. package/esm/typings/tooltip/handler.d.ts +1 -1
  782. package/esm/typings/tooltip/handler.js.map +1 -1
  783. package/esm/typings/tooltip/line.d.ts +6 -4
  784. package/esm/typings/tooltip/line.js.map +1 -1
  785. package/esm/typings/tooltip/shape.d.ts +3 -3
  786. package/esm/typings/tooltip/shape.js.map +1 -1
  787. package/esm/typings/tooltip/tooltip.d.ts +11 -8
  788. package/esm/typings/tooltip/tooltip.js.map +1 -1
  789. package/esm/typings/visual.d.ts +4 -11
  790. package/esm/typings/visual.js.map +1 -1
  791. package/esm/util/debug.d.ts +3 -3
  792. package/esm/util/debug.js +11 -14
  793. package/esm/util/debug.js.map +1 -1
  794. package/esm/util/index.d.ts +1 -0
  795. package/esm/util/index.js +2 -0
  796. package/esm/util/index.js.map +1 -1
  797. package/esm/util/style.js +3 -8
  798. package/esm/util/style.js.map +1 -1
  799. package/esm/vchart-all.d.ts +1 -1
  800. package/esm/vchart-all.js +4 -12
  801. package/esm/vchart-all.js.map +1 -1
  802. package/esm/vchart-simple.d.ts +1 -1
  803. package/esm/vchart-simple.js +4 -10
  804. package/esm/vchart-simple.js.map +1 -1
  805. package/layout.d.ts +1 -1
  806. package/layout.js +1 -1
  807. package/mark.d.ts +1 -1
  808. package/mark.js +1 -1
  809. package/package.json +35 -39
  810. package/series.d.ts +1 -1
  811. package/series.js +1 -1
  812. package/cjs/chart/range-column/rangeColumn.js.map +0 -1
  813. package/cjs/component/tooltip/handler/dom/utils/style.d.ts +0 -3
  814. package/cjs/component/tooltip/handler/dom/utils/style.js.map +0 -1
  815. package/cjs/component/tooltip/handler/interface/cache.d.ts +0 -28
  816. package/cjs/component/tooltip/handler/interface/cache.js +0 -6
  817. package/cjs/component/tooltip/handler/interface/cache.js.map +0 -1
  818. package/cjs/export/chart.d.ts +0 -57
  819. package/cjs/export/chart.js +0 -298
  820. package/cjs/export/chart.js.map +0 -1
  821. package/cjs/export/component.d.ts +0 -39
  822. package/cjs/export/component.js +0 -207
  823. package/cjs/export/component.js.map +0 -1
  824. package/cjs/export/core.js.map +0 -1
  825. package/cjs/export/layout.d.ts +0 -7
  826. package/cjs/export/layout.js +0 -33
  827. package/cjs/export/layout.js.map +0 -1
  828. package/cjs/export/mark.d.ts +0 -18
  829. package/cjs/export/mark.js.map +0 -1
  830. package/cjs/export/series.d.ts +0 -61
  831. package/cjs/export/series.js.map +0 -1
  832. package/cjs/mark/linkPath.js.map +0 -1
  833. package/cjs/mark/polygon.d.ts +0 -18
  834. package/cjs/mark/polygon.js +0 -32
  835. package/cjs/mark/polygon.js.map +0 -1
  836. package/cjs/theme/buildin-theme/dark.d.ts +0 -2
  837. package/cjs/theme/buildin-theme/dark.js +0 -16
  838. package/cjs/theme/buildin-theme/dark.js.map +0 -1
  839. package/esm/chart/range-column/rangeColumn.js.map +0 -1
  840. package/esm/component/tooltip/handler/dom/utils/style.d.ts +0 -3
  841. package/esm/component/tooltip/handler/dom/utils/style.js +0 -59
  842. package/esm/component/tooltip/handler/dom/utils/style.js.map +0 -1
  843. package/esm/component/tooltip/handler/interface/cache.d.ts +0 -28
  844. package/esm/component/tooltip/handler/interface/cache.js +0 -2
  845. package/esm/component/tooltip/handler/interface/cache.js.map +0 -1
  846. package/esm/export/chart.d.ts +0 -57
  847. package/esm/export/chart.js +0 -58
  848. package/esm/export/chart.js.map +0 -1
  849. package/esm/export/component.d.ts +0 -39
  850. package/esm/export/component.js +0 -40
  851. package/esm/export/component.js.map +0 -1
  852. package/esm/export/core.js.map +0 -1
  853. package/esm/export/layout.d.ts +0 -7
  854. package/esm/export/layout.js +0 -8
  855. package/esm/export/layout.js.map +0 -1
  856. package/esm/export/mark.d.ts +0 -18
  857. package/esm/export/mark.js +0 -34
  858. package/esm/export/mark.js.map +0 -1
  859. package/esm/export/series.d.ts +0 -61
  860. package/esm/export/series.js +0 -60
  861. package/esm/export/series.js.map +0 -1
  862. package/esm/mark/linkPath.js.map +0 -1
  863. package/esm/mark/polygon.d.ts +0 -18
  864. package/esm/mark/polygon.js +0 -28
  865. package/esm/mark/polygon.js.map +0 -1
  866. package/esm/theme/buildin-theme/dark.d.ts +0 -2
  867. package/esm/theme/buildin-theme/dark.js +0 -12
  868. package/esm/theme/buildin-theme/dark.js.map +0 -1
  869. /package/cjs/mark/{linkPath.d.ts → link-path.d.ts} +0 -0
  870. /package/esm/mark/{linkPath.d.ts → link-path.d.ts} +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/dom-tooltip-handler.ts"],"names":[],"mappings":"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","file":"dom-tooltip-handler.js","sourcesContent":["import type { IToolTipActual } from '../../../../typings/tooltip';\nimport type { ITooltipSpec, TooltipHandlerParams } from '../../interface';\nimport { BaseTooltipHandler } from '../base';\nimport { getDomStyles } from './utils/style';\nimport type { IDomTooltipStyle } from './interface';\nimport { TooltipModel } from './model/tooltip-model';\nimport { domDocument } from './model/base-tooltip-model';\nimport { TOOLTIP_CONTAINER_EL_CLASS_NAME, TooltipHandlerType } from '../constants';\nimport type { Tooltip } from '../../tooltip';\n\n/**\n * The tooltip handler class.\n */\nexport class DomTooltipHandler extends BaseTooltipHandler {\n type = TooltipHandlerType.dom;\n\n protected _tooltipContainer: HTMLElement = globalThis.document?.body;\n protected _domStyle: IDomTooltipStyle;\n protected declare _container: HTMLDivElement;\n\n protected model: TooltipModel;\n\n getVisibility() {\n return !!this.model?.getVisibility();\n }\n\n setVisibility(_value: boolean) {\n // 这里做个节流\n if (_value !== this.getVisibility()) {\n this.model?.setVisibility(_value);\n }\n }\n\n constructor(tooltipSpec: ITooltipSpec, tooltipId: string, component: Tooltip) {\n super(tooltipSpec, tooltipId, component);\n\n this._domStyle = getDomStyles(this._style);\n this.initEl();\n }\n\n initEl() {\n if (domDocument) {\n const { parentElement } = this._tooltipSpec;\n for (let i = 0; i < parentElement.children.length; i++) {\n if (parentElement.children[i].classList.contains(TOOLTIP_CONTAINER_EL_CLASS_NAME)) {\n this._container = parentElement.children[i] as HTMLDivElement;\n break;\n }\n }\n if (!this._container) {\n this._container = domDocument.createElement('div');\n this._container.style.position = 'relative';\n this._container.classList.add(TOOLTIP_CONTAINER_EL_CLASS_NAME);\n parentElement.appendChild(this._container);\n }\n this.model = new TooltipModel(\n this._container,\n { valueToHtml: this._option.sanitize },\n [this._tooltipSpec.className],\n this.id,\n this._domStyle\n );\n }\n }\n\n protected _removeTooltip() {\n this.model?.release();\n this._container = null;\n }\n\n protected _updateTooltip(visible: boolean, params: TooltipHandlerParams, actualTooltip: IToolTipActual) {\n if (!visible || !this.model) {\n this.setVisibility(visible);\n } else {\n if (!params.changePositionOnly) {\n this.model.setTooltipActual(actualTooltip);\n this.model.setStyle();\n this.model.setContent();\n }\n this.setVisibility(visible);\n\n // 位置\n const { x = 0, y = 0 } = actualTooltip.position ?? {};\n const el = this.model.product;\n // https://stackoverflow.com/questions/22111256/translate3d-vs-translate-performance\n el.style.transform = `translate3d(${x}px, ${y}px, 0)`;\n }\n }\n\n protected _getParentElement(spec: ITooltipSpec): HTMLElement {\n return this._container ?? super._getParentElement(spec);\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/dom/dom-tooltip-handler.ts"],"names":[],"mappings":"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","file":"dom-tooltip-handler.js","sourcesContent":["import type { IToolTipActual } from '../../../../typings/tooltip';\nimport type { ITooltipSpec, TooltipHandlerParams } from '../../interface';\nimport { BaseTooltipHandler } from '../base';\nimport { getDomStyles } from './util';\nimport type { IDomTooltipStyle } from './interface';\nimport { TooltipModel } from './model/tooltip-model';\nimport { domDocument } from './model/base-tooltip-model';\nimport { TOOLTIP_CONTAINER_EL_CLASS_NAME, TooltipHandlerType } from '../constants';\nimport type { Tooltip } from '../../tooltip';\nimport type { Maybe } from '@visactor/vutils';\n\n/**\n * The tooltip handler class.\n */\nexport class DomTooltipHandler extends BaseTooltipHandler {\n type = TooltipHandlerType.dom;\n\n protected _tooltipContainer: HTMLElement = globalThis.document?.body;\n protected _domStyle: IDomTooltipStyle;\n protected _tooltipActual: IToolTipActual;\n protected declare _container: Maybe<HTMLDivElement>;\n\n protected model: TooltipModel;\n\n getVisibility() {\n return !!this.model?.getVisibility();\n }\n\n setVisibility(_value: boolean) {\n // 这里做个节流\n if (_value !== this.getVisibility()) {\n this.model?.setVisibility(_value);\n }\n }\n\n constructor(tooltipId: string, component: Tooltip) {\n super(tooltipId, component);\n this._initStyle();\n this.initEl();\n }\n\n initEl() {\n const tooltipSpec = this._component.getSpec();\n const { parentElement } = tooltipSpec;\n if (domDocument && parentElement) {\n for (let i = 0; i < parentElement.children.length; i++) {\n if (parentElement.children[i].classList.contains(TOOLTIP_CONTAINER_EL_CLASS_NAME)) {\n this._container = parentElement.children[i] as HTMLDivElement;\n break;\n }\n }\n if (!this._container) {\n this._container = domDocument.createElement('div');\n this._container.style.position = 'relative';\n this._container.classList.add(TOOLTIP_CONTAINER_EL_CLASS_NAME);\n parentElement.appendChild(this._container);\n }\n this.model = new TooltipModel(\n this._container,\n {\n valueToHtml: this._option.sanitize,\n getTooltipStyle: () => this._domStyle,\n getTooltipActual: () => this._tooltipActual\n },\n [tooltipSpec.className],\n this.id\n );\n }\n }\n\n protected _removeTooltip() {\n this.model?.release();\n this._container = null;\n }\n\n protected _updateTooltip(visible: boolean, params: TooltipHandlerParams, actualTooltip: IToolTipActual) {\n if (!visible || !this.model) {\n this.setVisibility(visible);\n } else {\n if (!params.changePositionOnly) {\n this._tooltipActual = actualTooltip;\n this._initStyle();\n\n this.model.initAll();\n this.model.setStyle();\n this.model.setContent();\n }\n this.setVisibility(visible);\n\n // 位置\n const { x = 0, y = 0 } = actualTooltip.position ?? {};\n const el = this.model.product;\n if (el) {\n // https://stackoverflow.com/questions/22111256/translate3d-vs-translate-performance\n el.style.transform = `translate3d(${x}px, ${y}px, 0)`;\n }\n }\n }\n\n protected _initStyle() {\n this._domStyle = getDomStyles(this._style, this._attributeCache);\n }\n\n protected _getParentElement(spec: ITooltipSpec): HTMLElement {\n return this._container ?? super._getParentElement(spec);\n }\n\n reInit() {\n super.reInit();\n this._initStyle();\n }\n}\n"]}
@@ -1,6 +1,8 @@
1
1
  import type { FontWeight, TextAlign } from '../../../../typings/visual';
2
2
  export interface IDomTooltipStyle {
3
3
  panel: IPadding & IBorder & {
4
+ width?: string;
5
+ height?: string;
4
6
  backgroundColor?: string;
5
7
  boxShadow?: string;
6
8
  maxWidth?: string;
@@ -10,12 +12,21 @@ export interface IDomTooltipStyle {
10
12
  transitionProperty?: string;
11
13
  transitionTimingFunction?: string;
12
14
  };
13
- title?: ILabelStyle;
14
- content: IMargin & {
15
- key?: ILabelStyle;
16
- value?: ILabelStyle;
17
- shape?: IShapeStyle;
15
+ title: ILabelStyle;
16
+ content: IMargin;
17
+ shapeColumn: IMargin & {
18
+ width?: string;
19
+ item?: IShapeStyle;
18
20
  };
21
+ keyColumn: IMargin & {
22
+ width?: string;
23
+ item?: ILabelStyle;
24
+ };
25
+ valueColumn: IMargin & {
26
+ width?: string;
27
+ item?: ILabelStyle;
28
+ };
29
+ spaceRow: string;
19
30
  }
20
31
  export interface ILabelStyle extends IMargin {
21
32
  fontFamily?: string;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["import type { FontWeight, TextAlign } from '../../../../typings/visual';\n\nexport interface IDomTooltipStyle {\n panel: IPadding &\n IBorder & {\n backgroundColor?: string;\n boxShadow?: string;\n maxWidth?: string;\n minWidth?: string;\n pointerEvents?: 'auto' | 'none';\n transitionDuration?: string;\n transitionProperty?: string;\n transitionTimingFunction?: string;\n };\n title?: ILabelStyle;\n content: IMargin & {\n key?: ILabelStyle;\n value?: ILabelStyle;\n shape?: IShapeStyle;\n };\n}\n\nexport interface ILabelStyle extends IMargin {\n fontFamily?: string;\n fontSize?: string;\n color?: string;\n textAlign?: TextAlign;\n lineHeight?: string;\n fontWeight?: FontWeight;\n}\n\nexport interface IShapeStyle extends IMargin {\n width?: string;\n height?: string;\n}\n\nexport interface IMargin {\n marginLeft?: string;\n marginRight?: string;\n marginTop?: string;\n marginBottom?: string;\n}\n\nexport interface IPadding {\n paddingTop?: string;\n paddingRight?: string;\n paddingBottom?: string;\n paddingLeft?: string;\n}\n\nexport interface IBorder {\n borderColor?: string;\n borderWidth?: string;\n borderRadius?: string;\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/dom/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["import type { FontWeight, TextAlign } from '../../../../typings/visual';\n\nexport interface IDomTooltipStyle {\n panel: IPadding &\n IBorder & {\n width?: string;\n height?: string;\n backgroundColor?: string;\n boxShadow?: string;\n maxWidth?: string;\n minWidth?: string;\n pointerEvents?: 'auto' | 'none';\n transitionDuration?: string;\n transitionProperty?: string;\n transitionTimingFunction?: string;\n };\n title: ILabelStyle;\n content: IMargin;\n shapeColumn: IMargin & {\n width?: string;\n item?: IShapeStyle;\n };\n keyColumn: IMargin & {\n width?: string;\n item?: ILabelStyle;\n };\n valueColumn: IMargin & {\n width?: string;\n item?: ILabelStyle;\n };\n spaceRow: string;\n}\n\nexport interface ILabelStyle extends IMargin {\n fontFamily?: string;\n fontSize?: string;\n color?: string;\n textAlign?: TextAlign;\n lineHeight?: string;\n fontWeight?: FontWeight;\n}\n\nexport interface IShapeStyle extends IMargin {\n width?: string;\n height?: string;\n}\n\nexport interface IMargin {\n marginLeft?: string;\n marginRight?: string;\n marginTop?: string;\n marginBottom?: string;\n}\n\nexport interface IPadding {\n paddingTop?: string;\n paddingRight?: string;\n paddingBottom?: string;\n paddingLeft?: string;\n}\n\nexport interface IBorder {\n borderColor?: string;\n borderWidth?: string;\n borderRadius?: string;\n}\n"]}
@@ -1,8 +1,6 @@
1
- import type { IToolTipActual, IToolTipLineActual } from '../../../../../typings';
2
- import type { IDomTooltipStyle } from '../interface';
1
+ import type { Maybe } from '@visactor/vutils';
2
+ import type { IToolTipLineActual } from '../../../../../typings';
3
3
  import type { ITooltipModelOption } from './interface';
4
- export declare const TOOLTIP_MAX_COUNT = 20;
5
- export declare const TOOLTIP_EMPTY_STRING = "";
6
4
  export declare const domDocument: Document | undefined;
7
5
  export declare class BaseTooltipModel {
8
6
  static type: string;
@@ -10,23 +8,19 @@ export declare class BaseTooltipModel {
10
8
  readonly type: string;
11
9
  readonly parent: BaseTooltipModel | HTMLElement;
12
10
  readonly childIndex: number;
13
- protected _tooltipActual: IToolTipActual | null;
14
- setTooltipActual(tooltipActual: IToolTipActual): void;
15
- protected _tooltipStyle: IDomTooltipStyle | null;
16
- setTooltipStyle(tooltipStyle: IDomTooltipStyle): void;
17
11
  protected _option: ITooltipModelOption;
18
12
  setOption(option: ITooltipModelOption): void;
19
- protected _renderContentCache: IToolTipLineActual[];
13
+ protected _renderContentCache: IToolTipLineActual[] | null;
20
14
  children: Record<number, BaseTooltipModel>;
21
- product: HTMLElement;
15
+ product: Maybe<HTMLElement>;
22
16
  getParentEl(): HTMLElement;
23
- constructor(parent: BaseTooltipModel | HTMLElement, option: ITooltipModelOption, childIndex?: number, tooltipStyle?: IDomTooltipStyle, tooltipActual?: IToolTipActual);
17
+ constructor(parent: BaseTooltipModel | HTMLElement, option: ITooltipModelOption, childIndex?: number);
24
18
  init(classList?: string[], id?: string): void;
19
+ initAll(): void;
25
20
  setStyle(style?: Partial<CSSStyleDeclaration>): void;
26
21
  setContent(content?: any): void;
27
22
  setVisibility(visibility: boolean): void;
28
23
  getVisibility(): boolean;
29
24
  release(): void;
30
- protected createElement(tag: keyof HTMLElementTagNameMap, classList?: string[], style?: Partial<CSSStyleDeclaration>, id?: string): HTMLImageElement | HTMLElement | HTMLCanvasElement | HTMLSlotElement | HTMLObjectElement | HTMLProgressElement | HTMLLinkElement | HTMLAreaElement | HTMLTitleElement | HTMLLabelElement | HTMLStyleElement | HTMLAnchorElement | HTMLDataElement | HTMLSelectElement | HTMLMapElement | HTMLOutputElement | HTMLSourceElement | HTMLHtmlElement | HTMLTrackElement | HTMLLegendElement | HTMLInputElement | HTMLAudioElement | HTMLBaseElement | HTMLQuoteElement | HTMLBodyElement | HTMLBRElement | HTMLButtonElement | HTMLTableCaptionElement | HTMLTableColElement | HTMLDataListElement | HTMLModElement | HTMLDetailsElement | HTMLDialogElement | HTMLDivElement | HTMLDListElement | HTMLEmbedElement | HTMLFieldSetElement | HTMLFormElement | HTMLHeadingElement | HTMLHeadElement | HTMLHRElement | HTMLIFrameElement | HTMLLIElement | HTMLMenuElement | HTMLMetaElement | HTMLMeterElement | HTMLOListElement | HTMLOptGroupElement | HTMLOptionElement | HTMLParagraphElement | HTMLPictureElement | HTMLPreElement | HTMLScriptElement | HTMLSpanElement | HTMLTableElement | HTMLTableSectionElement | HTMLTableCellElement | HTMLTemplateElement | HTMLTextAreaElement | HTMLTimeElement | HTMLTableRowElement | HTMLUListElement | HTMLVideoElement;
31
- protected getRenderContent(): IToolTipLineActual[];
25
+ protected createElement(tag: keyof HTMLElementTagNameMap, classList?: string[], style?: Partial<CSSStyleDeclaration>, id?: string): HTMLElement;
32
26
  }
@@ -2,35 +2,28 @@
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: !0
5
- }), exports.BaseTooltipModel = exports.domDocument = exports.TOOLTIP_EMPTY_STRING = exports.TOOLTIP_MAX_COUNT = void 0,
6
- exports.TOOLTIP_MAX_COUNT = 20, exports.TOOLTIP_EMPTY_STRING = "", exports.domDocument = globalThis.document;
5
+ }), exports.BaseTooltipModel = exports.domDocument = void 0, exports.domDocument = globalThis.document;
7
6
 
8
7
  class BaseTooltipModel {
9
8
  static isInstance(obj) {
10
9
  return !!obj && obj.type === BaseTooltipModel.type;
11
10
  }
12
- setTooltipActual(tooltipActual) {
13
- this._tooltipActual = tooltipActual, this._renderContentCache = null, this.init(),
14
- Object.values(this.children).forEach((c => c.setTooltipActual(tooltipActual)));
15
- }
16
- setTooltipStyle(tooltipStyle) {
17
- this._tooltipStyle = tooltipStyle, this.init(), Object.values(this.children).forEach((c => c.setTooltipStyle(tooltipStyle)));
18
- }
19
11
  setOption(option) {
20
12
  this._option = option, Object.values(this.children).forEach((c => c.setOption(option)));
21
13
  }
22
14
  getParentEl() {
23
15
  return BaseTooltipModel.isInstance(this.parent) ? this.parent.product : this.parent;
24
16
  }
25
- constructor(parent, option, childIndex, tooltipStyle, tooltipActual) {
26
- this.type = BaseTooltipModel.type, this._tooltipActual = null, this._tooltipStyle = null,
27
- this._renderContentCache = null, this.children = {}, this.parent = parent, this._option = option,
28
- this.childIndex = null != childIndex ? childIndex : 0, this._tooltipStyle = tooltipStyle,
29
- this._tooltipActual = tooltipActual;
17
+ constructor(parent, option, childIndex) {
18
+ this.type = BaseTooltipModel.type, this._renderContentCache = null, this.children = {},
19
+ this.parent = parent, this._option = option, this.childIndex = null != childIndex ? childIndex : 0;
30
20
  }
31
21
  init(classList, id) {}
22
+ initAll() {
23
+ this.init(), Object.values(this.children).forEach((c => c.initAll()));
24
+ }
32
25
  setStyle(style) {
33
- style && Object.keys(style).forEach((key => {
26
+ this.product && style && Object.keys(style).forEach((key => {
34
27
  this.product.style[key] !== style[key] && (this.product.style[key] = style[key]);
35
28
  }));
36
29
  }
@@ -45,15 +38,16 @@ class BaseTooltipModel {
45
38
  return !!(null === (_b = null === (_a = this.product) || void 0 === _a ? void 0 : _a.style) || void 0 === _b ? void 0 : _b.visibility) && "hidden" !== this.product.style.visibility;
46
39
  }
47
40
  release() {
48
- Object.values(this.children).forEach((c => c.release())), this.children = {}, this.product && (this.getParentEl().removeChild(this.product),
41
+ var _a;
42
+ Object.values(this.children).forEach((c => c.release())), this.children = {}, this.product && (null === (_a = this.getParentEl()) || void 0 === _a || _a.removeChild(this.product),
49
43
  this.product = null);
50
44
  }
51
45
  createElement(tag, classList, style, id) {
52
- const element = exports.domDocument.createElement(tag);
46
+ const element = null === exports.domDocument || void 0 === exports.domDocument ? void 0 : exports.domDocument.createElement(tag), parentEl = this.getParentEl();
47
+ if (!element || !parentEl) return;
53
48
  classList && element.classList.add(...classList), style && Object.keys(style).forEach((key => {
54
49
  element.style[key] = style[key];
55
50
  })), id && (element.id = id);
56
- const parentEl = this.getParentEl();
57
51
  let ptr = this.childIndex;
58
52
  if (BaseTooltipModel.isInstance(this.parent)) {
59
53
  let nextChildIndex = Number.MAX_VALUE;
@@ -66,15 +60,6 @@ class BaseTooltipModel {
66
60
  return ptr >= parentEl.children.length ? parentEl.appendChild(element) : parentEl.insertBefore(element, parentEl.children[ptr]),
67
61
  element;
68
62
  }
69
- getRenderContent() {
70
- if (!this._tooltipActual) return [];
71
- if (this._renderContentCache) return this._renderContentCache;
72
- const {content: originContent = []} = this._tooltipActual, renderContent = originContent.slice(0, exports.TOOLTIP_MAX_COUNT);
73
- return (null == renderContent ? void 0 : renderContent[exports.TOOLTIP_MAX_COUNT - 1]) && (renderContent[exports.TOOLTIP_MAX_COUNT - 1] = Object.assign(Object.assign({}, renderContent[exports.TOOLTIP_MAX_COUNT - 1]), {
74
- key: "其他",
75
- value: "..."
76
- })), renderContent;
77
- }
78
63
  }
79
64
 
80
65
  exports.BaseTooltipModel = BaseTooltipModel, BaseTooltipModel.type = "tooltipModel";
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/model/base-tooltip-model.ts"],"names":[],"mappings":"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","file":"base-tooltip-model.js","sourcesContent":["import type { IToolTipActual, IToolTipLineActual } from '../../../../../typings';\nimport type { IDomTooltipStyle } from '../interface';\nimport type { ITooltipModelOption } from './interface';\n\nexport const TOOLTIP_MAX_COUNT = 20;\nexport const TOOLTIP_EMPTY_STRING = '';\n\nexport const domDocument: Document | undefined = globalThis.document;\n\nexport class BaseTooltipModel {\n static type = 'tooltipModel';\n static isInstance(obj: any): obj is BaseTooltipModel {\n if (!obj) {\n return false;\n }\n return obj.type === BaseTooltipModel.type;\n }\n readonly type = BaseTooltipModel.type;\n\n readonly parent: BaseTooltipModel | HTMLElement;\n readonly childIndex: number;\n\n protected _tooltipActual: IToolTipActual | null = null;\n setTooltipActual(tooltipActual: IToolTipActual) {\n this._tooltipActual = tooltipActual;\n this._renderContentCache = null; // 清除缓存\n this.init();\n Object.values(this.children).forEach(c => c.setTooltipActual(tooltipActual));\n }\n\n protected _tooltipStyle: IDomTooltipStyle | null = null;\n setTooltipStyle(tooltipStyle: IDomTooltipStyle) {\n this._tooltipStyle = tooltipStyle;\n this.init();\n Object.values(this.children).forEach(c => c.setTooltipStyle(tooltipStyle));\n }\n\n protected _option: ITooltipModelOption;\n setOption(option: ITooltipModelOption) {\n this._option = option;\n Object.values(this.children).forEach(c => c.setOption(option));\n }\n\n protected _renderContentCache: IToolTipLineActual[] = null;\n\n children: Record<number, BaseTooltipModel> = {};\n\n product: HTMLElement;\n\n getParentEl() {\n if (BaseTooltipModel.isInstance(this.parent)) {\n return this.parent.product;\n }\n return this.parent;\n }\n\n constructor(\n parent: BaseTooltipModel | HTMLElement,\n option: ITooltipModelOption,\n childIndex?: number,\n tooltipStyle?: IDomTooltipStyle,\n tooltipActual?: IToolTipActual\n ) {\n this.parent = parent;\n this._option = option;\n this.childIndex = childIndex ?? 0;\n this._tooltipStyle = tooltipStyle;\n this._tooltipActual = tooltipActual;\n }\n\n init(classList?: string[], id?: string) {\n // do nothing\n }\n\n setStyle(style?: Partial<CSSStyleDeclaration>) {\n if (style) {\n Object.keys(style).forEach(key => {\n if (this.product.style[key] !== style[key]) {\n this.product.style[key] = style[key];\n }\n });\n }\n }\n\n setContent(content?: any) {\n // do nothing\n }\n\n setVisibility(visibility: boolean) {\n if (!this.product) {\n return;\n }\n const { style } = this.product;\n if (visibility) {\n style.visibility = 'visible';\n } else {\n style.visibility = 'hidden';\n }\n Object.values(this.children).forEach(c => c.setVisibility(visibility));\n }\n\n getVisibility() {\n if (!this.product?.style?.visibility) {\n return false;\n }\n return this.product.style.visibility !== 'hidden';\n }\n\n release() {\n Object.values(this.children).forEach(c => c.release());\n this.children = {};\n if (this.product) {\n this.getParentEl().removeChild(this.product);\n this.product = null;\n }\n }\n\n protected createElement(\n tag: keyof HTMLElementTagNameMap,\n classList?: string[],\n style?: Partial<CSSStyleDeclaration>,\n id?: string\n ) {\n const element = domDocument.createElement(tag);\n if (classList) {\n element.classList.add(...classList);\n }\n if (style) {\n Object.keys(style).forEach(key => {\n element.style[key] = style[key];\n });\n }\n if (id) {\n element.id = id;\n }\n\n const parentEl = this.getParentEl();\n let ptr = this.childIndex;\n if (BaseTooltipModel.isInstance(this.parent)) {\n // 按照自身 childIndex 插入对应位置\n let nextChildIndex = Number.MAX_VALUE;\n for (let i = 0; i < parentEl.children.length; i++) {\n const childModel = Object.values(this.parent.children).find(c => c.product === parentEl.children[i]);\n if (childModel.childIndex > this.childIndex && childModel.childIndex < nextChildIndex) {\n nextChildIndex = childModel.childIndex;\n ptr = i;\n }\n }\n }\n if (ptr >= parentEl.children.length) {\n parentEl.appendChild(element);\n } else {\n parentEl.insertBefore(element, parentEl.children[ptr]);\n }\n return element;\n }\n\n protected getRenderContent() {\n if (!this._tooltipActual) {\n return [];\n }\n if (this._renderContentCache) {\n return this._renderContentCache;\n }\n\n const { content: originContent = [] } = this._tooltipActual;\n const renderContent = originContent.slice(0, TOOLTIP_MAX_COUNT);\n\n // 最后一行被转化为省略\n if (renderContent?.[TOOLTIP_MAX_COUNT - 1]) {\n renderContent[TOOLTIP_MAX_COUNT - 1] = {\n ...renderContent[TOOLTIP_MAX_COUNT - 1],\n key: '其他',\n value: '...'\n };\n }\n\n return renderContent;\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/dom/model/base-tooltip-model.ts"],"names":[],"mappings":"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","file":"base-tooltip-model.js","sourcesContent":["import type { Maybe } from '@visactor/vutils';\nimport type { IToolTipLineActual } from '../../../../../typings';\nimport type { ITooltipModelOption } from './interface';\n\nexport const domDocument: Document | undefined = globalThis.document;\n\nexport class BaseTooltipModel {\n static type = 'tooltipModel';\n static isInstance(obj: any): obj is BaseTooltipModel {\n if (!obj) {\n return false;\n }\n return obj.type === BaseTooltipModel.type;\n }\n readonly type = BaseTooltipModel.type;\n\n readonly parent: BaseTooltipModel | HTMLElement;\n readonly childIndex: number;\n\n protected _option: ITooltipModelOption;\n setOption(option: ITooltipModelOption) {\n this._option = option;\n Object.values(this.children).forEach(c => c.setOption(option));\n }\n\n protected _renderContentCache: IToolTipLineActual[] | null = null;\n\n children: Record<number, BaseTooltipModel> = {};\n\n product: Maybe<HTMLElement>;\n\n getParentEl() {\n if (BaseTooltipModel.isInstance(this.parent)) {\n return this.parent.product;\n }\n return this.parent;\n }\n\n constructor(parent: BaseTooltipModel | HTMLElement, option: ITooltipModelOption, childIndex?: number) {\n this.parent = parent;\n this._option = option;\n this.childIndex = childIndex ?? 0;\n }\n\n init(classList?: string[], id?: string) {\n // do nothing\n }\n\n initAll() {\n this.init();\n Object.values(this.children).forEach(c => c.initAll());\n }\n\n setStyle(style?: Partial<CSSStyleDeclaration>) {\n if (!this.product || !style) {\n return;\n }\n Object.keys(style).forEach(key => {\n if (this.product!.style[key] !== style[key]) {\n this.product!.style[key] = style[key];\n }\n });\n }\n\n setContent(content?: any) {\n // do nothing\n }\n\n setVisibility(visibility: boolean) {\n if (!this.product) {\n return;\n }\n const { style } = this.product;\n if (visibility) {\n style.visibility = 'visible';\n } else {\n style.visibility = 'hidden';\n }\n Object.values(this.children).forEach(c => c.setVisibility(visibility));\n }\n\n getVisibility() {\n if (!this.product?.style?.visibility) {\n return false;\n }\n return this.product.style.visibility !== 'hidden';\n }\n\n release() {\n Object.values(this.children).forEach(c => c.release());\n this.children = {};\n if (this.product) {\n this.getParentEl()?.removeChild(this.product);\n this.product = null;\n }\n }\n\n protected createElement(\n tag: keyof HTMLElementTagNameMap,\n classList?: string[],\n style?: Partial<CSSStyleDeclaration>,\n id?: string\n ) {\n const element = domDocument?.createElement(tag);\n const parentEl = this.getParentEl();\n if (!element || !parentEl) {\n return undefined;\n }\n\n if (classList) {\n element.classList.add(...classList);\n }\n if (style) {\n Object.keys(style).forEach(key => {\n element.style[key] = style[key];\n });\n }\n if (id) {\n element.id = id;\n }\n\n let ptr = this.childIndex;\n if (BaseTooltipModel.isInstance(this.parent)) {\n // 按照自身 childIndex 插入对应位置\n let nextChildIndex = Number.MAX_VALUE;\n for (let i = 0; i < parentEl.children.length; i++) {\n const childModel = Object.values(this.parent.children).find(c => c.product === parentEl.children[i])!;\n if (childModel.childIndex > this.childIndex && childModel.childIndex < nextChildIndex) {\n nextChildIndex = childModel.childIndex;\n ptr = i;\n }\n }\n }\n if (ptr >= parentEl.children.length) {\n parentEl.appendChild(element);\n } else {\n parentEl.insertBefore(element, parentEl.children[ptr]);\n }\n return element;\n }\n}\n"]}
@@ -1,12 +1,22 @@
1
1
  import { BaseTooltipModel } from './base-tooltip-model';
2
2
  import type { ITooltipModelOption } from './interface';
3
- import type { IDomTooltipStyle } from '../interface';
4
- import type { IToolTipActual } from '../../../../../typings';
5
3
  export type ContentColumnType = 'shape-box' | 'key-box' | 'value-box';
6
4
  export declare class ContentColumnModel extends BaseTooltipModel {
7
5
  readonly className: ContentColumnType;
8
- constructor(parent: BaseTooltipModel | HTMLElement, option: ITooltipModelOption, className: ContentColumnType, childIndex?: number, tooltipStyle?: IDomTooltipStyle, tooltipActual?: IToolTipActual);
6
+ constructor(parent: BaseTooltipModel | HTMLElement, option: ITooltipModelOption, className: ContentColumnType, childIndex?: number);
9
7
  init(): void;
10
8
  setStyle(): void;
11
9
  setContent(): void;
10
+ protected _getContentColumnStyle(): (import("../interface").IMargin & {
11
+ width?: string;
12
+ item?: import("../interface").ILabelStyle;
13
+ }) | {
14
+ display?: string;
15
+ marginLeft?: string;
16
+ marginRight?: string;
17
+ marginTop?: string;
18
+ marginBottom?: string;
19
+ width?: string;
20
+ item?: import("../interface").IShapeStyle;
21
+ };
12
22
  }
@@ -4,26 +4,27 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: !0
5
5
  }), exports.ContentColumnModel = void 0;
6
6
 
7
- const vutils_1 = require("@visactor/vutils"), style_constants_1 = require("./style-constants"), base_tooltip_model_1 = require("./base-tooltip-model"), shape_model_1 = require("./shape-model"), text_model_1 = require("./text-model");
7
+ const vutils_1 = require("@visactor/vutils"), style_constants_1 = require("./style-constants"), base_tooltip_model_1 = require("./base-tooltip-model"), shape_model_1 = require("./shape-model"), text_model_1 = require("./text-model"), constants_1 = require("../../constants");
8
8
 
9
9
  class ContentColumnModel extends base_tooltip_model_1.BaseTooltipModel {
10
- constructor(parent, option, className, childIndex, tooltipStyle, tooltipActual) {
11
- super(parent, option, childIndex, tooltipStyle, tooltipActual), this.className = className;
10
+ constructor(parent, option, className, childIndex) {
11
+ super(parent, option, childIndex), this.className = className;
12
12
  }
13
13
  init() {
14
+ var _a, _b;
14
15
  this.product || (this.product = this.createElement("div", [ this.className ]));
15
- const renderContent = this.getRenderContent();
16
+ const renderContent = null !== (_b = null === (_a = this._option.getTooltipActual()) || void 0 === _a ? void 0 : _a.content) && void 0 !== _b ? _b : [];
16
17
  if ("shape-box" !== this.className || renderContent.some((c => c.hasShape && c.shapeType))) {
17
18
  Object.keys(this.children).forEach((key => {
18
19
  const i = (0, vutils_1.toNumber)(key);
19
20
  i >= renderContent.length && (this.children[i].release(), delete this.children[i]);
20
21
  }));
21
22
  for (let i = 0; i < renderContent.length; i++) if (!this.children[i]) if ("key-box" === this.className || "value-box" === this.className) {
22
- const text = new text_model_1.TextModel(this.product, this._option, i, this._tooltipStyle, this._tooltipActual);
23
+ const text = new text_model_1.TextModel(this.product, this._option, i);
23
24
  text.init([ this.className.substring(0, this.className.indexOf("-")) ], void 0, "div"),
24
25
  this.children[i] = text;
25
26
  } else if ("shape-box" === this.className) {
26
- const shape = new shape_model_1.ShapeModel(this.product, this._option, i, this._tooltipStyle, this._tooltipActual);
27
+ const shape = new shape_model_1.ShapeModel(this.product, this._option, i);
27
28
  shape.init([ "shape" ], void 0, "div"), this.children[i] = shape;
28
29
  }
29
30
  } else Object.keys(this.children).forEach((key => {
@@ -32,58 +33,77 @@ class ContentColumnModel extends base_tooltip_model_1.BaseTooltipModel {
32
33
  }));
33
34
  }
34
35
  setStyle() {
35
- if (!this._tooltipStyle) return;
36
- super.setStyle((0, vutils_1.merge)({}, style_constants_1.defaultShapeBoxStyle, this._tooltipStyle.content));
37
- const renderContent = this.getRenderContent();
36
+ var _a, _b;
37
+ const tooltipStyle = this._option.getTooltipStyle();
38
+ super.setStyle((0, vutils_1.merge)({}, style_constants_1.defaultContentColumnStyle, tooltipStyle.content, this._getContentColumnStyle()));
39
+ const renderContent = null !== (_b = null === (_a = this._option.getTooltipActual()) || void 0 === _a ? void 0 : _a.content) && void 0 !== _b ? _b : [];
38
40
  renderContent.forEach(((line, i) => {
39
- var _a, _b;
41
+ var _a, _b, _c;
40
42
  let childStyle = {};
41
43
  if ("key-box" === this.className) {
42
- const keyContent = line.key;
43
- childStyle = (0, vutils_1.merge)({}, style_constants_1.defaultKeyStyle, Object.assign({
44
+ const {key: key, isKeyAdaptive: isKeyAdaptive} = line;
45
+ childStyle = (0, vutils_1.merge)({}, isKeyAdaptive ? style_constants_1.defaultAdaptiveKeyStyle : style_constants_1.defaultKeyStyle, Object.assign({
44
46
  height: 100 / renderContent.length + "%"
45
- }, this._tooltipStyle.content.key));
46
- (0, vutils_1.isString)(keyContent) && "" !== (null === (_a = null == keyContent ? void 0 : keyContent.trim) || void 0 === _a ? void 0 : _a.call(keyContent)) || (0,
47
- vutils_1.isNumber)(keyContent) || childStyle.visibility ? childStyle.visibility = "visible" : childStyle.visibility = "hidden",
47
+ }, tooltipStyle.keyColumn.item));
48
+ (0, vutils_1.isString)(key) && "" !== (null === (_a = null == key ? void 0 : key.trim) || void 0 === _a ? void 0 : _a.call(key)) || (0,
49
+ vutils_1.isNumber)(key) || childStyle.visibility ? childStyle.visibility = "visible" : childStyle.visibility = "hidden",
48
50
  this.children[i].setStyle(childStyle);
49
51
  } else if ("value-box" === this.className) childStyle = (0, vutils_1.merge)({}, style_constants_1.defaultValueStyle, Object.assign({
50
52
  height: 100 / renderContent.length + "%"
51
- }, this._tooltipStyle.content.value)), this.children[i].setStyle(childStyle); else if ("shape-box" === this.className) {
52
- childStyle = this._tooltipStyle.content.shape;
53
+ }, tooltipStyle.valueColumn.item)), this.children[i].setStyle(childStyle); else if ("shape-box" === this.className) {
54
+ childStyle = tooltipStyle.shapeColumn.item;
53
55
  const childContent = {
54
56
  hasShape: line.hasShape,
55
57
  shapeType: line.shapeType,
56
- size: this._tooltipStyle.content.shape.width,
58
+ size: null === (_b = tooltipStyle.shapeColumn.item) || void 0 === _b ? void 0 : _b.width,
57
59
  color: line.shapeColor,
58
60
  hollow: line.shapeHollow
59
61
  };
60
- null === (_b = this.children[i]) || void 0 === _b || _b.setStyle(childStyle, childContent);
62
+ null === (_c = this.children[i]) || void 0 === _c || _c.setStyle(childStyle, childContent);
61
63
  }
62
64
  }));
63
65
  }
64
66
  setContent() {
65
- if (!this._tooltipStyle) return;
66
- this.getRenderContent().forEach(((line, i) => {
67
- var _a, _b, _c;
67
+ var _a, _b;
68
+ const tooltipStyle = this._option.getTooltipStyle();
69
+ (null !== (_b = null === (_a = this._option.getTooltipActual()) || void 0 === _a ? void 0 : _a.content) && void 0 !== _b ? _b : []).forEach(((line, i) => {
70
+ var _a, _b, _c, _d;
68
71
  let childContent;
69
72
  if ("key-box" === this.className) {
70
73
  const keyContent = line.key;
71
74
  childContent = (0, vutils_1.isString)(keyContent) && "" !== (null === (_a = null == keyContent ? void 0 : keyContent.trim) || void 0 === _a ? void 0 : _a.call(keyContent)) || (0,
72
- vutils_1.isNumber)(keyContent) ? keyContent : base_tooltip_model_1.TOOLTIP_EMPTY_STRING;
75
+ vutils_1.isNumber)(keyContent) ? keyContent : constants_1.TOOLTIP_EMPTY_STRING;
73
76
  } else if ("value-box" === this.className) {
74
77
  const valueContent = line.value;
75
78
  childContent = (0, vutils_1.isString)(valueContent) && "" !== (null === (_b = null == valueContent ? void 0 : valueContent.trim) || void 0 === _b ? void 0 : _b.call(valueContent)) || (0,
76
- vutils_1.isNumber)(valueContent) ? valueContent : base_tooltip_model_1.TOOLTIP_EMPTY_STRING;
79
+ vutils_1.isNumber)(valueContent) ? valueContent : constants_1.TOOLTIP_EMPTY_STRING;
77
80
  } else "shape-box" === this.className && (childContent = {
78
81
  hasShape: line.hasShape,
79
82
  shapeType: line.shapeType,
80
- size: this._tooltipStyle.content.shape.width,
83
+ size: null === (_c = tooltipStyle.shapeColumn.item) || void 0 === _c ? void 0 : _c.width,
81
84
  color: line.shapeColor,
82
85
  hollow: line.shapeHollow
83
86
  });
84
- null === (_c = this.children[i]) || void 0 === _c || _c.setContent(childContent);
87
+ null === (_d = this.children[i]) || void 0 === _d || _d.setContent(childContent);
85
88
  }));
86
89
  }
90
+ _getContentColumnStyle() {
91
+ var _a, _b;
92
+ const tooltipStyle = this._option.getTooltipStyle();
93
+ switch (this.className) {
94
+ case "shape-box":
95
+ const renderContent = null !== (_b = null === (_a = this._option.getTooltipActual()) || void 0 === _a ? void 0 : _a.content) && void 0 !== _b ? _b : [];
96
+ return Object.assign(Object.assign({}, tooltipStyle.shapeColumn), "shape-box" !== this.className || renderContent.some((c => c.hasShape && c.shapeType)) ? {} : {
97
+ display: "none"
98
+ });
99
+
100
+ case "key-box":
101
+ return tooltipStyle.keyColumn;
102
+
103
+ case "value-box":
104
+ return tooltipStyle.valueColumn;
105
+ }
106
+ }
87
107
  }
88
108
 
89
109
  exports.ContentColumnModel = ContentColumnModel;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/model/content-column-model.ts"],"names":[],"mappings":"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","file":"content-column-model.js","sourcesContent":["import { isNumber, isString, merge, toNumber } from '@visactor/vutils';\nimport { defaultKeyStyle, defaultShapeBoxStyle, defaultValueStyle } from './style-constants';\nimport { BaseTooltipModel, TOOLTIP_EMPTY_STRING } from './base-tooltip-model';\nimport type { ITooltipModelOption } from './interface';\nimport type { IShapeSvgOption } from './shape-model';\n// eslint-disable-next-line no-duplicate-imports\nimport { ShapeModel } from './shape-model';\nimport { TextModel } from './text-model';\nimport type { IDomTooltipStyle } from '../interface';\nimport type { IToolTipActual } from '../../../../../typings';\n\nexport type ContentColumnType = 'shape-box' | 'key-box' | 'value-box';\n\nexport class ContentColumnModel extends BaseTooltipModel {\n readonly className: ContentColumnType;\n\n constructor(\n parent: BaseTooltipModel | HTMLElement,\n option: ITooltipModelOption,\n className: ContentColumnType,\n childIndex?: number,\n tooltipStyle?: IDomTooltipStyle,\n tooltipActual?: IToolTipActual\n ) {\n super(parent, option, childIndex, tooltipStyle, tooltipActual);\n this.className = className;\n }\n\n init(): void {\n if (!this.product) {\n this.product = this.createElement('div', [this.className]);\n }\n const renderContent = this.getRenderContent();\n\n if (this.className === 'shape-box' && !renderContent.some(c => c.hasShape && c.shapeType)) {\n // 当有一行配有形状的时候,其他行要对齐。如果没有一行配有形状,则删除所有的行\n Object.keys(this.children).forEach(key => {\n const i = toNumber(key);\n this.children[i].release();\n delete this.children[i];\n });\n } else {\n // 删除多余的行\n Object.keys(this.children).forEach(key => {\n const i = toNumber(key);\n if (i >= renderContent.length) {\n this.children[i].release();\n delete this.children[i];\n }\n });\n // 新增没有的行\n for (let i = 0; i < renderContent.length; i++) {\n if (!this.children[i]) {\n if (this.className === 'key-box' || this.className === 'value-box') {\n const text = new TextModel(this.product, this._option, i, this._tooltipStyle, this._tooltipActual);\n text.init([this.className.substring(0, this.className.indexOf('-'))], undefined, 'div');\n this.children[i] = text;\n } else if (this.className === 'shape-box') {\n const shape = new ShapeModel(this.product, this._option, i, this._tooltipStyle, this._tooltipActual);\n shape.init(['shape'], undefined, 'div');\n this.children[i] = shape;\n }\n }\n }\n }\n }\n\n setStyle() {\n if (!this._tooltipStyle) {\n return;\n }\n\n super.setStyle(merge({}, defaultShapeBoxStyle, this._tooltipStyle.content));\n\n const renderContent = this.getRenderContent();\n renderContent.forEach((line, i) => {\n let childStyle: any = {};\n if (this.className === 'key-box') {\n const keyContent = line.key;\n childStyle = merge({}, defaultKeyStyle, {\n height: `${100 / renderContent.length}%`,\n ...this._tooltipStyle.content.key\n });\n const hasContent = (isString(keyContent) && keyContent?.trim?.() !== '') || isNumber(keyContent);\n if (!hasContent && !childStyle.visibility) {\n childStyle.visibility = 'hidden';\n } else {\n childStyle.visibility = 'visible';\n }\n (this.children[i] as TextModel).setStyle(childStyle);\n } else if (this.className === 'value-box') {\n childStyle = merge({}, defaultValueStyle, {\n height: `${100 / renderContent.length}%`,\n ...this._tooltipStyle.content.value\n });\n (this.children[i] as TextModel).setStyle(childStyle);\n } else if (this.className === 'shape-box') {\n childStyle = this._tooltipStyle.content.shape;\n const childContent = {\n hasShape: line.hasShape,\n shapeType: line.shapeType,\n size: this._tooltipStyle.content.shape.width,\n color: line.shapeColor,\n hollow: line.shapeHollow\n } as IShapeSvgOption;\n (this.children[i] as ShapeModel)?.setStyle(childStyle, childContent);\n }\n });\n }\n\n setContent(): void {\n if (!this._tooltipStyle) {\n return;\n }\n\n const renderContent = this.getRenderContent();\n renderContent.forEach((line, i) => {\n let childContent: any;\n if (this.className === 'key-box') {\n const keyContent = line.key;\n if ((isString(keyContent) && keyContent?.trim?.() !== '') || isNumber(keyContent)) {\n childContent = keyContent;\n } else {\n childContent = TOOLTIP_EMPTY_STRING;\n }\n } else if (this.className === 'value-box') {\n const valueContent = line.value;\n if ((isString(valueContent) && valueContent?.trim?.() !== '') || isNumber(valueContent)) {\n childContent = valueContent;\n } else {\n childContent = TOOLTIP_EMPTY_STRING;\n }\n } else if (this.className === 'shape-box') {\n childContent = {\n hasShape: line.hasShape,\n shapeType: line.shapeType,\n size: this._tooltipStyle.content.shape.width,\n color: line.shapeColor,\n hollow: line.shapeHollow\n } as IShapeSvgOption;\n }\n this.children[i]?.setContent(childContent);\n });\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/dom/model/content-column-model.ts"],"names":[],"mappings":"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","file":"content-column-model.js","sourcesContent":["import { isNumber, isString, merge, toNumber } from '@visactor/vutils';\nimport {\n defaultKeyStyle,\n defaultContentColumnStyle,\n defaultValueStyle,\n defaultAdaptiveKeyStyle\n} from './style-constants';\nimport { BaseTooltipModel } from './base-tooltip-model';\nimport type { ITooltipModelOption } from './interface';\nimport type { IShapeSvgOption } from './shape-model';\n// eslint-disable-next-line no-duplicate-imports\nimport { ShapeModel } from './shape-model';\nimport { TextModel } from './text-model';\nimport { TOOLTIP_EMPTY_STRING } from '../../constants';\n\nexport type ContentColumnType = 'shape-box' | 'key-box' | 'value-box';\n\nexport class ContentColumnModel extends BaseTooltipModel {\n readonly className: ContentColumnType;\n\n constructor(\n parent: BaseTooltipModel | HTMLElement,\n option: ITooltipModelOption,\n className: ContentColumnType,\n childIndex?: number\n ) {\n super(parent, option, childIndex);\n this.className = className;\n }\n\n init(): void {\n if (!this.product) {\n this.product = this.createElement('div', [this.className]);\n }\n const renderContent = this._option.getTooltipActual()?.content ?? [];\n\n if (this.className === 'shape-box' && !renderContent.some(c => c.hasShape && c.shapeType)) {\n // 当有一行配有形状的时候,其他行要对齐。如果没有一行配有形状,则删除所有的行\n Object.keys(this.children).forEach(key => {\n const i = toNumber(key);\n this.children[i].release();\n delete this.children[i];\n });\n } else {\n // 删除多余的行\n Object.keys(this.children).forEach(key => {\n const i = toNumber(key);\n if (i >= renderContent.length) {\n this.children[i].release();\n delete this.children[i];\n }\n });\n // 新增没有的行\n for (let i = 0; i < renderContent.length; i++) {\n if (!this.children[i]) {\n if (this.className === 'key-box' || this.className === 'value-box') {\n const text = new TextModel(this.product!, this._option, i);\n text.init([this.className.substring(0, this.className.indexOf('-'))], undefined, 'div');\n this.children[i] = text;\n } else if (this.className === 'shape-box') {\n const shape = new ShapeModel(this.product!, this._option, i);\n shape.init(['shape'], undefined, 'div');\n this.children[i] = shape;\n }\n }\n }\n }\n }\n\n setStyle() {\n const tooltipStyle = this._option.getTooltipStyle();\n\n super.setStyle(merge({}, defaultContentColumnStyle, tooltipStyle.content, this._getContentColumnStyle()));\n\n const renderContent = this._option.getTooltipActual()?.content ?? [];\n renderContent.forEach((line, i) => {\n let childStyle: any = {};\n if (this.className === 'key-box') {\n const { key, isKeyAdaptive } = line;\n childStyle = merge({}, isKeyAdaptive ? defaultAdaptiveKeyStyle : defaultKeyStyle, {\n height: `${100 / renderContent.length}%`,\n ...tooltipStyle.keyColumn.item\n });\n const hasContent = (isString(key) && key?.trim?.() !== '') || isNumber(key);\n if (!hasContent && !childStyle.visibility) {\n childStyle.visibility = 'hidden';\n } else {\n childStyle.visibility = 'visible';\n }\n (this.children[i] as TextModel).setStyle(childStyle);\n } else if (this.className === 'value-box') {\n childStyle = merge({}, defaultValueStyle, {\n height: `${100 / renderContent.length}%`,\n ...tooltipStyle.valueColumn.item\n });\n (this.children[i] as TextModel).setStyle(childStyle);\n } else if (this.className === 'shape-box') {\n childStyle = tooltipStyle.shapeColumn.item;\n const childContent = {\n hasShape: line.hasShape,\n shapeType: line.shapeType,\n size: tooltipStyle.shapeColumn.item?.width,\n color: line.shapeColor,\n hollow: line.shapeHollow\n } as IShapeSvgOption;\n (this.children[i] as ShapeModel)?.setStyle(childStyle, childContent);\n }\n });\n }\n\n setContent(): void {\n const tooltipStyle = this._option.getTooltipStyle();\n\n const renderContent = this._option.getTooltipActual()?.content ?? [];\n renderContent.forEach((line, i) => {\n let childContent: any;\n if (this.className === 'key-box') {\n const keyContent = line.key;\n if ((isString(keyContent) && keyContent?.trim?.() !== '') || isNumber(keyContent)) {\n childContent = keyContent;\n } else {\n childContent = TOOLTIP_EMPTY_STRING;\n }\n } else if (this.className === 'value-box') {\n const valueContent = line.value;\n if ((isString(valueContent) && valueContent?.trim?.() !== '') || isNumber(valueContent)) {\n childContent = valueContent;\n } else {\n childContent = TOOLTIP_EMPTY_STRING;\n }\n } else if (this.className === 'shape-box') {\n childContent = {\n hasShape: line.hasShape,\n shapeType: line.shapeType,\n size: tooltipStyle.shapeColumn.item?.width,\n color: line.shapeColor,\n hollow: line.shapeHollow\n } as IShapeSvgOption;\n }\n this.children[i]?.setContent(childContent);\n });\n }\n\n protected _getContentColumnStyle() {\n const tooltipStyle = this._option.getTooltipStyle();\n\n switch (this.className) {\n case 'shape-box':\n const renderContent = this._option.getTooltipActual()?.content ?? [];\n return {\n ...tooltipStyle.shapeColumn,\n ...(this.className === 'shape-box' && !renderContent.some(c => c.hasShape && c.shapeType)\n ? { display: 'none' }\n : {})\n };\n case 'key-box':\n return tooltipStyle.keyColumn;\n case 'value-box':\n return tooltipStyle.valueColumn;\n }\n }\n}\n"]}
@@ -1,9 +1,10 @@
1
1
  import { BaseTooltipModel } from './base-tooltip-model';
2
2
  import { ContentColumnModel } from './content-column-model';
3
+ import type { Maybe } from '@visactor/vutils';
3
4
  export declare class ContentModel extends BaseTooltipModel {
4
- shapeBox: ContentColumnModel;
5
- keyBox: ContentColumnModel;
6
- valueBox: ContentColumnModel;
5
+ shapeBox: Maybe<ContentColumnModel>;
6
+ keyBox: Maybe<ContentColumnModel>;
7
+ valueBox: Maybe<ContentColumnModel>;
7
8
  init(): void;
8
9
  private _initShapeBox;
9
10
  private _initKeyBox;
@@ -12,19 +12,19 @@ class ContentModel extends base_tooltip_model_1.BaseTooltipModel {
12
12
  this.shapeBox || this._initShapeBox(), this.keyBox || this._initKeyBox(), this.valueBox || this._initValueBox();
13
13
  }
14
14
  _initShapeBox() {
15
- const shapeBox = new content_column_model_1.ContentColumnModel(this.product, this._option, "shape-box", 0, this._tooltipStyle, this._tooltipActual);
15
+ const shapeBox = new content_column_model_1.ContentColumnModel(this.product, this._option, "shape-box", 0);
16
16
  shapeBox.init(), this.shapeBox = shapeBox, this.children[shapeBox.childIndex] = shapeBox;
17
17
  }
18
18
  _initKeyBox() {
19
- const keyBox = new content_column_model_1.ContentColumnModel(this.product, this._option, "key-box", 1, this._tooltipStyle, this._tooltipActual);
19
+ const keyBox = new content_column_model_1.ContentColumnModel(this.product, this._option, "key-box", 1);
20
20
  keyBox.init(), this.keyBox = keyBox, this.children[keyBox.childIndex] = keyBox;
21
21
  }
22
22
  _initValueBox() {
23
- const valueBox = new content_column_model_1.ContentColumnModel(this.product, this._option, "value-box", 2, this._tooltipStyle, this._tooltipActual);
23
+ const valueBox = new content_column_model_1.ContentColumnModel(this.product, this._option, "value-box", 2);
24
24
  valueBox.init(), this.valueBox = valueBox, this.children[valueBox.childIndex] = valueBox;
25
25
  }
26
26
  setStyle(style) {
27
- super.setStyle((0, vutils_1.merge)({}, style_constants_1.defaultContainerBoxStyle, style)),
27
+ super.setStyle((0, vutils_1.merge)({}, style_constants_1.defaultContentContainerStyle, style)),
28
28
  Object.values(this.children).forEach((c => {
29
29
  c.setStyle();
30
30
  }));
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/model/content-model.ts"],"names":[],"mappings":";;;AAAA,uDAA6D;AAC7D,6DAAwD;AACxD,iEAA4D;AAC5D,6CAAyC;AAEzC,MAAa,YAAa,SAAQ,qCAAgB;IAKhD,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;SAC7D;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QACD,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IAEO,aAAa;QACnB,MAAM,QAAQ,GAAG,IAAI,yCAAkB,CACrC,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,EACZ,WAAW,EACX,CAAC,EACD,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,cAAc,CACpB,CAAC;QACF,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,QAAQ,CAAC;IAChD,CAAC;IAEO,WAAW;QACjB,MAAM,MAAM,GAAG,IAAI,yCAAkB,CACnC,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,EACZ,SAAS,EACT,CAAC,EACD,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,cAAc,CACpB,CAAC;QACF,MAAM,CAAC,IAAI,EAAE,CAAC;QACd,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,MAAM,CAAC;IAC5C,CAAC;IAEO,aAAa;QACnB,MAAM,QAAQ,GAAG,IAAI,yCAAkB,CACrC,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,EACZ,WAAW,EACX,CAAC,EACD,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,cAAc,CACpB,CAAC;QACF,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,QAAQ,CAAC;IAChD,CAAC;IAED,QAAQ,CAAC,KAAoC;QAC3C,KAAK,CAAC,QAAQ,CAAC,IAAA,cAAK,EAAC,EAAE,EAAE,0CAAwB,EAAE,KAAK,CAAC,CAAC,CAAC;QAC3D,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvC,CAAC,CAAC,QAAQ,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU;QACR,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvC,CAAC,CAAC,UAAU,EAAE,CAAC;QACjB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,KAAK,CAAC,OAAO,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;CACF;AAjFD,oCAiFC","file":"content-model.js","sourcesContent":["import { defaultContainerBoxStyle } from './style-constants';\nimport { BaseTooltipModel } from './base-tooltip-model';\nimport { ContentColumnModel } from './content-column-model';\nimport { merge } from '@visactor/vutils';\n\nexport class ContentModel extends BaseTooltipModel {\n shapeBox: ContentColumnModel;\n keyBox: ContentColumnModel;\n valueBox: ContentColumnModel;\n\n init(): void {\n if (!this.product) {\n this.product = this.createElement('div', ['container-box']);\n }\n if (!this.shapeBox) {\n this._initShapeBox();\n }\n if (!this.keyBox) {\n this._initKeyBox();\n }\n if (!this.valueBox) {\n this._initValueBox();\n }\n }\n\n private _initShapeBox() {\n const shapeBox = new ContentColumnModel(\n this.product,\n this._option,\n 'shape-box',\n 0,\n this._tooltipStyle,\n this._tooltipActual\n );\n shapeBox.init();\n this.shapeBox = shapeBox;\n this.children[shapeBox.childIndex] = shapeBox;\n }\n\n private _initKeyBox() {\n const keyBox = new ContentColumnModel(\n this.product,\n this._option,\n 'key-box',\n 1,\n this._tooltipStyle,\n this._tooltipActual\n );\n keyBox.init();\n this.keyBox = keyBox;\n this.children[keyBox.childIndex] = keyBox;\n }\n\n private _initValueBox() {\n const valueBox = new ContentColumnModel(\n this.product,\n this._option,\n 'value-box',\n 2,\n this._tooltipStyle,\n this._tooltipActual\n );\n valueBox.init();\n this.valueBox = valueBox;\n this.children[valueBox.childIndex] = valueBox;\n }\n\n setStyle(style?: Partial<CSSStyleDeclaration>): void {\n super.setStyle(merge({}, defaultContainerBoxStyle, style));\n Object.values(this.children).forEach(c => {\n c.setStyle();\n });\n }\n\n setContent(): void {\n Object.values(this.children).forEach(c => {\n c.setContent();\n });\n }\n\n release(): void {\n super.release();\n this.shapeBox = null;\n this.keyBox = null;\n this.valueBox = null;\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/dom/model/content-model.ts"],"names":[],"mappings":";;;AAAA,uDAAiE;AACjE,6DAAwD;AACxD,iEAA4D;AAG5D,6CAAyC;AAEzC,MAAa,YAAa,SAAQ,qCAAgB;IAKhD,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;SAC7D;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QACD,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IAEO,aAAa;QACnB,MAAM,QAAQ,GAAG,IAAI,yCAAkB,CAAC,IAAI,CAAC,OAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QACrF,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,QAAQ,CAAC;IAChD,CAAC;IAEO,WAAW;QACjB,MAAM,MAAM,GAAG,IAAI,yCAAkB,CAAC,IAAI,CAAC,OAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QACjF,MAAM,CAAC,IAAI,EAAE,CAAC;QACd,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,MAAM,CAAC;IAC5C,CAAC;IAEO,aAAa;QACnB,MAAM,QAAQ,GAAG,IAAI,yCAAkB,CAAC,IAAI,CAAC,OAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QACrF,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,QAAQ,CAAC;IAChD,CAAC;IAED,QAAQ,CAAC,KAAoC;QAC3C,KAAK,CAAC,QAAQ,CAAC,IAAA,cAAK,EAAC,EAAE,EAAE,8CAA4B,EAAE,KAAK,CAAC,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvC,CAAC,CAAC,QAAQ,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU;QACR,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvC,CAAC,CAAC,UAAU,EAAE,CAAC;QACjB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,KAAK,CAAC,OAAO,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;CACF;AA5DD,oCA4DC","file":"content-model.js","sourcesContent":["import { defaultContentContainerStyle } from './style-constants';\nimport { BaseTooltipModel } from './base-tooltip-model';\nimport { ContentColumnModel } from './content-column-model';\nimport type { Maybe } from '@visactor/vutils';\n// eslint-disable-next-line no-duplicate-imports\nimport { merge } from '@visactor/vutils';\n\nexport class ContentModel extends BaseTooltipModel {\n shapeBox: Maybe<ContentColumnModel>;\n keyBox: Maybe<ContentColumnModel>;\n valueBox: Maybe<ContentColumnModel>;\n\n init(): void {\n if (!this.product) {\n this.product = this.createElement('div', ['container-box']);\n }\n if (!this.shapeBox) {\n this._initShapeBox();\n }\n if (!this.keyBox) {\n this._initKeyBox();\n }\n if (!this.valueBox) {\n this._initValueBox();\n }\n }\n\n private _initShapeBox() {\n const shapeBox = new ContentColumnModel(this.product!, this._option, 'shape-box', 0);\n shapeBox.init();\n this.shapeBox = shapeBox;\n this.children[shapeBox.childIndex] = shapeBox;\n }\n\n private _initKeyBox() {\n const keyBox = new ContentColumnModel(this.product!, this._option, 'key-box', 1);\n keyBox.init();\n this.keyBox = keyBox;\n this.children[keyBox.childIndex] = keyBox;\n }\n\n private _initValueBox() {\n const valueBox = new ContentColumnModel(this.product!, this._option, 'value-box', 2);\n valueBox.init();\n this.valueBox = valueBox;\n this.children[valueBox.childIndex] = valueBox;\n }\n\n setStyle(style?: Partial<CSSStyleDeclaration>): void {\n super.setStyle(merge({}, defaultContentContainerStyle, style));\n Object.values(this.children).forEach(c => {\n c.setStyle();\n });\n }\n\n setContent(): void {\n Object.values(this.children).forEach(c => {\n c.setContent();\n });\n }\n\n release(): void {\n super.release();\n this.shapeBox = null;\n this.keyBox = null;\n this.valueBox = null;\n }\n}\n"]}
@@ -1,3 +1,7 @@
1
+ import type { IToolTipActual } from '../../../../../typings';
2
+ import type { IDomTooltipStyle } from '../interface';
1
3
  export interface ITooltipModelOption {
2
4
  valueToHtml: (value: any) => string;
5
+ getTooltipStyle: () => IDomTooltipStyle;
6
+ getTooltipActual: () => IToolTipActual;
3
7
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/model/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["export interface ITooltipModelOption {\n valueToHtml: (value: any) => string;\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/dom/model/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["import type { IToolTipActual } from '../../../../../typings';\nimport type { IDomTooltipStyle } from '../interface';\n\nexport interface ITooltipModelOption {\n valueToHtml: (value: any) => string;\n getTooltipStyle: () => IDomTooltipStyle;\n getTooltipActual: () => IToolTipActual;\n}\n"]}
@@ -2,10 +2,10 @@ import type { IGradientColor } from '@visactor/vrender';
2
2
  import type { ShapeType } from '../../../../../typings';
3
3
  import { BaseTooltipModel } from './base-tooltip-model';
4
4
  export interface IShapeSvgOption {
5
- hasShape: boolean;
6
- shapeType: ShapeType;
7
- size: string;
8
- color: string | IGradientColor;
5
+ hasShape?: boolean;
6
+ shapeType?: ShapeType;
7
+ size?: string;
8
+ color?: string | IGradientColor;
9
9
  hollow?: boolean;
10
10
  }
11
11
  export declare class ShapeModel extends BaseTooltipModel {
@@ -14,6 +14,6 @@ export declare class ShapeModel extends BaseTooltipModel {
14
14
  init(classList?: string[], id?: string, tag?: keyof HTMLElementTagNameMap): void;
15
15
  setStyle(style?: Partial<CSSStyleDeclaration>, option?: IShapeSvgOption): void;
16
16
  setContent(option: IShapeSvgOption): void;
17
- setSvg(option: IShapeSvgOption): void;
17
+ setSvg(option?: IShapeSvgOption): void;
18
18
  release(): void;
19
19
  }
@@ -21,7 +21,7 @@ class ShapeModel extends base_tooltip_model_1.BaseTooltipModel {
21
21
  }
22
22
  setSvg(option) {
23
23
  const html = getSvgHtml(option);
24
- html !== this._svgHtmlCache && (this._svgHtmlCache = html, this.product.innerHTML = html);
24
+ this.product && html !== this._svgHtmlCache && (this._svgHtmlCache = html, this.product.innerHTML = html);
25
25
  }
26
26
  release() {
27
27
  super.release(), this._svgHtmlCache = "";
@@ -30,16 +30,16 @@ class ShapeModel extends base_tooltip_model_1.BaseTooltipModel {
30
30
 
31
31
  function getSvgHtml(option) {
32
32
  var _a, _b, _c, _d, _e, _f, _g;
33
- if (!(null == option ? void 0 : option.hasShape) || !vrender_1.builtinSymbolsMap[option.shapeType]) return "";
33
+ if (!(null == option ? void 0 : option.hasShape) || !option.shapeType || !vrender_1.builtinSymbolsMap[option.shapeType]) return "";
34
34
  const {shapeType: shapeType, size: size, color: color, hollow: hollow = !1} = option, path = vrender_1.builtinSymbolsMap[shapeType].pathStr;
35
35
  let fill = "currentColor";
36
36
  if (!color || (0, util_1.isString)(color) || hollow) return fill = hollow ? "none" : null !== (_a = color) && void 0 !== _a ? _a : "currentColor",
37
- `\n <svg width="${size}"\n height="${size}" viewBox="-0.8 -0.8 1.5 1.5" style="display: inline-block; vertical-align: middle;">\n <path fill="${fill}" d="${path}" style="fill: ${fill};">\n </path>\n </svg>`;
37
+ `\n <svg width="${size}"\n height="${size}" viewBox="-0.5 -0.5 1 1" style="display: inline-block; vertical-align: middle;">\n <path fill="${fill}" d="${path}" style="fill: ${fill};">\n </path>\n </svg>`;
38
38
  if ((0, util_1.isObject)(color)) {
39
39
  fill = "gradientColor";
40
40
  let gradient = "";
41
41
  return "radial" === color.gradient ? gradient = `\n <radialGradient id="${fill}" cx="50%" cy="50%" r="50%" fx="0%" fy="0%">\n ${(null !== (_b = color.stops) && void 0 !== _b ? _b : []).map((s => `<stop offset="${s.offset}" stop-color="${s.color}"/>`))}\n \t</radialGradient>\n ` : "linear" === color.gradient && (gradient = `\n <linearGradient id="${fill}" x1="${100 * (null !== (_c = color.x0) && void 0 !== _c ? _c : 0)}%" y1="${100 * (null !== (_d = color.y0) && void 0 !== _d ? _d : 0)}%" x2="${100 * (null !== (_e = color.x1) && void 0 !== _e ? _e : 0)}%" y2="${100 * (null !== (_f = color.y1) && void 0 !== _f ? _f : 0)}%">\n ${(null !== (_g = color.stops) && void 0 !== _g ? _g : []).map((s => `<stop offset="${s.offset}" stop-color="${s.color}"/>`))}\n </linearGradient>\n `),
42
- `\n <svg width="${size}" height="${size}"\n viewBox="-0.8 -0.8 1.5 1.5" style="display: inline-block; vertical-align: middle;">\n ${gradient}\n <path fill="url(#${fill})" d="${path}" style="fill: url(#${fill});">\n </path>\n </svg>`;
42
+ `\n <svg width="${size}" height="${size}"\n viewBox="-0.5 -0.5 1 1" style="display: inline-block; vertical-align: middle;">\n ${gradient}\n <path fill="url(#${fill})" d="${path}" style="fill: url(#${fill});">\n </path>\n </svg>`;
43
43
  }
44
44
  return "";
45
45
  }