@visactor/vrender-components 0.0.38-brush.2-alpha.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 (736) hide show
  1. package/README.md +9 -0
  2. package/cjs/axis/animate/group-fade.d.ts +17 -0
  3. package/cjs/axis/animate/group-fade.js +72 -0
  4. package/cjs/axis/animate/group-fade.js.map +1 -0
  5. package/cjs/axis/animate/group-transition.d.ts +10 -0
  6. package/cjs/axis/animate/group-transition.js +76 -0
  7. package/cjs/axis/animate/group-transition.js.map +1 -0
  8. package/cjs/axis/animate/index.d.ts +2 -0
  9. package/cjs/axis/animate/index.js +21 -0
  10. package/cjs/axis/animate/index.js.map +1 -0
  11. package/cjs/axis/base.d.ts +53 -0
  12. package/cjs/axis/base.js +305 -0
  13. package/cjs/axis/base.js.map +1 -0
  14. package/cjs/axis/circle.d.ts +88 -0
  15. package/cjs/axis/circle.js +182 -0
  16. package/cjs/axis/circle.js.map +1 -0
  17. package/cjs/axis/config.d.ts +71 -0
  18. package/cjs/axis/config.js +76 -0
  19. package/cjs/axis/config.js.map +1 -0
  20. package/cjs/axis/constant.d.ts +27 -0
  21. package/cjs/axis/constant.js +26 -0
  22. package/cjs/axis/constant.js.map +1 -0
  23. package/cjs/axis/grid.d.ts +9 -0
  24. package/cjs/axis/grid.js +106 -0
  25. package/cjs/axis/grid.js.map +1 -0
  26. package/cjs/axis/index.d.ts +6 -0
  27. package/cjs/axis/index.js +23 -0
  28. package/cjs/axis/index.js.map +1 -0
  29. package/cjs/axis/line.d.ts +89 -0
  30. package/cjs/axis/line.js +199 -0
  31. package/cjs/axis/line.js.map +1 -0
  32. package/cjs/axis/type.d.ts +177 -0
  33. package/cjs/axis/type.js +6 -0
  34. package/cjs/axis/type.js.map +1 -0
  35. package/cjs/brush/brush.d.ts +65 -0
  36. package/cjs/brush/brush.js +169 -0
  37. package/cjs/brush/brush.js.map +1 -0
  38. package/cjs/brush/config.d.ts +21 -0
  39. package/cjs/brush/config.js +26 -0
  40. package/cjs/brush/config.js.map +1 -0
  41. package/cjs/brush/index.d.ts +2 -0
  42. package/cjs/brush/index.js +21 -0
  43. package/cjs/brush/index.js.map +1 -0
  44. package/cjs/brush/type.d.ts +21 -0
  45. package/cjs/brush/type.js +6 -0
  46. package/cjs/brush/type.js.map +1 -0
  47. package/cjs/constant.d.ts +16 -0
  48. package/cjs/constant.js +18 -0
  49. package/cjs/constant.js.map +1 -0
  50. package/cjs/core/base.d.ts +12 -0
  51. package/cjs/core/base.js +44 -0
  52. package/cjs/core/base.js.map +1 -0
  53. package/cjs/core/type.d.ts +28 -0
  54. package/cjs/core/type.js +5 -0
  55. package/cjs/core/type.js.map +1 -0
  56. package/cjs/crosshair/base.d.ts +10 -0
  57. package/cjs/crosshair/base.js +19 -0
  58. package/cjs/crosshair/base.js.map +1 -0
  59. package/cjs/crosshair/circle.d.ts +17 -0
  60. package/cjs/crosshair/circle.js +33 -0
  61. package/cjs/crosshair/circle.js.map +1 -0
  62. package/cjs/crosshair/index.d.ts +6 -0
  63. package/cjs/crosshair/index.js +23 -0
  64. package/cjs/crosshair/index.js.map +1 -0
  65. package/cjs/crosshair/line.d.ts +17 -0
  66. package/cjs/crosshair/line.js +36 -0
  67. package/cjs/crosshair/line.js.map +1 -0
  68. package/cjs/crosshair/polygon.d.ts +17 -0
  69. package/cjs/crosshair/polygon.js +39 -0
  70. package/cjs/crosshair/polygon.js.map +1 -0
  71. package/cjs/crosshair/rect.d.ts +20 -0
  72. package/cjs/crosshair/rect.js +37 -0
  73. package/cjs/crosshair/rect.js.map +1 -0
  74. package/cjs/crosshair/sector.d.ts +15 -0
  75. package/cjs/crosshair/sector.js +38 -0
  76. package/cjs/crosshair/sector.js.map +1 -0
  77. package/cjs/crosshair/type.d.ts +37 -0
  78. package/cjs/crosshair/type.js +6 -0
  79. package/cjs/crosshair/type.js.map +1 -0
  80. package/cjs/data-zoom/config.d.ts +104 -0
  81. package/cjs/data-zoom/config.js +109 -0
  82. package/cjs/data-zoom/config.js.map +1 -0
  83. package/cjs/data-zoom/data-zoom.d.ts +193 -0
  84. package/cjs/data-zoom/data-zoom.js +447 -0
  85. package/cjs/data-zoom/data-zoom.js.map +1 -0
  86. package/cjs/data-zoom/index.d.ts +2 -0
  87. package/cjs/data-zoom/index.js +21 -0
  88. package/cjs/data-zoom/index.js.map +1 -0
  89. package/cjs/data-zoom/type.d.ts +59 -0
  90. package/cjs/data-zoom/type.js +6 -0
  91. package/cjs/data-zoom/type.js.map +1 -0
  92. package/cjs/index.d.ts +20 -0
  93. package/cjs/index.js +30 -0
  94. package/cjs/index.js.map +1 -0
  95. package/cjs/indicator/config.d.ts +2 -0
  96. package/cjs/indicator/config.js +31 -0
  97. package/cjs/indicator/config.js.map +1 -0
  98. package/cjs/indicator/index.d.ts +2 -0
  99. package/cjs/indicator/index.js +21 -0
  100. package/cjs/indicator/index.js.map +1 -0
  101. package/cjs/indicator/indicator.d.ts +9 -0
  102. package/cjs/indicator/indicator.js +73 -0
  103. package/cjs/indicator/indicator.js.map +1 -0
  104. package/cjs/indicator/type.d.ts +21 -0
  105. package/cjs/indicator/type.js +5 -0
  106. package/cjs/indicator/type.js.map +1 -0
  107. package/cjs/interface.d.ts +6 -0
  108. package/cjs/interface.js +6 -0
  109. package/cjs/interface.js.map +1 -0
  110. package/cjs/label/animate/animate.d.ts +7 -0
  111. package/cjs/label/animate/animate.js +53 -0
  112. package/cjs/label/animate/animate.js.map +1 -0
  113. package/cjs/label/animate/index.d.ts +1 -0
  114. package/cjs/label/animate/index.js +3 -0
  115. package/cjs/label/animate/index.js.map +1 -0
  116. package/cjs/label/base.d.ts +43 -0
  117. package/cjs/label/base.js +263 -0
  118. package/cjs/label/base.js.map +1 -0
  119. package/cjs/label/dataLabel.d.ts +13 -0
  120. package/cjs/label/dataLabel.js +56 -0
  121. package/cjs/label/dataLabel.js.map +1 -0
  122. package/cjs/label/index.d.ts +6 -0
  123. package/cjs/label/index.js +23 -0
  124. package/cjs/label/index.js.map +1 -0
  125. package/cjs/label/line.d.ts +15 -0
  126. package/cjs/label/line.js +47 -0
  127. package/cjs/label/line.js.map +1 -0
  128. package/cjs/label/overlap/bitmap.d.ts +13 -0
  129. package/cjs/label/overlap/bitmap.js +73 -0
  130. package/cjs/label/overlap/bitmap.js.map +1 -0
  131. package/cjs/label/overlap/index.d.ts +3 -0
  132. package/cjs/label/overlap/index.js +22 -0
  133. package/cjs/label/overlap/index.js.map +1 -0
  134. package/cjs/label/overlap/place.d.ts +14 -0
  135. package/cjs/label/overlap/place.js +61 -0
  136. package/cjs/label/overlap/place.js.map +1 -0
  137. package/cjs/label/overlap/scaler.d.ts +27 -0
  138. package/cjs/label/overlap/scaler.js +26 -0
  139. package/cjs/label/overlap/scaler.js.map +1 -0
  140. package/cjs/label/rect.d.ts +10 -0
  141. package/cjs/label/rect.js +59 -0
  142. package/cjs/label/rect.js.map +1 -0
  143. package/cjs/label/symbol.d.ts +10 -0
  144. package/cjs/label/symbol.js +69 -0
  145. package/cjs/label/symbol.js.map +1 -0
  146. package/cjs/label/type.d.ts +90 -0
  147. package/cjs/label/type.js +6 -0
  148. package/cjs/label/type.js.map +1 -0
  149. package/cjs/legend/base.d.ts +14 -0
  150. package/cjs/legend/base.js +58 -0
  151. package/cjs/legend/base.js.map +1 -0
  152. package/cjs/legend/color/color.d.ts +37 -0
  153. package/cjs/legend/color/color.js +128 -0
  154. package/cjs/legend/color/color.js.map +1 -0
  155. package/cjs/legend/color/index.d.ts +2 -0
  156. package/cjs/legend/color/index.js +21 -0
  157. package/cjs/legend/color/index.js.map +1 -0
  158. package/cjs/legend/color/type.d.ts +5 -0
  159. package/cjs/legend/color/type.js +6 -0
  160. package/cjs/legend/color/type.js.map +1 -0
  161. package/cjs/legend/constant.d.ts +29 -0
  162. package/cjs/legend/constant.js +24 -0
  163. package/cjs/legend/constant.js.map +1 -0
  164. package/cjs/legend/discrete/discrete.d.ts +26 -0
  165. package/cjs/legend/discrete/discrete.js +413 -0
  166. package/cjs/legend/discrete/discrete.js.map +1 -0
  167. package/cjs/legend/discrete/index.d.ts +2 -0
  168. package/cjs/legend/discrete/index.js +21 -0
  169. package/cjs/legend/discrete/index.js.map +1 -0
  170. package/cjs/legend/discrete/type.d.ts +65 -0
  171. package/cjs/legend/discrete/type.js +6 -0
  172. package/cjs/legend/discrete/type.js.map +1 -0
  173. package/cjs/legend/index.d.ts +8 -0
  174. package/cjs/legend/index.js +24 -0
  175. package/cjs/legend/index.js.map +1 -0
  176. package/cjs/legend/size/index.d.ts +1 -0
  177. package/cjs/legend/size/index.js +3 -0
  178. package/cjs/legend/size/index.js.map +1 -0
  179. package/cjs/legend/size/size.d.ts +34 -0
  180. package/cjs/legend/size/size.js +106 -0
  181. package/cjs/legend/size/size.js.map +1 -0
  182. package/cjs/legend/size/type.d.ts +6 -0
  183. package/cjs/legend/size/type.js +6 -0
  184. package/cjs/legend/size/type.js.map +1 -0
  185. package/cjs/legend/type.d.ts +27 -0
  186. package/cjs/legend/type.js +6 -0
  187. package/cjs/legend/type.js.map +1 -0
  188. package/cjs/link-path/index.d.ts +2 -0
  189. package/cjs/link-path/index.js +21 -0
  190. package/cjs/link-path/index.js.map +1 -0
  191. package/cjs/link-path/link-path.d.ts +15 -0
  192. package/cjs/link-path/link-path.js +65 -0
  193. package/cjs/link-path/link-path.js.map +1 -0
  194. package/cjs/link-path/type.d.ts +17 -0
  195. package/cjs/link-path/type.js +6 -0
  196. package/cjs/link-path/type.js.map +1 -0
  197. package/cjs/marker/area.d.ts +56 -0
  198. package/cjs/marker/area.js +64 -0
  199. package/cjs/marker/area.js.map +1 -0
  200. package/cjs/marker/base.d.ts +11 -0
  201. package/cjs/marker/base.js +22 -0
  202. package/cjs/marker/base.js.map +1 -0
  203. package/cjs/marker/config.d.ts +154 -0
  204. package/cjs/marker/config.js +240 -0
  205. package/cjs/marker/config.js.map +1 -0
  206. package/cjs/marker/index.d.ts +4 -0
  207. package/cjs/marker/index.js +22 -0
  208. package/cjs/marker/index.js.map +1 -0
  209. package/cjs/marker/line.d.ts +10 -0
  210. package/cjs/marker/line.js +45 -0
  211. package/cjs/marker/line.js.map +1 -0
  212. package/cjs/marker/point.d.ts +80 -0
  213. package/cjs/marker/point.js +102 -0
  214. package/cjs/marker/point.js.map +1 -0
  215. package/cjs/marker/type.d.ts +93 -0
  216. package/cjs/marker/type.js +26 -0
  217. package/cjs/marker/type.js.map +1 -0
  218. package/cjs/pager/index.d.ts +2 -0
  219. package/cjs/pager/index.js +21 -0
  220. package/cjs/pager/index.js.map +1 -0
  221. package/cjs/pager/pager.d.ts +20 -0
  222. package/cjs/pager/pager.js +132 -0
  223. package/cjs/pager/pager.js.map +1 -0
  224. package/cjs/pager/type.d.ts +19 -0
  225. package/cjs/pager/type.js +6 -0
  226. package/cjs/pager/type.js.map +1 -0
  227. package/cjs/player/base-player.d.ts +103 -0
  228. package/cjs/player/base-player.js +199 -0
  229. package/cjs/player/base-player.js.map +1 -0
  230. package/cjs/player/constant.d.ts +12 -0
  231. package/cjs/player/constant.js +16 -0
  232. package/cjs/player/constant.js.map +1 -0
  233. package/cjs/player/continuous-player.d.ts +34 -0
  234. package/cjs/player/continuous-player.js +107 -0
  235. package/cjs/player/continuous-player.js.map +1 -0
  236. package/cjs/player/controller/assets/index.d.ts +6 -0
  237. package/cjs/player/controller/assets/index.js +12 -0
  238. package/cjs/player/controller/assets/index.js.map +1 -0
  239. package/cjs/player/controller/constant.d.ts +12 -0
  240. package/cjs/player/controller/constant.js +15 -0
  241. package/cjs/player/controller/constant.js.map +1 -0
  242. package/cjs/player/controller/controller.d.ts +32 -0
  243. package/cjs/player/controller/controller.js +93 -0
  244. package/cjs/player/controller/controller.js.map +1 -0
  245. package/cjs/player/controller/icon/icon.d.ts +4 -0
  246. package/cjs/player/controller/icon/icon.js +16 -0
  247. package/cjs/player/controller/icon/icon.js.map +1 -0
  248. package/cjs/player/controller/icon/index.d.ts +1 -0
  249. package/cjs/player/controller/icon/index.js +21 -0
  250. package/cjs/player/controller/icon/index.js.map +1 -0
  251. package/cjs/player/controller/icon/type.d.ts +1 -0
  252. package/cjs/player/controller/icon/type.js +3 -0
  253. package/cjs/player/controller/icon/type.js.map +1 -0
  254. package/cjs/player/controller/index.d.ts +2 -0
  255. package/cjs/player/controller/index.js +21 -0
  256. package/cjs/player/controller/index.js.map +1 -0
  257. package/cjs/player/controller/type.d.ts +11 -0
  258. package/cjs/player/controller/type.js +6 -0
  259. package/cjs/player/controller/type.js.map +1 -0
  260. package/cjs/player/discrete-player.d.ts +32 -0
  261. package/cjs/player/discrete-player.js +85 -0
  262. package/cjs/player/discrete-player.js.map +1 -0
  263. package/cjs/player/index.d.ts +4 -0
  264. package/cjs/player/index.js +22 -0
  265. package/cjs/player/index.js.map +1 -0
  266. package/cjs/player/type/base.d.ts +7 -0
  267. package/cjs/player/type/base.js +6 -0
  268. package/cjs/player/type/base.js.map +1 -0
  269. package/cjs/player/type/continuous-player.d.ts +7 -0
  270. package/cjs/player/type/continuous-player.js +6 -0
  271. package/cjs/player/type/continuous-player.js.map +1 -0
  272. package/cjs/player/type/direction.d.ts +5 -0
  273. package/cjs/player/type/direction.js +10 -0
  274. package/cjs/player/type/direction.js.map +1 -0
  275. package/cjs/player/type/discrete-player.d.ts +9 -0
  276. package/cjs/player/type/discrete-player.js +6 -0
  277. package/cjs/player/type/discrete-player.js.map +1 -0
  278. package/cjs/player/type/event.d.ts +8 -0
  279. package/cjs/player/type/event.js +12 -0
  280. package/cjs/player/type/event.js.map +1 -0
  281. package/cjs/player/type/index.d.ts +9 -0
  282. package/cjs/player/type/index.js +23 -0
  283. package/cjs/player/type/index.js.map +1 -0
  284. package/cjs/player/type/layout.d.ts +35 -0
  285. package/cjs/player/type/layout.js +6 -0
  286. package/cjs/player/type/layout.js.map +1 -0
  287. package/cjs/player/utils.d.ts +20 -0
  288. package/cjs/player/utils.js +74 -0
  289. package/cjs/player/utils.js.map +1 -0
  290. package/cjs/scrollbar/index.d.ts +2 -0
  291. package/cjs/scrollbar/index.js +21 -0
  292. package/cjs/scrollbar/index.js.map +1 -0
  293. package/cjs/scrollbar/scrollbar.d.ts +43 -0
  294. package/cjs/scrollbar/scrollbar.js +161 -0
  295. package/cjs/scrollbar/scrollbar.js.map +1 -0
  296. package/cjs/scrollbar/type.d.ts +16 -0
  297. package/cjs/scrollbar/type.js +6 -0
  298. package/cjs/scrollbar/type.js.map +1 -0
  299. package/cjs/segment/index.d.ts +2 -0
  300. package/cjs/segment/index.js +21 -0
  301. package/cjs/segment/index.js.map +1 -0
  302. package/cjs/segment/segment.d.ts +18 -0
  303. package/cjs/segment/segment.js +105 -0
  304. package/cjs/segment/segment.js.map +1 -0
  305. package/cjs/segment/type.d.ts +22 -0
  306. package/cjs/segment/type.js +6 -0
  307. package/cjs/segment/type.js.map +1 -0
  308. package/cjs/slider/constant.d.ts +13 -0
  309. package/cjs/slider/constant.js +15 -0
  310. package/cjs/slider/constant.js.map +1 -0
  311. package/cjs/slider/index.d.ts +3 -0
  312. package/cjs/slider/index.js +22 -0
  313. package/cjs/slider/index.js.map +1 -0
  314. package/cjs/slider/slider.d.ts +96 -0
  315. package/cjs/slider/slider.js +405 -0
  316. package/cjs/slider/slider.js.map +1 -0
  317. package/cjs/slider/type.d.ts +44 -0
  318. package/cjs/slider/type.js +6 -0
  319. package/cjs/slider/type.js.map +1 -0
  320. package/cjs/tag/index.d.ts +2 -0
  321. package/cjs/tag/index.js +21 -0
  322. package/cjs/tag/index.js.map +1 -0
  323. package/cjs/tag/tag.d.ts +8 -0
  324. package/cjs/tag/tag.js +103 -0
  325. package/cjs/tag/tag.js.map +1 -0
  326. package/cjs/tag/type.d.ts +24 -0
  327. package/cjs/tag/type.js +6 -0
  328. package/cjs/tag/type.js.map +1 -0
  329. package/cjs/title/index.d.ts +2 -0
  330. package/cjs/title/index.js +21 -0
  331. package/cjs/title/index.js.map +1 -0
  332. package/cjs/title/title.d.ts +10 -0
  333. package/cjs/title/title.js +133 -0
  334. package/cjs/title/title.js.map +1 -0
  335. package/cjs/title/type.d.ts +41 -0
  336. package/cjs/title/type.js +6 -0
  337. package/cjs/title/type.js.map +1 -0
  338. package/cjs/tooltip/config.d.ts +3 -0
  339. package/cjs/tooltip/config.js +78 -0
  340. package/cjs/tooltip/config.js.map +1 -0
  341. package/cjs/tooltip/index.d.ts +2 -0
  342. package/cjs/tooltip/index.js +21 -0
  343. package/cjs/tooltip/index.js.map +1 -0
  344. package/cjs/tooltip/tooltip.d.ts +18 -0
  345. package/cjs/tooltip/tooltip.js +160 -0
  346. package/cjs/tooltip/tooltip.js.map +1 -0
  347. package/cjs/tooltip/type.d.ts +60 -0
  348. package/cjs/tooltip/type.js +6 -0
  349. package/cjs/tooltip/type.js.map +1 -0
  350. package/cjs/tooltip/util.d.ts +2 -0
  351. package/cjs/tooltip/util.js +17 -0
  352. package/cjs/tooltip/util.js.map +1 -0
  353. package/cjs/util/common.d.ts +3 -0
  354. package/cjs/util/common.js +21 -0
  355. package/cjs/util/common.js.map +1 -0
  356. package/cjs/util/index.d.ts +4 -0
  357. package/cjs/util/index.js +22 -0
  358. package/cjs/util/index.js.map +1 -0
  359. package/cjs/util/labelSmartInvert.d.ts +2 -0
  360. package/cjs/util/labelSmartInvert.js +45 -0
  361. package/cjs/util/labelSmartInvert.js.map +1 -0
  362. package/cjs/util/matrix.d.ts +4 -0
  363. package/cjs/util/matrix.js +24 -0
  364. package/cjs/util/matrix.js.map +1 -0
  365. package/cjs/util/text.d.ts +7 -0
  366. package/cjs/util/text.js +40 -0
  367. package/cjs/util/text.js.map +1 -0
  368. package/dist/vrender-components.js.js +1 -0
  369. package/dist/vrender-components.js.min.js +1 -0
  370. package/es/axis/animate/group-fade.d.ts +17 -0
  371. package/es/axis/animate/group-fade.js +62 -0
  372. package/es/axis/animate/group-fade.js.map +1 -0
  373. package/es/axis/animate/group-transition.d.ts +10 -0
  374. package/es/axis/animate/group-transition.js +72 -0
  375. package/es/axis/animate/group-transition.js.map +1 -0
  376. package/es/axis/animate/index.d.ts +2 -0
  377. package/es/axis/animate/index.js +4 -0
  378. package/es/axis/animate/index.js.map +1 -0
  379. package/es/axis/base.d.ts +53 -0
  380. package/es/axis/base.js +306 -0
  381. package/es/axis/base.js.map +1 -0
  382. package/es/axis/circle.d.ts +88 -0
  383. package/es/axis/circle.js +186 -0
  384. package/es/axis/circle.js.map +1 -0
  385. package/es/axis/config.d.ts +71 -0
  386. package/es/axis/config.js +72 -0
  387. package/es/axis/config.js.map +1 -0
  388. package/es/axis/constant.d.ts +27 -0
  389. package/es/axis/constant.js +26 -0
  390. package/es/axis/constant.js.map +1 -0
  391. package/es/axis/grid.d.ts +9 -0
  392. package/es/axis/grid.js +102 -0
  393. package/es/axis/grid.js.map +1 -0
  394. package/es/axis/index.d.ts +6 -0
  395. package/es/axis/index.js +12 -0
  396. package/es/axis/index.js.map +1 -0
  397. package/es/axis/line.d.ts +89 -0
  398. package/es/axis/line.js +204 -0
  399. package/es/axis/line.js.map +1 -0
  400. package/es/axis/type.d.ts +177 -0
  401. package/es/axis/type.js +2 -0
  402. package/es/axis/type.js.map +1 -0
  403. package/es/brush/brush.d.ts +65 -0
  404. package/es/brush/brush.js +171 -0
  405. package/es/brush/brush.js.map +1 -0
  406. package/es/brush/config.d.ts +21 -0
  407. package/es/brush/config.js +22 -0
  408. package/es/brush/config.js.map +1 -0
  409. package/es/brush/index.d.ts +2 -0
  410. package/es/brush/index.js +4 -0
  411. package/es/brush/index.js.map +1 -0
  412. package/es/brush/type.d.ts +21 -0
  413. package/es/brush/type.js +2 -0
  414. package/es/brush/type.js.map +1 -0
  415. package/es/constant.d.ts +16 -0
  416. package/es/constant.js +21 -0
  417. package/es/constant.js.map +1 -0
  418. package/es/core/base.d.ts +12 -0
  419. package/es/core/base.js +40 -0
  420. package/es/core/base.js.map +1 -0
  421. package/es/core/type.d.ts +28 -0
  422. package/es/core/type.js +1 -0
  423. package/es/core/type.js.map +1 -0
  424. package/es/crosshair/base.d.ts +10 -0
  425. package/es/crosshair/base.js +11 -0
  426. package/es/crosshair/base.js.map +1 -0
  427. package/es/crosshair/circle.d.ts +17 -0
  428. package/es/crosshair/circle.js +29 -0
  429. package/es/crosshair/circle.js.map +1 -0
  430. package/es/crosshair/index.d.ts +6 -0
  431. package/es/crosshair/index.js +12 -0
  432. package/es/crosshair/index.js.map +1 -0
  433. package/es/crosshair/line.d.ts +17 -0
  434. package/es/crosshair/line.js +32 -0
  435. package/es/crosshair/line.js.map +1 -0
  436. package/es/crosshair/polygon.d.ts +17 -0
  437. package/es/crosshair/polygon.js +35 -0
  438. package/es/crosshair/polygon.js.map +1 -0
  439. package/es/crosshair/rect.d.ts +20 -0
  440. package/es/crosshair/rect.js +33 -0
  441. package/es/crosshair/rect.js.map +1 -0
  442. package/es/crosshair/sector.d.ts +15 -0
  443. package/es/crosshair/sector.js +35 -0
  444. package/es/crosshair/sector.js.map +1 -0
  445. package/es/crosshair/type.d.ts +37 -0
  446. package/es/crosshair/type.js +2 -0
  447. package/es/crosshair/type.js.map +1 -0
  448. package/es/data-zoom/config.d.ts +104 -0
  449. package/es/data-zoom/config.js +106 -0
  450. package/es/data-zoom/config.js.map +1 -0
  451. package/es/data-zoom/data-zoom.d.ts +193 -0
  452. package/es/data-zoom/data-zoom.js +444 -0
  453. package/es/data-zoom/data-zoom.js.map +1 -0
  454. package/es/data-zoom/index.d.ts +2 -0
  455. package/es/data-zoom/index.js +4 -0
  456. package/es/data-zoom/index.js.map +1 -0
  457. package/es/data-zoom/type.d.ts +59 -0
  458. package/es/data-zoom/type.js +2 -0
  459. package/es/data-zoom/type.js.map +1 -0
  460. package/es/index.d.ts +20 -0
  461. package/es/index.js +40 -0
  462. package/es/index.js.map +1 -0
  463. package/es/indicator/config.d.ts +2 -0
  464. package/es/indicator/config.js +27 -0
  465. package/es/indicator/config.js.map +1 -0
  466. package/es/indicator/index.d.ts +2 -0
  467. package/es/indicator/index.js +4 -0
  468. package/es/indicator/index.js.map +1 -0
  469. package/es/indicator/indicator.d.ts +9 -0
  470. package/es/indicator/indicator.js +69 -0
  471. package/es/indicator/indicator.js.map +1 -0
  472. package/es/indicator/type.d.ts +21 -0
  473. package/es/indicator/type.js +1 -0
  474. package/es/indicator/type.js.map +1 -0
  475. package/es/interface.d.ts +6 -0
  476. package/es/interface.js +2 -0
  477. package/es/interface.js.map +1 -0
  478. package/es/label/animate/animate.d.ts +7 -0
  479. package/es/label/animate/animate.js +47 -0
  480. package/es/label/animate/animate.js.map +1 -0
  481. package/es/label/animate/index.d.ts +1 -0
  482. package/es/label/animate/index.js +3 -0
  483. package/es/label/animate/index.js.map +1 -0
  484. package/es/label/base.d.ts +43 -0
  485. package/es/label/base.js +263 -0
  486. package/es/label/base.js.map +1 -0
  487. package/es/label/dataLabel.d.ts +13 -0
  488. package/es/label/dataLabel.js +60 -0
  489. package/es/label/dataLabel.js.map +1 -0
  490. package/es/label/index.d.ts +6 -0
  491. package/es/label/index.js +12 -0
  492. package/es/label/index.js.map +1 -0
  493. package/es/label/line.d.ts +15 -0
  494. package/es/label/line.js +43 -0
  495. package/es/label/line.js.map +1 -0
  496. package/es/label/overlap/bitmap.d.ts +13 -0
  497. package/es/label/overlap/bitmap.js +65 -0
  498. package/es/label/overlap/bitmap.js.map +1 -0
  499. package/es/label/overlap/index.d.ts +3 -0
  500. package/es/label/overlap/index.js +6 -0
  501. package/es/label/overlap/index.js.map +1 -0
  502. package/es/label/overlap/place.d.ts +14 -0
  503. package/es/label/overlap/place.js +57 -0
  504. package/es/label/overlap/place.js.map +1 -0
  505. package/es/label/overlap/scaler.d.ts +27 -0
  506. package/es/label/overlap/scaler.js +18 -0
  507. package/es/label/overlap/scaler.js.map +1 -0
  508. package/es/label/rect.d.ts +10 -0
  509. package/es/label/rect.js +55 -0
  510. package/es/label/rect.js.map +1 -0
  511. package/es/label/symbol.d.ts +10 -0
  512. package/es/label/symbol.js +65 -0
  513. package/es/label/symbol.js.map +1 -0
  514. package/es/label/type.d.ts +90 -0
  515. package/es/label/type.js +2 -0
  516. package/es/label/type.js.map +1 -0
  517. package/es/legend/base.d.ts +14 -0
  518. package/es/legend/base.js +56 -0
  519. package/es/legend/base.js.map +1 -0
  520. package/es/legend/color/color.d.ts +37 -0
  521. package/es/legend/color/color.js +128 -0
  522. package/es/legend/color/color.js.map +1 -0
  523. package/es/legend/color/index.d.ts +2 -0
  524. package/es/legend/color/index.js +4 -0
  525. package/es/legend/color/index.js.map +1 -0
  526. package/es/legend/color/type.d.ts +5 -0
  527. package/es/legend/color/type.js +2 -0
  528. package/es/legend/color/type.js.map +1 -0
  529. package/es/legend/constant.d.ts +29 -0
  530. package/es/legend/constant.js +40 -0
  531. package/es/legend/constant.js.map +1 -0
  532. package/es/legend/discrete/discrete.d.ts +26 -0
  533. package/es/legend/discrete/discrete.js +409 -0
  534. package/es/legend/discrete/discrete.js.map +1 -0
  535. package/es/legend/discrete/index.d.ts +2 -0
  536. package/es/legend/discrete/index.js +4 -0
  537. package/es/legend/discrete/index.js.map +1 -0
  538. package/es/legend/discrete/type.d.ts +65 -0
  539. package/es/legend/discrete/type.js +2 -0
  540. package/es/legend/discrete/type.js.map +1 -0
  541. package/es/legend/index.d.ts +8 -0
  542. package/es/legend/index.js +16 -0
  543. package/es/legend/index.js.map +1 -0
  544. package/es/legend/size/index.d.ts +1 -0
  545. package/es/legend/size/index.js +3 -0
  546. package/es/legend/size/index.js.map +1 -0
  547. package/es/legend/size/size.d.ts +34 -0
  548. package/es/legend/size/size.js +105 -0
  549. package/es/legend/size/size.js.map +1 -0
  550. package/es/legend/size/type.d.ts +6 -0
  551. package/es/legend/size/type.js +2 -0
  552. package/es/legend/size/type.js.map +1 -0
  553. package/es/legend/type.d.ts +27 -0
  554. package/es/legend/type.js +2 -0
  555. package/es/legend/type.js.map +1 -0
  556. package/es/link-path/index.d.ts +2 -0
  557. package/es/link-path/index.js +4 -0
  558. package/es/link-path/index.js.map +1 -0
  559. package/es/link-path/link-path.d.ts +15 -0
  560. package/es/link-path/link-path.js +59 -0
  561. package/es/link-path/link-path.js.map +1 -0
  562. package/es/link-path/type.d.ts +17 -0
  563. package/es/link-path/type.js +2 -0
  564. package/es/link-path/type.js.map +1 -0
  565. package/es/marker/area.d.ts +56 -0
  566. package/es/marker/area.js +65 -0
  567. package/es/marker/area.js.map +1 -0
  568. package/es/marker/base.d.ts +11 -0
  569. package/es/marker/base.js +15 -0
  570. package/es/marker/base.js.map +1 -0
  571. package/es/marker/config.d.ts +154 -0
  572. package/es/marker/config.js +244 -0
  573. package/es/marker/config.js.map +1 -0
  574. package/es/marker/index.d.ts +4 -0
  575. package/es/marker/index.js +8 -0
  576. package/es/marker/index.js.map +1 -0
  577. package/es/marker/line.d.ts +10 -0
  578. package/es/marker/line.js +47 -0
  579. package/es/marker/line.js.map +1 -0
  580. package/es/marker/point.d.ts +80 -0
  581. package/es/marker/point.js +106 -0
  582. package/es/marker/point.js.map +1 -0
  583. package/es/marker/type.d.ts +93 -0
  584. package/es/marker/type.js +27 -0
  585. package/es/marker/type.js.map +1 -0
  586. package/es/pager/index.d.ts +2 -0
  587. package/es/pager/index.js +4 -0
  588. package/es/pager/index.js.map +1 -0
  589. package/es/pager/pager.d.ts +20 -0
  590. package/es/pager/pager.js +132 -0
  591. package/es/pager/pager.js.map +1 -0
  592. package/es/pager/type.d.ts +19 -0
  593. package/es/pager/type.js +2 -0
  594. package/es/pager/type.js.map +1 -0
  595. package/es/player/base-player.d.ts +103 -0
  596. package/es/player/base-player.js +200 -0
  597. package/es/player/base-player.js.map +1 -0
  598. package/es/player/constant.d.ts +12 -0
  599. package/es/player/constant.js +14 -0
  600. package/es/player/constant.js.map +1 -0
  601. package/es/player/continuous-player.d.ts +34 -0
  602. package/es/player/continuous-player.js +104 -0
  603. package/es/player/continuous-player.js.map +1 -0
  604. package/es/player/controller/assets/index.d.ts +6 -0
  605. package/es/player/controller/assets/index.js +12 -0
  606. package/es/player/controller/assets/index.js.map +1 -0
  607. package/es/player/controller/constant.d.ts +12 -0
  608. package/es/player/controller/constant.js +14 -0
  609. package/es/player/controller/constant.js.map +1 -0
  610. package/es/player/controller/controller.d.ts +32 -0
  611. package/es/player/controller/controller.js +97 -0
  612. package/es/player/controller/controller.js.map +1 -0
  613. package/es/player/controller/icon/icon.d.ts +4 -0
  614. package/es/player/controller/icon/icon.js +8 -0
  615. package/es/player/controller/icon/icon.js.map +1 -0
  616. package/es/player/controller/icon/index.d.ts +1 -0
  617. package/es/player/controller/icon/index.js +2 -0
  618. package/es/player/controller/icon/index.js.map +1 -0
  619. package/es/player/controller/icon/type.d.ts +1 -0
  620. package/es/player/controller/icon/type.js +3 -0
  621. package/es/player/controller/icon/type.js.map +1 -0
  622. package/es/player/controller/index.d.ts +2 -0
  623. package/es/player/controller/index.js +4 -0
  624. package/es/player/controller/index.js.map +1 -0
  625. package/es/player/controller/type.d.ts +11 -0
  626. package/es/player/controller/type.js +2 -0
  627. package/es/player/controller/type.js.map +1 -0
  628. package/es/player/discrete-player.d.ts +32 -0
  629. package/es/player/discrete-player.js +86 -0
  630. package/es/player/discrete-player.js.map +1 -0
  631. package/es/player/index.d.ts +4 -0
  632. package/es/player/index.js +8 -0
  633. package/es/player/index.js.map +1 -0
  634. package/es/player/type/base.d.ts +7 -0
  635. package/es/player/type/base.js +2 -0
  636. package/es/player/type/base.js.map +1 -0
  637. package/es/player/type/continuous-player.d.ts +7 -0
  638. package/es/player/type/continuous-player.js +2 -0
  639. package/es/player/type/continuous-player.js.map +1 -0
  640. package/es/player/type/direction.d.ts +5 -0
  641. package/es/player/type/direction.js +6 -0
  642. package/es/player/type/direction.js.map +1 -0
  643. package/es/player/type/discrete-player.d.ts +9 -0
  644. package/es/player/type/discrete-player.js +2 -0
  645. package/es/player/type/discrete-player.js.map +1 -0
  646. package/es/player/type/event.d.ts +8 -0
  647. package/es/player/type/event.js +8 -0
  648. package/es/player/type/event.js.map +1 -0
  649. package/es/player/type/index.d.ts +9 -0
  650. package/es/player/type/index.js +12 -0
  651. package/es/player/type/index.js.map +1 -0
  652. package/es/player/type/layout.d.ts +35 -0
  653. package/es/player/type/layout.js +2 -0
  654. package/es/player/type/layout.js.map +1 -0
  655. package/es/player/utils.d.ts +20 -0
  656. package/es/player/utils.js +45 -0
  657. package/es/player/utils.js.map +1 -0
  658. package/es/scrollbar/index.d.ts +2 -0
  659. package/es/scrollbar/index.js +4 -0
  660. package/es/scrollbar/index.js.map +1 -0
  661. package/es/scrollbar/scrollbar.d.ts +43 -0
  662. package/es/scrollbar/scrollbar.js +154 -0
  663. package/es/scrollbar/scrollbar.js.map +1 -0
  664. package/es/scrollbar/type.d.ts +16 -0
  665. package/es/scrollbar/type.js +2 -0
  666. package/es/scrollbar/type.js.map +1 -0
  667. package/es/segment/index.d.ts +2 -0
  668. package/es/segment/index.js +4 -0
  669. package/es/segment/index.js.map +1 -0
  670. package/es/segment/segment.d.ts +18 -0
  671. package/es/segment/segment.js +103 -0
  672. package/es/segment/segment.js.map +1 -0
  673. package/es/segment/type.d.ts +22 -0
  674. package/es/segment/type.js +2 -0
  675. package/es/segment/type.js.map +1 -0
  676. package/es/slider/constant.d.ts +13 -0
  677. package/es/slider/constant.js +11 -0
  678. package/es/slider/constant.js.map +1 -0
  679. package/es/slider/index.d.ts +3 -0
  680. package/es/slider/index.js +6 -0
  681. package/es/slider/index.js.map +1 -0
  682. package/es/slider/slider.d.ts +96 -0
  683. package/es/slider/slider.js +399 -0
  684. package/es/slider/slider.js.map +1 -0
  685. package/es/slider/type.d.ts +44 -0
  686. package/es/slider/type.js +2 -0
  687. package/es/slider/type.js.map +1 -0
  688. package/es/tag/index.d.ts +2 -0
  689. package/es/tag/index.js +4 -0
  690. package/es/tag/index.js.map +1 -0
  691. package/es/tag/tag.d.ts +8 -0
  692. package/es/tag/tag.js +97 -0
  693. package/es/tag/tag.js.map +1 -0
  694. package/es/tag/type.d.ts +24 -0
  695. package/es/tag/type.js +2 -0
  696. package/es/tag/type.js.map +1 -0
  697. package/es/title/index.d.ts +2 -0
  698. package/es/title/index.js +4 -0
  699. package/es/title/index.js.map +1 -0
  700. package/es/title/title.d.ts +10 -0
  701. package/es/title/title.js +125 -0
  702. package/es/title/title.js.map +1 -0
  703. package/es/title/type.d.ts +41 -0
  704. package/es/title/type.js +2 -0
  705. package/es/title/type.js.map +1 -0
  706. package/es/tooltip/config.d.ts +3 -0
  707. package/es/tooltip/config.js +76 -0
  708. package/es/tooltip/config.js.map +1 -0
  709. package/es/tooltip/index.d.ts +2 -0
  710. package/es/tooltip/index.js +4 -0
  711. package/es/tooltip/index.js.map +1 -0
  712. package/es/tooltip/tooltip.d.ts +18 -0
  713. package/es/tooltip/tooltip.js +161 -0
  714. package/es/tooltip/tooltip.js.map +1 -0
  715. package/es/tooltip/type.d.ts +60 -0
  716. package/es/tooltip/type.js +2 -0
  717. package/es/tooltip/type.js.map +1 -0
  718. package/es/tooltip/util.d.ts +2 -0
  719. package/es/tooltip/util.js +11 -0
  720. package/es/tooltip/util.js.map +1 -0
  721. package/es/util/common.d.ts +3 -0
  722. package/es/util/common.js +11 -0
  723. package/es/util/common.js.map +1 -0
  724. package/es/util/index.d.ts +4 -0
  725. package/es/util/index.js +8 -0
  726. package/es/util/index.js.map +1 -0
  727. package/es/util/labelSmartInvert.d.ts +2 -0
  728. package/es/util/labelSmartInvert.js +39 -0
  729. package/es/util/labelSmartInvert.js.map +1 -0
  730. package/es/util/matrix.d.ts +4 -0
  731. package/es/util/matrix.js +13 -0
  732. package/es/util/matrix.js.map +1 -0
  733. package/es/util/text.d.ts +7 -0
  734. package/es/util/text.js +38 -0
  735. package/es/util/text.js.map +1 -0
  736. package/package.json +49 -0
