@ai-group/chat-sdk 3.2.0 → 3.3.0

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 (105) hide show
  1. package/README.md +89 -60
  2. package/dist/cjs/components/XAdkChatbot/components/FunctionCallRender/index.d.ts +1 -6
  3. package/dist/cjs/components/XAdkChatbot/components/FunctionCallRender/index.js +19 -3
  4. package/dist/cjs/components/XAdkChatbot/components/FunctionCallRender/index.js.map +2 -2
  5. package/dist/cjs/components/XAdkChatbot/index.js +36 -8
  6. package/dist/cjs/components/XAdkChatbot/index.js.map +3 -3
  7. package/dist/cjs/components/XAdkProvider/compound/DefaultLayout.d.ts +5 -0
  8. package/dist/cjs/components/XAdkProvider/compound/DefaultLayout.js +8 -3
  9. package/dist/cjs/components/XAdkProvider/compound/DefaultLayout.js.map +2 -2
  10. package/dist/cjs/components/XAdkProvider/compound/Messages.d.ts +7 -0
  11. package/dist/cjs/components/XAdkProvider/compound/Messages.js +88 -56
  12. package/dist/cjs/components/XAdkProvider/compound/Messages.js.map +2 -2
  13. package/dist/cjs/components/XAdkProvider/context/ChatStateContext.d.ts +4 -1
  14. package/dist/cjs/components/XAdkProvider/context/ChatStateContext.js.map +2 -2
  15. package/dist/cjs/components/XAdkProvider/index.js +27 -3
  16. package/dist/cjs/components/XAdkProvider/index.js.map +2 -2
  17. package/dist/cjs/components/XAdkSender/index.js +18 -13
  18. package/dist/cjs/components/XAdkSender/index.js.map +2 -2
  19. package/dist/cjs/components/XAdkThoughtChain/index.js +29 -8
  20. package/dist/cjs/components/XAdkThoughtChain/index.js.map +3 -3
  21. package/dist/cjs/hooks/useADKChat.d.ts +1 -1
  22. package/dist/cjs/hooks/useADKChat.js +3 -1
  23. package/dist/cjs/hooks/useADKChat.js.map +2 -2
  24. package/dist/cjs/index.d.ts +3 -2
  25. package/dist/cjs/index.js +20 -1
  26. package/dist/cjs/index.js.map +2 -2
  27. package/dist/cjs/presets/xGroupAdk.d.ts +20 -0
  28. package/dist/cjs/presets/xGroupAdk.js +130 -0
  29. package/dist/cjs/presets/xGroupAdk.js.map +7 -0
  30. package/dist/cjs/types/ChatStrategies.d.ts +45 -0
  31. package/dist/cjs/types/ChatStrategies.js +18 -0
  32. package/dist/cjs/types/ChatStrategies.js.map +7 -0
  33. package/dist/cjs/types/FunctionCallRender.d.ts +35 -0
  34. package/dist/cjs/types/FunctionCallRender.js +32 -0
  35. package/dist/cjs/types/FunctionCallRender.js.map +7 -0
  36. package/dist/cjs/types/XAdkChatbot.d.ts +32 -0
  37. package/dist/cjs/types/XAdkChatbot.js.map +1 -1
  38. package/dist/cjs/types/XAdkProvider.d.ts +19 -0
  39. package/dist/cjs/types/XAdkProvider.js.map +2 -2
  40. package/dist/cjs/types/XAdkSender.d.ts +20 -4
  41. package/dist/cjs/types/XAdkSender.js.map +1 -1
  42. package/dist/cjs/types/XAdkThoughtChain.d.ts +10 -2
  43. package/dist/cjs/types/XAdkThoughtChain.js.map +1 -1
  44. package/dist/cjs/types/XAiChatbot.d.ts +1 -1
  45. package/dist/cjs/types/XAiChatbot.js.map +1 -1
  46. package/dist/cjs/types/XAiProvider.d.ts +1 -1
  47. package/dist/cjs/types/XAiProvider.js.map +1 -1
  48. package/dist/cjs/types/index.d.ts +2 -0
  49. package/dist/cjs/types/index.js +5 -1
  50. package/dist/cjs/types/index.js.map +2 -2
  51. package/dist/cjs/utils/providerManager.d.ts +1 -1
  52. package/dist/cjs/utils/providerManager.js.map +1 -1
  53. package/dist/esm/components/XAdkChatbot/components/FunctionCallRender/index.d.ts +1 -6
  54. package/dist/esm/components/XAdkChatbot/components/FunctionCallRender/index.js +25 -5
  55. package/dist/esm/components/XAdkChatbot/components/FunctionCallRender/index.js.map +1 -1
  56. package/dist/esm/components/XAdkChatbot/index.js +35 -8
  57. package/dist/esm/components/XAdkChatbot/index.js.map +1 -1
  58. package/dist/esm/components/XAdkProvider/compound/DefaultLayout.d.ts +5 -0
  59. package/dist/esm/components/XAdkProvider/compound/DefaultLayout.js +8 -4
  60. package/dist/esm/components/XAdkProvider/compound/DefaultLayout.js.map +1 -1
  61. package/dist/esm/components/XAdkProvider/compound/Messages.d.ts +7 -0
  62. package/dist/esm/components/XAdkProvider/compound/Messages.js +18 -11
  63. package/dist/esm/components/XAdkProvider/compound/Messages.js.map +1 -1
  64. package/dist/esm/components/XAdkProvider/context/ChatStateContext.d.ts +4 -1
  65. package/dist/esm/components/XAdkProvider/context/ChatStateContext.js.map +1 -1
  66. package/dist/esm/components/XAdkProvider/index.js +21 -4
  67. package/dist/esm/components/XAdkProvider/index.js.map +1 -1
  68. package/dist/esm/components/XAdkSender/index.js +25 -17
  69. package/dist/esm/components/XAdkSender/index.js.map +1 -1
  70. package/dist/esm/components/XAdkThoughtChain/index.js +23 -7
  71. package/dist/esm/components/XAdkThoughtChain/index.js.map +1 -1
  72. package/dist/esm/hooks/useADKChat.d.ts +1 -1
  73. package/dist/esm/hooks/useADKChat.js +3 -1
  74. package/dist/esm/hooks/useADKChat.js.map +1 -1
  75. package/dist/esm/index.d.ts +3 -2
  76. package/dist/esm/index.js +2 -1
  77. package/dist/esm/index.js.map +1 -1
  78. package/dist/esm/presets/xGroupAdk.d.ts +20 -0
  79. package/dist/esm/presets/xGroupAdk.js +122 -0
  80. package/dist/esm/presets/xGroupAdk.js.map +1 -0
  81. package/dist/esm/types/ChatStrategies.d.ts +45 -0
  82. package/dist/esm/types/ChatStrategies.js +2 -0
  83. package/dist/esm/types/ChatStrategies.js.map +1 -0
  84. package/dist/esm/types/FunctionCallRender.d.ts +35 -0
  85. package/dist/esm/types/FunctionCallRender.js +14 -0
  86. package/dist/esm/types/FunctionCallRender.js.map +1 -0
  87. package/dist/esm/types/XAdkChatbot.d.ts +32 -0
  88. package/dist/esm/types/XAdkChatbot.js.map +1 -1
  89. package/dist/esm/types/XAdkProvider.d.ts +19 -0
  90. package/dist/esm/types/XAdkProvider.js.map +1 -1
  91. package/dist/esm/types/XAdkSender.d.ts +20 -4
  92. package/dist/esm/types/XAdkSender.js.map +1 -1
  93. package/dist/esm/types/XAdkThoughtChain.d.ts +10 -2
  94. package/dist/esm/types/XAdkThoughtChain.js.map +1 -1
  95. package/dist/esm/types/XAiChatbot.d.ts +1 -1
  96. package/dist/esm/types/XAiChatbot.js.map +1 -1
  97. package/dist/esm/types/XAiProvider.d.ts +1 -1
  98. package/dist/esm/types/XAiProvider.js.map +1 -1
  99. package/dist/esm/types/index.d.ts +2 -0
  100. package/dist/esm/types/index.js +2 -0
  101. package/dist/esm/types/index.js.map +1 -1
  102. package/dist/esm/utils/providerManager.d.ts +1 -1
  103. package/dist/esm/utils/providerManager.js.map +1 -1
  104. package/dist/umd/chat-sdk.min.js +1 -1
  105. package/package.json +12 -14
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/index.ts"],
4
- "sourcesContent": ["// index.ts\nimport { useXAi } from \"./context/AiProviderContext\";\nimport XAiProvider from \"./components/XAiProvider\";\nimport XAiChatbot from \"./components/XAiChatbot\";\nimport XAiSDK from \"./components/XAiSDK\";\nimport XAiSender from \"./components/XAiSender\";\nimport FileGallery from \"./components/FileGallery\";\nimport XAiConversations from \"./components/XAiConversations\";\nimport XAdkThoughtChain from \"./components/XAdkThoughtChain\";\nimport useXAiSDK from \"./hooks/useXAiSDK\";\nimport request from \"./utils/request\";\n\n// 新的 Compound Components 架构\nimport XAdkProvider from \"./components/XAdkProvider\";\nimport XAdkChatbot from \"./components/XAdkChatbot\";\nimport XAdkSender from \"./components/XAdkSender\";\nimport useADKChat from \"./hooks/useADKChat\";\n\n// 导出新的 Context Hooks\nexport {\n useChatState,\n useChatActions,\n useSession,\n} from \"./components/XAdkProvider/context\";\n\nexport * from \"./types\";\n\n// 导出自定义 Hook 相关类型\nexport type { ChatHookResult, ChatHookFactory } from \"./types/ChatHook\";\n\n// 旧 API - 保持向后兼容\nexport {\n useXAi,\n XAiProvider,\n XAiChatbot,\n XAiSDK,\n XAiSender,\n XAiConversations,\n useXAiSDK,\n request,\n};\n\n// 新 API - 推荐使用\nexport {\n XAdkProvider,\n XAdkChatbot,\n XAdkSender,\n FileGallery,\n XAdkThoughtChain,\n useADKChat,\n};\n\n// 基础组件导出 - 供高级用户和业务侧使用\nexport { default as MarkdownRender } from \"./components/XAdkChatbot/components/MarkdownRender\";\nexport { default as FunctionCallRender } from \"./components/XAdkChatbot/components/FunctionCallRender\";\nexport { default as ThinkRender } from \"./components/XAdkChatbot/components/ThinkRender\";\n\n// 基础组件类型导出\nexport type { MarkdownRenderProps } from \"./components/XAdkChatbot/components/MarkdownRender\";\nexport type { FunctionCallRenderProps } from \"./components/XAdkChatbot/components/FunctionCallRender\";\nexport type {\n XAdkThoughtChainProps,\n ThoughtChainItemType,\n} from \"./types/XAdkThoughtChain\";\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA,wCAAAA;AAAA,EAAA;AAAA;AAAA;AAAA,wCAAAC;AAAA,EAAA,wCAAAC;AAAA,EAAA,oCAAAC;AAAA,EAAA,gDAAAC;AAAA,EAAA,oCAAAC;AAAA,EAAA,gDAAAC;AAAA,EAAA,sCAAAC;AAAA,EAAA,4BAAAC;AAAA,EAAA,kCAAAC;AAAA,EAAA,8BAAAC;AAAA,EAAA,oCAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,oCAAAC;AAAA;AAAA;AACA,+BAAuB;AACvB,yBAAwB;AACxB,wBAAuB;AACvB,oBAAmB;AACnB,uBAAsB;AACtB,yBAAwB;AACxB,8BAA6B;AAC7B,8BAA6B;AAC7B,uBAAsB;AACtB,qBAAoB;AAGpB,0BAAyB;AACzB,yBAAwB;AACxB,wBAAuB;AACvB,wBAAuB;AAGvB,qBAIO;AAEP,wBAAc,oBAzBd;AAqDA,4BAA0C;AAC1C,gCAA8C;AAC9C,yBAAuC;",
4
+ "sourcesContent": ["// index.ts\nimport { useXAi } from \"./context/AiProviderContext\";\nimport XAiProvider from \"./components/XAiProvider\";\nimport XAiChatbot from \"./components/XAiChatbot\";\nimport XAiSDK from \"./components/XAiSDK\";\nimport XAiSender from \"./components/XAiSender\";\nimport FileGallery from \"./components/FileGallery\";\nimport XAiConversations from \"./components/XAiConversations\";\nimport XAdkThoughtChain from \"./components/XAdkThoughtChain\";\nimport useXAiSDK from \"./hooks/useXAiSDK\";\nimport request from \"./utils/request\";\n\n// 新的 Compound Components 架构\nimport XAdkProvider from \"./components/XAdkProvider\";\nimport XAdkChatbot from \"./components/XAdkChatbot\";\nimport XAdkSender from \"./components/XAdkSender\";\nimport useADKChat from \"./hooks/useADKChat\";\nimport {\n baseChatStrategies,\n basePreset,\n baseToolKindResolver,\n mergeChatStrategies,\n resolvePresetUploadRequest,\n resolveChatPreset,\n createXGroupUploadRequest,\n xGroupAdkPreset,\n xGroupToolKindResolver,\n} from \"./presets/xGroupAdk\";\n\n// 导出新的 Context Hooks\nexport {\n useChatState,\n useChatActions,\n useSession,\n} from \"./components/XAdkProvider/context\";\n\nexport * from \"./types\";\n\n// 导出自定义 Hook 相关类型\nexport type { ChatHookResult, ChatHookFactory } from \"./types/ChatHook\";\n\n// 旧 API - 保持向后兼容\nexport {\n useXAi,\n XAiProvider,\n XAiChatbot,\n XAiSDK,\n XAiSender,\n XAiConversations,\n useXAiSDK,\n request,\n};\n\n// 新 API - 推荐使用\nexport {\n XAdkProvider,\n XAdkChatbot,\n XAdkSender,\n FileGallery,\n XAdkThoughtChain,\n useADKChat,\n baseChatStrategies,\n basePreset,\n baseToolKindResolver,\n createXGroupUploadRequest,\n mergeChatStrategies,\n resolvePresetUploadRequest,\n resolveChatPreset,\n xGroupAdkPreset,\n xGroupToolKindResolver,\n};\n\n// 基础组件导出 - 供高级用户和业务侧使用\nexport { default as MarkdownRender } from \"./components/XAdkChatbot/components/MarkdownRender\";\nexport { default as FunctionCallRender } from \"./components/XAdkChatbot/components/FunctionCallRender\";\nexport { default as ThinkRender } from \"./components/XAdkChatbot/components/ThinkRender\";\n\n// 基础组件类型导出\nexport type { MarkdownRenderProps } from \"./components/XAdkChatbot/components/MarkdownRender\";\nexport type { FunctionCallRenderProps } from \"./types/FunctionCallRender\";\nexport type {\n XAdkThoughtChainProps,\n ThoughtChainItemType,\n} from \"./types/XAdkThoughtChain\";\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA,wCAAAA;AAAA,EAAA;AAAA;AAAA;AAAA,wCAAAC;AAAA,EAAA,wCAAAC;AAAA,EAAA,oCAAAC;AAAA,EAAA,gDAAAC;AAAA,EAAA,oCAAAC;AAAA,EAAA,gDAAAC;AAAA,EAAA,sCAAAC;AAAA,EAAA,4BAAAC;AAAA,EAAA,kCAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gCAAAC;AAAA,EAAA;AAAA;AAAA,sCAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,oCAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AACA,+BAAuB;AACvB,yBAAwB;AACxB,wBAAuB;AACvB,oBAAmB;AACnB,uBAAsB;AACtB,yBAAwB;AACxB,8BAA6B;AAC7B,8BAA6B;AAC7B,uBAAsB;AACtB,qBAAoB;AAGpB,0BAAyB;AACzB,yBAAwB;AACxB,wBAAuB;AACvB,wBAAuB;AACvB,uBAUO;AAGP,qBAIO;AAEP,wBAAc,oBApCd;AAyEA,4BAA0C;AAC1C,gCAA8C;AAC9C,yBAAuC;",
6
6
  "names": ["FileGallery", "XAdkChatbot", "XAdkProvider", "XAdkSender", "XAdkThoughtChain", "XAiChatbot", "XAiConversations", "XAiProvider", "XAiSDK", "XAiSender", "request", "useADKChat", "useXAiSDK"]
7
7
  }
@@ -0,0 +1,20 @@
1
+ import type { ChatPreset, ChatPresetInput, ChatStrategies, ToolRenderKind, UploadRequestFn } from "../types";
2
+ export declare const baseToolKindResolver: () => ToolRenderKind;
3
+ export declare const xGroupToolKindResolver: ({ name, }: {
4
+ name?: string | undefined;
5
+ }) => ToolRenderKind;
6
+ export declare const baseChatStrategies: Required<Pick<ChatStrategies, "resolveToolKind" | "createFunctionResponse" | "parseProcessMessage">>;
7
+ export declare const createXGroupUploadRequest: ({ url, token, appNo, }: {
8
+ url: string;
9
+ token?: string | undefined;
10
+ appNo?: string | undefined;
11
+ }) => UploadRequestFn | undefined;
12
+ export declare const xGroupAdkPreset: ChatPreset;
13
+ export declare const basePreset: ChatPreset;
14
+ export declare const resolveChatPreset: (preset: ChatPresetInput | undefined) => ChatPreset;
15
+ export declare const mergeChatStrategies: (preset: ChatPresetInput | undefined, overrides?: ChatStrategies) => ChatStrategies;
16
+ export declare const resolvePresetUploadRequest: (preset: ChatPresetInput | undefined, context: {
17
+ url: string;
18
+ token?: string;
19
+ appNo?: string;
20
+ }) => UploadRequestFn | undefined;
@@ -0,0 +1,130 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+
19
+ // src/presets/xGroupAdk.ts
20
+ var xGroupAdk_exports = {};
21
+ __export(xGroupAdk_exports, {
22
+ baseChatStrategies: () => baseChatStrategies,
23
+ basePreset: () => basePreset,
24
+ baseToolKindResolver: () => baseToolKindResolver,
25
+ createXGroupUploadRequest: () => createXGroupUploadRequest,
26
+ mergeChatStrategies: () => mergeChatStrategies,
27
+ resolveChatPreset: () => resolveChatPreset,
28
+ resolvePresetUploadRequest: () => resolvePresetUploadRequest,
29
+ xGroupAdkPreset: () => xGroupAdkPreset,
30
+ xGroupToolKindResolver: () => xGroupToolKindResolver
31
+ });
32
+ module.exports = __toCommonJS(xGroupAdk_exports);
33
+ var import_utils = require("../utils");
34
+ var baseToolKindResolver = () => "default";
35
+ var xGroupToolKindResolver = ({
36
+ name
37
+ }) => {
38
+ if (name === "adk_request_confirmation")
39
+ return "approval";
40
+ if (name === "transferToAgent")
41
+ return "handoff";
42
+ return "default";
43
+ };
44
+ var baseChatStrategies = {
45
+ resolveToolKind: () => "default",
46
+ createFunctionResponse: (fnCall, confirmed) => ({
47
+ id: fnCall.id,
48
+ name: fnCall.name,
49
+ response: { confirmed }
50
+ }),
51
+ parseProcessMessage: import_utils.parseAgentMessage
52
+ };
53
+ var createXGroupUploadRequest = ({
54
+ url,
55
+ token,
56
+ appNo
57
+ }) => {
58
+ if (!appNo || !token)
59
+ return void 0;
60
+ return async ({ file, onProgress, onSuccess, onError }) => {
61
+ try {
62
+ onProgress == null ? void 0 : onProgress({ percent: 0 });
63
+ const formData = new FormData();
64
+ formData.append("file", file);
65
+ const response = await fetch(
66
+ `${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/uploadMultiFile`,
67
+ {
68
+ method: "POST",
69
+ body: formData,
70
+ credentials: "include",
71
+ headers: {
72
+ Accept: "application/json, text/plain, */*",
73
+ Authorization: `Bearer ${token}`,
74
+ "Cache-Control": "no-cache"
75
+ }
76
+ }
77
+ );
78
+ const result = await response.json().catch(() => ({}));
79
+ if (!response.ok) {
80
+ throw new Error((result == null ? void 0 : result.message) || `文件上传失败 (${response.status})`);
81
+ }
82
+ onProgress == null ? void 0 : onProgress({ percent: 100 });
83
+ onSuccess == null ? void 0 : onSuccess((result == null ? void 0 : result.data) ?? result);
84
+ } catch (error) {
85
+ onError == null ? void 0 : onError(error instanceof Error ? error : new Error("文件上传失败"));
86
+ }
87
+ };
88
+ };
89
+ var xGroupAdkPreset = {
90
+ name: "xgroup-adk",
91
+ strategies: {
92
+ resolveToolKind: xGroupToolKindResolver,
93
+ createFunctionResponse: baseChatStrategies.createFunctionResponse,
94
+ parseProcessMessage: (text, options) => (0, import_utils.parseAgentMessage)(text, { mode: "comment", ...options })
95
+ },
96
+ createUploadRequest: createXGroupUploadRequest
97
+ };
98
+ var basePreset = {
99
+ name: "base",
100
+ strategies: baseChatStrategies
101
+ };
102
+ var resolveChatPreset = (preset) => {
103
+ if (!preset || preset === "xgroup-adk")
104
+ return xGroupAdkPreset;
105
+ if (preset === "base")
106
+ return basePreset;
107
+ return preset;
108
+ };
109
+ var mergeChatStrategies = (preset, overrides) => ({
110
+ ...baseChatStrategies,
111
+ ...resolveChatPreset(preset).strategies,
112
+ ...overrides
113
+ });
114
+ var resolvePresetUploadRequest = (preset, context) => {
115
+ var _a, _b;
116
+ return (_b = (_a = resolveChatPreset(preset)).createUploadRequest) == null ? void 0 : _b.call(_a, context);
117
+ };
118
+ // Annotate the CommonJS export names for ESM import in node:
119
+ 0 && (module.exports = {
120
+ baseChatStrategies,
121
+ basePreset,
122
+ baseToolKindResolver,
123
+ createXGroupUploadRequest,
124
+ mergeChatStrategies,
125
+ resolveChatPreset,
126
+ resolvePresetUploadRequest,
127
+ xGroupAdkPreset,
128
+ xGroupToolKindResolver
129
+ });
130
+ //# sourceMappingURL=xGroupAdk.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/presets/xGroupAdk.ts"],
4
+ "sourcesContent": ["import { parseAgentMessage } from \"@/utils\";\nimport type {\n ChatPreset,\n ChatPresetInput,\n ChatStrategies,\n FunctionCall,\n FunctionResponse,\n ToolRenderKind,\n UploadRequestFn,\n} from \"@/types\";\n\nexport const baseToolKindResolver = (): ToolRenderKind => \"default\";\n\nexport const xGroupToolKindResolver = ({\n name,\n}: {\n name?: string;\n}): ToolRenderKind => {\n if (name === \"adk_request_confirmation\") return \"approval\";\n if (name === \"transferToAgent\") return \"handoff\";\n return \"default\";\n};\n\nexport const baseChatStrategies: Required<\n Pick<ChatStrategies, \"resolveToolKind\" | \"createFunctionResponse\" | \"parseProcessMessage\">\n> = {\n resolveToolKind: () => \"default\",\n createFunctionResponse: (\n fnCall: FunctionCall,\n confirmed: boolean,\n ): FunctionResponse => ({\n id: fnCall.id,\n name: fnCall.name,\n response: { confirmed },\n }),\n parseProcessMessage: parseAgentMessage,\n};\n\nexport const createXGroupUploadRequest = ({\n url,\n token,\n appNo,\n}: {\n url: string;\n token?: string;\n appNo?: string;\n}): UploadRequestFn | undefined => {\n if (!appNo || !token) return undefined;\n\n return async ({ file, onProgress, onSuccess, onError }) => {\n try {\n onProgress?.({ percent: 0 });\n\n const formData = new FormData();\n formData.append(\"file\", file);\n\n const response = await fetch(\n `${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/uploadMultiFile`,\n {\n method: \"POST\",\n body: formData,\n credentials: \"include\",\n headers: {\n Accept: \"application/json, text/plain, */*\",\n Authorization: `Bearer ${token}`,\n \"Cache-Control\": \"no-cache\",\n },\n },\n );\n\n const result = await response.json().catch(() => ({}));\n\n if (!response.ok) {\n throw new Error(result?.message || `文件上传失败 (${response.status})`);\n }\n\n onProgress?.({ percent: 100 });\n onSuccess?.(result?.data ?? result);\n } catch (error) {\n onError?.(error instanceof Error ? error : new Error(\"文件上传失败\"));\n }\n };\n};\n\nexport const xGroupAdkPreset: ChatPreset = {\n name: \"xgroup-adk\",\n strategies: {\n resolveToolKind: xGroupToolKindResolver,\n createFunctionResponse: baseChatStrategies.createFunctionResponse,\n parseProcessMessage: (text, options) =>\n parseAgentMessage(text, { mode: \"comment\", ...options }),\n },\n createUploadRequest: createXGroupUploadRequest,\n};\n\nexport const basePreset: ChatPreset = {\n name: \"base\",\n strategies: baseChatStrategies,\n};\n\nexport const resolveChatPreset = (\n preset: ChatPresetInput | undefined,\n): ChatPreset => {\n if (!preset || preset === \"xgroup-adk\") return xGroupAdkPreset;\n if (preset === \"base\") return basePreset;\n return preset;\n};\n\nexport const mergeChatStrategies = (\n preset: ChatPresetInput | undefined,\n overrides?: ChatStrategies,\n): ChatStrategies => ({\n ...baseChatStrategies,\n ...resolveChatPreset(preset).strategies,\n ...overrides,\n});\n\nexport const resolvePresetUploadRequest = (\n preset: ChatPresetInput | undefined,\n context: {\n url: string;\n token?: string;\n appNo?: string;\n },\n): UploadRequestFn | undefined => {\n return resolveChatPreset(preset).createUploadRequest?.(context);\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkC;AAW3B,IAAM,uBAAuB,MAAsB;AAEnD,IAAM,yBAAyB,CAAC;AAAA,EACrC;AACF,MAEsB;AACpB,MAAI,SAAS;AAA4B,WAAO;AAChD,MAAI,SAAS;AAAmB,WAAO;AACvC,SAAO;AACT;AAEO,IAAM,qBAET;AAAA,EACF,iBAAiB,MAAM;AAAA,EACvB,wBAAwB,CACtB,QACA,eACsB;AAAA,IACtB,IAAI,OAAO;AAAA,IACX,MAAM,OAAO;AAAA,IACb,UAAU,EAAE,UAAU;AAAA,EACxB;AAAA,EACA,qBAAqB;AACvB;AAEO,IAAM,4BAA4B,CAAC;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AACF,MAImC;AACjC,MAAI,CAAC,SAAS,CAAC;AAAO,WAAO;AAE7B,SAAO,OAAO,EAAE,MAAM,YAAY,WAAW,QAAQ,MAAM;AACzD,QAAI;AACF,+CAAa,EAAE,SAAS,EAAE;AAE1B,YAAM,WAAW,IAAI,SAAS;AAC9B,eAAS,OAAO,QAAQ,IAAI;AAE5B,YAAM,WAAW,MAAM;AAAA,QACrB,GAAG,2CAA2C;AAAA,QAC9C;AAAA,UACE,QAAQ;AAAA,UACR,MAAM;AAAA,UACN,aAAa;AAAA,UACb,SAAS;AAAA,YACP,QAAQ;AAAA,YACR,eAAe,UAAU;AAAA,YACzB,iBAAiB;AAAA,UACnB;AAAA,QACF;AAAA,MACF;AAEA,YAAM,SAAS,MAAM,SAAS,KAAK,EAAE,MAAM,OAAO,CAAC,EAAE;AAErD,UAAI,CAAC,SAAS,IAAI;AAChB,cAAM,IAAI,OAAM,iCAAQ,YAAW,WAAW,SAAS,SAAS;AAAA,MAClE;AAEA,+CAAa,EAAE,SAAS,IAAI;AAC5B,8CAAY,iCAAQ,SAAQ;AAAA,IAC9B,SAAS,OAAP;AACA,yCAAU,iBAAiB,QAAQ,QAAQ,IAAI,MAAM,QAAQ;AAAA,IAC/D;AAAA,EACF;AACF;AAEO,IAAM,kBAA8B;AAAA,EACzC,MAAM;AAAA,EACN,YAAY;AAAA,IACV,iBAAiB;AAAA,IACjB,wBAAwB,mBAAmB;AAAA,IAC3C,qBAAqB,CAAC,MAAM,gBAC1B,gCAAkB,MAAM,EAAE,MAAM,WAAW,GAAG,QAAQ,CAAC;AAAA,EAC3D;AAAA,EACA,qBAAqB;AACvB;AAEO,IAAM,aAAyB;AAAA,EACpC,MAAM;AAAA,EACN,YAAY;AACd;AAEO,IAAM,oBAAoB,CAC/B,WACe;AACf,MAAI,CAAC,UAAU,WAAW;AAAc,WAAO;AAC/C,MAAI,WAAW;AAAQ,WAAO;AAC9B,SAAO;AACT;AAEO,IAAM,sBAAsB,CACjC,QACA,eACoB;AAAA,EACpB,GAAG;AAAA,EACH,GAAG,kBAAkB,MAAM,EAAE;AAAA,EAC7B,GAAG;AACL;AAEO,IAAM,6BAA6B,CACxC,QACA,YAKgC;AA5HlC;AA6HE,UAAO,6BAAkB,MAAM,GAAE,wBAA1B,4BAAgD;AACzD;",
6
+ "names": []
7
+ }
@@ -0,0 +1,45 @@
1
+ import type React from "react";
2
+ import type { ParseAgentMessageOptions, ParsedPart } from "../utils";
3
+ import type { IMessage, FunctionCall, FunctionResponse } from "./XAdkChatbot";
4
+ import type { ToolRenderKind } from "./FunctionCallRender";
5
+ import type { UploadRequestFn } from "./XAdkSender";
6
+ export interface ToolKindResolveContext {
7
+ name?: string;
8
+ msg?: IMessage;
9
+ }
10
+ export interface ChatStrategies {
11
+ /**
12
+ * 工具名/消息 -> 渲染类型解析策略。
13
+ */
14
+ resolveToolKind?: (ctx: ToolKindResolveContext) => ToolRenderKind;
15
+ /**
16
+ * 函数调用确认场景中,基于工具调用和用户选择生成 functionResponse。
17
+ */
18
+ createFunctionResponse?: (fnCall: FunctionCall, confirmed: boolean) => FunctionResponse;
19
+ /**
20
+ * 将模型文本拆分为过程节点和最终答案。
21
+ */
22
+ parseProcessMessage?: (text: string, options?: ParseAgentMessageOptions) => ParsedPart[];
23
+ /**
24
+ * 自定义 approval 场景渲染,返回 null 则使用默认渲染。
25
+ */
26
+ renderApproval?: (msg: IMessage, onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void) => React.ReactNode | null;
27
+ /**
28
+ * 自定义 handoff 场景渲染,返回 null 则使用默认渲染。
29
+ */
30
+ renderHandoff?: (msg: IMessage) => React.ReactNode | null;
31
+ }
32
+ export interface ChatPreset {
33
+ name: string;
34
+ strategies?: ChatStrategies;
35
+ /**
36
+ * 基于当前协议预设创建默认文件上传函数。
37
+ * 用户显式传入 config.uploadRequest 时优先使用用户配置。
38
+ */
39
+ createUploadRequest?: (context: {
40
+ url: string;
41
+ token?: string;
42
+ appNo?: string;
43
+ }) => UploadRequestFn | undefined;
44
+ }
45
+ export type ChatPresetInput = "base" | "xgroup-adk" | ChatPreset;
@@ -0,0 +1,18 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __copyProps = (to, from, except, desc) => {
6
+ if (from && typeof from === "object" || typeof from === "function") {
7
+ for (let key of __getOwnPropNames(from))
8
+ if (!__hasOwnProp.call(to, key) && key !== except)
9
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
10
+ }
11
+ return to;
12
+ };
13
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
14
+
15
+ // src/types/ChatStrategies.ts
16
+ var ChatStrategies_exports = {};
17
+ module.exports = __toCommonJS(ChatStrategies_exports);
18
+ //# sourceMappingURL=ChatStrategies.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types/ChatStrategies.ts"],
4
+ "sourcesContent": ["import type React from \"react\";\nimport type { ParseAgentMessageOptions, ParsedPart } from \"@/utils\";\nimport type { IMessage, FunctionCall, FunctionResponse } from \"./XAdkChatbot\";\nimport type { ToolRenderKind } from \"./FunctionCallRender\";\nimport type { UploadRequestFn } from \"./XAdkSender\";\n\nexport interface ToolKindResolveContext {\n name?: string;\n msg?: IMessage;\n}\n\nexport interface ChatStrategies {\n /**\n * 工具名/消息 -> 渲染类型解析策略。\n */\n resolveToolKind?: (ctx: ToolKindResolveContext) => ToolRenderKind;\n /**\n * 函数调用确认场景中,基于工具调用和用户选择生成 functionResponse。\n */\n createFunctionResponse?: (\n fnCall: FunctionCall,\n confirmed: boolean,\n ) => FunctionResponse;\n /**\n * 将模型文本拆分为过程节点和最终答案。\n */\n parseProcessMessage?: (\n text: string,\n options?: ParseAgentMessageOptions,\n ) => ParsedPart[];\n /**\n * 自定义 approval 场景渲染,返回 null 则使用默认渲染。\n */\n renderApproval?: (\n msg: IMessage,\n onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void,\n ) => React.ReactNode | null;\n /**\n * 自定义 handoff 场景渲染,返回 null 则使用默认渲染。\n */\n renderHandoff?: (msg: IMessage) => React.ReactNode | null;\n}\n\nexport interface ChatPreset {\n name: string;\n strategies?: ChatStrategies;\n /**\n * 基于当前协议预设创建默认文件上传函数。\n * 用户显式传入 config.uploadRequest 时优先使用用户配置。\n */\n createUploadRequest?: (context: {\n url: string;\n token?: string;\n appNo?: string;\n }) => UploadRequestFn | undefined;\n}\n\nexport type ChatPresetInput = \"base\" | \"xgroup-adk\" | ChatPreset;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;AAAA;AAAA;",
6
+ "names": []
7
+ }
@@ -0,0 +1,35 @@
1
+ /// <reference types="react" />
2
+ import type { IMessage, FunctionCall } from "./";
3
+ /**
4
+ * 工具调用渲染类型
5
+ * - approval: 需要用户确认的调用(如危险操作确认)
6
+ * - handoff: 任务转交给其他 Agent
7
+ * - default: 普通工具调用
8
+ */
9
+ export type ToolRenderKind = "approval" | "handoff" | "default";
10
+ /**
11
+ * 默认的工具名 → 渲染类型推导策略
12
+ */
13
+ export declare const defaultToolKindResolver: (_name: string | undefined) => ToolRenderKind;
14
+ export interface FunctionCallRenderProps {
15
+ msg: IMessage;
16
+ showDetail?: boolean;
17
+ onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void;
18
+ /**
19
+ * 工具渲染类型,不传则使用 toolKindResolver 自动推导
20
+ */
21
+ kind?: ToolRenderKind;
22
+ /**
23
+ * 工具名 → 渲染类型的解析策略,默认使用中立的 defaultToolKindResolver。
24
+ * 业务协议可通过 XAdkProvider preset/strategies 自动下发,或局部传入覆盖。
25
+ */
26
+ toolKindResolver?: (name: string | undefined) => ToolRenderKind;
27
+ /**
28
+ * 自定义 approval 场景渲染,返回 null 则使用默认渲染
29
+ */
30
+ renderApproval?: (msg: IMessage, onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void) => React.ReactNode | null;
31
+ /**
32
+ * 自定义 handoff 场景渲染,返回 null 则使用默认渲染
33
+ */
34
+ renderHandoff?: (msg: IMessage) => React.ReactNode | null;
35
+ }
@@ -0,0 +1,32 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+
19
+ // src/types/FunctionCallRender.ts
20
+ var FunctionCallRender_exports = {};
21
+ __export(FunctionCallRender_exports, {
22
+ defaultToolKindResolver: () => defaultToolKindResolver
23
+ });
24
+ module.exports = __toCommonJS(FunctionCallRender_exports);
25
+ var defaultToolKindResolver = (_name) => {
26
+ return "default";
27
+ };
28
+ // Annotate the CommonJS export names for ESM import in node:
29
+ 0 && (module.exports = {
30
+ defaultToolKindResolver
31
+ });
32
+ //# sourceMappingURL=FunctionCallRender.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types/FunctionCallRender.ts"],
4
+ "sourcesContent": ["import type { IMessage, FunctionCall } from \"@/types\";\n\n/**\n * 工具调用渲染类型\n * - approval: 需要用户确认的调用(如危险操作确认)\n * - handoff: 任务转交给其他 Agent\n * - default: 普通工具调用\n */\nexport type ToolRenderKind = \"approval\" | \"handoff\" | \"default\";\n\n/**\n * 默认的工具名 → 渲染类型推导策略\n */\nexport const defaultToolKindResolver = (\n _name: string | undefined,\n): ToolRenderKind => {\n return \"default\";\n};\n\nexport interface FunctionCallRenderProps {\n msg: IMessage;\n showDetail?: boolean;\n onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void;\n /**\n * 工具渲染类型,不传则使用 toolKindResolver 自动推导\n */\n kind?: ToolRenderKind;\n /**\n * 工具名 → 渲染类型的解析策略,默认使用中立的 defaultToolKindResolver。\n * 业务协议可通过 XAdkProvider preset/strategies 自动下发,或局部传入覆盖。\n */\n toolKindResolver?: (name: string | undefined) => ToolRenderKind;\n /**\n * 自定义 approval 场景渲染,返回 null 则使用默认渲染\n */\n renderApproval?: (\n msg: IMessage,\n onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void,\n ) => React.ReactNode | null;\n /**\n * 自定义 handoff 场景渲染,返回 null 则使用默认渲染\n */\n renderHandoff?: (msg: IMessage) => React.ReactNode | null;\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAaO,IAAM,0BAA0B,CACrC,UACmB;AACnB,SAAO;AACT;",
6
+ "names": []
7
+ }
@@ -2,6 +2,8 @@ import { JSX } from "react";
2
2
  import { type XAdkSenderProps } from "./XAdkSender";
3
3
  import { type SendContent } from "./XAiSender";
4
4
  import { type FileItem } from "./FileGallery";
5
+ import { type ToolRenderKind } from "./FunctionCallRender";
6
+ import { type ChatPresetInput, type ChatStrategies } from "./ChatStrategies";
5
7
  /**
6
8
  * 消息分组接口
7
9
  */
@@ -201,7 +203,37 @@ export type ActionProps = (data: {
201
203
  message: ChatGroup;
202
204
  isLastBotMsg: boolean;
203
205
  }) => JSX.Element | null;
206
+ /**
207
+ * 自定义工具调用渲染函数
208
+ * - 返回 ReactNode:使用自定义渲染
209
+ * - 返回 null:降级使用默认渲染
210
+ *
211
+ * @example
212
+ * renderFunctionCall={(msg) => {
213
+ * if (msg.functionCall?.name === 'my_tool') return <MyToolRender msg={msg} />;
214
+ * return null; // 其他工具使用默认渲染
215
+ * }}
216
+ */
217
+ export type RenderFunctionCall = (msg: IMessage) => React.ReactNode | null;
204
218
  export interface XAdkChatbotProps extends Partial<XAdkSenderProps> {
219
+ /**
220
+ * 自定义工具调用渲染函数
221
+ * 返回 null 则降级使用默认渲染
222
+ */
223
+ renderFunctionCall?: RenderFunctionCall;
224
+ /**
225
+ * 工具名 → 渲染类型的解析策略,默认使用 defaultToolKindResolver
226
+ */
227
+ toolKindResolver?: (name: string | undefined) => ToolRenderKind;
228
+ /**
229
+ * 聊天策略,可由 Provider preset 自动下发,也可在组件局部覆盖。
230
+ */
231
+ strategies?: ChatStrategies;
232
+ /**
233
+ * 组件直用时的协议预设。默认沿用 xgroup-adk 以兼容既有业务接入;
234
+ * 需要中立行为时可传入 base。
235
+ */
236
+ preset?: ChatPresetInput;
205
237
  className?: string;
206
238
  style?: React.CSSProperties;
207
239
  loading?: boolean;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/types/XAdkChatbot.ts"],
4
- "sourcesContent": ["import { JSX } from \"react\";\nimport { type XAdkSenderProps } from \"./XAdkSender\";\nimport { type SendContent } from \"./XAiSender\";\nimport { type FileItem } from \"./FileGallery\";\n\n/**\n * 消息分组接口\n */\nexport interface ChatGroup {\n id: string;\n role: \"user\" | \"bot\";\n msgs: IMessage[];\n invocationId?: string;\n allFiles: any[];\n /** 点赞状态: 1=赞, -1=踩, 0=未反馈 */\n isLike?: number;\n}\n\nexport interface IInvocation {\n id: string;\n name: string;\n spanId: string;\n traceId: string;\n parentSpanId: string;\n startTime: number;\n endTime: number;\n sessionId: string;\n invocationId: string;\n duration: number;\n attributes: Record<string, string>;\n botName: string;\n workspaceNo: string;\n status: number;\n agentName: string;\n agentNo: string;\n agentVersionNo: string;\n userId: string;\n}\n\nexport interface AgentRunRequest {\n stream?: boolean;\n sessionId: string | undefined;\n content: {\n parts: Array<{\n text?: string;\n functionResponse?: {\n id?: string;\n name?: string;\n response?: any;\n };\n }>;\n role: string;\n };\n files?: Array<{\n fileName: string;\n fileId?: string;\n tempUrl: string;\n type?: string;\n mimeType: string;\n }>;\n stateDelta?: any;\n}\nexport interface Blob {\n displayName?: string;\n mimeType?: string;\n data: string;\n}\n\nexport interface FunctionCall {\n id?: string;\n name: string;\n args: { [key: string]: any };\n}\n\nexport interface FunctionResponse {\n id?: string;\n name: string;\n response: { [key: string]: any };\n}\n\nexport interface FileData {\n displayName: string;\n mimeType: string;\n fileUri: string;\n}\n\nexport interface ExecutableCode {\n language: \"UNKNOWN\" | \"PYTHON\";\n code: string;\n}\n\nexport interface CodeExecutionResult {\n outcome: \"UNKNOWN\" | \"OK\" | \"FAILED\" | \"DEADLINE_EXCEEDED\";\n output: string;\n}\n\nexport interface Part {\n text?: string;\n inlineData?: Blob;\n functionCall?: FunctionCall;\n functionResponse?: FunctionResponse;\n thought?: boolean;\n fileData?: FileData;\n executableCode?: ExecutableCode;\n codeExecutionResult?: CodeExecutionResult;\n errorMessage?: string;\n}\n\nexport interface GenAiContent {\n role: string;\n parts: Part[];\n}\n\nexport interface LlmRequest {\n contents: GenAiContent[];\n}\n\nexport interface LlmResponse {\n partial?: boolean;\n content: GenAiContent;\n error?: string;\n errorMessage?: string;\n errorCode?: string;\n longRunningToolIds?: string[];\n}\n\nexport interface EventActions {\n message?: string;\n artifactDelta?: any;\n functionCall?: FunctionCall;\n functionResponse?: FunctionResponse;\n finishReason?: string;\n}\n\nexport interface Event extends LlmResponse {\n id?: string;\n author?: string;\n invocationId?: string;\n actions?: EventActions;\n longRunningToolIds?: string[];\n branch?: string;\n timestamp?: number;\n evalStatus?: any;\n failedMetric?: any;\n evalScore?: any;\n evalThreshold?: any;\n groundingMetadata?: {\n searchEntryPoint?: {\n renderedContent?: any;\n };\n };\n isLike?: number;\n sessionId?: string;\n}\n\nexport interface SessionState {\n [key: string]: unknown;\n}\n\nexport interface Session {\n id?: string;\n appName?: string;\n userId?: string;\n state?: SessionState;\n events?: Event[];\n lastUpdateTime?: number;\n}\n\nexport interface TimeTick {\n position: number;\n label: string;\n}\n\nexport interface IMessage {\n /** 前端生成的唯一标识 */\n id: string;\n /** 单次请求的唯一标识 */\n invocationId?: string;\n /** 单个Event的唯一标识,一个event里有可能有多个parts的消息 */\n eventId?: string;\n /** 消息发起人:智能体名称、user */\n author?: string;\n role: \"bot\" | \"user\";\n /** 时间戳 */\n timestamp?: number;\n isLoading?: boolean;\n /** 函数调用 */\n functionCall?: FunctionCall;\n /** 函数调用结果 */\n functionResponse?: FunctionResponse;\n /** 文件上传 */\n inlineData?: Blob;\n /** 文本消息 */\n text?: string;\n /** 文件信息 */\n fileData?: FileData[];\n /** 思考 */\n thought?: boolean;\n executableCode?: ExecutableCode;\n codeExecutionResult?: CodeExecutionResult;\n renderedContent?: any;\n /** 原始数据 */\n raw?: any;\n // 下面暂时没有用到\n evalStatus?: any;\n failedMetric?: any;\n evalScore?: any;\n evalThreshold?: any;\n invocationIndex?: any;\n finalResponsePartIndex?: any;\n toolUseIndex?: any;\n /** 是否赞/踩 */\n isLike?: number;\n}\n\nexport type ActionProps = (data: {\n message: ChatGroup;\n isLastBotMsg: boolean;\n}) => JSX.Element | null;\n\nexport interface XAdkChatbotProps extends Partial<XAdkSenderProps> {\n className?: string;\n style?: React.CSSProperties;\n // 加载状态\n loading?: boolean;\n /** 消息列表 */\n messages: IMessage[];\n /** 开场白 */\n prologue?: string;\n /** 建议回复 */\n suggestions?: string[];\n /** 欢迎页面 */\n welcome?: React.ReactNode;\n /** 显示函数调用详情 */\n showFnCallDetail?: boolean;\n /** 是否初始化完成,初始化完成后自动滚动到最新消息 */\n initialized?: boolean;\n /** 提交回调 */\n onSubmit?: ({ text, files }: SendContent) => void;\n /** 函数调用确认回调 */\n onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void;\n /** 停止回调 */\n onStop?: () => void;\n /** 清除回调 */\n onClear?: () => void;\n /** 建议回复回调 */\n onSuggest?: (text: string) => void;\n\n // ========== 新增功能 ==========\n\n /** Agent 名称 (欢迎页面) */\n agentName?: string;\n /** Agent 图标 (欢迎页面) */\n agentIcon?: string;\n /** Agent 描述 (欢迎页面) */\n description?: string;\n\n /** 是否显示重试按钮 */\n showRetry?: boolean;\n /** 是否显示复制按钮 */\n showCopy?: boolean;\n /** 是否显示日志按钮 */\n showLog?: boolean;\n\n /** 重试回调 */\n onRetry?: () => void;\n /** 复制回调 */\n onCopy?: (text: string) => void;\n /** 查看日志回调 */\n onShowLog?: (invocationId: string, timestamp?: number) => void;\n\n /** 是否启用消息分组 (默认 true) */\n enableGrouping?: boolean;\n\n /** 是否自动解析 process 内容并展示思维链 (默认 true) */\n enableProcessParsing?: boolean;\n\n /** 消息功能区 */\n actions?: ActionProps;\n\n /**\n * Process 解析选项\n * @example\n * // 业务项目格式 (注释模式)\n * parseOptions={{ mode: 'comment' }}\n *\n * @example\n * // 自定义格式\n * parseOptions={{\n * mode: 'custom',\n * customPatterns: [\n * { regex: /\\[REASONING\\]([\\s\\S]*?)\\[\\/REASONING\\]/g, type: 'reasoning' }\n * ]\n * }}\n */\n parseOptions?: {\n mode?: \"xml\" | \"comment\" | \"custom\";\n customPatterns?: Array<{ regex: RegExp; type: string }>;\n finalMarker?: string;\n };\n\n /** 是否禁用输入 */\n disabled?: boolean;\n\n /** 是否流式响应 */\n stream?: boolean;\n\n /** 点击对话中附件卡片的回调(非图片、非音视频文件) */\n onFileClick?: (file: FileItem) => void;\n}\n"],
4
+ "sourcesContent": ["import { JSX } from \"react\";\nimport { type XAdkSenderProps } from \"./XAdkSender\";\nimport { type SendContent } from \"./XAiSender\";\nimport { type FileItem } from \"./FileGallery\";\nimport { type ToolRenderKind } from \"./FunctionCallRender\";\nimport { type ChatPresetInput, type ChatStrategies } from \"./ChatStrategies\";\n\n/**\n * 消息分组接口\n */\nexport interface ChatGroup {\n id: string;\n role: \"user\" | \"bot\";\n msgs: IMessage[];\n invocationId?: string;\n allFiles: any[];\n /** 点赞状态: 1=赞, -1=踩, 0=未反馈 */\n isLike?: number;\n}\n\nexport interface IInvocation {\n id: string;\n name: string;\n spanId: string;\n traceId: string;\n parentSpanId: string;\n startTime: number;\n endTime: number;\n sessionId: string;\n invocationId: string;\n duration: number;\n attributes: Record<string, string>;\n botName: string;\n workspaceNo: string;\n status: number;\n agentName: string;\n agentNo: string;\n agentVersionNo: string;\n userId: string;\n}\n\nexport interface AgentRunRequest {\n stream?: boolean;\n sessionId: string | undefined;\n content: {\n parts: Array<{\n text?: string;\n functionResponse?: {\n id?: string;\n name?: string;\n response?: any;\n };\n }>;\n role: string;\n };\n files?: Array<{\n fileName: string;\n fileId?: string;\n tempUrl: string;\n type?: string;\n mimeType: string;\n }>;\n stateDelta?: any;\n}\nexport interface Blob {\n displayName?: string;\n mimeType?: string;\n data: string;\n}\n\nexport interface FunctionCall {\n id?: string;\n name: string;\n args: { [key: string]: any };\n}\n\nexport interface FunctionResponse {\n id?: string;\n name: string;\n response: { [key: string]: any };\n}\n\nexport interface FileData {\n displayName: string;\n mimeType: string;\n fileUri: string;\n}\n\nexport interface ExecutableCode {\n language: \"UNKNOWN\" | \"PYTHON\";\n code: string;\n}\n\nexport interface CodeExecutionResult {\n outcome: \"UNKNOWN\" | \"OK\" | \"FAILED\" | \"DEADLINE_EXCEEDED\";\n output: string;\n}\n\nexport interface Part {\n text?: string;\n inlineData?: Blob;\n functionCall?: FunctionCall;\n functionResponse?: FunctionResponse;\n thought?: boolean;\n fileData?: FileData;\n executableCode?: ExecutableCode;\n codeExecutionResult?: CodeExecutionResult;\n errorMessage?: string;\n}\n\nexport interface GenAiContent {\n role: string;\n parts: Part[];\n}\n\nexport interface LlmRequest {\n contents: GenAiContent[];\n}\n\nexport interface LlmResponse {\n partial?: boolean;\n content: GenAiContent;\n error?: string;\n errorMessage?: string;\n errorCode?: string;\n longRunningToolIds?: string[];\n}\n\nexport interface EventActions {\n message?: string;\n artifactDelta?: any;\n functionCall?: FunctionCall;\n functionResponse?: FunctionResponse;\n finishReason?: string;\n}\n\nexport interface Event extends LlmResponse {\n id?: string;\n author?: string;\n invocationId?: string;\n actions?: EventActions;\n longRunningToolIds?: string[];\n branch?: string;\n timestamp?: number;\n evalStatus?: any;\n failedMetric?: any;\n evalScore?: any;\n evalThreshold?: any;\n groundingMetadata?: {\n searchEntryPoint?: {\n renderedContent?: any;\n };\n };\n isLike?: number;\n sessionId?: string;\n}\n\nexport interface SessionState {\n [key: string]: unknown;\n}\n\nexport interface Session {\n id?: string;\n appName?: string;\n userId?: string;\n state?: SessionState;\n events?: Event[];\n lastUpdateTime?: number;\n}\n\nexport interface TimeTick {\n position: number;\n label: string;\n}\n\nexport interface IMessage {\n /** 前端生成的唯一标识 */\n id: string;\n /** 单次请求的唯一标识 */\n invocationId?: string;\n /** 单个Event的唯一标识,一个event里有可能有多个parts的消息 */\n eventId?: string;\n /** 消息发起人:智能体名称、user */\n author?: string;\n role: \"bot\" | \"user\";\n /** 时间戳 */\n timestamp?: number;\n isLoading?: boolean;\n /** 函数调用 */\n functionCall?: FunctionCall;\n /** 函数调用结果 */\n functionResponse?: FunctionResponse;\n /** 文件上传 */\n inlineData?: Blob;\n /** 文本消息 */\n text?: string;\n /** 文件信息 */\n fileData?: FileData[];\n /** 思考 */\n thought?: boolean;\n executableCode?: ExecutableCode;\n codeExecutionResult?: CodeExecutionResult;\n renderedContent?: any;\n /** 原始数据 */\n raw?: any;\n // 下面暂时没有用到\n evalStatus?: any;\n failedMetric?: any;\n evalScore?: any;\n evalThreshold?: any;\n invocationIndex?: any;\n finalResponsePartIndex?: any;\n toolUseIndex?: any;\n /** 是否赞/踩 */\n isLike?: number;\n}\n\nexport type ActionProps = (data: {\n message: ChatGroup;\n isLastBotMsg: boolean;\n}) => JSX.Element | null;\n\n/**\n * 自定义工具调用渲染函数\n * - 返回 ReactNode:使用自定义渲染\n * - 返回 null:降级使用默认渲染\n *\n * @example\n * renderFunctionCall={(msg) => {\n * if (msg.functionCall?.name === 'my_tool') return <MyToolRender msg={msg} />;\n * return null; // 其他工具使用默认渲染\n * }}\n */\nexport type RenderFunctionCall = (msg: IMessage) => React.ReactNode | null;\n\nexport interface XAdkChatbotProps extends Partial<XAdkSenderProps> {\n /**\n * 自定义工具调用渲染函数\n * 返回 null 则降级使用默认渲染\n */\n renderFunctionCall?: RenderFunctionCall;\n /**\n * 工具名 → 渲染类型的解析策略,默认使用 defaultToolKindResolver\n */\n toolKindResolver?: (name: string | undefined) => ToolRenderKind;\n /**\n * 聊天策略,可由 Provider preset 自动下发,也可在组件局部覆盖。\n */\n strategies?: ChatStrategies;\n /**\n * 组件直用时的协议预设。默认沿用 xgroup-adk 以兼容既有业务接入;\n * 需要中立行为时可传入 base。\n */\n preset?: ChatPresetInput;\n className?: string;\n style?: React.CSSProperties;\n // 加载状态\n loading?: boolean;\n /** 消息列表 */\n messages: IMessage[];\n /** 开场白 */\n prologue?: string;\n /** 建议回复 */\n suggestions?: string[];\n /** 欢迎页面 */\n welcome?: React.ReactNode;\n /** 显示函数调用详情 */\n showFnCallDetail?: boolean;\n /** 是否初始化完成,初始化完成后自动滚动到最新消息 */\n initialized?: boolean;\n /** 提交回调 */\n onSubmit?: ({ text, files }: SendContent) => void;\n /** 函数调用确认回调 */\n onConfirm?: (fnCall: FunctionCall, confirmed: boolean) => void;\n /** 停止回调 */\n onStop?: () => void;\n /** 清除回调 */\n onClear?: () => void;\n /** 建议回复回调 */\n onSuggest?: (text: string) => void;\n\n // ========== 新增功能 ==========\n\n /** Agent 名称 (欢迎页面) */\n agentName?: string;\n /** Agent 图标 (欢迎页面) */\n agentIcon?: string;\n /** Agent 描述 (欢迎页面) */\n description?: string;\n\n /** 是否显示重试按钮 */\n showRetry?: boolean;\n /** 是否显示复制按钮 */\n showCopy?: boolean;\n /** 是否显示日志按钮 */\n showLog?: boolean;\n\n /** 重试回调 */\n onRetry?: () => void;\n /** 复制回调 */\n onCopy?: (text: string) => void;\n /** 查看日志回调 */\n onShowLog?: (invocationId: string, timestamp?: number) => void;\n\n /** 是否启用消息分组 (默认 true) */\n enableGrouping?: boolean;\n\n /** 是否自动解析 process 内容并展示思维链 (默认 true) */\n enableProcessParsing?: boolean;\n\n /** 消息功能区 */\n actions?: ActionProps;\n\n /**\n * Process 解析选项\n * @example\n * // 业务项目格式 (注释模式)\n * parseOptions={{ mode: 'comment' }}\n *\n * @example\n * // 自定义格式\n * parseOptions={{\n * mode: 'custom',\n * customPatterns: [\n * { regex: /\\[REASONING\\]([\\s\\S]*?)\\[\\/REASONING\\]/g, type: 'reasoning' }\n * ]\n * }}\n */\n parseOptions?: {\n mode?: \"xml\" | \"comment\" | \"custom\";\n customPatterns?: Array<{ regex: RegExp; type: string }>;\n finalMarker?: string;\n };\n\n /** 是否禁用输入 */\n disabled?: boolean;\n\n /** 是否流式响应 */\n stream?: boolean;\n\n /** 点击对话中附件卡片的回调(非图片、非音视频文件) */\n onFileClick?: (file: FileItem) => void;\n}\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;AAAA;AAAA;",
6
6
  "names": []
7
7
  }
@@ -1,5 +1,6 @@
1
1
  import { ReactNode } from "react";
2
2
  import { IMessage, Success, Event, Error, SendContent, ThemeType, FileItem, UploadRequestFn } from "./";
3
+ import type { ChatPresetInput, ChatStrategies } from "./ChatStrategies";
3
4
  export interface DebugOptions {
4
5
  url: string;
5
6
  sessionId?: string;
@@ -12,6 +13,7 @@ export interface DebugOptions {
12
13
  * @default true
13
14
  */
14
15
  enabled?: boolean;
16
+ strategies?: ChatStrategies;
15
17
  onError?: (error: Error) => void;
16
18
  onSuccess?: (data: Success) => void;
17
19
  onStream?: (data: Event) => void;
@@ -125,6 +127,15 @@ export interface XAdkProviderConfig {
125
127
  * 自定义文件上传函数
126
128
  */
127
129
  uploadRequest?: UploadRequestFn;
130
+ /**
131
+ * 预设策略。默认 xgroup-adk,用于兼容众安信科现有 ADK 协议。
132
+ * 传入 base 可获得更中立的组件默认行为。
133
+ */
134
+ preset?: ChatPresetInput;
135
+ /**
136
+ * 覆盖或补充当前 preset 的局部策略。
137
+ */
138
+ strategies?: ChatStrategies;
128
139
  }
129
140
  /**
130
141
  * XAdkProvider Props
@@ -142,6 +153,14 @@ export interface XAdkProviderProps {
142
153
  * 组件功能配置
143
154
  */
144
155
  config?: XAdkProviderConfig;
156
+ /**
157
+ * Provider 级预设策略,优先级高于 config.preset。
158
+ */
159
+ preset?: ChatPresetInput;
160
+ /**
161
+ * Provider 级策略覆盖,优先级高于 config.strategies。
162
+ */
163
+ strategies?: ChatStrategies;
145
164
  /**
146
165
  * Provider 唯一标识
147
166
  */
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/types/XAdkProvider.ts"],
4
- "sourcesContent": ["import { ReactNode } from \"react\";\nimport {\n IMessage,\n Success,\n Event,\n Error,\n SendContent,\n ThemeType,\n FileItem,\n UploadRequestFn,\n} from \"@/types\";\n\nexport interface DebugOptions {\n url: string;\n sessionId?: string;\n config: any;\n token: string;\n type?: \"agentDebug\" | \"appDebug\";\n /**\n * 是否启用 Hook\n * 当使用自定义 chatData 时,应设置为 false 以避免内部 Hook 初始化\n * @default true\n */\n enabled?: boolean;\n onError?: (error: Error) => void;\n onSuccess?: (data: Success) => void;\n onStream?: (data: Event) => void;\n onMessage?: (content: string, data: IMessage) => void;\n}\n\n/**\n * 事件状态码枚举\n * @enum {string}\n * @version 1.0.0\n */\nexport enum EventCode {\n /** 切换会话 */\n SESSION_SWITCH = \"SESSION_SWITCH\",\n /** 开启新会话 */\n SESSION_CREATE = \"SESSION_CREATE\",\n}\n\nexport type handleEvent = {\n code: EventCode;\n message: string;\n data?: any;\n};\n/**\n * renderFooter insert 参数说明\n */\nexport interface FooterRenderArgs {\n message: IMessage;\n isLastBotMsg: boolean;\n isLastMsg: boolean;\n}\n\n/**\n * Provider 可通过 ref 暴露的方法句柄\n */\nexport interface XAdkProviderHandle {\n startChat: (content: SendContent) => void;\n stopChat: () => void;\n reChat: () => void;\n clearChat: () => void;\n deleteSession: (id: string) => void;\n updateSession: (id: string, title: string) => void;\n getAppInfo: () => any;\n getMessages: () => IMessage[];\n getSessions: () => any[];\n setMessages: (msgs: IMessage[]) => void;\n setCurrentSession: (id: string) => void;\n /**\n * 设置自定义业务参数 (stateDelta)\n * 设置后每次发送消息时会自动携带该参数至后端\n * 传入 undefined 可清除已设置的参数\n *\n * @example\n * providerRef.current.setStateDelta({ userId: '123', bizType: 'order' });\n * // 之后发送消息,请求体会携带 stateDelta: { userId: '123', bizType: 'order' }\n *\n * @example\n * // 清除自定义参数\n * providerRef.current.setStateDelta(undefined);\n */\n setStateDelta: (delta: Record<string, any> | undefined) => void;\n}\n\n/**\n * config.chatProps 中的配置\n */\nexport interface ChatConfig {\n /**\n * 是否展示清空按钮\n * @type {boolean}\n * @default false\n */\n clearBtnShow?: boolean;\n /**\n * 是否展示输入框\n * @type {boolean}\n * @default true\n */\n inputShow?: boolean;\n /**\n * 打字机效果速度(单位:毫秒)\n * @type {number}\n * @default 60\n * @version 1.0.0\n */\n textSpeed?: number;\n}\n\n/**\n * Provider config 整体配置结构\n */\nexport interface XAdkProviderConfig {\n session?: {\n showSessionList?: boolean;\n };\n /**\n * 初始化后是否默认展示第一条会话内容\n * @type {boolean}\n * @default false\n */\n showFirstSession?: boolean;\n allowUpload?: boolean;\n appNo?: string;\n chatProps?: ChatConfig;\n debug?: boolean;\n /**\n * 是否展示点赞/点踩按钮\n * @default true\n */\n showFeedback?: boolean;\n /**\n * 点击对话中附件卡片的回调(非图片、非音视频文件)\n */\n onFileClick?: (file: FileItem) => void;\n /**\n * 自定义文件上传函数\n */\n uploadRequest?: UploadRequestFn;\n}\n\n/**\n * XAdkProvider Props\n */\nexport interface XAdkProviderProps {\n /**\n * AI 服务基础地址\n */\n url?: string;\n /**\n * 认证 token\n */\n token: string;\n /**\n * 组件功能配置\n */\n config?: XAdkProviderConfig;\n /**\n * Provider 唯一标识\n */\n providerId?: string;\n /**\n * 消息成功回调\n */\n onSuccess?: (success: any) => void;\n /**\n * 流式消息回调\n */\n onStream?: (data: Event) => void;\n /**\n * 错误回调\n */\n onError?: (err: any) => void;\n /**\n * 每条消息回调\n */\n onMessage?: (content: string, data: IMessage) => void;\n /**\n * 事件回调\n */\n onEvent?: (event: handleEvent) => void;\n /**\n * React 子元素 - 支持 Compound Components\n */\n children?: ReactNode;\n}\n\n// XAiSDKProps 继承 XAdkProviderProps\nexport interface XAdkSDKProps extends XAdkProviderProps {\n /**\n * 主题类型\n * @type {ThemeType}\n * @default 'default'\n * @version 1.0.0\n */\n theme?: ThemeType;\n\n /**\n * 组件属性配置\n * @type {object}\n * @default undefined\n * @version 1.0.0\n */\n componentProps?: {\n /**\n * 组件ID\n * @type {string}\n * @default undefined\n * @version 1.0.0\n */\n id?: string;\n /** 支持任意 CSS 属性 */\n [key: string]: any;\n };\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAmCO,IAAK,YAAL,kBAAKA,eAAL;AAEL,EAAAA,WAAA,oBAAiB;AAEjB,EAAAA,WAAA,oBAAiB;AAJP,SAAAA;AAAA,GAAA;",
4
+ "sourcesContent": ["import { ReactNode } from \"react\";\nimport {\n IMessage,\n Success,\n Event,\n Error,\n SendContent,\n ThemeType,\n FileItem,\n UploadRequestFn,\n} from \"@/types\";\nimport type { ChatPresetInput, ChatStrategies } from \"./ChatStrategies\";\n\nexport interface DebugOptions {\n url: string;\n sessionId?: string;\n config: any;\n token: string;\n type?: \"agentDebug\" | \"appDebug\";\n /**\n * 是否启用 Hook\n * 当使用自定义 chatData 时,应设置为 false 以避免内部 Hook 初始化\n * @default true\n */\n enabled?: boolean;\n strategies?: ChatStrategies;\n onError?: (error: Error) => void;\n onSuccess?: (data: Success) => void;\n onStream?: (data: Event) => void;\n onMessage?: (content: string, data: IMessage) => void;\n}\n\n/**\n * 事件状态码枚举\n * @enum {string}\n * @version 1.0.0\n */\nexport enum EventCode {\n /** 切换会话 */\n SESSION_SWITCH = \"SESSION_SWITCH\",\n /** 开启新会话 */\n SESSION_CREATE = \"SESSION_CREATE\",\n}\n\nexport type handleEvent = {\n code: EventCode;\n message: string;\n data?: any;\n};\n/**\n * renderFooter insert 参数说明\n */\nexport interface FooterRenderArgs {\n message: IMessage;\n isLastBotMsg: boolean;\n isLastMsg: boolean;\n}\n\n/**\n * Provider 可通过 ref 暴露的方法句柄\n */\nexport interface XAdkProviderHandle {\n startChat: (content: SendContent) => void;\n stopChat: () => void;\n reChat: () => void;\n clearChat: () => void;\n deleteSession: (id: string) => void;\n updateSession: (id: string, title: string) => void;\n getAppInfo: () => any;\n getMessages: () => IMessage[];\n getSessions: () => any[];\n setMessages: (msgs: IMessage[]) => void;\n setCurrentSession: (id: string) => void;\n /**\n * 设置自定义业务参数 (stateDelta)\n * 设置后每次发送消息时会自动携带该参数至后端\n * 传入 undefined 可清除已设置的参数\n *\n * @example\n * providerRef.current.setStateDelta({ userId: '123', bizType: 'order' });\n * // 之后发送消息,请求体会携带 stateDelta: { userId: '123', bizType: 'order' }\n *\n * @example\n * // 清除自定义参数\n * providerRef.current.setStateDelta(undefined);\n */\n setStateDelta: (delta: Record<string, any> | undefined) => void;\n}\n\n/**\n * config.chatProps 中的配置\n */\nexport interface ChatConfig {\n /**\n * 是否展示清空按钮\n * @type {boolean}\n * @default false\n */\n clearBtnShow?: boolean;\n /**\n * 是否展示输入框\n * @type {boolean}\n * @default true\n */\n inputShow?: boolean;\n /**\n * 打字机效果速度(单位:毫秒)\n * @type {number}\n * @default 60\n * @version 1.0.0\n */\n textSpeed?: number;\n}\n\n/**\n * Provider config 整体配置结构\n */\nexport interface XAdkProviderConfig {\n session?: {\n showSessionList?: boolean;\n };\n /**\n * 初始化后是否默认展示第一条会话内容\n * @type {boolean}\n * @default false\n */\n showFirstSession?: boolean;\n allowUpload?: boolean;\n appNo?: string;\n chatProps?: ChatConfig;\n debug?: boolean;\n /**\n * 是否展示点赞/点踩按钮\n * @default true\n */\n showFeedback?: boolean;\n /**\n * 点击对话中附件卡片的回调(非图片、非音视频文件)\n */\n onFileClick?: (file: FileItem) => void;\n /**\n * 自定义文件上传函数\n */\n uploadRequest?: UploadRequestFn;\n /**\n * 预设策略。默认 xgroup-adk,用于兼容众安信科现有 ADK 协议。\n * 传入 base 可获得更中立的组件默认行为。\n */\n preset?: ChatPresetInput;\n /**\n * 覆盖或补充当前 preset 的局部策略。\n */\n strategies?: ChatStrategies;\n}\n\n/**\n * XAdkProvider Props\n */\nexport interface XAdkProviderProps {\n /**\n * AI 服务基础地址\n */\n url?: string;\n /**\n * 认证 token\n */\n token: string;\n /**\n * 组件功能配置\n */\n config?: XAdkProviderConfig;\n /**\n * Provider 级预设策略,优先级高于 config.preset。\n */\n preset?: ChatPresetInput;\n /**\n * Provider 级策略覆盖,优先级高于 config.strategies。\n */\n strategies?: ChatStrategies;\n /**\n * Provider 唯一标识\n */\n providerId?: string;\n /**\n * 消息成功回调\n */\n onSuccess?: (success: any) => void;\n /**\n * 流式消息回调\n */\n onStream?: (data: Event) => void;\n /**\n * 错误回调\n */\n onError?: (err: any) => void;\n /**\n * 每条消息回调\n */\n onMessage?: (content: string, data: IMessage) => void;\n /**\n * 事件回调\n */\n onEvent?: (event: handleEvent) => void;\n /**\n * React 子元素 - 支持 Compound Components\n */\n children?: ReactNode;\n}\n\n// XAiSDKProps 继承 XAdkProviderProps\nexport interface XAdkSDKProps extends XAdkProviderProps {\n /**\n * 主题类型\n * @type {ThemeType}\n * @default 'default'\n * @version 1.0.0\n */\n theme?: ThemeType;\n\n /**\n * 组件属性配置\n * @type {object}\n * @default undefined\n * @version 1.0.0\n */\n componentProps?: {\n /**\n * 组件ID\n * @type {string}\n * @default undefined\n * @version 1.0.0\n */\n id?: string;\n /** 支持任意 CSS 属性 */\n [key: string]: any;\n };\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAqCO,IAAK,YAAL,kBAAKA,eAAL;AAEL,EAAAA,WAAA,oBAAiB;AAEjB,EAAAA,WAAA,oBAAiB;AAJP,SAAAA;AAAA,GAAA;",
6
6
  "names": ["EventCode"]
7
7
  }
@@ -1,22 +1,38 @@
1
1
  import React from "react";
2
+ export interface UploadFileResult {
3
+ fileName?: string;
4
+ fileId?: string | number;
5
+ tempUrl?: string;
6
+ url?: string;
7
+ fileUrl?: string;
8
+ fileType?: string;
9
+ fileSize?: number;
10
+ mimeType?: string;
11
+ [key: string]: any;
12
+ }
13
+ export interface UploadSuccessResponse {
14
+ data?: UploadFileResult;
15
+ [key: string]: any;
16
+ }
2
17
  interface uploadRequestProps {
3
18
  (options: {
4
19
  file: File;
5
20
  onProgress?: (e: {
6
21
  percent: number;
7
22
  }) => void;
8
- onSuccess?: (response: any) => void;
23
+ onSuccess?: (response: UploadFileResult | UploadSuccessResponse) => void;
9
24
  onError?: (error: Error) => void;
10
25
  }): Promise<void> | void;
11
26
  }
12
27
  export type UploadRequestFn = uploadRequestProps;
13
28
  export interface ServerFile {
14
29
  fileName: string;
15
- fileId: number;
30
+ fileId: string | number;
16
31
  tempUrl: string;
17
32
  type: string;
18
- size: number;
33
+ size?: number;
19
34
  mimeType: string;
35
+ raw?: UploadFileResult;
20
36
  }
21
37
  export interface LocalFile {
22
38
  id: string;
@@ -27,7 +43,7 @@ export interface LocalFile {
27
43
  type: string;
28
44
  progress: number;
29
45
  status: "pending" | "uploading" | "success" | "error";
30
- fileId?: number;
46
+ fileId?: string | number;
31
47
  tempUrl?: string;
32
48
  response?: any;
33
49
  errorMessage?: string;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/types/XAdkSender.ts"],
4
- "sourcesContent": ["// types/XAdkSender.ts\nimport React from \"react\";\n\ninterface uploadRequestProps {\n (options: {\n file: File;\n onProgress?: (e: { percent: number }) => void;\n onSuccess?: (response: any) => void;\n onError?: (error: Error) => void;\n }): Promise<void> | void;\n}\n\nexport type UploadRequestFn = uploadRequestProps;\n\nexport interface ServerFile {\n fileName: string;\n fileId: number;\n tempUrl: string;\n type: string;\n size: number;\n mimeType: string;\n}\n\nexport interface LocalFile {\n id: string;\n uid: string;\n name: string;\n file: File;\n size: number;\n type: string;\n progress: number;\n status: \"pending\" | \"uploading\" | \"success\" | \"error\";\n // 服务器返回字段\n fileId?: number;\n tempUrl?: string;\n response?: any;\n errorMessage?: string; // 上传错误信息\n}\n\nexport type FileValidator = (\n file: File,\n context: { files: LocalFile[] },\n) => string | null;\n\nexport interface ActionsComponents {\n SendButton: React.ComponentType<any>;\n UploadButton: React.ComponentType<any>;\n ClearButton: React.ComponentType<any>;\n}\n\nexport type SlotRenderFunction = (\n oriNode: React.ReactNode,\n info: { components: ActionsComponents },\n) => React.ReactNode | false;\n\n// 上传相关\nexport interface UploaderCoreProps {\n uploadRequest?: uploadRequestProps;\n\n maxFileSize?: number;\n allowedFileTypes?: string[];\n maxFiles?: number;\n\n validators?: FileValidator[];\n\n // 数据层回调\n onFilesChange?: (files: LocalFile[]) => void;\n onUploadSuccess?: (file: LocalFile) => void;\n onUploadError?: (file: LocalFile, error: Error) => void;\n}\n\n// UI 相关\nexport interface SenderUIProps {\n clearBtnShow?: boolean;\n allowUpload?: boolean;\n loading?: boolean;\n disabled?: boolean; // 只读状态\n onClear?: () => void;\n onChange?: (value: string) => void;\n onSubmit?: (data: { text: string; files: ServerFile[] }) => void;\n onStop?: () => void;\n\n // UI插槽功能\n /** 后缀内容,默认展示操作按钮,设为 false 时不显示 */\n suffix?: React.ReactNode | false | SlotRenderFunction;\n /** 头部面板 */\n header?: React.ReactNode | false | SlotRenderFunction;\n /** 前缀内容 */\n prefix?: React.ReactNode | false | SlotRenderFunction;\n /** 底部内容 */\n footer?: React.ReactNode | false | SlotRenderFunction;\n}\n\nexport type XAdkSenderProps = SenderUIProps & UploaderCoreProps;\n"],
4
+ "sourcesContent": ["// types/XAdkSender.ts\nimport React from \"react\";\n\nexport interface UploadFileResult {\n fileName?: string;\n fileId?: string | number;\n tempUrl?: string;\n url?: string;\n fileUrl?: string;\n fileType?: string;\n fileSize?: number;\n mimeType?: string;\n [key: string]: any;\n}\n\nexport interface UploadSuccessResponse {\n data?: UploadFileResult;\n [key: string]: any;\n}\n\ninterface uploadRequestProps {\n (options: {\n file: File;\n onProgress?: (e: { percent: number }) => void;\n onSuccess?: (response: UploadFileResult | UploadSuccessResponse) => void;\n onError?: (error: Error) => void;\n }): Promise<void> | void;\n}\n\nexport type UploadRequestFn = uploadRequestProps;\n\nexport interface ServerFile {\n fileName: string;\n fileId: string | number;\n tempUrl: string;\n type: string;\n size?: number;\n mimeType: string;\n raw?: UploadFileResult;\n}\n\nexport interface LocalFile {\n id: string;\n uid: string;\n name: string;\n file: File;\n size: number;\n type: string;\n progress: number;\n status: \"pending\" | \"uploading\" | \"success\" | \"error\";\n // 服务器返回字段\n fileId?: string | number;\n tempUrl?: string;\n response?: any;\n errorMessage?: string; // 上传错误信息\n}\n\nexport type FileValidator = (\n file: File,\n context: { files: LocalFile[] },\n) => string | null;\n\nexport interface ActionsComponents {\n SendButton: React.ComponentType<any>;\n UploadButton: React.ComponentType<any>;\n ClearButton: React.ComponentType<any>;\n}\n\nexport type SlotRenderFunction = (\n oriNode: React.ReactNode,\n info: { components: ActionsComponents },\n) => React.ReactNode | false;\n\n// 上传相关\nexport interface UploaderCoreProps {\n uploadRequest?: uploadRequestProps;\n\n maxFileSize?: number;\n allowedFileTypes?: string[];\n maxFiles?: number;\n\n validators?: FileValidator[];\n\n // 数据层回调\n onFilesChange?: (files: LocalFile[]) => void;\n onUploadSuccess?: (file: LocalFile) => void;\n onUploadError?: (file: LocalFile, error: Error) => void;\n}\n\n// UI 相关\nexport interface SenderUIProps {\n clearBtnShow?: boolean;\n allowUpload?: boolean;\n loading?: boolean;\n disabled?: boolean; // 只读状态\n onClear?: () => void;\n onChange?: (value: string) => void;\n onSubmit?: (data: { text: string; files: ServerFile[] }) => void;\n onStop?: () => void;\n\n // UI插槽功能\n /** 后缀内容,默认展示操作按钮,设为 false 时不显示 */\n suffix?: React.ReactNode | false | SlotRenderFunction;\n /** 头部面板 */\n header?: React.ReactNode | false | SlotRenderFunction;\n /** 前缀内容 */\n prefix?: React.ReactNode | false | SlotRenderFunction;\n /** 底部内容 */\n footer?: React.ReactNode | false | SlotRenderFunction;\n}\n\nexport type XAdkSenderProps = SenderUIProps & UploaderCoreProps;\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;AAAA;AAAA;",
6
6
  "names": []
7
7
  }
@@ -1,5 +1,5 @@
1
1
  import React, { type ReactNode } from "react";
2
- import { IMessage } from "./XAdkChatbot";
2
+ import { IMessage, RenderFunctionCall, ToolRenderKind, ChatStrategies } from "./";
3
3
  export interface XAdkThoughtChainProps {
4
4
  defaultOpen?: boolean;
5
5
  loading?: boolean;
@@ -8,6 +8,14 @@ export interface XAdkThoughtChainProps {
8
8
  showFnCallDetail?: boolean;
9
9
  onConfirm?: (fnCall: any, confirmed: boolean) => void;
10
10
  blink?: boolean;
11
+ /** 自定义工具调用渲染函数,返回 null 则使用默认渲染 */
12
+ renderFunctionCall?: RenderFunctionCall;
13
+ /**
14
+ * 工具名 → 渲染类型的解析策略,默认使用 defaultToolKindResolver
15
+ */
16
+ toolKindResolver?: (name: string | undefined) => ToolRenderKind;
17
+ /** 聊天策略,可由 Provider preset 自动下发,也可在组件局部覆盖。 */
18
+ strategies?: ChatStrategies;
11
19
  }
12
20
  export interface TimelineItemProps {
13
21
  icon: React.ReactNode;
@@ -21,7 +29,7 @@ export interface ThoughtChainItemType {
21
29
  type: "tool" | "text";
22
30
  key: string;
23
31
  content: string;
24
- title?: React.ReactNode;
32
+ title?: ReactNode;
25
33
  collapsible?: boolean;
26
34
  msg?: IMessage;
27
35
  }