@tdesign-react/chat 1.0.2-alpha.9 → 1.1.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (303) hide show
  1. package/es/_chunks/dep-f2051ebd.js +839 -0
  2. package/es/_chunks/dep-f2051ebd.js.map +1 -0
  3. package/es/_util/reactify.js +1 -1
  4. package/es/_util/useDynamicStyle.js +1 -1
  5. package/es/attachments/index.js +1 -1
  6. package/es/chat-actionbar/index.js +1 -1
  7. package/es/chat-engine/components/a2ui/A2UIActivityRenderer.d.ts +196 -0
  8. package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js +301 -0
  9. package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js.map +1 -0
  10. package/es/chat-engine/components/a2ui/A2UIComponentRenderer.d.ts +37 -0
  11. package/es/chat-engine/components/a2ui/A2UIComponentRenderer.js +116 -0
  12. package/es/chat-engine/components/a2ui/A2UIComponentRenderer.js.map +1 -0
  13. package/es/chat-engine/components/a2ui/A2UIErrorBoundary.d.ts +42 -0
  14. package/es/chat-engine/components/a2ui/A2UIErrorBoundary.js +113 -0
  15. package/es/chat-engine/components/a2ui/A2UIErrorBoundary.js.map +1 -0
  16. package/es/chat-engine/components/a2ui/A2UISkeleton.d.ts +60 -0
  17. package/es/chat-engine/components/a2ui/A2UISkeleton.js +197 -0
  18. package/es/chat-engine/components/a2ui/A2UISkeleton.js.map +1 -0
  19. package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.d.ts +44 -0
  20. package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.js +139 -0
  21. package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.js.map +1 -0
  22. package/es/chat-engine/components/a2ui/containers/A2UICard.d.ts +22 -0
  23. package/es/chat-engine/components/a2ui/containers/A2UICard.js +82 -0
  24. package/es/chat-engine/components/a2ui/containers/A2UICard.js.map +1 -0
  25. package/es/chat-engine/components/a2ui/containers/A2UIColumn.d.ts +18 -0
  26. package/es/chat-engine/components/a2ui/containers/A2UIColumn.js +81 -0
  27. package/es/chat-engine/components/a2ui/containers/A2UIColumn.js.map +1 -0
  28. package/es/chat-engine/components/a2ui/containers/A2UIList.d.ts +14 -0
  29. package/es/chat-engine/components/a2ui/containers/A2UIList.js +62 -0
  30. package/es/chat-engine/components/a2ui/containers/A2UIList.js.map +1 -0
  31. package/es/chat-engine/components/a2ui/containers/A2UIRow.d.ts +20 -0
  32. package/es/chat-engine/components/a2ui/containers/A2UIRow.js +84 -0
  33. package/es/chat-engine/components/a2ui/containers/A2UIRow.js.map +1 -0
  34. package/es/chat-engine/components/a2ui/containers/A2UITabs.d.ts +14 -0
  35. package/es/chat-engine/components/a2ui/containers/A2UITabs.js +69 -0
  36. package/es/chat-engine/components/a2ui/containers/A2UITabs.js.map +1 -0
  37. package/es/chat-engine/components/a2ui/containers/index.d.ts +8 -0
  38. package/es/chat-engine/components/a2ui/containers/index.js +30 -0
  39. package/es/chat-engine/components/a2ui/containers/index.js.map +1 -0
  40. package/es/chat-engine/components/a2ui/index.d.ts +11 -0
  41. package/es/chat-engine/components/a2ui/index.js +62 -0
  42. package/es/chat-engine/components/a2ui/index.js.map +1 -0
  43. package/es/chat-engine/components/a2ui/primitives/A2UIButton.d.ts +33 -0
  44. package/es/chat-engine/components/a2ui/primitives/A2UIButton.js +80 -0
  45. package/es/chat-engine/components/a2ui/primitives/A2UIButton.js.map +1 -0
  46. package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.d.ts +12 -0
  47. package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.js +43 -0
  48. package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.js.map +1 -0
  49. package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.d.ts +50 -0
  50. package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.js +54 -0
  51. package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.js.map +1 -0
  52. package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.d.ts +13 -0
  53. package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.js +89 -0
  54. package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.js.map +1 -0
  55. package/es/chat-engine/components/a2ui/primitives/A2UIDivider.d.ts +12 -0
  56. package/es/chat-engine/components/a2ui/primitives/A2UIDivider.js +25 -0
  57. package/es/chat-engine/components/a2ui/primitives/A2UIDivider.js.map +1 -0
  58. package/es/chat-engine/components/a2ui/primitives/A2UIIcon.d.ts +13 -0
  59. package/es/chat-engine/components/a2ui/primitives/A2UIIcon.js +138942 -0
  60. package/es/chat-engine/components/a2ui/primitives/A2UIIcon.js.map +1 -0
  61. package/es/chat-engine/components/a2ui/primitives/A2UIImage.d.ts +12 -0
  62. package/es/chat-engine/components/a2ui/primitives/A2UIImage.js +75 -0
  63. package/es/chat-engine/components/a2ui/primitives/A2UIImage.js.map +1 -0
  64. package/es/chat-engine/components/a2ui/primitives/A2UIInput.d.ts +20 -0
  65. package/es/chat-engine/components/a2ui/primitives/A2UIInput.js +63 -0
  66. package/es/chat-engine/components/a2ui/primitives/A2UIInput.js.map +1 -0
  67. package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.d.ts +56 -0
  68. package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.js +64 -0
  69. package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.js.map +1 -0
  70. package/es/chat-engine/components/a2ui/primitives/A2UISlider.d.ts +12 -0
  71. package/es/chat-engine/components/a2ui/primitives/A2UISlider.js +55 -0
  72. package/es/chat-engine/components/a2ui/primitives/A2UISlider.js.map +1 -0
  73. package/es/chat-engine/components/a2ui/primitives/A2UIText.d.ts +12 -0
  74. package/es/chat-engine/components/a2ui/primitives/A2UIText.js +104 -0
  75. package/es/chat-engine/components/a2ui/primitives/A2UIText.js.map +1 -0
  76. package/es/chat-engine/components/a2ui/primitives/A2UITextField.d.ts +12 -0
  77. package/es/chat-engine/components/a2ui/primitives/A2UITextField.js +80 -0
  78. package/es/chat-engine/components/a2ui/primitives/A2UITextField.js.map +1 -0
  79. package/es/chat-engine/components/a2ui/primitives/index.d.ts +15 -0
  80. package/es/chat-engine/components/a2ui/primitives/index.js +39 -0
  81. package/es/chat-engine/components/a2ui/primitives/index.js.map +1 -0
  82. package/es/chat-engine/components/a2ui/registry.d.ts +35 -0
  83. package/es/chat-engine/components/a2ui/registry.js +74 -0
  84. package/es/chat-engine/components/a2ui/registry.js.map +1 -0
  85. package/es/chat-engine/components/activity/index.js +1 -1
  86. package/es/chat-engine/components/activity/registry.d.ts +1 -1
  87. package/es/chat-engine/components/activity/registry.js +1 -1
  88. package/es/chat-engine/components/activity/registry.js.map +1 -1
  89. package/es/chat-engine/components/activity/render.d.ts +2 -2
  90. package/es/chat-engine/components/activity/render.js +1 -1
  91. package/es/chat-engine/components/activity/render.js.map +1 -1
  92. package/es/chat-engine/components/activity/types.js +1 -1
  93. package/es/chat-engine/components/index.d.ts +1 -0
  94. package/es/chat-engine/components/index.js +57 -9
  95. package/es/chat-engine/components/index.js.map +1 -1
  96. package/es/chat-engine/components/json-render/A2UIJsonRenderActivityRenderer.d.ts +36 -0
  97. package/es/chat-engine/components/json-render/A2UIJsonRenderActivityRenderer.js +36 -0
  98. package/es/chat-engine/components/json-render/A2UIJsonRenderActivityRenderer.js.map +1 -0
  99. package/es/chat-engine/components/json-render/JsonRenderActivityRenderer.d.ts +46 -0
  100. package/es/chat-engine/components/json-render/JsonRenderActivityRenderer.js +36 -0
  101. package/es/chat-engine/components/json-render/JsonRenderActivityRenderer.js.map +1 -0
  102. package/es/chat-engine/components/json-render/SurfaceStateManager.d.ts +113 -0
  103. package/es/chat-engine/components/json-render/SurfaceStateManager.js +195 -0
  104. package/es/chat-engine/components/json-render/SurfaceStateManager.js.map +1 -0
  105. package/es/chat-engine/components/json-render/adapters/a2ui-to-jsonrender.d.ts +49 -0
  106. package/es/chat-engine/components/json-render/adapters/a2ui-to-jsonrender.js +307 -0
  107. package/es/chat-engine/components/json-render/adapters/a2ui-to-jsonrender.js.map +1 -0
  108. package/es/chat-engine/components/json-render/adapters/a2ui-types.d.ts +96 -0
  109. package/es/chat-engine/components/json-render/adapters/a2ui-types.js +7 -0
  110. package/es/chat-engine/components/json-render/adapters/a2ui-types.js.map +1 -0
  111. package/es/chat-engine/components/json-render/adapters/index.d.ts +7 -0
  112. package/es/chat-engine/components/json-render/adapters/index.js +11 -0
  113. package/es/chat-engine/components/json-render/adapters/index.js.map +1 -0
  114. package/es/chat-engine/components/json-render/catalog/a2ui-binding.d.ts +64 -0
  115. package/es/chat-engine/components/json-render/catalog/a2ui-binding.js +36 -0
  116. package/es/chat-engine/components/json-render/catalog/a2ui-binding.js.map +1 -0
  117. package/es/chat-engine/components/json-render/catalog/a2ui-registry.d.ts +78 -0
  118. package/es/chat-engine/components/json-render/catalog/a2ui-registry.js +36 -0
  119. package/es/chat-engine/components/json-render/catalog/a2ui-registry.js.map +1 -0
  120. package/es/chat-engine/components/json-render/catalog/button.d.ts +14 -0
  121. package/es/chat-engine/components/json-render/catalog/button.js +71 -0
  122. package/es/chat-engine/components/json-render/catalog/button.js.map +1 -0
  123. package/es/chat-engine/components/json-render/catalog/card.d.ts +11 -0
  124. package/es/chat-engine/components/json-render/catalog/card.js +57 -0
  125. package/es/chat-engine/components/json-render/catalog/card.js.map +1 -0
  126. package/es/chat-engine/components/json-render/catalog/index.d.ts +127 -0
  127. package/es/chat-engine/components/json-render/catalog/index.js +36 -0
  128. package/es/chat-engine/components/json-render/catalog/index.js.map +1 -0
  129. package/es/chat-engine/components/json-render/catalog/input.d.ts +20 -0
  130. package/es/chat-engine/components/json-render/catalog/input.js +36 -0
  131. package/es/chat-engine/components/json-render/catalog/input.js.map +1 -0
  132. package/es/chat-engine/components/json-render/catalog/layout.d.ts +44 -0
  133. package/es/chat-engine/components/json-render/catalog/layout.js +129 -0
  134. package/es/chat-engine/components/json-render/catalog/layout.js.map +1 -0
  135. package/es/chat-engine/components/json-render/catalog/text.d.ts +11 -0
  136. package/es/chat-engine/components/json-render/catalog/text.js +31 -0
  137. package/es/chat-engine/components/json-render/catalog/text.js.map +1 -0
  138. package/es/chat-engine/components/json-render/catalog.d.ts +549 -0
  139. package/es/chat-engine/components/json-render/catalog.js +147 -0
  140. package/es/chat-engine/components/json-render/catalog.js.map +1 -0
  141. package/es/chat-engine/components/json-render/config.d.ts +154 -0
  142. package/es/chat-engine/components/json-render/config.js +36 -0
  143. package/es/chat-engine/components/json-render/config.js.map +1 -0
  144. package/es/chat-engine/components/json-render/contexts/actions.d.ts +74 -0
  145. package/es/chat-engine/components/json-render/contexts/actions.js +290 -0
  146. package/es/chat-engine/components/json-render/contexts/actions.js.map +1 -0
  147. package/es/chat-engine/components/json-render/contexts/data.d.ts +45 -0
  148. package/es/chat-engine/components/json-render/contexts/data.js +104 -0
  149. package/es/chat-engine/components/json-render/contexts/data.js.map +1 -0
  150. package/es/chat-engine/components/json-render/contexts/validation.d.ts +59 -0
  151. package/es/chat-engine/components/json-render/contexts/validation.js +151 -0
  152. package/es/chat-engine/components/json-render/contexts/validation.js.map +1 -0
  153. package/es/chat-engine/components/json-render/contexts/visibility.d.ts +29 -0
  154. package/es/chat-engine/components/json-render/contexts/visibility.js +56 -0
  155. package/es/chat-engine/components/json-render/contexts/visibility.js.map +1 -0
  156. package/es/chat-engine/components/json-render/engine.d.ts +58 -0
  157. package/es/chat-engine/components/json-render/engine.js +88 -0
  158. package/es/chat-engine/components/json-render/engine.js.map +1 -0
  159. package/es/chat-engine/components/json-render/index.d.ts +34 -0
  160. package/es/chat-engine/components/json-render/index.js +36 -0
  161. package/es/chat-engine/components/json-render/index.js.map +1 -0
  162. package/es/chat-engine/components/json-render/performance.d.ts +91 -0
  163. package/es/chat-engine/components/json-render/performance.js +135 -0
  164. package/es/chat-engine/components/json-render/performance.js.map +1 -0
  165. package/es/chat-engine/components/json-render/renderer.d.ts +71 -0
  166. package/es/chat-engine/components/json-render/renderer.js +124 -0
  167. package/es/chat-engine/components/json-render/renderer.js.map +1 -0
  168. package/es/chat-engine/components/json-render/types.d.ts +69 -0
  169. package/es/chat-engine/components/json-render/types.js +7 -0
  170. package/es/chat-engine/components/json-render/types.js.map +1 -0
  171. package/es/chat-engine/components/provider/agent-state.js +39 -2
  172. package/es/chat-engine/components/provider/agent-state.js.map +1 -1
  173. package/es/chat-engine/components/toolcall/index.js +32 -2
  174. package/es/chat-engine/components/toolcall/index.js.map +1 -1
  175. package/es/chat-engine/components/toolcall/registry.js +1 -1
  176. package/es/chat-engine/components/toolcall/render.d.ts +1 -1
  177. package/es/chat-engine/components/toolcall/render.js +33 -4
  178. package/es/chat-engine/components/toolcall/render.js.map +1 -1
  179. package/es/chat-engine/components/toolcall/types.js +1 -1
  180. package/es/chat-engine/core/a2ui/index.d.ts +10 -0
  181. package/es/chat-engine/core/a2ui/index.js +24 -0
  182. package/es/chat-engine/core/a2ui/index.js.map +1 -0
  183. package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.d.ts +197 -0
  184. package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.js +438 -0
  185. package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.js.map +1 -0
  186. package/es/chat-engine/core/a2ui/processor/ComponentTree.d.ts +53 -0
  187. package/es/chat-engine/core/a2ui/processor/ComponentTree.js +158 -0
  188. package/es/chat-engine/core/a2ui/processor/ComponentTree.js.map +1 -0
  189. package/es/chat-engine/core/a2ui/processor/DataStore.d.ts +63 -0
  190. package/es/chat-engine/core/a2ui/processor/DataStore.js +172 -0
  191. package/es/chat-engine/core/a2ui/processor/DataStore.js.map +1 -0
  192. package/es/chat-engine/core/a2ui/processor/PathResolver.d.ts +47 -0
  193. package/es/chat-engine/core/a2ui/processor/PathResolver.js +99 -0
  194. package/es/chat-engine/core/a2ui/processor/PathResolver.js.map +1 -0
  195. package/es/chat-engine/core/a2ui/types/index.d.ts +4 -0
  196. package/es/chat-engine/core/a2ui/types/index.js +9 -0
  197. package/es/chat-engine/core/a2ui/types/index.js.map +1 -0
  198. package/es/chat-engine/core/a2ui/types/types.d.ts +770 -0
  199. package/es/chat-engine/core/a2ui/types/types.js +104 -0
  200. package/es/chat-engine/core/a2ui/types/types.js.map +1 -0
  201. package/es/chat-engine/core/a2ui/utils/binding.d.ts +34 -0
  202. package/es/chat-engine/core/a2ui/utils/binding.js +1784 -0
  203. package/es/chat-engine/core/a2ui/utils/binding.js.map +1 -0
  204. package/es/chat-engine/core/a2ui/utils/index.d.ts +5 -0
  205. package/es/chat-engine/core/a2ui/utils/index.js +13 -0
  206. package/es/chat-engine/core/a2ui/utils/index.js.map +1 -0
  207. package/es/chat-engine/core/a2ui/utils/validation.d.ts +70 -0
  208. package/es/chat-engine/core/a2ui/utils/validation.js +333 -0
  209. package/es/chat-engine/core/a2ui/utils/validation.js.map +1 -0
  210. package/es/chat-engine/core/adapters/agui/activity-manager.d.ts +102 -0
  211. package/es/chat-engine/core/adapters/agui/activity-manager.js +144 -0
  212. package/es/chat-engine/core/adapters/agui/activity-manager.js.map +1 -0
  213. package/es/chat-engine/core/adapters/agui/event-mapper.d.ts +42 -2
  214. package/es/chat-engine/core/adapters/agui/event-mapper.js +90 -50
  215. package/es/chat-engine/core/adapters/agui/event-mapper.js.map +1 -1
  216. package/es/chat-engine/core/adapters/agui/events.d.ts +222 -222
  217. package/es/chat-engine/core/adapters/agui/events.js +34 -34
  218. package/es/chat-engine/core/adapters/agui/events.js.map +1 -1
  219. package/es/chat-engine/core/adapters/agui/index.d.ts +22 -2
  220. package/es/chat-engine/core/adapters/agui/index.js +34 -14
  221. package/es/chat-engine/core/adapters/agui/index.js.map +1 -1
  222. package/es/chat-engine/core/adapters/agui/state-manager.js +1 -1
  223. package/es/chat-engine/core/adapters/agui/types.d.ts +57 -56
  224. package/es/chat-engine/core/adapters/agui/types.js +5 -5
  225. package/es/chat-engine/core/adapters/agui/types.js.map +1 -1
  226. package/es/chat-engine/core/adapters/agui/utils.d.ts +9 -3
  227. package/es/chat-engine/core/adapters/agui/utils.js +23 -4
  228. package/es/chat-engine/core/adapters/agui/utils.js.map +1 -1
  229. package/es/chat-engine/core/event-bus/ChatEventBus.d.ts +88 -0
  230. package/es/chat-engine/core/event-bus/ChatEventBus.js +295 -0
  231. package/es/chat-engine/core/event-bus/ChatEventBus.js.map +1 -0
  232. package/es/chat-engine/core/event-bus/index.d.ts +5 -0
  233. package/es/chat-engine/core/event-bus/index.js +13 -0
  234. package/es/chat-engine/core/event-bus/index.js.map +1 -0
  235. package/es/chat-engine/core/event-bus/types.d.ts +230 -0
  236. package/es/chat-engine/core/event-bus/types.js +32 -0
  237. package/es/chat-engine/core/event-bus/types.js.map +1 -0
  238. package/es/chat-engine/core/index.d.ts +16 -1
  239. package/es/chat-engine/core/index.js +174 -17
  240. package/es/chat-engine/core/index.js.map +1 -1
  241. package/es/chat-engine/core/processor/index.js +1 -1
  242. package/es/chat-engine/core/server/batch-client.js +1 -1
  243. package/es/chat-engine/core/server/connection-manager.js +1 -1
  244. package/es/chat-engine/core/server/errors.js +1 -1
  245. package/es/chat-engine/core/server/index.js +1 -1
  246. package/es/chat-engine/core/server/llm-service.js +17 -15
  247. package/es/chat-engine/core/server/llm-service.js.map +1 -1
  248. package/es/chat-engine/core/server/sse-client.js +1 -1
  249. package/es/chat-engine/core/server/sse-parser.js +1 -1
  250. package/es/chat-engine/core/server/types.js +1 -1
  251. package/es/chat-engine/core/store/message.js +2 -2
  252. package/es/chat-engine/core/store/message.js.map +1 -1
  253. package/es/chat-engine/core/store/model.js +1 -1
  254. package/es/chat-engine/core/store/reactiveState.js +1 -1
  255. package/es/chat-engine/core/type.d.ts +18 -2
  256. package/es/chat-engine/core/type.js +1 -1
  257. package/es/chat-engine/core/utils/eventEmitter.js +1 -1
  258. package/es/chat-engine/core/utils/index.js +1 -1
  259. package/es/chat-engine/core/utils/logger.js +1 -1
  260. package/es/chat-engine/hooks/a2ui/A2UIContext.d.ts +90 -0
  261. package/es/chat-engine/hooks/a2ui/A2UIContext.js +97 -0
  262. package/es/chat-engine/hooks/a2ui/A2UIContext.js.map +1 -0
  263. package/es/chat-engine/hooks/a2ui/index.d.ts +12 -0
  264. package/es/chat-engine/hooks/a2ui/index.js +19 -0
  265. package/es/chat-engine/hooks/a2ui/index.js.map +1 -0
  266. package/es/chat-engine/hooks/a2ui/useA2UIAction.d.ts +40 -0
  267. package/es/chat-engine/hooks/a2ui/useA2UIAction.js +74 -0
  268. package/es/chat-engine/hooks/a2ui/useA2UIAction.js.map +1 -0
  269. package/es/chat-engine/hooks/a2ui/useA2UISurface.d.ts +36 -0
  270. package/es/chat-engine/hooks/a2ui/useA2UISurface.js +39 -0
  271. package/es/chat-engine/hooks/a2ui/useA2UISurface.js.map +1 -0
  272. package/es/chat-engine/hooks/a2ui/useDataBinding.d.ts +53 -0
  273. package/es/chat-engine/hooks/a2ui/useDataBinding.js +111 -0
  274. package/es/chat-engine/hooks/a2ui/useDataBinding.js.map +1 -0
  275. package/es/chat-engine/hooks/index.js +38 -4
  276. package/es/chat-engine/hooks/index.js.map +1 -1
  277. package/es/chat-engine/hooks/useAgentActivity.d.ts +1 -2
  278. package/es/chat-engine/hooks/useAgentActivity.js +1 -1
  279. package/es/chat-engine/hooks/useAgentActivity.js.map +1 -1
  280. package/es/chat-engine/hooks/useAgentState.js +39 -2
  281. package/es/chat-engine/hooks/useAgentState.js.map +1 -1
  282. package/es/chat-engine/hooks/useAgentToolcall.js +1 -1
  283. package/es/chat-engine/hooks/useChat.d.ts +3 -3
  284. package/es/chat-engine/hooks/useChat.js +40 -2
  285. package/es/chat-engine/hooks/useChat.js.map +1 -1
  286. package/es/chat-engine/hooks/useJsonRenderActivity.d.ts +56 -0
  287. package/es/chat-engine/hooks/useJsonRenderActivity.js +63 -0
  288. package/es/chat-engine/hooks/useJsonRenderActivity.js.map +1 -0
  289. package/es/chat-engine/index.d.ts +1 -3
  290. package/es/chat-engine/index.js +30 -8
  291. package/es/chat-engine/index.js.map +1 -1
  292. package/es/chat-filecard/index.js +1 -1
  293. package/es/chat-loading/index.js +1 -1
  294. package/es/chat-markdown/index.js +1 -1
  295. package/es/chat-message/index.js +1 -1
  296. package/es/chat-sender/index.js +1 -1
  297. package/es/chat-thinking/index.js +1 -1
  298. package/es/chatbot/docs/react-best-practice.d.ts +13 -0
  299. package/es/chatbot/index.js +1 -1
  300. package/es/index.js +27 -5
  301. package/es/index.js.map +1 -1
  302. package/es/style/index.js +1 -1
  303. package/package.json +6 -3