@@ -0,0 +1,44 @@
1
+ import { ISymbolGraphicAttribute, IRectGraphicAttribute, ITextGraphicAttribute, IGroupGraphicAttribute } from '@visactor/vrender';
2
+ type Text = string | number;
3
+ export type TextAttribute = {
4
+ visible?: boolean;
5
+ text?: Text;
6
+ space?: number;
7
+ style?: Omit<Partial<ITextGraphicAttribute>, 'text'>;
8
+ };
9
+ export type HandlerTextAttribute = {
10
+ visible?: boolean;
11
+ precision?: number;
12
+ formatter?: (text: Text) => Text;
13
+ space?: number;
14
+ style?: Omit<Partial<ITextGraphicAttribute>, 'text'>;
15
+ };
16
+ export type TooltipConfig = {
17
+ formatter?: (value: Text) => Text;
18
+ };
19
+ export type RangeType = boolean | {
20
+ draggableTrack?: boolean;
21
+ };
22
+ export type SliderAttributes = {
23
+ slidable?: boolean;
24
+ layout?: 'horizontal' | 'vertical' | string;
25
+ align?: 'top' | 'bottom' | 'left' | 'right';
26
+ range?: RangeType;
27
+ min: number;
28
+ max: number;
29
+ value?: number | [number, number];
30
+ step?: number;
31
+ railWidth: number;
32
+ railHeight: number;
33
+ showHandler?: boolean;
34
+ handlerSize?: number;
35
+ handlerStyle?: Partial<ISymbolGraphicAttribute>;
36
+ railStyle?: Omit<Partial<IRectGraphicAttribute>, 'width' | 'height'>;
37
+ trackStyle?: Omit<Partial<IRectGraphicAttribute>, 'width' | 'height'>;
38
+ startText?: TextAttribute;
39
+ endText?: TextAttribute;
40
+ handlerText?: HandlerTextAttribute;
41
+ showTooltip?: boolean;
42
+ tooltip?: TooltipConfig;
43
+ } & IGroupGraphicAttribute;
44
+ export {};
@@ -0,0 +1,2 @@
1
+ export { };
2
+ //# sourceMappingURL=type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/slider/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import {\n ISymbolGraphicAttribute,\n IRectGraphicAttribute,\n ITextGraphicAttribute,\n IGroupGraphicAttribute\n} from '@visactor/vrender';\n\ntype Text = string | number;\n\nexport type TextAttribute = {\n /** 是否展示 */\n visible?: boolean;\n /** 文本内容 */\n text?: Text;\n /**\n * 文本同滑块的间距,默认为 6\n */\n space?: number;\n /**\n * 文本样式\n */\n style?: Omit<Partial<ITextGraphicAttribute>, 'text'>;\n};\n\nexport type HandlerTextAttribute = {\n /** 是否展示 */\n visible?: boolean;\n /**\n * 数据展示的小数精度,默认为0,无小数点。\n */\n precision?: number;\n /** 文本内容格式化函数 */\n formatter?: (text: Text) => Text;\n /**\n * 文本同滑块的间距,默认为 6\n */\n space?: number;\n /**\n * 文本样式\n */\n style?: Omit<Partial<ITextGraphicAttribute>, 'text'>;\n};\n\nexport type TooltipConfig = {\n // /**\n // * 是否始终展示\n // */\n // alwaysShow?: boolean;\n /**\n * 格式化函数\n */\n formatter?: (value: Text) => Text;\n // TODO: 待补充一些样式属性\n};\n\nexport type RangeType =\n | boolean\n | {\n /**\n * 范围刻度是否可被拖拽,默认值为 false\n */\n draggableTrack?: boolean;\n };\n\nexport type SliderAttributes = {\n /**\n * 是否允许拖动,默认为 true\n */\n slidable?: boolean;\n /**\n * TODO: 这个类型有问题\n * 布局方式。\n * - 'horizontal' 水平布局\n * - 'vertical' 垂直布局\n */\n layout?: 'horizontal' | 'vertical' | string;\n /**\n * 指定组件中手柄和文字的摆放位置,可选值为:\n * 'left' 手柄和label在滑块左侧,layout 为 vertical 时有效。\n * 'right' 手柄和label在滑块右侧,layout 为 vertical 时有效。\n * 'top' 手柄和label在滑块上侧,layout 为 horizontal 时有效。\n * 'bottom' 手柄和label在滑块下侧,layout 为 horizontal 时有效。\n */\n align?: 'top' | 'bottom' | 'left' | 'right';\n /**\n * 双滑块模式,默认为 false,单滑块模式\n */\n range?: RangeType;\n /**\n * 最小值\n */\n min: number;\n /**\n * 最大值\n */\n max: number;\n /**\n * 设置当前取值。当 range 为 false 时,使用 number,否则用 [number, number]\n */\n value?: number | [number, number];\n /**\n * TODO:\n * 步长,取值必须大于 0,并且可被 (max - min) 整除。\n * 用于离散连续场景\n */\n step?: number;\n\n /**\n * 滑块的宽度\n */\n railWidth: number;\n /**\n * 滑块的高度\n */\n railHeight: number;\n\n /**\n * 是否绘制 handler,默认为 true\n */\n showHandler?: boolean;\n\n /**\n * handler 操作按钮的大小\n */\n handlerSize?: number;\n\n /**\n * 滑块手柄的样式配置\n */\n handlerStyle?: Partial<ISymbolGraphicAttribute>;\n /**\n * 背景轨道样式配置\n */\n railStyle?: Omit<Partial<IRectGraphicAttribute>, 'width' | 'height'>;\n /**\n * 选中区域样式配置\n */\n trackStyle?: Omit<Partial<IRectGraphicAttribute>, 'width' | 'height'>;\n\n /**\n * 滑块首部文本配置\n */\n startText?: TextAttribute;\n /**\n * 滑块尾部文本配置\n */\n endText?: TextAttribute;\n\n /**\n * 滑块对应的文本配置项\n */\n handlerText?: HandlerTextAttribute;\n\n /**\n * TODO\n * 是否显示 hander 上的 tooltip\n */\n showTooltip?: boolean;\n /**\n * handler tooltip 配置\n */\n tooltip?: TooltipConfig;\n} & IGroupGraphicAttribute;\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './tag';
2
+ export * from './type';
@@ -0,0 +1,4 @@
1
+ export * from "./tag";
2
+
3
+ export * from "./type";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tag/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,QAAQ,CAAC","file":"index.js","sourcesContent":["export * from './tag';\nexport * from './type';\n"]}
@@ -0,0 +1,8 @@
1
+ import { AbstractComponent } from '../core/base';
2
+ import { TagAttributes } from './type';
3
+ export declare class Tag extends AbstractComponent<Required<TagAttributes>> {
4
+ name: string;
5
+ static defaultAttributes: Partial<TagAttributes>;
6
+ constructor(attributes: TagAttributes);
7
+ protected render(): void;
8
+ }
package/es/tag/tag.js ADDED
@@ -0,0 +1,97 @@
1
+ var __rest = this && this.__rest || function(s, e) {
2
+ var t = {};
3
+ for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
4
+ if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
5
+ var i = 0;
6
+ for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
7
+ }
8
+ return t;
9
+ };
10
+
11
+ import { isBoolean, isEmpty, isNil, isNumber, isValid, merge, normalizePadding } from "@visactor/vutils";
12
+
13
+ import { AbstractComponent } from "../core/base";
14
+
15
+ import { measureTextSize } from "../util";
16
+
17
+ export class Tag extends AbstractComponent {
18
+ constructor(attributes) {
19
+ super(merge({}, Tag.defaultAttributes, attributes)), this.name = "tag";
20
+ }
21
+ render() {
22
+ var _a;
23
+ const {text: text = "", textStyle: textStyle = {}, shape: shape = {}, panel: panel = {}, space: space = 4, minWidth: minWidth, maxWidth: maxWidth, padding: padding = 4, visible: visible, state: state} = this.attribute, parsedPadding = normalizePadding(padding), group = this.createOrUpdateChild("tag-content", {
24
+ x: 0,
25
+ y: 0,
26
+ zIndex: 1
27
+ }, "group");
28
+ let symbol, tagWidth = parsedPadding[1] + parsedPadding[3], tagHeight = parsedPadding[0] + parsedPadding[2], textX = 0, symbolPlaceWidth = 0;
29
+ const {visible: shapeVisible} = shape, shapeStyle = __rest(shape, [ "visible" ]);
30
+ if (isBoolean(shapeVisible)) {
31
+ const size = (null == shapeStyle ? void 0 : shapeStyle.size) || 10, maxSize = isNumber(size) ? size : Math.max(size[0], size[1]);
32
+ symbol = group.createOrUpdateChild("tag-shape", Object.assign(Object.assign({
33
+ symbolType: "circle",
34
+ size: size,
35
+ strokeBoundsBuffer: 0
36
+ }, shapeStyle), {
37
+ visible: shapeVisible,
38
+ x: maxSize / 2,
39
+ y: maxSize / 2
40
+ }), "symbol"), isEmpty(null == state ? void 0 : state.shape) || (symbol.states = state.shape),
41
+ shapeVisible && (symbolPlaceWidth = maxSize + space);
42
+ }
43
+ tagWidth += symbolPlaceWidth, textX += symbolPlaceWidth;
44
+ const textAttrs = Object.assign(Object.assign({
45
+ text: text,
46
+ visible: isValid(text) && !1 !== visible,
47
+ lineHeight: null == textStyle ? void 0 : textStyle.fontSize
48
+ }, textStyle), {
49
+ x: textX,
50
+ y: 0
51
+ });
52
+ isNil(textAttrs.lineHeight) && (textAttrs.lineHeight = textAttrs.fontSize);
53
+ const textShape = group.createOrUpdateChild("tag-text", textAttrs, "text");
54
+ isEmpty(null == state ? void 0 : state.text) || (textShape.states = state.text);
55
+ const textBounds = measureTextSize(textAttrs.text, textStyle), textWidth = textBounds.width, textHeight = textBounds.height;
56
+ tagWidth += textWidth;
57
+ const size = null !== (_a = shape.size) && void 0 !== _a ? _a : 10, maxSize = isNumber(size) ? size : Math.max(size[0], size[1]);
58
+ tagHeight += Math.max(textHeight, (null == shape ? void 0 : shape.visible) ? maxSize : 0);
59
+ const {textAlign: textAlign, textBaseline: textBaseline} = textStyle;
60
+ (isValid(minWidth) || isValid(maxWidth)) && (isValid(minWidth) && tagWidth < minWidth && (tagWidth = minWidth),
61
+ isValid(maxWidth) && tagWidth > maxWidth && (tagWidth = maxWidth, textShape.setAttribute("maxLineWidth", maxWidth - parsedPadding[1] - parsedPadding[2])));
62
+ let x = 0, y = 0;
63
+ "center" === textAlign ? (x -= tagWidth / 2, symbol && symbol.setAttribute("x", (symbol.attribute.x || 0) - textWidth / 2),
64
+ group.setAttribute("x", -symbolPlaceWidth / 2)) : "right" === textAlign || "end" === textAlign ? (x -= tagWidth,
65
+ symbol && symbol.setAttribute("x", (symbol.attribute.x || 0) - textWidth), group.setAttribute("x", -parsedPadding[1] - symbolPlaceWidth)) : "left" !== textAlign && "start" !== textAlign || group.setAttribute("x", parsedPadding[3]),
66
+ "middle" === textBaseline ? (y -= tagHeight / 2, symbol && symbol.setAttribute("y", 0)) : "bottom" === textBaseline ? (y -= tagHeight,
67
+ symbol && symbol.setAttribute("y", -textHeight / 2), group.setAttribute("y", -parsedPadding[2])) : "top" === textBaseline && (group.setAttribute("y", parsedPadding[0]),
68
+ symbol && symbol.setAttribute("y", textHeight / 2));
69
+ const {visible: bgVisible} = panel, backgroundStyle = __rest(panel, [ "visible" ]);
70
+ if (isBoolean(bgVisible)) {
71
+ const bgRect = this.createOrUpdateChild("tag-panel", Object.assign(Object.assign({}, backgroundStyle), {
72
+ visible: bgVisible && !!text,
73
+ x: x,
74
+ y: y,
75
+ width: tagWidth,
76
+ height: tagHeight
77
+ }), "rect");
78
+ isEmpty(null == state ? void 0 : state.panel) || (bgRect.states = state.panel);
79
+ }
80
+ }
81
+ }
82
+
83
+ Tag.defaultAttributes = {
84
+ visible: !0,
85
+ textStyle: {
86
+ fontSize: 12,
87
+ fillColor: "#000",
88
+ textAlign: "left",
89
+ textBaseline: "top"
90
+ },
91
+ space: 4,
92
+ padding: 4,
93
+ shape: {
94
+ fillColor: "#000"
95
+ }
96
+ };
97
+ //# sourceMappingURL=tag.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tag/tag.ts"],"names":[],"mappings":"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","file":"tag.js","sourcesContent":["/**\n * @description 标签组件\n */\nimport { IGroup, IRect, ISymbol, IText, ITextAttribute, ITextGraphicAttribute } from '@visactor/vrender';\nimport { isBoolean, isEmpty, isNil, isNumber, isValid, merge, normalizePadding } from '@visactor/vutils';\nimport { AbstractComponent } from '../core/base';\nimport { measureTextSize } from '../util';\nimport { BackgroundAttributes } from '../interface';\nimport { TagAttributes, TagShapeAttributes } from './type';\n\nexport class Tag extends AbstractComponent<Required<TagAttributes>> {\n name = 'tag';\n\n static defaultAttributes: Partial<TagAttributes> = {\n visible: true,\n textStyle: {\n fontSize: 12,\n fillColor: '#000',\n textAlign: 'left',\n textBaseline: 'top'\n },\n space: 4,\n padding: 4,\n // @ts-ignore\n shape: {\n fillColor: '#000'\n }\n };\n\n constructor(attributes: TagAttributes) {\n super(merge({}, Tag.defaultAttributes, attributes));\n }\n\n protected render() {\n const {\n text = '',\n textStyle = {} as ITextGraphicAttribute,\n shape = {} as TagShapeAttributes,\n panel = {} as BackgroundAttributes,\n space = 4,\n minWidth,\n maxWidth,\n padding = 4,\n visible,\n state\n } = this.attribute as TagAttributes;\n\n const parsedPadding = normalizePadding(padding);\n\n const group = this.createOrUpdateChild('tag-content', { x: 0, y: 0, zIndex: 1 }, 'group') as IGroup;\n\n let symbol;\n let tagWidth = parsedPadding[1] + parsedPadding[3];\n let tagHeight = parsedPadding[0] + parsedPadding[2];\n let textX = 0;\n let symbolPlaceWidth = 0;\n const { visible: shapeVisible, ...shapeStyle } = shape;\n if (isBoolean(shapeVisible)) {\n const size = shapeStyle?.size || 10;\n const maxSize = isNumber(size) ? size : Math.max(size[0], size[1]);\n\n symbol = group.createOrUpdateChild(\n 'tag-shape',\n {\n symbolType: 'circle',\n size,\n strokeBoundsBuffer: 0,\n ...shapeStyle,\n visible: shapeVisible,\n x: maxSize / 2,\n y: maxSize / 2\n },\n 'symbol'\n ) as ISymbol;\n if (!isEmpty(state?.shape)) {\n symbol.states = state.shape;\n }\n\n if (shapeVisible) {\n symbolPlaceWidth = maxSize + space;\n }\n }\n\n tagWidth += symbolPlaceWidth;\n textX += symbolPlaceWidth;\n\n const textAttrs = {\n text,\n visible: isValid(text) && visible !== false,\n lineHeight: textStyle?.fontSize,\n ...textStyle,\n x: textX,\n y: 0\n };\n if (isNil(textAttrs.lineHeight)) {\n textAttrs.lineHeight = textAttrs.fontSize;\n }\n const textShape = group.createOrUpdateChild('tag-text', textAttrs, 'text') as IText;\n if (!isEmpty(state?.text)) {\n textShape.states = state.text;\n }\n\n // 因为文本可能发生旋转,所以需要使用 measureTextSize 方法\n const textBounds = measureTextSize(textAttrs.text, textStyle);\n const textWidth = textBounds.width;\n const textHeight = textBounds.height;\n tagWidth += textWidth;\n const size = shape.size ?? 10;\n const maxSize = isNumber(size) ? size : Math.max(size[0], size[1]);\n tagHeight += Math.max(textHeight, shape?.visible ? maxSize : 0);\n\n const { textAlign, textBaseline } = textStyle as ITextAttribute;\n\n if (isValid(minWidth) || isValid(maxWidth)) {\n if (isValid(minWidth) && tagWidth < minWidth) {\n tagWidth = minWidth;\n }\n if (isValid(maxWidth) && tagWidth > maxWidth) {\n tagWidth = maxWidth;\n textShape.setAttribute('maxLineWidth', maxWidth - parsedPadding[1] - parsedPadding[2]);\n }\n }\n\n let x = 0;\n let y = 0;\n if (textAlign === 'center') {\n x -= tagWidth / 2;\n if (symbol) {\n symbol.setAttribute('x', (symbol.attribute.x || 0) - textWidth / 2);\n }\n\n group.setAttribute('x', -symbolPlaceWidth / 2);\n } else if (textAlign === 'right' || textAlign === 'end') {\n x -= tagWidth;\n if (symbol) {\n symbol.setAttribute('x', (symbol.attribute.x || 0) - textWidth);\n }\n\n group.setAttribute('x', -parsedPadding[1] - symbolPlaceWidth);\n } else if (textAlign === 'left' || textAlign === 'start') {\n group.setAttribute('x', parsedPadding[3]);\n }\n if (textBaseline === 'middle') {\n y -= tagHeight / 2;\n if (symbol) {\n symbol.setAttribute('y', 0);\n }\n } else if (textBaseline === 'bottom') {\n y -= tagHeight;\n if (symbol) {\n symbol.setAttribute('y', -textHeight / 2);\n }\n\n group.setAttribute('y', -parsedPadding[2]);\n } else if (textBaseline === 'top') {\n group.setAttribute('y', parsedPadding[0]);\n if (symbol) {\n symbol.setAttribute('y', textHeight / 2);\n }\n }\n\n // 绘制背景层\n const { visible: bgVisible, ...backgroundStyle } = panel;\n if (isBoolean(bgVisible)) {\n const bgRect = this.createOrUpdateChild(\n 'tag-panel',\n {\n ...backgroundStyle,\n visible: bgVisible && !!text,\n x,\n y,\n width: tagWidth,\n height: tagHeight\n },\n 'rect'\n ) as IRect;\n if (!isEmpty(state?.panel)) {\n bgRect.states = state.panel;\n }\n }\n }\n}\n"]}
@@ -0,0 +1,24 @@
1
+ import { ITextGraphicAttribute, ISymbolGraphicAttribute, IGroupGraphicAttribute, IRectGraphicAttribute } from '@visactor/vrender';
2
+ import { Padding, State } from '../core/type';
3
+ import { BackgroundAttributes } from '../interface';
4
+ type StateStyle = {
5
+ text?: State<Partial<ITextGraphicAttribute>>;
6
+ shape?: State<Partial<ISymbolGraphicAttribute>>;
7
+ panel?: State<Partial<IRectGraphicAttribute>>;
8
+ };
9
+ export type TagAttributes = {
10
+ text?: string | string[] | number | number[];
11
+ textStyle?: Partial<ITextGraphicAttribute>;
12
+ shape?: TagShapeAttributes;
13
+ space?: number;
14
+ padding?: Padding;
15
+ panel?: BackgroundAttributes;
16
+ minWidth?: number;
17
+ maxWidth?: number;
18
+ visible?: boolean;
19
+ state?: StateStyle;
20
+ } & Omit<IGroupGraphicAttribute, 'background'>;
21
+ export type TagShapeAttributes = {
22
+ visible: boolean;
23
+ } & Partial<ISymbolGraphicAttribute>;
24
+ export {};
package/es/tag/type.js ADDED
@@ -0,0 +1,2 @@
1
+ export { };
2
+ //# sourceMappingURL=type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tag/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import {\n ITextGraphicAttribute,\n ISymbolGraphicAttribute,\n IGroupGraphicAttribute,\n IRectGraphicAttribute\n} from '@visactor/vrender';\nimport { Padding, State } from '../core/type';\nimport { BackgroundAttributes } from '../interface';\n\ntype StateStyle = {\n /**\n * text 文本的状态配置\n */\n text?: State<Partial<ITextGraphicAttribute>>;\n /**\n * shape 标记的状态配置\n */\n shape?: State<Partial<ISymbolGraphicAttribute>>;\n /**\n * panel 背景的状态配置ß\n */\n panel?: State<Partial<IRectGraphicAttribute>>;\n};\n\nexport type TagAttributes = {\n /**\n * 文本内容,如果需要进行换行,则使用数组形式,如 ['abc', '123']\n */\n text?: string | string[] | number | number[];\n /** 文本样式 */\n textStyle?: Partial<ITextGraphicAttribute>;\n /** 文本前 mark 图元 */\n shape?: TagShapeAttributes;\n /**\n * shape 同文本之间的间距\n */\n space?: number;\n /**\n * 内部边距\n */\n padding?: Padding;\n /**\n * 标签的背景面板配置, TODO: 支持symbol形状\n */\n panel?: BackgroundAttributes;\n /**\n * 最小宽度,像素值\n * @default 30\n */\n minWidth?: number;\n /**\n * 最大宽度,像素值。当文字超过最大宽度时,会自动省略。\n */\n maxWidth?: number;\n visible?: boolean;\n state?: StateStyle;\n} & Omit<IGroupGraphicAttribute, 'background'>;\n\nexport type TagShapeAttributes = {\n /**\n * 是否展示 shape\n */\n visible: boolean;\n} & Partial<ISymbolGraphicAttribute>;\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './title';
2
+ export * from './type';
@@ -0,0 +1,4 @@
1
+ export * from "./title";
2
+
3
+ export * from "./type";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/title/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC","file":"index.js","sourcesContent":["export * from './title';\nexport * from './type';\n"]}
@@ -0,0 +1,10 @@
1
+ import { AbstractComponent } from '../core/base';
2
+ import { TitleAttrs } from './type';
3
+ export declare class Title extends AbstractComponent<Required<TitleAttrs>> {
4
+ name: string;
5
+ private _mainTitle?;
6
+ private _subTitle?;
7
+ static defaultAttributes: Partial<TitleAttrs>;
8
+ constructor(attributes: TitleAttrs);
9
+ protected render(): void;
10
+ }
@@ -0,0 +1,125 @@
1
+ import { merge, isValid, normalizePadding } from "@visactor/vutils";
2
+
3
+ import { AbstractComponent } from "../core/base";
4
+
5
+ export class Title extends AbstractComponent {
6
+ constructor(attributes) {
7
+ super(merge({}, Title.defaultAttributes, attributes)), this.name = "title";
8
+ }
9
+ render() {
10
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18, _19, _20, _21, _22, _23, _24, _25, _26, _27, _28, _29, _30, _31, _32, _33, _34, _35, _36, _37;
11
+ const {text: text, textStyle: textStyle, subtext: subtext, subtextStyle: subtextStyle, width: width, height: height, minWidth: minWidth, maxWidth: maxWidth, minHeight: minHeight, maxHeight: maxHeight, align: align, verticalAlign: verticalAlign, padding: padding = 0} = this.attribute, parsedPadding = normalizePadding(padding), group = this.createOrUpdateChild("title-container", {
12
+ x: parsedPadding[3],
13
+ y: parsedPadding[0],
14
+ zIndex: 1
15
+ }, "group");
16
+ if (!1 !== (null === (_a = this.attribute) || void 0 === _a ? void 0 : _a.visible) && !1 !== (null == textStyle ? void 0 : textStyle.visible)) if (textStyle && isValid(null == textStyle ? void 0 : textStyle.character)) {
17
+ const attr = {
18
+ x: null !== (_b = textStyle.x) && void 0 !== _b ? _b : 0,
19
+ y: null !== (_c = textStyle.y) && void 0 !== _c ? _c : 0,
20
+ width: null !== (_e = null !== (_d = textStyle.width) && void 0 !== _d ? _d : width) && void 0 !== _e ? _e : 0,
21
+ height: null !== (_g = null !== (_f = textStyle.height) && void 0 !== _f ? _f : height) && void 0 !== _g ? _g : 0,
22
+ ellipsis: null === (_h = textStyle.ellipsis) || void 0 === _h || _h,
23
+ wordBreak: null !== (_j = textStyle.wordBreak) && void 0 !== _j ? _j : "break-word",
24
+ maxHeight: textStyle.maxHeight,
25
+ maxWidth: textStyle.maxWidth,
26
+ textConfig: textStyle.character
27
+ };
28
+ this._mainTitle = group.createOrUpdateChild("mainTitle", attr, "richtext");
29
+ } else isValid(text) && (this._mainTitle = group.createOrUpdateChild("mainTitle", Object.assign(Object.assign({
30
+ text: [ text ]
31
+ }, textStyle), {
32
+ maxLineWidth: null !== (_k = null == textStyle ? void 0 : textStyle.maxLineWidth) && void 0 !== _k ? _k : width,
33
+ heightLimit: null == textStyle ? void 0 : textStyle.heightLimit,
34
+ lineClamp: null == textStyle ? void 0 : textStyle.lineClamp,
35
+ ellipsis: null === (_l = null == textStyle ? void 0 : textStyle.ellipsis) || void 0 === _l || _l,
36
+ x: 0,
37
+ y: 0
38
+ }), "wrapText"));
39
+ const maintextHeight = this._mainTitle ? null === (_m = this._mainTitle) || void 0 === _m ? void 0 : _m.AABBBounds.height() : 0, maintextWidth = this._mainTitle ? null === (_o = this._mainTitle) || void 0 === _o ? void 0 : _o.AABBBounds.width() : 0;
40
+ if (!1 !== (null === (_p = this.attribute) || void 0 === _p ? void 0 : _p.visible) && !1 !== (null == subtextStyle ? void 0 : subtextStyle.visible)) if (subtextStyle && isValid(null == subtextStyle ? void 0 : subtextStyle.character)) {
41
+ const attr = {
42
+ x: null !== (_q = subtextStyle.x) && void 0 !== _q ? _q : 0,
43
+ y: null !== (_r = subtextStyle.y) && void 0 !== _r ? _r : maintextHeight,
44
+ width: null !== (_t = null !== (_s = subtextStyle.width) && void 0 !== _s ? _s : width) && void 0 !== _t ? _t : 0,
45
+ height: null !== (_v = null !== (_u = subtextStyle.height) && void 0 !== _u ? _u : height) && void 0 !== _v ? _v : 0,
46
+ ellipsis: null === (_w = subtextStyle.ellipsis) || void 0 === _w || _w,
47
+ wordBreak: null !== (_x = subtextStyle.wordBreak) && void 0 !== _x ? _x : "break-word",
48
+ maxHeight: subtextStyle.maxHeight,
49
+ maxWidth: subtextStyle.maxWidth,
50
+ textConfig: subtextStyle.character
51
+ };
52
+ this._subTitle = group.createOrUpdateChild("subTitle", attr, "richtext");
53
+ } else isValid(subtext) && (this._subTitle = group.createOrUpdateChild("subTitle", Object.assign(Object.assign({
54
+ text: [ subtext ]
55
+ }, subtextStyle), {
56
+ maxLineWidth: null !== (_y = null == subtextStyle ? void 0 : subtextStyle.maxLineWidth) && void 0 !== _y ? _y : width,
57
+ heightLimit: null == subtextStyle ? void 0 : subtextStyle.heightLimit,
58
+ lineClamp: null == subtextStyle ? void 0 : subtextStyle.lineClamp,
59
+ ellipsis: null === (_z = null == subtextStyle ? void 0 : subtextStyle.ellipsis) || void 0 === _z || _z,
60
+ x: 0,
61
+ y: maintextHeight
62
+ }), "wrapText"));
63
+ const subtextHeight = this._subTitle ? null === (_0 = this._subTitle) || void 0 === _0 ? void 0 : _0.AABBBounds.height() : 0, subtextWidth = this._subTitle ? null === (_1 = this._subTitle) || void 0 === _1 ? void 0 : _1.AABBBounds.width() : 0;
64
+ let titleWidth = Math.max(maintextWidth, subtextWidth), titleHeight = maintextHeight + (null !== (_2 = null == subtextStyle ? void 0 : subtextStyle.height) && void 0 !== _2 ? _2 : subtextHeight);
65
+ if (isValid(width) && (titleWidth = width, null === (_3 = this._mainTitle) || void 0 === _3 || _3.setAttribute("maxLineWidth", width),
66
+ null === (_4 = this._subTitle) || void 0 === _4 || _4.setAttribute("maxLineWidth", width)),
67
+ isValid(height) && (titleHeight = height), isValid(minWidth) && titleWidth < minWidth && (titleWidth = minWidth),
68
+ isValid(maxWidth) && (null === (_5 = this._mainTitle) || void 0 === _5 || _5.setAttribute("maxLineWidth", maxWidth),
69
+ null === (_6 = this._subTitle) || void 0 === _6 || _6.setAttribute("maxLineWidth", maxWidth),
70
+ null === (_7 = this._mainTitle) || void 0 === _7 || _7.setAttribute("maxWidth", maxWidth),
71
+ null === (_8 = this._subTitle) || void 0 === _8 || _8.setAttribute("maxWidth", maxWidth),
72
+ titleWidth > maxWidth && (titleWidth = maxWidth)), isValid(minHeight) && titleHeight < minHeight && (titleHeight = minHeight),
73
+ isValid(maxHeight) && (null === (_9 = this._mainTitle) || void 0 === _9 || _9.setAttribute("maxHeight", maxHeight),
74
+ null === (_10 = this._subTitle) || void 0 === _10 || _10.setAttribute("maxHeight", maxHeight - maintextHeight),
75
+ titleHeight > maxHeight && (titleHeight = maxHeight)), group.attribute.width = titleWidth + parsedPadding[1] + parsedPadding[3],
76
+ group.attribute.height = titleHeight + parsedPadding[0] + parsedPadding[2], isValid(align) || isValid(null == textStyle ? void 0 : textStyle.align)) {
77
+ const mainTitleAlign = (null == textStyle ? void 0 : textStyle.align) ? null == textStyle ? void 0 : textStyle.align : align, mainTitleWidth = null !== (_11 = null == textStyle ? void 0 : textStyle.width) && void 0 !== _11 ? _11 : maintextWidth;
78
+ "left" === mainTitleAlign ? (null === (_12 = this._mainTitle) || void 0 === _12 || _12.setAttribute("x", 0),
79
+ null === (_13 = this._mainTitle) || void 0 === _13 || _13.setAttribute("textAlign", "left")) : "center" === mainTitleAlign ? (null === (_14 = this._mainTitle) || void 0 === _14 || _14.setAttribute("x", mainTitleWidth / 2),
80
+ null === (_15 = this._mainTitle) || void 0 === _15 || _15.setAttribute("textAlign", "center")) : "right" === mainTitleAlign && (null === (_16 = this._mainTitle) || void 0 === _16 || _16.setAttribute("x", mainTitleWidth),
81
+ null === (_17 = this._mainTitle) || void 0 === _17 || _17.setAttribute("textAlign", "right"));
82
+ }
83
+ if (isValid(verticalAlign) || isValid(null == textStyle ? void 0 : textStyle.verticalAlign)) {
84
+ const mainTitleVerticalAlign = (null == textStyle ? void 0 : textStyle.verticalAlign) ? null == textStyle ? void 0 : textStyle.verticalAlign : verticalAlign, mainTitleHeight = (null == textStyle ? void 0 : textStyle.height) ? null == textStyle ? void 0 : textStyle.height : titleWidth;
85
+ "top" === mainTitleVerticalAlign ? (null === (_18 = this._mainTitle) || void 0 === _18 || _18.setAttribute("y", 0),
86
+ null === (_19 = this._mainTitle) || void 0 === _19 || _19.setAttribute("textBaseline", "top")) : "middle" === mainTitleVerticalAlign ? (null === (_20 = this._mainTitle) || void 0 === _20 || _20.setAttribute("y", mainTitleHeight / 2),
87
+ null === (_21 = this._mainTitle) || void 0 === _21 || _21.setAttribute("textBaseline", "middle")) : "bottom" === mainTitleVerticalAlign && (null === (_22 = this._mainTitle) || void 0 === _22 || _22.setAttribute("y", mainTitleHeight),
88
+ null === (_23 = this._mainTitle) || void 0 === _23 || _23.setAttribute("textBaseline", "bottom"));
89
+ }
90
+ if (isValid(align) || isValid(null == subtextStyle ? void 0 : subtextStyle.align)) {
91
+ const subTitleAlign = (null == subtextStyle ? void 0 : subtextStyle.align) ? null == subtextStyle ? void 0 : subtextStyle.align : align, subTitleWidth = null !== (_24 = null == subtextStyle ? void 0 : subtextStyle.width) && void 0 !== _24 ? _24 : subtextWidth;
92
+ "left" === subTitleAlign ? (null === (_25 = this._subTitle) || void 0 === _25 || _25.setAttribute("x", 0),
93
+ null === (_26 = this._subTitle) || void 0 === _26 || _26.setAttribute("textAlign", "left")) : "center" === subTitleAlign ? (null === (_27 = this._subTitle) || void 0 === _27 || _27.setAttribute("x", subTitleWidth / 2),
94
+ null === (_28 = this._subTitle) || void 0 === _28 || _28.setAttribute("textAlign", "center")) : "right" === subTitleAlign && (null === (_29 = this._subTitle) || void 0 === _29 || _29.setAttribute("x", subTitleWidth),
95
+ null === (_30 = this._subTitle) || void 0 === _30 || _30.setAttribute("textAlign", "right"));
96
+ }
97
+ if (isValid(verticalAlign) || isValid(null == textStyle ? void 0 : textStyle.verticalAlign)) {
98
+ const subTitleVerticalAlign = (null == subtextStyle ? void 0 : subtextStyle.verticalAlign) ? null == subtextStyle ? void 0 : subtextStyle.verticalAlign : verticalAlign, subTitleYStart = maintextHeight, subTitleHeight = null !== (_31 = null == subtextStyle ? void 0 : subtextStyle.height) && void 0 !== _31 ? _31 : 0;
99
+ "top" === subTitleVerticalAlign ? (null === (_32 = this._subTitle) || void 0 === _32 || _32.setAttribute("y", subTitleYStart),
100
+ null === (_33 = this._subTitle) || void 0 === _33 || _33.setAttribute("textBaseline", "top")) : "middle" === subTitleVerticalAlign ? (null === (_34 = this._subTitle) || void 0 === _34 || _34.setAttribute("y", subTitleYStart + subTitleHeight / 2),
101
+ null === (_35 = this._subTitle) || void 0 === _35 || _35.setAttribute("textBaseline", "middle")) : "bottom" === subTitleVerticalAlign && (null === (_36 = this._subTitle) || void 0 === _36 || _36.setAttribute("y", subTitleYStart + subTitleHeight),
102
+ null === (_37 = this._subTitle) || void 0 === _37 || _37.setAttribute("textBaseline", "bottom"));
103
+ }
104
+ }
105
+ }
106
+
107
+ Title.defaultAttributes = {
108
+ textStyle: {
109
+ ellipsis: "...",
110
+ fillColor: "#333",
111
+ fontSize: 20,
112
+ fontWeight: "bold",
113
+ textAlign: "left",
114
+ textBaseline: "top"
115
+ },
116
+ subtextStyle: {
117
+ ellipsis: "...",
118
+ fillColor: "#6F6F6F",
119
+ fontSize: 16,
120
+ fontWeight: "normal",
121
+ textAlign: "left",
122
+ textBaseline: "top"
123
+ }
124
+ };
125
+ //# sourceMappingURL=title.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/title/title.ts"],"names":[],"mappings":"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","file":"title.js","sourcesContent":["/**\n * @description 标题组件\n */\nimport { IGroup, IText, IRichText } from '@visactor/vrender';\nimport { merge, isValid, normalizePadding } from '@visactor/vutils';\nimport { AbstractComponent } from '../core/base';\nimport { TitleAttrs } from './type';\n\nexport class Title extends AbstractComponent<Required<TitleAttrs>> {\n name = 'title';\n\n private _mainTitle?: IText | IRichText;\n private _subTitle?: IText | IRichText;\n\n static defaultAttributes: Partial<TitleAttrs> = {\n textStyle: {\n ellipsis: '...',\n fillColor: '#333',\n fontSize: 20,\n fontWeight: 'bold',\n textAlign: 'left',\n textBaseline: 'top'\n },\n subtextStyle: {\n ellipsis: '...',\n fillColor: '#6F6F6F',\n fontSize: 16,\n fontWeight: 'normal',\n textAlign: 'left',\n textBaseline: 'top'\n }\n };\n\n constructor(attributes: TitleAttrs) {\n super(merge({}, Title.defaultAttributes, attributes));\n }\n\n protected render() {\n const {\n text,\n textStyle,\n subtext,\n subtextStyle,\n width,\n height,\n minWidth,\n maxWidth,\n minHeight,\n maxHeight,\n align,\n verticalAlign,\n padding = 0\n } = this.attribute as TitleAttrs;\n\n const parsedPadding = normalizePadding(padding);\n\n const group = this.createOrUpdateChild(\n 'title-container',\n { x: parsedPadding[3], y: parsedPadding[0], zIndex: 1 },\n 'group'\n ) as IGroup;\n\n if (this.attribute?.visible !== false && textStyle?.visible !== false) {\n if (textStyle && isValid(textStyle?.character)) {\n const attr = {\n x: textStyle.x ?? 0,\n y: textStyle.y ?? 0,\n width: textStyle.width ?? width ?? 0,\n height: textStyle.height ?? height ?? 0,\n ellipsis: textStyle.ellipsis ?? true,\n wordBreak: textStyle.wordBreak ?? 'break-word',\n maxHeight: textStyle.maxHeight,\n maxWidth: textStyle.maxWidth,\n textConfig: textStyle.character\n };\n this._mainTitle = group.createOrUpdateChild('mainTitle', attr, 'richtext') as IRichText;\n } else if (isValid(text)) {\n this._mainTitle = group.createOrUpdateChild(\n 'mainTitle',\n {\n text: [text as string],\n ...textStyle,\n maxLineWidth: textStyle?.maxLineWidth ?? width,\n heightLimit: textStyle?.heightLimit,\n lineClamp: textStyle?.lineClamp,\n ellipsis: textStyle?.ellipsis ?? true,\n x: 0,\n y: 0\n },\n 'wrapText'\n ) as IText;\n }\n }\n\n const maintextHeight = this._mainTitle ? this._mainTitle?.AABBBounds.height() : 0;\n const maintextWidth = this._mainTitle ? this._mainTitle?.AABBBounds.width() : 0;\n\n if (this.attribute?.visible !== false && subtextStyle?.visible !== false) {\n if (subtextStyle && isValid(subtextStyle?.character)) {\n const attr = {\n x: subtextStyle.x ?? 0,\n y: subtextStyle.y ?? maintextHeight,\n width: subtextStyle.width ?? width ?? 0,\n height: subtextStyle.height ?? height ?? 0,\n ellipsis: subtextStyle.ellipsis ?? true,\n wordBreak: subtextStyle.wordBreak ?? 'break-word',\n maxHeight: subtextStyle.maxHeight,\n maxWidth: subtextStyle.maxWidth,\n textConfig: subtextStyle.character\n };\n this._subTitle = group.createOrUpdateChild('subTitle', attr, 'richtext') as IRichText;\n } else if (isValid(subtext)) {\n this._subTitle = group.createOrUpdateChild(\n 'subTitle',\n {\n text: [subtext as string],\n ...subtextStyle,\n maxLineWidth: subtextStyle?.maxLineWidth ?? width,\n heightLimit: subtextStyle?.heightLimit,\n lineClamp: subtextStyle?.lineClamp,\n ellipsis: subtextStyle?.ellipsis ?? true,\n x: 0,\n y: maintextHeight\n },\n 'wrapText'\n ) as IText;\n }\n }\n\n const subtextHeight = this._subTitle ? this._subTitle?.AABBBounds.height() : 0;\n const subtextWidth = this._subTitle ? this._subTitle?.AABBBounds.width() : 0;\n\n // 设置宽高\n let titleWidth = Math.max(maintextWidth, subtextWidth);\n let titleHeight = maintextHeight + (subtextStyle?.height ?? subtextHeight);\n\n if (isValid(width)) {\n titleWidth = width;\n this._mainTitle?.setAttribute('maxLineWidth', width);\n this._subTitle?.setAttribute('maxLineWidth', width);\n }\n\n if (isValid(height)) {\n titleHeight = height;\n }\n\n if (isValid(minWidth) && titleWidth < minWidth) {\n titleWidth = minWidth;\n }\n if (isValid(maxWidth)) {\n this._mainTitle?.setAttribute('maxLineWidth', maxWidth);\n this._subTitle?.setAttribute('maxLineWidth', maxWidth);\n this._mainTitle?.setAttribute('maxWidth', maxWidth);\n this._subTitle?.setAttribute('maxWidth', maxWidth);\n if (titleWidth > maxWidth) {\n titleWidth = maxWidth;\n }\n }\n\n if (isValid(minHeight) && titleHeight < minHeight) {\n titleHeight = minHeight;\n }\n if (isValid(maxHeight)) {\n this._mainTitle?.setAttribute('maxHeight', maxHeight);\n this._subTitle?.setAttribute('maxHeight', maxHeight - maintextHeight);\n if (titleHeight > maxHeight) {\n titleHeight = maxHeight;\n }\n }\n\n group.attribute.width = titleWidth + parsedPadding[1] + parsedPadding[3];\n group.attribute.height = titleHeight + parsedPadding[0] + parsedPadding[2];\n\n // 设置对齐\n if (isValid(align) || isValid(textStyle?.align)) {\n const mainTitleAlign = textStyle?.align ? textStyle?.align : align;\n const mainTitleWidth = textStyle?.width ?? maintextWidth;\n if (mainTitleAlign === 'left') {\n this._mainTitle?.setAttribute('x', 0);\n this._mainTitle?.setAttribute('textAlign', 'left');\n } else if (mainTitleAlign === 'center') {\n this._mainTitle?.setAttribute('x', mainTitleWidth / 2);\n this._mainTitle?.setAttribute('textAlign', 'center');\n } else if (mainTitleAlign === 'right') {\n this._mainTitle?.setAttribute('x', mainTitleWidth);\n this._mainTitle?.setAttribute('textAlign', 'right');\n }\n }\n\n if (isValid(verticalAlign) || isValid(textStyle?.verticalAlign)) {\n const mainTitleVerticalAlign = textStyle?.verticalAlign ? textStyle?.verticalAlign : verticalAlign;\n const mainTitleHeight = textStyle?.height ? textStyle?.height : titleWidth;\n if (mainTitleVerticalAlign === 'top') {\n this._mainTitle?.setAttribute('y', 0);\n this._mainTitle?.setAttribute('textBaseline', 'top');\n } else if (mainTitleVerticalAlign === 'middle') {\n this._mainTitle?.setAttribute('y', mainTitleHeight / 2);\n this._mainTitle?.setAttribute('textBaseline', 'middle');\n } else if (mainTitleVerticalAlign === 'bottom') {\n this._mainTitle?.setAttribute('y', mainTitleHeight);\n this._mainTitle?.setAttribute('textBaseline', 'bottom');\n }\n }\n\n if (isValid(align) || isValid(subtextStyle?.align)) {\n const subTitleAlign = subtextStyle?.align ? subtextStyle?.align : align;\n const subTitleWidth = subtextStyle?.width ?? subtextWidth;\n if (subTitleAlign === 'left') {\n this._subTitle?.setAttribute('x', 0);\n this._subTitle?.setAttribute('textAlign', 'left');\n } else if (subTitleAlign === 'center') {\n this._subTitle?.setAttribute('x', subTitleWidth / 2);\n this._subTitle?.setAttribute('textAlign', 'center');\n } else if (subTitleAlign === 'right') {\n this._subTitle?.setAttribute('x', subTitleWidth);\n this._subTitle?.setAttribute('textAlign', 'right');\n }\n }\n\n if (isValid(verticalAlign) || isValid(textStyle?.verticalAlign)) {\n const subTitleVerticalAlign = subtextStyle?.verticalAlign ? subtextStyle?.verticalAlign : verticalAlign;\n const subTitleYStart = maintextHeight;\n const subTitleHeight = subtextStyle?.height ?? 0;\n if (subTitleVerticalAlign === 'top') {\n this._subTitle?.setAttribute('y', subTitleYStart);\n this._subTitle?.setAttribute('textBaseline', 'top');\n } else if (subTitleVerticalAlign === 'middle') {\n this._subTitle?.setAttribute('y', subTitleYStart + subTitleHeight / 2);\n this._subTitle?.setAttribute('textBaseline', 'middle');\n } else if (subTitleVerticalAlign === 'bottom') {\n this._subTitle?.setAttribute('y', subTitleYStart + subTitleHeight);\n this._subTitle?.setAttribute('textBaseline', 'bottom');\n }\n }\n }\n}\n"]}
@@ -0,0 +1,41 @@
1
+ import type { IGroupGraphicAttribute, ITextGraphicAttribute, IRichTextCharacter, RichTextWordBreak } from '@visactor/vrender';
2
+ import { Padding } from '../core/type';
3
+ export interface TitleAttrs extends IGroupGraphicAttribute {
4
+ text?: string | number | string[] | number[];
5
+ subtext?: string | number | string[] | number[];
6
+ width?: number;
7
+ height?: number;
8
+ minWidth?: number;
9
+ maxWidth?: number;
10
+ minHeight?: number;
11
+ maxHeight?: number;
12
+ padding?: Padding;
13
+ align?: string;
14
+ verticalAlign?: string;
15
+ textStyle?: {
16
+ width?: number;
17
+ height?: number;
18
+ maxWidth?: number;
19
+ maxHeight?: number;
20
+ align?: string;
21
+ verticalAlign?: string;
22
+ wordBreak?: RichTextWordBreak;
23
+ maxLineWidth?: number;
24
+ heightLimit?: number;
25
+ lineClamp?: number;
26
+ character?: IRichTextCharacter[];
27
+ } & Partial<ITextGraphicAttribute>;
28
+ subtextStyle?: {
29
+ width?: number;
30
+ height?: number;
31
+ maxWidth?: number;
32
+ maxHeight?: number;
33
+ align?: string;
34
+ verticalAlign?: string;
35
+ wordBreak?: RichTextWordBreak;
36
+ maxLineWidth?: number;
37
+ heightLimit?: number;
38
+ lineClamp?: number;
39
+ character?: IRichTextCharacter[];
40
+ } & Partial<ITextGraphicAttribute>;
41
+ }
@@ -0,0 +1,2 @@
1
+ export { };
2
+ //# sourceMappingURL=type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/title/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import type { IGroupGraphicAttribute, ITextGraphicAttribute, IRichTextCharacter, RichTextWordBreak } from '@visactor/vrender';\nimport { Padding } from '../core/type';\n\nexport interface TitleAttrs extends IGroupGraphicAttribute {\n /**\n * 主标题文本内容\n */\n text?: string | number | string[] | number[];\n /**\n * 副标题文本内容\n */\n subtext?: string | number | string[] | number[];\n /**\n * 指定宽度,像素值\n */\n width?: number;\n /**\n * 指定高度,像素值\n */\n height?: number;\n /**\n * 最小宽度,像素值\n */\n minWidth?: number;\n /**\n * 最大宽度,像素值。当文字超过最大宽度时,会自动省略。\n */\n maxWidth?: number;\n /**\n * 最小高度,像素值\n */\n minHeight?: number;\n /**\n * 最大高度,像素值\n */\n maxHeight?: number;\n /**\n * 内部边距\n */\n padding?: Padding;\n /**\n * 整体(包括 text 和 subtext)的水平对齐\n * 'left' | 'center' | 'right'\n */\n align?: string;\n /**\n * 整体(包括 text 和 subtext)的垂直对齐\n * 'top' | 'middle' | 'bottom'\n */\n verticalAlign?: string;\n /**\n * 主标题样式\n */\n textStyle?: {\n /** 指定宽度 */\n width?: number;\n /** 指定高度 */\n height?: number;\n /** 最大宽度 */\n maxWidth?: number;\n /** 最大高度 */\n maxHeight?: number;\n /**\n * 文字水平对齐方式\n * 'left' | 'center' | 'right'\n */\n align?: string;\n /**\n * 文字垂直对齐方式\n * 'top' | 'middle' | 'bottom'\n */\n verticalAlign?: string;\n /**\n * 折行方式\n * 'break-word' | 'break-all'\n */\n wordBreak?: RichTextWordBreak;\n /**\n * 按照宽度限制自动折行或显示省略号(maxLineWidth)\n * 默认设置为title宽度\n */\n maxLineWidth?: number;\n /**\n * 高度限制控制显示内容及省略号(heightLimit)\n */\n heightLimit?: number;\n /**\n * 按照行数限制显示内容及省略号(lineClamp)\n */\n lineClamp?: number;\n /**\n * 富文本配置\n */\n character?: IRichTextCharacter[];\n } & Partial<ITextGraphicAttribute>;\n /**\n * 副标题样式\n */\n subtextStyle?: {\n /** 指定宽度 */\n width?: number;\n /** 指定高度 */\n height?: number;\n /** 最大宽度 */\n maxWidth?: number;\n /** 最大高度 */\n maxHeight?: number;\n /**\n * 文字水平对齐方式\n * 'left' | 'center' | 'right'\n */\n align?: string;\n /**\n * 文字垂直对齐方式\n * 'top' | 'middle' | 'bottom'\n */\n verticalAlign?: string;\n /**\n * 折行方式\n * 'break-word' | 'break-all'\n */\n wordBreak?: RichTextWordBreak;\n /**\n * 按照宽度限制自动折行或显示省略号(maxLineWidth)\n * 默认设置为title宽度\n */\n maxLineWidth?: number;\n /**\n * 高度限制控制显示内容及省略号(heightLimit)\n */\n heightLimit?: number;\n /**\n * 按照行数限制显示内容及省略号(lineClamp)\n */\n lineClamp?: number;\n /**\n * 富文本配置\n */\n character?: IRichTextCharacter[];\n } & Partial<ITextGraphicAttribute>;\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { TooltipAttributes } from './type';
2
+ export declare const defaultAttributes: Partial<TooltipAttributes>;
3
+ export declare const TOOLTIP_POSITION_ATTRIBUTES: string[];
@@ -0,0 +1,76 @@
1
+ import { AABBBounds } from "@visactor/vutils";
2
+
3
+ import { DEFAULT_TEXT_FONT_FAMILY } from "../constant";
4
+
5
+ export const defaultAttributes = {
6
+ panel: {
7
+ visible: !0,
8
+ borderRadius: [ 3, 3, 3, 3 ],
9
+ fill: !0,
10
+ fillColor: "white",
11
+ shadow: !0,
12
+ shadowBlur: 12,
13
+ shadowColor: "rgba(0, 0, 0, 0.1)",
14
+ shadowOffsetX: 0,
15
+ shadowOffsetY: 4,
16
+ shadowSpread: 0,
17
+ stroke: !0,
18
+ strokeColor: "white"
19
+ },
20
+ titleStyle: {
21
+ value: {
22
+ fill: !0,
23
+ fillColor: "#4E5969",
24
+ fontFamily: DEFAULT_TEXT_FONT_FAMILY,
25
+ fontSize: 14,
26
+ lineHeight: 18,
27
+ textAlign: "left",
28
+ textBaseline: "middle"
29
+ },
30
+ spaceRow: 6
31
+ },
32
+ contentStyle: {
33
+ shape: {
34
+ fill: !0,
35
+ fillColor: "black",
36
+ size: 8,
37
+ symbolType: "circle",
38
+ spacing: 6
39
+ },
40
+ key: {
41
+ fill: !0,
42
+ fillColor: "#4E5969",
43
+ fontFamily: DEFAULT_TEXT_FONT_FAMILY,
44
+ fontSize: 12,
45
+ lineHeight: 18,
46
+ textAlign: "left",
47
+ textBaseline: "middle",
48
+ spacing: 26
49
+ },
50
+ value: {
51
+ fill: !0,
52
+ fillColor: "#4E5969",
53
+ fontFamily: DEFAULT_TEXT_FONT_FAMILY,
54
+ fontSize: 12,
55
+ lineHeight: 18,
56
+ textAlign: "right",
57
+ textBaseline: "middle",
58
+ spacing: 0
59
+ },
60
+ spaceRow: 6
61
+ },
62
+ padding: 10,
63
+ positionX: "right",
64
+ positionY: "bottom",
65
+ offsetX: 10,
66
+ offsetY: 10,
67
+ parentBounds: (new AABBBounds).setValue(Number.NEGATIVE_INFINITY, Number.NEGATIVE_INFINITY, Number.POSITIVE_INFINITY, Number.POSITIVE_INFINITY),
68
+ autoCalculatePosition: !0,
69
+ autoMeasure: !0,
70
+ pickable: !1,
71
+ childrenPickable: !1,
72
+ zIndex: 500
73
+ };
74
+
75
+ export const TOOLTIP_POSITION_ATTRIBUTES = [ "pointerX", "pointerY", "offsetX", "offsetY", "positionX", "positionY", "parentBounds" ];
76
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tooltip/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AAGvD,MAAM,CAAC,MAAM,iBAAiB,GAA+B;IAC3D,KAAK,EAAE;QACL,OAAO,EAAE,IAAI;QACb,YAAY,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAC1B,IAAI,EAAE,IAAI;QACV,SAAS,EAAE,OAAO;QAClB,MAAM,EAAE,IAAI;QACZ,UAAU,EAAE,EAAE;QACd,WAAW,EAAE,oBAAoB;QACjC,aAAa,EAAE,CAAC;QAChB,aAAa,EAAE,CAAC;QAChB,YAAY,EAAE,CAAC;QACf,MAAM,EAAE,IAAI;QACZ,WAAW,EAAE,OAAO;KACrB;IACD,UAAU,EAAE;QACV,KAAK,EAAE;YACL,IAAI,EAAE,IAAI;YACV,SAAS,EAAE,SAAS;YACpB,UAAU,EAAE,wBAAwB;YACpC,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;YACd,SAAS,EAAE,MAAM;YACjB,YAAY,EAAE,QAAQ;SACvB;QACD,QAAQ,EAAE,CAAC;KACZ;IACD,YAAY,EAAE;QACZ,KAAK,EAAE;YACL,IAAI,EAAE,IAAI;YACV,SAAS,EAAE,OAAO;YAClB,IAAI,EAAE,CAAC;YACP,UAAU,EAAE,QAAQ;YACpB,OAAO,EAAE,CAAC;SACX;QACD,GAAG,EAAE;YACH,IAAI,EAAE,IAAI;YACV,SAAS,EAAE,SAAS;YACpB,UAAU,EAAE,wBAAwB;YACpC,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;YACd,SAAS,EAAE,MAAM;YACjB,YAAY,EAAE,QAAQ;YACtB,OAAO,EAAE,EAAE;SACZ;QACD,KAAK,EAAE;YACL,IAAI,EAAE,IAAI;YACV,SAAS,EAAE,SAAS;YACpB,UAAU,EAAE,wBAAwB;YACpC,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;YACd,SAAS,EAAE,OAAO;YAClB,YAAY,EAAE,QAAQ;YACtB,OAAO,EAAE,CAAC;SACX;QACD,QAAQ,EAAE,CAAC;KACZ;IACD,OAAO,EAAE,EAAE;IACX,SAAS,EAAE,OAAO;IAClB,SAAS,EAAE,QAAQ;IACnB,OAAO,EAAE,EAAE;IACX,OAAO,EAAE,EAAE;IACX,YAAY,EAAE,IAAI,UAAU,EAAE,CAAC,QAAQ,CACrC,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,iBAAiB,CACzB;IACD,qBAAqB,EAAE,IAAI;IAC3B,WAAW,EAAE,IAAI;IAEjB,QAAQ,EAAE,KAAK;IACf,gBAAgB,EAAE,KAAK;IACvB,MAAM,EAAE,GAAG;CACZ,CAAC;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAG;IACzC,UAAU;IACV,UAAU;IACV,SAAS;IACT,SAAS;IACT,WAAW;IACX,WAAW;IACX,cAAc;CACf,CAAC","file":"config.js","sourcesContent":["import { AABBBounds } from '@visactor/vutils';\nimport { DEFAULT_TEXT_FONT_FAMILY } from '../constant';\nimport { TooltipAttributes } from './type';\n\nexport const defaultAttributes: Partial<TooltipAttributes> = {\n panel: {\n visible: true,\n borderRadius: [3, 3, 3, 3],\n fill: true,\n fillColor: 'white',\n shadow: true,\n shadowBlur: 12,\n shadowColor: 'rgba(0, 0, 0, 0.1)',\n shadowOffsetX: 0,\n shadowOffsetY: 4,\n shadowSpread: 0,\n stroke: true,\n strokeColor: 'white'\n },\n titleStyle: {\n value: {\n fill: true,\n fillColor: '#4E5969',\n fontFamily: DEFAULT_TEXT_FONT_FAMILY,\n fontSize: 14,\n lineHeight: 18,\n textAlign: 'left',\n textBaseline: 'middle'\n },\n spaceRow: 6\n },\n contentStyle: {\n shape: {\n fill: true,\n fillColor: 'black',\n size: 8,\n symbolType: 'circle',\n spacing: 6\n },\n key: {\n fill: true,\n fillColor: '#4E5969',\n fontFamily: DEFAULT_TEXT_FONT_FAMILY,\n fontSize: 12,\n lineHeight: 18,\n textAlign: 'left',\n textBaseline: 'middle',\n spacing: 26\n },\n value: {\n fill: true,\n fillColor: '#4E5969',\n fontFamily: DEFAULT_TEXT_FONT_FAMILY,\n fontSize: 12,\n lineHeight: 18,\n textAlign: 'right',\n textBaseline: 'middle',\n spacing: 0\n },\n spaceRow: 6\n },\n padding: 10,\n positionX: 'right',\n positionY: 'bottom',\n offsetX: 10,\n offsetY: 10,\n parentBounds: new AABBBounds().setValue(\n Number.NEGATIVE_INFINITY,\n Number.NEGATIVE_INFINITY,\n Number.POSITIVE_INFINITY,\n Number.POSITIVE_INFINITY\n ),\n autoCalculatePosition: true,\n autoMeasure: true,\n\n pickable: false,\n childrenPickable: false,\n zIndex: 500\n};\n\nexport const TOOLTIP_POSITION_ATTRIBUTES = [\n 'pointerX',\n 'pointerY',\n 'offsetX',\n 'offsetY',\n 'positionX',\n 'positionY',\n 'parentBounds'\n];\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './tooltip';
2
+ export * from './type';
@@ -0,0 +1,4 @@
1
+ export * from "./tooltip";
2
+
3
+ export * from "./type";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tooltip/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,QAAQ,CAAC","file":"index.js","sourcesContent":["export * from './tooltip';\nexport * from './type';\n"]}