@visactor/vchart 1.0.1-alpha.2 → 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 (438) hide show
  1. package/build/index.js +6014 -5864
  2. package/build/index.min.js +2 -2
  3. package/cjs/chart/area/area.d.ts +1 -0
  4. package/cjs/chart/area/area.js +4 -1
  5. package/cjs/chart/area/area.js.map +1 -1
  6. package/cjs/chart/bar/bar.d.ts +1 -0
  7. package/cjs/chart/bar/bar.js +4 -1
  8. package/cjs/chart/bar/bar.js.map +1 -1
  9. package/cjs/chart/base-chart.js +2 -1
  10. package/cjs/chart/base-chart.js.map +1 -1
  11. package/cjs/chart/box-plot/box-plot.js +2 -2
  12. package/cjs/chart/box-plot/box-plot.js.map +1 -1
  13. package/cjs/chart/histogram/histogram.d.ts +1 -0
  14. package/cjs/chart/histogram/histogram.js +4 -1
  15. package/cjs/chart/histogram/histogram.js.map +1 -1
  16. package/cjs/chart/line/line.d.ts +1 -0
  17. package/cjs/chart/line/line.js +4 -1
  18. package/cjs/chart/line/line.js.map +1 -1
  19. package/cjs/chart/range-area/range-area.d.ts +1 -0
  20. package/cjs/chart/range-area/range-area.js +4 -1
  21. package/cjs/chart/range-area/range-area.js.map +1 -1
  22. package/cjs/chart/range-column/range-column.d.ts +1 -0
  23. package/cjs/chart/range-column/range-column.js +4 -1
  24. package/cjs/chart/range-column/range-column.js.map +1 -1
  25. package/cjs/chart/sequence/sequence.js +1 -1
  26. package/cjs/chart/sequence/sequence.js.map +1 -1
  27. package/cjs/chart/util.d.ts +2 -0
  28. package/cjs/chart/util.js +23 -0
  29. package/cjs/chart/util.js.map +1 -0
  30. package/cjs/chart/waterfall/waterfall.js +2 -2
  31. package/cjs/chart/waterfall/waterfall.js.map +1 -1
  32. package/cjs/compile/grammar-item.js +2 -1
  33. package/cjs/component/axis/cartesian/axis.js +1 -1
  34. package/cjs/component/axis/cartesian/axis.js.map +1 -1
  35. package/cjs/component/crosshair/base.js +1 -2
  36. package/cjs/component/crosshair/base.js.map +1 -1
  37. package/cjs/component/crosshair/interface/spec.d.ts +1 -1
  38. package/cjs/component/crosshair/interface/spec.js.map +1 -1
  39. package/cjs/component/custom-mark/custom-mark.js.map +1 -1
  40. package/cjs/component/index.js +1 -2
  41. package/cjs/component/legend/base-legend.js +7 -3
  42. package/cjs/component/legend/base-legend.js.map +1 -1
  43. package/cjs/component/legend/util.d.ts +1 -1
  44. package/cjs/component/player/utils/transform.js +1 -3
  45. package/cjs/component/player/utils/transform.js.map +1 -1
  46. package/cjs/component/tooltip/handler/base.d.ts +5 -4
  47. package/cjs/component/tooltip/handler/base.js +44 -34
  48. package/cjs/component/tooltip/handler/base.js.map +1 -1
  49. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.d.ts +2 -2
  50. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.js +2 -2
  51. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.js.map +1 -1
  52. package/cjs/component/tooltip/handler/constants.d.ts +4 -0
  53. package/cjs/component/tooltip/handler/constants.js +5 -2
  54. package/cjs/component/tooltip/handler/constants.js.map +1 -1
  55. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.d.ts +6 -2
  56. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.js +20 -13
  57. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.js.map +1 -1
  58. package/cjs/component/tooltip/handler/dom/interface.d.ts +16 -5
  59. package/cjs/component/tooltip/handler/dom/interface.js.map +1 -1
  60. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.d.ts +7 -13
  61. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.js +12 -27
  62. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.js.map +1 -1
  63. package/cjs/component/tooltip/handler/dom/model/content-column-model.d.ts +13 -3
  64. package/cjs/component/tooltip/handler/dom/model/content-column-model.js +46 -26
  65. package/cjs/component/tooltip/handler/dom/model/content-column-model.js.map +1 -1
  66. package/cjs/component/tooltip/handler/dom/model/content-model.d.ts +4 -3
  67. package/cjs/component/tooltip/handler/dom/model/content-model.js +4 -4
  68. package/cjs/component/tooltip/handler/dom/model/content-model.js.map +1 -1
  69. package/cjs/component/tooltip/handler/dom/model/interface.d.ts +4 -0
  70. package/cjs/component/tooltip/handler/dom/model/interface.js.map +1 -1
  71. package/cjs/component/tooltip/handler/dom/model/shape-model.d.ts +5 -5
  72. package/cjs/component/tooltip/handler/dom/model/shape-model.js +4 -4
  73. package/cjs/component/tooltip/handler/dom/model/shape-model.js.map +1 -1
  74. package/cjs/component/tooltip/handler/dom/model/style-constants.d.ts +4 -4
  75. package/cjs/component/tooltip/handler/dom/model/style-constants.js +16 -18
  76. package/cjs/component/tooltip/handler/dom/model/style-constants.js.map +1 -1
  77. package/cjs/component/tooltip/handler/dom/model/text-model.js +1 -0
  78. package/cjs/component/tooltip/handler/dom/model/text-model.js.map +1 -1
  79. package/cjs/component/tooltip/handler/dom/model/title-model.d.ts +3 -2
  80. package/cjs/component/tooltip/handler/dom/model/title-model.js +15 -19
  81. package/cjs/component/tooltip/handler/dom/model/title-model.js.map +1 -1
  82. package/cjs/component/tooltip/handler/dom/model/tooltip-model.d.ts +1 -2
  83. package/cjs/component/tooltip/handler/dom/model/tooltip-model.js +21 -16
  84. package/cjs/component/tooltip/handler/dom/model/tooltip-model.js.map +1 -1
  85. package/cjs/component/tooltip/handler/dom/util.d.ts +5 -0
  86. package/cjs/component/tooltip/handler/dom/{utils/style.js → util.js} +32 -20
  87. package/cjs/component/tooltip/handler/dom/util.js.map +1 -0
  88. package/cjs/component/tooltip/handler/interface/index.d.ts +0 -1
  89. package/cjs/component/tooltip/handler/interface/index.js +1 -1
  90. package/cjs/component/tooltip/handler/interface/index.js.map +1 -1
  91. package/cjs/component/tooltip/handler/utils/attribute.js +12 -8
  92. package/cjs/component/tooltip/handler/utils/attribute.js.map +1 -1
  93. package/cjs/component/tooltip/handler/utils/common.d.ts +6 -2
  94. package/cjs/component/tooltip/handler/utils/common.js +30 -5
  95. package/cjs/component/tooltip/handler/utils/common.js.map +1 -1
  96. package/cjs/component/tooltip/handler/utils/compose.d.ts +3 -2
  97. package/cjs/component/tooltip/handler/utils/compose.js +56 -45
  98. package/cjs/component/tooltip/handler/utils/compose.js.map +1 -1
  99. package/cjs/component/tooltip/handler/utils/get-spec.js +64 -28
  100. package/cjs/component/tooltip/handler/utils/get-spec.js.map +1 -1
  101. package/cjs/component/tooltip/handler/utils/style.d.ts +2 -1
  102. package/cjs/component/tooltip/handler/utils/style.js +4 -4
  103. package/cjs/component/tooltip/handler/utils/style.js.map +1 -1
  104. package/cjs/component/tooltip/tooltip.d.ts +3 -1
  105. package/cjs/component/tooltip/tooltip.js +33 -18
  106. package/cjs/component/tooltip/tooltip.js.map +1 -1
  107. package/cjs/component/tooltip/utils/common.js +4 -2
  108. package/cjs/component/tooltip/utils/common.js.map +1 -1
  109. package/cjs/constant/marker.js +2 -1
  110. package/cjs/core/factory.js +1 -2
  111. package/cjs/core/index.d.ts +1 -1
  112. package/cjs/core/index.js +1 -1
  113. package/cjs/core/index.js.map +1 -1
  114. package/cjs/core/instance-manager.d.ts +1 -1
  115. package/cjs/core/instance-manager.js.map +1 -1
  116. package/cjs/core/vchart.d.ts +1 -0
  117. package/cjs/core/vchart.js +10 -2
  118. package/cjs/core/vchart.js.map +1 -1
  119. package/cjs/interaction/interface.js +1 -1
  120. package/cjs/interaction/trigger.js +1 -1
  121. package/cjs/layout/base-layout.js +9 -10
  122. package/cjs/layout/base-layout.js.map +1 -1
  123. package/cjs/layout/grid-layout/grid-layout.d.ts +5 -35
  124. package/cjs/layout/grid-layout/grid-layout.js +2 -1
  125. package/cjs/layout/grid-layout/grid-layout.js.map +1 -1
  126. package/cjs/layout/index.d.ts +1 -2
  127. package/cjs/layout/index.js.map +1 -1
  128. package/cjs/layout/interface.d.ts +31 -3
  129. package/cjs/layout/interface.js.map +1 -1
  130. package/cjs/mark/arc-3d.js +1 -1
  131. package/cjs/mark/arc.d.ts +5 -4
  132. package/cjs/mark/arc.js +11 -13
  133. package/cjs/mark/arc.js.map +1 -1
  134. package/cjs/mark/area.js +1 -1
  135. package/cjs/mark/base/base-line.js +3 -3
  136. package/cjs/mark/base/base-line.js.map +1 -1
  137. package/cjs/mark/base/base-mark.d.ts +7 -0
  138. package/cjs/mark/base/base-mark.js +10 -6
  139. package/cjs/mark/base/base-mark.js.map +1 -1
  140. package/cjs/mark/box-plot.js +1 -1
  141. package/cjs/mark/cell.js +1 -1
  142. package/cjs/mark/utils/common.d.ts +0 -12
  143. package/cjs/mark/utils/common.js +2 -13
  144. package/cjs/mark/utils/common.js.map +1 -1
  145. package/cjs/model/base-model.js +1 -1
  146. package/cjs/model/interface.js +1 -1
  147. package/cjs/model/layout-item.js +2 -1
  148. package/cjs/model/model-state-manager.js +1 -1
  149. package/cjs/model/tooltip-helper.d.ts +3 -4
  150. package/cjs/model/tooltip-helper.js +5 -10
  151. package/cjs/model/tooltip-helper.js.map +1 -1
  152. package/cjs/plugin/interface.js +1 -1
  153. package/cjs/region/interface.js +1 -1
  154. package/cjs/region/region.js +6 -11
  155. package/cjs/region/region.js.map +1 -1
  156. package/cjs/series/base/base-series.js +1 -1
  157. package/cjs/series/base/base-series.js.map +1 -1
  158. package/cjs/series/base/tooltip-helper.d.ts +9 -8
  159. package/cjs/series/base/tooltip-helper.js +23 -12
  160. package/cjs/series/base/tooltip-helper.js.map +1 -1
  161. package/cjs/series/dot/dot.js +2 -2
  162. package/cjs/series/dot/dot.js.map +1 -1
  163. package/cjs/series/dot/tooltip-helper.d.ts +1 -2
  164. package/cjs/series/dot/tooltip-helper.js +6 -5
  165. package/cjs/series/dot/tooltip-helper.js.map +1 -1
  166. package/cjs/series/funnel/funnel.d.ts +1 -1
  167. package/cjs/series/funnel/funnel.js +8 -8
  168. package/cjs/series/funnel/funnel.js.map +1 -1
  169. package/cjs/series/funnel/tooltip-helper.d.ts +5 -3
  170. package/cjs/series/funnel/tooltip-helper.js +10 -8
  171. package/cjs/series/funnel/tooltip-helper.js.map +1 -1
  172. package/cjs/series/interface/series.d.ts +2 -1
  173. package/cjs/series/interface/series.js.map +1 -1
  174. package/cjs/series/interface/tooltip-helper.d.ts +6 -6
  175. package/cjs/series/interface/tooltip-helper.js.map +1 -1
  176. package/cjs/series/link/link.js +2 -2
  177. package/cjs/series/link/link.js.map +1 -1
  178. package/cjs/series/treemap/treemap.js.map +1 -1
  179. package/cjs/series/word-cloud/base.js +2 -2
  180. package/cjs/series/word-cloud/base.js.map +1 -1
  181. package/cjs/series/word-cloud/word-cloud-3d.js +3 -3
  182. package/cjs/series/word-cloud/word-cloud-3d.js.map +1 -1
  183. package/cjs/theme/buildin-theme/index.d.ts +0 -1
  184. package/cjs/theme/buildin-theme/index.js +3 -3
  185. package/cjs/theme/buildin-theme/index.js.map +1 -1
  186. package/cjs/theme/buildin-theme/light/component/crosshair.js +4 -4
  187. package/cjs/theme/buildin-theme/light/component/crosshair.js.map +1 -1
  188. package/cjs/theme/buildin-theme/light/component/tooltip.js +1 -0
  189. package/cjs/theme/buildin-theme/light/component/tooltip.js.map +1 -1
  190. package/cjs/typings/spec/common.d.ts +1 -1
  191. package/cjs/typings/spec/common.js.map +1 -1
  192. package/cjs/typings/tooltip/common.d.ts +7 -1
  193. package/cjs/typings/tooltip/common.js.map +1 -1
  194. package/cjs/typings/tooltip/handler.d.ts +1 -1
  195. package/cjs/typings/tooltip/handler.js.map +1 -1
  196. package/cjs/typings/tooltip/line.d.ts +6 -4
  197. package/cjs/typings/tooltip/line.js.map +1 -1
  198. package/cjs/typings/tooltip/shape.d.ts +3 -3
  199. package/cjs/typings/tooltip/shape.js.map +1 -1
  200. package/cjs/typings/tooltip/tooltip.d.ts +11 -8
  201. package/cjs/typings/tooltip/tooltip.js.map +1 -1
  202. package/cjs/typings/visual.d.ts +4 -11
  203. package/cjs/typings/visual.js.map +1 -1
  204. package/cjs/util/debug.d.ts +3 -3
  205. package/cjs/util/debug.js +11 -20
  206. package/cjs/util/debug.js.map +1 -1
  207. package/cjs/util/index.d.ts +1 -0
  208. package/cjs/util/index.js +2 -1
  209. package/cjs/util/index.js.map +1 -1
  210. package/cjs/util/style.js +3 -7
  211. package/cjs/util/style.js.map +1 -1
  212. package/esm/chart/area/area.d.ts +1 -0
  213. package/esm/chart/area/area.js +5 -0
  214. package/esm/chart/area/area.js.map +1 -1
  215. package/esm/chart/bar/bar.d.ts +1 -0
  216. package/esm/chart/bar/bar.js +5 -0
  217. package/esm/chart/bar/bar.js.map +1 -1
  218. package/esm/chart/base-chart.js +2 -1
  219. package/esm/chart/base-chart.js.map +1 -1
  220. package/esm/chart/box-plot/box-plot.js +3 -1
  221. package/esm/chart/box-plot/box-plot.js.map +1 -1
  222. package/esm/chart/histogram/histogram.d.ts +1 -0
  223. package/esm/chart/histogram/histogram.js +5 -0
  224. package/esm/chart/histogram/histogram.js.map +1 -1
  225. package/esm/chart/line/line.d.ts +1 -0
  226. package/esm/chart/line/line.js +5 -0
  227. package/esm/chart/line/line.js.map +1 -1
  228. package/esm/chart/range-area/range-area.d.ts +1 -0
  229. package/esm/chart/range-area/range-area.js +5 -0
  230. package/esm/chart/range-area/range-area.js.map +1 -1
  231. package/esm/chart/range-column/range-column.d.ts +1 -0
  232. package/esm/chart/range-column/range-column.js +5 -0
  233. package/esm/chart/range-column/range-column.js.map +1 -1
  234. package/esm/chart/sequence/sequence.js +2 -2
  235. package/esm/chart/sequence/sequence.js.map +1 -1
  236. package/esm/chart/util.d.ts +2 -0
  237. package/esm/chart/util.js +16 -0
  238. package/esm/chart/util.js.map +1 -0
  239. package/esm/chart/waterfall/waterfall.js +3 -1
  240. package/esm/chart/waterfall/waterfall.js.map +1 -1
  241. package/esm/compile/grammar-item.js +2 -1
  242. package/esm/component/axis/cartesian/axis.js +2 -2
  243. package/esm/component/axis/cartesian/axis.js.map +1 -1
  244. package/esm/component/crosshair/base.js +1 -2
  245. package/esm/component/crosshair/base.js.map +1 -1
  246. package/esm/component/crosshair/interface/spec.d.ts +1 -1
  247. package/esm/component/crosshair/interface/spec.js.map +1 -1
  248. package/esm/component/custom-mark/custom-mark.js.map +1 -1
  249. package/esm/component/index.js +1 -2
  250. package/esm/component/legend/base-legend.js +7 -3
  251. package/esm/component/legend/base-legend.js.map +1 -1
  252. package/esm/component/legend/util.d.ts +1 -1
  253. package/esm/component/player/utils/transform.js +1 -3
  254. package/esm/component/player/utils/transform.js.map +1 -1
  255. package/esm/component/tooltip/handler/base.d.ts +5 -4
  256. package/esm/component/tooltip/handler/base.js +45 -35
  257. package/esm/component/tooltip/handler/base.js.map +1 -1
  258. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.d.ts +2 -2
  259. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.js +2 -3
  260. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.js.map +1 -1
  261. package/esm/component/tooltip/handler/constants.d.ts +4 -0
  262. package/esm/component/tooltip/handler/constants.js +9 -0
  263. package/esm/component/tooltip/handler/constants.js.map +1 -1
  264. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.d.ts +6 -2
  265. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.js +20 -12
  266. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.js.map +1 -1
  267. package/esm/component/tooltip/handler/dom/interface.d.ts +16 -5
  268. package/esm/component/tooltip/handler/dom/interface.js.map +1 -1
  269. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.d.ts +7 -13
  270. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.js +11 -29
  271. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.js.map +1 -1
  272. package/esm/component/tooltip/handler/dom/model/content-column-model.d.ts +13 -3
  273. package/esm/component/tooltip/handler/dom/model/content-column-model.js +46 -24
  274. package/esm/component/tooltip/handler/dom/model/content-column-model.js.map +1 -1
  275. package/esm/component/tooltip/handler/dom/model/content-model.d.ts +4 -3
  276. package/esm/component/tooltip/handler/dom/model/content-model.js +5 -5
  277. package/esm/component/tooltip/handler/dom/model/content-model.js.map +1 -1
  278. package/esm/component/tooltip/handler/dom/model/interface.d.ts +4 -0
  279. package/esm/component/tooltip/handler/dom/model/interface.js.map +1 -1
  280. package/esm/component/tooltip/handler/dom/model/shape-model.d.ts +5 -5
  281. package/esm/component/tooltip/handler/dom/model/shape-model.js +4 -4
  282. package/esm/component/tooltip/handler/dom/model/shape-model.js.map +1 -1
  283. package/esm/component/tooltip/handler/dom/model/style-constants.d.ts +4 -4
  284. package/esm/component/tooltip/handler/dom/model/style-constants.js +18 -20
  285. package/esm/component/tooltip/handler/dom/model/style-constants.js.map +1 -1
  286. package/esm/component/tooltip/handler/dom/model/text-model.js +1 -0
  287. package/esm/component/tooltip/handler/dom/model/text-model.js.map +1 -1
  288. package/esm/component/tooltip/handler/dom/model/title-model.d.ts +3 -2
  289. package/esm/component/tooltip/handler/dom/model/title-model.js +15 -19
  290. package/esm/component/tooltip/handler/dom/model/title-model.js.map +1 -1
  291. package/esm/component/tooltip/handler/dom/model/tooltip-model.d.ts +1 -2
  292. package/esm/component/tooltip/handler/dom/model/tooltip-model.js +22 -16
  293. package/esm/component/tooltip/handler/dom/model/tooltip-model.js.map +1 -1
  294. package/esm/component/tooltip/handler/dom/util.d.ts +5 -0
  295. package/esm/component/tooltip/handler/dom/util.js +71 -0
  296. package/esm/component/tooltip/handler/dom/util.js.map +1 -0
  297. package/esm/component/tooltip/handler/interface/index.d.ts +0 -1
  298. package/esm/component/tooltip/handler/interface/index.js +0 -2
  299. package/esm/component/tooltip/handler/interface/index.js.map +1 -1
  300. package/esm/component/tooltip/handler/utils/attribute.js +11 -7
  301. package/esm/component/tooltip/handler/utils/attribute.js.map +1 -1
  302. package/esm/component/tooltip/handler/utils/common.d.ts +6 -2
  303. package/esm/component/tooltip/handler/utils/common.js +25 -2
  304. package/esm/component/tooltip/handler/utils/common.js.map +1 -1
  305. package/esm/component/tooltip/handler/utils/compose.d.ts +3 -2
  306. package/esm/component/tooltip/handler/utils/compose.js +52 -43
  307. package/esm/component/tooltip/handler/utils/compose.js.map +1 -1
  308. package/esm/component/tooltip/handler/utils/get-spec.js +60 -23
  309. package/esm/component/tooltip/handler/utils/get-spec.js.map +1 -1
  310. package/esm/component/tooltip/handler/utils/style.d.ts +2 -1
  311. package/esm/component/tooltip/handler/utils/style.js +4 -4
  312. package/esm/component/tooltip/handler/utils/style.js.map +1 -1
  313. package/esm/component/tooltip/tooltip.d.ts +3 -1
  314. package/esm/component/tooltip/tooltip.js +33 -18
  315. package/esm/component/tooltip/tooltip.js.map +1 -1
  316. package/esm/component/tooltip/utils/common.js +4 -2
  317. package/esm/component/tooltip/utils/common.js.map +1 -1
  318. package/esm/constant/marker.js +2 -1
  319. package/esm/core/factory.js +1 -2
  320. package/esm/core/index.d.ts +1 -1
  321. package/esm/core/index.js +1 -1
  322. package/esm/core/index.js.map +1 -1
  323. package/esm/core/instance-manager.d.ts +1 -1
  324. package/esm/core/instance-manager.js.map +1 -1
  325. package/esm/core/vchart.d.ts +1 -0
  326. package/esm/core/vchart.js +9 -2
  327. package/esm/core/vchart.js.map +1 -1
  328. package/esm/interaction/interface.js +1 -1
  329. package/esm/interaction/trigger.js +1 -1
  330. package/esm/layout/base-layout.js +9 -10
  331. package/esm/layout/base-layout.js.map +1 -1
  332. package/esm/layout/grid-layout/grid-layout.d.ts +5 -35
  333. package/esm/layout/grid-layout/grid-layout.js +2 -1
  334. package/esm/layout/grid-layout/grid-layout.js.map +1 -1
  335. package/esm/layout/index.d.ts +1 -2
  336. package/esm/layout/index.js.map +1 -1
  337. package/esm/layout/interface.d.ts +31 -3
  338. package/esm/layout/interface.js.map +1 -1
  339. package/esm/mark/arc-3d.js +1 -1
  340. package/esm/mark/arc.d.ts +5 -4
  341. package/esm/mark/arc.js +11 -13
  342. package/esm/mark/arc.js.map +1 -1
  343. package/esm/mark/area.js +1 -1
  344. package/esm/mark/base/base-line.js +2 -4
  345. package/esm/mark/base/base-line.js.map +1 -1
  346. package/esm/mark/base/base-mark.d.ts +7 -0
  347. package/esm/mark/base/base-mark.js +9 -7
  348. package/esm/mark/base/base-mark.js.map +1 -1
  349. package/esm/mark/box-plot.js +1 -1
  350. package/esm/mark/cell.js +1 -1
  351. package/esm/mark/utils/common.d.ts +0 -12
  352. package/esm/mark/utils/common.js +0 -13
  353. package/esm/mark/utils/common.js.map +1 -1
  354. package/esm/model/base-model.js +1 -1
  355. package/esm/model/interface.js +1 -1
  356. package/esm/model/layout-item.js +2 -1
  357. package/esm/model/model-state-manager.js +1 -1
  358. package/esm/model/tooltip-helper.d.ts +3 -4
  359. package/esm/model/tooltip-helper.js +5 -10
  360. package/esm/model/tooltip-helper.js.map +1 -1
  361. package/esm/plugin/interface.js +1 -1
  362. package/esm/region/interface.js +1 -1
  363. package/esm/region/region.js +7 -11
  364. package/esm/region/region.js.map +1 -1
  365. package/esm/series/base/base-series.js +1 -1
  366. package/esm/series/base/base-series.js.map +1 -1
  367. package/esm/series/base/tooltip-helper.d.ts +9 -8
  368. package/esm/series/base/tooltip-helper.js +23 -12
  369. package/esm/series/base/tooltip-helper.js.map +1 -1
  370. package/esm/series/dot/dot.js +1 -3
  371. package/esm/series/dot/dot.js.map +1 -1
  372. package/esm/series/dot/tooltip-helper.d.ts +1 -2
  373. package/esm/series/dot/tooltip-helper.js +7 -4
  374. package/esm/series/dot/tooltip-helper.js.map +1 -1
  375. package/esm/series/funnel/funnel.d.ts +1 -1
  376. package/esm/series/funnel/funnel.js +8 -8
  377. package/esm/series/funnel/funnel.js.map +1 -1
  378. package/esm/series/funnel/tooltip-helper.d.ts +5 -3
  379. package/esm/series/funnel/tooltip-helper.js +11 -7
  380. package/esm/series/funnel/tooltip-helper.js.map +1 -1
  381. package/esm/series/interface/series.d.ts +2 -1
  382. package/esm/series/interface/series.js.map +1 -1
  383. package/esm/series/interface/tooltip-helper.d.ts +6 -6
  384. package/esm/series/interface/tooltip-helper.js.map +1 -1
  385. package/esm/series/link/link.js +1 -3
  386. package/esm/series/link/link.js.map +1 -1
  387. package/esm/series/treemap/treemap.js.map +1 -1
  388. package/esm/series/word-cloud/base.js +3 -3
  389. package/esm/series/word-cloud/base.js.map +1 -1
  390. package/esm/series/word-cloud/word-cloud-3d.js +2 -4
  391. package/esm/series/word-cloud/word-cloud-3d.js.map +1 -1
  392. package/esm/theme/buildin-theme/index.d.ts +0 -1
  393. package/esm/theme/buildin-theme/index.js +1 -5
  394. package/esm/theme/buildin-theme/index.js.map +1 -1
  395. package/esm/theme/buildin-theme/light/component/crosshair.js +4 -4
  396. package/esm/theme/buildin-theme/light/component/crosshair.js.map +1 -1
  397. package/esm/theme/buildin-theme/light/component/tooltip.js +1 -0
  398. package/esm/theme/buildin-theme/light/component/tooltip.js.map +1 -1
  399. package/esm/typings/spec/common.d.ts +1 -1
  400. package/esm/typings/spec/common.js.map +1 -1
  401. package/esm/typings/tooltip/common.d.ts +7 -1
  402. package/esm/typings/tooltip/common.js.map +1 -1
  403. package/esm/typings/tooltip/handler.d.ts +1 -1
  404. package/esm/typings/tooltip/handler.js.map +1 -1
  405. package/esm/typings/tooltip/line.d.ts +6 -4
  406. package/esm/typings/tooltip/line.js.map +1 -1
  407. package/esm/typings/tooltip/shape.d.ts +3 -3
  408. package/esm/typings/tooltip/shape.js.map +1 -1
  409. package/esm/typings/tooltip/tooltip.d.ts +11 -8
  410. package/esm/typings/tooltip/tooltip.js.map +1 -1
  411. package/esm/typings/visual.d.ts +4 -11
  412. package/esm/typings/visual.js.map +1 -1
  413. package/esm/util/debug.d.ts +3 -3
  414. package/esm/util/debug.js +11 -14
  415. package/esm/util/debug.js.map +1 -1
  416. package/esm/util/index.d.ts +1 -0
  417. package/esm/util/index.js +2 -0
  418. package/esm/util/index.js.map +1 -1
  419. package/esm/util/style.js +3 -8
  420. package/esm/util/style.js.map +1 -1
  421. package/package.json +35 -39
  422. package/cjs/component/tooltip/handler/dom/utils/style.d.ts +0 -3
  423. package/cjs/component/tooltip/handler/dom/utils/style.js.map +0 -1
  424. package/cjs/component/tooltip/handler/interface/cache.d.ts +0 -28
  425. package/cjs/component/tooltip/handler/interface/cache.js +0 -6
  426. package/cjs/component/tooltip/handler/interface/cache.js.map +0 -1
  427. package/cjs/theme/buildin-theme/dark.d.ts +0 -2
  428. package/cjs/theme/buildin-theme/dark.js +0 -16
  429. package/cjs/theme/buildin-theme/dark.js.map +0 -1
  430. package/esm/component/tooltip/handler/dom/utils/style.d.ts +0 -3
  431. package/esm/component/tooltip/handler/dom/utils/style.js +0 -59
  432. package/esm/component/tooltip/handler/dom/utils/style.js.map +0 -1
  433. package/esm/component/tooltip/handler/interface/cache.d.ts +0 -28
  434. package/esm/component/tooltip/handler/interface/cache.js +0 -2
  435. package/esm/component/tooltip/handler/interface/cache.js.map +0 -1
  436. package/esm/theme/buildin-theme/dark.d.ts +0 -2
  437. package/esm/theme/buildin-theme/dark.js +0 -12
  438. package/esm/theme/buildin-theme/dark.js.map +0 -1
