@antv/infographic 0.1.2 → 0.1.4

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 (676) hide show
  1. package/README.md +26 -2
  2. package/README.zh-CN.md +26 -3
  3. package/dist/infographic.min.js +491 -81
  4. package/dist/infographic.min.js.map +1 -1
  5. package/esm/constants/components.d.ts +1 -0
  6. package/esm/constants/components.js +1 -0
  7. package/esm/constants/element.d.ts +17 -6
  8. package/esm/constants/index.d.ts +3 -0
  9. package/esm/constants/index.js +3 -0
  10. package/esm/constants/service.d.ts +1 -0
  11. package/esm/constants/service.js +1 -0
  12. package/esm/constants/shape.d.ts +16 -0
  13. package/esm/designs/components/Btn.js +2 -2
  14. package/esm/designs/components/BtnsGroup.js +1 -1
  15. package/esm/designs/components/Illus.js +2 -2
  16. package/esm/designs/components/ItemDesc.js +1 -2
  17. package/esm/designs/components/ItemIcon.js +1 -1
  18. package/esm/designs/components/ItemLabel.js +1 -2
  19. package/esm/designs/components/ItemValue.js +1 -2
  20. package/esm/designs/components/ItemsGroup.js +1 -1
  21. package/esm/designs/components/Title.js +2 -5
  22. package/esm/designs/items/CandyCardLite.js +1 -1
  23. package/esm/designs/items/CircularProgress.js +2 -1
  24. package/esm/designs/items/HorizontalIconArrow.js +1 -2
  25. package/esm/designs/items/HorizontalIconLine.js +1 -1
  26. package/esm/designs/items/IconBadge.js +1 -1
  27. package/esm/designs/items/LinedText.d.ts +12 -0
  28. package/esm/designs/items/LinedText.js +57 -0
  29. package/esm/designs/items/PlainText.d.ts +1 -0
  30. package/esm/designs/items/PlainText.js +16 -3
  31. package/esm/designs/items/QuarterCircular.js +1 -31
  32. package/esm/designs/items/index.d.ts +1 -0
  33. package/esm/designs/items/index.js +1 -0
  34. package/esm/designs/layouts/Align.js +31 -45
  35. package/esm/designs/layouts/Flex.js +33 -29
  36. package/esm/designs/structures/chart-bar.d.ts +15 -0
  37. package/esm/designs/structures/chart-bar.js +99 -0
  38. package/esm/designs/structures/chart-line.d.ts +12 -0
  39. package/esm/designs/structures/chart-line.js +164 -0
  40. package/esm/designs/structures/chart-pie.d.ts +9 -0
  41. package/esm/designs/structures/chart-pie.js +127 -0
  42. package/esm/designs/structures/chart-wordcloud.d.ts +11 -0
  43. package/esm/designs/structures/chart-wordcloud.js +156 -0
  44. package/esm/designs/structures/compare-binary-horizontal/dividers/pros-cons-arrow.js +1 -1
  45. package/esm/designs/structures/hierarchy-mindmap.d.ts +24 -0
  46. package/esm/designs/structures/hierarchy-mindmap.js +199 -0
  47. package/esm/designs/structures/hierarchy-tree.d.ts +2 -0
  48. package/esm/designs/structures/hierarchy-tree.js +179 -50
  49. package/esm/designs/structures/index.d.ts +6 -0
  50. package/esm/designs/structures/index.js +6 -0
  51. package/esm/designs/structures/list-sector.js +1 -1
  52. package/esm/designs/structures/sequence-circular.js +1 -1
  53. package/esm/designs/structures/sequence-cylinders-3d.js +4 -4
  54. package/esm/designs/structures/sequence-roadmap-vertical.js +1 -1
  55. package/esm/designs/structures/sequence-stairs-front.d.ts +8 -0
  56. package/esm/designs/structures/sequence-stairs-front.js +116 -0
  57. package/esm/designs/structures/sequence-zigzag-pucks-3d.js +5 -5
  58. package/esm/designs/types.d.ts +8 -0
  59. package/esm/editor/commands/Batch.d.ts +11 -0
  60. package/esm/editor/commands/Batch.js +21 -0
  61. package/esm/editor/commands/UpdateElement.d.ts +16 -0
  62. package/esm/editor/commands/UpdateElement.js +83 -0
  63. package/esm/editor/commands/UpdateOptions.d.ts +14 -0
  64. package/esm/editor/commands/UpdateOptions.js +25 -0
  65. package/esm/editor/commands/UpdateText.d.ts +16 -0
  66. package/esm/editor/commands/UpdateText.js +40 -0
  67. package/esm/editor/commands/index.d.ts +4 -0
  68. package/esm/editor/commands/index.js +4 -0
  69. package/esm/editor/editor.d.ts +16 -0
  70. package/esm/editor/editor.js +50 -0
  71. package/esm/editor/index.d.ts +4 -0
  72. package/esm/editor/index.js +3 -0
  73. package/esm/editor/interactions/base.d.ts +12 -0
  74. package/esm/editor/interactions/base.js +5 -0
  75. package/esm/editor/interactions/brush-select.d.ts +23 -0
  76. package/esm/editor/interactions/brush-select.js +167 -0
  77. package/esm/editor/interactions/click-select.d.ts +12 -0
  78. package/esm/editor/interactions/click-select.js +67 -0
  79. package/esm/editor/interactions/dblclick-edit-text.d.ts +10 -0
  80. package/esm/editor/interactions/dblclick-edit-text.js +204 -0
  81. package/esm/editor/interactions/drag-element.d.ts +41 -0
  82. package/esm/editor/interactions/drag-element.js +391 -0
  83. package/esm/editor/interactions/hotkey-history.d.ts +10 -0
  84. package/esm/editor/interactions/hotkey-history.js +27 -0
  85. package/esm/editor/interactions/index.d.ts +8 -0
  86. package/esm/editor/interactions/index.js +8 -0
  87. package/esm/editor/interactions/select-highlight.d.ts +16 -0
  88. package/esm/editor/interactions/select-highlight.js +99 -0
  89. package/esm/editor/interactions/zoom-wheel.d.ts +8 -0
  90. package/esm/editor/interactions/zoom-wheel.js +46 -0
  91. package/esm/editor/managers/command.d.ts +19 -0
  92. package/esm/editor/managers/command.js +63 -0
  93. package/esm/editor/managers/index.d.ts +4 -0
  94. package/esm/editor/managers/index.js +4 -0
  95. package/esm/editor/managers/interaction.d.ts +33 -0
  96. package/esm/editor/managers/interaction.js +196 -0
  97. package/esm/editor/managers/plugin.d.ts +14 -0
  98. package/esm/editor/managers/plugin.js +45 -0
  99. package/esm/editor/managers/state.d.ts +22 -0
  100. package/esm/editor/managers/state.js +141 -0
  101. package/esm/editor/plugins/base.d.ts +12 -0
  102. package/esm/editor/plugins/base.js +5 -0
  103. package/esm/editor/plugins/edit-bar/components/button.d.ts +12 -0
  104. package/esm/editor/plugins/edit-bar/components/button.js +53 -0
  105. package/esm/editor/plugins/edit-bar/components/color-picker.d.ts +10 -0
  106. package/esm/editor/plugins/edit-bar/components/color-picker.js +351 -0
  107. package/esm/editor/plugins/edit-bar/components/icons.d.ts +26 -0
  108. package/esm/editor/plugins/edit-bar/components/icons.js +30 -0
  109. package/esm/editor/plugins/edit-bar/components/index.d.ts +5 -0
  110. package/esm/editor/plugins/edit-bar/components/index.js +5 -0
  111. package/esm/editor/plugins/edit-bar/components/popover.d.ts +23 -0
  112. package/esm/editor/plugins/edit-bar/components/popover.js +378 -0
  113. package/esm/editor/plugins/edit-bar/components/select.d.ts +22 -0
  114. package/esm/editor/plugins/edit-bar/components/select.js +201 -0
  115. package/esm/editor/plugins/edit-bar/edit-bar.d.ts +32 -0
  116. package/esm/editor/plugins/edit-bar/edit-bar.js +211 -0
  117. package/esm/editor/plugins/edit-bar/edit-items/align-elements.d.ts +2 -0
  118. package/esm/editor/plugins/edit-bar/edit-items/align-elements.js +312 -0
  119. package/esm/editor/plugins/edit-bar/edit-items/font-align.d.ts +3 -0
  120. package/esm/editor/plugins/edit-bar/edit-items/font-align.js +81 -0
  121. package/esm/editor/plugins/edit-bar/edit-items/font-color.d.ts +3 -0
  122. package/esm/editor/plugins/edit-bar/edit-items/font-color.js +77 -0
  123. package/esm/editor/plugins/edit-bar/edit-items/font-family.d.ts +3 -0
  124. package/esm/editor/plugins/edit-bar/edit-items/font-family.js +115 -0
  125. package/esm/editor/plugins/edit-bar/edit-items/font-size.d.ts +3 -0
  126. package/esm/editor/plugins/edit-bar/edit-items/font-size.js +88 -0
  127. package/esm/editor/plugins/edit-bar/edit-items/icon-color.d.ts +3 -0
  128. package/esm/editor/plugins/edit-bar/edit-items/icon-color.js +77 -0
  129. package/esm/editor/plugins/edit-bar/edit-items/index.d.ts +7 -0
  130. package/esm/editor/plugins/edit-bar/edit-items/index.js +6 -0
  131. package/esm/editor/plugins/edit-bar/edit-items/types.d.ts +3 -0
  132. package/esm/editor/plugins/edit-bar/index.d.ts +4 -0
  133. package/esm/editor/plugins/edit-bar/index.js +2 -0
  134. package/esm/editor/plugins/edit-bar/utils.d.ts +4 -0
  135. package/esm/editor/plugins/edit-bar/utils.js +14 -0
  136. package/esm/editor/plugins/index.d.ts +3 -0
  137. package/esm/editor/plugins/index.js +3 -0
  138. package/esm/editor/plugins/resize-element.d.ts +45 -0
  139. package/esm/editor/plugins/resize-element.js +393 -0
  140. package/esm/editor/types/command.d.ts +28 -0
  141. package/esm/editor/types/command.js +1 -0
  142. package/esm/editor/types/editor.d.ts +4 -0
  143. package/esm/editor/types/editor.js +1 -0
  144. package/esm/editor/types/index.d.ts +7 -0
  145. package/esm/editor/types/index.js +1 -0
  146. package/esm/editor/types/interaction.d.ts +44 -0
  147. package/esm/editor/types/interaction.js +1 -0
  148. package/esm/editor/types/plugin.d.ts +30 -0
  149. package/esm/editor/types/plugin.js +1 -0
  150. package/esm/editor/types/selection.d.ts +2 -0
  151. package/esm/editor/types/selection.js +1 -0
  152. package/esm/editor/types/shape.d.ts +16 -0
  153. package/esm/editor/types/shape.js +1 -0
  154. package/esm/editor/types/state.d.ts +57 -0
  155. package/esm/editor/types/state.js +1 -0
  156. package/esm/editor/utils/click-handler.d.ts +28 -0
  157. package/esm/editor/utils/click-handler.js +97 -0
  158. package/esm/editor/utils/coordinate.d.ts +6 -0
  159. package/esm/editor/utils/coordinate.js +31 -0
  160. package/esm/editor/utils/data.d.ts +10 -0
  161. package/esm/editor/utils/data.js +18 -0
  162. package/esm/editor/utils/element.d.ts +2 -0
  163. package/esm/editor/utils/element.js +9 -0
  164. package/esm/editor/utils/event.d.ts +3 -0
  165. package/esm/editor/utils/event.js +63 -0
  166. package/esm/editor/utils/extension.d.ts +13 -0
  167. package/esm/editor/utils/extension.js +39 -0
  168. package/esm/editor/utils/hotkey.d.ts +20 -0
  169. package/esm/editor/utils/hotkey.js +109 -0
  170. package/esm/editor/utils/index.d.ts +7 -0
  171. package/esm/editor/utils/index.js +7 -0
  172. package/esm/exporter/svg.js +7 -5
  173. package/esm/index.d.ts +7 -2
  174. package/esm/index.js +3 -0
  175. package/esm/jsx/components/Polygon.js +2 -1
  176. package/esm/jsx/components/Text.js +66 -68
  177. package/esm/options/parser.d.ts +1 -1
  178. package/esm/options/parser.js +33 -15
  179. package/esm/options/types.d.ts +15 -2
  180. package/esm/renderer/composites/background.js +2 -2
  181. package/esm/renderer/composites/button.js +4 -3
  182. package/esm/renderer/composites/icon.d.ts +1 -1
  183. package/esm/renderer/composites/icon.js +3 -1
  184. package/esm/renderer/composites/illus.js +1 -1
  185. package/esm/renderer/composites/text.js +2 -1
  186. package/esm/renderer/renderer.js +3 -2
  187. package/esm/renderer/stylize/rough.js +3 -7
  188. package/esm/renderer/types/index.d.ts +0 -1
  189. package/esm/resource/loader.d.ts +2 -2
  190. package/esm/resource/loader.js +22 -11
  191. package/esm/resource/loaders/index.d.ts +1 -0
  192. package/esm/resource/loaders/index.js +1 -0
  193. package/esm/resource/loaders/remote.d.ts +1 -1
  194. package/esm/resource/loaders/remote.js +10 -2
  195. package/esm/resource/loaders/search.d.ts +1 -0
  196. package/esm/resource/loaders/search.js +51 -0
  197. package/esm/resource/types/index.d.ts +1 -0
  198. package/esm/resource/types/resource.d.ts +8 -1
  199. package/esm/resource/types/scene.d.ts +1 -0
  200. package/esm/resource/types/scene.js +1 -0
  201. package/esm/resource/utils/data-uri.js +20 -11
  202. package/esm/resource/utils/index.d.ts +0 -1
  203. package/esm/resource/utils/index.js +0 -1
  204. package/esm/resource/utils/parser.js +92 -1
  205. package/esm/resource/utils/ref.js +3 -3
  206. package/esm/runtime/Infographic.d.ts +14 -7
  207. package/esm/runtime/Infographic.js +70 -10
  208. package/esm/runtime/options.d.ts +2 -0
  209. package/esm/runtime/options.js +24 -0
  210. package/esm/runtime/utils.d.ts +4 -0
  211. package/esm/runtime/utils.js +38 -0
  212. package/esm/syntax/index.d.ts +3 -0
  213. package/esm/syntax/index.js +101 -0
  214. package/esm/syntax/mapper.d.ts +3 -0
  215. package/esm/syntax/mapper.js +238 -0
  216. package/esm/syntax/parser.d.ts +14 -0
  217. package/esm/syntax/parser.js +142 -0
  218. package/esm/syntax/schema.d.ts +6 -0
  219. package/esm/syntax/schema.js +74 -0
  220. package/esm/syntax/types.d.ts +61 -0
  221. package/esm/syntax/types.js +1 -0
  222. package/esm/templates/built-in.js +116 -1
  223. package/esm/templates/hierarchy-mindmap.d.ts +2 -0
  224. package/esm/templates/hierarchy-mindmap.js +61 -0
  225. package/esm/templates/hierarchy-tree.js +25 -11
  226. package/esm/templates/sequence-stairs.d.ts +2 -0
  227. package/esm/templates/sequence-stairs.js +42 -0
  228. package/esm/templates/word-cloud.d.ts +2 -0
  229. package/esm/templates/word-cloud.js +19 -0
  230. package/esm/themes/types.d.ts +1 -1
  231. package/esm/types/attrs.d.ts +15 -13
  232. package/esm/types/data.d.ts +2 -0
  233. package/esm/types/element.d.ts +1 -1
  234. package/esm/types/event.d.ts +6 -0
  235. package/esm/types/event.js +1 -0
  236. package/esm/types/index.d.ts +2 -0
  237. package/esm/{renderer/types → types}/text.d.ts +0 -1
  238. package/esm/types/text.js +1 -0
  239. package/esm/utils/attrs.d.ts +1 -0
  240. package/esm/utils/attrs.js +9 -0
  241. package/esm/utils/design.d.ts +2 -0
  242. package/esm/utils/design.js +10 -0
  243. package/esm/utils/element.d.ts +4 -0
  244. package/esm/utils/element.js +13 -0
  245. package/esm/utils/font.js +11 -1
  246. package/esm/utils/icon.d.ts +5 -3
  247. package/esm/utils/icon.js +38 -19
  248. package/esm/utils/index.d.ts +6 -0
  249. package/esm/utils/index.js +6 -0
  250. package/esm/utils/measure-text.d.ts +5 -0
  251. package/esm/utils/measure-text.js +22 -0
  252. package/esm/utils/recognizer.d.ts +15 -0
  253. package/esm/utils/recognizer.js +61 -1
  254. package/esm/utils/style.d.ts +1 -0
  255. package/esm/utils/style.js +8 -0
  256. package/esm/utils/text.d.ts +7 -0
  257. package/esm/utils/text.js +110 -35
  258. package/lib/constants/components.d.ts +1 -0
  259. package/lib/constants/components.js +4 -0
  260. package/lib/constants/element.d.ts +17 -6
  261. package/lib/constants/index.d.ts +3 -0
  262. package/lib/constants/index.js +3 -0
  263. package/lib/constants/service.d.ts +1 -0
  264. package/lib/constants/service.js +4 -0
  265. package/lib/constants/shape.d.ts +16 -0
  266. package/lib/designs/components/Btn.js +2 -2
  267. package/lib/designs/components/BtnsGroup.js +1 -1
  268. package/lib/designs/components/Illus.js +2 -2
  269. package/lib/designs/components/ItemDesc.js +1 -2
  270. package/lib/designs/components/ItemIcon.js +1 -1
  271. package/lib/designs/components/ItemLabel.js +1 -2
  272. package/lib/designs/components/ItemValue.js +1 -2
  273. package/lib/designs/components/ItemsGroup.js +1 -1
  274. package/lib/designs/components/Title.js +2 -5
  275. package/lib/designs/items/CandyCardLite.js +1 -1
  276. package/lib/designs/items/CircularProgress.js +2 -1
  277. package/lib/designs/items/HorizontalIconArrow.js +1 -2
  278. package/lib/designs/items/HorizontalIconLine.js +1 -1
  279. package/lib/designs/items/IconBadge.js +1 -1
  280. package/lib/designs/items/LinedText.d.ts +12 -0
  281. package/lib/designs/items/LinedText.js +61 -0
  282. package/lib/designs/items/PlainText.d.ts +1 -0
  283. package/lib/designs/items/PlainText.js +16 -3
  284. package/lib/designs/items/QuarterCircular.js +1 -31
  285. package/lib/designs/items/index.d.ts +1 -0
  286. package/lib/designs/items/index.js +1 -0
  287. package/lib/designs/layouts/Align.js +31 -45
  288. package/lib/designs/layouts/Flex.js +33 -29
  289. package/lib/designs/structures/chart-bar.d.ts +15 -0
  290. package/lib/designs/structures/chart-bar.js +103 -0
  291. package/lib/designs/structures/chart-line.d.ts +12 -0
  292. package/lib/designs/structures/chart-line.js +168 -0
  293. package/lib/designs/structures/chart-pie.d.ts +9 -0
  294. package/lib/designs/structures/chart-pie.js +131 -0
  295. package/lib/designs/structures/chart-wordcloud.d.ts +11 -0
  296. package/lib/designs/structures/chart-wordcloud.js +160 -0
  297. package/lib/designs/structures/compare-binary-horizontal/dividers/pros-cons-arrow.js +1 -1
  298. package/lib/designs/structures/hierarchy-mindmap.d.ts +24 -0
  299. package/lib/designs/structures/hierarchy-mindmap.js +203 -0
  300. package/lib/designs/structures/hierarchy-tree.d.ts +2 -0
  301. package/lib/designs/structures/hierarchy-tree.js +179 -50
  302. package/lib/designs/structures/index.d.ts +6 -0
  303. package/lib/designs/structures/index.js +6 -0
  304. package/lib/designs/structures/list-sector.js +1 -1
  305. package/lib/designs/structures/sequence-circular.js +1 -1
  306. package/lib/designs/structures/sequence-cylinders-3d.js +4 -4
  307. package/lib/designs/structures/sequence-roadmap-vertical.js +1 -1
  308. package/lib/designs/structures/sequence-stairs-front.d.ts +8 -0
  309. package/lib/designs/structures/sequence-stairs-front.js +120 -0
  310. package/lib/designs/structures/sequence-zigzag-pucks-3d.js +5 -5
  311. package/lib/designs/types.d.ts +8 -0
  312. package/lib/editor/commands/Batch.d.ts +11 -0
  313. package/lib/editor/commands/Batch.js +25 -0
  314. package/lib/editor/commands/UpdateElement.d.ts +16 -0
  315. package/lib/editor/commands/UpdateElement.js +87 -0
  316. package/lib/editor/commands/UpdateOptions.d.ts +14 -0
  317. package/lib/editor/commands/UpdateOptions.js +29 -0
  318. package/lib/editor/commands/UpdateText.d.ts +16 -0
  319. package/lib/editor/commands/UpdateText.js +44 -0
  320. package/lib/editor/commands/index.d.ts +4 -0
  321. package/lib/editor/commands/index.js +20 -0
  322. package/lib/editor/editor.d.ts +16 -0
  323. package/lib/editor/editor.js +54 -0
  324. package/lib/editor/index.d.ts +4 -0
  325. package/lib/editor/index.js +21 -0
  326. package/lib/editor/interactions/base.d.ts +12 -0
  327. package/lib/editor/interactions/base.js +9 -0
  328. package/lib/editor/interactions/brush-select.d.ts +23 -0
  329. package/lib/editor/interactions/brush-select.js +171 -0
  330. package/lib/editor/interactions/click-select.d.ts +12 -0
  331. package/lib/editor/interactions/click-select.js +71 -0
  332. package/lib/editor/interactions/dblclick-edit-text.d.ts +10 -0
  333. package/lib/editor/interactions/dblclick-edit-text.js +208 -0
  334. package/lib/editor/interactions/drag-element.d.ts +41 -0
  335. package/lib/editor/interactions/drag-element.js +395 -0
  336. package/lib/editor/interactions/hotkey-history.d.ts +10 -0
  337. package/lib/editor/interactions/hotkey-history.js +31 -0
  338. package/lib/editor/interactions/index.d.ts +8 -0
  339. package/lib/editor/interactions/index.js +19 -0
  340. package/lib/editor/interactions/select-highlight.d.ts +16 -0
  341. package/lib/editor/interactions/select-highlight.js +103 -0
  342. package/lib/editor/interactions/zoom-wheel.d.ts +8 -0
  343. package/lib/editor/interactions/zoom-wheel.js +50 -0
  344. package/lib/editor/managers/command.d.ts +19 -0
  345. package/lib/editor/managers/command.js +67 -0
  346. package/lib/editor/managers/index.d.ts +4 -0
  347. package/lib/editor/managers/index.js +20 -0
  348. package/lib/editor/managers/interaction.d.ts +33 -0
  349. package/lib/editor/managers/interaction.js +200 -0
  350. package/lib/editor/managers/plugin.d.ts +14 -0
  351. package/lib/editor/managers/plugin.js +49 -0
  352. package/lib/editor/managers/state.d.ts +22 -0
  353. package/lib/editor/managers/state.js +145 -0
  354. package/lib/editor/plugins/base.d.ts +12 -0
  355. package/lib/editor/plugins/base.js +9 -0
  356. package/lib/editor/plugins/edit-bar/components/button.d.ts +12 -0
  357. package/lib/editor/plugins/edit-bar/components/button.js +57 -0
  358. package/lib/editor/plugins/edit-bar/components/color-picker.d.ts +10 -0
  359. package/lib/editor/plugins/edit-bar/components/color-picker.js +354 -0
  360. package/lib/editor/plugins/edit-bar/components/icons.d.ts +26 -0
  361. package/lib/editor/plugins/edit-bar/components/icons.js +33 -0
  362. package/lib/editor/plugins/edit-bar/components/index.d.ts +5 -0
  363. package/lib/editor/plugins/edit-bar/components/index.js +21 -0
  364. package/lib/editor/plugins/edit-bar/components/popover.d.ts +23 -0
  365. package/lib/editor/plugins/edit-bar/components/popover.js +381 -0
  366. package/lib/editor/plugins/edit-bar/components/select.d.ts +22 -0
  367. package/lib/editor/plugins/edit-bar/components/select.js +204 -0
  368. package/lib/editor/plugins/edit-bar/edit-bar.d.ts +32 -0
  369. package/lib/editor/plugins/edit-bar/edit-bar.js +215 -0
  370. package/lib/editor/plugins/edit-bar/edit-items/align-elements.d.ts +2 -0
  371. package/lib/editor/plugins/edit-bar/edit-items/align-elements.js +316 -0
  372. package/lib/editor/plugins/edit-bar/edit-items/font-align.d.ts +3 -0
  373. package/lib/editor/plugins/edit-bar/edit-items/font-align.js +85 -0
  374. package/lib/editor/plugins/edit-bar/edit-items/font-color.d.ts +3 -0
  375. package/lib/editor/plugins/edit-bar/edit-items/font-color.js +81 -0
  376. package/lib/editor/plugins/edit-bar/edit-items/font-family.d.ts +3 -0
  377. package/lib/editor/plugins/edit-bar/edit-items/font-family.js +119 -0
  378. package/lib/editor/plugins/edit-bar/edit-items/font-size.d.ts +3 -0
  379. package/lib/editor/plugins/edit-bar/edit-items/font-size.js +92 -0
  380. package/lib/editor/plugins/edit-bar/edit-items/icon-color.d.ts +3 -0
  381. package/lib/editor/plugins/edit-bar/edit-items/icon-color.js +81 -0
  382. package/lib/editor/plugins/edit-bar/edit-items/index.d.ts +7 -0
  383. package/lib/editor/plugins/edit-bar/edit-items/index.js +22 -0
  384. package/lib/editor/plugins/edit-bar/edit-items/types.d.ts +3 -0
  385. package/lib/editor/plugins/edit-bar/index.d.ts +4 -0
  386. package/lib/editor/plugins/edit-bar/index.js +9 -0
  387. package/lib/editor/plugins/edit-bar/utils.d.ts +4 -0
  388. package/lib/editor/plugins/edit-bar/utils.js +17 -0
  389. package/lib/editor/plugins/index.d.ts +3 -0
  390. package/lib/editor/plugins/index.js +22 -0
  391. package/lib/editor/plugins/resize-element.d.ts +45 -0
  392. package/lib/editor/plugins/resize-element.js +397 -0
  393. package/lib/editor/types/command.d.ts +28 -0
  394. package/lib/editor/types/command.js +2 -0
  395. package/lib/editor/types/editor.d.ts +4 -0
  396. package/lib/editor/types/editor.js +2 -0
  397. package/lib/editor/types/index.d.ts +7 -0
  398. package/lib/editor/types/index.js +2 -0
  399. package/lib/editor/types/interaction.d.ts +44 -0
  400. package/lib/editor/types/interaction.js +2 -0
  401. package/lib/editor/types/plugin.d.ts +30 -0
  402. package/lib/editor/types/plugin.js +2 -0
  403. package/lib/editor/types/selection.d.ts +2 -0
  404. package/lib/editor/types/selection.js +2 -0
  405. package/lib/editor/types/shape.d.ts +16 -0
  406. package/lib/editor/types/shape.js +2 -0
  407. package/lib/editor/types/state.d.ts +57 -0
  408. package/lib/editor/types/state.js +2 -0
  409. package/lib/editor/utils/click-handler.d.ts +28 -0
  410. package/lib/editor/utils/click-handler.js +101 -0
  411. package/lib/editor/utils/coordinate.d.ts +6 -0
  412. package/lib/editor/utils/coordinate.js +38 -0
  413. package/lib/editor/utils/data.d.ts +10 -0
  414. package/lib/editor/utils/data.js +22 -0
  415. package/lib/editor/utils/element.d.ts +2 -0
  416. package/lib/editor/utils/element.js +12 -0
  417. package/lib/editor/utils/event.d.ts +3 -0
  418. package/lib/editor/utils/event.js +67 -0
  419. package/lib/editor/utils/extension.d.ts +13 -0
  420. package/lib/editor/utils/extension.js +43 -0
  421. package/lib/editor/utils/hotkey.d.ts +20 -0
  422. package/lib/editor/utils/hotkey.js +113 -0
  423. package/lib/editor/utils/index.d.ts +7 -0
  424. package/lib/editor/utils/index.js +23 -0
  425. package/lib/exporter/svg.js +6 -4
  426. package/lib/index.d.ts +7 -2
  427. package/lib/index.js +17 -1
  428. package/lib/jsx/components/Polygon.js +2 -1
  429. package/lib/jsx/components/Text.js +66 -68
  430. package/lib/options/parser.d.ts +1 -1
  431. package/lib/options/parser.js +32 -14
  432. package/lib/options/types.d.ts +15 -2
  433. package/lib/renderer/composites/background.js +1 -1
  434. package/lib/renderer/composites/button.js +3 -2
  435. package/lib/renderer/composites/icon.d.ts +1 -1
  436. package/lib/renderer/composites/icon.js +3 -1
  437. package/lib/renderer/composites/illus.js +1 -1
  438. package/lib/renderer/composites/text.js +2 -1
  439. package/lib/renderer/renderer.js +2 -1
  440. package/lib/renderer/stylize/rough.js +3 -7
  441. package/lib/renderer/types/index.d.ts +0 -1
  442. package/lib/resource/loader.d.ts +2 -2
  443. package/lib/resource/loader.js +21 -10
  444. package/lib/resource/loaders/index.d.ts +1 -0
  445. package/lib/resource/loaders/index.js +1 -0
  446. package/lib/resource/loaders/remote.d.ts +1 -1
  447. package/lib/resource/loaders/remote.js +10 -2
  448. package/lib/resource/loaders/search.d.ts +1 -0
  449. package/lib/resource/loaders/search.js +54 -0
  450. package/lib/resource/types/index.d.ts +1 -0
  451. package/lib/resource/types/resource.d.ts +8 -1
  452. package/lib/resource/types/scene.d.ts +1 -0
  453. package/lib/resource/types/scene.js +2 -0
  454. package/lib/resource/utils/data-uri.js +20 -11
  455. package/lib/resource/utils/index.d.ts +0 -1
  456. package/lib/resource/utils/index.js +0 -1
  457. package/lib/resource/utils/parser.js +92 -1
  458. package/lib/resource/utils/ref.js +4 -4
  459. package/lib/runtime/Infographic.d.ts +14 -7
  460. package/lib/runtime/Infographic.js +73 -10
  461. package/lib/runtime/options.d.ts +2 -0
  462. package/lib/runtime/options.js +27 -0
  463. package/lib/runtime/utils.d.ts +4 -0
  464. package/lib/runtime/utils.js +43 -0
  465. package/lib/syntax/index.d.ts +3 -0
  466. package/lib/syntax/index.js +104 -0
  467. package/lib/syntax/mapper.d.ts +3 -0
  468. package/lib/syntax/mapper.js +242 -0
  469. package/lib/syntax/parser.d.ts +14 -0
  470. package/lib/syntax/parser.js +146 -0
  471. package/lib/syntax/schema.d.ts +6 -0
  472. package/lib/syntax/schema.js +77 -0
  473. package/lib/syntax/types.d.ts +61 -0
  474. package/lib/syntax/types.js +2 -0
  475. package/lib/templates/built-in.js +116 -1
  476. package/lib/templates/hierarchy-mindmap.d.ts +2 -0
  477. package/lib/templates/hierarchy-mindmap.js +64 -0
  478. package/lib/templates/hierarchy-tree.js +25 -11
  479. package/lib/templates/sequence-stairs.d.ts +2 -0
  480. package/lib/templates/sequence-stairs.js +45 -0
  481. package/lib/templates/word-cloud.d.ts +2 -0
  482. package/lib/templates/word-cloud.js +22 -0
  483. package/lib/themes/types.d.ts +1 -1
  484. package/lib/types/attrs.d.ts +15 -13
  485. package/lib/types/data.d.ts +2 -0
  486. package/lib/types/element.d.ts +1 -1
  487. package/lib/types/event.d.ts +6 -0
  488. package/lib/types/event.js +2 -0
  489. package/lib/types/index.d.ts +2 -0
  490. package/lib/{renderer/types → types}/text.d.ts +0 -1
  491. package/lib/types/text.js +2 -0
  492. package/lib/utils/attrs.d.ts +1 -0
  493. package/lib/utils/attrs.js +12 -0
  494. package/lib/utils/design.d.ts +2 -0
  495. package/lib/utils/design.js +13 -0
  496. package/lib/utils/element.d.ts +4 -0
  497. package/lib/utils/element.js +18 -0
  498. package/lib/utils/font.js +11 -1
  499. package/lib/utils/icon.d.ts +5 -3
  500. package/lib/utils/icon.js +42 -21
  501. package/lib/utils/index.d.ts +6 -0
  502. package/lib/utils/index.js +6 -0
  503. package/lib/utils/measure-text.d.ts +5 -0
  504. package/lib/utils/measure-text.js +28 -0
  505. package/lib/utils/recognizer.d.ts +15 -0
  506. package/lib/utils/recognizer.js +72 -2
  507. package/lib/utils/style.d.ts +1 -0
  508. package/lib/utils/style.js +11 -0
  509. package/lib/utils/text.d.ts +7 -0
  510. package/lib/utils/text.js +113 -32
  511. package/package.json +7 -3
  512. package/src/constants/components.ts +1 -0
  513. package/src/constants/element.ts +17 -5
  514. package/src/constants/index.ts +3 -0
  515. package/src/constants/service.ts +1 -0
  516. package/src/constants/shape.ts +16 -0
  517. package/src/designs/components/Btn.tsx +3 -2
  518. package/src/designs/components/BtnsGroup.tsx +2 -1
  519. package/src/designs/components/Illus.tsx +3 -2
  520. package/src/designs/components/ItemDesc.tsx +2 -2
  521. package/src/designs/components/ItemIcon.tsx +3 -2
  522. package/src/designs/components/ItemLabel.tsx +2 -2
  523. package/src/designs/components/ItemValue.tsx +2 -2
  524. package/src/designs/components/ItemsGroup.tsx +2 -1
  525. package/src/designs/components/Title.tsx +8 -5
  526. package/src/designs/items/CandyCardLite.tsx +3 -3
  527. package/src/designs/items/CircularProgress.tsx +19 -8
  528. package/src/designs/items/HorizontalIconArrow.tsx +4 -5
  529. package/src/designs/items/HorizontalIconLine.tsx +7 -10
  530. package/src/designs/items/IconBadge.tsx +3 -3
  531. package/src/designs/items/LinedText.tsx +131 -0
  532. package/src/designs/items/PlainText.tsx +25 -3
  533. package/src/designs/items/QuarterCircular.tsx +2 -31
  534. package/src/designs/items/index.ts +1 -0
  535. package/src/designs/layouts/Align.tsx +31 -48
  536. package/src/designs/layouts/Flex.tsx +33 -31
  537. package/src/designs/structures/chart-bar.tsx +289 -0
  538. package/src/designs/structures/chart-line.tsx +415 -0
  539. package/src/designs/structures/chart-pie.tsx +298 -0
  540. package/src/designs/structures/chart-wordcloud.tsx +278 -0
  541. package/src/designs/structures/compare-binary-horizontal/dividers/pros-cons-arrow.tsx +2 -2
  542. package/src/designs/structures/hierarchy-mindmap.tsx +394 -0
  543. package/src/designs/structures/hierarchy-tree.tsx +212 -59
  544. package/src/designs/structures/index.ts +6 -0
  545. package/src/designs/structures/list-sector.tsx +2 -1
  546. package/src/designs/structures/sequence-ascending-steps.tsx +0 -1
  547. package/src/designs/structures/sequence-circular.tsx +1 -1
  548. package/src/designs/structures/sequence-cylinders-3d.tsx +5 -5
  549. package/src/designs/structures/sequence-roadmap-vertical.tsx +2 -1
  550. package/src/designs/structures/sequence-stairs-front.tsx +291 -0
  551. package/src/designs/structures/sequence-zigzag-pucks-3d.tsx +18 -25
  552. package/src/designs/types.ts +9 -0
  553. package/src/editor/commands/Batch.ts +24 -0
  554. package/src/editor/commands/UpdateElement.ts +115 -0
  555. package/src/editor/commands/UpdateOptions.ts +31 -0
  556. package/src/editor/commands/UpdateText.ts +54 -0
  557. package/src/editor/commands/index.ts +4 -0
  558. package/src/editor/editor.ts +78 -0
  559. package/src/editor/index.ts +4 -0
  560. package/src/editor/interactions/base.ts +25 -0
  561. package/src/editor/interactions/brush-select.ts +204 -0
  562. package/src/editor/interactions/click-select.ts +72 -0
  563. package/src/editor/interactions/dblclick-edit-text.ts +260 -0
  564. package/src/editor/interactions/drag-element.ts +516 -0
  565. package/src/editor/interactions/hotkey-history.ts +34 -0
  566. package/src/editor/interactions/index.ts +8 -0
  567. package/src/editor/interactions/select-highlight.ts +140 -0
  568. package/src/editor/interactions/zoom-wheel.ts +52 -0
  569. package/src/editor/managers/command.ts +83 -0
  570. package/src/editor/managers/index.ts +4 -0
  571. package/src/editor/managers/interaction.ts +244 -0
  572. package/src/editor/managers/plugin.ts +66 -0
  573. package/src/editor/managers/state.ts +186 -0
  574. package/src/editor/plugins/base.ts +25 -0
  575. package/src/editor/plugins/edit-bar/components/button.ts +77 -0
  576. package/src/editor/plugins/edit-bar/components/color-picker.ts +397 -0
  577. package/src/editor/plugins/edit-bar/components/icons.ts +86 -0
  578. package/src/editor/plugins/edit-bar/components/index.ts +5 -0
  579. package/src/editor/plugins/edit-bar/components/popover.ts +446 -0
  580. package/src/editor/plugins/edit-bar/components/select.ts +247 -0
  581. package/src/editor/plugins/edit-bar/edit-bar.ts +292 -0
  582. package/src/editor/plugins/edit-bar/edit-items/align-elements.ts +447 -0
  583. package/src/editor/plugins/edit-bar/edit-items/font-align.ts +129 -0
  584. package/src/editor/plugins/edit-bar/edit-items/font-color.ts +101 -0
  585. package/src/editor/plugins/edit-bar/edit-items/font-family.ts +147 -0
  586. package/src/editor/plugins/edit-bar/edit-items/font-size.ts +116 -0
  587. package/src/editor/plugins/edit-bar/edit-items/icon-color.ts +101 -0
  588. package/src/editor/plugins/edit-bar/edit-items/index.ts +7 -0
  589. package/src/editor/plugins/edit-bar/edit-items/types.ts +9 -0
  590. package/src/editor/plugins/edit-bar/index.ts +18 -0
  591. package/src/editor/plugins/edit-bar/utils.ts +16 -0
  592. package/src/editor/plugins/index.ts +3 -0
  593. package/src/editor/plugins/resize-element.ts +518 -0
  594. package/src/editor/types/command.ts +32 -0
  595. package/src/editor/types/editor.ts +4 -0
  596. package/src/editor/types/index.ts +7 -0
  597. package/src/editor/types/interaction.ts +56 -0
  598. package/src/editor/types/plugin.ts +34 -0
  599. package/src/editor/types/selection.ts +3 -0
  600. package/src/editor/types/shape.ts +28 -0
  601. package/src/editor/types/state.ts +51 -0
  602. package/src/editor/utils/click-handler.ts +114 -0
  603. package/src/editor/utils/coordinate.ts +54 -0
  604. package/src/editor/utils/data.ts +30 -0
  605. package/src/editor/utils/element.ts +13 -0
  606. package/src/editor/utils/event.ts +92 -0
  607. package/src/editor/utils/extension.ts +45 -0
  608. package/src/editor/utils/hotkey.ts +139 -0
  609. package/src/editor/utils/index.ts +7 -0
  610. package/src/exporter/svg.ts +15 -5
  611. package/src/index.ts +16 -3
  612. package/src/jsx/components/Polygon.ts +2 -1
  613. package/src/jsx/components/Text.ts +70 -71
  614. package/src/options/parser.ts +57 -28
  615. package/src/options/types.ts +17 -2
  616. package/src/renderer/composites/background.ts +2 -2
  617. package/src/renderer/composites/button.ts +4 -3
  618. package/src/renderer/composites/icon.ts +3 -1
  619. package/src/renderer/composites/illus.ts +1 -1
  620. package/src/renderer/composites/text.ts +2 -1
  621. package/src/renderer/renderer.ts +4 -2
  622. package/src/renderer/stylize/rough.ts +3 -7
  623. package/src/renderer/types/index.ts +0 -1
  624. package/src/resource/loader.ts +22 -8
  625. package/src/resource/loaders/index.ts +1 -0
  626. package/src/resource/loaders/remote.ts +9 -2
  627. package/src/resource/loaders/search.ts +52 -0
  628. package/src/resource/types/index.ts +2 -1
  629. package/src/resource/types/resource.ts +12 -1
  630. package/src/resource/types/scene.ts +1 -0
  631. package/src/resource/utils/data-uri.ts +20 -11
  632. package/src/resource/utils/index.ts +0 -1
  633. package/src/resource/utils/parser.ts +103 -2
  634. package/src/resource/utils/ref.ts +3 -3
  635. package/src/runtime/Infographic.tsx +106 -13
  636. package/src/runtime/options.ts +37 -0
  637. package/src/runtime/utils.ts +45 -0
  638. package/src/syntax/index.ts +124 -0
  639. package/src/syntax/mapper.ts +362 -0
  640. package/src/syntax/parser.ts +171 -0
  641. package/src/syntax/schema.ts +98 -0
  642. package/src/syntax/types.ts +89 -0
  643. package/src/templates/built-in.ts +116 -1
  644. package/src/templates/hierarchy-mindmap.ts +129 -0
  645. package/src/templates/hierarchy-tree.ts +34 -11
  646. package/src/templates/sequence-stairs.ts +44 -0
  647. package/src/templates/word-cloud.ts +21 -0
  648. package/src/themes/types.ts +1 -1
  649. package/src/types/attrs.ts +17 -13
  650. package/src/types/data.ts +2 -0
  651. package/src/types/element.ts +1 -1
  652. package/src/types/event.ts +6 -0
  653. package/src/types/index.ts +2 -0
  654. package/src/{renderer/types → types}/text.ts +0 -1
  655. package/src/utils/attrs.ts +9 -0
  656. package/src/utils/design.ts +14 -0
  657. package/src/utils/element.ts +26 -0
  658. package/src/utils/font.ts +11 -1
  659. package/src/utils/icon.ts +45 -25
  660. package/src/utils/index.ts +6 -0
  661. package/src/utils/measure-text.ts +38 -0
  662. package/src/utils/recognizer.ts +75 -1
  663. package/src/utils/style.ts +8 -0
  664. package/src/utils/text.ts +135 -40
  665. package/esm/resource/types/font.d.ts +0 -12
  666. package/lib/resource/types/font.d.ts +0 -12
  667. package/src/resource/types/font.ts +0 -23
  668. /package/esm/{renderer/types/text.js → constants/shape.js} +0 -0
  669. /package/esm/{resource/types/font.js → editor/plugins/edit-bar/edit-items/types.js} +0 -0
  670. /package/esm/{resource/utils → utils}/hash.d.ts +0 -0
  671. /package/esm/{resource/utils → utils}/hash.js +0 -0
  672. /package/lib/{renderer/types/text.js → constants/shape.js} +0 -0
  673. /package/lib/{resource/types/font.js → editor/plugins/edit-bar/edit-items/types.js} +0 -0
  674. /package/lib/{resource/utils → utils}/hash.d.ts +0 -0
  675. /package/lib/{resource/utils → utils}/hash.js +0 -0
  676. /package/src/{resource/utils → utils}/hash.ts +0 -0
