@ai-group/chat-sdk 3.0.9 → 3.0.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (78) hide show
  1. package/dist/cjs/components/FileGallery/index.js +7 -5
  2. package/dist/cjs/components/FileGallery/index.js.map +2 -2
  3. package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/index.d.ts +3 -0
  4. package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/index.js +74 -2
  5. package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/index.js.map +3 -3
  6. package/dist/cjs/components/XAdkChatbot/index.js +10 -7
  7. package/dist/cjs/components/XAdkChatbot/index.js.map +2 -2
  8. package/dist/cjs/types/FileGallery.d.ts +2 -0
  9. package/dist/cjs/types/FileGallery.js.map +1 -1
  10. package/dist/cjs/types/XAdkChatbot.d.ts +3 -0
  11. package/dist/cjs/types/XAdkChatbot.js.map +1 -1
  12. package/dist/esm/components/FileGallery/index.js +12 -5
  13. package/dist/esm/components/FileGallery/index.js.map +1 -1
  14. package/dist/esm/components/XAdkChatbot/components/MarkdownRender/index.d.ts +3 -0
  15. package/dist/esm/components/XAdkChatbot/components/MarkdownRender/index.js +81 -2
  16. package/dist/esm/components/XAdkChatbot/components/MarkdownRender/index.js.map +1 -1
  17. package/dist/esm/components/XAdkChatbot/index.js +14 -8
  18. package/dist/esm/components/XAdkChatbot/index.js.map +1 -1
  19. package/dist/esm/types/FileGallery.d.ts +2 -0
  20. package/dist/esm/types/FileGallery.js.map +1 -1
  21. package/dist/esm/types/XAdkChatbot.d.ts +3 -0
  22. package/dist/esm/types/XAdkChatbot.js.map +1 -1
  23. package/dist/umd/chat-sdk.min.js +1 -1
  24. package/package.json +2 -3
  25. package/dist/cjs/components/FileGallery/FileGallery.stories.d.ts +0 -6
  26. package/dist/cjs/components/FileGallery/FileGallery.stories.js +0 -143
  27. package/dist/cjs/components/FileGallery/FileGallery.stories.js.map +0 -7
  28. package/dist/cjs/components/XAdkChatbot/XAdkChatbot.stories.d.ts +0 -13
  29. package/dist/cjs/components/XAdkChatbot/XAdkChatbot.stories.js +0 -633
  30. package/dist/cjs/components/XAdkChatbot/XAdkChatbot.stories.js.map +0 -7
  31. package/dist/cjs/components/XAdkProvider/XAdkProvider.stories.d.ts +0 -10
  32. package/dist/cjs/components/XAdkProvider/XAdkProvider.stories.js +0 -394
  33. package/dist/cjs/components/XAdkProvider/XAdkProvider.stories.js.map +0 -7
  34. package/dist/cjs/components/XAdkSender/XAdkSender.stories.d.ts +0 -6
  35. package/dist/cjs/components/XAdkSender/XAdkSender.stories.js +0 -121
  36. package/dist/cjs/components/XAdkSender/XAdkSender.stories.js.map +0 -7
  37. package/dist/cjs/components/XAiChatbot/XAiChatbot.stories.d.ts +0 -10
  38. package/dist/cjs/components/XAiChatbot/XAiChatbot.stories.js +0 -773
  39. package/dist/cjs/components/XAiChatbot/XAiChatbot.stories.js.map +0 -7
  40. package/dist/cjs/components/XAiConversations/XAiConversations.stories.d.ts +0 -6
  41. package/dist/cjs/components/XAiConversations/XAiConversations.stories.js +0 -83
  42. package/dist/cjs/components/XAiConversations/XAiConversations.stories.js.map +0 -7
  43. package/dist/cjs/components/XAiProvider/XAiProvider.stories.d.ts +0 -8
  44. package/dist/cjs/components/XAiProvider/XAiProvider.stories.js +0 -206
  45. package/dist/cjs/components/XAiProvider/XAiProvider.stories.js.map +0 -7
  46. package/dist/cjs/components/XAiSender/XAiSender.stories.d.ts +0 -6
  47. package/dist/cjs/components/XAiSender/XAiSender.stories.js +0 -102
  48. package/dist/cjs/components/XAiSender/XAiSender.stories.js.map +0 -7
  49. package/dist/cjs/components/XAiThoughtChain/XAiThoughtChain.stories.d.ts +0 -6
  50. package/dist/cjs/components/XAiThoughtChain/XAiThoughtChain.stories.js +0 -180
  51. package/dist/cjs/components/XAiThoughtChain/XAiThoughtChain.stories.js.map +0 -7
  52. package/dist/esm/components/FileGallery/FileGallery.stories.d.ts +0 -6
  53. package/dist/esm/components/FileGallery/FileGallery.stories.js +0 -48
  54. package/dist/esm/components/FileGallery/FileGallery.stories.js.map +0 -1
  55. package/dist/esm/components/XAdkChatbot/XAdkChatbot.stories.d.ts +0 -13
  56. package/dist/esm/components/XAdkChatbot/XAdkChatbot.stories.js +0 -510
  57. package/dist/esm/components/XAdkChatbot/XAdkChatbot.stories.js.map +0 -1
  58. package/dist/esm/components/XAdkProvider/XAdkProvider.stories.d.ts +0 -10
  59. package/dist/esm/components/XAdkProvider/XAdkProvider.stories.js +0 -338
  60. package/dist/esm/components/XAdkProvider/XAdkProvider.stories.js.map +0 -1
  61. package/dist/esm/components/XAdkSender/XAdkSender.stories.d.ts +0 -6
  62. package/dist/esm/components/XAdkSender/XAdkSender.stories.js +0 -128
  63. package/dist/esm/components/XAdkSender/XAdkSender.stories.js.map +0 -1
  64. package/dist/esm/components/XAiChatbot/XAiChatbot.stories.d.ts +0 -10
  65. package/dist/esm/components/XAiChatbot/XAiChatbot.stories.js +0 -636
  66. package/dist/esm/components/XAiChatbot/XAiChatbot.stories.js.map +0 -1
  67. package/dist/esm/components/XAiConversations/XAiConversations.stories.d.ts +0 -6
  68. package/dist/esm/components/XAiConversations/XAiConversations.stories.js +0 -42
  69. package/dist/esm/components/XAiConversations/XAiConversations.stories.js.map +0 -1
  70. package/dist/esm/components/XAiProvider/XAiProvider.stories.d.ts +0 -8
  71. package/dist/esm/components/XAiProvider/XAiProvider.stories.js +0 -208
  72. package/dist/esm/components/XAiProvider/XAiProvider.stories.js.map +0 -1
  73. package/dist/esm/components/XAiSender/XAiSender.stories.d.ts +0 -6
  74. package/dist/esm/components/XAiSender/XAiSender.stories.js +0 -87
  75. package/dist/esm/components/XAiSender/XAiSender.stories.js.map +0 -1
  76. package/dist/esm/components/XAiThoughtChain/XAiThoughtChain.stories.d.ts +0 -6
  77. package/dist/esm/components/XAiThoughtChain/XAiThoughtChain.stories.js +0 -159
  78. package/dist/esm/components/XAiThoughtChain/XAiThoughtChain.stories.js.map +0 -1
