@tdesign-react/chat 1.0.2-alpha.8 → 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.d.ts +1 -2
- package/es/_util/reactify.js +81 -231
- package/es/_util/reactify.js.map +1 -1
- package/es/_util/useDynamicStyle.js +1 -1
- package/es/attachments/index.js +4 -6
- package/es/attachments/index.js.map +1 -1
- package/es/chat-actionbar/_example-js/base.d.ts +2 -0
- package/es/chat-actionbar/_example-js/custom.d.ts +2 -0
- package/es/chat-actionbar/_example-js/style.d.ts +2 -0
- package/es/chat-actionbar/index.js +4 -6
- package/es/chat-actionbar/index.js.map +1 -1
- package/es/chat-attachments/_example-js/base.d.ts +2 -0
- package/es/chat-attachments/_example-js/scroll-x.d.ts +2 -0
- package/es/chat-attachments/_example-js/scroll-y.d.ts +2 -0
- package/es/chat-attachments/index.js +3 -1
- package/es/chat-attachments/index.js.map +1 -1
- package/es/chat-engine/_example-js/agui-basic.d.ts +10 -0
- package/es/chat-engine/_example-js/agui-comprehensive.d.ts +2 -0
- package/es/chat-engine/_example-js/agui-test.d.ts +11 -0
- package/es/chat-engine/_example-js/agui-toolcall.d.ts +5 -0
- package/es/chat-engine/_example-js/agui-videoclip.d.ts +8 -0
- package/es/chat-engine/_example-js/agui.d.ts +1 -0
- package/es/chat-engine/_example-js/basic.d.ts +9 -0
- package/es/chat-engine/_example-js/components/HotelCard.d.ts +3 -0
- package/es/chat-engine/_example-js/components/HumanInputForm.d.ts +6 -0
- package/es/chat-engine/_example-js/components/HumanInputResult.d.ts +3 -0
- package/es/chat-engine/_example-js/components/ItineraryCard.d.ts +3 -0
- package/es/chat-engine/_example-js/components/PlanningStatePanel.d.ts +4 -0
- package/es/chat-engine/_example-js/components/Toolcall.d.ts +4 -0
- package/es/chat-engine/_example-js/components/WeatherCard.d.ts +3 -0
- package/es/chat-engine/_example-js/components/login.d.ts +1 -0
- package/es/chat-engine/_example-js/comprehensive.d.ts +12 -0
- package/es/chat-engine/_example-js/custom-content.d.ts +1 -0
- package/es/chat-engine/_example-js/hookComponent.d.ts +1 -0
- package/es/chat-engine/_example-js/initial-messages.d.ts +9 -0
- package/es/chat-engine/_example-js/instance-methods.d.ts +13 -0
- package/es/chat-engine/_example-js/travel-actions.d.ts +91 -0
- package/es/chat-engine/_example-js/travelToolcall.d.ts +1 -0
- 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/{chatbot/components/toolcall → chat-engine/components/activity}/index.d.ts +1 -0
- package/es/chat-engine/components/activity/index.js +18 -0
- package/es/chat-engine/components/activity/index.js.map +1 -0
- package/es/chat-engine/components/activity/registry.d.ts +44 -0
- package/es/{chatbot/components/toolcall → chat-engine/components/activity}/registry.js +32 -22
- package/es/chat-engine/components/activity/registry.js.map +1 -0
- package/es/chat-engine/components/activity/render.d.ts +11 -0
- package/es/chat-engine/components/activity/render.js +107 -0
- package/es/chat-engine/components/activity/render.js.map +1 -0
- package/es/chat-engine/components/activity/types.d.ts +32 -0
- package/es/chat-engine/components/activity/types.js +7 -0
- package/es/chat-engine/components/activity/types.js.map +1 -0
- package/es/chat-engine/components/index.d.ts +4 -0
- package/es/chat-engine/components/index.js +76 -0
- package/es/chat-engine/components/index.js.map +1 -0
- 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 +35 -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 +102 -26
- 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 +149 -0
- package/es/chat-engine/core/adapters/agui/event-mapper.js +415 -0
- package/es/chat-engine/core/adapters/agui/event-mapper.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/events.d.ts +1550 -0
- package/es/chat-engine/core/adapters/agui/events.js +199 -0
- package/es/chat-engine/core/adapters/agui/events.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/index.d.ts +95 -0
- package/es/chat-engine/core/adapters/agui/index.js +195 -0
- package/es/chat-engine/core/adapters/agui/index.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/state-manager.d.ts +99 -0
- package/es/chat-engine/core/adapters/agui/state-manager.js +168 -0
- package/es/chat-engine/core/adapters/agui/state-manager.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/types.d.ts +818 -0
- package/es/chat-engine/core/adapters/agui/types.js +95 -0
- package/es/chat-engine/core/adapters/agui/types.js.map +1 -0
- package/es/chat-engine/core/adapters/agui/utils.d.ts +203 -0
- package/es/chat-engine/core/adapters/agui/utils.js +330 -0
- package/es/chat-engine/core/adapters/agui/utils.js.map +1 -0
- 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 +147 -0
- package/es/chat-engine/core/index.js +754 -0
- package/es/chat-engine/core/index.js.map +1 -0
- package/es/chat-engine/core/processor/index.d.ts +20 -0
- package/es/chat-engine/core/processor/index.js +146 -0
- package/es/chat-engine/core/processor/index.js.map +1 -0
- package/es/chat-engine/core/server/batch-client.d.ts +20 -0
- package/es/chat-engine/core/server/batch-client.js +114 -0
- package/es/chat-engine/core/server/batch-client.js.map +1 -0
- package/es/chat-engine/core/server/connection-manager.d.ts +39 -0
- package/es/chat-engine/core/server/connection-manager.js +84 -0
- package/es/chat-engine/core/server/connection-manager.js.map +1 -0
- package/es/chat-engine/core/server/errors.d.ts +22 -0
- package/es/chat-engine/core/server/errors.js +80 -0
- package/es/chat-engine/core/server/errors.js.map +1 -0
- package/es/chat-engine/core/server/index.d.ts +11 -0
- package/es/chat-engine/core/server/index.js +26 -0
- package/es/chat-engine/core/server/index.js.map +1 -0
- package/es/chat-engine/core/server/llm-service.d.ts +44 -0
- package/es/chat-engine/core/server/llm-service.js +200 -0
- package/es/chat-engine/core/server/llm-service.js.map +1 -0
- package/es/chat-engine/core/server/sse-client.d.ts +77 -0
- package/es/chat-engine/core/server/sse-client.js +362 -0
- package/es/chat-engine/core/server/sse-client.js.map +1 -0
- package/es/chat-engine/core/server/sse-parser.d.ts +49 -0
- package/es/chat-engine/core/server/sse-parser.js +116 -0
- package/es/chat-engine/core/server/sse-parser.js.map +1 -0
- package/es/chat-engine/core/server/types.d.ts +54 -0
- package/es/chat-engine/core/server/types.js +28 -0
- package/es/chat-engine/core/server/types.js.map +1 -0
- package/es/chat-engine/core/store/message.d.ts +27 -0
- package/es/chat-engine/core/store/message.js +263 -0
- package/es/chat-engine/core/store/message.js.map +1 -0
- package/es/chat-engine/core/store/model.d.ts +8 -0
- package/es/chat-engine/core/store/model.js +65 -0
- package/es/chat-engine/core/store/model.js.map +1 -0
- package/es/chat-engine/core/store/reactiveState.d.ts +52 -0
- package/es/chat-engine/core/store/reactiveState.js +1359 -0
- package/es/chat-engine/core/store/reactiveState.js.map +1 -0
- package/es/chat-engine/core/type.d.ts +271 -0
- package/es/chat-engine/core/type.js +7 -0
- package/es/chat-engine/core/type.js.map +1 -0
- package/es/chat-engine/core/utils/eventEmitter.d.ts +10 -0
- package/es/chat-engine/core/utils/eventEmitter.js +67 -0
- package/es/chat-engine/core/utils/eventEmitter.js.map +1 -0
- package/es/chat-engine/core/utils/index.d.ts +33 -0
- package/es/chat-engine/core/utils/index.js +999 -0
- package/es/chat-engine/core/utils/index.js.map +1 -0
- package/es/chat-engine/core/utils/logger.d.ts +30 -0
- package/es/chat-engine/core/utils/logger.js +87 -0
- package/es/chat-engine/core/utils/logger.js.map +1 -0
- 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/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.d.ts +4 -0
- package/es/chat-engine/hooks/index.js +54 -0
- package/es/chat-engine/hooks/index.js.map +1 -0
- package/es/chat-engine/hooks/useAgentActivity.d.ts +15 -0
- package/es/chat-engine/hooks/useAgentActivity.js +73 -0
- package/es/chat-engine/hooks/useAgentActivity.js.map +1 -0
- 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 +41 -3
- 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 +3 -3
- package/es/chat-engine/index.js +61 -5
- package/es/chat-engine/index.js.map +1 -1
- package/es/chat-filecard/_example-js/base.d.ts +1 -0
- package/es/chat-filecard/index.js +4 -6
- package/es/chat-filecard/index.js.map +1 -1
- package/es/chat-loading/_example-js/base.d.ts +2 -0
- package/es/chat-loading/_example-js/text.d.ts +2 -0
- package/es/chat-loading/index.js +4 -6
- package/es/chat-loading/index.js.map +1 -1
- package/es/chat-markdown/_example-js/base.d.ts +1 -0
- package/es/chat-markdown/_example-js/custom.d.ts +2 -0
- package/es/chat-markdown/_example-js/event.d.ts +1 -0
- package/es/chat-markdown/_example-js/footnote.d.ts +2 -0
- package/es/chat-markdown/_example-js/plugin.d.ts +2 -0
- package/es/chat-markdown/_example-js/theme.d.ts +2 -0
- package/es/chat-markdown/index.js +4 -6
- package/es/chat-markdown/index.js.map +1 -1
- package/es/chat-message/_example-js/action.d.ts +1 -0
- package/es/chat-message/_example-js/base.d.ts +1 -0
- package/es/chat-message/_example-js/configure.d.ts +1 -0
- package/es/chat-message/_example-js/content.d.ts +1 -0
- package/es/chat-message/_example-js/custom.d.ts +1 -0
- package/es/chat-message/_example-js/handle-actions.d.ts +7 -0
- package/es/chat-message/_example-js/status.d.ts +1 -0
- package/es/chat-message/_example-js/think.d.ts +1 -0
- package/es/chat-message/index.js +4 -6
- package/es/chat-message/index.js.map +1 -1
- package/es/chat-sender/_example-js/attachment.d.ts +2 -0
- package/es/chat-sender/_example-js/base.d.ts +2 -0
- package/es/chat-sender/_example-js/custom.d.ts +2 -0
- package/es/chat-sender/index.js +4 -6
- package/es/chat-sender/index.js.map +1 -1
- package/es/chat-thinking/_example-js/base.d.ts +1 -0
- package/es/chat-thinking/_example-js/style.d.ts +1 -0
- package/es/chat-thinking/index.js +4 -6
- package/es/chat-thinking/index.js.map +1 -1
- package/es/chatbot/_example-js/agent.d.ts +1 -0
- package/es/chatbot/_example-js/agui.d.ts +13 -0
- package/es/chatbot/_example-js/backup/travel.d.ts +1 -0
- package/es/chatbot/_example-js/basic.d.ts +1 -0
- package/es/chatbot/_example-js/code.d.ts +1 -0
- package/es/chatbot/_example-js/components/ItineraryCard.d.ts +3 -0
- package/es/chatbot/_example-js/components/login.d.ts +1 -0
- package/es/chatbot/_example-js/comprehensive.d.ts +1 -0
- package/es/chatbot/_example-js/custom-content.d.ts +1 -0
- package/es/chatbot/_example-js/custom-merge.d.ts +1 -0
- package/es/chatbot/_example-js/custom.d.ts +1 -0
- package/es/chatbot/_example-js/docs.d.ts +1 -0
- package/es/chatbot/_example-js/image.d.ts +1 -0
- package/es/chatbot/_example-js/initial-messages.d.ts +9 -0
- package/es/chatbot/_example-js/instance-methods.d.ts +14 -0
- package/es/chatbot/_example-js/nostream.d.ts +1 -0
- package/es/chatbot/_example-js/quick-start.d.ts +9 -0
- package/es/chatbot/_example-js/research.d.ts +1 -0
- package/es/chatbot/_example-js/role-message-config.d.ts +22 -0
- package/es/chatbot/_example-js/sender-config.d.ts +20 -0
- package/es/chatbot/_example-js/service-config.d.ts +17 -0
- package/es/chatbot/_example-js/simple.d.ts +1 -0
- package/es/chatbot/_example-js/utils/messageRenderer.d.ts +5 -0
- package/es/chatbot/docs/react-best-practice.d.ts +13 -0
- package/es/chatbot/index.js +4 -6
- package/es/chatbot/index.js.map +1 -1
- package/es/index.js +59 -9
- package/es/index.js.map +1 -1
- package/es/style/index.js +1 -1
- package/package.json +6 -3
- package/es/chatbot/components/provider/agent-state.d.ts +0 -5
- package/es/chatbot/components/provider/agent-state.js +0 -28
- package/es/chatbot/components/provider/agent-state.js.map +0 -1
- package/es/chatbot/components/toolcall/index.js +0 -19
- package/es/chatbot/components/toolcall/registry.d.ts +0 -35
- package/es/chatbot/components/toolcall/registry.js.map +0 -1
- package/es/chatbot/components/toolcall/render.d.ts +0 -13
- package/es/chatbot/components/toolcall/render.js +0 -207
- package/es/chatbot/components/toolcall/render.js.map +0 -1
- package/es/chatbot/components/toolcall/types.d.ts +0 -57
- package/es/chatbot/components/toolcall/types.js +0 -15
- package/es/chatbot/components/toolcall/types.js.map +0 -1
- package/es/chatbot/hooks/useAgentState.d.ts +0 -40
- package/es/chatbot/hooks/useAgentState.js +0 -76
- package/es/chatbot/hooks/useAgentState.js.map +0 -1
- package/es/chatbot/hooks/useAgentToolcall.d.ts +0 -28
- package/es/chatbot/hooks/useAgentToolcall.js +0 -78
- package/es/chatbot/hooks/useAgentToolcall.js.map +0 -1
- package/es/chatbot/hooks/useChat.d.ts +0 -11
- package/es/chatbot/hooks/useChat.js +0 -66
- package/es/chatbot/hooks/useChat.js.map +0 -1
- /package/es/{chatbot/components/toolcall → chat-engine/hooks/a2ui}/index.js.map +0 -0
|
@@ -0,0 +1,113 @@
|
|
|
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 _classCallCheck from '@babel/runtime/helpers/classCallCheck';
|
|
9
|
+
import _createClass from '@babel/runtime/helpers/createClass';
|
|
10
|
+
import _possibleConstructorReturn from '@babel/runtime/helpers/possibleConstructorReturn';
|
|
11
|
+
import _getPrototypeOf from '@babel/runtime/helpers/getPrototypeOf';
|
|
12
|
+
import _inherits from '@babel/runtime/helpers/inherits';
|
|
13
|
+
import React__default, { Component } from 'react';
|
|
14
|
+
|
|
15
|
+
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; }
|
|
16
|
+
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; }
|
|
17
|
+
function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
|
|
18
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
19
|
+
var A2UIErrorBoundary = /*#__PURE__*/function (_Component) {
|
|
20
|
+
function A2UIErrorBoundary(props) {
|
|
21
|
+
var _this;
|
|
22
|
+
_classCallCheck(this, A2UIErrorBoundary);
|
|
23
|
+
_this = _callSuper(this, A2UIErrorBoundary, [props]);
|
|
24
|
+
_this.state = {
|
|
25
|
+
hasError: false,
|
|
26
|
+
error: null
|
|
27
|
+
};
|
|
28
|
+
return _this;
|
|
29
|
+
}
|
|
30
|
+
_inherits(A2UIErrorBoundary, _Component);
|
|
31
|
+
return _createClass(A2UIErrorBoundary, [{
|
|
32
|
+
key: "componentDidCatch",
|
|
33
|
+
value: function componentDidCatch(error, errorInfo) {
|
|
34
|
+
var _this$props = this.props,
|
|
35
|
+
componentType = _this$props.componentType,
|
|
36
|
+
componentId = _this$props.componentId,
|
|
37
|
+
onError = _this$props.onError;
|
|
38
|
+
console.error("[A2UI] Component render error", {
|
|
39
|
+
componentType: componentType,
|
|
40
|
+
componentId: componentId,
|
|
41
|
+
error: error.message,
|
|
42
|
+
stack: error.stack,
|
|
43
|
+
componentStack: errorInfo.componentStack
|
|
44
|
+
});
|
|
45
|
+
onError === null || onError === void 0 || onError(error, componentType, componentId);
|
|
46
|
+
}
|
|
47
|
+
}, {
|
|
48
|
+
key: "render",
|
|
49
|
+
value: function render() {
|
|
50
|
+
var _this$state = this.state,
|
|
51
|
+
hasError = _this$state.hasError,
|
|
52
|
+
error = _this$state.error;
|
|
53
|
+
var _this$props2 = this.props,
|
|
54
|
+
children = _this$props2.children,
|
|
55
|
+
fallback = _this$props2.fallback,
|
|
56
|
+
_this$props2$showErro = _this$props2.showError,
|
|
57
|
+
showError = _this$props2$showErro === void 0 ? false : _this$props2$showErro,
|
|
58
|
+
componentType = _this$props2.componentType;
|
|
59
|
+
if (hasError) {
|
|
60
|
+
if (fallback) {
|
|
61
|
+
if (typeof fallback === "function") {
|
|
62
|
+
return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, fallback(error, componentType));
|
|
63
|
+
}
|
|
64
|
+
return /* @__PURE__ */React__default.createElement(React__default.Fragment, null, fallback);
|
|
65
|
+
}
|
|
66
|
+
if (showError) {
|
|
67
|
+
return /* @__PURE__ */React__default.createElement("div", {
|
|
68
|
+
className: "a2ui-error-boundary",
|
|
69
|
+
style: {
|
|
70
|
+
padding: "8px 12px",
|
|
71
|
+
backgroundColor: "rgba(255, 77, 79, 0.1)",
|
|
72
|
+
border: "1px solid rgba(255, 77, 79, 0.3)",
|
|
73
|
+
borderRadius: "4px",
|
|
74
|
+
color: "#ff4d4f",
|
|
75
|
+
fontSize: "12px"
|
|
76
|
+
}
|
|
77
|
+
}, /* @__PURE__ */React__default.createElement("div", {
|
|
78
|
+
style: {
|
|
79
|
+
fontWeight: 500,
|
|
80
|
+
marginBottom: "4px"
|
|
81
|
+
}
|
|
82
|
+
}, "\u7EC4\u4EF6\u6E32\u67D3\u9519\u8BEF ", componentType ? "(".concat(componentType, ")") : ""), /* @__PURE__ */React__default.createElement("div", {
|
|
83
|
+
style: {
|
|
84
|
+
color: "#666",
|
|
85
|
+
wordBreak: "break-all"
|
|
86
|
+
}
|
|
87
|
+
}, (error === null || error === void 0 ? void 0 : error.message) || "\u672A\u77E5\u9519\u8BEF"));
|
|
88
|
+
}
|
|
89
|
+
return null;
|
|
90
|
+
}
|
|
91
|
+
return children;
|
|
92
|
+
}
|
|
93
|
+
}], [{
|
|
94
|
+
key: "getDerivedStateFromError",
|
|
95
|
+
value: function getDerivedStateFromError(error) {
|
|
96
|
+
return {
|
|
97
|
+
hasError: true,
|
|
98
|
+
error: error
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
}]);
|
|
102
|
+
}(Component);
|
|
103
|
+
function withA2UIErrorBoundary(WrappedComponent) {
|
|
104
|
+
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
105
|
+
var WithErrorBoundary = function WithErrorBoundary(props) {
|
|
106
|
+
return /* @__PURE__ */React__default.createElement(A2UIErrorBoundary, _objectSpread({}, options), /* @__PURE__ */React__default.createElement(WrappedComponent, _objectSpread({}, props)));
|
|
107
|
+
};
|
|
108
|
+
WithErrorBoundary.displayName = "WithA2UIErrorBoundary(".concat(WrappedComponent.displayName || WrappedComponent.name || "Component", ")");
|
|
109
|
+
return WithErrorBoundary;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
export { A2UIErrorBoundary, A2UIErrorBoundary as default, withA2UIErrorBoundary };
|
|
113
|
+
//# sourceMappingURL=A2UIErrorBoundary.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UIErrorBoundary.js","sources":["../../../../../pro-components/chat/chat-engine/components/a2ui/A2UIErrorBoundary.tsx"],"sourcesContent":["/**\n * A2UI 错误边界组件\n * 捕获组件渲染错误,防止整个 Surface 崩溃\n */\n\nimport React, { Component, ErrorInfo, ReactNode } from 'react';\n\nexport interface A2UIErrorBoundaryProps {\n /** 子组件 */\n children: ReactNode;\n /** 组件类型(用于日志) */\n componentType?: string;\n /** 组件 ID(用于日志) */\n componentId?: string;\n /** 自定义 fallback 渲染 */\n fallback?: ReactNode | ((error: Error, componentType?: string) => ReactNode);\n /** 错误回调 */\n onError?: (error: Error, componentType?: string, componentId?: string) => void;\n /** 是否显示错误 UI(默认 false,静默失败) */\n showError?: boolean;\n}\n\ninterface A2UIErrorBoundaryState {\n hasError: boolean;\n error: Error | null;\n}\n\n/**\n * A2UI 错误边界\n * \n * 设计原则:\n * 1. 默认静默失败,不显示错误 UI(避免影响用户体验)\n * 2. 在控制台输出详细错误信息(便于调试)\n * 3. 支持自定义 fallback 和错误回调(便于业务定制)\n */\nexport class A2UIErrorBoundary extends Component<A2UIErrorBoundaryProps, A2UIErrorBoundaryState> {\n constructor(props: A2UIErrorBoundaryProps) {\n super(props);\n this.state = { hasError: false, error: null };\n }\n\n static getDerivedStateFromError(error: Error): A2UIErrorBoundaryState {\n return { hasError: true, error };\n }\n\n componentDidCatch(error: Error, errorInfo: ErrorInfo): void {\n const { componentType, componentId, onError } = this.props;\n\n // 输出详细错误日志\n console.error(\n `[A2UI] Component render error`,\n {\n componentType,\n componentId,\n error: error.message,\n stack: error.stack,\n componentStack: errorInfo.componentStack,\n }\n );\n\n // 调用错误回调\n onError?.(error, componentType, componentId);\n }\n\n render() {\n const { hasError, error } = this.state;\n const { children, fallback, showError = false, componentType } = this.props;\n\n if (hasError) {\n // 自定义 fallback\n if (fallback) {\n if (typeof fallback === 'function') {\n return <>{fallback(error!, componentType)}</>;\n }\n return <>{fallback}</>;\n }\n\n // 显示错误 UI\n if (showError) {\n return (\n <div\n className=\"a2ui-error-boundary\"\n style={{\n padding: '8px 12px',\n backgroundColor: 'rgba(255, 77, 79, 0.1)',\n border: '1px solid rgba(255, 77, 79, 0.3)',\n borderRadius: '4px',\n color: '#ff4d4f',\n fontSize: '12px',\n }}\n >\n <div style={{ fontWeight: 500, marginBottom: '4px' }}>\n 组件渲染错误 {componentType ? `(${componentType})` : ''}\n </div>\n <div style={{ color: '#666', wordBreak: 'break-all' }}>\n {error?.message || '未知错误'}\n </div>\n </div>\n );\n }\n\n // 默认静默失败,返回 null\n return null;\n }\n\n return children;\n }\n}\n\n/**\n * 高阶组件:为组件添加错误边界\n */\nexport function withA2UIErrorBoundary<P extends object>(\n WrappedComponent: React.ComponentType<P>,\n options: Omit<A2UIErrorBoundaryProps, 'children'> = {}\n): React.FC<P> {\n const WithErrorBoundary: React.FC<P> = (props) => (\n <A2UIErrorBoundary {...options}>\n <WrappedComponent {...props} />\n </A2UIErrorBoundary>\n );\n\n WithErrorBoundary.displayName = `WithA2UIErrorBoundary(${\n WrappedComponent.displayName || WrappedComponent.name || 'Component'\n })`;\n\n return WithErrorBoundary;\n}\n\nexport default A2UIErrorBoundary;\n"],"names":["A2UIErrorBoundary","props","_this","_classCallCheck","_callSuper","state","hasError","error","_inherits","_Component","_createClass","key","value","componentDidCatch","errorInfo","_this$props","componentType","componentId","onError","console","message","stack","componentStack","render","_this$state","_this$props2","children","fallback","_this$props2$showErro","showError","React","createElement","Fragment","className","style","padding","backgroundColor","border","borderRadius","color","fontSize","fontWeight","marginBottom","concat","wordBreak","getDerivedStateFromError","Component","withA2UIErrorBoundary","WrappedComponent","options","arguments","length","undefined","WithErrorBoundary","_objectSpread","displayName","name"],"mappings":"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"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI Skeleton 组件
|
|
3
|
+
* 在组件树渲染前显示骨架屏占位
|
|
4
|
+
*/
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import type { A2UIComponent } from '../../core/a2ui';
|
|
7
|
+
export interface A2UISkeletonProps {
|
|
8
|
+
/** 组件定义(可选,用于推断骨架形状) */
|
|
9
|
+
component?: A2UIComponent | null;
|
|
10
|
+
/** 是否显示动画 */
|
|
11
|
+
animation?: 'gradient' | 'flashed' | 'none';
|
|
12
|
+
/** 自定义类名 */
|
|
13
|
+
className?: string;
|
|
14
|
+
/** 自定义样式 */
|
|
15
|
+
style?: React.CSSProperties;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* A2UI Skeleton 占位组件
|
|
19
|
+
*
|
|
20
|
+
* 用法1: 简单骨架
|
|
21
|
+
* ```tsx
|
|
22
|
+
* <A2UISkeleton />
|
|
23
|
+
* ```
|
|
24
|
+
*
|
|
25
|
+
* 用法2: 根据组件类型显示对应骨架
|
|
26
|
+
* ```tsx
|
|
27
|
+
* <A2UISkeleton component={surface.root} />
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export declare const A2UISkeleton: React.FC<A2UISkeletonProps>;
|
|
31
|
+
/**
|
|
32
|
+
* A2UI Surface 骨架屏
|
|
33
|
+
* 适用于整个 Surface 加载时的占位
|
|
34
|
+
*/
|
|
35
|
+
export interface A2UISurfaceSkeletonProps {
|
|
36
|
+
/** 骨架布局类型 */
|
|
37
|
+
layout?: 'form' | 'card' | 'list' | 'simple' | 'wizard';
|
|
38
|
+
/** 是否显示动画 */
|
|
39
|
+
animation?: 'gradient' | 'flashed' | 'none';
|
|
40
|
+
/** 行数(list 布局时生效) */
|
|
41
|
+
rowCount?: number;
|
|
42
|
+
/** 自定义类名 */
|
|
43
|
+
className?: string;
|
|
44
|
+
/** 自定义样式 */
|
|
45
|
+
style?: React.CSSProperties;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* A2UI Surface 骨架屏
|
|
49
|
+
*
|
|
50
|
+
* 用法:
|
|
51
|
+
* ```tsx
|
|
52
|
+
* <A2UISurfaceRenderer
|
|
53
|
+
* processor={processor}
|
|
54
|
+
* surfaceId="my-surface"
|
|
55
|
+
* loading={<A2UISurfaceSkeleton layout="form" />}
|
|
56
|
+
* />
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
export declare const A2UISurfaceSkeleton: React.FC<A2UISurfaceSkeletonProps>;
|
|
60
|
+
export default A2UISkeleton;
|
|
@@ -0,0 +1,197 @@
|
|
|
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 { Skeleton } from 'tdesign-react';
|
|
9
|
+
|
|
10
|
+
var getRowColByType = function getRowColByType(componentType) {
|
|
11
|
+
switch (componentType) {
|
|
12
|
+
case "Text":
|
|
13
|
+
return [1];
|
|
14
|
+
case "Button":
|
|
15
|
+
return [{
|
|
16
|
+
width: "80px",
|
|
17
|
+
height: "32px"
|
|
18
|
+
}];
|
|
19
|
+
case "Input":
|
|
20
|
+
return [{
|
|
21
|
+
width: "100%",
|
|
22
|
+
height: "32px"
|
|
23
|
+
}];
|
|
24
|
+
case "RadioGroup":
|
|
25
|
+
case "CheckboxGroup":
|
|
26
|
+
return [[{
|
|
27
|
+
type: "rect",
|
|
28
|
+
width: "80px",
|
|
29
|
+
height: "22px"
|
|
30
|
+
}, {
|
|
31
|
+
type: "rect",
|
|
32
|
+
width: "80px",
|
|
33
|
+
height: "22px"
|
|
34
|
+
}, {
|
|
35
|
+
type: "rect",
|
|
36
|
+
width: "80px",
|
|
37
|
+
height: "22px"
|
|
38
|
+
}]];
|
|
39
|
+
case "Row":
|
|
40
|
+
return [[{
|
|
41
|
+
type: "rect",
|
|
42
|
+
width: "100px",
|
|
43
|
+
height: "32px"
|
|
44
|
+
}, {
|
|
45
|
+
type: "rect",
|
|
46
|
+
width: "100px",
|
|
47
|
+
height: "32px"
|
|
48
|
+
}]];
|
|
49
|
+
case "Column":
|
|
50
|
+
return [{
|
|
51
|
+
width: "100%",
|
|
52
|
+
height: "20px"
|
|
53
|
+
}, {
|
|
54
|
+
width: "80%",
|
|
55
|
+
height: "20px"
|
|
56
|
+
}];
|
|
57
|
+
case "Card":
|
|
58
|
+
return [{
|
|
59
|
+
type: "rect",
|
|
60
|
+
height: "30px",
|
|
61
|
+
width: "100%"
|
|
62
|
+
}, {
|
|
63
|
+
type: "rect",
|
|
64
|
+
height: "100px",
|
|
65
|
+
width: "100%"
|
|
66
|
+
}];
|
|
67
|
+
default:
|
|
68
|
+
return [1];
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
var A2UISkeleton = function A2UISkeleton(_ref) {
|
|
72
|
+
var component = _ref.component,
|
|
73
|
+
_ref$animation = _ref.animation,
|
|
74
|
+
animation = _ref$animation === void 0 ? "gradient" : _ref$animation,
|
|
75
|
+
className = _ref.className,
|
|
76
|
+
style = _ref.style;
|
|
77
|
+
var animationProp = animation === "none" ? "none" : animation;
|
|
78
|
+
var rowCol = getRowColByType(component === null || component === void 0 ? void 0 : component.component);
|
|
79
|
+
return /* @__PURE__ */React__default.createElement("div", {
|
|
80
|
+
className: className,
|
|
81
|
+
style: style
|
|
82
|
+
}, /* @__PURE__ */React__default.createElement(Skeleton, {
|
|
83
|
+
animation: animationProp,
|
|
84
|
+
rowCol: rowCol
|
|
85
|
+
}));
|
|
86
|
+
};
|
|
87
|
+
A2UISkeleton.displayName = "A2UISkeleton";
|
|
88
|
+
var getRowColByLayout = function getRowColByLayout(layout, rowCount) {
|
|
89
|
+
switch (layout) {
|
|
90
|
+
case "form":
|
|
91
|
+
return [{
|
|
92
|
+
width: "200px",
|
|
93
|
+
height: "28px"
|
|
94
|
+
}, {
|
|
95
|
+
width: "80px",
|
|
96
|
+
height: "16px"
|
|
97
|
+
}, {
|
|
98
|
+
width: "100%",
|
|
99
|
+
height: "32px"
|
|
100
|
+
}, {
|
|
101
|
+
width: "80px",
|
|
102
|
+
height: "16px"
|
|
103
|
+
}, {
|
|
104
|
+
width: "100%",
|
|
105
|
+
height: "32px"
|
|
106
|
+
}, [{
|
|
107
|
+
type: "rect",
|
|
108
|
+
width: "80px",
|
|
109
|
+
height: "32px"
|
|
110
|
+
}, {
|
|
111
|
+
type: "rect",
|
|
112
|
+
width: "80px",
|
|
113
|
+
height: "32px"
|
|
114
|
+
}]];
|
|
115
|
+
case "card":
|
|
116
|
+
return [{
|
|
117
|
+
type: "rect",
|
|
118
|
+
height: "30px",
|
|
119
|
+
width: "100%"
|
|
120
|
+
}, {
|
|
121
|
+
type: "rect",
|
|
122
|
+
height: "200px",
|
|
123
|
+
width: "100%"
|
|
124
|
+
}];
|
|
125
|
+
case "list":
|
|
126
|
+
return Array.from({
|
|
127
|
+
length: rowCount
|
|
128
|
+
}, function (_, i) {
|
|
129
|
+
return {
|
|
130
|
+
width: "".concat(100 - i * 10, "%"),
|
|
131
|
+
height: "20px"
|
|
132
|
+
};
|
|
133
|
+
});
|
|
134
|
+
case "wizard":
|
|
135
|
+
return [[{
|
|
136
|
+
type: "circle",
|
|
137
|
+
size: "32px"
|
|
138
|
+
}, {
|
|
139
|
+
type: "rect",
|
|
140
|
+
width: "60px",
|
|
141
|
+
height: "4px"
|
|
142
|
+
}, {
|
|
143
|
+
type: "circle",
|
|
144
|
+
size: "32px"
|
|
145
|
+
}, {
|
|
146
|
+
type: "rect",
|
|
147
|
+
width: "60px",
|
|
148
|
+
height: "4px"
|
|
149
|
+
}, {
|
|
150
|
+
type: "circle",
|
|
151
|
+
size: "32px"
|
|
152
|
+
}], {
|
|
153
|
+
width: "180px",
|
|
154
|
+
height: "24px"
|
|
155
|
+
}, {
|
|
156
|
+
width: "100%",
|
|
157
|
+
height: "40px"
|
|
158
|
+
}, {
|
|
159
|
+
width: "100%",
|
|
160
|
+
height: "40px"
|
|
161
|
+
}, [{
|
|
162
|
+
type: "rect",
|
|
163
|
+
width: "80px",
|
|
164
|
+
height: "32px"
|
|
165
|
+
}, {
|
|
166
|
+
type: "rect",
|
|
167
|
+
width: "80px",
|
|
168
|
+
height: "32px"
|
|
169
|
+
}]];
|
|
170
|
+
case "simple":
|
|
171
|
+
default:
|
|
172
|
+
return [1];
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
var A2UISurfaceSkeleton = function A2UISurfaceSkeleton(_ref2) {
|
|
176
|
+
var _ref2$layout = _ref2.layout,
|
|
177
|
+
layout = _ref2$layout === void 0 ? "simple" : _ref2$layout,
|
|
178
|
+
_ref2$animation = _ref2.animation,
|
|
179
|
+
animation = _ref2$animation === void 0 ? "gradient" : _ref2$animation,
|
|
180
|
+
_ref2$rowCount = _ref2.rowCount,
|
|
181
|
+
rowCount = _ref2$rowCount === void 0 ? 3 : _ref2$rowCount,
|
|
182
|
+
className = _ref2.className,
|
|
183
|
+
style = _ref2.style;
|
|
184
|
+
var animationProp = animation === "none" ? "none" : animation;
|
|
185
|
+
var rowCol = getRowColByLayout(layout, rowCount);
|
|
186
|
+
return /* @__PURE__ */React__default.createElement("div", {
|
|
187
|
+
className: className,
|
|
188
|
+
style: style
|
|
189
|
+
}, /* @__PURE__ */React__default.createElement(Skeleton, {
|
|
190
|
+
animation: animationProp,
|
|
191
|
+
rowCol: rowCol
|
|
192
|
+
}));
|
|
193
|
+
};
|
|
194
|
+
A2UISurfaceSkeleton.displayName = "A2UISurfaceSkeleton";
|
|
195
|
+
|
|
196
|
+
export { A2UISkeleton, A2UISurfaceSkeleton, A2UISkeleton as default };
|
|
197
|
+
//# sourceMappingURL=A2UISkeleton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A2UISkeleton.js","sources":["../../../../../pro-components/chat/chat-engine/components/a2ui/A2UISkeleton.tsx"],"sourcesContent":["/**\n * A2UI Skeleton 组件\n * 在组件树渲染前显示骨架屏占位\n */\n\nimport React from 'react';\nimport { Skeleton } from 'tdesign-react';\nimport type { A2UIComponent } from '../../core/a2ui';\n\nexport interface A2UISkeletonProps {\n /** 组件定义(可选,用于推断骨架形状) */\n component?: A2UIComponent | null;\n /** 是否显示动画 */\n animation?: 'gradient' | 'flashed' | 'none';\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n}\n\n/**\n * 根据组件类型生成对应的 Skeleton rowCol\n */\nconst getRowColByType = (componentType?: string): Array<number | object | object[]> => {\n switch (componentType) {\n case 'Text':\n return [1];\n\n case 'Button':\n return [{ width: '80px', height: '32px' }];\n\n case 'Input':\n return [{ width: '100%', height: '32px' }];\n\n case 'RadioGroup':\n case 'CheckboxGroup':\n return [[\n { type: 'rect' as const, width: '80px', height: '22px' },\n { type: 'rect' as const, width: '80px', height: '22px' },\n { type: 'rect' as const, width: '80px', height: '22px' },\n ]];\n\n case 'Row':\n return [[\n { type: 'rect' as const, width: '100px', height: '32px' },\n { type: 'rect' as const, width: '100px', height: '32px' },\n ]];\n\n case 'Column':\n return [\n { width: '100%', height: '20px' },\n { width: '80%', height: '20px' },\n ];\n\n case 'Card':\n return [\n { type: 'rect' as const, height: '30px', width: '100%' },\n { type: 'rect' as const, height: '100px', width: '100%' },\n ];\n\n default:\n return [1];\n }\n};\n\n/**\n * A2UI Skeleton 占位组件\n * \n * 用法1: 简单骨架\n * ```tsx\n * <A2UISkeleton />\n * ```\n * \n * 用法2: 根据组件类型显示对应骨架\n * ```tsx\n * <A2UISkeleton component={surface.root} />\n * ```\n */\nexport const A2UISkeleton: React.FC<A2UISkeletonProps> = ({\n component,\n animation = 'gradient',\n className,\n style,\n}) => {\n const animationProp = animation === 'none' ? 'none' : animation;\n const rowCol = getRowColByType(component?.component);\n\n return (\n <div className={className} style={style}>\n <Skeleton animation={animationProp} rowCol={rowCol} />\n </div>\n );\n};\n\nA2UISkeleton.displayName = 'A2UISkeleton';\n\n/**\n * A2UI Surface 骨架屏\n * 适用于整个 Surface 加载时的占位\n */\nexport interface A2UISurfaceSkeletonProps {\n /** 骨架布局类型 */\n layout?: 'form' | 'card' | 'list' | 'simple' | 'wizard';\n /** 是否显示动画 */\n animation?: 'gradient' | 'flashed' | 'none';\n /** 行数(list 布局时生效) */\n rowCount?: number;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n}\n\n/**\n * 根据布局类型获取 rowCol 配置\n */\nconst getRowColByLayout = (\n layout: string,\n rowCount: number\n): Array<number | object | object[]> => {\n switch (layout) {\n case 'form':\n return [\n // 标题\n { width: '200px', height: '28px' },\n // 表单项 1\n { width: '80px', height: '16px' },\n { width: '100%', height: '32px' },\n // 表单项 2\n { width: '80px', height: '16px' },\n { width: '100%', height: '32px' },\n // 按钮\n [\n { type: 'rect' as const, width: '80px', height: '32px' },\n { type: 'rect' as const, width: '80px', height: '32px' },\n ],\n ];\n\n case 'card':\n return [\n { type: 'rect' as const, height: '30px', width: '100%' },\n { type: 'rect' as const, height: '200px', width: '100%' },\n ];\n\n case 'list':\n return Array.from({ length: rowCount }, (_, i) => ({\n width: `${100 - i * 10}%`,\n height: '20px',\n }));\n\n case 'wizard':\n return [\n // 步骤指示器\n [\n { type: 'circle' as const, size: '32px' },\n { type: 'rect' as const, width: '60px', height: '4px' },\n { type: 'circle' as const, size: '32px' },\n { type: 'rect' as const, width: '60px', height: '4px' },\n { type: 'circle' as const, size: '32px' },\n ],\n // 标题\n { width: '180px', height: '24px' },\n // 内容\n { width: '100%', height: '40px' },\n { width: '100%', height: '40px' },\n // 按钮\n [\n { type: 'rect' as const, width: '80px', height: '32px' },\n { type: 'rect' as const, width: '80px', height: '32px' },\n ],\n ];\n\n case 'simple':\n default:\n return [1];\n }\n};\n\n/**\n * A2UI Surface 骨架屏\n * \n * 用法:\n * ```tsx\n * <A2UISurfaceRenderer\n * processor={processor}\n * surfaceId=\"my-surface\"\n * loading={<A2UISurfaceSkeleton layout=\"form\" />}\n * />\n * ```\n */\nexport const A2UISurfaceSkeleton: React.FC<A2UISurfaceSkeletonProps> = ({\n layout = 'simple',\n animation = 'gradient',\n rowCount = 3,\n className,\n style,\n}) => {\n const animationProp = animation === 'none' ? 'none' : animation;\n const rowCol = getRowColByLayout(layout, rowCount);\n\n return (\n <div className={className} style={style}>\n <Skeleton animation={animationProp} rowCol={rowCol} />\n </div>\n );\n};\n\nA2UISurfaceSkeleton.displayName = 'A2UISurfaceSkeleton';\n\nexport default A2UISkeleton;\n"],"names":["getRowColByType","componentType","width","height","type","A2UISkeleton","component","_ref","_ref$animation","animation","className","style","animationProp","rowCol","React","createElement","Skeleton","displayName","getRowColByLayout","layout","rowCount","Array","from","length","_","i","concat","size","A2UISurfaceSkeleton","_ref2$layout","_ref2","_ref2$animation","_ref2$rowCount"],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A2UI Surface 渲染器
|
|
3
|
+
* 渲染单个 Surface 的入口组件
|
|
4
|
+
*/
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import { type ComponentRegistry } from '../../hooks/a2ui/A2UIContext';
|
|
7
|
+
import type { A2uiMessageProcessor } from '../../core/a2ui';
|
|
8
|
+
import type { ActionHandler } from '../../core/a2ui';
|
|
9
|
+
export interface A2UISurfaceRendererProps {
|
|
10
|
+
/** A2UI 消息处理器 */
|
|
11
|
+
processor: A2uiMessageProcessor;
|
|
12
|
+
/** Surface ID */
|
|
13
|
+
surfaceId: string;
|
|
14
|
+
/** 自定义组件注册表(可选,不传使用默认注册表) */
|
|
15
|
+
registry?: ComponentRegistry;
|
|
16
|
+
/** Action 处理回调 */
|
|
17
|
+
onAction?: ActionHandler;
|
|
18
|
+
/** 自定义类名 */
|
|
19
|
+
className?: string;
|
|
20
|
+
/** 自定义样式 */
|
|
21
|
+
style?: React.CSSProperties;
|
|
22
|
+
/**
|
|
23
|
+
* 加载中占位
|
|
24
|
+
* - 传入 ReactNode:使用自定义骨架屏
|
|
25
|
+
* - 传入 true:使用服务端 skeletonHint 或默认骨架屏
|
|
26
|
+
*/
|
|
27
|
+
loading?: React.ReactNode | boolean;
|
|
28
|
+
/** Surface 不存在时的占位 */
|
|
29
|
+
fallback?: React.ReactNode;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* A2UI Surface 渲染器
|
|
33
|
+
*
|
|
34
|
+
* 使用方式:
|
|
35
|
+
* ```tsx
|
|
36
|
+
* <A2UISurfaceRenderer
|
|
37
|
+
* processor={processor}
|
|
38
|
+
* surfaceId="confirm-form"
|
|
39
|
+
* onAction={handleAction}
|
|
40
|
+
* />
|
|
41
|
+
* ```
|
|
42
|
+
*/
|
|
43
|
+
export declare const A2UISurfaceRenderer: React.FC<A2UISurfaceRendererProps>;
|
|
44
|
+
export default A2UISurfaceRenderer;
|
|
@@ -0,0 +1,139 @@
|
|
|
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, 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;
|