@@ -36,6 +36,7 @@ export const CircularProgress: ComponentType<CircularProgressProps> = (
36
36
  const start = strokeWidth / 2;
37
37
  const d = size - strokeWidth;
38
38
 
39
+ const isFullCircle = percentage >= 1;
39
40
  const angle = percentage * 360;
40
41
  const pathData = describeArc(center, center, radius, 0, angle);
41
42
 
@@ -54,14 +55,24 @@ export const CircularProgress: ComponentType<CircularProgressProps> = (
54
55
  />
55
56
 
56
57
  {/* 进度圆环 */}
57
- <Path
58
- d={pathData}
59
- fill="none"
60
- stroke={themeColors.colorPrimary}
61
- strokeWidth={strokeWidth}
62
- strokeLinecap="round"
63
- data-element-type="shape"
64
- />
58
+ {isFullCircle ? (
59
+ <Ellipse
60
+ {...bounds}
61
+ fill="none"
62
+ stroke={themeColors.colorPrimary}
63
+ strokeWidth={strokeWidth}
64
+ data-element-type="shape"
65
+ />
66
+ ) : (
67
+ <Path
68
+ d={pathData}
69
+ fill="none"
70
+ stroke={themeColors.colorPrimary}
71
+ strokeWidth={strokeWidth}
72
+ strokeLinecap="round"
73
+ data-element-type="shape"
74
+ />
75
+ )}
65
76
 
66
77
  {/* 中心数值 */}
67
78
  <ItemValue
@@ -16,7 +16,6 @@ import {
16
16
  ShapesGroup,
17
17
  } from '../components';
18
18
  import { FlexLayout } from '../layouts';
19
- import { AlignLayout } from '../layouts/Align';
20
19
  import { getItemProps } from '../utils';
21
20
  import { registerItem } from './registry';
22
21
  import type { BaseItemProps } from './types';
@@ -115,15 +114,15 @@ export const HorizontalIconArrow: ComponentType<HorizontalIconArrowProps> = (
115
114
  <Gap height={iconGap} />
116
115
  </>
117
116
  )}
118
- <AlignLayout horizontal="center" vertical="middle">
117
+ <Group>
119
118
  <HorizontalArrow
120
119
  width={width}
121
120
  height={arrowHeight}
122
121
  fill={themeColors.colorPrimary}
123
122
  />
124
123
  <Text
125
- width={width}
126
- height={arrowHeight}
124
+ x={width / 2}
125
+ y={arrowHeight / 2}
127
126
  alignHorizontal="center"
128
127
  alignVertical="middle"
129
128
  fill={themeColors.colorWhite}
@@ -136,7 +135,7 @@ export const HorizontalIconArrow: ComponentType<HorizontalIconArrowProps> = (
136
135
  .padStart(2, '0')
137
136
  .slice(-2)}
138
137
  </Text>
139
- </AlignLayout>
138
+ </Group>
140
139
  {!isVNormal ? (
141
140
  <>
142
141
  {dotLine}
@@ -87,10 +87,14 @@ export const HorizontalIconLine: ComponentType<HorizontalIconLineProps> = (
87
87
  </Text>
88
88
  ) : null;
89
89
  const timeBounds = getElementBounds(time);
90
-
91
90
  const lineHeight = 18;
92
91
  const line = (
93
- <AlignLayout horizontal="center" width={width} height={lineHeight}>
92
+ <AlignLayout
93
+ horizontal="center"
94
+ vertical="middle"
95
+ width={width}
96
+ height={lineHeight}
97
+ >
94
98
  <Rect
95
99
  width={width}
96
100
  height={lineHeight}
@@ -98,20 +102,13 @@ export const HorizontalIconLine: ComponentType<HorizontalIconLineProps> = (
98
102
  data-element-type="shape"
99
103
  />
100
104
  <Ellipse
101
- y={-3}
102
105
  width={lineHeight + 6}
103
106
  height={lineHeight + 6}
104
107
  fill={themeColors.colorBg}
105
108
  fillOpacity={0.5}
106
109
  data-element-type="shape"
107
110
  />
108
- <Ellipse
109
- y={(lineHeight - 12) / 2}
110
- width={12}
111
- height={12}
112
- fill="white"
113
- data-element-type="shape"
114
- />
111
+ <Ellipse width={12} height={12} fill="white" data-element-type="shape" />
115
112
  </AlignLayout>
116
113
  );
117
114
 
@@ -78,7 +78,6 @@ export const IconBadge: ComponentType<IconBadgeProps> = (props) => {
78
78
  {/* 数值徽章 */}
79
79
  <Ellipse
80
80
  x={size - badgeSize + 4}
81
- y={0}
82
81
  width={badgeSize}
83
82
  height={badgeSize}
84
83
  fill={`url(#${badgeGradientId})`}
@@ -86,8 +85,9 @@ export const IconBadge: ComponentType<IconBadgeProps> = (props) => {
86
85
 
87
86
  {/* 徽章数值 */}
88
87
  <Text
89
- x={size - badgeSize / 2 + 4}
90
- y={badgeSize / 2}
88
+ x={size - badgeSize + 4}
89
+ width={badgeSize}
90
+ height={badgeSize}
91
91
  fontSize={10}
92
92
  fontWeight="bold"
93
93
  fill={themeColors.colorWhite}
@@ -0,0 +1,131 @@
1
+ import { ComponentType, Group, Path, getElementBounds } from '../../jsx';
2
+ import { ItemLabel } from '../components';
3
+ import { getItemProps } from '../utils';
4
+ import { registerItem } from './registry';
5
+ import type { BaseItemProps } from './types';
6
+
7
+ export interface LinedTextProps extends BaseItemProps {
8
+ width?: number;
9
+ formatter?: (text?: string) => string;
10
+ usePaletteColor?: boolean;
11
+ showUnderline?: boolean;
12
+ underlineGap?: number;
13
+ underlineExtend?: number;
14
+ underlineThickness?: number;
15
+ }
16
+
17
+ export const LinedText: ComponentType<LinedTextProps> = (props) => {
18
+ const [
19
+ {
20
+ datum,
21
+ indexes,
22
+ width,
23
+ themeColors,
24
+ positionH = 'normal',
25
+ positionV = 'center',
26
+ formatter = (text?: string) => text || '',
27
+ usePaletteColor = false,
28
+ showUnderline = false,
29
+ underlineGap = 6,
30
+ underlineExtend = 8,
31
+ underlineThickness = 2,
32
+ },
33
+ restProps,
34
+ ] = getItemProps(props, [
35
+ 'width',
36
+ 'formatter',
37
+ 'usePaletteColor',
38
+ 'showUnderline',
39
+ 'underlineGap',
40
+ 'underlineExtend',
41
+ 'underlineThickness',
42
+ ]);
43
+
44
+ const content = formatter(datum.label ?? datum.desc ?? '');
45
+ const alignH =
46
+ positionH === 'flipped'
47
+ ? 'right'
48
+ : positionH === 'center'
49
+ ? 'center'
50
+ : 'left';
51
+
52
+ const measuredLabel = getElementBounds(
53
+ <ItemLabel indexes={indexes} width={width}>
54
+ {content}
55
+ </ItemLabel>,
56
+ );
57
+ const contentWidth = width ?? measuredLabel.width;
58
+ const labelHeight = measuredLabel.height;
59
+ const underlineWidth = showUnderline ? contentWidth + underlineExtend * 2 : 0;
60
+ const totalHeight =
61
+ labelHeight + (showUnderline ? underlineGap + underlineThickness : 0);
62
+ const finalWidth = showUnderline
63
+ ? Math.max(contentWidth, underlineWidth)
64
+ : contentWidth;
65
+ const finalHeight = (restProps.height as number | undefined) ?? totalHeight;
66
+ const offsetY =
67
+ positionV === 'middle'
68
+ ? (finalHeight - totalHeight) / 2
69
+ : positionV === 'flipped'
70
+ ? finalHeight - totalHeight
71
+ : 0;
72
+
73
+ const labelX =
74
+ alignH === 'right'
75
+ ? finalWidth - contentWidth
76
+ : alignH === 'center'
77
+ ? (finalWidth - contentWidth) / 2
78
+ : 0;
79
+ const labelY = offsetY;
80
+ const underlineX =
81
+ alignH === 'right'
82
+ ? finalWidth - underlineWidth
83
+ : alignH === 'center'
84
+ ? (finalWidth - underlineWidth) / 2
85
+ : 0;
86
+ const underlineY = finalHeight;
87
+
88
+ return (
89
+ <Group {...restProps} width={finalWidth} height={finalHeight}>
90
+ <ItemLabel
91
+ indexes={indexes}
92
+ x={labelX}
93
+ y={labelY}
94
+ width={contentWidth}
95
+ height={labelHeight}
96
+ alignHorizontal={alignH}
97
+ alignVertical={
98
+ positionV === 'flipped'
99
+ ? 'bottom'
100
+ : positionV === 'center'
101
+ ? 'middle'
102
+ : 'top'
103
+ }
104
+ fill={
105
+ usePaletteColor ? themeColors.colorPrimary : themeColors.colorText
106
+ }
107
+ >
108
+ {content}
109
+ </ItemLabel>
110
+ {showUnderline && (
111
+ <Path
112
+ d={`M 0 ${underlineThickness / 2} L ${underlineWidth} ${underlineThickness / 2}`}
113
+ x={underlineX}
114
+ y={underlineY - underlineThickness / 2}
115
+ width={underlineWidth}
116
+ height={underlineThickness}
117
+ stroke={themeColors.colorPrimary}
118
+ strokeWidth={underlineThickness}
119
+ fill="none"
120
+ strokeLinecap="round"
121
+ data-element-type="shape"
122
+ />
123
+ )}
124
+ </Group>
125
+ );
126
+ };
127
+
128
+ registerItem('lined-text', {
129
+ component: LinedText,
130
+ composites: ['label'],
131
+ });
@@ -8,6 +8,7 @@ export interface LabelTextProps extends BaseItemProps {
8
8
  width?: number;
9
9
  formatter?: (text?: string) => string;
10
10
  usePaletteColor?: boolean;
11
+ lineNumber?: number;
11
12
  }
12
13
 
13
14
  export const LabelText: ComponentType<LabelTextProps> = (props) => {
@@ -18,19 +19,34 @@ export const LabelText: ComponentType<LabelTextProps> = (props) => {
18
19
  width = 120,
19
20
  themeColors,
20
21
  positionH = 'normal',
22
+ positionV = 'center',
21
23
  formatter = (text?: string) => text || '',
22
24
  usePaletteColor = false,
25
+ lineNumber = 1,
23
26
  },
24
27
  restProps,
25
- ] = getItemProps(props, ['width', 'formatter', 'usePaletteColor']);
28
+ ] = getItemProps(props, [
29
+ 'width',
30
+ 'formatter',
31
+ 'usePaletteColor',
32
+ 'lineNumber',
33
+ ]);
34
+
35
+ const fontSize = 14;
36
+ const lineHeight = 1.4;
37
+ const height =
38
+ (restProps.height as number | undefined) ??
39
+ Math.ceil(lineNumber * lineHeight * fontSize);
26
40
 
27
41
  return (
28
42
  <ItemLabel
29
43
  {...restProps}
30
44
  indexes={indexes}
31
45
  width={width}
46
+ height={height}
47
+ lineHeight={lineHeight}
32
48
  fill={usePaletteColor ? themeColors.colorPrimary : themeColors.colorText}
33
- fontSize={14}
49
+ fontSize={fontSize}
34
50
  fontWeight="regular"
35
51
  alignHorizontal={
36
52
  positionH === 'flipped'
@@ -39,7 +55,13 @@ export const LabelText: ComponentType<LabelTextProps> = (props) => {
39
55
  ? 'center'
40
56
  : 'left'
41
57
  }
42
- alignVertical="middle"
58
+ alignVertical={
59
+ positionV === 'flipped'
60
+ ? 'bottom'
61
+ : positionV === 'center'
62
+ ? 'middle'
63
+ : 'top'
64
+ }
43
65
  >
44
66
  {formatter(datum.label || datum.desc)}
45
67
  </ItemLabel>
@@ -54,7 +54,6 @@ export const QuarterCircular: ComponentType<QuarterCircularProps> = (props) => {
54
54
 
55
55
  // 根据 positionH 调整布局
56
56
  const isFlipped = positionH === 'flipped';
57
- const isCentered = positionH === 'center';
58
57
 
59
58
  // 根据 positionV 调整布局
60
59
  const isVFlipped = positionV === 'flipped';
@@ -74,22 +73,6 @@ export const QuarterCircular: ComponentType<QuarterCircularProps> = (props) => {
74
73
  topLineEndX: CIRCLE_MASS,
75
74
  topLineY: isVFlipped ? height - DOT_RADIUS : DOT_RADIUS,
76
75
  };
77
- } else if (isCentered) {
78
- // 居中对齐
79
- const totalContentWidth =
80
- width - circleRadius - DECORATION_HORIZONTAL_SPACING;
81
- const centerOffset = (width - totalContentWidth) / 2;
82
- return {
83
- diagonalStartX: centerOffset + DOT_RADIUS,
84
- diagonalStartY: isVFlipped
85
- ? height - DECORATION_VERTICAL_SPACING
86
- : DECORATION_VERTICAL_SPACING,
87
- diagonalEndX: centerOffset + DECORATION_HORIZONTAL_SPACING,
88
- diagonalEndY: isVFlipped ? height - DOT_RADIUS : DOT_RADIUS,
89
- topLineStartX: centerOffset + DECORATION_HORIZONTAL_SPACING,
90
- topLineEndX: centerOffset + totalContentWidth - CIRCLE_MASS,
91
- topLineY: isVFlipped ? height - DOT_RADIUS : DOT_RADIUS,
92
- };
93
76
  } else {
94
77
  // 默认左对齐
95
78
  return {
@@ -120,19 +103,6 @@ export const QuarterCircular: ComponentType<QuarterCircularProps> = (props) => {
120
103
  circleY: isVFlipped ? 0 : height,
121
104
  iconX: CIRCLE_MASS - iconSize / 2,
122
105
  };
123
- } else if (isCentered) {
124
- // 居中对齐
125
- const totalContentWidth =
126
- width - circleRadius - DECORATION_HORIZONTAL_SPACING;
127
- const centerOffset = (width - totalContentWidth) / 2;
128
- return {
129
- valueX: centerOffset,
130
- contentX: centerOffset + DECORATION_HORIZONTAL_SPACING,
131
- contentWidth: totalContentWidth - circleRadius - 10,
132
- circleX: centerOffset + totalContentWidth,
133
- circleY: isVFlipped ? 0 : height,
134
- iconX: centerOffset + totalContentWidth - CIRCLE_MASS - iconSize / 2,
135
- };
136
106
  } else {
137
107
  // 默认左对齐
138
108
  return {
@@ -227,7 +197,6 @@ export const QuarterCircular: ComponentType<QuarterCircularProps> = (props) => {
227
197
  fontSize={VALUE_SIZE}
228
198
  fontWeight="bold"
229
199
  fill={themeColors.colorPrimary}
230
- width={40}
231
200
  >
232
201
  {indexStr}
233
202
  </Text>
@@ -259,6 +228,7 @@ export const QuarterCircular: ComponentType<QuarterCircularProps> = (props) => {
259
228
  width={contentCoords.contentWidth}
260
229
  fontWeight="bold"
261
230
  fill={themeColors.colorText}
231
+ alignHorizontal={isFlipped ? 'right' : 'left'}
262
232
  >
263
233
  {datum.label}
264
234
  </ItemLabel>
@@ -272,6 +242,7 @@ export const QuarterCircular: ComponentType<QuarterCircularProps> = (props) => {
272
242
  y={descY}
273
243
  width={contentCoords.contentWidth}
274
244
  fill={themeColors.colorTextSecondary}
245
+ alignHorizontal={isFlipped ? 'right' : 'left'}
275
246
  >
276
247
  {datum.desc}
277
248
  </ItemDesc>
@@ -11,6 +11,7 @@ export * from './IconBadge';
11
11
  export * from './IndexedCard';
12
12
  export * from './LCornerCard';
13
13
  export * from './LetterCard';
14
+ export * from './LinedText';
14
15
  export * from './PillBadge';
15
16
  export * from './PlainText';
16
17
  export * from './ProgressCard';
@@ -21,83 +21,66 @@ export const AlignLayout = createLayout<AlignLayoutProps>(
21
21
  }
22
22
 
23
23
  const childBounds = children.map((child) => getElementBounds(child));
24
-
25
- // 检查是否设置了容器的宽高
26
- const hasContainerWidth = props.width !== undefined;
27
- const hasContainerHeight = props.height !== undefined;
28
-
29
- let positionedChildren = [...children];
30
-
31
- // 如果没有设置容器尺寸,先获取子节点的整体包围盒
32
24
  const childrenBounds = getElementsBounds(children);
33
25
 
34
- // 确定对齐的基础区域
35
- const alignmentWidth = hasContainerWidth
36
- ? props.width!
37
- : childrenBounds.width;
38
- const alignmentHeight = hasContainerHeight
39
- ? props.height!
40
- : childrenBounds.height;
41
- const alignmentX = hasContainerWidth ? props.x || 0 : childrenBounds.x;
42
- const alignmentY = hasContainerHeight ? props.y || 0 : childrenBounds.y;
26
+ // 容器尺寸和位置
27
+ const containerX = props.x ?? childrenBounds.x;
28
+ const containerY = props.y ?? childrenBounds.y;
29
+ const containerWidth = props.width ?? childrenBounds.width;
30
+ const containerHeight = props.height ?? childrenBounds.height;
43
31
 
44
- // 应用对齐
45
- positionedChildren = children.map((child, index) => {
32
+ // 对齐子元素(使用相对于容器的坐标)
33
+ const positionedChildren = children.map((child, index) => {
46
34
  const bounds = childBounds[index];
47
35
  const childProps = { ...child.props };
48
36
 
49
- // 水平对齐
50
- if (horizontal) {
37
+ // 水平对齐(相对于容器左边界)
38
+ if (horizontal !== undefined) {
51
39
  switch (horizontal) {
52
40
  case 'left':
53
- childProps.x = alignmentX;
41
+ childProps.x = 0; // 相对容器
54
42
  break;
55
43
  case 'center':
56
- childProps.x = alignmentX + (alignmentWidth - bounds.width) / 2;
44
+ childProps.x = (containerWidth - bounds.width) / 2;
57
45
  break;
58
46
  case 'right':
59
- childProps.x = alignmentX + alignmentWidth - bounds.width;
47
+ childProps.x = containerWidth - bounds.width;
60
48
  break;
61
49
  }
62
- } else {
63
- // 如果没有设置水平对齐,保持原有的 x 坐标
64
- childProps.x = child.props.x || bounds.x;
50
+ } else if (childProps.x === undefined) {
51
+ // 保持相对位置
52
+ childProps.x = bounds.x - containerX;
65
53
  }
66
54
 
67
- // 垂直对齐
68
- if (vertical) {
55
+ // 垂直对齐(相对于容器顶边界)
56
+ if (vertical !== undefined) {
69
57
  switch (vertical) {
70
58
  case 'top':
71
- childProps.y = alignmentY;
59
+ childProps.y = 0;
72
60
  break;
73
61
  case 'middle':
74
- childProps.y = alignmentY + (alignmentHeight - bounds.height) / 2;
62
+ childProps.y = (containerHeight - bounds.height) / 2;
75
63
  break;
76
64
  case 'bottom':
77
- childProps.y = alignmentY + alignmentHeight - bounds.height;
65
+ childProps.y = containerHeight - bounds.height;
78
66
  break;
79
67
  }
80
- } else {
81
- // 如果没有设置垂直对齐,保持原有的 y 坐标
82
- childProps.y = child.props.y || bounds.y;
68
+ } else if (childProps.y === undefined) {
69
+ // 保持相对位置
70
+ childProps.y = bounds.y - containerY;
83
71
  }
84
72
 
85
73
  return cloneElement(child, childProps);
86
74
  });
87
75
 
88
- // 如果没有设置容器尺寸,更新容器的边界框
89
- if (!hasContainerWidth || !hasContainerHeight) {
90
- const finalBounds = getElementsBounds(positionedChildren);
91
- if (!hasContainerWidth) {
92
- // props.x ??= finalBounds.x;
93
- props.width ??= finalBounds.width;
94
- }
95
- if (!hasContainerHeight) {
96
- // props.y ??= finalBounds.y;
97
- props.height ??= finalBounds.height;
98
- }
99
- }
76
+ const containerProps = {
77
+ ...props,
78
+ x: containerX,
79
+ y: containerY,
80
+ width: containerWidth,
81
+ height: containerHeight,
82
+ };
100
83
 
101
- return <Group {...props}>{positionedChildren}</Group>;
84
+ return <Group {...containerProps}>{positionedChildren}</Group>;
102
85
  },
103
86
  );
@@ -40,11 +40,12 @@ export const FlexLayout = createLayout<FlexLayoutProps>(
40
40
  flexDirection === 'row-reverse' || flexDirection === 'column-reverse';
41
41
 
42
42
  const childBounds = children.map((child) => getElementBounds(child));
43
+ const childrenBounds = getElementsBounds(children);
43
44
 
45
+ const containerWidth = props.width ?? childrenBounds.width;
46
+ const containerHeight = props.height ?? childrenBounds.height;
44
47
  const hasContainerSize =
45
48
  props.width !== undefined && props.height !== undefined;
46
- const containerWidth = props.width || 0;
47
- const containerHeight = props.height || 0;
48
49
 
49
50
  const lines: Array<{ children: JSXElement[]; bounds: Bounds[] }> = [];
50
51
 
@@ -237,37 +238,38 @@ export const FlexLayout = createLayout<FlexLayoutProps>(
237
238
  }
238
239
 
239
240
  if (!hasContainerSize) {
240
- if (alignItems === 'center' && !isRow) {
241
- // For column layout, center items horizontally
242
- const maxWidth = Math.max(...childBounds.map((bounds) => bounds.width));
243
- layoutChildren.forEach((child, index) => {
244
- const bounds = childBounds[index];
245
- const centerOffset = (maxWidth - bounds.width) / 2;
246
- const newProps = { ...child.props };
247
- newProps.x = (newProps.x || 0) + centerOffset;
248
- layoutChildren[index] = cloneElement(child, newProps);
249
- });
250
- } else if (alignItems === 'center' && isRow) {
251
- // For row layout, center items vertically
252
- const maxHeight = Math.max(
253
- ...childBounds.map((bounds) => bounds.height),
254
- );
255
- layoutChildren.forEach((child, index) => {
256
- const bounds = childBounds[index];
257
- const centerOffset = (maxHeight - bounds.height) / 2;
258
- const newProps = { ...child.props };
259
- newProps.y = (newProps.y || 0) + centerOffset;
260
- layoutChildren[index] = cloneElement(child, newProps);
261
- });
241
+ if (alignItems === 'center') {
242
+ if (isRow) {
243
+ const maxHeight = Math.max(...childBounds.map((b) => b.height));
244
+ layoutChildren.forEach((child, index) => {
245
+ const bounds = childBounds[index];
246
+ const centerOffset = (maxHeight - bounds.height) / 2;
247
+ const newProps = { ...child.props };
248
+ newProps.y = (newProps.y || 0) + centerOffset;
249
+ layoutChildren[index] = cloneElement(child, newProps);
250
+ });
251
+ } else {
252
+ const maxWidth = Math.max(...childBounds.map((b) => b.width));
253
+ layoutChildren.forEach((child, index) => {
254
+ const bounds = childBounds[index];
255
+ const centerOffset = (maxWidth - bounds.width) / 2;
256
+ const newProps = { ...child.props };
257
+ newProps.x = (newProps.x || 0) + centerOffset;
258
+ layoutChildren[index] = cloneElement(child, newProps);
259
+ });
260
+ }
262
261
  }
263
-
264
- const finalBounds = getElementsBounds(layoutChildren);
265
- // props.x ??= finalBounds.x;
266
- // props.y ??= finalBounds.y;
267
- props.width ??= finalBounds.width;
268
- props.height ??= finalBounds.height;
269
262
  }
270
263
 
271
- return <Group {...props}>{layoutChildren}</Group>;
264
+ const finalBounds = getElementsBounds(layoutChildren);
265
+ const containerProps = {
266
+ ...props,
267
+ x: props.x ?? childrenBounds.x,
268
+ y: props.y ?? childrenBounds.y,
269
+ width: props.width ?? finalBounds.width,
270
+ height: props.height ?? finalBounds.height,
271
+ };
272
+
273
+ return <Group {...containerProps}>{layoutChildren}</Group>;
272
274
  },
273
275
  );