@@ -0,0 +1,82 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.14
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ import React__default from 'react';
8
+ import { Card } from 'tdesign-react';
9
+ import { useDataBinding } from '../../../hooks/a2ui/useDataBinding.js';
10
+ import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
11
+ import '@babel/runtime/helpers/slicedToArray';
12
+ import '../../../hooks/a2ui/A2UIContext.js';
13
+ import '@babel/runtime/helpers/defineProperty';
14
+ import '../../../core/a2ui/utils/index.js';
15
+ import '../../../core/a2ui/utils/binding.js';
16
+ import '@babel/runtime/helpers/typeof';
17
+ import '../../../core/a2ui/utils/validation.js';
18
+ import '@babel/runtime/helpers/toConsumableArray';
19
+ import '../A2UIErrorBoundary.js';
20
+ import '@babel/runtime/helpers/classCallCheck';
21
+ import '@babel/runtime/helpers/createClass';
22
+ import '@babel/runtime/helpers/possibleConstructorReturn';
23
+ import '@babel/runtime/helpers/getPrototypeOf';
24
+ import '@babel/runtime/helpers/inherits';
25
+
26
+ var A2UICard = function A2UICard(_ref) {
27
+ var id = _ref.id,
28
+ child = _ref.child,
29
+ resolvedChildren = _ref.resolvedChildren,
30
+ title = _ref.title,
31
+ _ref$bordered = _ref.bordered,
32
+ bordered = _ref$bordered === void 0 ? true : _ref$bordered,
33
+ _ref$shadow = _ref.shadow,
34
+ shadow = _ref$shadow === void 0 ? false : _ref$shadow,
35
+ subtitle = _ref.subtitle,
36
+ description = _ref.description,
37
+ _ref$hoverShadow = _ref.hoverShadow,
38
+ hoverShadow = _ref$hoverShadow === void 0 ? false : _ref$hoverShadow,
39
+ _ref$size = _ref.size,
40
+ size = _ref$size === void 0 ? "medium" : _ref$size,
41
+ _ref$headerBordered = _ref.headerBordered,
42
+ headerBordered = _ref$headerBordered === void 0 ? false : _ref$headerBordered,
43
+ children = _ref.children,
44
+ className = _ref.className,
45
+ style = _ref.style;
46
+ var resolvedTitle = useDataBinding(title);
47
+ var renderContent = function renderContent() {
48
+ if (resolvedChildren && resolvedChildren.length > 0) {
49
+ return resolvedChildren.map(function (comp, index) {
50
+ return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
51
+ key: comp.id || index,
52
+ component: comp
53
+ });
54
+ });
55
+ }
56
+ if (children && Array.isArray(children)) {
57
+ return children.map(function (comp, index) {
58
+ return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
59
+ key: comp.id || index,
60
+ component: comp
61
+ });
62
+ });
63
+ }
64
+ return null;
65
+ };
66
+ return /* @__PURE__ */React__default.createElement(Card, {
67
+ className: className,
68
+ style: style,
69
+ title: resolvedTitle,
70
+ subtitle: subtitle,
71
+ description: description,
72
+ bordered: bordered,
73
+ shadow: shadow,
74
+ hoverShadow: hoverShadow,
75
+ size: size,
76
+ headerBordered: headerBordered
77
+ }, renderContent());
78
+ };
79
+ A2UICard.displayName = "A2UICard";
80
+
81
+ export { A2UICard, A2UICard as default };
82
+ //# sourceMappingURL=A2UICard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"A2UICard.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UICard.tsx"],"sourcesContent":["/**\n * A2UI Card 容器组件\n * 复用 TDesign Card,支持 A2UI v0.9 child 模式\n */\n\nimport React from 'react';\nimport { Card } from 'tdesign-react';\nimport { useDataBinding } from '../../../hooks/a2ui/useDataBinding';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UICardComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UICardProps extends Omit<A2UICardComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n /** TDesign 扩展属性 */\n subtitle?: string;\n description?: string;\n hoverShadow?: boolean;\n size?: 'medium' | 'small';\n headerBordered?: boolean;\n /** 向后兼容:children 数组 */\n children?: any[];\n}\n\nexport const A2UICard: React.FC<A2UICardProps> = ({\n id,\n child,\n resolvedChildren,\n title,\n bordered = true,\n shadow = false,\n // TDesign 扩展\n subtitle,\n description,\n hoverShadow = false,\n size = 'medium',\n headerBordered = false,\n // 向后兼容\n children,\n className,\n style,\n}) => {\n // 解析绑定值\n const resolvedTitle = useDataBinding<React.ReactNode>(title);\n\n // 渲染内容:优先使用 resolvedChildren(A2UI v0.9),其次使用 children(向后兼容)\n const renderContent = () => {\n if (resolvedChildren && resolvedChildren.length > 0) {\n return resolvedChildren.map((comp, index) => (\n <A2UIComponentRenderer key={comp.id || index} component={comp} />\n ));\n }\n // 向后兼容:直接渲染 children\n if (children && Array.isArray(children)) {\n return children.map((comp, index) => (\n <A2UIComponentRenderer key={comp.id || index} component={comp} />\n ));\n }\n return null;\n };\n\n return (\n <Card\n className={className}\n style={style}\n title={resolvedTitle}\n subtitle={subtitle}\n description={description}\n bordered={bordered as boolean}\n shadow={shadow as boolean}\n hoverShadow={hoverShadow as boolean}\n size={size}\n headerBordered={headerBordered}\n >\n {renderContent()}\n </Card>\n );\n};\n\nA2UICard.displayName = 'A2UICard';\n\nexport default A2UICard;\n"],"names":["A2UICard","id","_ref","child","resolvedChildren","title","_ref$bordered","bordered","_ref$shadow","shadow","subtitle","description","_ref$hoverShadow","hoverShadow","_ref$size","size","_ref$headerBordered","headerBordered","children","className","style","resolvedTitle","useDataBinding","renderContent","length","map","comp","index","React","createElement","A2UIComponentRenderer","key","component","Array","isArray","Card","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;IA0BaA,WAAoC,SAApCA,eAiBP;AAAA,EAAA,IAhBJC,EAAA,GAAAC,IAAA,CAAAD,EAAA;IACAE,KAAA,GAAAD,IAAA,CAAAC,KAAA;IACAC,gBAAA,GAAAF,IAAA,CAAAE,gBAAA;IACAC,KAAA,GAAAH,IAAA,CAAAG,KAAA;IAAAC,aAAA,GAAAJ,IAAA,CACAK,QAAW;AAAXA,IAAAA,QAAW,GAAAD,aAAA,KAAA,KAAA,CAAA,GAAA,IAAA,GAAAA,aAAA;IAAAE,WAAA,GAAAN,IAAA,CACXO,MAAS;AAATA,IAAAA,MAAS,GAAAD,WAAA,KAAA,KAAA,CAAA,GAAA,KAAA,GAAAA,WAAA;IAETE,QAAA,GAAAR,IAAA,CAAAQ,QAAA;IACAC,WAAA,GAAAT,IAAA,CAAAS,WAAA;IAAAC,gBAAA,GAAAV,IAAA,CACAW,WAAc;AAAdA,IAAAA,WAAc,GAAAD,gBAAA,KAAA,KAAA,CAAA,GAAA,KAAA,GAAAA,gBAAA;IAAAE,SAAA,GAAAZ,IAAA,CACda,IAAO;AAAPA,IAAAA,IAAO,GAAAD,SAAA,KAAA,KAAA,CAAA,GAAA,QAAA,GAAAA,SAAA;IAAAE,mBAAA,GAAAd,IAAA,CACPe,cAAiB;AAAjBA,IAAAA,cAAiB,GAAAD,mBAAA,KAAA,KAAA,CAAA,GAAA,KAAA,GAAAA,mBAAA;IAEjBE,QAAA,GAAAhB,IAAA,CAAAgB,QAAA;IACAC,SAAA,GAAAjB,IAAA,CAAAiB,SAAA;IACAC,KAAA,GAAAlB,IAAA,CAAAkB,KAAA,CAAA;AAGM,EAAA,IAAAC,aAAA,GAAgBC,eAAgCjB,KAAK,CAAA,CAAA;AAG3D,EAAA,IAAMkB,gBAAgB,SAAhBA,gBAAsB;AACtB,IAAA,IAAAnB,gBAAA,IAAoBA,gBAAiB,CAAAoB,MAAA,GAAS,CAAG,EAAA;AACnD,MAAA,OAAOpB,gBAAiB,CAAAqB,GAAA,CAAI,UAACC,IAAA,EAAMC;8BAChCC,cAAA,CAAAC,aAAA,CAAAC,qBAAA,EAAA;AAAsBC,UAAAA,GAAA,EAAKL,KAAKzB,EAAM,IAAA0B,KAAA;AAAOK,UAAAA,SAAW,EAAAN,IAAAA;AAAA,SAAM,CAChE,CAAA;OAAA,CAAA,CAAA;AACH,KAAA;IAEA,IAAIR,QAAY,IAAAe,KAAA,CAAMC,OAAQ,CAAAhB,QAAQ,CAAG,EAAA;AACvC,MAAA,OAAOA,QAAS,CAAAO,GAAA,CAAI,UAACC,IAAA,EAAMC;8BACxBC,cAAA,CAAAC,aAAA,CAAAC,qBAAA,EAAA;AAAsBC,UAAAA,GAAA,EAAKL,KAAKzB,EAAM,IAAA0B,KAAA;AAAOK,UAAAA,SAAW,EAAAN,IAAAA;AAAA,SAAM,CAChE,CAAA;OAAA,CAAA,CAAA;AACH,KAAA;AACO,IAAA,OAAA,IAAA,CAAA;GACT,CAAA;AAEA,EAAA,sBACGE,cAAA,CAAAC,aAAA,CAAAM,IAAA,EAAA;AACChB,IAAAA,SAAA,EAAAA,SAAA;AACAC,IAAAA,KAAA,EAAAA,KAAA;AACAf,IAAAA,KAAO,EAAAgB,aAAA;AACPX,IAAAA,QAAA,EAAAA,QAAA;AACAC,IAAAA,WAAA,EAAAA,WAAA;AACAJ,IAAAA,QAAA,EAAAA,QAAA;AACAE,IAAAA,MAAA,EAAAA,MAAA;AACAI,IAAAA,WAAA,EAAAA,WAAA;AACAE,IAAAA,IAAA,EAAAA,IAAA;AACAE,IAAAA,cAAA,EAAAA,cAAAA;AAAA,GAAA,EAECM,eACH,CAAA,CAAA;AAEJ,EAAA;AAEAvB,QAAA,CAASoC,WAAc,GAAA,UAAA;;;;"}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * A2UI Column 容器组件
3
+ * A2UI v0.9 标准垂直布局组件
4
+ */
5
+ import React from 'react';
6
+ import type { A2UIColumnComponent, ResolvedComponent } from '../../../core/a2ui';
7
+ export interface A2UIColumnProps extends Omit<A2UIColumnComponent, 'component'> {
8
+ /** 解析后的子组件(由 ComponentRenderer 传入) */
9
+ resolvedChildren?: ResolvedComponent[];
10
+ className?: string;
11
+ style?: React.CSSProperties;
12
+ /** 向后兼容:gap 属性 */
13
+ gap?: number | string;
14
+ /** 向后兼容:align 属性 */
15
+ align?: 'start' | 'center' | 'end' | 'stretch';
16
+ }
17
+ export declare const A2UIColumn: React.FC<A2UIColumnProps>;
18
+ export default A2UIColumn;
@@ -0,0 +1,81 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.14
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ import _defineProperty from '@babel/runtime/helpers/defineProperty';
8
+ import React__default, { useMemo } from 'react';
9
+ import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
10
+ import '../../../hooks/a2ui/A2UIContext.js';
11
+ import '../A2UIErrorBoundary.js';
12
+ import '@babel/runtime/helpers/classCallCheck';
13
+ import '@babel/runtime/helpers/createClass';
14
+ import '@babel/runtime/helpers/possibleConstructorReturn';
15
+ import '@babel/runtime/helpers/getPrototypeOf';
16
+ import '@babel/runtime/helpers/inherits';
17
+
18
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
19
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
20
+ var distributionMap = {
21
+ start: "flex-start",
22
+ center: "center",
23
+ end: "flex-end",
24
+ spaceBetween: "space-between",
25
+ spaceAround: "space-around",
26
+ spaceEvenly: "space-evenly",
27
+ stretch: "stretch"
28
+ };
29
+ var alignmentMap = {
30
+ start: "flex-start",
31
+ center: "center",
32
+ end: "flex-end",
33
+ stretch: "stretch"
34
+ };
35
+ var A2UIColumn = function A2UIColumn(_ref) {
36
+ var id = _ref.id,
37
+ children = _ref.children,
38
+ resolvedChildren = _ref.resolvedChildren,
39
+ distribution = _ref.distribution,
40
+ alignment = _ref.alignment,
41
+ gap = _ref.gap,
42
+ align = _ref.align,
43
+ className = _ref.className,
44
+ style = _ref.style;
45
+ var computedStyle = useMemo(function () {
46
+ var baseStyle = {
47
+ display: "flex",
48
+ flexDirection: "column"
49
+ };
50
+ if (distribution && typeof distribution === "string") {
51
+ baseStyle.justifyContent = distributionMap[distribution] || distribution;
52
+ }
53
+ if (alignment && typeof alignment === "string") {
54
+ baseStyle.alignItems = alignmentMap[alignment] || alignment;
55
+ } else if (align) {
56
+ baseStyle.alignItems = align === "start" ? "flex-start" : align === "end" ? "flex-end" : align;
57
+ }
58
+ if (gap !== void 0) {
59
+ baseStyle.gap = typeof gap === "number" ? "".concat(gap, "px") : gap;
60
+ } else {
61
+ baseStyle.gap = "8px";
62
+ }
63
+ return baseStyle;
64
+ }, [distribution, alignment, gap, align]);
65
+ if (!resolvedChildren || resolvedChildren.length === 0) {
66
+ return null;
67
+ }
68
+ return /* @__PURE__ */React__default.createElement("div", {
69
+ className: className,
70
+ style: _objectSpread(_objectSpread({}, computedStyle), style)
71
+ }, resolvedChildren.map(function (child, index) {
72
+ return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
73
+ key: child.id || index,
74
+ component: child
75
+ });
76
+ }));
77
+ };
78
+ A2UIColumn.displayName = "A2UIColumn";
79
+
80
+ export { A2UIColumn, A2UIColumn as default };
81
+ //# sourceMappingURL=A2UIColumn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"A2UIColumn.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UIColumn.tsx"],"sourcesContent":["/**\n * A2UI Column 容器组件\n * A2UI v0.9 标准垂直布局组件\n */\n\nimport React, { useMemo } from 'react';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UIColumnComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UIColumnProps extends Omit<A2UIColumnComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n /** 向后兼容:gap 属性 */\n gap?: number | string;\n /** 向后兼容:align 属性 */\n align?: 'start' | 'center' | 'end' | 'stretch';\n}\n\n// A2UI v0.9 distribution 到 CSS justify-content 的映射\nconst distributionMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n spaceBetween: 'space-between',\n spaceAround: 'space-around',\n spaceEvenly: 'space-evenly',\n stretch: 'stretch',\n};\n\n// A2UI v0.9 alignment 到 CSS align-items 的映射\nconst alignmentMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n stretch: 'stretch',\n};\n\nexport const A2UIColumn: React.FC<A2UIColumnProps> = ({\n id,\n children,\n resolvedChildren,\n distribution,\n alignment,\n // 向后兼容\n gap,\n align,\n className,\n style,\n}) => {\n // 计算样式\n const computedStyle = useMemo<React.CSSProperties>(() => {\n const baseStyle: React.CSSProperties = {\n display: 'flex',\n flexDirection: 'column',\n };\n\n // A2UI v0.9 distribution\n if (distribution && typeof distribution === 'string') {\n baseStyle.justifyContent = distributionMap[distribution] || distribution;\n }\n\n // A2UI v0.9 alignment\n if (alignment && typeof alignment === 'string') {\n baseStyle.alignItems = alignmentMap[alignment] || alignment;\n } else if (align) {\n // 向后兼容 align\n baseStyle.alignItems = align === 'start' ? 'flex-start' :\n align === 'end' ? 'flex-end' : align;\n }\n\n // gap\n if (gap !== undefined) {\n baseStyle.gap = typeof gap === 'number' ? `${gap}px` : gap;\n } else {\n baseStyle.gap = '8px'; // 默认间距\n }\n\n return baseStyle;\n }, [distribution, alignment, gap, align]);\n\n // 渲染子组件\n if (!resolvedChildren || resolvedChildren.length === 0) {\n return null;\n }\n\n return (\n <div className={className} style={{ ...computedStyle, ...style }}>\n {resolvedChildren.map((child, index) => (\n <A2UIComponentRenderer key={child.id || index} component={child} />\n ))}\n </div>\n );\n};\n\nA2UIColumn.displayName = 'A2UIColumn';\n\nexport default A2UIColumn;\n"],"names":["distributionMap","start","center","end","spaceBetween","spaceAround","spaceEvenly","stretch","alignmentMap","A2UIColumn","id","_ref","children","resolvedChildren","distribution","alignment","gap","align","className","style","computedStyle","useMemo","baseStyle","display","flexDirection","justifyContent","alignItems","concat","length","React","createElement","_objectSpread","map","child","index","A2UIComponentRenderer","key","component","displayName"],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * A2UI List 容器组件
3
+ * A2UI v0.9 标准列表组件
4
+ */
5
+ import React from 'react';
6
+ import type { A2UIListComponent, ResolvedComponent } from '../../../core/a2ui';
7
+ export interface A2UIListProps extends Omit<A2UIListComponent, 'component'> {
8
+ /** 解析后的子组件(由 ComponentRenderer 传入) */
9
+ resolvedChildren?: ResolvedComponent[];
10
+ className?: string;
11
+ style?: React.CSSProperties;
12
+ }
13
+ export declare const A2UIList: React.FC<A2UIListProps>;
14
+ export default A2UIList;
@@ -0,0 +1,62 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.14
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ import _defineProperty from '@babel/runtime/helpers/defineProperty';
8
+ import React__default, { useMemo } from 'react';
9
+ import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
10
+ import '../../../hooks/a2ui/A2UIContext.js';
11
+ import '../A2UIErrorBoundary.js';
12
+ import '@babel/runtime/helpers/classCallCheck';
13
+ import '@babel/runtime/helpers/createClass';
14
+ import '@babel/runtime/helpers/possibleConstructorReturn';
15
+ import '@babel/runtime/helpers/getPrototypeOf';
16
+ import '@babel/runtime/helpers/inherits';
17
+
18
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
19
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
20
+ var alignmentMap = {
21
+ start: "flex-start",
22
+ center: "center",
23
+ end: "flex-end",
24
+ stretch: "stretch"
25
+ };
26
+ var A2UIList = function A2UIList(_ref) {
27
+ var id = _ref.id,
28
+ children = _ref.children,
29
+ resolvedChildren = _ref.resolvedChildren,
30
+ _ref$direction = _ref.direction,
31
+ direction = _ref$direction === void 0 ? "vertical" : _ref$direction,
32
+ alignment = _ref.alignment,
33
+ className = _ref.className,
34
+ style = _ref.style;
35
+ var computedStyle = useMemo(function () {
36
+ var baseStyle = {
37
+ display: "flex",
38
+ flexDirection: direction === "horizontal" ? "row" : "column",
39
+ gap: "8px"
40
+ };
41
+ if (alignment && typeof alignment === "string") {
42
+ baseStyle.alignItems = alignmentMap[alignment] || alignment;
43
+ }
44
+ return baseStyle;
45
+ }, [direction, alignment]);
46
+ if (!resolvedChildren || resolvedChildren.length === 0) {
47
+ return null;
48
+ }
49
+ return /* @__PURE__ */React__default.createElement("div", {
50
+ className: className,
51
+ style: _objectSpread(_objectSpread({}, computedStyle), style)
52
+ }, resolvedChildren.map(function (child, index) {
53
+ return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
54
+ key: child.id || index,
55
+ component: child
56
+ });
57
+ }));
58
+ };
59
+ A2UIList.displayName = "A2UIList";
60
+
61
+ export { A2UIList, A2UIList as default };
62
+ //# sourceMappingURL=A2UIList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"A2UIList.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UIList.tsx"],"sourcesContent":["/**\n * A2UI List 容器组件\n * A2UI v0.9 标准列表组件\n */\n\nimport React, { useMemo } from 'react';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UIListComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UIListProps extends Omit<A2UIListComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n}\n\n// A2UI v0.9 alignment 到 CSS align-items 的映射\nconst alignmentMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n stretch: 'stretch',\n};\n\nexport const A2UIList: React.FC<A2UIListProps> = ({\n id,\n children,\n resolvedChildren,\n direction = 'vertical',\n alignment,\n className,\n style,\n}) => {\n // 计算样式\n const computedStyle = useMemo<React.CSSProperties>(() => {\n const baseStyle: React.CSSProperties = {\n display: 'flex',\n flexDirection: direction === 'horizontal' ? 'row' : 'column',\n gap: '8px',\n };\n\n if (alignment && typeof alignment === 'string') {\n baseStyle.alignItems = alignmentMap[alignment] || alignment;\n }\n\n return baseStyle;\n }, [direction, alignment]);\n\n // 渲染子组件\n if (!resolvedChildren || resolvedChildren.length === 0) {\n return null;\n }\n\n return (\n <div className={className} style={{ ...computedStyle, ...style }}>\n {resolvedChildren.map((child, index) => (\n <A2UIComponentRenderer key={child.id || index} component={child} />\n ))}\n </div>\n );\n};\n\nA2UIList.displayName = 'A2UIList';\n\nexport default A2UIList;\n"],"names":["alignmentMap","start","center","end","stretch","A2UIList","id","_ref","children","resolvedChildren","_ref$direction","direction","alignment","className","style","computedStyle","useMemo","baseStyle","display","flexDirection","gap","alignItems","length","React","createElement","_objectSpread","map","child","index","A2UIComponentRenderer","key","component","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;AAiBA,IAAMA,YAAuC,GAAA;AAC3CC,EAAAA,KAAO,EAAA,YAAA;AACPC,EAAAA,MAAQ,EAAA,QAAA;AACRC,EAAAA,GAAK,EAAA,UAAA;AACLC,EAAAA,OAAS,EAAA,SAAA;AACX,CAAA,CAAA;IAEaC,WAAoC,SAApCA,eAQP;AAAA,EAAA,IAPJC,EAAA,GAAAC,IAAA,CAAAD,EAAA;IACAE,QAAA,GAAAD,IAAA,CAAAC,QAAA;IACAC,gBAAA,GAAAF,IAAA,CAAAE,gBAAA;IAAAC,cAAA,GAAAH,IAAA,CACAI,SAAY;AAAZA,IAAAA,SAAY,GAAAD,cAAA,KAAA,KAAA,CAAA,GAAA,UAAA,GAAAA,cAAA;IACZE,SAAA,GAAAL,IAAA,CAAAK,SAAA;IACAC,SAAA,GAAAN,IAAA,CAAAM,SAAA;IACAC,KAAA,GAAAP,IAAA,CAAAO,KAAA,CAAA;AAGM,EAAA,IAAAC,aAAA,GAAgBC,QAA6B,YAAM;AACvD,IAAA,IAAMC,SAAiC,GAAA;AACrCC,MAAAA,OAAS,EAAA,MAAA;AACTC,MAAAA,aAAA,EAAeR,SAAc,KAAA,YAAA,GAAe,KAAQ,GAAA,QAAA;AACpDS,MAAAA,GAAK,EAAA,KAAA;KACP,CAAA;AAEI,IAAA,IAAAR,SAAA,IAAa,OAAOA,SAAA,KAAc,QAAU,EAAA;MACpCK,SAAA,CAAAI,UAAA,GAAarB,aAAaY,SAAc,CAAA,IAAAA,SAAA,CAAA;AACpD,KAAA;AAEO,IAAA,OAAAK,SAAA,CAAA;AACT,GAAG,EAAA,CAACN,SAAW,EAAAC,SAAS,CAAC,CAAA,CAAA;EAGzB,IAAI,CAACH,gBAAA,IAAoBA,gBAAiB,CAAAa,MAAA,KAAW,CAAG,EAAA;AAC/C,IAAA,OAAA,IAAA,CAAA;AACT,GAAA;AAEA,EAAA,sBACGC,cAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAIX,IAAAA,SAAA,EAAAA,SAAA;AAAsBC,IAAAA,KAAO,EAAAW,aAAA,CAAAA,aAAA,CAAKV,EAAAA,EAAAA,aAAA,GAAkBD,KAAM,CAAA;GAAA,EAC5DL,gBAAiB,CAAAiB,GAAA,CAAI,UAACC,KAAA,EAAOC;0BAC3BL,cAAA,CAAAC,aAAA,CAAAK,qBAAA,EAAA;AAAsBC,MAAAA,GAAA,EAAKH,MAAMrB,EAAM,IAAAsB,KAAA;AAAOG,MAAAA,SAAW,EAAAJ,KAAAA;AAAA,KAAO,CAClE,CAAA;AAAA,GAAA,CACH,CAAA,CAAA;AAEJ,EAAA;AAEAtB,QAAA,CAAS2B,WAAc,GAAA,UAAA;;;;"}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * A2UI Row 容器组件
3
+ * A2UI v0.9 标准水平布局组件
4
+ */
5
+ import React from 'react';
6
+ import type { A2UIRowComponent, ResolvedComponent } from '../../../core/a2ui';
7
+ export interface A2UIRowProps extends Omit<A2UIRowComponent, 'component'> {
8
+ /** 解析后的子组件(由 ComponentRenderer 传入) */
9
+ resolvedChildren?: ResolvedComponent[];
10
+ className?: string;
11
+ style?: React.CSSProperties;
12
+ /** 向后兼容:gap 属性 */
13
+ gap?: number | string;
14
+ /** 向后兼容:align 属性 */
15
+ align?: 'start' | 'center' | 'end' | 'stretch';
16
+ /** 向后兼容:justify 属性 */
17
+ justify?: 'start' | 'center' | 'end' | 'space-between' | 'space-around';
18
+ }
19
+ export declare const A2UIRow: React.FC<A2UIRowProps>;
20
+ export default A2UIRow;
@@ -0,0 +1,84 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.14
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ import _defineProperty from '@babel/runtime/helpers/defineProperty';
8
+ import React__default, { useMemo } from 'react';
9
+ import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
10
+ import '../../../hooks/a2ui/A2UIContext.js';
11
+ import '../A2UIErrorBoundary.js';
12
+ import '@babel/runtime/helpers/classCallCheck';
13
+ import '@babel/runtime/helpers/createClass';
14
+ import '@babel/runtime/helpers/possibleConstructorReturn';
15
+ import '@babel/runtime/helpers/getPrototypeOf';
16
+ import '@babel/runtime/helpers/inherits';
17
+
18
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
19
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
20
+ var distributionMap = {
21
+ start: "flex-start",
22
+ center: "center",
23
+ end: "flex-end",
24
+ spaceBetween: "space-between",
25
+ spaceAround: "space-around",
26
+ spaceEvenly: "space-evenly",
27
+ stretch: "stretch"
28
+ };
29
+ var alignmentMap = {
30
+ start: "flex-start",
31
+ center: "center",
32
+ end: "flex-end",
33
+ stretch: "stretch"
34
+ };
35
+ var A2UIRow = function A2UIRow(_ref) {
36
+ var id = _ref.id,
37
+ children = _ref.children,
38
+ resolvedChildren = _ref.resolvedChildren,
39
+ distribution = _ref.distribution,
40
+ alignment = _ref.alignment,
41
+ gap = _ref.gap,
42
+ align = _ref.align,
43
+ justify = _ref.justify,
44
+ className = _ref.className,
45
+ style = _ref.style;
46
+ var computedStyle = useMemo(function () {
47
+ var baseStyle = {
48
+ display: "flex",
49
+ flexDirection: "row"
50
+ };
51
+ if (distribution && typeof distribution === "string") {
52
+ baseStyle.justifyContent = distributionMap[distribution] || distribution;
53
+ } else if (justify) {
54
+ baseStyle.justifyContent = justify === "start" ? "flex-start" : justify === "end" ? "flex-end" : justify;
55
+ }
56
+ if (alignment && typeof alignment === "string") {
57
+ baseStyle.alignItems = alignmentMap[alignment] || alignment;
58
+ } else if (align) {
59
+ baseStyle.alignItems = align === "start" ? "flex-start" : align === "end" ? "flex-end" : align;
60
+ }
61
+ if (gap !== void 0) {
62
+ baseStyle.gap = typeof gap === "number" ? "".concat(gap, "px") : gap;
63
+ } else {
64
+ baseStyle.gap = "8px";
65
+ }
66
+ return baseStyle;
67
+ }, [distribution, alignment, gap, align, justify]);
68
+ if (!resolvedChildren || resolvedChildren.length === 0) {
69
+ return null;
70
+ }
71
+ return /* @__PURE__ */React__default.createElement("div", {
72
+ className: className,
73
+ style: _objectSpread(_objectSpread({}, computedStyle), style)
74
+ }, resolvedChildren.map(function (child, index) {
75
+ return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
76
+ key: child.id || index,
77
+ component: child
78
+ });
79
+ }));
80
+ };
81
+ A2UIRow.displayName = "A2UIRow";
82
+
83
+ export { A2UIRow, A2UIRow as default };
84
+ //# sourceMappingURL=A2UIRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"A2UIRow.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UIRow.tsx"],"sourcesContent":["/**\n * A2UI Row 容器组件\n * A2UI v0.9 标准水平布局组件\n */\n\nimport React, { useMemo } from 'react';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UIRowComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UIRowProps extends Omit<A2UIRowComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n /** 向后兼容:gap 属性 */\n gap?: number | string;\n /** 向后兼容:align 属性 */\n align?: 'start' | 'center' | 'end' | 'stretch';\n /** 向后兼容:justify 属性 */\n justify?: 'start' | 'center' | 'end' | 'space-between' | 'space-around';\n}\n\n// A2UI v0.9 distribution 到 CSS justify-content 的映射\nconst distributionMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n spaceBetween: 'space-between',\n spaceAround: 'space-around',\n spaceEvenly: 'space-evenly',\n stretch: 'stretch',\n};\n\n// A2UI v0.9 alignment 到 CSS align-items 的映射\nconst alignmentMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n stretch: 'stretch',\n};\n\nexport const A2UIRow: React.FC<A2UIRowProps> = ({\n id,\n children,\n resolvedChildren,\n distribution,\n alignment,\n // 向后兼容\n gap,\n align,\n justify,\n className,\n style,\n}) => {\n // 计算样式\n const computedStyle = useMemo<React.CSSProperties>(() => {\n const baseStyle: React.CSSProperties = {\n display: 'flex',\n flexDirection: 'row',\n };\n\n // A2UI v0.9 distribution\n if (distribution && typeof distribution === 'string') {\n baseStyle.justifyContent = distributionMap[distribution] || distribution;\n } else if (justify) {\n // 向后兼容 justify\n baseStyle.justifyContent = justify === 'start' ? 'flex-start' :\n justify === 'end' ? 'flex-end' : justify;\n }\n\n // A2UI v0.9 alignment\n if (alignment && typeof alignment === 'string') {\n baseStyle.alignItems = alignmentMap[alignment] || alignment;\n } else if (align) {\n // 向后兼容 align\n baseStyle.alignItems = align === 'start' ? 'flex-start' :\n align === 'end' ? 'flex-end' : align;\n }\n\n // gap\n if (gap !== undefined) {\n baseStyle.gap = typeof gap === 'number' ? `${gap}px` : gap;\n } else {\n baseStyle.gap = '8px'; // 默认间距\n }\n\n return baseStyle;\n }, [distribution, alignment, gap, align, justify]);\n\n // 渲染子组件\n if (!resolvedChildren || resolvedChildren.length === 0) {\n return null;\n }\n\n return (\n <div className={className} style={{ ...computedStyle, ...style }}>\n {resolvedChildren.map((child, index) => (\n <A2UIComponentRenderer key={child.id || index} component={child} />\n ))}\n </div>\n );\n};\n\nA2UIRow.displayName = 'A2UIRow';\n\nexport default A2UIRow;\n"],"names":["distributionMap","start","center","end","spaceBetween","spaceAround","spaceEvenly","stretch","alignmentMap","A2UIRow","id","_ref","children","resolvedChildren","distribution","alignment","gap","align","justify","className","style","computedStyle","useMemo","baseStyle","display","flexDirection","justifyContent","alignItems","concat","length","React","createElement","_objectSpread","map","child","index","A2UIComponentRenderer","key","component","displayName"],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * A2UI Tabs 容器组件
3
+ * A2UI v0.9 标准标签页组件
4
+ */
5
+ import React from 'react';
6
+ import type { A2UITabsComponent, ResolvedComponent } from '../../../core/a2ui';
7
+ export interface A2UITabsProps extends Omit<A2UITabsComponent, 'component'> {
8
+ /** 解析后的子组件(由 ComponentRenderer 传入) */
9
+ resolvedChildren?: ResolvedComponent[];
10
+ className?: string;
11
+ style?: React.CSSProperties;
12
+ }
13
+ export declare const A2UITabs: React.FC<A2UITabsProps>;
14
+ export default A2UITabs;
@@ -0,0 +1,69 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.14
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
8
+ import React__default, { useState } from 'react';
9
+ import { Tabs } from 'tdesign-react';
10
+ import { useDataBinding } from '../../../hooks/a2ui/useDataBinding.js';
11
+ import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
12
+ import '../../../hooks/a2ui/A2UIContext.js';
13
+ import '@babel/runtime/helpers/defineProperty';
14
+ import '../../../core/a2ui/utils/index.js';
15
+ import '../../../core/a2ui/utils/binding.js';
16
+ import '@babel/runtime/helpers/typeof';
17
+ import '../../../core/a2ui/utils/validation.js';
18
+ import '@babel/runtime/helpers/toConsumableArray';
19
+ import '../A2UIErrorBoundary.js';
20
+ import '@babel/runtime/helpers/classCallCheck';
21
+ import '@babel/runtime/helpers/createClass';
22
+ import '@babel/runtime/helpers/possibleConstructorReturn';
23
+ import '@babel/runtime/helpers/getPrototypeOf';
24
+ import '@babel/runtime/helpers/inherits';
25
+
26
+ var TabPanel = Tabs.TabPanel;
27
+ var TabTitle = function TabTitle(_ref) {
28
+ var title = _ref.title;
29
+ var resolvedTitle = useDataBinding(title);
30
+ return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, resolvedTitle);
31
+ };
32
+ var A2UITabs = function A2UITabs(_ref2) {
33
+ var id = _ref2.id,
34
+ tabItems = _ref2.tabItems,
35
+ resolvedChildren = _ref2.resolvedChildren,
36
+ className = _ref2.className,
37
+ style = _ref2.style;
38
+ var _useState = useState("0"),
39
+ _useState2 = _slicedToArray(_useState, 2),
40
+ activeTab = _useState2[0],
41
+ setActiveTab = _useState2[1];
42
+ if (!tabItems || !Array.isArray(tabItems) || tabItems.length === 0) {
43
+ return null;
44
+ }
45
+ var handleChange = function handleChange(value) {
46
+ setActiveTab(String(value));
47
+ };
48
+ return /* @__PURE__ */React__default.createElement(Tabs, {
49
+ className: className,
50
+ style: style,
51
+ value: activeTab,
52
+ onChange: handleChange
53
+ }, tabItems.map(function (item, index) {
54
+ var childComponent = resolvedChildren === null || resolvedChildren === void 0 ? void 0 : resolvedChildren[index];
55
+ return /* @__PURE__ */React__default.createElement(TabPanel, {
56
+ key: index,
57
+ value: String(index),
58
+ label: /* @__PURE__ */React__default.createElement(TabTitle, {
59
+ title: item.title
60
+ })
61
+ }, childComponent && /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
62
+ component: childComponent
63
+ }));
64
+ }));
65
+ };
66
+ A2UITabs.displayName = "A2UITabs";
67
+
68
+ export { A2UITabs, A2UITabs as default };
69
+ //# sourceMappingURL=A2UITabs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"A2UITabs.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UITabs.tsx"],"sourcesContent":["/**\n * A2UI Tabs 容器组件\n * A2UI v0.9 标准标签页组件\n */\n\nimport React, { useState } from 'react';\nimport { Tabs } from 'tdesign-react';\nimport { useDataBinding } from '../../../hooks/a2ui/useDataBinding';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UITabsComponent, A2UITabItem, ResolvedComponent, Bindable } from '../../../core/a2ui';\n\nconst { TabPanel } = Tabs;\n\nexport interface A2UITabsProps extends Omit<A2UITabsComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n}\n\n/**\n * Tab 标题组件(支持数据绑定)\n */\nconst TabTitle: React.FC<{ title: Bindable<string> }> = ({ title }) => {\n const resolvedTitle = useDataBinding<string>(title);\n return <>{resolvedTitle}</>;\n};\n\nexport const A2UITabs: React.FC<A2UITabsProps> = ({\n id,\n tabItems,\n resolvedChildren,\n className,\n style,\n}) => {\n const [activeTab, setActiveTab] = useState<string>('0');\n\n // 如果没有 tabItems,返回 null\n if (!tabItems || !Array.isArray(tabItems) || tabItems.length === 0) {\n return null;\n }\n\n // 处理 tab 切换\n const handleChange = (value: string | number) => {\n setActiveTab(String(value));\n };\n\n return (\n <Tabs\n className={className}\n style={style}\n value={activeTab}\n onChange={handleChange}\n >\n {tabItems.map((item, index) => {\n // 从 resolvedChildren 中找到对应的子组件\n const childComponent = resolvedChildren?.[index];\n\n return (\n <TabPanel\n key={index}\n value={String(index)}\n label={<TabTitle title={item.title} />}\n >\n {childComponent && (\n <A2UIComponentRenderer component={childComponent} />\n )}\n </TabPanel>\n );\n })}\n </Tabs>\n );\n};\n\nA2UITabs.displayName = 'A2UITabs';\n\nexport default A2UITabs;\n"],"names":["TabPanel","Tabs","TabTitle","_ref","title","resolvedTitle","useDataBinding","A2UITabs","id","_ref2","tabItems","resolvedChildren","className","style","_useState","useState","_useState2","_slicedToArray","activeTab","setActiveTab","Array","isArray","length","handleChange","value","String","React","createElement","onChange","map","item","index","childComponent","key","label","A2UIComponentRenderer","component","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAWA,IAAQA,WAAaC,IAAA,CAAbD;AAYR,IAAME,QAAkD,GAAA,SAAlDA,QAAkDA,CAAAC,IAAA,EAAe;AAAA,EAAA,IAAZC,KAAA,GAAAD,IAAA,CAAAC,KAAA,CAAA;AACnD,EAAA,IAAAC,aAAA,GAAgBC,eAAuBF,KAAK,CAAA,CAAA;AAClD,EAAA,kFAAUC,aAAc,CAAA,CAAA;AAC1B,CAAA,CAAA;IAEaE,WAAoC,SAApCA,gBAMP;AAAA,EAAA,IALJC,EAAA,GAAAC,KAAA,CAAAD,EAAA;IACAE,QAAA,GAAAD,KAAA,CAAAC,QAAA;IACAC,gBAAA,GAAAF,KAAA,CAAAE,gBAAA;IACAC,SAAA,GAAAH,KAAA,CAAAG,SAAA;IACAC,KAAA,GAAAJ,KAAA,CAAAI,KAAA,CAAA;AAEA,EAAA,IAAAC,SAAA,GAAkCC,SAAiB,GAAG,CAAA;IAAAC,UAAA,GAAAC,cAAA,CAAAH,SAAA,EAAA,CAAA,CAAA;AAA/CI,IAAAA,SAAA,GAAAF,UAAA,CAAA,CAAA,CAAA;AAAWG,IAAAA,YAAY,GAAAH,UAAA,CAAA,CAAA,CAAA,CAAA;AAG1B,EAAA,IAAA,CAACN,YAAY,CAACU,KAAA,CAAMC,QAAQX,QAAQ,CAAA,IAAKA,QAAS,CAAAY,MAAA,KAAW,CAAG,EAAA;AAC3D,IAAA,OAAA,IAAA,CAAA;AACT,GAAA;AAGM,EAAA,IAAAC,YAAA,GAAe,SAAfA,YAAAA,CAAgBC,KAA2B,EAAA;AAClCL,IAAAA,YAAA,CAAAM,MAAA,CAAOD,KAAK,CAAC,CAAA,CAAA;GAC5B,CAAA;AAEA,EAAA,sBACGE,cAAA,CAAAC,aAAA,CAAA1B,IAAA,EAAA;AACCW,IAAAA,SAAA,EAAAA,SAAA;AACAC,IAAAA,KAAA,EAAAA,KAAA;AACAW,IAAAA,KAAO,EAAAN,SAAA;AACPU,IAAAA,QAAU,EAAAL,YAAAA;GAAA,EAETb,QAAS,CAAAmB,GAAA,CAAI,UAACC,IAAA,EAAMC,KAAU,EAAA;IAE7B,IAAMC,iBAAiBrB,gBAAmB,KAAA,IAAA,IAAnBA,gBAAmB,KAAnBA,KAAAA,CAAAA,GAAAA,KAAAA,CAAAA,GAAAA,gBAAmB,CAAAoB,KAAA,CAAA,CAAA;AAE1C,IAAA,sBACGL,cAAA,CAAAC,aAAA,CAAA3B,QAAA,EAAA;AACCiC,MAAAA,GAAK,EAAAF,KAAA;AACLP,MAAAA,KAAA,EAAOC,OAAOM,KAAK,CAAA;AACnBG,MAAAA,sBAAQR,cAAA,CAAAC,aAAA,CAAAzB,QAAA,EAAA;QAASE,OAAO0B,IAAK,CAAA1B,KAAAA;OAAO,CAAA;KAAA,EAEnC4B,iCACEN,cAAA,CAAAC,aAAA,CAAAQ,qBAAA,EAAA;AAAsBC,MAAAA,SAAW,EAAAJ,cAAAA;AAAA,KAAgB,CAEtD,CAAA,CAAA;AAEJ,GAAC,CACH,CAAA,CAAA;AAEJ,EAAA;AAEAzB,QAAA,CAAS8B,WAAc,GAAA,UAAA;;;;"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * A2UI 容器组件导出
3
+ */
4
+ export { A2UICard, type A2UICardProps } from './A2UICard';
5
+ export { A2UIRow, type A2UIRowProps } from './A2UIRow';
6
+ export { A2UIColumn, type A2UIColumnProps } from './A2UIColumn';
7
+ export { A2UIList, type A2UIListProps } from './A2UIList';
8
+ export { A2UITabs, type A2UITabsProps } from './A2UITabs';
@@ -0,0 +1,30 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.14
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ export { A2UICard } from './A2UICard.js';
8
+ export { A2UIRow } from './A2UIRow.js';
9
+ export { A2UIColumn } from './A2UIColumn.js';
10
+ export { A2UIList } from './A2UIList.js';
11
+ export { A2UITabs } from './A2UITabs.js';
12
+ import 'react';
13
+ import 'tdesign-react';
14
+ import '../../../hooks/a2ui/useDataBinding.js';
15
+ import '@babel/runtime/helpers/slicedToArray';
16
+ import '../../../hooks/a2ui/A2UIContext.js';
17
+ import '@babel/runtime/helpers/defineProperty';
18
+ import '../../../core/a2ui/utils/index.js';
19
+ import '../../../core/a2ui/utils/binding.js';
20
+ import '@babel/runtime/helpers/typeof';
21
+ import '../../../core/a2ui/utils/validation.js';
22
+ import '@babel/runtime/helpers/toConsumableArray';
23
+ import '../A2UIComponentRenderer.js';
24
+ import '../A2UIErrorBoundary.js';
25
+ import '@babel/runtime/helpers/classCallCheck';
26
+ import '@babel/runtime/helpers/createClass';
27
+ import '@babel/runtime/helpers/possibleConstructorReturn';
28
+ import '@babel/runtime/helpers/getPrototypeOf';
29
+ import '@babel/runtime/helpers/inherits';
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * A2UI 组件层导出
3
+ */
4
+ export { A2UIComponentRenderer, A2UIChildrenRenderer, type A2UIComponentRendererProps, } from './A2UIComponentRenderer';
5
+ export { A2UISurfaceRenderer, type A2UISurfaceRendererProps, } from './A2UISurfaceRenderer';
6
+ export { A2UIActivityRenderer, createA2UIActivityConfig, createA2UIActionHandler, type A2UIActivityRendererProps, type A2UIActivityContent, type A2UIActivityConfigOptions, type UserActionMessage, type ActionResult, type OnActionCallback, type DeltaInfo, } from './A2UIActivityRenderer';
7
+ export { A2UIErrorBoundary, withA2UIErrorBoundary, type A2UIErrorBoundaryProps, } from './A2UIErrorBoundary';
8
+ export { A2UISkeleton, A2UISurfaceSkeleton, type A2UISkeletonProps, type A2UISurfaceSkeletonProps, } from './A2UISkeleton';
9
+ export { defaultComponentRegistry, createComponentRegistry, extendComponentRegistry, } from './registry';
10
+ export * from './primitives';
11
+ export * from './containers';