@visactor/vchart 1.0.0-alpha.0 → 1.0.0-alpha.1

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 (236) hide show
  1. package/README.md +1 -1
  2. package/build/index.js +1053 -1006
  3. package/build/index.min.js +2 -2
  4. package/cjs/component/axis/cartesian/axis.js +3 -3
  5. package/cjs/component/axis/cartesian/axis.js.map +1 -1
  6. package/cjs/component/tooltip/handler/base.d.ts +5 -4
  7. package/cjs/component/tooltip/handler/base.js +44 -34
  8. package/cjs/component/tooltip/handler/base.js.map +1 -1
  9. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.d.ts +2 -2
  10. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.js +2 -2
  11. package/cjs/component/tooltip/handler/canvas/canvas-tooltip-handler.js.map +1 -1
  12. package/cjs/component/tooltip/handler/dom/constants.d.ts +2 -0
  13. package/cjs/component/tooltip/handler/dom/constants.js +7 -0
  14. package/cjs/component/tooltip/handler/dom/constants.js.map +1 -0
  15. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.d.ts +9 -3
  16. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.js +30 -13
  17. package/cjs/component/tooltip/handler/dom/dom-tooltip-handler.js.map +1 -1
  18. package/cjs/component/tooltip/handler/dom/interface.d.ts +16 -5
  19. package/cjs/component/tooltip/handler/dom/interface.js.map +1 -1
  20. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.d.ts +7 -13
  21. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.js +12 -27
  22. package/cjs/component/tooltip/handler/dom/model/base-tooltip-model.js.map +1 -1
  23. package/cjs/component/tooltip/handler/dom/model/content-column-model.d.ts +13 -3
  24. package/cjs/component/tooltip/handler/dom/model/content-column-model.js +42 -26
  25. package/cjs/component/tooltip/handler/dom/model/content-column-model.js.map +1 -1
  26. package/cjs/component/tooltip/handler/dom/model/content-model.d.ts +4 -3
  27. package/cjs/component/tooltip/handler/dom/model/content-model.js +4 -4
  28. package/cjs/component/tooltip/handler/dom/model/content-model.js.map +1 -1
  29. package/cjs/component/tooltip/handler/dom/model/interface.d.ts +5 -0
  30. package/cjs/component/tooltip/handler/dom/model/interface.js.map +1 -1
  31. package/cjs/component/tooltip/handler/dom/model/shape-model.d.ts +5 -5
  32. package/cjs/component/tooltip/handler/dom/model/shape-model.js +4 -4
  33. package/cjs/component/tooltip/handler/dom/model/shape-model.js.map +1 -1
  34. package/cjs/component/tooltip/handler/dom/model/style-constants.d.ts +4 -4
  35. package/cjs/component/tooltip/handler/dom/model/style-constants.js +16 -15
  36. package/cjs/component/tooltip/handler/dom/model/style-constants.js.map +1 -1
  37. package/cjs/component/tooltip/handler/dom/model/text-model.js +1 -0
  38. package/cjs/component/tooltip/handler/dom/model/text-model.js.map +1 -1
  39. package/cjs/component/tooltip/handler/dom/model/title-model.d.ts +3 -2
  40. package/cjs/component/tooltip/handler/dom/model/title-model.js +15 -19
  41. package/cjs/component/tooltip/handler/dom/model/title-model.js.map +1 -1
  42. package/cjs/component/tooltip/handler/dom/model/tooltip-model.d.ts +1 -2
  43. package/cjs/component/tooltip/handler/dom/model/tooltip-model.js +20 -16
  44. package/cjs/component/tooltip/handler/dom/model/tooltip-model.js.map +1 -1
  45. package/cjs/component/tooltip/handler/dom/util.d.ts +5 -0
  46. package/cjs/component/tooltip/handler/dom/{utils/style.js → util.js} +31 -19
  47. package/cjs/component/tooltip/handler/dom/util.js.map +1 -0
  48. package/cjs/component/tooltip/handler/interface/index.d.ts +0 -1
  49. package/cjs/component/tooltip/handler/interface/index.js +1 -1
  50. package/cjs/component/tooltip/handler/interface/index.js.map +1 -1
  51. package/cjs/component/tooltip/handler/utils/attribute.js +10 -7
  52. package/cjs/component/tooltip/handler/utils/attribute.js.map +1 -1
  53. package/cjs/component/tooltip/handler/utils/common.d.ts +6 -2
  54. package/cjs/component/tooltip/handler/utils/common.js +19 -5
  55. package/cjs/component/tooltip/handler/utils/common.js.map +1 -1
  56. package/cjs/component/tooltip/handler/utils/compose.d.ts +3 -2
  57. package/cjs/component/tooltip/handler/utils/compose.js +27 -37
  58. package/cjs/component/tooltip/handler/utils/compose.js.map +1 -1
  59. package/cjs/component/tooltip/handler/utils/get-spec.js +26 -20
  60. package/cjs/component/tooltip/handler/utils/get-spec.js.map +1 -1
  61. package/cjs/component/tooltip/handler/utils/style.d.ts +2 -1
  62. package/cjs/component/tooltip/handler/utils/style.js +4 -4
  63. package/cjs/component/tooltip/handler/utils/style.js.map +1 -1
  64. package/cjs/component/tooltip/tooltip.d.ts +3 -1
  65. package/cjs/component/tooltip/tooltip.js +33 -18
  66. package/cjs/component/tooltip/tooltip.js.map +1 -1
  67. package/cjs/constant/box-plot.js +2 -1
  68. package/cjs/constant/scroll-bar.js +1 -2
  69. package/cjs/core/instance-manager.d.ts +1 -1
  70. package/cjs/core/instance-manager.js.map +1 -1
  71. package/cjs/core/vchart.d.ts +1 -0
  72. package/cjs/core/vchart.js +6 -0
  73. package/cjs/core/vchart.js.map +1 -1
  74. package/cjs/index.d.ts +1 -1
  75. package/cjs/index.js +1 -1
  76. package/cjs/index.js.map +1 -1
  77. package/cjs/layout/layout3d/index.js +2 -2
  78. package/cjs/layout/layout3d/index.js.map +1 -1
  79. package/cjs/mark/area.js +2 -1
  80. package/cjs/mark/cell.js +1 -1
  81. package/cjs/mark/component.js +1 -1
  82. package/cjs/mark/group.js +1 -1
  83. package/cjs/mark/line.js +1 -1
  84. package/cjs/mark/linkPath.js +1 -1
  85. package/cjs/mark/path.js +1 -1
  86. package/cjs/model/base-model.js +1 -1
  87. package/cjs/model/interface.js +1 -1
  88. package/cjs/model/layout-item.js +1 -1
  89. package/cjs/model/model-state-manager.js +1 -2
  90. package/cjs/model/tooltip-helper.js +1 -1
  91. package/cjs/plugin/interface.js +1 -1
  92. package/cjs/series/base/tooltip-helper.d.ts +8 -7
  93. package/cjs/series/base/tooltip-helper.js +4 -4
  94. package/cjs/series/base/tooltip-helper.js.map +1 -1
  95. package/cjs/series/dot/tooltip-helper.js +2 -2
  96. package/cjs/series/dot/tooltip-helper.js.map +1 -1
  97. package/cjs/series/funnel/tooltip-helper.d.ts +5 -3
  98. package/cjs/series/funnel/tooltip-helper.js +8 -7
  99. package/cjs/series/funnel/tooltip-helper.js.map +1 -1
  100. package/cjs/series/interface/tooltip-helper.d.ts +6 -6
  101. package/cjs/series/interface/tooltip-helper.js.map +1 -1
  102. package/cjs/theme/buildin-theme/light/component/tooltip.js +1 -0
  103. package/cjs/theme/buildin-theme/light/component/tooltip.js.map +1 -1
  104. package/cjs/typings/tooltip/common.d.ts +7 -1
  105. package/cjs/typings/tooltip/common.js.map +1 -1
  106. package/cjs/typings/tooltip/handler.d.ts +1 -1
  107. package/cjs/typings/tooltip/handler.js.map +1 -1
  108. package/cjs/typings/tooltip/line.d.ts +6 -4
  109. package/cjs/typings/tooltip/line.js.map +1 -1
  110. package/cjs/typings/tooltip/shape.d.ts +3 -3
  111. package/cjs/typings/tooltip/shape.js.map +1 -1
  112. package/cjs/typings/tooltip/tooltip.d.ts +9 -8
  113. package/cjs/typings/tooltip/tooltip.js.map +1 -1
  114. package/esm/component/axis/cartesian/axis.js +3 -3
  115. package/esm/component/axis/cartesian/axis.js.map +1 -1
  116. package/esm/component/tooltip/handler/base.d.ts +5 -4
  117. package/esm/component/tooltip/handler/base.js +45 -35
  118. package/esm/component/tooltip/handler/base.js.map +1 -1
  119. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.d.ts +2 -2
  120. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.js +2 -3
  121. package/esm/component/tooltip/handler/canvas/canvas-tooltip-handler.js.map +1 -1
  122. package/esm/component/tooltip/handler/dom/constants.d.ts +2 -0
  123. package/esm/component/tooltip/handler/dom/constants.js +4 -0
  124. package/esm/component/tooltip/handler/dom/constants.js.map +1 -0
  125. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.d.ts +9 -3
  126. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.js +32 -12
  127. package/esm/component/tooltip/handler/dom/dom-tooltip-handler.js.map +1 -1
  128. package/esm/component/tooltip/handler/dom/interface.d.ts +16 -5
  129. package/esm/component/tooltip/handler/dom/interface.js.map +1 -1
  130. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.d.ts +7 -13
  131. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.js +11 -29
  132. package/esm/component/tooltip/handler/dom/model/base-tooltip-model.js.map +1 -1
  133. package/esm/component/tooltip/handler/dom/model/content-column-model.d.ts +13 -3
  134. package/esm/component/tooltip/handler/dom/model/content-column-model.js +42 -24
  135. package/esm/component/tooltip/handler/dom/model/content-column-model.js.map +1 -1
  136. package/esm/component/tooltip/handler/dom/model/content-model.d.ts +4 -3
  137. package/esm/component/tooltip/handler/dom/model/content-model.js +5 -5
  138. package/esm/component/tooltip/handler/dom/model/content-model.js.map +1 -1
  139. package/esm/component/tooltip/handler/dom/model/interface.d.ts +5 -0
  140. package/esm/component/tooltip/handler/dom/model/interface.js.map +1 -1
  141. package/esm/component/tooltip/handler/dom/model/shape-model.d.ts +5 -5
  142. package/esm/component/tooltip/handler/dom/model/shape-model.js +4 -4
  143. package/esm/component/tooltip/handler/dom/model/shape-model.js.map +1 -1
  144. package/esm/component/tooltip/handler/dom/model/style-constants.d.ts +4 -4
  145. package/esm/component/tooltip/handler/dom/model/style-constants.js +19 -18
  146. package/esm/component/tooltip/handler/dom/model/style-constants.js.map +1 -1
  147. package/esm/component/tooltip/handler/dom/model/text-model.js +1 -0
  148. package/esm/component/tooltip/handler/dom/model/text-model.js.map +1 -1
  149. package/esm/component/tooltip/handler/dom/model/title-model.d.ts +3 -2
  150. package/esm/component/tooltip/handler/dom/model/title-model.js +15 -19
  151. package/esm/component/tooltip/handler/dom/model/title-model.js.map +1 -1
  152. package/esm/component/tooltip/handler/dom/model/tooltip-model.d.ts +1 -2
  153. package/esm/component/tooltip/handler/dom/model/tooltip-model.js +21 -16
  154. package/esm/component/tooltip/handler/dom/model/tooltip-model.js.map +1 -1
  155. package/esm/component/tooltip/handler/dom/util.d.ts +5 -0
  156. package/esm/component/tooltip/handler/dom/util.js +71 -0
  157. package/esm/component/tooltip/handler/dom/util.js.map +1 -0
  158. package/esm/component/tooltip/handler/interface/index.d.ts +0 -1
  159. package/esm/component/tooltip/handler/interface/index.js +0 -2
  160. package/esm/component/tooltip/handler/interface/index.js.map +1 -1
  161. package/esm/component/tooltip/handler/utils/attribute.js +9 -6
  162. package/esm/component/tooltip/handler/utils/attribute.js.map +1 -1
  163. package/esm/component/tooltip/handler/utils/common.d.ts +6 -2
  164. package/esm/component/tooltip/handler/utils/common.js +12 -1
  165. package/esm/component/tooltip/handler/utils/common.js.map +1 -1
  166. package/esm/component/tooltip/handler/utils/compose.d.ts +3 -2
  167. package/esm/component/tooltip/handler/utils/compose.js +22 -35
  168. package/esm/component/tooltip/handler/utils/compose.js.map +1 -1
  169. package/esm/component/tooltip/handler/utils/get-spec.js +25 -19
  170. package/esm/component/tooltip/handler/utils/get-spec.js.map +1 -1
  171. package/esm/component/tooltip/handler/utils/style.d.ts +2 -1
  172. package/esm/component/tooltip/handler/utils/style.js +4 -4
  173. package/esm/component/tooltip/handler/utils/style.js.map +1 -1
  174. package/esm/component/tooltip/tooltip.d.ts +3 -1
  175. package/esm/component/tooltip/tooltip.js +33 -18
  176. package/esm/component/tooltip/tooltip.js.map +1 -1
  177. package/esm/constant/box-plot.js +2 -1
  178. package/esm/constant/scroll-bar.js +1 -2
  179. package/esm/core/instance-manager.d.ts +1 -1
  180. package/esm/core/instance-manager.js.map +1 -1
  181. package/esm/core/vchart.d.ts +1 -0
  182. package/esm/core/vchart.js +6 -0
  183. package/esm/core/vchart.js.map +1 -1
  184. package/esm/index.d.ts +1 -1
  185. package/esm/index.js +1 -1
  186. package/esm/index.js.map +1 -1
  187. package/esm/layout/layout3d/index.js +2 -2
  188. package/esm/layout/layout3d/index.js.map +1 -1
  189. package/esm/mark/area.js +2 -1
  190. package/esm/mark/cell.js +1 -1
  191. package/esm/mark/component.js +1 -1
  192. package/esm/mark/group.js +1 -1
  193. package/esm/mark/line.js +1 -1
  194. package/esm/mark/linkPath.js +1 -1
  195. package/esm/mark/path.js +1 -1
  196. package/esm/model/base-model.js +1 -1
  197. package/esm/model/interface.js +1 -1
  198. package/esm/model/layout-item.js +1 -1
  199. package/esm/model/model-state-manager.js +1 -2
  200. package/esm/model/tooltip-helper.js +1 -1
  201. package/esm/plugin/interface.js +1 -1
  202. package/esm/series/base/tooltip-helper.d.ts +8 -7
  203. package/esm/series/base/tooltip-helper.js +4 -4
  204. package/esm/series/base/tooltip-helper.js.map +1 -1
  205. package/esm/series/dot/tooltip-helper.js +2 -2
  206. package/esm/series/dot/tooltip-helper.js.map +1 -1
  207. package/esm/series/funnel/tooltip-helper.d.ts +5 -3
  208. package/esm/series/funnel/tooltip-helper.js +8 -5
  209. package/esm/series/funnel/tooltip-helper.js.map +1 -1
  210. package/esm/series/interface/tooltip-helper.d.ts +6 -6
  211. package/esm/series/interface/tooltip-helper.js.map +1 -1
  212. package/esm/theme/buildin-theme/light/component/tooltip.js +1 -0
  213. package/esm/theme/buildin-theme/light/component/tooltip.js.map +1 -1
  214. package/esm/typings/tooltip/common.d.ts +7 -1
  215. package/esm/typings/tooltip/common.js.map +1 -1
  216. package/esm/typings/tooltip/handler.d.ts +1 -1
  217. package/esm/typings/tooltip/handler.js.map +1 -1
  218. package/esm/typings/tooltip/line.d.ts +6 -4
  219. package/esm/typings/tooltip/line.js.map +1 -1
  220. package/esm/typings/tooltip/shape.d.ts +3 -3
  221. package/esm/typings/tooltip/shape.js.map +1 -1
  222. package/esm/typings/tooltip/tooltip.d.ts +9 -8
  223. package/esm/typings/tooltip/tooltip.js.map +1 -1
  224. package/package.json +3 -3
  225. package/README.zh-CN.md +0 -1
  226. package/cjs/component/tooltip/handler/dom/utils/style.d.ts +0 -3
  227. package/cjs/component/tooltip/handler/dom/utils/style.js.map +0 -1
  228. package/cjs/component/tooltip/handler/interface/cache.d.ts +0 -28
  229. package/cjs/component/tooltip/handler/interface/cache.js +0 -6
  230. package/cjs/component/tooltip/handler/interface/cache.js.map +0 -1
  231. package/esm/component/tooltip/handler/dom/utils/style.d.ts +0 -3
  232. package/esm/component/tooltip/handler/dom/utils/style.js +0 -59
  233. package/esm/component/tooltip/handler/dom/utils/style.js.map +0 -1
  234. package/esm/component/tooltip/handler/interface/cache.d.ts +0 -28
  235. package/esm/component/tooltip/handler/interface/cache.js +0 -2
  236. package/esm/component/tooltip/handler/interface/cache.js.map +0 -1
