@tdesign-react/chat 1.0.2-alpha.9 → 1.1.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/_chunks/dep-f2051ebd.js +839 -0
- package/es/_chunks/dep-f2051ebd.js.map +1 -0
- package/es/_util/reactify.js +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 +196 -0
- package/es/chat-engine/components/a2ui/A2UIActivityRenderer.js +301 -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 +62 -0
- package/es/chat-engine/components/a2ui/index.js.map +1 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIButton.d.ts +33 -0
- package/es/chat-engine/components/a2ui/primitives/A2UIButton.js +80 -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.d.ts +1 -1
- package/es/chat-engine/components/activity/registry.js +1 -1
- package/es/chat-engine/components/activity/registry.js.map +1 -1
- package/es/chat-engine/components/activity/render.d.ts +2 -2
- package/es/chat-engine/components/activity/render.js +1 -1
- 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.d.ts +1 -0
- package/es/chat-engine/components/index.js +57 -9
- package/es/chat-engine/components/index.js.map +1 -1
- package/es/chat-engine/components/json-render/A2UIJsonRenderActivityRenderer.d.ts +36 -0
- package/es/chat-engine/components/json-render/A2UIJsonRenderActivityRenderer.js +36 -0
- package/es/chat-engine/components/json-render/A2UIJsonRenderActivityRenderer.js.map +1 -0
- package/es/chat-engine/components/json-render/JsonRenderActivityRenderer.d.ts +46 -0
- package/es/chat-engine/components/json-render/JsonRenderActivityRenderer.js +36 -0
- package/es/chat-engine/components/json-render/JsonRenderActivityRenderer.js.map +1 -0
- package/es/chat-engine/components/json-render/SurfaceStateManager.d.ts +113 -0
- package/es/chat-engine/components/json-render/SurfaceStateManager.js +195 -0
- package/es/chat-engine/components/json-render/SurfaceStateManager.js.map +1 -0
- package/es/chat-engine/components/json-render/adapters/a2ui-to-jsonrender.d.ts +49 -0
- package/es/chat-engine/components/json-render/adapters/a2ui-to-jsonrender.js +307 -0
- package/es/chat-engine/components/json-render/adapters/a2ui-to-jsonrender.js.map +1 -0
- package/es/chat-engine/components/json-render/adapters/a2ui-types.d.ts +96 -0
- package/es/chat-engine/components/json-render/adapters/a2ui-types.js +7 -0
- package/es/chat-engine/components/json-render/adapters/a2ui-types.js.map +1 -0
- package/es/chat-engine/components/json-render/adapters/index.d.ts +7 -0
- package/es/chat-engine/components/json-render/adapters/index.js +11 -0
- package/es/chat-engine/components/json-render/adapters/index.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/a2ui-binding.d.ts +64 -0
- package/es/chat-engine/components/json-render/catalog/a2ui-binding.js +36 -0
- package/es/chat-engine/components/json-render/catalog/a2ui-binding.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/a2ui-registry.d.ts +78 -0
- package/es/chat-engine/components/json-render/catalog/a2ui-registry.js +36 -0
- package/es/chat-engine/components/json-render/catalog/a2ui-registry.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/button.d.ts +14 -0
- package/es/chat-engine/components/json-render/catalog/button.js +71 -0
- package/es/chat-engine/components/json-render/catalog/button.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/card.d.ts +11 -0
- package/es/chat-engine/components/json-render/catalog/card.js +57 -0
- package/es/chat-engine/components/json-render/catalog/card.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/index.d.ts +127 -0
- package/es/chat-engine/components/json-render/catalog/index.js +36 -0
- package/es/chat-engine/components/json-render/catalog/index.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/input.d.ts +20 -0
- package/es/chat-engine/components/json-render/catalog/input.js +36 -0
- package/es/chat-engine/components/json-render/catalog/input.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/layout.d.ts +44 -0
- package/es/chat-engine/components/json-render/catalog/layout.js +129 -0
- package/es/chat-engine/components/json-render/catalog/layout.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog/text.d.ts +11 -0
- package/es/chat-engine/components/json-render/catalog/text.js +31 -0
- package/es/chat-engine/components/json-render/catalog/text.js.map +1 -0
- package/es/chat-engine/components/json-render/catalog.d.ts +549 -0
- package/es/chat-engine/components/json-render/catalog.js +147 -0
- package/es/chat-engine/components/json-render/catalog.js.map +1 -0
- package/es/chat-engine/components/json-render/config.d.ts +154 -0
- package/es/chat-engine/components/json-render/config.js +36 -0
- package/es/chat-engine/components/json-render/config.js.map +1 -0
- package/es/chat-engine/components/json-render/contexts/actions.d.ts +74 -0
- package/es/chat-engine/components/json-render/contexts/actions.js +290 -0
- package/es/chat-engine/components/json-render/contexts/actions.js.map +1 -0
- package/es/chat-engine/components/json-render/contexts/data.d.ts +45 -0
- package/es/chat-engine/components/json-render/contexts/data.js +104 -0
- package/es/chat-engine/components/json-render/contexts/data.js.map +1 -0
- package/es/chat-engine/components/json-render/contexts/validation.d.ts +59 -0
- package/es/chat-engine/components/json-render/contexts/validation.js +151 -0
- package/es/chat-engine/components/json-render/contexts/validation.js.map +1 -0
- package/es/chat-engine/components/json-render/contexts/visibility.d.ts +29 -0
- package/es/chat-engine/components/json-render/contexts/visibility.js +56 -0
- package/es/chat-engine/components/json-render/contexts/visibility.js.map +1 -0
- package/es/chat-engine/components/json-render/engine.d.ts +58 -0
- package/es/chat-engine/components/json-render/engine.js +88 -0
- package/es/chat-engine/components/json-render/engine.js.map +1 -0
- package/es/chat-engine/components/json-render/index.d.ts +34 -0
- package/es/chat-engine/components/json-render/index.js +36 -0
- package/es/chat-engine/components/json-render/index.js.map +1 -0
- package/es/chat-engine/components/json-render/performance.d.ts +91 -0
- package/es/chat-engine/components/json-render/performance.js +135 -0
- package/es/chat-engine/components/json-render/performance.js.map +1 -0
- package/es/chat-engine/components/json-render/renderer.d.ts +71 -0
- package/es/chat-engine/components/json-render/renderer.js +124 -0
- package/es/chat-engine/components/json-render/renderer.js.map +1 -0
- package/es/chat-engine/components/json-render/types.d.ts +69 -0
- package/es/chat-engine/components/json-render/types.js +7 -0
- package/es/chat-engine/components/json-render/types.js.map +1 -0
- package/es/chat-engine/components/provider/agent-state.js +39 -2
- package/es/chat-engine/components/provider/agent-state.js.map +1 -1
- package/es/chat-engine/components/toolcall/index.js +32 -2
- package/es/chat-engine/components/toolcall/index.js.map +1 -1
- package/es/chat-engine/components/toolcall/registry.js +1 -1
- package/es/chat-engine/components/toolcall/render.d.ts +1 -1
- package/es/chat-engine/components/toolcall/render.js +33 -4
- 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 +770 -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/activity-manager.d.ts +102 -0
- package/es/chat-engine/core/adapters/agui/activity-manager.js +144 -0
- package/es/chat-engine/core/adapters/agui/activity-manager.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/event-mapper.d.ts +42 -2
- package/es/chat-engine/core/adapters/agui/event-mapper.js +90 -50
- package/es/chat-engine/core/adapters/agui/event-mapper.js.map +1 -1
- package/es/chat-engine/core/adapters/agui/events.d.ts +222 -222
- package/es/chat-engine/core/adapters/agui/events.js +34 -34
- package/es/chat-engine/core/adapters/agui/events.js.map +1 -1
- package/es/chat-engine/core/adapters/agui/index.d.ts +22 -2
- package/es/chat-engine/core/adapters/agui/index.js +34 -14
- 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.d.ts +57 -56
- package/es/chat-engine/core/adapters/agui/types.js +5 -5
- package/es/chat-engine/core/adapters/agui/types.js.map +1 -1
- package/es/chat-engine/core/adapters/agui/utils.d.ts +9 -3
- package/es/chat-engine/core/adapters/agui/utils.js +23 -4
- 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 +16 -1
- package/es/chat-engine/core/index.js +174 -17
- 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 +2 -2
- package/es/chat-engine/core/store/message.js.map +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 +12 -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 +38 -4
- package/es/chat-engine/hooks/index.js.map +1 -1
- package/es/chat-engine/hooks/useAgentActivity.d.ts +1 -2
- package/es/chat-engine/hooks/useAgentActivity.js +1 -1
- package/es/chat-engine/hooks/useAgentActivity.js.map +1 -1
- package/es/chat-engine/hooks/useAgentState.js +39 -2
- 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.d.ts +3 -3
- package/es/chat-engine/hooks/useChat.js +40 -2
- package/es/chat-engine/hooks/useChat.js.map +1 -1
- package/es/chat-engine/hooks/useJsonRenderActivity.d.ts +56 -0
- package/es/chat-engine/hooks/useJsonRenderActivity.js +63 -0
- package/es/chat-engine/hooks/useJsonRenderActivity.js.map +1 -0
- package/es/chat-engine/index.d.ts +1 -3
- package/es/chat-engine/index.js +30 -8
- 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 +27 -5
- package/es/index.js.map +1 -1
- package/es/style/index.js +1 -1
- package/package.json +6 -3
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.14
|
|
3
|
+
* (c) 2026 tdesign
|
|
4
|
+
* @license MIT
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import React__default from 'react';
|
|
8
|
+
import { Card } from 'tdesign-react';
|
|
9
|
+
import { useDataBinding } from '../../../hooks/a2ui/useDataBinding.js';
|
|
10
|
+
import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
|
|
11
|
+
import '@babel/runtime/helpers/slicedToArray';
|
|
12
|
+
import '../../../hooks/a2ui/A2UIContext.js';
|
|
13
|
+
import '@babel/runtime/helpers/defineProperty';
|
|
14
|
+
import '../../../core/a2ui/utils/index.js';
|
|
15
|
+
import '../../../core/a2ui/utils/binding.js';
|
|
16
|
+
import '@babel/runtime/helpers/typeof';
|
|
17
|
+
import '../../../core/a2ui/utils/validation.js';
|
|
18
|
+
import '@babel/runtime/helpers/toConsumableArray';
|
|
19
|
+
import '../A2UIErrorBoundary.js';
|
|
20
|
+
import '@babel/runtime/helpers/classCallCheck';
|
|
21
|
+
import '@babel/runtime/helpers/createClass';
|
|
22
|
+
import '@babel/runtime/helpers/possibleConstructorReturn';
|
|
23
|
+
import '@babel/runtime/helpers/getPrototypeOf';
|
|
24
|
+
import '@babel/runtime/helpers/inherits';
|
|
25
|
+
|
|
26
|
+
var A2UICard = function A2UICard(_ref) {
|
|
27
|
+
var id = _ref.id,
|
|
28
|
+
child = _ref.child,
|
|
29
|
+
resolvedChildren = _ref.resolvedChildren,
|
|
30
|
+
title = _ref.title,
|
|
31
|
+
_ref$bordered = _ref.bordered,
|
|
32
|
+
bordered = _ref$bordered === void 0 ? true : _ref$bordered,
|
|
33
|
+
_ref$shadow = _ref.shadow,
|
|
34
|
+
shadow = _ref$shadow === void 0 ? false : _ref$shadow,
|
|
35
|
+
subtitle = _ref.subtitle,
|
|
36
|
+
description = _ref.description,
|
|
37
|
+
_ref$hoverShadow = _ref.hoverShadow,
|
|
38
|
+
hoverShadow = _ref$hoverShadow === void 0 ? false : _ref$hoverShadow,
|
|
39
|
+
_ref$size = _ref.size,
|
|
40
|
+
size = _ref$size === void 0 ? "medium" : _ref$size,
|
|
41
|
+
_ref$headerBordered = _ref.headerBordered,
|
|
42
|
+
headerBordered = _ref$headerBordered === void 0 ? false : _ref$headerBordered,
|
|
43
|
+
children = _ref.children,
|
|
44
|
+
className = _ref.className,
|
|
45
|
+
style = _ref.style;
|
|
46
|
+
var resolvedTitle = useDataBinding(title);
|
|
47
|
+
var renderContent = function renderContent() {
|
|
48
|
+
if (resolvedChildren && resolvedChildren.length > 0) {
|
|
49
|
+
return resolvedChildren.map(function (comp, index) {
|
|
50
|
+
return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
|
|
51
|
+
key: comp.id || index,
|
|
52
|
+
component: comp
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
if (children && Array.isArray(children)) {
|
|
57
|
+
return children.map(function (comp, index) {
|
|
58
|
+
return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
|
|
59
|
+
key: comp.id || index,
|
|
60
|
+
component: comp
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
return null;
|
|
65
|
+
};
|
|
66
|
+
return /* @__PURE__ */React__default.createElement(Card, {
|
|
67
|
+
className: className,
|
|
68
|
+
style: style,
|
|
69
|
+
title: resolvedTitle,
|
|
70
|
+
subtitle: subtitle,
|
|
71
|
+
description: description,
|
|
72
|
+
bordered: bordered,
|
|
73
|
+
shadow: shadow,
|
|
74
|
+
hoverShadow: hoverShadow,
|
|
75
|
+
size: size,
|
|
76
|
+
headerBordered: headerBordered
|
|
77
|
+
}, renderContent());
|
|
78
|
+
};
|
|
79
|
+
A2UICard.displayName = "A2UICard";
|
|
80
|
+
|
|
81
|
+
export { A2UICard, A2UICard as default };
|
|
82
|
+
//# sourceMappingURL=A2UICard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UICard.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UICard.tsx"],"sourcesContent":["/**\n * A2UI Card 容器组件\n * 复用 TDesign Card,支持 A2UI v0.9 child 模式\n */\n\nimport React from 'react';\nimport { Card } from 'tdesign-react';\nimport { useDataBinding } from '../../../hooks/a2ui/useDataBinding';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UICardComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UICardProps extends Omit<A2UICardComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n /** TDesign 扩展属性 */\n subtitle?: string;\n description?: string;\n hoverShadow?: boolean;\n size?: 'medium' | 'small';\n headerBordered?: boolean;\n /** 向后兼容:children 数组 */\n children?: any[];\n}\n\nexport const A2UICard: React.FC<A2UICardProps> = ({\n id,\n child,\n resolvedChildren,\n title,\n bordered = true,\n shadow = false,\n // TDesign 扩展\n subtitle,\n description,\n hoverShadow = false,\n size = 'medium',\n headerBordered = false,\n // 向后兼容\n children,\n className,\n style,\n}) => {\n // 解析绑定值\n const resolvedTitle = useDataBinding<React.ReactNode>(title);\n\n // 渲染内容:优先使用 resolvedChildren(A2UI v0.9),其次使用 children(向后兼容)\n const renderContent = () => {\n if (resolvedChildren && resolvedChildren.length > 0) {\n return resolvedChildren.map((comp, index) => (\n <A2UIComponentRenderer key={comp.id || index} component={comp} />\n ));\n }\n // 向后兼容:直接渲染 children\n if (children && Array.isArray(children)) {\n return children.map((comp, index) => (\n <A2UIComponentRenderer key={comp.id || index} component={comp} />\n ));\n }\n return null;\n };\n\n return (\n <Card\n className={className}\n style={style}\n title={resolvedTitle}\n subtitle={subtitle}\n description={description}\n bordered={bordered as boolean}\n shadow={shadow as boolean}\n hoverShadow={hoverShadow as boolean}\n size={size}\n headerBordered={headerBordered}\n >\n {renderContent()}\n </Card>\n );\n};\n\nA2UICard.displayName = 'A2UICard';\n\nexport default A2UICard;\n"],"names":["A2UICard","id","_ref","child","resolvedChildren","title","_ref$bordered","bordered","_ref$shadow","shadow","subtitle","description","_ref$hoverShadow","hoverShadow","_ref$size","size","_ref$headerBordered","headerBordered","children","className","style","resolvedTitle","useDataBinding","renderContent","length","map","comp","index","React","createElement","A2UIComponentRenderer","key","component","Array","isArray","Card","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;IA0BaA,WAAoC,SAApCA,eAiBP;AAAA,EAAA,IAhBJC,EAAA,GAAAC,IAAA,CAAAD,EAAA;IACAE,KAAA,GAAAD,IAAA,CAAAC,KAAA;IACAC,gBAAA,GAAAF,IAAA,CAAAE,gBAAA;IACAC,KAAA,GAAAH,IAAA,CAAAG,KAAA;IAAAC,aAAA,GAAAJ,IAAA,CACAK,QAAW;AAAXA,IAAAA,QAAW,GAAAD,aAAA,KAAA,KAAA,CAAA,GAAA,IAAA,GAAAA,aAAA;IAAAE,WAAA,GAAAN,IAAA,CACXO,MAAS;AAATA,IAAAA,MAAS,GAAAD,WAAA,KAAA,KAAA,CAAA,GAAA,KAAA,GAAAA,WAAA;IAETE,QAAA,GAAAR,IAAA,CAAAQ,QAAA;IACAC,WAAA,GAAAT,IAAA,CAAAS,WAAA;IAAAC,gBAAA,GAAAV,IAAA,CACAW,WAAc;AAAdA,IAAAA,WAAc,GAAAD,gBAAA,KAAA,KAAA,CAAA,GAAA,KAAA,GAAAA,gBAAA;IAAAE,SAAA,GAAAZ,IAAA,CACda,IAAO;AAAPA,IAAAA,IAAO,GAAAD,SAAA,KAAA,KAAA,CAAA,GAAA,QAAA,GAAAA,SAAA;IAAAE,mBAAA,GAAAd,IAAA,CACPe,cAAiB;AAAjBA,IAAAA,cAAiB,GAAAD,mBAAA,KAAA,KAAA,CAAA,GAAA,KAAA,GAAAA,mBAAA;IAEjBE,QAAA,GAAAhB,IAAA,CAAAgB,QAAA;IACAC,SAAA,GAAAjB,IAAA,CAAAiB,SAAA;IACAC,KAAA,GAAAlB,IAAA,CAAAkB,KAAA,CAAA;AAGM,EAAA,IAAAC,aAAA,GAAgBC,eAAgCjB,KAAK,CAAA,CAAA;AAG3D,EAAA,IAAMkB,gBAAgB,SAAhBA,gBAAsB;AACtB,IAAA,IAAAnB,gBAAA,IAAoBA,gBAAiB,CAAAoB,MAAA,GAAS,CAAG,EAAA;AACnD,MAAA,OAAOpB,gBAAiB,CAAAqB,GAAA,CAAI,UAACC,IAAA,EAAMC;8BAChCC,cAAA,CAAAC,aAAA,CAAAC,qBAAA,EAAA;AAAsBC,UAAAA,GAAA,EAAKL,KAAKzB,EAAM,IAAA0B,KAAA;AAAOK,UAAAA,SAAW,EAAAN,IAAAA;AAAA,SAAM,CAChE,CAAA;OAAA,CAAA,CAAA;AACH,KAAA;IAEA,IAAIR,QAAY,IAAAe,KAAA,CAAMC,OAAQ,CAAAhB,QAAQ,CAAG,EAAA;AACvC,MAAA,OAAOA,QAAS,CAAAO,GAAA,CAAI,UAACC,IAAA,EAAMC;8BACxBC,cAAA,CAAAC,aAAA,CAAAC,qBAAA,EAAA;AAAsBC,UAAAA,GAAA,EAAKL,KAAKzB,EAAM,IAAA0B,KAAA;AAAOK,UAAAA,SAAW,EAAAN,IAAAA;AAAA,SAAM,CAChE,CAAA;OAAA,CAAA,CAAA;AACH,KAAA;AACO,IAAA,OAAA,IAAA,CAAA;GACT,CAAA;AAEA,EAAA,sBACGE,cAAA,CAAAC,aAAA,CAAAM,IAAA,EAAA;AACChB,IAAAA,SAAA,EAAAA,SAAA;AACAC,IAAAA,KAAA,EAAAA,KAAA;AACAf,IAAAA,KAAO,EAAAgB,aAAA;AACPX,IAAAA,QAAA,EAAAA,QAAA;AACAC,IAAAA,WAAA,EAAAA,WAAA;AACAJ,IAAAA,QAAA,EAAAA,QAAA;AACAE,IAAAA,MAAA,EAAAA,MAAA;AACAI,IAAAA,WAAA,EAAAA,WAAA;AACAE,IAAAA,IAAA,EAAAA,IAAA;AACAE,IAAAA,cAAA,EAAAA,cAAAA;AAAA,GAAA,EAECM,eACH,CAAA,CAAA;AAEJ,EAAA;AAEAvB,QAAA,CAASoC,WAAc,GAAA,UAAA;;;;"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI Column 容器组件
|
|
3
|
+
* A2UI v0.9 标准垂直布局组件
|
|
4
|
+
*/
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import type { A2UIColumnComponent, ResolvedComponent } from '../../../core/a2ui';
|
|
7
|
+
export interface A2UIColumnProps extends Omit<A2UIColumnComponent, 'component'> {
|
|
8
|
+
/** 解析后的子组件(由 ComponentRenderer 传入) */
|
|
9
|
+
resolvedChildren?: ResolvedComponent[];
|
|
10
|
+
className?: string;
|
|
11
|
+
style?: React.CSSProperties;
|
|
12
|
+
/** 向后兼容:gap 属性 */
|
|
13
|
+
gap?: number | string;
|
|
14
|
+
/** 向后兼容:align 属性 */
|
|
15
|
+
align?: 'start' | 'center' | 'end' | 'stretch';
|
|
16
|
+
}
|
|
17
|
+
export declare const A2UIColumn: React.FC<A2UIColumnProps>;
|
|
18
|
+
export default A2UIColumn;
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.14
|
|
3
|
+
* (c) 2026 tdesign
|
|
4
|
+
* @license MIT
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
8
|
+
import React__default, { useMemo } from 'react';
|
|
9
|
+
import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
|
|
10
|
+
import '../../../hooks/a2ui/A2UIContext.js';
|
|
11
|
+
import '../A2UIErrorBoundary.js';
|
|
12
|
+
import '@babel/runtime/helpers/classCallCheck';
|
|
13
|
+
import '@babel/runtime/helpers/createClass';
|
|
14
|
+
import '@babel/runtime/helpers/possibleConstructorReturn';
|
|
15
|
+
import '@babel/runtime/helpers/getPrototypeOf';
|
|
16
|
+
import '@babel/runtime/helpers/inherits';
|
|
17
|
+
|
|
18
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
19
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
20
|
+
var distributionMap = {
|
|
21
|
+
start: "flex-start",
|
|
22
|
+
center: "center",
|
|
23
|
+
end: "flex-end",
|
|
24
|
+
spaceBetween: "space-between",
|
|
25
|
+
spaceAround: "space-around",
|
|
26
|
+
spaceEvenly: "space-evenly",
|
|
27
|
+
stretch: "stretch"
|
|
28
|
+
};
|
|
29
|
+
var alignmentMap = {
|
|
30
|
+
start: "flex-start",
|
|
31
|
+
center: "center",
|
|
32
|
+
end: "flex-end",
|
|
33
|
+
stretch: "stretch"
|
|
34
|
+
};
|
|
35
|
+
var A2UIColumn = function A2UIColumn(_ref) {
|
|
36
|
+
var id = _ref.id,
|
|
37
|
+
children = _ref.children,
|
|
38
|
+
resolvedChildren = _ref.resolvedChildren,
|
|
39
|
+
distribution = _ref.distribution,
|
|
40
|
+
alignment = _ref.alignment,
|
|
41
|
+
gap = _ref.gap,
|
|
42
|
+
align = _ref.align,
|
|
43
|
+
className = _ref.className,
|
|
44
|
+
style = _ref.style;
|
|
45
|
+
var computedStyle = useMemo(function () {
|
|
46
|
+
var baseStyle = {
|
|
47
|
+
display: "flex",
|
|
48
|
+
flexDirection: "column"
|
|
49
|
+
};
|
|
50
|
+
if (distribution && typeof distribution === "string") {
|
|
51
|
+
baseStyle.justifyContent = distributionMap[distribution] || distribution;
|
|
52
|
+
}
|
|
53
|
+
if (alignment && typeof alignment === "string") {
|
|
54
|
+
baseStyle.alignItems = alignmentMap[alignment] || alignment;
|
|
55
|
+
} else if (align) {
|
|
56
|
+
baseStyle.alignItems = align === "start" ? "flex-start" : align === "end" ? "flex-end" : align;
|
|
57
|
+
}
|
|
58
|
+
if (gap !== void 0) {
|
|
59
|
+
baseStyle.gap = typeof gap === "number" ? "".concat(gap, "px") : gap;
|
|
60
|
+
} else {
|
|
61
|
+
baseStyle.gap = "8px";
|
|
62
|
+
}
|
|
63
|
+
return baseStyle;
|
|
64
|
+
}, [distribution, alignment, gap, align]);
|
|
65
|
+
if (!resolvedChildren || resolvedChildren.length === 0) {
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
return /* @__PURE__ */React__default.createElement("div", {
|
|
69
|
+
className: className,
|
|
70
|
+
style: _objectSpread(_objectSpread({}, computedStyle), style)
|
|
71
|
+
}, resolvedChildren.map(function (child, index) {
|
|
72
|
+
return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
|
|
73
|
+
key: child.id || index,
|
|
74
|
+
component: child
|
|
75
|
+
});
|
|
76
|
+
}));
|
|
77
|
+
};
|
|
78
|
+
A2UIColumn.displayName = "A2UIColumn";
|
|
79
|
+
|
|
80
|
+
export { A2UIColumn, A2UIColumn as default };
|
|
81
|
+
//# sourceMappingURL=A2UIColumn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UIColumn.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UIColumn.tsx"],"sourcesContent":["/**\n * A2UI Column 容器组件\n * A2UI v0.9 标准垂直布局组件\n */\n\nimport React, { useMemo } from 'react';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UIColumnComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UIColumnProps extends Omit<A2UIColumnComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n /** 向后兼容:gap 属性 */\n gap?: number | string;\n /** 向后兼容:align 属性 */\n align?: 'start' | 'center' | 'end' | 'stretch';\n}\n\n// A2UI v0.9 distribution 到 CSS justify-content 的映射\nconst distributionMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n spaceBetween: 'space-between',\n spaceAround: 'space-around',\n spaceEvenly: 'space-evenly',\n stretch: 'stretch',\n};\n\n// A2UI v0.9 alignment 到 CSS align-items 的映射\nconst alignmentMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n stretch: 'stretch',\n};\n\nexport const A2UIColumn: React.FC<A2UIColumnProps> = ({\n id,\n children,\n resolvedChildren,\n distribution,\n alignment,\n // 向后兼容\n gap,\n align,\n className,\n style,\n}) => {\n // 计算样式\n const computedStyle = useMemo<React.CSSProperties>(() => {\n const baseStyle: React.CSSProperties = {\n display: 'flex',\n flexDirection: 'column',\n };\n\n // A2UI v0.9 distribution\n if (distribution && typeof distribution === 'string') {\n baseStyle.justifyContent = distributionMap[distribution] || distribution;\n }\n\n // A2UI v0.9 alignment\n if (alignment && typeof alignment === 'string') {\n baseStyle.alignItems = alignmentMap[alignment] || alignment;\n } else if (align) {\n // 向后兼容 align\n baseStyle.alignItems = align === 'start' ? 'flex-start' :\n align === 'end' ? 'flex-end' : align;\n }\n\n // gap\n if (gap !== undefined) {\n baseStyle.gap = typeof gap === 'number' ? `${gap}px` : gap;\n } else {\n baseStyle.gap = '8px'; // 默认间距\n }\n\n return baseStyle;\n }, [distribution, alignment, gap, align]);\n\n // 渲染子组件\n if (!resolvedChildren || resolvedChildren.length === 0) {\n return null;\n }\n\n return (\n <div className={className} style={{ ...computedStyle, ...style }}>\n {resolvedChildren.map((child, index) => (\n <A2UIComponentRenderer key={child.id || index} component={child} />\n ))}\n </div>\n );\n};\n\nA2UIColumn.displayName = 'A2UIColumn';\n\nexport default A2UIColumn;\n"],"names":["distributionMap","start","center","end","spaceBetween","spaceAround","spaceEvenly","stretch","alignmentMap","A2UIColumn","id","_ref","children","resolvedChildren","distribution","alignment","gap","align","className","style","computedStyle","useMemo","baseStyle","display","flexDirection","justifyContent","alignItems","concat","length","React","createElement","_objectSpread","map","child","index","A2UIComponentRenderer","key","component","displayName"],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI List 容器组件
|
|
3
|
+
* A2UI v0.9 标准列表组件
|
|
4
|
+
*/
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import type { A2UIListComponent, ResolvedComponent } from '../../../core/a2ui';
|
|
7
|
+
export interface A2UIListProps extends Omit<A2UIListComponent, 'component'> {
|
|
8
|
+
/** 解析后的子组件(由 ComponentRenderer 传入) */
|
|
9
|
+
resolvedChildren?: ResolvedComponent[];
|
|
10
|
+
className?: string;
|
|
11
|
+
style?: React.CSSProperties;
|
|
12
|
+
}
|
|
13
|
+
export declare const A2UIList: React.FC<A2UIListProps>;
|
|
14
|
+
export default A2UIList;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.14
|
|
3
|
+
* (c) 2026 tdesign
|
|
4
|
+
* @license MIT
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
8
|
+
import React__default, { useMemo } from 'react';
|
|
9
|
+
import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
|
|
10
|
+
import '../../../hooks/a2ui/A2UIContext.js';
|
|
11
|
+
import '../A2UIErrorBoundary.js';
|
|
12
|
+
import '@babel/runtime/helpers/classCallCheck';
|
|
13
|
+
import '@babel/runtime/helpers/createClass';
|
|
14
|
+
import '@babel/runtime/helpers/possibleConstructorReturn';
|
|
15
|
+
import '@babel/runtime/helpers/getPrototypeOf';
|
|
16
|
+
import '@babel/runtime/helpers/inherits';
|
|
17
|
+
|
|
18
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
19
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
20
|
+
var alignmentMap = {
|
|
21
|
+
start: "flex-start",
|
|
22
|
+
center: "center",
|
|
23
|
+
end: "flex-end",
|
|
24
|
+
stretch: "stretch"
|
|
25
|
+
};
|
|
26
|
+
var A2UIList = function A2UIList(_ref) {
|
|
27
|
+
var id = _ref.id,
|
|
28
|
+
children = _ref.children,
|
|
29
|
+
resolvedChildren = _ref.resolvedChildren,
|
|
30
|
+
_ref$direction = _ref.direction,
|
|
31
|
+
direction = _ref$direction === void 0 ? "vertical" : _ref$direction,
|
|
32
|
+
alignment = _ref.alignment,
|
|
33
|
+
className = _ref.className,
|
|
34
|
+
style = _ref.style;
|
|
35
|
+
var computedStyle = useMemo(function () {
|
|
36
|
+
var baseStyle = {
|
|
37
|
+
display: "flex",
|
|
38
|
+
flexDirection: direction === "horizontal" ? "row" : "column",
|
|
39
|
+
gap: "8px"
|
|
40
|
+
};
|
|
41
|
+
if (alignment && typeof alignment === "string") {
|
|
42
|
+
baseStyle.alignItems = alignmentMap[alignment] || alignment;
|
|
43
|
+
}
|
|
44
|
+
return baseStyle;
|
|
45
|
+
}, [direction, alignment]);
|
|
46
|
+
if (!resolvedChildren || resolvedChildren.length === 0) {
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
return /* @__PURE__ */React__default.createElement("div", {
|
|
50
|
+
className: className,
|
|
51
|
+
style: _objectSpread(_objectSpread({}, computedStyle), style)
|
|
52
|
+
}, resolvedChildren.map(function (child, index) {
|
|
53
|
+
return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
|
|
54
|
+
key: child.id || index,
|
|
55
|
+
component: child
|
|
56
|
+
});
|
|
57
|
+
}));
|
|
58
|
+
};
|
|
59
|
+
A2UIList.displayName = "A2UIList";
|
|
60
|
+
|
|
61
|
+
export { A2UIList, A2UIList as default };
|
|
62
|
+
//# sourceMappingURL=A2UIList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UIList.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UIList.tsx"],"sourcesContent":["/**\n * A2UI List 容器组件\n * A2UI v0.9 标准列表组件\n */\n\nimport React, { useMemo } from 'react';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UIListComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UIListProps extends Omit<A2UIListComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n}\n\n// A2UI v0.9 alignment 到 CSS align-items 的映射\nconst alignmentMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n stretch: 'stretch',\n};\n\nexport const A2UIList: React.FC<A2UIListProps> = ({\n id,\n children,\n resolvedChildren,\n direction = 'vertical',\n alignment,\n className,\n style,\n}) => {\n // 计算样式\n const computedStyle = useMemo<React.CSSProperties>(() => {\n const baseStyle: React.CSSProperties = {\n display: 'flex',\n flexDirection: direction === 'horizontal' ? 'row' : 'column',\n gap: '8px',\n };\n\n if (alignment && typeof alignment === 'string') {\n baseStyle.alignItems = alignmentMap[alignment] || alignment;\n }\n\n return baseStyle;\n }, [direction, alignment]);\n\n // 渲染子组件\n if (!resolvedChildren || resolvedChildren.length === 0) {\n return null;\n }\n\n return (\n <div className={className} style={{ ...computedStyle, ...style }}>\n {resolvedChildren.map((child, index) => (\n <A2UIComponentRenderer key={child.id || index} component={child} />\n ))}\n </div>\n );\n};\n\nA2UIList.displayName = 'A2UIList';\n\nexport default A2UIList;\n"],"names":["alignmentMap","start","center","end","stretch","A2UIList","id","_ref","children","resolvedChildren","_ref$direction","direction","alignment","className","style","computedStyle","useMemo","baseStyle","display","flexDirection","gap","alignItems","length","React","createElement","_objectSpread","map","child","index","A2UIComponentRenderer","key","component","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;AAiBA,IAAMA,YAAuC,GAAA;AAC3CC,EAAAA,KAAO,EAAA,YAAA;AACPC,EAAAA,MAAQ,EAAA,QAAA;AACRC,EAAAA,GAAK,EAAA,UAAA;AACLC,EAAAA,OAAS,EAAA,SAAA;AACX,CAAA,CAAA;IAEaC,WAAoC,SAApCA,eAQP;AAAA,EAAA,IAPJC,EAAA,GAAAC,IAAA,CAAAD,EAAA;IACAE,QAAA,GAAAD,IAAA,CAAAC,QAAA;IACAC,gBAAA,GAAAF,IAAA,CAAAE,gBAAA;IAAAC,cAAA,GAAAH,IAAA,CACAI,SAAY;AAAZA,IAAAA,SAAY,GAAAD,cAAA,KAAA,KAAA,CAAA,GAAA,UAAA,GAAAA,cAAA;IACZE,SAAA,GAAAL,IAAA,CAAAK,SAAA;IACAC,SAAA,GAAAN,IAAA,CAAAM,SAAA;IACAC,KAAA,GAAAP,IAAA,CAAAO,KAAA,CAAA;AAGM,EAAA,IAAAC,aAAA,GAAgBC,QAA6B,YAAM;AACvD,IAAA,IAAMC,SAAiC,GAAA;AACrCC,MAAAA,OAAS,EAAA,MAAA;AACTC,MAAAA,aAAA,EAAeR,SAAc,KAAA,YAAA,GAAe,KAAQ,GAAA,QAAA;AACpDS,MAAAA,GAAK,EAAA,KAAA;KACP,CAAA;AAEI,IAAA,IAAAR,SAAA,IAAa,OAAOA,SAAA,KAAc,QAAU,EAAA;MACpCK,SAAA,CAAAI,UAAA,GAAarB,aAAaY,SAAc,CAAA,IAAAA,SAAA,CAAA;AACpD,KAAA;AAEO,IAAA,OAAAK,SAAA,CAAA;AACT,GAAG,EAAA,CAACN,SAAW,EAAAC,SAAS,CAAC,CAAA,CAAA;EAGzB,IAAI,CAACH,gBAAA,IAAoBA,gBAAiB,CAAAa,MAAA,KAAW,CAAG,EAAA;AAC/C,IAAA,OAAA,IAAA,CAAA;AACT,GAAA;AAEA,EAAA,sBACGC,cAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAIX,IAAAA,SAAA,EAAAA,SAAA;AAAsBC,IAAAA,KAAO,EAAAW,aAAA,CAAAA,aAAA,CAAKV,EAAAA,EAAAA,aAAA,GAAkBD,KAAM,CAAA;GAAA,EAC5DL,gBAAiB,CAAAiB,GAAA,CAAI,UAACC,KAAA,EAAOC;0BAC3BL,cAAA,CAAAC,aAAA,CAAAK,qBAAA,EAAA;AAAsBC,MAAAA,GAAA,EAAKH,MAAMrB,EAAM,IAAAsB,KAAA;AAAOG,MAAAA,SAAW,EAAAJ,KAAAA;AAAA,KAAO,CAClE,CAAA;AAAA,GAAA,CACH,CAAA,CAAA;AAEJ,EAAA;AAEAtB,QAAA,CAAS2B,WAAc,GAAA,UAAA;;;;"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI Row 容器组件
|
|
3
|
+
* A2UI v0.9 标准水平布局组件
|
|
4
|
+
*/
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import type { A2UIRowComponent, ResolvedComponent } from '../../../core/a2ui';
|
|
7
|
+
export interface A2UIRowProps extends Omit<A2UIRowComponent, 'component'> {
|
|
8
|
+
/** 解析后的子组件(由 ComponentRenderer 传入) */
|
|
9
|
+
resolvedChildren?: ResolvedComponent[];
|
|
10
|
+
className?: string;
|
|
11
|
+
style?: React.CSSProperties;
|
|
12
|
+
/** 向后兼容:gap 属性 */
|
|
13
|
+
gap?: number | string;
|
|
14
|
+
/** 向后兼容:align 属性 */
|
|
15
|
+
align?: 'start' | 'center' | 'end' | 'stretch';
|
|
16
|
+
/** 向后兼容:justify 属性 */
|
|
17
|
+
justify?: 'start' | 'center' | 'end' | 'space-between' | 'space-around';
|
|
18
|
+
}
|
|
19
|
+
export declare const A2UIRow: React.FC<A2UIRowProps>;
|
|
20
|
+
export default A2UIRow;
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.14
|
|
3
|
+
* (c) 2026 tdesign
|
|
4
|
+
* @license MIT
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
8
|
+
import React__default, { useMemo } from 'react';
|
|
9
|
+
import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
|
|
10
|
+
import '../../../hooks/a2ui/A2UIContext.js';
|
|
11
|
+
import '../A2UIErrorBoundary.js';
|
|
12
|
+
import '@babel/runtime/helpers/classCallCheck';
|
|
13
|
+
import '@babel/runtime/helpers/createClass';
|
|
14
|
+
import '@babel/runtime/helpers/possibleConstructorReturn';
|
|
15
|
+
import '@babel/runtime/helpers/getPrototypeOf';
|
|
16
|
+
import '@babel/runtime/helpers/inherits';
|
|
17
|
+
|
|
18
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
19
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
20
|
+
var distributionMap = {
|
|
21
|
+
start: "flex-start",
|
|
22
|
+
center: "center",
|
|
23
|
+
end: "flex-end",
|
|
24
|
+
spaceBetween: "space-between",
|
|
25
|
+
spaceAround: "space-around",
|
|
26
|
+
spaceEvenly: "space-evenly",
|
|
27
|
+
stretch: "stretch"
|
|
28
|
+
};
|
|
29
|
+
var alignmentMap = {
|
|
30
|
+
start: "flex-start",
|
|
31
|
+
center: "center",
|
|
32
|
+
end: "flex-end",
|
|
33
|
+
stretch: "stretch"
|
|
34
|
+
};
|
|
35
|
+
var A2UIRow = function A2UIRow(_ref) {
|
|
36
|
+
var id = _ref.id,
|
|
37
|
+
children = _ref.children,
|
|
38
|
+
resolvedChildren = _ref.resolvedChildren,
|
|
39
|
+
distribution = _ref.distribution,
|
|
40
|
+
alignment = _ref.alignment,
|
|
41
|
+
gap = _ref.gap,
|
|
42
|
+
align = _ref.align,
|
|
43
|
+
justify = _ref.justify,
|
|
44
|
+
className = _ref.className,
|
|
45
|
+
style = _ref.style;
|
|
46
|
+
var computedStyle = useMemo(function () {
|
|
47
|
+
var baseStyle = {
|
|
48
|
+
display: "flex",
|
|
49
|
+
flexDirection: "row"
|
|
50
|
+
};
|
|
51
|
+
if (distribution && typeof distribution === "string") {
|
|
52
|
+
baseStyle.justifyContent = distributionMap[distribution] || distribution;
|
|
53
|
+
} else if (justify) {
|
|
54
|
+
baseStyle.justifyContent = justify === "start" ? "flex-start" : justify === "end" ? "flex-end" : justify;
|
|
55
|
+
}
|
|
56
|
+
if (alignment && typeof alignment === "string") {
|
|
57
|
+
baseStyle.alignItems = alignmentMap[alignment] || alignment;
|
|
58
|
+
} else if (align) {
|
|
59
|
+
baseStyle.alignItems = align === "start" ? "flex-start" : align === "end" ? "flex-end" : align;
|
|
60
|
+
}
|
|
61
|
+
if (gap !== void 0) {
|
|
62
|
+
baseStyle.gap = typeof gap === "number" ? "".concat(gap, "px") : gap;
|
|
63
|
+
} else {
|
|
64
|
+
baseStyle.gap = "8px";
|
|
65
|
+
}
|
|
66
|
+
return baseStyle;
|
|
67
|
+
}, [distribution, alignment, gap, align, justify]);
|
|
68
|
+
if (!resolvedChildren || resolvedChildren.length === 0) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
return /* @__PURE__ */React__default.createElement("div", {
|
|
72
|
+
className: className,
|
|
73
|
+
style: _objectSpread(_objectSpread({}, computedStyle), style)
|
|
74
|
+
}, resolvedChildren.map(function (child, index) {
|
|
75
|
+
return /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
|
|
76
|
+
key: child.id || index,
|
|
77
|
+
component: child
|
|
78
|
+
});
|
|
79
|
+
}));
|
|
80
|
+
};
|
|
81
|
+
A2UIRow.displayName = "A2UIRow";
|
|
82
|
+
|
|
83
|
+
export { A2UIRow, A2UIRow as default };
|
|
84
|
+
//# sourceMappingURL=A2UIRow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UIRow.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UIRow.tsx"],"sourcesContent":["/**\n * A2UI Row 容器组件\n * A2UI v0.9 标准水平布局组件\n */\n\nimport React, { useMemo } from 'react';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UIRowComponent, ResolvedComponent } from '../../../core/a2ui';\n\nexport interface A2UIRowProps extends Omit<A2UIRowComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n /** 向后兼容:gap 属性 */\n gap?: number | string;\n /** 向后兼容:align 属性 */\n align?: 'start' | 'center' | 'end' | 'stretch';\n /** 向后兼容:justify 属性 */\n justify?: 'start' | 'center' | 'end' | 'space-between' | 'space-around';\n}\n\n// A2UI v0.9 distribution 到 CSS justify-content 的映射\nconst distributionMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n spaceBetween: 'space-between',\n spaceAround: 'space-around',\n spaceEvenly: 'space-evenly',\n stretch: 'stretch',\n};\n\n// A2UI v0.9 alignment 到 CSS align-items 的映射\nconst alignmentMap: Record<string, string> = {\n start: 'flex-start',\n center: 'center',\n end: 'flex-end',\n stretch: 'stretch',\n};\n\nexport const A2UIRow: React.FC<A2UIRowProps> = ({\n id,\n children,\n resolvedChildren,\n distribution,\n alignment,\n // 向后兼容\n gap,\n align,\n justify,\n className,\n style,\n}) => {\n // 计算样式\n const computedStyle = useMemo<React.CSSProperties>(() => {\n const baseStyle: React.CSSProperties = {\n display: 'flex',\n flexDirection: 'row',\n };\n\n // A2UI v0.9 distribution\n if (distribution && typeof distribution === 'string') {\n baseStyle.justifyContent = distributionMap[distribution] || distribution;\n } else if (justify) {\n // 向后兼容 justify\n baseStyle.justifyContent = justify === 'start' ? 'flex-start' :\n justify === 'end' ? 'flex-end' : justify;\n }\n\n // A2UI v0.9 alignment\n if (alignment && typeof alignment === 'string') {\n baseStyle.alignItems = alignmentMap[alignment] || alignment;\n } else if (align) {\n // 向后兼容 align\n baseStyle.alignItems = align === 'start' ? 'flex-start' :\n align === 'end' ? 'flex-end' : align;\n }\n\n // gap\n if (gap !== undefined) {\n baseStyle.gap = typeof gap === 'number' ? `${gap}px` : gap;\n } else {\n baseStyle.gap = '8px'; // 默认间距\n }\n\n return baseStyle;\n }, [distribution, alignment, gap, align, justify]);\n\n // 渲染子组件\n if (!resolvedChildren || resolvedChildren.length === 0) {\n return null;\n }\n\n return (\n <div className={className} style={{ ...computedStyle, ...style }}>\n {resolvedChildren.map((child, index) => (\n <A2UIComponentRenderer key={child.id || index} component={child} />\n ))}\n </div>\n );\n};\n\nA2UIRow.displayName = 'A2UIRow';\n\nexport default A2UIRow;\n"],"names":["distributionMap","start","center","end","spaceBetween","spaceAround","spaceEvenly","stretch","alignmentMap","A2UIRow","id","_ref","children","resolvedChildren","distribution","alignment","gap","align","justify","className","style","computedStyle","useMemo","baseStyle","display","flexDirection","justifyContent","alignItems","concat","length","React","createElement","_objectSpread","map","child","index","A2UIComponentRenderer","key","component","displayName"],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI Tabs 容器组件
|
|
3
|
+
* A2UI v0.9 标准标签页组件
|
|
4
|
+
*/
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import type { A2UITabsComponent, ResolvedComponent } from '../../../core/a2ui';
|
|
7
|
+
export interface A2UITabsProps extends Omit<A2UITabsComponent, 'component'> {
|
|
8
|
+
/** 解析后的子组件(由 ComponentRenderer 传入) */
|
|
9
|
+
resolvedChildren?: ResolvedComponent[];
|
|
10
|
+
className?: string;
|
|
11
|
+
style?: React.CSSProperties;
|
|
12
|
+
}
|
|
13
|
+
export declare const A2UITabs: React.FC<A2UITabsProps>;
|
|
14
|
+
export default A2UITabs;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.14
|
|
3
|
+
* (c) 2026 tdesign
|
|
4
|
+
* @license MIT
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
|
|
8
|
+
import React__default, { useState } from 'react';
|
|
9
|
+
import { Tabs } from 'tdesign-react';
|
|
10
|
+
import { useDataBinding } from '../../../hooks/a2ui/useDataBinding.js';
|
|
11
|
+
import { A2UIComponentRenderer } from '../A2UIComponentRenderer.js';
|
|
12
|
+
import '../../../hooks/a2ui/A2UIContext.js';
|
|
13
|
+
import '@babel/runtime/helpers/defineProperty';
|
|
14
|
+
import '../../../core/a2ui/utils/index.js';
|
|
15
|
+
import '../../../core/a2ui/utils/binding.js';
|
|
16
|
+
import '@babel/runtime/helpers/typeof';
|
|
17
|
+
import '../../../core/a2ui/utils/validation.js';
|
|
18
|
+
import '@babel/runtime/helpers/toConsumableArray';
|
|
19
|
+
import '../A2UIErrorBoundary.js';
|
|
20
|
+
import '@babel/runtime/helpers/classCallCheck';
|
|
21
|
+
import '@babel/runtime/helpers/createClass';
|
|
22
|
+
import '@babel/runtime/helpers/possibleConstructorReturn';
|
|
23
|
+
import '@babel/runtime/helpers/getPrototypeOf';
|
|
24
|
+
import '@babel/runtime/helpers/inherits';
|
|
25
|
+
|
|
26
|
+
var TabPanel = Tabs.TabPanel;
|
|
27
|
+
var TabTitle = function TabTitle(_ref) {
|
|
28
|
+
var title = _ref.title;
|
|
29
|
+
var resolvedTitle = useDataBinding(title);
|
|
30
|
+
return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, resolvedTitle);
|
|
31
|
+
};
|
|
32
|
+
var A2UITabs = function A2UITabs(_ref2) {
|
|
33
|
+
var id = _ref2.id,
|
|
34
|
+
tabItems = _ref2.tabItems,
|
|
35
|
+
resolvedChildren = _ref2.resolvedChildren,
|
|
36
|
+
className = _ref2.className,
|
|
37
|
+
style = _ref2.style;
|
|
38
|
+
var _useState = useState("0"),
|
|
39
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
40
|
+
activeTab = _useState2[0],
|
|
41
|
+
setActiveTab = _useState2[1];
|
|
42
|
+
if (!tabItems || !Array.isArray(tabItems) || tabItems.length === 0) {
|
|
43
|
+
return null;
|
|
44
|
+
}
|
|
45
|
+
var handleChange = function handleChange(value) {
|
|
46
|
+
setActiveTab(String(value));
|
|
47
|
+
};
|
|
48
|
+
return /* @__PURE__ */React__default.createElement(Tabs, {
|
|
49
|
+
className: className,
|
|
50
|
+
style: style,
|
|
51
|
+
value: activeTab,
|
|
52
|
+
onChange: handleChange
|
|
53
|
+
}, tabItems.map(function (item, index) {
|
|
54
|
+
var childComponent = resolvedChildren === null || resolvedChildren === void 0 ? void 0 : resolvedChildren[index];
|
|
55
|
+
return /* @__PURE__ */React__default.createElement(TabPanel, {
|
|
56
|
+
key: index,
|
|
57
|
+
value: String(index),
|
|
58
|
+
label: /* @__PURE__ */React__default.createElement(TabTitle, {
|
|
59
|
+
title: item.title
|
|
60
|
+
})
|
|
61
|
+
}, childComponent && /* @__PURE__ */React__default.createElement(A2UIComponentRenderer, {
|
|
62
|
+
component: childComponent
|
|
63
|
+
}));
|
|
64
|
+
}));
|
|
65
|
+
};
|
|
66
|
+
A2UITabs.displayName = "A2UITabs";
|
|
67
|
+
|
|
68
|
+
export { A2UITabs, A2UITabs as default };
|
|
69
|
+
//# sourceMappingURL=A2UITabs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UITabs.js","sources":["../../../../../../pro-components/chat/chat-engine/components/a2ui/containers/A2UITabs.tsx"],"sourcesContent":["/**\n * A2UI Tabs 容器组件\n * A2UI v0.9 标准标签页组件\n */\n\nimport React, { useState } from 'react';\nimport { Tabs } from 'tdesign-react';\nimport { useDataBinding } from '../../../hooks/a2ui/useDataBinding';\nimport { A2UIComponentRenderer } from '../A2UIComponentRenderer';\nimport type { A2UITabsComponent, A2UITabItem, ResolvedComponent, Bindable } from '../../../core/a2ui';\n\nconst { TabPanel } = Tabs;\n\nexport interface A2UITabsProps extends Omit<A2UITabsComponent, 'component'> {\n /** 解析后的子组件(由 ComponentRenderer 传入) */\n resolvedChildren?: ResolvedComponent[];\n className?: string;\n style?: React.CSSProperties;\n}\n\n/**\n * Tab 标题组件(支持数据绑定)\n */\nconst TabTitle: React.FC<{ title: Bindable<string> }> = ({ title }) => {\n const resolvedTitle = useDataBinding<string>(title);\n return <>{resolvedTitle}</>;\n};\n\nexport const A2UITabs: React.FC<A2UITabsProps> = ({\n id,\n tabItems,\n resolvedChildren,\n className,\n style,\n}) => {\n const [activeTab, setActiveTab] = useState<string>('0');\n\n // 如果没有 tabItems,返回 null\n if (!tabItems || !Array.isArray(tabItems) || tabItems.length === 0) {\n return null;\n }\n\n // 处理 tab 切换\n const handleChange = (value: string | number) => {\n setActiveTab(String(value));\n };\n\n return (\n <Tabs\n className={className}\n style={style}\n value={activeTab}\n onChange={handleChange}\n >\n {tabItems.map((item, index) => {\n // 从 resolvedChildren 中找到对应的子组件\n const childComponent = resolvedChildren?.[index];\n\n return (\n <TabPanel\n key={index}\n value={String(index)}\n label={<TabTitle title={item.title} />}\n >\n {childComponent && (\n <A2UIComponentRenderer component={childComponent} />\n )}\n </TabPanel>\n );\n })}\n </Tabs>\n );\n};\n\nA2UITabs.displayName = 'A2UITabs';\n\nexport default A2UITabs;\n"],"names":["TabPanel","Tabs","TabTitle","_ref","title","resolvedTitle","useDataBinding","A2UITabs","id","_ref2","tabItems","resolvedChildren","className","style","_useState","useState","_useState2","_slicedToArray","activeTab","setActiveTab","Array","isArray","length","handleChange","value","String","React","createElement","onChange","map","item","index","childComponent","key","label","A2UIComponentRenderer","component","displayName"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAWA,IAAQA,WAAaC,IAAA,CAAbD;AAYR,IAAME,QAAkD,GAAA,SAAlDA,QAAkDA,CAAAC,IAAA,EAAe;AAAA,EAAA,IAAZC,KAAA,GAAAD,IAAA,CAAAC,KAAA,CAAA;AACnD,EAAA,IAAAC,aAAA,GAAgBC,eAAuBF,KAAK,CAAA,CAAA;AAClD,EAAA,kFAAUC,aAAc,CAAA,CAAA;AAC1B,CAAA,CAAA;IAEaE,WAAoC,SAApCA,gBAMP;AAAA,EAAA,IALJC,EAAA,GAAAC,KAAA,CAAAD,EAAA;IACAE,QAAA,GAAAD,KAAA,CAAAC,QAAA;IACAC,gBAAA,GAAAF,KAAA,CAAAE,gBAAA;IACAC,SAAA,GAAAH,KAAA,CAAAG,SAAA;IACAC,KAAA,GAAAJ,KAAA,CAAAI,KAAA,CAAA;AAEA,EAAA,IAAAC,SAAA,GAAkCC,SAAiB,GAAG,CAAA;IAAAC,UAAA,GAAAC,cAAA,CAAAH,SAAA,EAAA,CAAA,CAAA;AAA/CI,IAAAA,SAAA,GAAAF,UAAA,CAAA,CAAA,CAAA;AAAWG,IAAAA,YAAY,GAAAH,UAAA,CAAA,CAAA,CAAA,CAAA;AAG1B,EAAA,IAAA,CAACN,YAAY,CAACU,KAAA,CAAMC,QAAQX,QAAQ,CAAA,IAAKA,QAAS,CAAAY,MAAA,KAAW,CAAG,EAAA;AAC3D,IAAA,OAAA,IAAA,CAAA;AACT,GAAA;AAGM,EAAA,IAAAC,YAAA,GAAe,SAAfA,YAAAA,CAAgBC,KAA2B,EAAA;AAClCL,IAAAA,YAAA,CAAAM,MAAA,CAAOD,KAAK,CAAC,CAAA,CAAA;GAC5B,CAAA;AAEA,EAAA,sBACGE,cAAA,CAAAC,aAAA,CAAA1B,IAAA,EAAA;AACCW,IAAAA,SAAA,EAAAA,SAAA;AACAC,IAAAA,KAAA,EAAAA,KAAA;AACAW,IAAAA,KAAO,EAAAN,SAAA;AACPU,IAAAA,QAAU,EAAAL,YAAAA;GAAA,EAETb,QAAS,CAAAmB,GAAA,CAAI,UAACC,IAAA,EAAMC,KAAU,EAAA;IAE7B,IAAMC,iBAAiBrB,gBAAmB,KAAA,IAAA,IAAnBA,gBAAmB,KAAnBA,KAAAA,CAAAA,GAAAA,KAAAA,CAAAA,GAAAA,gBAAmB,CAAAoB,KAAA,CAAA,CAAA;AAE1C,IAAA,sBACGL,cAAA,CAAAC,aAAA,CAAA3B,QAAA,EAAA;AACCiC,MAAAA,GAAK,EAAAF,KAAA;AACLP,MAAAA,KAAA,EAAOC,OAAOM,KAAK,CAAA;AACnBG,MAAAA,sBAAQR,cAAA,CAAAC,aAAA,CAAAzB,QAAA,EAAA;QAASE,OAAO0B,IAAK,CAAA1B,KAAAA;OAAO,CAAA;KAAA,EAEnC4B,iCACEN,cAAA,CAAAC,aAAA,CAAAQ,qBAAA,EAAA;AAAsBC,MAAAA,SAAW,EAAAJ,cAAAA;AAAA,KAAgB,CAEtD,CAAA,CAAA;AAEJ,GAAC,CACH,CAAA,CAAA;AAEJ,EAAA;AAEAzB,QAAA,CAAS8B,WAAc,GAAA,UAAA;;;;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI 容器组件导出
|
|
3
|
+
*/
|
|
4
|
+
export { A2UICard, type A2UICardProps } from './A2UICard';
|
|
5
|
+
export { A2UIRow, type A2UIRowProps } from './A2UIRow';
|
|
6
|
+
export { A2UIColumn, type A2UIColumnProps } from './A2UIColumn';
|
|
7
|
+
export { A2UIList, type A2UIListProps } from './A2UIList';
|
|
8
|
+
export { A2UITabs, type A2UITabsProps } from './A2UITabs';
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* tdesign v1.0.2-alpha.14
|
|
3
|
+
* (c) 2026 tdesign
|
|
4
|
+
* @license MIT
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
export { A2UICard } from './A2UICard.js';
|
|
8
|
+
export { A2UIRow } from './A2UIRow.js';
|
|
9
|
+
export { A2UIColumn } from './A2UIColumn.js';
|
|
10
|
+
export { A2UIList } from './A2UIList.js';
|
|
11
|
+
export { A2UITabs } from './A2UITabs.js';
|
|
12
|
+
import 'react';
|
|
13
|
+
import 'tdesign-react';
|
|
14
|
+
import '../../../hooks/a2ui/useDataBinding.js';
|
|
15
|
+
import '@babel/runtime/helpers/slicedToArray';
|
|
16
|
+
import '../../../hooks/a2ui/A2UIContext.js';
|
|
17
|
+
import '@babel/runtime/helpers/defineProperty';
|
|
18
|
+
import '../../../core/a2ui/utils/index.js';
|
|
19
|
+
import '../../../core/a2ui/utils/binding.js';
|
|
20
|
+
import '@babel/runtime/helpers/typeof';
|
|
21
|
+
import '../../../core/a2ui/utils/validation.js';
|
|
22
|
+
import '@babel/runtime/helpers/toConsumableArray';
|
|
23
|
+
import '../A2UIComponentRenderer.js';
|
|
24
|
+
import '../A2UIErrorBoundary.js';
|
|
25
|
+
import '@babel/runtime/helpers/classCallCheck';
|
|
26
|
+
import '@babel/runtime/helpers/createClass';
|
|
27
|
+
import '@babel/runtime/helpers/possibleConstructorReturn';
|
|
28
|
+
import '@babel/runtime/helpers/getPrototypeOf';
|
|
29
|
+
import '@babel/runtime/helpers/inherits';
|
|
30
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI 组件层导出
|
|
3
|
+
*/
|
|
4
|
+
export { A2UIComponentRenderer, A2UIChildrenRenderer, type A2UIComponentRendererProps, } from './A2UIComponentRenderer';
|
|
5
|
+
export { A2UISurfaceRenderer, type A2UISurfaceRendererProps, } from './A2UISurfaceRenderer';
|
|
6
|
+
export { A2UIActivityRenderer, createA2UIActivityConfig, createA2UIActionHandler, type A2UIActivityRendererProps, type A2UIActivityContent, type A2UIActivityConfigOptions, type UserActionMessage, type ActionResult, type OnActionCallback, type DeltaInfo, } from './A2UIActivityRenderer';
|
|
7
|
+
export { A2UIErrorBoundary, withA2UIErrorBoundary, type A2UIErrorBoundaryProps, } from './A2UIErrorBoundary';
|
|
8
|
+
export { A2UISkeleton, A2UISurfaceSkeleton, type A2UISkeletonProps, type A2UISurfaceSkeletonProps, } from './A2UISkeleton';
|
|
9
|
+
export { defaultComponentRegistry, createComponentRegistry, extendComponentRegistry, } from './registry';
|
|
10
|
+
export * from './primitives';
|
|
11
|
+
export * from './containers';
|