@tdesign-react/chat 1.0.2-alpha.11 → 1.0.2-alpha.13
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.
- package/es/_util/reactify.js +4 -4
- package/es/_util/reactify.js.map +1 -1
- package/es/_util/useDynamicStyle.js +1 -1
- package/es/attachments/index.js +1 -1
- package/es/chat-actionbar/index.js +1 -1
- package/es/chat-engine/components/a2ui/A2UIActivityRenderer.d.ts +91 -0
- package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js +236 -0
- package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js.map +1 -0
- package/es/chat-engine/components/a2ui/A2UIComponentRenderer.d.ts +37 -0
- package/es/chat-engine/components/a2ui/A2UIComponentRenderer.js +116 -0
- package/es/chat-engine/components/a2ui/A2UIComponentRenderer.js.map +1 -0
- package/es/chat-engine/components/a2ui/A2UIErrorBoundary.d.ts +42 -0
- package/es/chat-engine/components/a2ui/A2UIErrorBoundary.js +113 -0
- package/es/chat-engine/components/a2ui/A2UIErrorBoundary.js.map +1 -0
- package/es/chat-engine/components/a2ui/A2UISkeleton.d.ts +60 -0
- package/es/chat-engine/components/a2ui/A2UISkeleton.js +197 -0
- package/es/chat-engine/components/a2ui/A2UISkeleton.js.map +1 -0
- package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.d.ts +44 -0
- package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.js +139 -0
- package/es/chat-engine/components/a2ui/A2UISurfaceRenderer.js.map +1 -0
- package/es/chat-engine/components/a2ui/containers/A2UICard.d.ts +22 -0
- package/es/chat-engine/components/a2ui/containers/A2UICard.js +82 -0
- package/es/chat-engine/components/a2ui/containers/A2UICard.js.map +1 -0
- package/es/chat-engine/components/a2ui/containers/A2UIColumn.d.ts +18 -0
- package/es/chat-engine/components/a2ui/containers/A2UIColumn.js +81 -0
- package/es/chat-engine/components/a2ui/containers/A2UIColumn.js.map +1 -0
- package/es/chat-engine/components/a2ui/containers/A2UIList.d.ts +14 -0
- package/es/chat-engine/components/a2ui/containers/A2UIList.js +62 -0
- package/es/chat-engine/components/a2ui/containers/A2UIList.js.map +1 -0
- package/es/chat-engine/components/a2ui/containers/A2UIRow.d.ts +20 -0
- package/es/chat-engine/components/a2ui/containers/A2UIRow.js +84 -0
- package/es/chat-engine/components/a2ui/containers/A2UIRow.js.map +1 -0
- package/es/chat-engine/components/a2ui/containers/A2UITabs.d.ts +14 -0
- package/es/chat-engine/components/a2ui/containers/A2UITabs.js +69 -0
- package/es/chat-engine/components/a2ui/containers/A2UITabs.js.map +1 -0
- package/es/chat-engine/components/a2ui/containers/index.d.ts +8 -0
- package/es/chat-engine/components/a2ui/containers/index.js +30 -0
- package/es/chat-engine/components/a2ui/containers/index.js.map +1 -0
- package/es/chat-engine/components/a2ui/index.d.ts +11 -0
- package/es/chat-engine/components/a2ui/index.js +60 -0
- package/es/chat-engine/components/a2ui/index.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIButton.d.ts +31 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIButton.js +76 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIButton.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.d.ts +12 -0
- package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.js +43 -0
- package/es/chat-engine/components/a2ui/primitives/A2UICheckBox.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.d.ts +50 -0
- package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.js +54 -0
- package/es/chat-engine/components/a2ui/primitives/A2UICheckboxGroup.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.d.ts +13 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.js +89 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIChoicePicker.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIDivider.d.ts +12 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIDivider.js +25 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIDivider.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIIcon.d.ts +13 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIIcon.js +138942 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIIcon.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIImage.d.ts +12 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIImage.js +75 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIImage.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIInput.d.ts +20 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIInput.js +63 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIInput.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.d.ts +56 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.js +64 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIRadioGroup.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UISlider.d.ts +12 -0
- package/es/chat-engine/components/a2ui/primitives/A2UISlider.js +55 -0
- package/es/chat-engine/components/a2ui/primitives/A2UISlider.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIText.d.ts +12 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIText.js +104 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIText.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UITextField.d.ts +12 -0
- package/es/chat-engine/components/a2ui/primitives/A2UITextField.js +80 -0
- package/es/chat-engine/components/a2ui/primitives/A2UITextField.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/index.d.ts +15 -0
- package/es/chat-engine/components/a2ui/primitives/index.js +39 -0
- package/es/chat-engine/components/a2ui/primitives/index.js.map +1 -0
- package/es/chat-engine/components/a2ui/registry.d.ts +35 -0
- package/es/chat-engine/components/a2ui/registry.js +74 -0
- package/es/chat-engine/components/a2ui/registry.js.map +1 -0
- package/es/chat-engine/components/activity/index.js +1 -1
- package/es/chat-engine/components/activity/registry.js +4 -4
- package/es/chat-engine/components/activity/registry.js.map +1 -1
- package/es/chat-engine/components/activity/render.js +6 -6
- package/es/chat-engine/components/activity/render.js.map +1 -1
- package/es/chat-engine/components/activity/types.js +1 -1
- package/es/chat-engine/components/index.js +4 -1
- package/es/chat-engine/components/index.js.map +1 -1
- package/es/chat-engine/components/provider/agent-state.js +6 -3
- package/es/chat-engine/components/provider/agent-state.js.map +1 -1
- package/es/chat-engine/components/toolcall/index.js +4 -1
- package/es/chat-engine/components/toolcall/index.js.map +1 -1
- package/es/chat-engine/components/toolcall/registry.js +4 -4
- package/es/chat-engine/components/toolcall/registry.js.map +1 -1
- package/es/chat-engine/components/toolcall/render.js +14 -11
- package/es/chat-engine/components/toolcall/render.js.map +1 -1
- package/es/chat-engine/components/toolcall/types.js +1 -1
- package/es/chat-engine/core/a2ui/index.d.ts +10 -0
- package/es/chat-engine/core/a2ui/index.js +24 -0
- package/es/chat-engine/core/a2ui/index.js.map +1 -0
- package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.d.ts +197 -0
- package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.js +438 -0
- package/es/chat-engine/core/a2ui/processor/A2uiMessageProcessor.js.map +1 -0
- package/es/chat-engine/core/a2ui/processor/ComponentTree.d.ts +53 -0
- package/es/chat-engine/core/a2ui/processor/ComponentTree.js +158 -0
- package/es/chat-engine/core/a2ui/processor/ComponentTree.js.map +1 -0
- package/es/chat-engine/core/a2ui/processor/DataStore.d.ts +63 -0
- package/es/chat-engine/core/a2ui/processor/DataStore.js +172 -0
- package/es/chat-engine/core/a2ui/processor/DataStore.js.map +1 -0
- package/es/chat-engine/core/a2ui/processor/PathResolver.d.ts +47 -0
- package/es/chat-engine/core/a2ui/processor/PathResolver.js +99 -0
- package/es/chat-engine/core/a2ui/processor/PathResolver.js.map +1 -0
- package/es/chat-engine/core/a2ui/types/index.d.ts +4 -0
- package/es/chat-engine/core/a2ui/types/index.js +9 -0
- package/es/chat-engine/core/a2ui/types/index.js.map +1 -0
- package/es/chat-engine/core/a2ui/types/types.d.ts +769 -0
- package/es/chat-engine/core/a2ui/types/types.js +104 -0
- package/es/chat-engine/core/a2ui/types/types.js.map +1 -0
- package/es/chat-engine/core/a2ui/utils/binding.d.ts +34 -0
- package/es/chat-engine/core/a2ui/utils/binding.js +1784 -0
- package/es/chat-engine/core/a2ui/utils/binding.js.map +1 -0
- package/es/chat-engine/core/a2ui/utils/index.d.ts +5 -0
- package/es/chat-engine/core/a2ui/utils/index.js +13 -0
- package/es/chat-engine/core/a2ui/utils/index.js.map +1 -0
- package/es/chat-engine/core/a2ui/utils/validation.d.ts +70 -0
- package/es/chat-engine/core/a2ui/utils/validation.js +333 -0
- package/es/chat-engine/core/a2ui/utils/validation.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/event-mapper.d.ts +16 -0
- package/es/chat-engine/core/adapters/agui/event-mapper.js +60 -6
- package/es/chat-engine/core/adapters/agui/event-mapper.js.map +1 -1
- package/es/chat-engine/core/adapters/agui/events.js +1 -1
- package/es/chat-engine/core/adapters/agui/index.d.ts +1 -1
- package/es/chat-engine/core/adapters/agui/index.js +1 -1
- package/es/chat-engine/core/adapters/agui/index.js.map +1 -1
- package/es/chat-engine/core/adapters/agui/state-manager.js +1 -1
- package/es/chat-engine/core/adapters/agui/types.js +1 -1
- package/es/chat-engine/core/adapters/agui/utils.d.ts +5 -1
- package/es/chat-engine/core/adapters/agui/utils.js +6 -2
- package/es/chat-engine/core/adapters/agui/utils.js.map +1 -1
- package/es/chat-engine/core/event-bus/ChatEventBus.d.ts +88 -0
- package/es/chat-engine/core/event-bus/ChatEventBus.js +295 -0
- package/es/chat-engine/core/event-bus/ChatEventBus.js.map +1 -0
- package/es/chat-engine/core/event-bus/index.d.ts +5 -0
- package/es/chat-engine/core/event-bus/index.js +13 -0
- package/es/chat-engine/core/event-bus/index.js.map +1 -0
- package/es/chat-engine/core/event-bus/types.d.ts +230 -0
- package/es/chat-engine/core/event-bus/types.js +32 -0
- package/es/chat-engine/core/event-bus/types.js.map +1 -0
- package/es/chat-engine/core/index.d.ts +8 -1
- package/es/chat-engine/core/index.js +128 -10
- package/es/chat-engine/core/index.js.map +1 -1
- package/es/chat-engine/core/processor/index.js +1 -1
- package/es/chat-engine/core/server/batch-client.js +1 -1
- package/es/chat-engine/core/server/connection-manager.js +1 -1
- package/es/chat-engine/core/server/errors.js +1 -1
- package/es/chat-engine/core/server/index.js +1 -1
- package/es/chat-engine/core/server/llm-service.js +17 -15
- package/es/chat-engine/core/server/llm-service.js.map +1 -1
- package/es/chat-engine/core/server/sse-client.js +1 -1
- package/es/chat-engine/core/server/sse-parser.js +1 -1
- package/es/chat-engine/core/server/types.js +1 -1
- package/es/chat-engine/core/store/message.js +1 -1
- package/es/chat-engine/core/store/model.js +1 -1
- package/es/chat-engine/core/store/reactiveState.js +1 -1
- package/es/chat-engine/core/type.d.ts +18 -2
- package/es/chat-engine/core/type.js +1 -1
- package/es/chat-engine/core/utils/eventEmitter.js +1 -1
- package/es/chat-engine/core/utils/index.js +1 -1
- package/es/chat-engine/core/utils/logger.js +1 -1
- package/es/chat-engine/hooks/a2ui/A2UIContext.d.ts +90 -0
- package/es/chat-engine/hooks/a2ui/A2UIContext.js +97 -0
- package/es/chat-engine/hooks/a2ui/A2UIContext.js.map +1 -0
- package/es/chat-engine/hooks/a2ui/index.d.ts +7 -0
- package/es/chat-engine/hooks/a2ui/index.js +19 -0
- package/es/chat-engine/hooks/a2ui/index.js.map +1 -0
- package/es/chat-engine/hooks/a2ui/useA2UIAction.d.ts +40 -0
- package/es/chat-engine/hooks/a2ui/useA2UIAction.js +74 -0
- package/es/chat-engine/hooks/a2ui/useA2UIAction.js.map +1 -0
- package/es/chat-engine/hooks/a2ui/useA2UISurface.d.ts +36 -0
- package/es/chat-engine/hooks/a2ui/useA2UISurface.js +39 -0
- package/es/chat-engine/hooks/a2ui/useA2UISurface.js.map +1 -0
- package/es/chat-engine/hooks/a2ui/useDataBinding.d.ts +53 -0
- package/es/chat-engine/hooks/a2ui/useDataBinding.js +111 -0
- package/es/chat-engine/hooks/a2ui/useDataBinding.js.map +1 -0
- package/es/chat-engine/hooks/index.js +4 -1
- package/es/chat-engine/hooks/index.js.map +1 -1
- package/es/chat-engine/hooks/useAgentActivity.js +1 -1
- package/es/chat-engine/hooks/useAgentState.js +4 -1
- package/es/chat-engine/hooks/useAgentState.js.map +1 -1
- package/es/chat-engine/hooks/useAgentToolcall.js +1 -1
- package/es/chat-engine/hooks/useChat.js +4 -1
- package/es/chat-engine/hooks/useChat.js.map +1 -1
- package/es/chat-engine/index.js +4 -1
- package/es/chat-engine/index.js.map +1 -1
- package/es/chat-filecard/index.js +1 -1
- package/es/chat-loading/index.js +1 -1
- package/es/chat-markdown/index.js +1 -1
- package/es/chat-message/index.js +1 -1
- package/es/chat-sender/index.js +1 -1
- package/es/chat-thinking/index.js +1 -1
- package/es/chatbot/docs/react-best-practice.d.ts +13 -0
- package/es/chatbot/index.js +1 -1
- package/es/index.js +4 -1
- package/es/index.js.map +1 -1
- package/es/style/index.js +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.12
|
|
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.12
|
|
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.12
|
|
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":";;;;;;;;;;;;;;;;;;;AAqBA,IAAMA,eAA0C,GAAA;AAC9CC,EAAAA,KAAO,EAAA,YAAA;AACPC,EAAAA,MAAQ,EAAA,QAAA;AACRC,EAAAA,GAAK,EAAA,UAAA;AACLC,EAAAA,YAAc,EAAA,eAAA;AACdC,EAAAA,WAAa,EAAA,cAAA;AACbC,EAAAA,WAAa,EAAA,cAAA;AACbC,EAAAA,OAAS,EAAA,SAAA;AACX,CAAA,CAAA;AAGA,IAAMC,YAAuC,GAAA;AAC3CP,EAAAA,KAAO,EAAA,YAAA;AACPC,EAAAA,MAAQ,EAAA,QAAA;AACRC,EAAAA,GAAK,EAAA,UAAA;AACLI,EAAAA,OAAS,EAAA,SAAA;AACX,CAAA,CAAA;IAEaE,aAAwC,SAAxCA,iBAWP;AAAA,EAAA,IAVJC,EAAA,GAAAC,IAAA,CAAAD,EAAA;IACAE,QAAA,GAAAD,IAAA,CAAAC,QAAA;IACAC,gBAAA,GAAAF,IAAA,CAAAE,gBAAA;IACAC,YAAA,GAAAH,IAAA,CAAAG,YAAA;IACAC,SAAA,GAAAJ,IAAA,CAAAI,SAAA;IAEAC,GAAA,GAAAL,IAAA,CAAAK,GAAA;IACAC,KAAA,GAAAN,IAAA,CAAAM,KAAA;IACAC,SAAA,GAAAP,IAAA,CAAAO,SAAA;IACAC,KAAA,GAAAR,IAAA,CAAAQ,KAAA,CAAA;AAGM,EAAA,IAAAC,aAAA,GAAgBC,QAA6B,YAAM;AACvD,IAAA,IAAMC,SAAiC,GAAA;AACrCC,MAAAA,OAAS,EAAA,MAAA;AACTC,MAAAA,aAAe,EAAA,QAAA;KACjB,CAAA;AAGI,IAAA,IAAAV,YAAA,IAAgB,OAAOA,YAAA,KAAiB,QAAU,EAAA;MAC1CQ,SAAA,CAAAG,cAAA,GAAiBzB,gBAAgBc,YAAiB,CAAA,IAAAA,YAAA,CAAA;AAC9D,KAAA;AAGI,IAAA,IAAAC,SAAA,IAAa,OAAOA,SAAA,KAAc,QAAU,EAAA;MACpCO,SAAA,CAAAI,UAAA,GAAalB,aAAaO,SAAc,CAAA,IAAAA,SAAA,CAAA;eACzCE,KAAO,EAAA;AAEhBK,MAAAA,SAAA,CAAUI,aAAaT,KAAU,KAAA,OAAA,GAAU,YACzC,GAAAA,KAAA,KAAU,QAAQ,UAAa,GAAAA,KAAA,CAAA;AACnC,KAAA;AAGA,IAAA,IAAID,QAAQ,KAAW,CAAA,EAAA;AACrBM,MAAAA,SAAA,CAAUN,GAAM,GAAA,OAAOA,GAAQ,KAAA,QAAA,GAAA,EAAA,CAAAW,MAAA,CAAcX,GAAU,EAAA,IAAA,CAAA,GAAAA,GAAA,CAAA;AACzD,KAAO,MAAA;MACLM,SAAA,CAAUN,GAAM,GAAA,KAAA,CAAA;AAClB,KAAA;AAEO,IAAA,OAAAM,SAAA,CAAA;KACN,CAACR,YAAA,EAAcC,SAAW,EAAAC,GAAA,EAAKC,KAAK,CAAC,CAAA,CAAA;EAGxC,IAAI,CAACJ,gBAAA,IAAoBA,gBAAiB,CAAAe,MAAA,KAAW,CAAG,EAAA;AAC/C,IAAA,OAAA,IAAA,CAAA;AACT,GAAA;AAEA,EAAA,sBACGC,cAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAIZ,IAAAA,SAAA,EAAAA,SAAA;AAAsBC,IAAAA,KAAO,EAAAY,aAAA,CAAAA,aAAA,CAAKX,EAAAA,EAAAA,aAAA,GAAkBD,KAAM,CAAA;GAAA,EAC5DN,gBAAiB,CAAAmB,GAAA,CAAI,UAACC,KAAA,EAAOC;0BAC3BL,cAAA,CAAAC,aAAA,CAAAK,qBAAA,EAAA;AAAsBC,MAAAA,GAAA,EAAKH,MAAMvB,EAAM,IAAAwB,KAAA;AAAOG,MAAAA,SAAW,EAAAJ,KAAAA;AAAA,KAAO,CAClE,CAAA;AAAA,GAAA,CACH,CAAA,CAAA;AAEJ,EAAA;AAEAxB,UAAA,CAAW6B,WAAc,GAAA,YAAA;;;;"}
|
|
@@ -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.12
|
|
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.12
|
|
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;
|