@@ -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, IToolTipLineActual } 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';\nimport { TOOLTIP_MAX_COUNT } from './constants';\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 _renderContent: IToolTipLineActual[];\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 getRenderContent: () => this._renderContent\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._updateTooltipActual(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 protected _updateTooltipActual(actualTooltip: IToolTipActual) {\n this._tooltipActual = actualTooltip;\n\n // 计算 renderContent\n if (!this._tooltipActual) {\n this._renderContent = [];\n } else {\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 // TODO: i18n\n key: '其他',\n value: '...'\n };\n }\n this._renderContent = renderContent;\n }\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 | HTMLTitleElement | HTMLLabelElement | HTMLAreaElement | HTMLSelectElement | HTMLTimeElement | HTMLMapElement | HTMLDataElement | HTMLStyleElement | HTMLSourceElement | HTMLInputElement | HTMLLegendElement | HTMLAnchorElement | HTMLTrackElement | 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
  }
@@ -1,35 +1,25 @@
1
- export const TOOLTIP_MAX_COUNT = 20;
2
-
3
- export const TOOLTIP_EMPTY_STRING = "";
4
-
5
1
  export const domDocument = globalThis.document;
6
2
 
7
3
  export class BaseTooltipModel {
8
4
  static isInstance(obj) {
9
5
  return !!obj && obj.type === BaseTooltipModel.type;
10
6
  }
11
- setTooltipActual(tooltipActual) {
12
- this._tooltipActual = tooltipActual, this._renderContentCache = null, this.init(),
13
- Object.values(this.children).forEach((c => c.setTooltipActual(tooltipActual)));
14
- }
15
- setTooltipStyle(tooltipStyle) {
16
- this._tooltipStyle = tooltipStyle, this.init(), Object.values(this.children).forEach((c => c.setTooltipStyle(tooltipStyle)));
17
- }
18
7
  setOption(option) {
19
8
  this._option = option, Object.values(this.children).forEach((c => c.setOption(option)));
20
9
  }
21
10
  getParentEl() {
22
11
  return BaseTooltipModel.isInstance(this.parent) ? this.parent.product : this.parent;
23
12
  }
24
- constructor(parent, option, childIndex, tooltipStyle, tooltipActual) {
25
- this.type = BaseTooltipModel.type, this._tooltipActual = null, this._tooltipStyle = null,
26
- this._renderContentCache = null, this.children = {}, this.parent = parent, this._option = option,
27
- this.childIndex = null != childIndex ? childIndex : 0, this._tooltipStyle = tooltipStyle,
28
- this._tooltipActual = tooltipActual;
13
+ constructor(parent, option, childIndex) {
14
+ this.type = BaseTooltipModel.type, this._renderContentCache = null, this.children = {},
15
+ this.parent = parent, this._option = option, this.childIndex = null != childIndex ? childIndex : 0;
29
16
  }
30
17
  init(classList, id) {}
18
+ initAll() {
19
+ this.init(), Object.values(this.children).forEach((c => c.initAll()));
20
+ }
31
21
  setStyle(style) {
32
- style && Object.keys(style).forEach((key => {
22
+ this.product && style && Object.keys(style).forEach((key => {
33
23
  this.product.style[key] !== style[key] && (this.product.style[key] = style[key]);
34
24
  }));
35
25
  }
@@ -44,15 +34,16 @@ export class BaseTooltipModel {
44
34
  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;
45
35
  }
46
36
  release() {
47
- Object.values(this.children).forEach((c => c.release())), this.children = {}, this.product && (this.getParentEl().removeChild(this.product),
37
+ var _a;
38
+ Object.values(this.children).forEach((c => c.release())), this.children = {}, this.product && (null === (_a = this.getParentEl()) || void 0 === _a || _a.removeChild(this.product),
48
39
  this.product = null);
49
40
  }
50
41
  createElement(tag, classList, style, id) {
51
- const element = domDocument.createElement(tag);
42
+ const element = null == domDocument ? void 0 : domDocument.createElement(tag), parentEl = this.getParentEl();
43
+ if (!element || !parentEl) return;
52
44
  classList && element.classList.add(...classList), style && Object.keys(style).forEach((key => {
53
45
  element.style[key] = style[key];
54
46
  })), id && (element.id = id);
55
- const parentEl = this.getParentEl();
56
47
  let ptr = this.childIndex;
57
48
  if (BaseTooltipModel.isInstance(this.parent)) {
58
49
  let nextChildIndex = Number.MAX_VALUE;
@@ -65,15 +56,6 @@ export class BaseTooltipModel {
65
56
  return ptr >= parentEl.children.length ? parentEl.appendChild(element) : parentEl.insertBefore(element, parentEl.children[ptr]),
66
57
  element;
67
58
  }
68
- getRenderContent() {
69
- if (!this._tooltipActual) return [];
70
- if (this._renderContentCache) return this._renderContentCache;
71
- const {content: originContent = []} = this._tooltipActual, renderContent = originContent.slice(0, 20);
72
- return (null == renderContent ? void 0 : renderContent[19]) && (renderContent[19] = Object.assign(Object.assign({}, renderContent[19]), {
73
- key: "其他",
74
- value: "..."
75
- })), renderContent;
76
- }
77
59
  }
78
60
 
79
61
  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
  }
@@ -1,31 +1,33 @@
1
1
  import { isNumber, isString, merge, toNumber } from "@visactor/vutils";
2
2
 
3
- import { defaultKeyStyle, defaultShapeBoxStyle, defaultValueStyle } from "./style-constants";
3
+ import { defaultKeyStyle, defaultContentColumnStyle, defaultValueStyle, defaultAdaptiveKeyStyle } from "./style-constants";
4
4
 
5
- import { BaseTooltipModel, TOOLTIP_EMPTY_STRING } from "./base-tooltip-model";
5
+ import { BaseTooltipModel } from "./base-tooltip-model";
6
6
 
7
7
  import { ShapeModel } from "./shape-model";
8
8
 
9
9
  import { TextModel } from "./text-model";
10
10
 
11
+ import { TOOLTIP_EMPTY_STRING } from "../constants";
12
+
11
13
  export class ContentColumnModel extends BaseTooltipModel {
12
- constructor(parent, option, className, childIndex, tooltipStyle, tooltipActual) {
13
- super(parent, option, childIndex, tooltipStyle, tooltipActual), this.className = className;
14
+ constructor(parent, option, className, childIndex) {
15
+ super(parent, option, childIndex), this.className = className;
14
16
  }
15
17
  init() {
16
18
  this.product || (this.product = this.createElement("div", [ this.className ]));
17
- const renderContent = this.getRenderContent();
19
+ const renderContent = this._option.getRenderContent();
18
20
  if ("shape-box" !== this.className || renderContent.some((c => c.hasShape && c.shapeType))) {
19
21
  Object.keys(this.children).forEach((key => {
20
22
  const i = toNumber(key);
21
23
  i >= renderContent.length && (this.children[i].release(), delete this.children[i]);
22
24
  }));
23
25
  for (let i = 0; i < renderContent.length; i++) if (!this.children[i]) if ("key-box" === this.className || "value-box" === this.className) {
24
- const text = new TextModel(this.product, this._option, i, this._tooltipStyle, this._tooltipActual);
26
+ const text = new TextModel(this.product, this._option, i);
25
27
  text.init([ this.className.substring(0, this.className.indexOf("-")) ], void 0, "div"),
26
28
  this.children[i] = text;
27
29
  } else if ("shape-box" === this.className) {
28
- const shape = new ShapeModel(this.product, this._option, i, this._tooltipStyle, this._tooltipActual);
30
+ const shape = new ShapeModel(this.product, this._option, i);
29
31
  shape.init([ "shape" ], void 0, "div"), this.children[i] = shape;
30
32
  }
31
33
  } else Object.keys(this.children).forEach((key => {
@@ -34,38 +36,38 @@ export class ContentColumnModel extends BaseTooltipModel {
34
36
  }));
35
37
  }
36
38
  setStyle() {
37
- if (!this._tooltipStyle) return;
38
- super.setStyle(merge({}, defaultShapeBoxStyle, this._tooltipStyle.content));
39
- const renderContent = this.getRenderContent();
39
+ const tooltipStyle = this._option.getTooltipStyle();
40
+ super.setStyle(merge({}, defaultContentColumnStyle, tooltipStyle.content, this._getContentColumnStyle()));
41
+ const renderContent = this._option.getRenderContent();
40
42
  renderContent.forEach(((line, i) => {
41
- var _a, _b;
43
+ var _a, _b, _c;
42
44
  let childStyle = {};
43
45
  if ("key-box" === this.className) {
44
- const keyContent = line.key;
45
- childStyle = merge({}, defaultKeyStyle, Object.assign({
46
+ const {key: key, isKeyAdaptive: isKeyAdaptive} = line;
47
+ childStyle = merge({}, isKeyAdaptive ? defaultAdaptiveKeyStyle : defaultKeyStyle, Object.assign({
46
48
  height: 100 / renderContent.length + "%"
47
- }, this._tooltipStyle.content.key));
48
- isString(keyContent) && "" !== (null === (_a = null == keyContent ? void 0 : keyContent.trim) || void 0 === _a ? void 0 : _a.call(keyContent)) || isNumber(keyContent) || childStyle.visibility ? childStyle.visibility = "visible" : childStyle.visibility = "hidden",
49
+ }, tooltipStyle.keyColumn.item));
50
+ isString(key) && "" !== (null === (_a = null == key ? void 0 : key.trim) || void 0 === _a ? void 0 : _a.call(key)) || isNumber(key) || childStyle.visibility ? childStyle.visibility = "visible" : childStyle.visibility = "hidden",
49
51
  this.children[i].setStyle(childStyle);
50
52
  } else if ("value-box" === this.className) childStyle = merge({}, defaultValueStyle, Object.assign({
51
53
  height: 100 / renderContent.length + "%"
52
- }, this._tooltipStyle.content.value)), this.children[i].setStyle(childStyle); else if ("shape-box" === this.className) {
53
- childStyle = this._tooltipStyle.content.shape;
54
+ }, tooltipStyle.valueColumn.item)), this.children[i].setStyle(childStyle); else if ("shape-box" === this.className) {
55
+ childStyle = tooltipStyle.shapeColumn.item;
54
56
  const childContent = {
55
57
  hasShape: line.hasShape,
56
58
  shapeType: line.shapeType,
57
- size: this._tooltipStyle.content.shape.width,
59
+ size: null === (_b = tooltipStyle.shapeColumn.item) || void 0 === _b ? void 0 : _b.width,
58
60
  color: line.shapeColor,
59
61
  hollow: line.shapeHollow
60
62
  };
61
- null === (_b = this.children[i]) || void 0 === _b || _b.setStyle(childStyle, childContent);
63
+ null === (_c = this.children[i]) || void 0 === _c || _c.setStyle(childStyle, childContent);
62
64
  }
63
65
  }));
64
66
  }
65
67
  setContent() {
66
- if (!this._tooltipStyle) return;
67
- this.getRenderContent().forEach(((line, i) => {
68
- var _a, _b, _c;
68
+ const tooltipStyle = this._option.getTooltipStyle();
69
+ this._option.getRenderContent().forEach(((line, i) => {
70
+ var _a, _b, _c, _d;
69
71
  let childContent;
70
72
  if ("key-box" === this.className) {
71
73
  const keyContent = line.key;
@@ -76,12 +78,28 @@ export class ContentColumnModel extends BaseTooltipModel {
76
78
  } else "shape-box" === this.className && (childContent = {
77
79
  hasShape: line.hasShape,
78
80
  shapeType: line.shapeType,
79
- size: this._tooltipStyle.content.shape.width,
81
+ size: null === (_c = tooltipStyle.shapeColumn.item) || void 0 === _c ? void 0 : _c.width,
80
82
  color: line.shapeColor,
81
83
  hollow: line.shapeHollow
82
84
  });
83
- null === (_c = this.children[i]) || void 0 === _c || _c.setContent(childContent);
85
+ null === (_d = this.children[i]) || void 0 === _d || _d.setContent(childContent);
84
86
  }));
85
87
  }
88
+ _getContentColumnStyle() {
89
+ const tooltipStyle = this._option.getTooltipStyle();
90
+ switch (this.className) {
91
+ case "shape-box":
92
+ const renderContent = this._option.getRenderContent();
93
+ return Object.assign(Object.assign({}, tooltipStyle.shapeColumn), "shape-box" !== this.className || renderContent.some((c => c.hasShape && c.shapeType)) ? {} : {
94
+ display: "none"
95
+ });
96
+
97
+ case "key-box":
98
+ return tooltipStyle.keyColumn;
99
+
100
+ case "value-box":
101
+ return tooltipStyle.valueColumn;
102
+ }
103
+ }
86
104
  }
87
105
  //# sourceMappingURL=content-column-model.js.map
@@ -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.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);\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.getRenderContent();\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.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: 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.getRenderContent();\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;
@@ -1,4 +1,4 @@
1
- import { defaultContainerBoxStyle } from "./style-constants";
1
+ import { defaultContentContainerStyle } from "./style-constants";
2
2
 
3
3
  import { BaseTooltipModel } from "./base-tooltip-model";
4
4
 
@@ -12,19 +12,19 @@ export class ContentModel extends BaseTooltipModel {
12
12
  this.shapeBox || this._initShapeBox(), this.keyBox || this._initKeyBox(), this.valueBox || this._initValueBox();
13
13
  }
14
14
  _initShapeBox() {
15
- const shapeBox = new ContentColumnModel(this.product, this._option, "shape-box", 0, this._tooltipStyle, this._tooltipActual);
15
+ const shapeBox = new 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 ContentColumnModel(this.product, this._option, "key-box", 1, this._tooltipStyle, this._tooltipActual);
19
+ const keyBox = new 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 ContentColumnModel(this.product, this._option, "value-box", 2, this._tooltipStyle, this._tooltipActual);
23
+ const valueBox = new 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(merge({}, defaultContainerBoxStyle, style)), Object.values(this.children).forEach((c => {
27
+ super.setStyle(merge({}, defaultContentContainerStyle, style)), Object.values(this.children).forEach((c => {
28
28
  c.setStyle();
29
29
  }));
30
30
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/component/tooltip/handler/dom/model/content-model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzC,MAAM,OAAO,YAAa,SAAQ,gBAAgB;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,kBAAkB,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,kBAAkB,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,kBAAkB,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,KAAK,CAAC,EAAE,EAAE,wBAAwB,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","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,OAAO,EAAE,4BAA4B,EAAE,MAAM,mBAAmB,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAG5D,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzC,MAAM,OAAO,YAAa,SAAQ,gBAAgB;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,kBAAkB,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,kBAAkB,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,kBAAkB,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,KAAK,CAAC,EAAE,EAAE,4BAA4B,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","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,8 @@
1
+ import type { IToolTipActual, IToolTipLineActual } 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;
7
+ getRenderContent: () => IToolTipLineActual[];
3
8
  }
@@ -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, IToolTipLineActual } from '../../../../../typings';\nimport type { IDomTooltipStyle } from '../interface';\n\nexport interface ITooltipModelOption {\n valueToHtml: (value: any) => string;\n getTooltipStyle: () => IDomTooltipStyle;\n getTooltipActual: () => IToolTipActual;\n getRenderContent: () => IToolTipLineActual[];\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
  }
@@ -19,7 +19,7 @@ export class ShapeModel extends BaseTooltipModel {
19
19
  }
20
20
  setSvg(option) {
21
21
  const html = getSvgHtml(option);
22
- html !== this._svgHtmlCache && (this._svgHtmlCache = html, this.product.innerHTML = html);
22
+ this.product && html !== this._svgHtmlCache && (this._svgHtmlCache = html, this.product.innerHTML = html);
23
23
  }
24
24
  release() {
25
25
  super.release(), this._svgHtmlCache = "";
@@ -28,16 +28,16 @@ export class ShapeModel extends BaseTooltipModel {
28
28
 
29
29
  function getSvgHtml(option) {
30
30
  var _a, _b, _c, _d, _e, _f, _g;
31
- if (!(null == option ? void 0 : option.hasShape) || !builtinSymbolsMap[option.shapeType]) return "";
31
+ if (!(null == option ? void 0 : option.hasShape) || !option.shapeType || !builtinSymbolsMap[option.shapeType]) return "";
32
32
  const {shapeType: shapeType, size: size, color: color, hollow: hollow = !1} = option, path = builtinSymbolsMap[shapeType].pathStr;
33
33
  let fill = "currentColor";
34
34
  if (!color || isString(color) || hollow) return fill = hollow ? "none" : null !== (_a = color) && void 0 !== _a ? _a : "currentColor",
35
- `\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>`;
35
+ `\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>`;
36
36
  if (isObject(color)) {
37
37
  fill = "gradientColor";
38
38
  let gradient = "";
39
39
  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 `),
40
- `\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>`;
40
+ `\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>`;
41
41
  }
42
42
  return "";
43
43
  }