@tdesign-react/chat 1.0.2-alpha.11 → 1.0.2-alpha.12

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 (211) hide show
  1. package/es/_util/reactify.js +4 -4
  2. package/es/_util/reactify.js.map +1 -1
  3. package/es/_util/useDynamicStyle.js +1 -1
  4. package/es/attachments/index.js +1 -1
  5. package/es/chat-actionbar/index.js +1 -1
  6. package/es/chat-engine/components/a2ui/A2UIActivityRenderer.d.ts +91 -0
  7. package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js +236 -0
  8. package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js.map +1 -0
  9. package/es/chat-engine/components/a2ui/A2UIComponentRenderer.d.ts +37 -0
  10. package/es/chat-engine/components/a2ui/A2UIComponentRenderer.js +116 -0
  11. package/es/chat-engine/components/a2ui/A2UIComponentRenderer.js.map +1 -0
  12. package/es/chat-engine/components/a2ui/A2UIErrorBoundary.d.ts +42 -0
  13. package/es/chat-engine/components/a2ui/A2UIErrorBoundary.js +113 -0
  14. package/es/chat-engine/components/a2ui/A2UIErrorBoundary.js.map +1 -0
  15. package/es/chat-engine/components/a2ui/A2UISkeleton.d.ts +60 -0
  16. package/es/chat-engine/components/a2ui/A2UISkeleton.js +197 -0
  17. package/es/chat-engine/components/a2ui/A2UISkeleton.js.map +1 -0
  18. package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.d.ts +44 -0
  19. package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.js +139 -0
  20. package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.js.map +1 -0
  21. package/es/chat-engine/components/a2ui/containers/A2UICard.d.ts +22 -0
  22. package/es/chat-engine/components/a2ui/containers/A2UICard.js +82 -0
  23. package/es/chat-engine/components/a2ui/containers/A2UICard.js.map +1 -0
  24. package/es/chat-engine/components/a2ui/containers/A2UIColumn.d.ts +18 -0
  25. package/es/chat-engine/components/a2ui/containers/A2UIColumn.js +81 -0
  26. package/es/chat-engine/components/a2ui/containers/A2UIColumn.js.map +1 -0
  27. package/es/chat-engine/components/a2ui/containers/A2UIList.d.ts +14 -0
  28. package/es/chat-engine/components/a2ui/containers/A2UIList.js +62 -0
  29. package/es/chat-engine/components/a2ui/containers/A2UIList.js.map +1 -0
  30. package/es/chat-engine/components/a2ui/containers/A2UIRow.d.ts +20 -0
  31. package/es/chat-engine/components/a2ui/containers/A2UIRow.js +84 -0
  32. package/es/chat-engine/components/a2ui/containers/A2UIRow.js.map +1 -0
  33. package/es/chat-engine/components/a2ui/containers/A2UITabs.d.ts +14 -0
  34. package/es/chat-engine/components/a2ui/containers/A2UITabs.js +69 -0
  35. package/es/chat-engine/components/a2ui/containers/A2UITabs.js.map +1 -0
  36. package/es/chat-engine/components/a2ui/containers/index.d.ts +8 -0
  37. package/es/chat-engine/components/a2ui/containers/index.js +30 -0
  38. package/es/chat-engine/components/a2ui/containers/index.js.map +1 -0
  39. package/es/chat-engine/components/a2ui/index.d.ts +11 -0
  40. package/es/chat-engine/components/a2ui/index.js +60 -0
  41. package/es/chat-engine/components/a2ui/index.js.map +1 -0
  42. package/es/chat-engine/components/a2ui/primitives/A2UIButton.d.ts +31 -0
  43. package/es/chat-engine/components/a2ui/primitives/A2UIButton.js +76 -0
  44. package/es/chat-engine/components/a2ui/primitives/A2UIButton.js.map +1 -0
  45. package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.d.ts +12 -0
  46. package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.js +43 -0
  47. package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.js.map +1 -0
  48. package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.d.ts +50 -0
  49. package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.js +54 -0
  50. package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.js.map +1 -0
  51. package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.d.ts +13 -0
  52. package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.js +89 -0
  53. package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.js.map +1 -0
  54. package/es/chat-engine/components/a2ui/primitives/A2UIDivider.d.ts +12 -0
  55. package/es/chat-engine/components/a2ui/primitives/A2UIDivider.js +25 -0
  56. package/es/chat-engine/components/a2ui/primitives/A2UIDivider.js.map +1 -0
  57. package/es/chat-engine/components/a2ui/primitives/A2UIIcon.d.ts +13 -0
  58. package/es/chat-engine/components/a2ui/primitives/A2UIIcon.js +138942 -0
  59. package/es/chat-engine/components/a2ui/primitives/A2UIIcon.js.map +1 -0
  60. package/es/chat-engine/components/a2ui/primitives/A2UIImage.d.ts +12 -0
  61. package/es/chat-engine/components/a2ui/primitives/A2UIImage.js +75 -0
  62. package/es/chat-engine/components/a2ui/primitives/A2UIImage.js.map +1 -0
  63. package/es/chat-engine/components/a2ui/primitives/A2UIInput.d.ts +20 -0
  64. package/es/chat-engine/components/a2ui/primitives/A2UIInput.js +63 -0
  65. package/es/chat-engine/components/a2ui/primitives/A2UIInput.js.map +1 -0
  66. package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.d.ts +56 -0
  67. package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.js +64 -0
  68. package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.js.map +1 -0
  69. package/es/chat-engine/components/a2ui/primitives/A2UISlider.d.ts +12 -0
  70. package/es/chat-engine/components/a2ui/primitives/A2UISlider.js +55 -0
  71. package/es/chat-engine/components/a2ui/primitives/A2UISlider.js.map +1 -0
  72. package/es/chat-engine/components/a2ui/primitives/A2UIText.d.ts +12 -0
  73. package/es/chat-engine/components/a2ui/primitives/A2UIText.js +104 -0
  74. package/es/chat-engine/components/a2ui/primitives/A2UIText.js.map +1 -0
  75. package/es/chat-engine/components/a2ui/primitives/A2UITextField.d.ts +12 -0
  76. package/es/chat-engine/components/a2ui/primitives/A2UITextField.js +80 -0
  77. package/es/chat-engine/components/a2ui/primitives/A2UITextField.js.map +1 -0
  78. package/es/chat-engine/components/a2ui/primitives/index.d.ts +15 -0
  79. package/es/chat-engine/components/a2ui/primitives/index.js +39 -0
  80. package/es/chat-engine/components/a2ui/primitives/index.js.map +1 -0
  81. package/es/chat-engine/components/a2ui/registry.d.ts +35 -0
  82. package/es/chat-engine/components/a2ui/registry.js +74 -0
  83. package/es/chat-engine/components/a2ui/registry.js.map +1 -0
  84. package/es/chat-engine/components/activity/index.js +1 -1
  85. package/es/chat-engine/components/activity/registry.js +4 -4
  86. package/es/chat-engine/components/activity/registry.js.map +1 -1
  87. package/es/chat-engine/components/activity/render.js +6 -6
  88. package/es/chat-engine/components/activity/render.js.map +1 -1
  89. package/es/chat-engine/components/activity/types.js +1 -1
  90. package/es/chat-engine/components/index.d.ts +1 -0
  91. package/es/chat-engine/components/index.js +47 -1
  92. package/es/chat-engine/components/index.js.map +1 -1
  93. package/es/chat-engine/components/provider/agent-state.js +6 -3
  94. package/es/chat-engine/components/provider/agent-state.js.map +1 -1
  95. package/es/chat-engine/components/toolcall/index.js +4 -1
  96. package/es/chat-engine/components/toolcall/index.js.map +1 -1
  97. package/es/chat-engine/components/toolcall/registry.js +4 -4
  98. package/es/chat-engine/components/toolcall/registry.js.map +1 -1
  99. package/es/chat-engine/components/toolcall/render.js +14 -11
  100. package/es/chat-engine/components/toolcall/render.js.map +1 -1
  101. package/es/chat-engine/components/toolcall/types.js +1 -1
  102. package/es/chat-engine/core/a2ui/index.d.ts +10 -0
  103. package/es/chat-engine/core/a2ui/index.js +24 -0
  104. package/es/chat-engine/core/a2ui/index.js.map +1 -0
  105. package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.d.ts +197 -0
  106. package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.js +438 -0
  107. package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.js.map +1 -0
  108. package/es/chat-engine/core/a2ui/processor/ComponentTree.d.ts +53 -0
  109. package/es/chat-engine/core/a2ui/processor/ComponentTree.js +158 -0
  110. package/es/chat-engine/core/a2ui/processor/ComponentTree.js.map +1 -0
  111. package/es/chat-engine/core/a2ui/processor/DataStore.d.ts +63 -0
  112. package/es/chat-engine/core/a2ui/processor/DataStore.js +172 -0
  113. package/es/chat-engine/core/a2ui/processor/DataStore.js.map +1 -0
  114. package/es/chat-engine/core/a2ui/processor/PathResolver.d.ts +47 -0
  115. package/es/chat-engine/core/a2ui/processor/PathResolver.js +99 -0
  116. package/es/chat-engine/core/a2ui/processor/PathResolver.js.map +1 -0
  117. package/es/chat-engine/core/a2ui/types/index.d.ts +4 -0
  118. package/es/chat-engine/core/a2ui/types/index.js +9 -0
  119. package/es/chat-engine/core/a2ui/types/index.js.map +1 -0
  120. package/es/chat-engine/core/a2ui/types/types.d.ts +769 -0
  121. package/es/chat-engine/core/a2ui/types/types.js +104 -0
  122. package/es/chat-engine/core/a2ui/types/types.js.map +1 -0
  123. package/es/chat-engine/core/a2ui/utils/binding.d.ts +34 -0
  124. package/es/chat-engine/core/a2ui/utils/binding.js +1784 -0
  125. package/es/chat-engine/core/a2ui/utils/binding.js.map +1 -0
  126. package/es/chat-engine/core/a2ui/utils/index.d.ts +5 -0
  127. package/es/chat-engine/core/a2ui/utils/index.js +13 -0
  128. package/es/chat-engine/core/a2ui/utils/index.js.map +1 -0
  129. package/es/chat-engine/core/a2ui/utils/validation.d.ts +70 -0
  130. package/es/chat-engine/core/a2ui/utils/validation.js +333 -0
  131. package/es/chat-engine/core/a2ui/utils/validation.js.map +1 -0
  132. package/es/chat-engine/core/adapters/agui/event-mapper.d.ts +16 -0
  133. package/es/chat-engine/core/adapters/agui/event-mapper.js +60 -6
  134. package/es/chat-engine/core/adapters/agui/event-mapper.js.map +1 -1
  135. package/es/chat-engine/core/adapters/agui/events.js +1 -1
  136. package/es/chat-engine/core/adapters/agui/index.d.ts +1 -1
  137. package/es/chat-engine/core/adapters/agui/index.js +1 -1
  138. package/es/chat-engine/core/adapters/agui/index.js.map +1 -1
  139. package/es/chat-engine/core/adapters/agui/state-manager.js +1 -1
  140. package/es/chat-engine/core/adapters/agui/types.js +1 -1
  141. package/es/chat-engine/core/adapters/agui/utils.d.ts +5 -1
  142. package/es/chat-engine/core/adapters/agui/utils.js +6 -2
  143. package/es/chat-engine/core/adapters/agui/utils.js.map +1 -1
  144. package/es/chat-engine/core/event-bus/ChatEventBus.d.ts +88 -0
  145. package/es/chat-engine/core/event-bus/ChatEventBus.js +295 -0
  146. package/es/chat-engine/core/event-bus/ChatEventBus.js.map +1 -0
  147. package/es/chat-engine/core/event-bus/index.d.ts +5 -0
  148. package/es/chat-engine/core/event-bus/index.js +13 -0
  149. package/es/chat-engine/core/event-bus/index.js.map +1 -0
  150. package/es/chat-engine/core/event-bus/types.d.ts +230 -0
  151. package/es/chat-engine/core/event-bus/types.js +32 -0
  152. package/es/chat-engine/core/event-bus/types.js.map +1 -0
  153. package/es/chat-engine/core/index.d.ts +8 -1
  154. package/es/chat-engine/core/index.js +128 -10
  155. package/es/chat-engine/core/index.js.map +1 -1
  156. package/es/chat-engine/core/processor/index.js +1 -1
  157. package/es/chat-engine/core/server/batch-client.js +1 -1
  158. package/es/chat-engine/core/server/connection-manager.js +1 -1
  159. package/es/chat-engine/core/server/errors.js +1 -1
  160. package/es/chat-engine/core/server/index.js +1 -1
  161. package/es/chat-engine/core/server/llm-service.js +17 -15
  162. package/es/chat-engine/core/server/llm-service.js.map +1 -1
  163. package/es/chat-engine/core/server/sse-client.js +1 -1
  164. package/es/chat-engine/core/server/sse-parser.js +1 -1
  165. package/es/chat-engine/core/server/types.js +1 -1
  166. package/es/chat-engine/core/store/message.js +1 -1
  167. package/es/chat-engine/core/store/model.js +1 -1
  168. package/es/chat-engine/core/store/reactiveState.js +1 -1
  169. package/es/chat-engine/core/type.d.ts +18 -2
  170. package/es/chat-engine/core/type.js +1 -1
  171. package/es/chat-engine/core/utils/eventEmitter.js +1 -1
  172. package/es/chat-engine/core/utils/index.js +1 -1
  173. package/es/chat-engine/core/utils/logger.js +1 -1
  174. package/es/chat-engine/hooks/a2ui/A2UIContext.d.ts +90 -0
  175. package/es/chat-engine/hooks/a2ui/A2UIContext.js +97 -0
  176. package/es/chat-engine/hooks/a2ui/A2UIContext.js.map +1 -0
  177. package/es/chat-engine/hooks/a2ui/index.d.ts +7 -0
  178. package/es/chat-engine/hooks/a2ui/index.js +19 -0
  179. package/es/chat-engine/hooks/a2ui/index.js.map +1 -0
  180. package/es/chat-engine/hooks/a2ui/useA2UIAction.d.ts +40 -0
  181. package/es/chat-engine/hooks/a2ui/useA2UIAction.js +74 -0
  182. package/es/chat-engine/hooks/a2ui/useA2UIAction.js.map +1 -0
  183. package/es/chat-engine/hooks/a2ui/useA2UISurface.d.ts +36 -0
  184. package/es/chat-engine/hooks/a2ui/useA2UISurface.js +39 -0
  185. package/es/chat-engine/hooks/a2ui/useA2UISurface.js.map +1 -0
  186. package/es/chat-engine/hooks/a2ui/useDataBinding.d.ts +53 -0
  187. package/es/chat-engine/hooks/a2ui/useDataBinding.js +111 -0
  188. package/es/chat-engine/hooks/a2ui/useDataBinding.js.map +1 -0
  189. package/es/chat-engine/hooks/index.d.ts +1 -0
  190. package/es/chat-engine/hooks/index.js +12 -1
  191. package/es/chat-engine/hooks/index.js.map +1 -1
  192. package/es/chat-engine/hooks/useAgentActivity.js +1 -1
  193. package/es/chat-engine/hooks/useAgentState.js +4 -1
  194. package/es/chat-engine/hooks/useAgentState.js.map +1 -1
  195. package/es/chat-engine/hooks/useAgentToolcall.js +1 -1
  196. package/es/chat-engine/hooks/useChat.js +4 -1
  197. package/es/chat-engine/hooks/useChat.js.map +1 -1
  198. package/es/chat-engine/index.js +47 -1
  199. package/es/chat-engine/index.js.map +1 -1
  200. package/es/chat-filecard/index.js +1 -1
  201. package/es/chat-loading/index.js +1 -1
  202. package/es/chat-markdown/index.js +1 -1
  203. package/es/chat-message/index.js +1 -1
  204. package/es/chat-sender/index.js +1 -1
  205. package/es/chat-thinking/index.js +1 -1
  206. package/es/chatbot/docs/react-best-practice.d.ts +13 -0
  207. package/es/chatbot/index.js +1 -1
  208. package/es/index.js +47 -1
  209. package/es/index.js.map +1 -1
  210. package/es/style/index.js +1 -1
  211. package/package.json +2 -2