@@ -1,510 +0,0 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
- import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
3
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
4
- import React, { useEffect, useState } from "react";
5
- import { Button, Space } from "antd";
6
- import XAdkChatbot from "./index";
7
- import { jsx as _jsx } from "react/jsx-runtime";
8
- import { jsxs as _jsxs } from "react/jsx-runtime";
9
- var meta = {
10
- title: "AI组件/XAdkChatbot 聊天消息组件",
11
- component: XAdkChatbot,
12
- parameters: {
13
- layout: "padded",
14
- docs: {
15
- description: {
16
- component: "\n\n\u72EC\u7ACB\u7684\u804A\u5929\u6D88\u606F\u663E\u793A\u7EC4\u4EF6,\u7528\u4E8E\u6E32\u67D3\u6D88\u606F\u5217\u8868\u548C\u5EFA\u8BAE\u95EE\u9898\u3002\n\n## \u6838\u5FC3\u529F\u80FD\n\n- \uD83D\uDCDD **\u6D88\u606F\u6E32\u67D3**: \u652F\u6301\u6587\u672C\u3001Markdown\u3001\u4EE3\u7801\u5757\u3001\u51FD\u6570\u8C03\u7528\u7B49\n- \uD83D\uDCAD **\u601D\u7EF4\u94FE**: \u652F\u6301\u663E\u793A AI \u63A8\u7406\u8FC7\u7A0B\n- \uD83C\uDFAF **\u5EFA\u8BAE\u95EE\u9898**: \u663E\u793A\u548C\u70B9\u51FB\u5EFA\u8BAE\u95EE\u9898\n- \uD83D\uDCCC **\u5F00\u573A\u767D**: \u652F\u6301\u663E\u793A\u6B22\u8FCE\u6D88\u606F\n- \uD83D\uDD04 **\u52A0\u8F7D\u72B6\u6001**: \u5B9E\u65F6\u663E\u793A AI \u751F\u6210\u72B6\u6001\n- \uD83C\uDFA8 **\u81EA\u5B9A\u4E49\u6E32\u67D3**: \u652F\u6301\u81EA\u5B9A\u4E49\u6D88\u606F\u5E95\u90E8\u5185\u5BB9\n\n## Props\n\n| \u5C5E\u6027 | \u7C7B\u578B | \u9ED8\u8BA4\u503C | \u8BF4\u660E |\n|------|------|--------|------|\n| messages | IMessage[] | [] | \u6D88\u606F\u5217\u8868 |\n| loading | boolean | false | \u662F\u5426\u6B63\u5728\u52A0\u8F7D |\n| prologue | string | - | \u5F00\u573A\u767D |\n| suggestions | string[] | [] | \u5EFA\u8BAE\u95EE\u9898 |\n| showFnCallDetail | boolean | false | \u663E\u793A\u51FD\u6570\u8C03\u7528\u8BE6\u60C5 |\n| footer | (msg) => ReactNode | - | \u81EA\u5B9A\u4E49\u6D88\u606F\u5E95\u90E8 |\n| onSubmit | (content) => void | - | \u53D1\u9001\u6D88\u606F\u56DE\u8C03 |\n| onStop | () => void | - | \u505C\u6B62\u751F\u6210\u56DE\u8C03 |\n| onClear | () => void | - | \u6E05\u7A7A\u6D88\u606F\u56DE\u8C03 |\n| onSuggest | (text) => void | - | \u70B9\u51FB\u5EFA\u8BAE\u56DE\u8C03 |\n| onConfirm | (fnCall, confirmed) => void | - | \u786E\u8BA4\u51FD\u6570\u8C03\u7528 |\n "
17
- }
18
- }
19
- },
20
- tags: ["autodocs"],
21
- argTypes: {
22
- loading: {
23
- description: "是否正在加载(AI 生成中)",
24
- control: "boolean"
25
- },
26
- showFnCallDetail: {
27
- description: "是否显示函数调用详情",
28
- control: "boolean"
29
- }
30
- }
31
- };
32
- export default meta;
33
- // Mock 消息数据
34
- var mockMessages = [{
35
- id: "1",
36
- role: "user",
37
- text: "你好"
38
- }, {
39
- id: "2",
40
- role: "bot",
41
- text: "你好!我是 AI 助手,很高兴为你服务。有什么我可以帮助你的吗?",
42
- invocationId: "inv-1"
43
- }, {
44
- id: "3",
45
- role: "user",
46
- text: "介绍一下 React Hooks"
47
- }, {
48
- id: "4",
49
- role: "bot",
50
- text: "React Hooks \u662F React 16.8 \u5F15\u5165\u7684\u65B0\u7279\u6027,\u5B83\u8BA9\u4F60\u5728\u4E0D\u7F16\u5199 class \u7684\u60C5\u51B5\u4E0B\u4F7F\u7528 state \u548C\u5176\u4ED6 React \u7279\u6027\u3002\n\n## \u5E38\u7528\u7684 Hooks\n\n### 1. useState\n\u7528\u4E8E\u5728\u51FD\u6570\u7EC4\u4EF6\u4E2D\u6DFB\u52A0\u72B6\u6001:\n\n```jsx\nconst [count, setCount] = useState(0);\n```\n\n### 2. useEffect\n\u7528\u4E8E\u5904\u7406\u526F\u4F5C\u7528:\n\n```jsx\nuseEffect(() => {\n document.title = `Count: ${count}`;\n}, [count]);\n```\n\n### 3. useContext\n\u7528\u4E8E\u8BBF\u95EE Context:\n\n```jsx\nconst theme = useContext(ThemeContext);\n```\n\n## \u4F18\u52BF\n\n- \u2705 \u4EE3\u7801\u66F4\u7B80\u6D01\n- \u2705 \u903B\u8F91\u590D\u7528\u66F4\u5BB9\u6613\n- \u2705 \u907F\u514D this \u76F8\u5173\u95EE\u9898\n- \u2705 \u66F4\u597D\u7684\u4EE3\u7801\u7EC4\u7EC7",
51
- invocationId: "inv-2"
52
- }, {
53
- id: "5",
54
- role: "user",
55
- text: "来一段富文本"
56
- }, {
57
- id: "6",
58
- role: "bot",
59
- text: "# 我是标题\n\n我是正文\n\n**我是加粗**\n\n*我是斜体*\n\n<u>我是下划线</u>\n\n- 我是无序列表\n \n- 1\n \n- 2\n \n\n1. 我是有序列表\n \n2. 1\n \n3. 2\n \n\n> 我是引用\n\n[我是链接](https://www.baidu.com)\n\n```\n我是代码库\n```"
60
- }];
61
-
62
- // ============================================
63
- // 示例 1: 基础用法
64
- // ============================================
65
- export var 基础用法 = {
66
- render: function render() {
67
- var _useState = useState(mockMessages),
68
- _useState2 = _slicedToArray(_useState, 2),
69
- messages = _useState2[0],
70
- setMessages = _useState2[1];
71
- var _useState3 = useState(false),
72
- _useState4 = _slicedToArray(_useState3, 2),
73
- loading = _useState4[0],
74
- setLoading = _useState4[1];
75
- useEffect(function () {
76
- var userMsg = {
77
- id: Date.now().toString(),
78
- role: "user",
79
- text: "你好",
80
- fileData: [{
81
- displayName: "06f26c566fe4a3b5eaad678d0d270c97_origin.jpg",
82
- fileUri: "https://ai-platform-test.oss-cn-hangzhou.aliyuncs.com/ZABX/vidfnxlkpzxoa.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20260317T083458Z&X-Amz-SignedHeaders=host&X-Amz-Credential=LTAI5tSfMvkvWhU43Ev1cFJo%2F20260317%2Foss-cn-hangzhou%2Fs3%2Faws4_request&X-Amz-Expires=518400&X-Amz-Signature=14439e184614d76f1ca19437f76496a6d24a8aa537a29ebf61fb2af9d3f9b285",
83
- mimeType: "image/jpeg"
84
- }, {
85
- displayName: "06f26c566fe4a3b5eaad678d0d270c98_origin.jpg",
86
- fileUri: "https://ai-platform-test.oss-cn-hangzhou.aliyuncs.com/ZABX/vidfnxlkpzxoa.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20260317T083458Z&X-Amz-SignedHeaders=host&X-Amz-Credential=LTAI5tSfMvkvWhU43Ev1cFJo%2F20260317%2Foss-cn-hangzhou%2Fs3%2Faws4_request&X-Amz-Expires=518400&X-Amz-Signature=14439e184614d76f1ca19437f76496a6d24a8aa537a29ebf61fb2af9d3f9b285",
87
- mimeType: "image/jpeg"
88
- }]
89
- };
90
- setMessages(function (prev) {
91
- return [].concat(_toConsumableArray(prev), [userMsg]);
92
- });
93
- setLoading(true);
94
- setTimeout(function () {
95
- var botMsg = {
96
- id: (Date.now() + 1).toString(),
97
- role: "bot",
98
- text: "\u8FD9\u662F\u5BF9 \"\u7528\u6237\" \u7684\u6A21\u62DF\u56DE\u590D\u3002",
99
- invocationId: "inv-".concat(Date.now())
100
- };
101
- setMessages(function (prev) {
102
- return [].concat(_toConsumableArray(prev), [botMsg]);
103
- });
104
- setLoading(false);
105
- }, 1000);
106
- }, []);
107
- return /*#__PURE__*/_jsx("div", {
108
- style: {
109
- width: 700,
110
- height: "600px",
111
- padding: "20px",
112
- border: "1px solid #f0f0f0",
113
- borderRadius: "8px",
114
- overflow: "hidden"
115
- },
116
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
117
- messages: messages,
118
- loading: loading,
119
- initialized: true,
120
- style: {
121
- width: "670px"
122
- }
123
- })
124
- });
125
- }
126
- };
127
-
128
- // ============================================
129
- // 示例 2: 开场白和建议问题
130
- // ============================================
131
- export var 开场白和建议 = {
132
- render: function render() {
133
- var _useState5 = useState([]),
134
- _useState6 = _slicedToArray(_useState5, 2),
135
- messages = _useState6[0],
136
- setMessages = _useState6[1];
137
- var _useState7 = useState(["什么是 React Hooks?", "如何使用 useState?", "useEffect 的作用是什么?"]),
138
- _useState8 = _slicedToArray(_useState7, 2),
139
- suggestions = _useState8[0],
140
- setSuggestions = _useState8[1];
141
- var prologue = "你好!我是 AI 助手,专注于 React 开发相关的问题。";
142
- var handleSuggest = function handleSuggest(text) {
143
- var userMsg = {
144
- id: Date.now().toString(),
145
- role: "user",
146
- text: text
147
- };
148
- setMessages([userMsg]);
149
- setSuggestions([]);
150
- setTimeout(function () {
151
- var botMsg = {
152
- id: (Date.now() + 1).toString(),
153
- role: "bot",
154
- text: "\u8FD9\u662F\u5BF9 \"".concat(text, "\" \u7684\u56DE\u7B54..."),
155
- invocationId: "inv-".concat(Date.now())
156
- };
157
- setMessages(function (prev) {
158
- return [].concat(_toConsumableArray(prev), [botMsg]);
159
- });
160
- }, 1000);
161
- };
162
- return /*#__PURE__*/_jsx("div", {
163
- style: {
164
- width: 700,
165
- height: "600px",
166
- border: "1px solid #f0f0f0",
167
- borderRadius: "8px",
168
- overflow: "hidden"
169
- },
170
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
171
- messages: messages,
172
- loading: false,
173
- initialized: true,
174
- prologue: prologue,
175
- suggestions: suggestions,
176
- onSuggest: handleSuggest
177
- })
178
- });
179
- }
180
- };
181
-
182
- // ============================================
183
- // 示例 3: 流式输出
184
- // ============================================
185
- export var 流式输出 = {
186
- render: function render() {
187
- var _useState9 = useState([{
188
- id: "1",
189
- role: "user",
190
- text: "给我讲一个故事"
191
- }]),
192
- _useState10 = _slicedToArray(_useState9, 2),
193
- messages = _useState10[0],
194
- setMessages = _useState10[1];
195
- var _useState11 = useState(false),
196
- _useState12 = _slicedToArray(_useState11, 2),
197
- loading = _useState12[0],
198
- setLoading = _useState12[1];
199
- var handleStart = function handleStart() {
200
- setLoading(true);
201
- var fullText = "从前有座山,山里有座庙,庙里有个老和尚在给小和尚讲故事。讲什么呢?从前有座山,山里有座庙...";
202
- var currentText = "";
203
- var index = 0;
204
- var botMsg = {
205
- id: "2",
206
- role: "bot",
207
- text: "",
208
- invocationId: "inv-1"
209
- };
210
- setMessages(function (prev) {
211
- return [].concat(_toConsumableArray(prev), [botMsg]);
212
- });
213
- var interval = setInterval(function () {
214
- if (index < fullText.length) {
215
- currentText += fullText[index];
216
- setMessages(function (prev) {
217
- var newMessages = _toConsumableArray(prev);
218
- newMessages[newMessages.length - 1] = _objectSpread(_objectSpread({}, botMsg), {}, {
219
- text: currentText
220
- });
221
- return newMessages;
222
- });
223
- index++;
224
- } else {
225
- clearInterval(interval);
226
- setLoading(false);
227
- }
228
- }, 50);
229
- };
230
- return /*#__PURE__*/_jsxs("div", {
231
- style: {
232
- width: 700
233
- },
234
- children: [/*#__PURE__*/_jsx("div", {
235
- style: {
236
- marginBottom: "16px"
237
- },
238
- children: /*#__PURE__*/_jsx(Button, {
239
- type: "primary",
240
- onClick: handleStart,
241
- disabled: loading,
242
- children: "\u5F00\u59CB\u6D41\u5F0F\u8F93\u51FA\u6F14\u793A"
243
- })
244
- }), /*#__PURE__*/_jsx("div", {
245
- style: {
246
- height: "550px",
247
- border: "1px solid #f0f0f0",
248
- borderRadius: "8px",
249
- overflow: "hidden"
250
- },
251
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
252
- messages: messages,
253
- loading: loading,
254
- initialized: true,
255
- onStop: function onStop() {
256
- return setLoading(false);
257
- }
258
- })
259
- })]
260
- });
261
- }
262
- };
263
-
264
- // ============================================
265
- // 示例 4: 自定义消息 Footer
266
- // ============================================
267
- export var 自定义Footer = {
268
- render: function render() {
269
- var _useState13 = useState(mockMessages),
270
- _useState14 = _slicedToArray(_useState13, 1),
271
- messages = _useState14[0];
272
- var _useState15 = useState(new Set()),
273
- _useState16 = _slicedToArray(_useState15, 2),
274
- likedMessages = _useState16[0],
275
- setLikedMessages = _useState16[1];
276
- var handleLike = function handleLike(messageId) {
277
- setLikedMessages(function (prev) {
278
- var newSet = new Set(prev);
279
- if (newSet.has(messageId)) {
280
- newSet.delete(messageId);
281
- } else {
282
- newSet.add(messageId);
283
- }
284
- return newSet;
285
- });
286
- };
287
- var customFooter = function customFooter(data) {
288
- var message = data.message,
289
- isLastBotMsg = data.isLastBotMsg;
290
- if (!isLastBotMsg) return null;
291
- var isLiked = likedMessages.has(message.id);
292
- return /*#__PURE__*/_jsx("div", {
293
- style: {
294
- padding: "8px 0"
295
- },
296
- children: /*#__PURE__*/_jsxs(Space, {
297
- size: "small",
298
- children: [/*#__PURE__*/_jsx(Button, {
299
- size: "small",
300
- type: isLiked ? "primary" : "text",
301
- onClick: function onClick() {
302
- return handleLike(message.id);
303
- },
304
- children: isLiked ? "👍 已赞" : "👍 赞"
305
- }), /*#__PURE__*/_jsx(Button, {
306
- size: "small",
307
- type: "text",
308
- children: "\uD83D\uDC4E \u8E29"
309
- }), /*#__PURE__*/_jsx(Button, {
310
- size: "small",
311
- type: "text",
312
- children: "\uD83D\uDCCB \u590D\u5236"
313
- }), /*#__PURE__*/_jsx(Button, {
314
- size: "small",
315
- type: "text",
316
- children: "\uD83D\uDD04 \u91CD\u65B0\u751F\u6210"
317
- })]
318
- })
319
- });
320
- };
321
- return /*#__PURE__*/_jsx("div", {
322
- style: {
323
- width: 700,
324
- height: "600px",
325
- border: "1px solid #f0f0f0",
326
- borderRadius: "8px",
327
- overflow: "hidden"
328
- },
329
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
330
- messages: messages,
331
- loading: false,
332
- initialized: true,
333
- actions: customFooter
334
- })
335
- });
336
- }
337
- };
338
-
339
- // ============================================
340
- // 示例 5: 函数调用
341
- // ============================================
342
- export var 函数调用 = {
343
- render: function render() {
344
- var messagesWithFunctionCall = [{
345
- id: "1",
346
- role: "user",
347
- text: "今天北京的天气怎么样?"
348
- }, {
349
- id: "2",
350
- role: "bot",
351
- functionCall: {
352
- id: "call-1",
353
- name: "get_weather",
354
- args: {
355
- city: "北京",
356
- date: "2024-03-05"
357
- }
358
- },
359
- invocationId: "inv-1"
360
- }, {
361
- id: "3",
362
- role: "bot",
363
- text: "根据天气查询,今天北京的天气是晴天,温度 15-25°C,空气质量良好,适合户外活动。",
364
- invocationId: "inv-1"
365
- }];
366
- return /*#__PURE__*/_jsx("div", {
367
- style: {
368
- width: 700,
369
- height: "600px",
370
- border: "1px solid #f0f0f0",
371
- borderRadius: "8px",
372
- overflow: "hidden"
373
- },
374
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
375
- messages: messagesWithFunctionCall,
376
- loading: false,
377
- initialized: true,
378
- showFnCallDetail: true
379
- })
380
- });
381
- }
382
- };
383
-
384
- // ============================================
385
- // 示例 6: 思维链
386
- // ============================================
387
- export var 思维链 = {
388
- render: function render() {
389
- var messagesWithThought = [{
390
- id: "1",
391
- role: "user",
392
- text: "帮我分析一下这个问题"
393
- }, {
394
- id: "2",
395
- role: "bot",
396
- text: "让我分析一下这个问题...",
397
- thought: true,
398
- invocationId: "inv-1"
399
- }, {
400
- id: "3",
401
- role: "bot",
402
- text: "首先,我需要理解问题的核心...",
403
- thought: true,
404
- invocationId: "inv-1"
405
- }, {
406
- id: "4",
407
- role: "bot",
408
- text: "根据分析,我的结论是...(这是最终回答)",
409
- thought: false,
410
- invocationId: "inv-1"
411
- }];
412
- return /*#__PURE__*/_jsx("div", {
413
- style: {
414
- width: 700,
415
- height: "600px",
416
- border: "1px solid #f0f0f0",
417
- borderRadius: "8px",
418
- overflow: "hidden"
419
- },
420
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
421
- messages: messagesWithThought,
422
- loading: false,
423
- initialized: true
424
- })
425
- });
426
- }
427
- };
428
-
429
- // ============================================
430
- // 示例 7: 代码高亮
431
- // ============================================
432
- export var 代码高亮 = {
433
- render: function render() {
434
- var messagesWithCode = [{
435
- id: "1",
436
- role: "user",
437
- text: "写一个 React 组件"
438
- }, {
439
- id: "2",
440
- role: "bot",
441
- text: "\u8FD9\u662F\u4E00\u4E2A\u7B80\u5355\u7684 React \u8BA1\u6570\u5668\u7EC4\u4EF6:\n\n```jsx\nimport React, { useState } from 'react';\n\nfunction Counter() {\n const [count, setCount] = useState(0);\n\n return (\n <div>\n <h1>Count: {count}</h1>\n <button onClick={() => setCount(count + 1)}>\n +1\n </button>\n <button onClick={() => setCount(count - 1)}>\n -1\n </button>\n </div>\n );\n}\n\nexport default Counter;\n```\n\n\u8FD9\u4E2A\u7EC4\u4EF6\u4F7F\u7528\u4E86 `useState` Hook \u6765\u7BA1\u7406\u8BA1\u6570\u5668\u72B6\u6001\u3002",
442
- invocationId: "inv-1"
443
- }];
444
- return /*#__PURE__*/_jsx("div", {
445
- style: {
446
- width: 700,
447
- height: "600px",
448
- border: "1px solid #f0f0f0",
449
- borderRadius: "8px",
450
- overflow: "hidden"
451
- },
452
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
453
- messages: messagesWithCode,
454
- loading: false,
455
- initialized: true
456
- })
457
- });
458
- }
459
- };
460
-
461
- // ============================================
462
- // 示例 8: 多轮对话
463
- // ============================================
464
- export var 多轮对话 = {
465
- render: function render() {
466
- var multiRoundMessages = [{
467
- id: "1",
468
- role: "user",
469
- text: "React 是什么?"
470
- }, {
471
- id: "2",
472
- role: "bot",
473
- text: "React 是一个用于构建用户界面的 JavaScript 库。",
474
- invocationId: "inv-1"
475
- }, {
476
- id: "3",
477
- role: "user",
478
- text: "它有什么特点?"
479
- }, {
480
- id: "4",
481
- role: "bot",
482
- text: "React 的主要特点包括:\n1. 组件化\n2. 虚拟 DOM\n3. 单向数据流\n4. JSX 语法",
483
- invocationId: "inv-2"
484
- }, {
485
- id: "5",
486
- role: "user",
487
- text: "什么是虚拟 DOM?"
488
- }, {
489
- id: "6",
490
- role: "bot",
491
- text: "虚拟 DOM 是真实 DOM 的 JavaScript 对象表示,React 通过对比虚拟 DOM 的变化来高效更新真实 DOM。",
492
- invocationId: "inv-3"
493
- }];
494
- return /*#__PURE__*/_jsx("div", {
495
- style: {
496
- width: 700,
497
- height: "600px",
498
- border: "1px solid #f0f0f0",
499
- borderRadius: "8px",
500
- overflow: "hidden"
501
- },
502
- children: /*#__PURE__*/_jsx(XAdkChatbot, {
503
- messages: multiRoundMessages,
504
- loading: false,
505
- initialized: true
506
- })
507
- });
508
- }
509
- };
510
- //# sourceMappingURL=XAdkChatbot.stories.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","useEffect","useState","Button","Space","XAdkChatbot","jsx","_jsx","jsxs","_jsxs","meta","title","component","parameters","layout","docs","description","tags","argTypes","loading","control","showFnCallDetail","mockMessages","id","role","text","invocationId","基础用法","render","_useState","_useState2","_slicedToArray","messages","setMessages","_useState3","_useState4","setLoading","userMsg","Date","now","toString","fileData","displayName","fileUri","mimeType","prev","concat","_toConsumableArray","setTimeout","botMsg","style","width","height","padding","border","borderRadius","overflow","children","initialized","开场白和建议","_useState5","_useState6","_useState7","_useState8","suggestions","setSuggestions","prologue","handleSuggest","onSuggest","流式输出","_useState9","_useState10","_useState11","_useState12","handleStart","fullText","currentText","index","interval","setInterval","length","newMessages","_objectSpread","clearInterval","marginBottom","type","onClick","disabled","onStop","自定义Footer","_useState13","_useState14","_useState15","Set","_useState16","likedMessages","setLikedMessages","handleLike","messageId","newSet","has","delete","add","customFooter","data","message","isLastBotMsg","isLiked","size","actions","函数调用","messagesWithFunctionCall","functionCall","name","args","city","date","思维链","messagesWithThought","thought","代码高亮","messagesWithCode","多轮对话","multiRoundMessages"],"sources":["../../../../src/components/XAdkChatbot/XAdkChatbot.stories.tsx"],"sourcesContent":["import React, { useEffect, useState } from \"react\";\nimport type { Meta, StoryObj } from \"@storybook/react-vite\";\nimport { Button, Space } from \"antd\";\nimport XAdkChatbot from \"./index\";\nimport type { IMessage } from \"@/types\";\n\nconst meta: Meta<typeof XAdkChatbot> = {\n title: \"AI组件/XAdkChatbot 聊天消息组件\",\n component: XAdkChatbot,\n parameters: {\n layout: \"padded\",\n docs: {\n description: {\n component: `\n\n独立的聊天消息显示组件,用于渲染消息列表和建议问题。\n\n## 核心功能\n\n- 📝 **消息渲染**: 支持文本、Markdown、代码块、函数调用等\n- 💭 **思维链**: 支持显示 AI 推理过程\n- 🎯 **建议问题**: 显示和点击建议问题\n- 📌 **开场白**: 支持显示欢迎消息\n- 🔄 **加载状态**: 实时显示 AI 生成状态\n- 🎨 **自定义渲染**: 支持自定义消息底部内容\n\n## Props\n\n| 属性 | 类型 | 默认值 | 说明 |\n|------|------|--------|------|\n| messages | IMessage[] | [] | 消息列表 |\n| loading | boolean | false | 是否正在加载 |\n| prologue | string | - | 开场白 |\n| suggestions | string[] | [] | 建议问题 |\n| showFnCallDetail | boolean | false | 显示函数调用详情 |\n| footer | (msg) => ReactNode | - | 自定义消息底部 |\n| onSubmit | (content) => void | - | 发送消息回调 |\n| onStop | () => void | - | 停止生成回调 |\n| onClear | () => void | - | 清空消息回调 |\n| onSuggest | (text) => void | - | 点击建议回调 |\n| onConfirm | (fnCall, confirmed) => void | - | 确认函数调用 |\n `,\n },\n },\n },\n tags: [\"autodocs\"],\n argTypes: {\n loading: {\n description: \"是否正在加载(AI 生成中)\",\n control: \"boolean\",\n },\n showFnCallDetail: {\n description: \"是否显示函数调用详情\",\n control: \"boolean\",\n },\n },\n};\n\nexport default meta;\ntype Story = StoryObj<typeof meta>;\n\n// Mock 消息数据\nconst mockMessages: IMessage[] = [\n {\n id: \"1\",\n role: \"user\",\n text: \"你好\",\n },\n {\n id: \"2\",\n role: \"bot\",\n text: \"你好!我是 AI 助手,很高兴为你服务。有什么我可以帮助你的吗?\",\n invocationId: \"inv-1\",\n },\n {\n id: \"3\",\n role: \"user\",\n text: \"介绍一下 React Hooks\",\n },\n {\n id: \"4\",\n role: \"bot\",\n text: `React Hooks 是 React 16.8 引入的新特性,它让你在不编写 class 的情况下使用 state 和其他 React 特性。\n\n## 常用的 Hooks\n\n### 1. useState\n用于在函数组件中添加状态:\n\n\\`\\`\\`jsx\nconst [count, setCount] = useState(0);\n\\`\\`\\`\n\n### 2. useEffect\n用于处理副作用:\n\n\\`\\`\\`jsx\nuseEffect(() => {\n document.title = \\`Count: \\${count}\\`;\n}, [count]);\n\\`\\`\\`\n\n### 3. useContext\n用于访问 Context:\n\n\\`\\`\\`jsx\nconst theme = useContext(ThemeContext);\n\\`\\`\\`\n\n## 优势\n\n- ✅ 代码更简洁\n- ✅ 逻辑复用更容易\n- ✅ 避免 this 相关问题\n- ✅ 更好的代码组织`,\n invocationId: \"inv-2\",\n },\n {\n id: \"5\",\n role: \"user\",\n text: \"来一段富文本\",\n },\n {\n id: \"6\",\n role: \"bot\",\n text: \"# 我是标题\\n\\n我是正文\\n\\n**我是加粗**\\n\\n*我是斜体*\\n\\n<u>我是下划线</u>\\n\\n- 我是无序列表\\n \\n- 1\\n \\n- 2\\n \\n\\n1. 我是有序列表\\n \\n2. 1\\n \\n3. 2\\n \\n\\n> 我是引用\\n\\n[我是链接](https://www.baidu.com)\\n\\n```\\n我是代码库\\n```\",\n },\n];\n\n// ============================================\n// 示例 1: 基础用法\n// ============================================\nexport const 基础用法: Story = {\n render: () => {\n const [messages, setMessages] = useState<IMessage[]>(mockMessages);\n const [loading, setLoading] = useState(false);\n\n useEffect(() => {\n const userMsg: IMessage = {\n id: Date.now().toString(),\n role: \"user\",\n text: \"你好\",\n fileData: [\n {\n displayName: \"06f26c566fe4a3b5eaad678d0d270c97_origin.jpg\",\n fileUri:\n \"https://ai-platform-test.oss-cn-hangzhou.aliyuncs.com/ZABX/vidfnxlkpzxoa.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20260317T083458Z&X-Amz-SignedHeaders=host&X-Amz-Credential=LTAI5tSfMvkvWhU43Ev1cFJo%2F20260317%2Foss-cn-hangzhou%2Fs3%2Faws4_request&X-Amz-Expires=518400&X-Amz-Signature=14439e184614d76f1ca19437f76496a6d24a8aa537a29ebf61fb2af9d3f9b285\",\n mimeType: \"image/jpeg\",\n },\n {\n displayName: \"06f26c566fe4a3b5eaad678d0d270c98_origin.jpg\",\n fileUri:\n \"https://ai-platform-test.oss-cn-hangzhou.aliyuncs.com/ZABX/vidfnxlkpzxoa.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20260317T083458Z&X-Amz-SignedHeaders=host&X-Amz-Credential=LTAI5tSfMvkvWhU43Ev1cFJo%2F20260317%2Foss-cn-hangzhou%2Fs3%2Faws4_request&X-Amz-Expires=518400&X-Amz-Signature=14439e184614d76f1ca19437f76496a6d24a8aa537a29ebf61fb2af9d3f9b285\",\n mimeType: \"image/jpeg\",\n },\n ],\n };\n setMessages((prev) => [...prev, userMsg]);\n\n setLoading(true);\n setTimeout(() => {\n const botMsg: IMessage = {\n id: (Date.now() + 1).toString(),\n role: \"bot\",\n text: `这是对 \"用户\" 的模拟回复。`,\n invocationId: `inv-${Date.now()}`,\n };\n setMessages((prev) => [...prev, botMsg]);\n setLoading(false);\n }, 1000);\n }, []);\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n padding: \"20px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messages}\n loading={loading}\n initialized={true}\n style={{ width: \"670px\" }}\n />\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 2: 开场白和建议问题\n// ============================================\nexport const 开场白和建议: Story = {\n render: () => {\n const [messages, setMessages] = useState<IMessage[]>([]);\n const [suggestions, setSuggestions] = useState([\n \"什么是 React Hooks?\",\n \"如何使用 useState?\",\n \"useEffect 的作用是什么?\",\n ]);\n\n const prologue = \"你好!我是 AI 助手,专注于 React 开发相关的问题。\";\n\n const handleSuggest = (text: string) => {\n const userMsg: IMessage = {\n id: Date.now().toString(),\n role: \"user\",\n text,\n };\n setMessages([userMsg]);\n setSuggestions([]);\n\n setTimeout(() => {\n const botMsg: IMessage = {\n id: (Date.now() + 1).toString(),\n role: \"bot\",\n text: `这是对 \"${text}\" 的回答...`,\n invocationId: `inv-${Date.now()}`,\n };\n setMessages((prev) => [...prev, botMsg]);\n }, 1000);\n };\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messages}\n loading={false}\n initialized={true}\n prologue={prologue}\n suggestions={suggestions}\n onSuggest={handleSuggest}\n />\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 3: 流式输出\n// ============================================\nexport const 流式输出: Story = {\n render: () => {\n const [messages, setMessages] = useState<IMessage[]>([\n {\n id: \"1\",\n role: \"user\",\n text: \"给我讲一个故事\",\n },\n ]);\n const [loading, setLoading] = useState(false);\n\n const handleStart = () => {\n setLoading(true);\n\n const fullText =\n \"从前有座山,山里有座庙,庙里有个老和尚在给小和尚讲故事。讲什么呢?从前有座山,山里有座庙...\";\n let currentText = \"\";\n let index = 0;\n\n const botMsg: IMessage = {\n id: \"2\",\n role: \"bot\",\n text: \"\",\n invocationId: \"inv-1\",\n };\n\n setMessages((prev) => [...prev, botMsg]);\n\n const interval = setInterval(() => {\n if (index < fullText.length) {\n currentText += fullText[index];\n setMessages((prev) => {\n const newMessages = [...prev];\n newMessages[newMessages.length - 1] = {\n ...botMsg,\n text: currentText,\n };\n return newMessages;\n });\n index++;\n } else {\n clearInterval(interval);\n setLoading(false);\n }\n }, 50);\n };\n\n return (\n <div style={{ width: 700 }}>\n <div style={{ marginBottom: \"16px\" }}>\n <Button type=\"primary\" onClick={handleStart} disabled={loading}>\n 开始流式输出演示\n </Button>\n </div>\n <div\n style={{\n height: \"550px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messages}\n loading={loading}\n initialized={true}\n onStop={() => setLoading(false)}\n />\n </div>\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 4: 自定义消息 Footer\n// ============================================\nexport const 自定义Footer: Story = {\n render: () => {\n const [messages] = useState<IMessage[]>(mockMessages);\n const [likedMessages, setLikedMessages] = useState<Set<string>>(new Set());\n\n const handleLike = (messageId: string) => {\n setLikedMessages((prev) => {\n const newSet = new Set(prev);\n if (newSet.has(messageId)) {\n newSet.delete(messageId);\n } else {\n newSet.add(messageId);\n }\n return newSet;\n });\n };\n\n const customFooter = (data: any) => {\n const { message, isLastBotMsg } = data;\n\n if (!isLastBotMsg) return null;\n\n const isLiked = likedMessages.has(message.id);\n\n return (\n <div style={{ padding: \"8px 0\" }}>\n <Space size=\"small\">\n <Button\n size=\"small\"\n type={isLiked ? \"primary\" : \"text\"}\n onClick={() => handleLike(message.id)}\n >\n {isLiked ? \"👍 已赞\" : \"👍 赞\"}\n </Button>\n <Button size=\"small\" type=\"text\">\n 👎 踩\n </Button>\n <Button size=\"small\" type=\"text\">\n 📋 复制\n </Button>\n <Button size=\"small\" type=\"text\">\n 🔄 重新生成\n </Button>\n </Space>\n </div>\n );\n };\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messages}\n loading={false}\n initialized={true}\n actions={customFooter}\n />\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 5: 函数调用\n// ============================================\nexport const 函数调用: Story = {\n render: () => {\n const messagesWithFunctionCall: IMessage[] = [\n {\n id: \"1\",\n role: \"user\",\n text: \"今天北京的天气怎么样?\",\n },\n {\n id: \"2\",\n role: \"bot\",\n functionCall: {\n id: \"call-1\",\n name: \"get_weather\",\n args: {\n city: \"北京\",\n date: \"2024-03-05\",\n },\n },\n invocationId: \"inv-1\",\n },\n {\n id: \"3\",\n role: \"bot\",\n text: \"根据天气查询,今天北京的天气是晴天,温度 15-25°C,空气质量良好,适合户外活动。\",\n invocationId: \"inv-1\",\n },\n ];\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messagesWithFunctionCall}\n loading={false}\n initialized={true}\n showFnCallDetail={true}\n />\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 6: 思维链\n// ============================================\nexport const 思维链: Story = {\n render: () => {\n const messagesWithThought: IMessage[] = [\n {\n id: \"1\",\n role: \"user\",\n text: \"帮我分析一下这个问题\",\n },\n {\n id: \"2\",\n role: \"bot\",\n text: \"让我分析一下这个问题...\",\n thought: true,\n invocationId: \"inv-1\",\n },\n {\n id: \"3\",\n role: \"bot\",\n text: \"首先,我需要理解问题的核心...\",\n thought: true,\n invocationId: \"inv-1\",\n },\n {\n id: \"4\",\n role: \"bot\",\n text: \"根据分析,我的结论是...(这是最终回答)\",\n thought: false,\n invocationId: \"inv-1\",\n },\n ];\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messagesWithThought}\n loading={false}\n initialized={true}\n />\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 7: 代码高亮\n// ============================================\nexport const 代码高亮: Story = {\n render: () => {\n const messagesWithCode: IMessage[] = [\n {\n id: \"1\",\n role: \"user\",\n text: \"写一个 React 组件\",\n },\n {\n id: \"2\",\n role: \"bot\",\n text: `这是一个简单的 React 计数器组件:\n\n\\`\\`\\`jsx\nimport React, { useState } from 'react';\n\nfunction Counter() {\n const [count, setCount] = useState(0);\n\n return (\n <div>\n <h1>Count: {count}</h1>\n <button onClick={() => setCount(count + 1)}>\n +1\n </button>\n <button onClick={() => setCount(count - 1)}>\n -1\n </button>\n </div>\n );\n}\n\nexport default Counter;\n\\`\\`\\`\n\n这个组件使用了 \\`useState\\` Hook 来管理计数器状态。`,\n invocationId: \"inv-1\",\n },\n ];\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={messagesWithCode}\n loading={false}\n initialized={true}\n />\n </div>\n );\n },\n};\n\n// ============================================\n// 示例 8: 多轮对话\n// ============================================\nexport const 多轮对话: Story = {\n render: () => {\n const multiRoundMessages: IMessage[] = [\n {\n id: \"1\",\n role: \"user\",\n text: \"React 是什么?\",\n },\n {\n id: \"2\",\n role: \"bot\",\n text: \"React 是一个用于构建用户界面的 JavaScript 库。\",\n invocationId: \"inv-1\",\n },\n {\n id: \"3\",\n role: \"user\",\n text: \"它有什么特点?\",\n },\n {\n id: \"4\",\n role: \"bot\",\n text: \"React 的主要特点包括:\\n1. 组件化\\n2. 虚拟 DOM\\n3. 单向数据流\\n4. JSX 语法\",\n invocationId: \"inv-2\",\n },\n {\n id: \"5\",\n role: \"user\",\n text: \"什么是虚拟 DOM?\",\n },\n {\n id: \"6\",\n role: \"bot\",\n text: \"虚拟 DOM 是真实 DOM 的 JavaScript 对象表示,React 通过对比虚拟 DOM 的变化来高效更新真实 DOM。\",\n invocationId: \"inv-3\",\n },\n ];\n\n return (\n <div\n style={{\n width: 700,\n height: \"600px\",\n border: \"1px solid #f0f0f0\",\n borderRadius: \"8px\",\n overflow: \"hidden\",\n }}\n >\n <XAdkChatbot\n messages={multiRoundMessages}\n loading={false}\n initialized={true}\n />\n </div>\n );\n },\n};\n"],"mappings":"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"}
@@ -1,10 +0,0 @@
1
- import type { Meta, StoryObj } from "@storybook/react-vite";
2
- import XAdkProvider from "./index";
3
- declare const meta: Meta<typeof XAdkProvider>;
4
- export default meta;
5
- type Story = StoryObj<typeof meta>;
6
- export declare const 默认布局: Story;
7
- export declare const 带会话列表: Story;
8
- export declare const 自定义布局: Story;
9
- export declare const 使用Hooks: Story;
10
- export declare const 简化界面: Story;