@@ -1,5 +1,5 @@
1
1
  import type { IToolTipActual } from '../../../../typings/tooltip';
2
- import type { ITooltipSpec, TooltipHandlerParams } from '../../interface';
2
+ import type { TooltipHandlerParams } from '../../interface';
3
3
  import { BaseTooltipHandler } from '../base';
4
4
  import { Tooltip as TooltipComponent } from '@visactor/vrender-components';
5
5
  import type { Tooltip } from '../../tooltip';
@@ -9,7 +9,7 @@ export declare class CanvasTooltipHandler extends BaseTooltipHandler {
9
9
  protected _el?: HTMLCanvasElement;
10
10
  protected _tooltipCanvasId?: string;
11
11
  protected _tooltipComponent: TooltipComponent;
12
- constructor(tooltipSpec: ITooltipSpec, tooltipId: string, component: Tooltip);
12
+ constructor(tooltipId: string, component: Tooltip);
13
13
  private _initTooltipComponent;
14
14
  private _getLayer;
15
15
  protected _removeTooltip(): void;
@@ -7,9 +7,9 @@ Object.defineProperty(exports, "__esModule", {
7
7
  const base_1 = require("../base"), vrender_components_1 = require("@visactor/vrender-components"), vutils_1 = require("@visactor/vutils"), constants_1 = require("../constants");
8
8
 
9
9
  class CanvasTooltipHandler extends base_1.BaseTooltipHandler {
10
- constructor(tooltipSpec, tooltipId, component) {
10
+ constructor(tooltipId, component) {
11
11
  var _a;
12
- super(tooltipSpec, tooltipId, component), this.type = constants_1.TooltipHandlerType.canvas,
12
+ super(tooltipId, component), this.type = constants_1.TooltipHandlerType.canvas,
13
13
  this._tooltipCanvasId = null === (_a = this._chartOption.modeParams) || void 0 === _a ? void 0 : _a.tooltipCanvasId;
14
14
  }
15
15
  _initTooltipComponent(stage) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/canvas/canvas-tooltip-handler.ts"],"names":[],"mappings":"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","file":"canvas-tooltip-handler.js","sourcesContent":["import type { ILayer, INode, Stage } from '@visactor/vrender';\nimport type { IToolTipActual } from '../../../../typings/tooltip';\nimport type { ITooltipSpec, TooltipHandlerParams } from '../../interface';\nimport { BaseTooltipHandler } from '../base';\nimport { Tooltip as TooltipComponent } from '@visactor/vrender-components';\nimport { isValid } from '@visactor/vutils';\nimport { TooltipHandlerType } from '../constants';\nimport type { Tooltip } from '../../tooltip';\n\n/**\n * The tooltip handler class.\n */\nexport class CanvasTooltipHandler extends BaseTooltipHandler {\n type = TooltipHandlerType.canvas;\n\n private _layer: ILayer;\n protected _el?: HTMLCanvasElement;\n protected _tooltipCanvasId?: string;\n protected _tooltipComponent: TooltipComponent;\n\n constructor(tooltipSpec: ITooltipSpec, tooltipId: string, component: Tooltip) {\n super(tooltipSpec, tooltipId, component);\n this._tooltipCanvasId = (this._chartOption.modeParams as any)?.tooltipCanvasId;\n }\n\n private _initTooltipComponent(stage: Stage) {\n const layer = this._getLayer(stage);\n this._tooltipComponent = new TooltipComponent({\n autoCalculatePosition: false,\n autoMeasure: false\n });\n layer.add(this._tooltipComponent as unknown as INode);\n }\n\n private _getLayer(stage: Stage) {\n if (this._layer) {\n return this._layer;\n }\n\n this._layer = stage.createLayer(this._tooltipCanvasId);\n\n // 需要关闭 layer 对应的 canvas 的事件\n const layerCanvas = this._layer.layerHandler.canvas.nativeCanvas as HTMLCanvasElement;\n // TODO:待 vrender 支持\n if (layerCanvas && layerCanvas.style) {\n layerCanvas.style.touchAction = 'none';\n layerCanvas.style.pointerEvents = 'none';\n }\n\n return this._layer;\n }\n\n protected _removeTooltip() {\n if (this._layer) {\n this._layer.removeAllChild();\n // this._layer.render();\n }\n this._attributeCache = null;\n }\n\n protected _updateTooltip(visible: boolean, params: TooltipHandlerParams, actualTooltip: IToolTipActual) {\n this._visible = visible;\n\n const stage = this._compiler.getStage();\n if (!stage) {\n return;\n }\n\n if (!visible) {\n if (this._tooltipComponent && this._tooltipComponent.attribute.visible) {\n this._tooltipComponent.hideAll();\n stage.renderNextFrame();\n }\n return;\n }\n\n if (!this._tooltipComponent) {\n this._initTooltipComponent(stage);\n }\n\n const pos = actualTooltip?.position;\n if (!params.changePositionOnly) {\n this._tooltipComponent.setAttributes({\n visible: true,\n ...this._attributeCache,\n ...pos\n });\n } else if (isValid(pos)) {\n this._tooltipComponent.setAttributes(pos);\n }\n\n if (!this._tooltipComponent.attribute.visible) {\n this._tooltipComponent.showAll();\n }\n }\n\n release() {\n super.release();\n this._layer?.release();\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/canvas/canvas-tooltip-handler.ts"],"names":[],"mappings":"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","file":"canvas-tooltip-handler.js","sourcesContent":["import type { ILayer, INode, Stage } from '@visactor/vrender';\nimport type { IToolTipActual } from '../../../../typings/tooltip';\nimport type { TooltipHandlerParams } from '../../interface';\nimport { BaseTooltipHandler } from '../base';\nimport { Tooltip as TooltipComponent } from '@visactor/vrender-components';\nimport { isValid } from '@visactor/vutils';\nimport { TooltipHandlerType } from '../constants';\nimport type { Tooltip } from '../../tooltip';\n\n/**\n * The tooltip handler class.\n */\nexport class CanvasTooltipHandler extends BaseTooltipHandler {\n type = TooltipHandlerType.canvas;\n\n private _layer: ILayer;\n protected _el?: HTMLCanvasElement;\n protected _tooltipCanvasId?: string;\n protected _tooltipComponent: TooltipComponent;\n\n constructor(tooltipId: string, component: Tooltip) {\n super(tooltipId, component);\n this._tooltipCanvasId = (this._chartOption.modeParams as any)?.tooltipCanvasId;\n }\n\n private _initTooltipComponent(stage: Stage) {\n const layer = this._getLayer(stage);\n this._tooltipComponent = new TooltipComponent({\n autoCalculatePosition: false,\n autoMeasure: false\n });\n layer.add(this._tooltipComponent as unknown as INode);\n }\n\n private _getLayer(stage: Stage) {\n if (this._layer) {\n return this._layer;\n }\n\n this._layer = stage.createLayer(this._tooltipCanvasId);\n\n // 需要关闭 layer 对应的 canvas 的事件\n const layerCanvas = this._layer.layerHandler.canvas.nativeCanvas as HTMLCanvasElement;\n // TODO:待 vrender 支持\n if (layerCanvas && layerCanvas.style) {\n layerCanvas.style.touchAction = 'none';\n layerCanvas.style.pointerEvents = 'none';\n }\n\n return this._layer;\n }\n\n protected _removeTooltip() {\n if (this._layer) {\n this._layer.removeAllChild();\n // this._layer.render();\n }\n this._attributeCache = null;\n }\n\n protected _updateTooltip(visible: boolean, params: TooltipHandlerParams, actualTooltip: IToolTipActual) {\n this._visible = visible;\n\n const stage = this._compiler.getStage();\n if (!stage) {\n return;\n }\n\n if (!visible) {\n if (this._tooltipComponent && this._tooltipComponent.attribute.visible) {\n this._tooltipComponent.hideAll();\n stage.renderNextFrame();\n }\n return;\n }\n\n if (!this._tooltipComponent) {\n this._initTooltipComponent(stage);\n }\n\n const pos = actualTooltip?.position;\n if (!params.changePositionOnly) {\n this._tooltipComponent.setAttributes({\n visible: true,\n ...this._attributeCache,\n ...pos\n });\n } else if (isValid(pos)) {\n this._tooltipComponent.setAttributes(pos);\n }\n\n if (!this._tooltipComponent.attribute.visible) {\n this._tooltipComponent.showAll();\n }\n }\n\n release() {\n super.release();\n this._layer?.release();\n }\n}\n"]}
@@ -1,6 +1,10 @@
1
+ import type { IToolTipLineActual } from '../../../typings';
1
2
  import { escapeHTML } from './utils';
2
3
  export declare const TOOLTIP_EL_CLASS_NAME = "vchart-tooltip-element";
3
4
  export declare const TOOLTIP_CONTAINER_EL_CLASS_NAME = "vchart-tooltip-container";
5
+ export declare const TOOLTIP_MAX_LINE_COUNT = 20;
6
+ export declare const TOOLTIP_EMPTY_STRING = "";
7
+ export declare const TOOLTIP_OTHERS_LINE: IToolTipLineActual;
4
8
  export declare const DEFAULT_OPTIONS: {
5
9
  offsetX: number;
6
10
  offsetY: number;
@@ -2,12 +2,15 @@
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: !0
5
- }), exports.TooltipHandlerType = exports.DEFAULT_OPTIONS = exports.TOOLTIP_CONTAINER_EL_CLASS_NAME = exports.TOOLTIP_EL_CLASS_NAME = void 0;
5
+ }), exports.TooltipHandlerType = exports.DEFAULT_OPTIONS = exports.TOOLTIP_OTHERS_LINE = exports.TOOLTIP_EMPTY_STRING = exports.TOOLTIP_MAX_LINE_COUNT = exports.TOOLTIP_CONTAINER_EL_CLASS_NAME = exports.TOOLTIP_EL_CLASS_NAME = void 0;
6
6
 
7
7
  const constant_1 = require("../../../constant"), utils_1 = require("./utils");
8
8
 
9
9
  exports.TOOLTIP_EL_CLASS_NAME = "vchart-tooltip-element", exports.TOOLTIP_CONTAINER_EL_CLASS_NAME = "vchart-tooltip-container",
10
- exports.DEFAULT_OPTIONS = {
10
+ exports.TOOLTIP_MAX_LINE_COUNT = 20, exports.TOOLTIP_EMPTY_STRING = "", exports.TOOLTIP_OTHERS_LINE = {
11
+ key: "其他",
12
+ value: "..."
13
+ }, exports.DEFAULT_OPTIONS = {
11
14
  offsetX: 10,
12
15
  offsetY: 10,
13
16
  sanitize: utils_1.escapeHTML
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/constants.ts"],"names":[],"mappings":";;;AAAA,gDAA2C;AAC3C,mCAAqC;AAExB,QAAA,qBAAqB,GAAG,wBAAwB,CAAC;AACjD,QAAA,+BAA+B,GAAG,0BAA0B,CAAC;AAE7D,QAAA,eAAe,GAAG;IAI7B,OAAO,EAAE,EAAE;IAKX,OAAO,EAAE,EAAE;IAOX,QAAQ,EAAE,kBAAU;CACrB,CAAC;AAMF,MAAa,kBAAkB;;AAA/B,gDAGC;AAFQ,sBAAG,GAAG,GAAG,iBAAM,sBAAsB,CAAC;AACtC,yBAAM,GAAG,GAAG,iBAAM,yBAAyB,CAAC","file":"constants.js","sourcesContent":["import { PREFIX } from '../../../constant';\nimport { escapeHTML } from './utils';\n\nexport const TOOLTIP_EL_CLASS_NAME = 'vchart-tooltip-element';\nexport const TOOLTIP_CONTAINER_EL_CLASS_NAME = 'vchart-tooltip-container';\n\nexport const DEFAULT_OPTIONS = {\n /**\n * X offset.\n */\n offsetX: 10,\n\n /**\n * Y offset.\n */\n offsetY: 10,\n\n /**\n * HTML sanitizer function that removes dangerous HTML to prevent XSS.\n *\n * This should be a function from string to string. You may replace it with a formatter such as a markdown formatter.\n */\n sanitize: escapeHTML\n};\n\n// FIXME: 命名规范\nexport type Options = typeof DEFAULT_OPTIONS;\n\n/** 内置 handler 类型 */\nexport class TooltipHandlerType {\n static dom = `${PREFIX}_TOOLTIP_HANDLER_DOM`; // 模拟 enum\n static canvas = `${PREFIX}_TOOLTIP_HANDLER_CANVAS`;\n}\n"]}
1
+ {"version":3,"sources":["../src/component/tooltip/handler/constants.ts"],"names":[],"mappings":";;;AAAA,gDAA2C;AAE3C,mCAAqC;AAExB,QAAA,qBAAqB,GAAG,wBAAwB,CAAC;AACjD,QAAA,+BAA+B,GAAG,0BAA0B,CAAC;AAC7D,QAAA,sBAAsB,GAAG,EAAE,CAAC;AAC5B,QAAA,oBAAoB,GAAG,EAAE,CAAC;AAE1B,QAAA,mBAAmB,GAAG;IAEjC,GAAG,EAAE,IAAI;IACT,KAAK,EAAE,KAAK;CACS,CAAC;AAEX,QAAA,eAAe,GAAG;IAI7B,OAAO,EAAE,EAAE;IAKX,OAAO,EAAE,EAAE;IAOX,QAAQ,EAAE,kBAAU;CACrB,CAAC;AAMF,MAAa,kBAAkB;;AAA/B,gDAGC;AAFQ,sBAAG,GAAG,GAAG,iBAAM,sBAAsB,CAAC;AACtC,yBAAM,GAAG,GAAG,iBAAM,yBAAyB,CAAC","file":"constants.js","sourcesContent":["import { PREFIX } from '../../../constant';\nimport type { IToolTipLineActual } from '../../../typings';\nimport { escapeHTML } from './utils';\n\nexport const TOOLTIP_EL_CLASS_NAME = 'vchart-tooltip-element';\nexport const TOOLTIP_CONTAINER_EL_CLASS_NAME = 'vchart-tooltip-container';\nexport const TOOLTIP_MAX_LINE_COUNT = 20;\nexport const TOOLTIP_EMPTY_STRING = '';\n\nexport const TOOLTIP_OTHERS_LINE = {\n // TODO: i18n\n key: '其他',\n value: '...'\n} as IToolTipLineActual;\n\nexport const DEFAULT_OPTIONS = {\n /**\n * X offset.\n */\n offsetX: 10,\n\n /**\n * Y offset.\n */\n offsetY: 10,\n\n /**\n * HTML sanitizer function that removes dangerous HTML to prevent XSS.\n *\n * This should be a function from string to string. You may replace it with a formatter such as a markdown formatter.\n */\n sanitize: escapeHTML\n};\n\n// FIXME: 命名规范\nexport type Options = typeof DEFAULT_OPTIONS;\n\n/** 内置 handler 类型 */\nexport class TooltipHandlerType {\n static dom = `${PREFIX}_TOOLTIP_HANDLER_DOM`; // 模拟 enum\n static canvas = `${PREFIX}_TOOLTIP_HANDLER_CANVAS`;\n}\n"]}
@@ -4,17 +4,21 @@ import { BaseTooltipHandler } from '../base';
4
4
  import type { IDomTooltipStyle } from './interface';
5
5
  import { TooltipModel } from './model/tooltip-model';
6
6
  import type { Tooltip } from '../../tooltip';
7
+ import type { Maybe } from '@visactor/vutils';
7
8
  export declare class DomTooltipHandler extends BaseTooltipHandler {
8
9
  type: string;
9
10
  protected _tooltipContainer: HTMLElement;
10
11
  protected _domStyle: IDomTooltipStyle;
11
- protected _container: HTMLDivElement;
12
+ protected _tooltipActual: IToolTipActual;
13
+ protected _container: Maybe<HTMLDivElement>;
12
14
  protected model: TooltipModel;
13
15
  getVisibility(): boolean;
14
16
  setVisibility(_value: boolean): void;
15
- constructor(tooltipSpec: ITooltipSpec, tooltipId: string, component: Tooltip);
17
+ constructor(tooltipId: string, component: Tooltip);
16
18
  initEl(): void;
17
19
  protected _removeTooltip(): void;
18
20
  protected _updateTooltip(visible: boolean, params: TooltipHandlerParams, actualTooltip: IToolTipActual): void;
21
+ protected _initStyle(): void;
19
22
  protected _getParentElement(spec: ITooltipSpec): HTMLElement;
23
+ reInit(): void;
20
24
  }
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: !0
5
5
  }), exports.DomTooltipHandler = void 0;
6
6
 
7
- const base_1 = require("../base"), style_1 = require("./utils/style"), tooltip_model_1 = require("./model/tooltip-model"), base_tooltip_model_1 = require("./model/base-tooltip-model"), constants_1 = require("../constants");
7
+ const base_1 = require("../base"), util_1 = require("./util"), tooltip_model_1 = require("./model/tooltip-model"), base_tooltip_model_1 = require("./model/base-tooltip-model"), constants_1 = require("../constants");
8
8
 
9
9
  class DomTooltipHandler extends base_1.BaseTooltipHandler {
10
10
  getVisibility() {
@@ -15,15 +15,14 @@ class DomTooltipHandler extends base_1.BaseTooltipHandler {
15
15
  var _a;
16
16
  _value !== this.getVisibility() && (null === (_a = this.model) || void 0 === _a || _a.setVisibility(_value));
17
17
  }
18
- constructor(tooltipSpec, tooltipId, component) {
18
+ constructor(tooltipId, component) {
19
19
  var _a;
20
- super(tooltipSpec, tooltipId, component), this.type = constants_1.TooltipHandlerType.dom,
21
- this._tooltipContainer = null === (_a = globalThis.document) || void 0 === _a ? void 0 : _a.body,
22
- this._domStyle = (0, style_1.getDomStyles)(this._style), this.initEl();
20
+ super(tooltipId, component), this.type = constants_1.TooltipHandlerType.dom, this._tooltipContainer = null === (_a = globalThis.document) || void 0 === _a ? void 0 : _a.body,
21
+ this._initStyle(), this.initEl();
23
22
  }
24
23
  initEl() {
25
- if (base_tooltip_model_1.domDocument) {
26
- const {parentElement: parentElement} = this._tooltipSpec;
24
+ const tooltipSpec = this._component.getSpec(), {parentElement: parentElement} = tooltipSpec;
25
+ if (base_tooltip_model_1.domDocument && parentElement) {
27
26
  for (let i = 0; i < parentElement.children.length; i++) if (parentElement.children[i].classList.contains(constants_1.TOOLTIP_CONTAINER_EL_CLASS_NAME)) {
28
27
  this._container = parentElement.children[i];
29
28
  break;
@@ -31,8 +30,10 @@ class DomTooltipHandler extends base_1.BaseTooltipHandler {
31
30
  this._container || (this._container = base_tooltip_model_1.domDocument.createElement("div"),
32
31
  this._container.style.position = "relative", this._container.classList.add(constants_1.TOOLTIP_CONTAINER_EL_CLASS_NAME),
33
32
  parentElement.appendChild(this._container)), this.model = new tooltip_model_1.TooltipModel(this._container, {
34
- valueToHtml: this._option.sanitize
35
- }, [ this._tooltipSpec.className ], this.id, this._domStyle);
33
+ valueToHtml: this._option.sanitize,
34
+ getTooltipStyle: () => this._domStyle,
35
+ getTooltipActual: () => this._tooltipActual
36
+ }, [ tooltipSpec.className ], this.id);
36
37
  }
37
38
  }
38
39
  _removeTooltip() {
@@ -42,16 +43,22 @@ class DomTooltipHandler extends base_1.BaseTooltipHandler {
42
43
  _updateTooltip(visible, params, actualTooltip) {
43
44
  var _a;
44
45
  if (visible && this.model) {
45
- params.changePositionOnly || (this.model.setTooltipActual(actualTooltip), this.model.setStyle(),
46
- this.model.setContent()), this.setVisibility(visible);
47
- const {x: x = 0, y: y = 0} = null !== (_a = actualTooltip.position) && void 0 !== _a ? _a : {};
48
- this.model.product.style.transform = `translate3d(${x}px, ${y}px, 0)`;
46
+ params.changePositionOnly || (this._tooltipActual = actualTooltip, this._initStyle(),
47
+ this.model.initAll(), this.model.setStyle(), this.model.setContent()), this.setVisibility(visible);
48
+ const {x: x = 0, y: y = 0} = null !== (_a = actualTooltip.position) && void 0 !== _a ? _a : {}, el = this.model.product;
49
+ el && (el.style.transform = `translate3d(${x}px, ${y}px, 0)`);
49
50
  } else this.setVisibility(visible);
50
51
  }
52
+ _initStyle() {
53
+ this._domStyle = (0, util_1.getDomStyles)(this._style, this._attributeCache);
54
+ }
51
55
  _getParentElement(spec) {
52
56
  var _a;
53
57
  return null !== (_a = this._container) && void 0 !== _a ? _a : super._getParentElement(spec);
54
58
  }
59
+ reInit() {
60
+ super.reInit(), this._initStyle();
61
+ }
55
62
  }
56
63
 
57
64
  exports.DomTooltipHandler = DomTooltipHandler;
@@ -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 | HTMLMapElement | HTMLStyleElement | HTMLTitleElement | HTMLLabelElement | HTMLAnchorElement | HTMLDataElement | HTMLSelectElement | HTMLTrackElement | HTMLTimeElement | HTMLSourceElement | HTMLLegendElement | HTMLInputElement | HTMLOutputElement | HTMLHtmlElement | 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 | 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;