@@ -0,0 +1,139 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.11
3
+ * (c) 2026 tdesign
4
+ * @license MIT
5
+ */
6
+
7
+ import _defineProperty from '@babel/runtime/helpers/defineProperty';
8
+ import React__default, { useMemo, useCallback } from 'react';
9
+ import { A2UIRootProvider } from '../../hooks/a2ui/A2UIContext.js';
10
+ import { useA2UISurface } from '../../hooks/a2ui/useA2UISurface.js';
11
+ import { A2UIComponentRenderer } from './A2UIComponentRenderer.js';
12
+ import { A2UISurfaceSkeleton } from './A2UISkeleton.js';
13
+ import { defaultComponentRegistry } from './registry.js';
14
+ import './A2UIErrorBoundary.js';
15
+ import '@babel/runtime/helpers/classCallCheck';
16
+ import '@babel/runtime/helpers/createClass';
17
+ import '@babel/runtime/helpers/possibleConstructorReturn';
18
+ import '@babel/runtime/helpers/getPrototypeOf';
19
+ import '@babel/runtime/helpers/inherits';
20
+ import 'tdesign-react';
21
+ import './primitives/A2UIText.js';
22
+ import 'classnames';
23
+ import '../../hooks/a2ui/useDataBinding.js';
24
+ import '@babel/runtime/helpers/slicedToArray';
25
+ import '../../core/a2ui/utils/index.js';
26
+ import '../../core/a2ui/utils/binding.js';
27
+ import '@babel/runtime/helpers/typeof';
28
+ import '../../core/a2ui/utils/validation.js';
29
+ import '@babel/runtime/helpers/toConsumableArray';
30
+ import './primitives/A2UIImage.js';
31
+ import './primitives/A2UIIcon.js';
32
+ import './primitives/A2UIButton.js';
33
+ import '../../hooks/a2ui/useA2UIAction.js';
34
+ import './primitives/A2UIInput.js';
35
+ import './primitives/A2UITextField.js';
36
+ import './primitives/A2UICheckBox.js';
37
+ import './primitives/A2UIChoicePicker.js';
38
+ import './primitives/A2UISlider.js';
39
+ import './primitives/A2UIRadioGroup.js';
40
+ import './primitives/A2UICheckboxGroup.js';
41
+ import './primitives/A2UIDivider.js';
42
+ import './containers/A2UICard.js';
43
+ import './containers/A2UIRow.js';
44
+ import './containers/A2UIColumn.js';
45
+ import './containers/A2UIList.js';
46
+ import './containers/A2UITabs.js';
47
+
48
+ function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
49
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
50
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
51
+ 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; }
52
+ 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; }
53
+ var renderSkeleton = function renderSkeleton(hint) {
54
+ return /* @__PURE__ */React__default.createElement(A2UISurfaceSkeleton, {
55
+ layout: (hint === null || hint === void 0 ? void 0 : hint.layout) || "simple",
56
+ rowCount: hint === null || hint === void 0 ? void 0 : hint.rowCount,
57
+ animation: (hint === null || hint === void 0 ? void 0 : hint.animation) || "gradient"
58
+ });
59
+ };
60
+ var A2UISurfaceRenderer = function A2UISurfaceRenderer(_ref) {
61
+ var processor = _ref.processor,
62
+ surfaceId = _ref.surfaceId,
63
+ registry = _ref.registry,
64
+ onAction = _ref.onAction,
65
+ className = _ref.className,
66
+ style = _ref.style,
67
+ _ref$loading = _ref.loading,
68
+ loading = _ref$loading === void 0 ? null : _ref$loading,
69
+ _ref$fallback = _ref.fallback,
70
+ fallback = _ref$fallback === void 0 ? null : _ref$fallback;
71
+ var surface = useA2UISurface(processor, surfaceId);
72
+ var mergedRegistry = useMemo(function () {
73
+ return _objectSpread(_objectSpread({}, defaultComponentRegistry), registry);
74
+ }, [registry]);
75
+ var wrappedOnAction = useCallback(function (action) {
76
+ if (!onAction) return;
77
+ var context = {
78
+ surfaceId: surfaceId,
79
+ updateData: function updateData(path, value) {
80
+ processor.updateDataValue(surfaceId, path, value);
81
+ },
82
+ getData: function getData(path) {
83
+ var _processor$getSurface;
84
+ var data = (_processor$getSurface = processor.getSurface(surfaceId)) === null || _processor$getSurface === void 0 ? void 0 : _processor$getSurface.data;
85
+ if (!path) return data;
86
+ var segments = path.split("/").filter(Boolean);
87
+ var result = data;
88
+ var _iterator = _createForOfIteratorHelper(segments),
89
+ _step;
90
+ try {
91
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
92
+ var segment = _step.value;
93
+ if (result === null || result === void 0) return void 0;
94
+ result = result[segment];
95
+ }
96
+ } catch (err) {
97
+ _iterator.e(err);
98
+ } finally {
99
+ _iterator.f();
100
+ }
101
+ return result;
102
+ }
103
+ };
104
+ onAction(action, context);
105
+ }, [onAction, processor, surfaceId]);
106
+ if (!surface) {
107
+ return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, fallback);
108
+ }
109
+ if (surface.state === "pending") {
110
+ if (loading === true) {
111
+ return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, renderSkeleton(surface.skeletonHint));
112
+ }
113
+ if (loading) {
114
+ return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, loading);
115
+ }
116
+ return null;
117
+ }
118
+ if (surface.state === "closed") {
119
+ return null;
120
+ }
121
+ if (!surface.root) {
122
+ return null;
123
+ }
124
+ return /* @__PURE__ */React__default.createElement(A2UIRootProvider, {
125
+ processor: processor,
126
+ surfaceId: surfaceId,
127
+ registry: mergedRegistry,
128
+ onAction: wrappedOnAction
129
+ }, /* @__PURE__ */React__default.createElement("div", {
130
+ className: className,
131
+ style: style
132
+ }, /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
133
+ component: surface.root
134
+ })));
135
+ };
136
+ A2UISurfaceRenderer.displayName = "A2UISurfaceRenderer";
137
+
138
+ export { A2UISurfaceRenderer, A2UISurfaceRenderer as default };
139
+ //# sourceMappingURL=A2UISurfaceRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"A2UISurfaceRenderer.js","sources":["../../../../../pro-components/chat/chat-engine/components/a2ui/A2UISurfaceRenderer.tsx"],"sourcesContent":["/**\n * A2UI Surface 渲染器\n * 渲染单个 Surface 的入口组件\n */\n\nimport React, { useCallback, useMemo } from 'react';\nimport { A2UIRootProvider, type ComponentRegistry } from '../../hooks/a2ui/A2UIContext';\nimport { useA2UISurface } from '../../hooks/a2ui/useA2UISurface';\nimport { A2UIComponentRenderer } from './A2UIComponentRenderer';\nimport { A2UISurfaceSkeleton } from './A2UISkeleton';\nimport { defaultComponentRegistry } from './registry';\nimport type { A2uiMessageProcessor } from '../../core/a2ui';\nimport type { ActionHandler, ActionContext, A2UIAction, SkeletonHint } from '../../core/a2ui';\n\nexport interface A2UISurfaceRendererProps {\n /** A2UI 消息处理器 */\n processor: A2uiMessageProcessor;\n /** Surface ID */\n surfaceId: string;\n /** 自定义组件注册表(可选,不传使用默认注册表) */\n registry?: ComponentRegistry;\n /** Action 处理回调 */\n onAction?: ActionHandler;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** \n * 加载中占位\n * - 传入 ReactNode:使用自定义骨架屏\n * - 传入 true:使用服务端 skeletonHint 或默认骨架屏\n */\n loading?: React.ReactNode | boolean;\n /** Surface 不存在时的占位 */\n fallback?: React.ReactNode;\n}\n\n/**\n * 根据 skeletonHint 渲染骨架屏\n */\nconst renderSkeleton = (hint?: SkeletonHint): React.ReactNode => {\n return (\n <A2UISurfaceSkeleton\n layout={hint?.layout || 'simple'}\n rowCount={hint?.rowCount}\n animation={hint?.animation || 'gradient'}\n />\n );\n};\n\n/**\n * A2UI Surface 渲染器\n * \n * 使用方式:\n * ```tsx\n * <A2UISurfaceRenderer\n * processor={processor}\n * surfaceId=\"confirm-form\"\n * onAction={handleAction}\n * />\n * ```\n */\nexport const A2UISurfaceRenderer: React.FC<A2UISurfaceRendererProps> = ({\n processor,\n surfaceId,\n registry,\n onAction,\n className,\n style,\n loading = null,\n fallback = null,\n}) => {\n // 订阅 Surface\n const surface = useA2UISurface(processor, surfaceId);\n\n // 合并默认注册表和自定义注册表\n const mergedRegistry = useMemo<ComponentRegistry>(\n () => ({\n ...defaultComponentRegistry,\n ...registry,\n }),\n [registry]\n );\n\n // 创建带 context 的 action handler\n const wrappedOnAction = useCallback(\n (action: A2UIAction) => {\n if (!onAction) return;\n\n // 创建 ActionContext,提供更新 UI 的能力\n const context: ActionContext = {\n surfaceId,\n updateData: (path: string, value: unknown) => {\n processor.updateDataValue(surfaceId, path, value);\n },\n getData: (path?: string) => {\n const data = processor.getSurface(surfaceId)?.data;\n if (!path) return data;\n // 简单的 path 解析\n const segments = path.split('/').filter(Boolean);\n let result: unknown = data;\n for (const segment of segments) {\n if (result === null || result === undefined) return undefined;\n result = (result as Record<string, unknown>)[segment];\n }\n return result;\n },\n };\n\n onAction(action, context);\n },\n [onAction, processor, surfaceId]\n );\n\n // Surface 不存在\n if (!surface) {\n return <>{fallback}</>;\n }\n\n // Surface 正在加载(pending 状态)\n if (surface.state === 'pending') {\n // 优先级:自定义 loading > skeletonHint > 默认骨架屏\n if (loading === true) {\n // loading=true 时,使用服务端 skeletonHint 或默认骨架屏\n return <>{renderSkeleton(surface.skeletonHint)}</>;\n }\n if (loading) {\n // 自定义 loading 组件\n return <>{loading}</>;\n }\n // 无 loading 配置,不显示占位\n return null;\n }\n\n // Surface 已关闭\n if (surface.state === 'closed') {\n return null;\n }\n\n // 没有根组件\n if (!surface.root) {\n return null;\n }\n\n return (\n <A2UIRootProvider\n processor={processor}\n surfaceId={surfaceId}\n registry={mergedRegistry}\n onAction={wrappedOnAction}\n >\n <div className={className} style={style}>\n <A2UIComponentRenderer component={surface.root} />\n </div>\n </A2UIRootProvider>\n );\n};\n\nA2UISurfaceRenderer.displayName = 'A2UISurfaceRenderer';\n\nexport default A2UISurfaceRenderer;\n"],"names":["renderSkeleton","hint","React","createElement","A2UISurfaceSkeleton","layout","rowCount","animation","A2UISurfaceRenderer","processor","_ref","surfaceId","registry","onAction","className","style","_ref$loading","loading","_ref$fallback","fallback","surface","useA2UISurface","mergedRegistry","useMemo","_objectSpread","defaultComponentRegistry","wrappedOnAction","useCallback","action","context","updateData","path","value","updateDataValue","getData","_processor$getSurface","data","getSurface","segments","split","filter","Boolean","result","_iterator","_createForOfIteratorHelper","_step","s","n","done","segment","err","e","f","state","Fragment","skeletonHint","root","A2UIRootProvider","A2UIComponentRenderer","component","displayName"],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ /**
2
+ * A2UI Card 容器组件
3
+ * 复用 TDesign Card,支持 A2UI v0.9 child 模式
4
+ */
5
+ import React from 'react';
6
+ import type { A2UICardComponent, ResolvedComponent } from '../../../core/a2ui';
7
+ export interface A2UICardProps extends Omit<A2UICardComponent, 'component'> {
8
+ /** 解析后的子组件(由 ComponentRenderer 传入) */
9
+ resolvedChildren?: ResolvedComponent[];
10
+ className?: string;
11
+ style?: React.CSSProperties;
12
+ /** TDesign 扩展属性 */
13
+ subtitle?: string;
14
+ description?: string;
15
+ hoverShadow?: boolean;
16
+ size?: 'medium' | 'small';
17
+ headerBordered?: boolean;
18
+ /** 向后兼容:children 数组 */
19
+ children?: any[];
20
+ }
21
+ export declare const A2UICard: React.FC<A2UICardProps>;
22
+ export default A2UICard;
@@ -0,0 +1,82 @@
1
+ /**
2
+ * tdesign v1.0.2-alpha.11
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.11
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.11
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.11
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;