@ai-group/chat-sdk 2.1.5 → 2.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/index.js +7 -5
- package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/index.js.map +3 -3
- package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/styles.d.ts +38 -0
- package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/styles.js +51 -0
- package/dist/cjs/components/XAdkChatbot/components/MarkdownRender/styles.js.map +7 -0
- package/dist/cjs/components/XAdkWebProvider/XAdkWebProvider.stories.js +13 -7
- package/dist/cjs/components/XAdkWebProvider/XAdkWebProvider.stories.js.map +2 -2
- package/dist/cjs/components/XAdkWebProvider/index.js +19 -2
- package/dist/cjs/components/XAdkWebProvider/index.js.map +2 -2
- package/dist/cjs/hooks/useADKChat.js +4 -0
- package/dist/cjs/hooks/useADKChat.js.map +2 -2
- package/dist/cjs/services/api.js +2 -1
- package/dist/cjs/services/api.js.map +2 -2
- package/dist/cjs/types/XAdkProvider.d.ts +39 -0
- package/dist/cjs/types/XAdkProvider.js +16 -0
- package/dist/cjs/types/XAdkProvider.js.map +3 -3
- package/dist/esm/components/XAdkChatbot/components/MarkdownRender/index.js +27 -19
- package/dist/esm/components/XAdkChatbot/components/MarkdownRender/index.js.map +1 -1
- package/dist/esm/components/XAdkChatbot/components/MarkdownRender/styles.d.ts +38 -0
- package/dist/esm/components/XAdkChatbot/components/MarkdownRender/styles.js +12 -0
- package/dist/esm/components/XAdkChatbot/components/MarkdownRender/styles.js.map +1 -0
- package/dist/esm/components/XAdkWebProvider/XAdkWebProvider.stories.js +11 -6
- package/dist/esm/components/XAdkWebProvider/XAdkWebProvider.stories.js.map +1 -1
- package/dist/esm/components/XAdkWebProvider/index.js +17 -2
- package/dist/esm/components/XAdkWebProvider/index.js.map +1 -1
- package/dist/esm/hooks/useADKChat.js +4 -0
- package/dist/esm/hooks/useADKChat.js.map +1 -1
- package/dist/esm/services/api.js +2 -1
- package/dist/esm/services/api.js.map +1 -1
- package/dist/esm/types/XAdkProvider.d.ts +39 -0
- package/dist/esm/types/XAdkProvider.js +32 -1
- package/dist/esm/types/XAdkProvider.js.map +1 -1
- package/dist/umd/chat-sdk.min.js +1 -1
- package/package.json +5 -3
package/dist/cjs/services/api.js
CHANGED
|
@@ -64,7 +64,8 @@ var closeSession = async ({ url, appNo, sessionId, token }) => {
|
|
|
64
64
|
const response = await import_request.request.delete(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions/${sessionId}`, {
|
|
65
65
|
headers: {
|
|
66
66
|
Authorization: `Bearer ${token}`
|
|
67
|
-
}
|
|
67
|
+
},
|
|
68
|
+
data: {}
|
|
68
69
|
});
|
|
69
70
|
return response.data;
|
|
70
71
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/services/api.ts"],
|
|
4
|
-
"sourcesContent": ["import { request } from '@/utils/request';\n\n// 服务端API响应接口\nexport interface ServerApiResponse<T = unknown> {\n data: T;\n code: string;\n success: boolean;\n message: string;\n serverTime: number;\n traceId: string;\n}\n\n// 标准API响应类型\nexport interface ApiResponse<T> {\n data: T;\n pagination?: {\n hasMore: boolean;\n nextPage: number;\n total: number;\n };\n result: {\n status: string;\n message?: string;\n code: string;\n }\n}\n\n// 聊天配置类型\nexport interface ChatConfig {\n workspaceNo?: string;\n appNo: string;\n appName: string;\n appTheme: string;\n description?: string;\n icon?: string;\n onboardingInfo: {\n prologue: string;\n questionFiles?: { question: string; }[];\n // eslint-disable-next-line camelcase\n suggested_questions: string[];\n };\n appVersionNo?: string;\n publishDTO?: {\n id: number;\n tenantId: string;\n workspaceNo: string;\n publishNo: string;\n publishTime: string;\n publishVersionNo: string;\n publishVersionDesc: string;\n publishAppType: string;\n platformConfigInfo: string;\n appNo: string;\n appVersionNo: string;\n sessionTime?: string;\n enableFlag: number;\n gmtModified: string;\n creator: string;\n modifier: string;\n isDeleted: string;\n authLoginInfoDTO: Record<string, unknown>;\n shareLink: string;\n };\n}\n\n// 会话记录\nexport interface SessionData {\n sessionId: string;\n startTime: string;\n userId: string;\n title: string;\n workspaceNo: string;\n appNo: string;\n isLike: 1 | 0 | -1;\n}\n\n/**\n * 获取聊天配置\n * 使用request,会自动添加token\n */\nexport const fetchAppConfig = async ({ url, appNo }: { url: string; appNo: string }): Promise<ApiResponse<ChatConfig>> => {\n const response = await request.get<ApiResponse<ChatConfig>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}`, {\n headers: {\n 'Content-Type': 'application/json',\n 'x-za-application': appNo,\n },\n });\n return response.data;\n};\n\n/**\n * 发送消息\n * 使用request,会自动添加token\n */\nexport const sendMessage = async ({ url, appNo, msg }: { url: string; appNo: string; msg: string }): Promise<ApiResponse<ChatConfig>> => {\n const response = await request.post<ApiResponse<ChatConfig>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sendMsgSteaming`, {\n msg,\n });\n return response.data;\n};\n\n/**\n * 获取会话列表\n */\nexport const fetchSessionList = async ({ url, appNo, pageSize = 10, pageNum = 1, token }:\n { url: string; appNo: string; pageSize?: number; pageNum?: number; token: string }) => {\n const response = await request.get<ApiResponse<SessionData[]>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions?limit=${pageSize}&page=${pageNum}`, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\nexport interface SessionDetailAction {\n artifactDelta: Record<string, unknown>;\n requestedAuthConfigs: Record<string, unknown>;\n stateDelta: Record<string, unknown>;\n requestedToolConfirmations: Record<string, unknown>;\n}\n\nexport interface SessionDetailPartFileData {\n displayName: string;\n fileUri: string;\n mimeType: string;\n}\n\nexport interface SessionDetailPart {\n // 可能包含文本、文件等不同类型字段\n text?: string;\n fileData?: SessionDetailPartFileData;\n [key: string]: unknown;\n}\n\nexport interface SessionDetail {\n author: string;\n id: string;\n sessionId: string;\n invocationId?: string;\n actions: SessionDetailAction;\n content: {\n role: string; // e.g. 'user' or 'model'\n parts: SessionDetailPart[];\n };\n timestamp: number;\n [key: string]: unknown;\n}\n\n/**\n * 获取会话明细\n */\nexport const fetchSessionDetail = async ({ url, appNo, sessionId, pageSize = 999, pageNum = 1, token }:\n { url: string; appNo: string; sessionId: string; pageSize?: number; pageNum?: number; token: string }) => {\n const response = await request.get<ApiResponse<SessionDetail[]>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessionDetails?sessionId=${sessionId}&page=${pageNum}&limit=${pageSize}`, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\n/**\n * 删除会话\n */\nexport const closeSession = async ({ url, appNo, sessionId, token }:\n { url: string; appNo: string; sessionId: string; token: string }) => {\n const response = await request.delete<ApiResponse<boolean>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions/${sessionId}`, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\n/**\n * 修改会话标题\n */\nexport const updateSessionTitle = async ({ url, appNo, sessionId, title, token }:\n { url: string; appNo: string; sessionId: string; title: string; token: string }) => {\n const response = await request.put<ApiResponse<boolean>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions/${sessionId}/updateSessionTitle`, {\n title,\n }, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\nexport const addFeedback = async (params: {\n url: string;\n appNo: string;\n token: string;\n requestId: string;\n isLike: 1 | -1;\n feedbackTags?: string;\n feedbackDescription?: string;\n}) => {\n const { url, appNo, token, requestId, ...rest } = params;\n const response = await request.post<ApiResponse<void>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/invocation/${requestId}/feedback`, rest, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAAwB;AAgFjB,IAAM,iBAAiB,OAAO,EAAE,KAAK,MAAM,MAAwE;AACxH,QAAM,WAAW,MAAM,uBAAQ,IAA6B,GAAG,2CAA2C,SAAS;AAAA,IACjH,SAAS;AAAA,MACP,gBAAgB;AAAA,MAChB,oBAAoB;AAAA,IACtB;AAAA,EACF,CAAC;AACD,SAAO,SAAS;AAClB;AAMO,IAAM,cAAc,OAAO,EAAE,KAAK,OAAO,IAAI,MAAqF;AACvI,QAAM,WAAW,MAAM,uBAAQ,KAA8B,GAAG,2CAA2C,yBAAyB;AAAA,IAClI;AAAA,EACF,CAAC;AACD,SAAO,SAAS;AAClB;AAKO,IAAM,mBAAmB,OAAO,EAAE,KAAK,OAAO,WAAW,IAAI,UAAU,GAAG,MAAM,MACE;AACvF,QAAM,WAAW,MAAM,uBAAQ,IAAgC,GAAG,2CAA2C,wBAAwB,iBAAiB,WAAW;AAAA,IAC/J,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,EACF,CAAC;AAED,SAAO,SAAS;AAClB;AAuCO,IAAM,qBAAqB,OAAO,EAAE,KAAK,OAAO,WAAW,WAAW,KAAK,UAAU,GAAG,MAAM,MACO;AAC1G,QAAM,WAAW,MAAM,uBAAQ,IAAkC,GAAG,2CAA2C,kCAAkC,kBAAkB,iBAAiB,YAAY;AAAA,IAC9L,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,EACF,CAAC;AAED,SAAO,SAAS;AAClB;AAKO,IAAM,eAAe,OAAO,EAAE,KAAK,OAAO,WAAW,MAAM,MACK;AACrE,QAAM,WAAW,MAAM,uBAAQ,OAA6B,GAAG,2CAA2C,kBAAkB,aAAa;AAAA,IACvI,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,
|
|
4
|
+
"sourcesContent": ["import { request } from '@/utils/request';\n\n// 服务端API响应接口\nexport interface ServerApiResponse<T = unknown> {\n data: T;\n code: string;\n success: boolean;\n message: string;\n serverTime: number;\n traceId: string;\n}\n\n// 标准API响应类型\nexport interface ApiResponse<T> {\n data: T;\n pagination?: {\n hasMore: boolean;\n nextPage: number;\n total: number;\n };\n result: {\n status: string;\n message?: string;\n code: string;\n }\n}\n\n// 聊天配置类型\nexport interface ChatConfig {\n workspaceNo?: string;\n appNo: string;\n appName: string;\n appTheme: string;\n description?: string;\n icon?: string;\n onboardingInfo: {\n prologue: string;\n questionFiles?: { question: string; }[];\n // eslint-disable-next-line camelcase\n suggested_questions: string[];\n };\n appVersionNo?: string;\n publishDTO?: {\n id: number;\n tenantId: string;\n workspaceNo: string;\n publishNo: string;\n publishTime: string;\n publishVersionNo: string;\n publishVersionDesc: string;\n publishAppType: string;\n platformConfigInfo: string;\n appNo: string;\n appVersionNo: string;\n sessionTime?: string;\n enableFlag: number;\n gmtModified: string;\n creator: string;\n modifier: string;\n isDeleted: string;\n authLoginInfoDTO: Record<string, unknown>;\n shareLink: string;\n };\n}\n\n// 会话记录\nexport interface SessionData {\n sessionId: string;\n startTime: string;\n userId: string;\n title: string;\n workspaceNo: string;\n appNo: string;\n isLike: 1 | 0 | -1;\n}\n\n/**\n * 获取聊天配置\n * 使用request,会自动添加token\n */\nexport const fetchAppConfig = async ({ url, appNo }: { url: string; appNo: string }): Promise<ApiResponse<ChatConfig>> => {\n const response = await request.get<ApiResponse<ChatConfig>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}`, {\n headers: {\n 'Content-Type': 'application/json',\n 'x-za-application': appNo,\n },\n });\n return response.data;\n};\n\n/**\n * 发送消息\n * 使用request,会自动添加token\n */\nexport const sendMessage = async ({ url, appNo, msg }: { url: string; appNo: string; msg: string }): Promise<ApiResponse<ChatConfig>> => {\n const response = await request.post<ApiResponse<ChatConfig>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sendMsgSteaming`, {\n msg,\n });\n return response.data;\n};\n\n/**\n * 获取会话列表\n */\nexport const fetchSessionList = async ({ url, appNo, pageSize = 10, pageNum = 1, token }:\n { url: string; appNo: string; pageSize?: number; pageNum?: number; token: string }) => {\n const response = await request.get<ApiResponse<SessionData[]>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions?limit=${pageSize}&page=${pageNum}`, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\nexport interface SessionDetailAction {\n artifactDelta: Record<string, unknown>;\n requestedAuthConfigs: Record<string, unknown>;\n stateDelta: Record<string, unknown>;\n requestedToolConfirmations: Record<string, unknown>;\n}\n\nexport interface SessionDetailPartFileData {\n displayName: string;\n fileUri: string;\n mimeType: string;\n}\n\nexport interface SessionDetailPart {\n // 可能包含文本、文件等不同类型字段\n text?: string;\n fileData?: SessionDetailPartFileData;\n [key: string]: unknown;\n}\n\nexport interface SessionDetail {\n author: string;\n id: string;\n sessionId: string;\n invocationId?: string;\n actions: SessionDetailAction;\n content: {\n role: string; // e.g. 'user' or 'model'\n parts: SessionDetailPart[];\n };\n timestamp: number;\n [key: string]: unknown;\n}\n\n/**\n * 获取会话明细\n */\nexport const fetchSessionDetail = async ({ url, appNo, sessionId, pageSize = 999, pageNum = 1, token }:\n { url: string; appNo: string; sessionId: string; pageSize?: number; pageNum?: number; token: string }) => {\n const response = await request.get<ApiResponse<SessionDetail[]>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessionDetails?sessionId=${sessionId}&page=${pageNum}&limit=${pageSize}`, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\n/**\n * 删除会话\n */\nexport const closeSession = async ({ url, appNo, sessionId, token }:\n { url: string; appNo: string; sessionId: string; token: string }) => {\n const response = await request.delete<ApiResponse<boolean>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions/${sessionId}`, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n data: {}\n });\n\n return response.data;\n};\n\n/**\n * 修改会话标题\n */\nexport const updateSessionTitle = async ({ url, appNo, sessionId, title, token }:\n { url: string; appNo: string; sessionId: string; title: string; token: string }) => {\n const response = await request.put<ApiResponse<boolean>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/sessions/${sessionId}/updateSessionTitle`, {\n title,\n }, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n\nexport const addFeedback = async (params: {\n url: string;\n appNo: string;\n token: string;\n requestId: string;\n isLike: 1 | -1;\n feedbackTags?: string;\n feedbackDescription?: string;\n}) => {\n const { url, appNo, token, requestId, ...rest } = params;\n const response = await request.post<ApiResponse<void>>(`${url}/api/gateway-web/openApi/v1/aizt/app/${appNo}/invocation/${requestId}/feedback`, rest, {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n });\n\n return response.data;\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAAwB;AAgFjB,IAAM,iBAAiB,OAAO,EAAE,KAAK,MAAM,MAAwE;AACxH,QAAM,WAAW,MAAM,uBAAQ,IAA6B,GAAG,2CAA2C,SAAS;AAAA,IACjH,SAAS;AAAA,MACP,gBAAgB;AAAA,MAChB,oBAAoB;AAAA,IACtB;AAAA,EACF,CAAC;AACD,SAAO,SAAS;AAClB;AAMO,IAAM,cAAc,OAAO,EAAE,KAAK,OAAO,IAAI,MAAqF;AACvI,QAAM,WAAW,MAAM,uBAAQ,KAA8B,GAAG,2CAA2C,yBAAyB;AAAA,IAClI;AAAA,EACF,CAAC;AACD,SAAO,SAAS;AAClB;AAKO,IAAM,mBAAmB,OAAO,EAAE,KAAK,OAAO,WAAW,IAAI,UAAU,GAAG,MAAM,MACE;AACvF,QAAM,WAAW,MAAM,uBAAQ,IAAgC,GAAG,2CAA2C,wBAAwB,iBAAiB,WAAW;AAAA,IAC/J,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,EACF,CAAC;AAED,SAAO,SAAS;AAClB;AAuCO,IAAM,qBAAqB,OAAO,EAAE,KAAK,OAAO,WAAW,WAAW,KAAK,UAAU,GAAG,MAAM,MACO;AAC1G,QAAM,WAAW,MAAM,uBAAQ,IAAkC,GAAG,2CAA2C,kCAAkC,kBAAkB,iBAAiB,YAAY;AAAA,IAC9L,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,EACF,CAAC;AAED,SAAO,SAAS;AAClB;AAKO,IAAM,eAAe,OAAO,EAAE,KAAK,OAAO,WAAW,MAAM,MACK;AACrE,QAAM,WAAW,MAAM,uBAAQ,OAA6B,GAAG,2CAA2C,kBAAkB,aAAa;AAAA,IACvI,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,IACA,MAAM,CAAC;AAAA,EACT,CAAC;AAED,SAAO,SAAS;AAClB;AAKO,IAAM,qBAAqB,OAAO,EAAE,KAAK,OAAO,WAAW,OAAO,MAAM,MACO;AACpF,QAAM,WAAW,MAAM,uBAAQ,IAA0B,GAAG,2CAA2C,kBAAkB,gCAAgC;AAAA,IACvJ;AAAA,EACF,GAAG;AAAA,IACD,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,EACF,CAAC;AAED,SAAO,SAAS;AAClB;AAEO,IAAM,cAAc,OAAO,WAQ5B;AACJ,QAAM,EAAE,KAAK,OAAO,OAAO,WAAW,GAAG,KAAK,IAAI;AAClD,QAAM,WAAW,MAAM,uBAAQ,KAAwB,GAAG,2CAA2C,oBAAoB,sBAAsB,MAAM;AAAA,IACnJ,SAAS;AAAA,MACP,eAAe,UAAU;AAAA,IAC3B;AAAA,EACF,CAAC;AAED,SAAO,SAAS;AAClB;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -11,6 +11,22 @@ export interface DebugOptions {
|
|
|
11
11
|
onStream?: (data: Event) => void;
|
|
12
12
|
onMessage?: (content: string, data: IMessage) => void;
|
|
13
13
|
}
|
|
14
|
+
/**
|
|
15
|
+
* 事件状态码枚举
|
|
16
|
+
* @enum {string}
|
|
17
|
+
* @version 1.0.0
|
|
18
|
+
*/
|
|
19
|
+
export declare enum EventCode {
|
|
20
|
+
/** 切换会话 */
|
|
21
|
+
SESSION_SWITCH = "SESSION_SWITCH",
|
|
22
|
+
/** 开启新会话 */
|
|
23
|
+
SESSION_CREATE = "SESSION_CREATE"
|
|
24
|
+
}
|
|
25
|
+
export type handleEvent = {
|
|
26
|
+
code: EventCode;
|
|
27
|
+
message: string;
|
|
28
|
+
data?: any;
|
|
29
|
+
};
|
|
14
30
|
/**
|
|
15
31
|
* renderFooter insert 参数说明
|
|
16
32
|
*/
|
|
@@ -90,6 +106,25 @@ export interface XAdkProviderProps {
|
|
|
90
106
|
* Provider 唯一标识
|
|
91
107
|
*/
|
|
92
108
|
providerId?: string;
|
|
109
|
+
/**
|
|
110
|
+
* 获取应用信息
|
|
111
|
+
* @type {() => any}
|
|
112
|
+
* @version 1.0.0
|
|
113
|
+
*/
|
|
114
|
+
getData: () => any;
|
|
115
|
+
/**
|
|
116
|
+
* 发送聊天消息
|
|
117
|
+
* @param content - 消息内容
|
|
118
|
+
* @type {(content: string) => void}
|
|
119
|
+
* @version 1.0.0
|
|
120
|
+
*/
|
|
121
|
+
chat: (content: SendContent) => void;
|
|
122
|
+
/**
|
|
123
|
+
* 停止聊天
|
|
124
|
+
* @type {() => void}
|
|
125
|
+
* @version 1.0.0
|
|
126
|
+
*/
|
|
127
|
+
stop: () => void;
|
|
93
128
|
/**
|
|
94
129
|
* 消息成功回调
|
|
95
130
|
*/
|
|
@@ -106,6 +141,10 @@ export interface XAdkProviderProps {
|
|
|
106
141
|
* 每条消息回调
|
|
107
142
|
*/
|
|
108
143
|
onMessage?: (content: string, data: IMessage) => void;
|
|
144
|
+
/**
|
|
145
|
+
* 事件回调
|
|
146
|
+
*/
|
|
147
|
+
onEvent?: (event: handleEvent) => void;
|
|
109
148
|
/**
|
|
110
149
|
* 自定义插槽渲染函数
|
|
111
150
|
*/
|
|
@@ -2,6 +2,10 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
3
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
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
|
+
};
|
|
5
9
|
var __copyProps = (to, from, except, desc) => {
|
|
6
10
|
if (from && typeof from === "object" || typeof from === "function") {
|
|
7
11
|
for (let key of __getOwnPropNames(from))
|
|
@@ -14,5 +18,17 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
14
18
|
|
|
15
19
|
// src/types/XAdkProvider.ts
|
|
16
20
|
var XAdkProvider_exports = {};
|
|
21
|
+
__export(XAdkProvider_exports, {
|
|
22
|
+
EventCode: () => EventCode
|
|
23
|
+
});
|
|
17
24
|
module.exports = __toCommonJS(XAdkProvider_exports);
|
|
25
|
+
var EventCode = /* @__PURE__ */ ((EventCode2) => {
|
|
26
|
+
EventCode2["SESSION_SWITCH"] = "SESSION_SWITCH";
|
|
27
|
+
EventCode2["SESSION_CREATE"] = "SESSION_CREATE";
|
|
28
|
+
return EventCode2;
|
|
29
|
+
})(EventCode || {});
|
|
30
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
31
|
+
0 && (module.exports = {
|
|
32
|
+
EventCode
|
|
33
|
+
});
|
|
18
34
|
//# sourceMappingURL=XAdkProvider.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/types/XAdkProvider.ts"],
|
|
4
|
-
"sourcesContent": ["import { ReactNode } from 'react';\nimport { IMessage, Success, Event, Error, SendContent, ThemeType } from '@/types';\n\n\nexport interface DebugOptions {\n url: string\n sessionId?: string;\n config: any;\n token: string;\n type?: 'agentDebug' | 'appDebug';\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 * 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 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 setCurrentSessionDetail: (id: string) => 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 allowUpload?: boolean;\n appNo: string;\n chatProps?: ChatConfig;\n debug?: boolean;\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 footer?: (args: FooterRenderArgs) => ReactNode;\n /**\n * React 子元素\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}"],
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": []
|
|
4
|
+
"sourcesContent": ["import { ReactNode } from 'react';\nimport { IMessage, Success, Event, Error, SendContent, ThemeType } from '@/types';\n\n\nexport interface DebugOptions {\n url: string\n sessionId?: string;\n config: any;\n token: string;\n type?: 'agentDebug' | 'appDebug';\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\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 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 setCurrentSessionDetail: (id: string) => 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 allowUpload?: boolean;\n appNo: string;\n chatProps?: ChatConfig;\n debug?: boolean;\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 * @type {() => any}\n * @version 1.0.0\n */\n getData: () => any;\n\n /**\n * 发送聊天消息\n * @param content - 消息内容\n * @type {(content: string) => void}\n * @version 1.0.0\n */\n chat: (content: SendContent) => void;\n /**\n * 停止聊天\n * @type {() => void}\n * @version 1.0.0\n */\n stop: () => void;\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 * 自定义插槽渲染函数\n */\n footer?: (args: FooterRenderArgs) => ReactNode;\n /**\n * React 子元素\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}"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAqBO,IAAM,YAAN,kBAAMA,eAAN;AAEL,EAAAA,WAAA,oBAAiB;AAEjB,EAAAA,WAAA,oBAAiB;AAJN,SAAAA;AAAA,GAAA;",
|
|
6
|
+
"names": ["EventCode"]
|
|
7
7
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import XMarkdown from '@ant-design/x-markdown';
|
|
3
|
-
import
|
|
4
|
-
import Latex from '@ant-design/x-markdown/plugins/Latex';
|
|
3
|
+
import { CodeHighlighter } from "@ant-design/x";
|
|
5
4
|
import { Flex } from 'antd';
|
|
5
|
+
import Latex from '@ant-design/x-markdown/plugins/Latex';
|
|
6
|
+
import { useStyles } from "./styles";
|
|
6
7
|
import { BarsOutlined, BulbOutlined, ThunderboltOutlined, CheckCircleOutlined } from '@ant-design/icons';
|
|
7
8
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
8
9
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
@@ -12,7 +13,7 @@ var CodeComponent = function CodeComponent(props) {
|
|
|
12
13
|
children = props.children;
|
|
13
14
|
var lang = (className === null || className === void 0 || (_className$match = className.match(/language-(\w+)/)) === null || _className$match === void 0 ? void 0 : _className$match[1]) || '';
|
|
14
15
|
if (typeof children !== 'string') return null;
|
|
15
|
-
return /*#__PURE__*/_jsx(
|
|
16
|
+
return /*#__PURE__*/_jsx(CodeHighlighter, {
|
|
16
17
|
lang: lang,
|
|
17
18
|
children: children
|
|
18
19
|
});
|
|
@@ -47,23 +48,30 @@ var ThinkComponent = /*#__PURE__*/React.memo(function (props) {
|
|
|
47
48
|
});
|
|
48
49
|
var MarkdownRender = function MarkdownRender(_ref) {
|
|
49
50
|
var text = _ref.text;
|
|
51
|
+
var styles = useStyles();
|
|
50
52
|
var markdown = text.replaceAll(/\/\*\s*PLANNING\s*\*\//g, '<tag type="planning"></tag>').replaceAll(/\/\*\s*REPLANNING\s*\*\//g, '<tag type="replanning"></tag>').replaceAll(/\/\*\s*REASONING\s*\*\//g, '<tag type="reasoning"></tag>').replaceAll(/\/\*\s*ACTION\s*\*\//g, '<tag type="action"></tag>').replaceAll(/\/\*\s*FINAL_ANSWER\s*\*\//g, '<tag type="final_answer"></tag>');
|
|
51
|
-
return /*#__PURE__*/_jsx(
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
53
|
+
return /*#__PURE__*/_jsx("div", {
|
|
54
|
+
className: styles.markdownWrapper,
|
|
55
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
56
|
+
className: styles.markdownHost,
|
|
57
|
+
children: /*#__PURE__*/_jsx(XMarkdown, {
|
|
58
|
+
content: markdown,
|
|
59
|
+
paragraphTag: "div",
|
|
60
|
+
config: {
|
|
61
|
+
extensions: Latex()
|
|
62
|
+
},
|
|
63
|
+
components: {
|
|
64
|
+
tag: ThinkComponent,
|
|
65
|
+
code: CodeComponent
|
|
66
|
+
},
|
|
67
|
+
streaming: {
|
|
68
|
+
enableAnimation: true,
|
|
69
|
+
animationConfig: {
|
|
70
|
+
fadeDuration: 400
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
})
|
|
74
|
+
})
|
|
67
75
|
});
|
|
68
76
|
};
|
|
69
77
|
export default MarkdownRender;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","XMarkdown","
|
|
1
|
+
{"version":3,"names":["React","XMarkdown","CodeHighlighter","Flex","Latex","useStyles","BarsOutlined","BulbOutlined","ThunderboltOutlined","CheckCircleOutlined","jsx","_jsx","jsxs","_jsxs","CodeComponent","props","_className$match","className","children","lang","match","ThinkComponent","memo","type","titleMap","planning","replanning","reasoning","action","final_answer","iconMap","align","gap","style","color","margin","MarkdownRender","_ref","text","styles","markdown","replaceAll","markdownWrapper","markdownHost","content","paragraphTag","config","extensions","components","tag","code","streaming","enableAnimation","animationConfig","fadeDuration"],"sources":["../../../../../../src/components/XAdkChatbot/components/MarkdownRender/index.tsx"],"sourcesContent":["import React from 'react';\nimport XMarkdown, { type ComponentProps } from '@ant-design/x-markdown';\nimport { CodeHighlighter } from \"@ant-design/x\";\nimport { Flex } from 'antd';\nimport Latex from '@ant-design/x-markdown/plugins/Latex';\nimport { useStyles } from './styles';\nimport { BarsOutlined, BulbOutlined, ThunderboltOutlined, CheckCircleOutlined } from '@ant-design/icons';\n\n\nconst CodeComponent: React.FC<ComponentProps> = (props) => {\n const { className, children } = props;\n const lang = className?.match(/language-(\\w+)/)?.[1] || '';\n\n if (typeof children !== 'string') return null;\n return <CodeHighlighter lang={lang}>{children}</CodeHighlighter>;\n}\n\nexport interface MarkdownRenderProps {\n text: string;\n}\n\nconst ThinkComponent = React.memo((props: ComponentProps) => {\n const type = (props.type || '') as string;\n const titleMap: Record<string, string> = {\n planning: '规划',\n replanning: '重新规划',\n reasoning: '推理',\n action: '行动',\n final_answer: '最终答案',\n };\n const iconMap = {\n planning: <BarsOutlined />,\n replanning: <BarsOutlined />,\n reasoning: <BulbOutlined />,\n action: <ThunderboltOutlined />,\n final_answer: <CheckCircleOutlined />,\n };\n\n return (\n <Flex align=\"center\" gap={8} style={{ color: '#888', margin: '4px 0' }}>\n {type in titleMap && iconMap[type as keyof typeof iconMap]}\n <span>{titleMap[type]}</span>\n </Flex>\n );\n});\n\nconst MarkdownRender: React.FC<MarkdownRenderProps> = ({ text }) => {\n const styles = useStyles();\n const markdown = text\n .replaceAll(/\\/\\*\\s*PLANNING\\s*\\*\\//g, '<tag type=\"planning\"></tag>')\n .replaceAll(/\\/\\*\\s*REPLANNING\\s*\\*\\//g, '<tag type=\"replanning\"></tag>')\n .replaceAll(/\\/\\*\\s*REASONING\\s*\\*\\//g, '<tag type=\"reasoning\"></tag>')\n .replaceAll(/\\/\\*\\s*ACTION\\s*\\*\\//g, '<tag type=\"action\"></tag>')\n .replaceAll(/\\/\\*\\s*FINAL_ANSWER\\s*\\*\\//g, '<tag type=\"final_answer\"></tag>');\n \n return (\n <div className={styles.markdownWrapper}>\n <div className={styles.markdownHost}>\n <XMarkdown\n content={markdown}\n paragraphTag=\"div\"\n config={{\n extensions: Latex(),\n }}\n components={{\n tag: ThinkComponent,\n code: CodeComponent,\n }}\n streaming={{\n enableAnimation: true,\n animationConfig: {\n fadeDuration: 400,\n },\n }}\n />\n </div>\n </div>\n );\n};\n\nexport default MarkdownRender;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,SAAS,MAA+B,wBAAwB;AACvE,SAASC,eAAe,QAAQ,eAAe;AAC/C,SAASC,IAAI,QAAQ,MAAM;AAC3B,OAAOC,KAAK,MAAM,sCAAsC;AACxD,SAASC,SAAS;AAClB,SAASC,YAAY,EAAEC,YAAY,EAAEC,mBAAmB,EAAEC,mBAAmB,QAAQ,mBAAmB;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAAA,SAAAC,IAAA,IAAAC,KAAA;AAGzG,IAAMC,aAAuC,GAAG,SAA1CA,aAAuCA,CAAIC,KAAK,EAAK;EAAA,IAAAC,gBAAA;EACzD,IAAQC,SAAS,GAAeF,KAAK,CAA7BE,SAAS;IAAEC,QAAQ,GAAKH,KAAK,CAAlBG,QAAQ;EAC3B,IAAMC,IAAI,GAAG,CAAAF,SAAS,aAATA,SAAS,gBAAAD,gBAAA,GAATC,SAAS,CAAEG,KAAK,CAAC,gBAAgB,CAAC,cAAAJ,gBAAA,uBAAlCA,gBAAA,CAAqC,CAAC,CAAC,KAAI,EAAE;EAE1D,IAAI,OAAOE,QAAQ,KAAK,QAAQ,EAAE,OAAO,IAAI;EAC7C,oBAAOP,IAAA,CAACT,eAAe;IAACiB,IAAI,EAAEA,IAAK;IAAAD,QAAA,EAAEA;EAAQ,CAAkB,CAAC;AAClE,CAAC;AAMD,IAAMG,cAAc,gBAAGrB,KAAK,CAACsB,IAAI,CAAC,UAACP,KAAqB,EAAK;EAC3D,IAAMQ,IAAI,GAAIR,KAAK,CAACQ,IAAI,IAAI,EAAa;EACzC,IAAMC,QAAgC,GAAG;IACvCC,QAAQ,EAAE,IAAI;IACdC,UAAU,EAAE,MAAM;IAClBC,SAAS,EAAE,IAAI;IACfC,MAAM,EAAE,IAAI;IACZC,YAAY,EAAE;EAChB,CAAC;EACD,IAAMC,OAAO,GAAG;IACdL,QAAQ,eAAEd,IAAA,CAACL,YAAY,IAAE,CAAC;IAC1BoB,UAAU,eAAEf,IAAA,CAACL,YAAY,IAAE,CAAC;IAC5BqB,SAAS,eAAEhB,IAAA,CAACJ,YAAY,IAAE,CAAC;IAC3BqB,MAAM,eAAEjB,IAAA,CAACH,mBAAmB,IAAE,CAAC;IAC/BqB,YAAY,eAAElB,IAAA,CAACF,mBAAmB,IAAE;EACtC,CAAC;EAED,oBACEI,KAAA,CAACV,IAAI;IAAC4B,KAAK,EAAC,QAAQ;IAACC,GAAG,EAAE,CAAE;IAACC,KAAK,EAAE;MAAEC,KAAK,EAAE,MAAM;MAAEC,MAAM,EAAE;IAAQ,CAAE;IAAAjB,QAAA,GACpEK,IAAI,IAAIC,QAAQ,IAAIM,OAAO,CAACP,IAAI,CAAyB,eAC1DZ,IAAA;MAAAO,QAAA,EAAOM,QAAQ,CAACD,IAAI;IAAC,CAAO,CAAC;EAAA,CACzB,CAAC;AAEX,CAAC,CAAC;AAEF,IAAMa,cAA6C,GAAG,SAAhDA,cAA6CA,CAAAC,IAAA,EAAiB;EAAA,IAAXC,IAAI,GAAAD,IAAA,CAAJC,IAAI;EAC3D,IAAMC,MAAM,GAAGlC,SAAS,CAAC,CAAC;EAC1B,IAAMmC,QAAQ,GAAGF,IAAI,CAClBG,UAAU,CAAC,yBAAyB,EAAE,6BAA6B,CAAC,CACpEA,UAAU,CAAC,2BAA2B,EAAE,+BAA+B,CAAC,CACxEA,UAAU,CAAC,0BAA0B,EAAE,8BAA8B,CAAC,CACtEA,UAAU,CAAC,uBAAuB,EAAE,2BAA2B,CAAC,CAChEA,UAAU,CAAC,6BAA6B,EAAE,iCAAiC,CAAC;EAE/E,oBACE9B,IAAA;IAAKM,SAAS,EAAEsB,MAAM,CAACG,eAAgB;IAAAxB,QAAA,eACrCP,IAAA;MAAKM,SAAS,EAAEsB,MAAM,CAACI,YAAa;MAAAzB,QAAA,eAClCP,IAAA,CAACV,SAAS;QACR2C,OAAO,EAAEJ,QAAS;QAClBK,YAAY,EAAC,KAAK;QAClBC,MAAM,EAAE;UACNC,UAAU,EAAE3C,KAAK,CAAC;QACpB,CAAE;QACF4C,UAAU,EAAE;UACVC,GAAG,EAAE5B,cAAc;UACnB6B,IAAI,EAAEpC;QACR,CAAE;QACFqC,SAAS,EAAE;UACTC,eAAe,EAAE,IAAI;UACrBC,eAAe,EAAE;YACfC,YAAY,EAAE;UAChB;QACF;MAAE,CACH;IAAC,CACC;EAAC,CACH,CAAC;AAEV,CAAC;AAED,eAAelB,cAAc"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export declare const useStyles: () => {
|
|
2
|
+
markdownWrapper: string;
|
|
3
|
+
markdownHost: string;
|
|
4
|
+
} & {
|
|
5
|
+
w: (width: string | number) => string;
|
|
6
|
+
h: (height: string | number) => string;
|
|
7
|
+
p: (padding: string) => string;
|
|
8
|
+
pb: (padding: string | number) => string;
|
|
9
|
+
pt: (padding: string | number) => string;
|
|
10
|
+
pl: (padding: string | number) => string;
|
|
11
|
+
pr: (padding: string | number) => string;
|
|
12
|
+
m: (margin: string) => string;
|
|
13
|
+
mb: (margin: string | number) => string;
|
|
14
|
+
mt: (margin: string | number) => string;
|
|
15
|
+
ml: (margin: string | number) => string;
|
|
16
|
+
mr: (margin: string | number) => string;
|
|
17
|
+
text: (size: string | number) => string;
|
|
18
|
+
weight: (size: number) => string;
|
|
19
|
+
textColor: (c: string) => string;
|
|
20
|
+
bg: (c: string) => string;
|
|
21
|
+
rs: (radius: string | number) => string;
|
|
22
|
+
gap: (g: string | number) => string;
|
|
23
|
+
flex: string;
|
|
24
|
+
flexCenter: string;
|
|
25
|
+
flexBetween: string;
|
|
26
|
+
flexColumn: string;
|
|
27
|
+
flex1: string;
|
|
28
|
+
cursor: (type: string) => string;
|
|
29
|
+
border: (color: string, width?: string) => string;
|
|
30
|
+
boxShadow: (shadow: string) => string;
|
|
31
|
+
transition: (property?: string, duration?: string) => string;
|
|
32
|
+
overflow: (type: string) => string;
|
|
33
|
+
position: (type: string) => string;
|
|
34
|
+
zIndex: (index: number) => string;
|
|
35
|
+
flexCenterGap2: string;
|
|
36
|
+
flexCenterGap4: string;
|
|
37
|
+
};
|
|
38
|
+
export default useStyles;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import _taggedTemplateLiteral from "@babel/runtime/helpers/esm/taggedTemplateLiteral";
|
|
2
|
+
var _templateObject, _templateObject2;
|
|
3
|
+
import { css } from '@emotion/css';
|
|
4
|
+
import { withBasicStyles } from "../../../../styles/common";
|
|
5
|
+
export var useStyles = withBasicStyles(function () {
|
|
6
|
+
return {
|
|
7
|
+
markdownWrapper: css(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n display: grid;\n grid-template-columns: minmax(0, 1fr); /* \u5173\u952E\uFF1A\u5141\u8BB8\u5185\u5BB9\u6536\u7F29 */\n max-width: 100%; /* \u81EA\u5B9A\u4E49\u6700\u5927\u5BBD\u5EA6 */\n margin: 0 auto;\n "]))),
|
|
8
|
+
markdownHost: css(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n container-type: inline-size; /* \u542F\u7528\u5BB9\u5668\u67E5\u8BE2 */\n width: 100%;\n overflow: auto;\n\n ant-highlightCode {\n max-width: min(100%, 80ch); /* \u53CC\u91CD\u7EA6\u675F */\n overflow-x: auto;\n }\n "])))
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
export default useStyles;
|
|
12
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["css","withBasicStyles","useStyles","markdownWrapper","_templateObject","_taggedTemplateLiteral","markdownHost","_templateObject2"],"sources":["../../../../../../src/components/XAdkChatbot/components/MarkdownRender/styles.tsx"],"sourcesContent":["import { css } from '@emotion/css';\nimport { withBasicStyles } from '@/styles/common';\n\nexport const useStyles = withBasicStyles(() => ({\n markdownWrapper: css`\n display: grid;\n grid-template-columns: minmax(0, 1fr); /* 关键:允许内容收缩 */\n max-width: 100%; /* 自定义最大宽度 */\n margin: 0 auto;\n `,\n\n\n markdownHost: css`\n container-type: inline-size; /* 启用容器查询 */\n width: 100%;\n overflow: auto;\n\n ant-highlightCode {\n max-width: min(100%, 80ch); /* 双重约束 */\n overflow-x: auto;\n }\n `,\n}));\n\nexport default useStyles;\n"],"mappings":";;AAAA,SAASA,GAAG,QAAQ,cAAc;AAClC,SAASC,eAAe;AAExB,OAAO,IAAMC,SAAS,GAAGD,eAAe,CAAC;EAAA,OAAO;IAC9CE,eAAe,EAAEH,GAAG,CAAAI,eAAA,KAAAA,eAAA,GAAAC,sBAAA,qOAKnB;IAGDC,YAAY,EAAEN,GAAG,CAAAO,gBAAA,KAAAA,gBAAA,GAAAF,sBAAA;EAUnB,CAAC;AAAA,CAAC,CAAC;AAEH,eAAeH,SAAS"}
|
|
@@ -83,9 +83,9 @@ export var 单聊天窗口实例 = {
|
|
|
83
83
|
},
|
|
84
84
|
args: {
|
|
85
85
|
url: 'https://m-poc-dev.zaxline.com',
|
|
86
|
-
token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.
|
|
86
|
+
token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiVjRTT0htSm8zWmVhNFJOdWc3WFgyQT09Iiwic2NvcGUiOlsiTUZYNVR4bGhlSUtiZWtaSEtvZU9WTmxvIl0sImV4cCI6MTc2Nzk1MjM0NywianRpIjoiSHpLMll4cVdjSTA3QWtmOHlsQXYwV0w0aE5jIiwiY2xpZW50X2lkIjoiTUZYNVR4bGhlSUtiZWtaSEtvZU9WTmxvIn0.AjABoyZFxAACkfy-ywLlfaJd6YY0Ir3pBGx_-HzW9di9p_4rnptbFI4adk9pktSVtlLB0cs45SU6uzp6VCJUj9-q-MP8QBqL6i7u2HV9e-kuBJgyIZD4t0PsazpJNu4rDlBAymYzw73ptLPjCwsUkckUz4Xhy1WmR8mpmuG0nuSWzlDlWKiaPgeMhA0Cnp4BV47zplvQ-r60VkarCg9JGHQNmIkQfG3llcjc-ZK4UKVkrFZynXhcCsp1ry7TwfRnwtXwQ1kZXDmeQxWFudhVaHwthraFF-fkHmYZpyTDrZQJY2Rn9nWO59ZHNh3I6-KiKdsNzv8Jl5T_dCUVPj7l3w',
|
|
87
87
|
config: {
|
|
88
|
-
appNo: '
|
|
88
|
+
appNo: 'MFX5TxlheIKbekZHKoeOVNlo'
|
|
89
89
|
},
|
|
90
90
|
providerId: 'demo-provider'
|
|
91
91
|
}
|
|
@@ -99,7 +99,9 @@ export var 携带历史记录实例 = {
|
|
|
99
99
|
var _providerRef$current2;
|
|
100
100
|
if ((_providerRef$current2 = providerRef.current) !== null && _providerRef$current2 !== void 0 && _providerRef$current2.chat) {
|
|
101
101
|
providerRef.current.chat({
|
|
102
|
-
text: '你好,AI!'
|
|
102
|
+
text: '你好,AI!',
|
|
103
|
+
// 上传文案
|
|
104
|
+
files: [] // 如果需要上传附件
|
|
103
105
|
});
|
|
104
106
|
} else {
|
|
105
107
|
console.log('XAdkWebProvider ref 未准备好或 chat 方法不存在');
|
|
@@ -128,16 +130,19 @@ export var 携带历史记录实例 = {
|
|
|
128
130
|
},
|
|
129
131
|
onMessage: function onMessage(data, message) {
|
|
130
132
|
return console.log(data, message);
|
|
133
|
+
},
|
|
134
|
+
onEvent: function onEvent(event) {
|
|
135
|
+
return console.log(event);
|
|
131
136
|
}
|
|
132
137
|
}))
|
|
133
138
|
})
|
|
134
139
|
});
|
|
135
140
|
},
|
|
136
141
|
args: {
|
|
137
|
-
url: 'https://m-poc-
|
|
138
|
-
token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.
|
|
142
|
+
url: 'https://m-poc-test.zaxline.com',
|
|
143
|
+
token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiVjRTT0htSm8zWmVhNFJOdWc3WFgyQT09Iiwic2NvcGUiOlsidzVvRjZ5bFdzemtubzRadk5EMXB2Z3FIIl0sImV4cCI6MTc2ODIyODc2MywianRpIjoiMW1YSkxMS3FqeGRPNHhicVFQYkY0TkVaYTEwIiwiY2xpZW50X2lkIjoidzVvRjZ5bFdzemtubzRadk5EMXB2Z3FIIn0.HPa81m_zQBPg-bOb_WRM4JCnGjdxChwwBZdjwwpn6FHXMIMnbCqG9707zmlcHCS_ut0aaFNXn08liEUiP8R5BPq8Et6MnrjgpAIsNIAa7BnLXpqp6yIrZOkLiibG-BQg0bXQD4tV0XdAfD4sgWWRUJzxfzchgtKC-9ub_JWHuh6X8KZ_Trj0Ykus5cIaR6T4HForY6Ra6OczlVwAyEAFH9E9v9WpCc7eJmV6YnoUiHmWwGdQQtoLBrRCpb9uA6tqX1B1KPtJsgLXQ72Pb5ysxkrW39mzeCfN2Hf9dvZaD_74jPLRbuyx0bo5cDAcJUGu5eqXPKK2YWzSc3O9O-SzCQ',
|
|
139
144
|
config: {
|
|
140
|
-
appNo: '
|
|
145
|
+
appNo: 'w5oF6ylWszkno4ZvND1pvgqH',
|
|
141
146
|
session: {
|
|
142
147
|
showSessionList: true
|
|
143
148
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Button","XAdkWebProvider","jsx","_jsx","jsxs","_jsxs","meta","title","component","parameters","layout","docs","description","tags","argTypes","config","table","type","summary","detail","category","decorators","Story","style","padding","children","单聊天窗口实例","render","args","providerRef","useRef","handleSendMessage","_providerRef$current","current","chat","text","console","log","display","flexDirection","gap","marginRight","justifyContent","onClick","maxWidth","height","_objectSpread","ref","url","token","appNo","providerId","携带历史记录实例","_providerRef$current2","width","onError","providerError","onSuccess","appInfo","onStream","data","onMessage","message","session","showSessionList"],"sources":["../../../../src/components/XAdkWebProvider/XAdkWebProvider.stories.tsx"],"sourcesContent":["import React from 'react';\nimport type { Meta, StoryObj } from '@storybook/react-vite';\nimport { Button } from 'antd';\nimport XAdkWebProvider from './index';\n\nconst meta: Meta<typeof XAdkWebProvider> = {\n title: 'AI组件/XAdkWebProvider AI容器',\n component: XAdkWebProvider,\n parameters: {\n layout: 'centered',\n docs: {\n description: {\n component: 'AI 聊天机器人容器组件,提供全局上下文和消息管理功能。',\n },\n },\n },\n tags: ['autodocs'],\n argTypes: {\n config: {\n description: '配置信息',\n table: {\n type: {\n summary: 'XAdkWebProviderConfig',\n detail: `{\n appNo?: string; // 应用唯一编号\n }`,\n },\n category: '配置选项',\n },\n },\n },\n // 添加装饰器,确保组件有必要的上下文\n decorators: [\n (Story) => (\n <div style={{ padding: '20px' }}>\n <Story />\n </div>\n ),\n ],\n};\n\nexport default meta;\ntype Story = StoryObj<typeof meta>;\n\n// 使用 Provider 的 XAiChatbot\nexport const 单聊天窗口实例: Story = {\n render: (args) => {\n const providerRef = React.useRef<any>(null);\n\n const handleSendMessage = () => {\n if (providerRef.current?.chat) {\n providerRef.current.chat({ text: '你好,AI!' });\n } else {\n console.log('XAdkWebProvider ref 未准备好或 chat 方法不存在');\n }\n };\n\n return (\n <div style={{ display: 'flex' }}>\n <div style={{ display: 'flex', flexDirection: 'column', gap: '12px', marginRight: '24px', justifyContent: 'center' }}>\n <Button type=\"primary\" onClick={handleSendMessage}>发送消息</Button>\n </div>\n <div style={{ maxWidth: '350px', height: '600px' }}>\n <XAdkWebProvider\n ref={providerRef}\n {...args}\n // onError={(providerError) => console.log(providerError)}\n // onMessage={(data) => console.log(data)}\n >\n </XAdkWebProvider>\n </div>\n </div>\n );\n },\n args: {\n url: 'https://m-poc-dev.zaxline.com',\n token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.
|
|
1
|
+
{"version":3,"names":["React","Button","XAdkWebProvider","jsx","_jsx","jsxs","_jsxs","meta","title","component","parameters","layout","docs","description","tags","argTypes","config","table","type","summary","detail","category","decorators","Story","style","padding","children","单聊天窗口实例","render","args","providerRef","useRef","handleSendMessage","_providerRef$current","current","chat","text","console","log","display","flexDirection","gap","marginRight","justifyContent","onClick","maxWidth","height","_objectSpread","ref","url","token","appNo","providerId","携带历史记录实例","_providerRef$current2","files","width","onError","providerError","onSuccess","appInfo","onStream","data","onMessage","message","onEvent","event","session","showSessionList"],"sources":["../../../../src/components/XAdkWebProvider/XAdkWebProvider.stories.tsx"],"sourcesContent":["import React from 'react';\nimport type { Meta, StoryObj } from '@storybook/react-vite';\nimport { Button } from 'antd';\nimport XAdkWebProvider from './index';\n\nconst meta: Meta<typeof XAdkWebProvider> = {\n title: 'AI组件/XAdkWebProvider AI容器',\n component: XAdkWebProvider,\n parameters: {\n layout: 'centered',\n docs: {\n description: {\n component: 'AI 聊天机器人容器组件,提供全局上下文和消息管理功能。',\n },\n },\n },\n tags: ['autodocs'],\n argTypes: {\n config: {\n description: '配置信息',\n table: {\n type: {\n summary: 'XAdkWebProviderConfig',\n detail: `{\n appNo?: string; // 应用唯一编号\n }`,\n },\n category: '配置选项',\n },\n },\n },\n // 添加装饰器,确保组件有必要的上下文\n decorators: [\n (Story) => (\n <div style={{ padding: '20px' }}>\n <Story />\n </div>\n ),\n ],\n};\n\nexport default meta;\ntype Story = StoryObj<typeof meta>;\n\n// 使用 Provider 的 XAiChatbot\nexport const 单聊天窗口实例: Story = {\n render: (args) => {\n const providerRef = React.useRef<any>(null);\n\n const handleSendMessage = () => {\n if (providerRef.current?.chat) {\n providerRef.current.chat({ text: '你好,AI!' });\n } else {\n console.log('XAdkWebProvider ref 未准备好或 chat 方法不存在');\n }\n };\n\n return (\n <div style={{ display: 'flex' }}>\n <div style={{ display: 'flex', flexDirection: 'column', gap: '12px', marginRight: '24px', justifyContent: 'center' }}>\n <Button type=\"primary\" onClick={handleSendMessage}>发送消息</Button>\n </div>\n <div style={{ maxWidth: '350px', height: '600px' }}>\n <XAdkWebProvider\n ref={providerRef}\n {...args}\n // onError={(providerError) => console.log(providerError)}\n // onMessage={(data) => console.log(data)}\n >\n </XAdkWebProvider>\n </div>\n </div>\n );\n },\n args: {\n url: 'https://m-poc-dev.zaxline.com',\n token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiVjRTT0htSm8zWmVhNFJOdWc3WFgyQT09Iiwic2NvcGUiOlsiTUZYNVR4bGhlSUtiZWtaSEtvZU9WTmxvIl0sImV4cCI6MTc2Nzk1MjM0NywianRpIjoiSHpLMll4cVdjSTA3QWtmOHlsQXYwV0w0aE5jIiwiY2xpZW50X2lkIjoiTUZYNVR4bGhlSUtiZWtaSEtvZU9WTmxvIn0.AjABoyZFxAACkfy-ywLlfaJd6YY0Ir3pBGx_-HzW9di9p_4rnptbFI4adk9pktSVtlLB0cs45SU6uzp6VCJUj9-q-MP8QBqL6i7u2HV9e-kuBJgyIZD4t0PsazpJNu4rDlBAymYzw73ptLPjCwsUkckUz4Xhy1WmR8mpmuG0nuSWzlDlWKiaPgeMhA0Cnp4BV47zplvQ-r60VkarCg9JGHQNmIkQfG3llcjc-ZK4UKVkrFZynXhcCsp1ry7TwfRnwtXwQ1kZXDmeQxWFudhVaHwthraFF-fkHmYZpyTDrZQJY2Rn9nWO59ZHNh3I6-KiKdsNzv8Jl5T_dCUVPj7l3w',\n config: {\n appNo: 'MFX5TxlheIKbekZHKoeOVNlo',\n },\n providerId: 'demo-provider',\n },\n};\n\n\n// 使用 Provider 的 XAiChatbot\nexport const 携带历史记录实例: Story = {\n render: (args) => {\n const providerRef = React.useRef<any>(null);\n\n const handleSendMessage = () => {\n if (providerRef.current?.chat) {\n providerRef.current.chat({\n text: '你好,AI!', // 上传文案\n files: [], // 如果需要上传附件\n });\n } else {\n console.log('XAdkWebProvider ref 未准备好或 chat 方法不存在');\n }\n };\n\n return (\n <div style={{ display: 'flex' }}>\n <div style={{ height: '600px', width: '100vw' }}>\n <XAdkWebProvider\n ref={providerRef}\n {...args}\n onError={(providerError) => console.log(providerError)}\n onSuccess={(appInfo) => console.log(appInfo)}\n onStream={(data) => console.log(data)}\n onMessage={(data, message) => console.log(data, message)}\n onEvent={(event) => console.log(event)}\n />\n </div>\n </div>\n );\n },\n args: {\n url: 'https://m-poc-test.zaxline.com',\n token: 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiVjRTT0htSm8zWmVhNFJOdWc3WFgyQT09Iiwic2NvcGUiOlsidzVvRjZ5bFdzemtubzRadk5EMXB2Z3FIIl0sImV4cCI6MTc2ODIyODc2MywianRpIjoiMW1YSkxMS3FqeGRPNHhicVFQYkY0TkVaYTEwIiwiY2xpZW50X2lkIjoidzVvRjZ5bFdzemtubzRadk5EMXB2Z3FIIn0.HPa81m_zQBPg-bOb_WRM4JCnGjdxChwwBZdjwwpn6FHXMIMnbCqG9707zmlcHCS_ut0aaFNXn08liEUiP8R5BPq8Et6MnrjgpAIsNIAa7BnLXpqp6yIrZOkLiibG-BQg0bXQD4tV0XdAfD4sgWWRUJzxfzchgtKC-9ub_JWHuh6X8KZ_Trj0Ykus5cIaR6T4HForY6Ra6OczlVwAyEAFH9E9v9WpCc7eJmV6YnoUiHmWwGdQQtoLBrRCpb9uA6tqX1B1KPtJsgLXQ72Pb5ysxkrW39mzeCfN2Hf9dvZaD_74jPLRbuyx0bo5cDAcJUGu5eqXPKK2YWzSc3O9O-SzCQ',\n config: {\n appNo: 'w5oF6ylWszkno4ZvND1pvgqH',\n session: {\n showSessionList: true,\n },\n },\n providerId: 'demo-provider',\n },\n};"],"mappings":"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"}
|
|
@@ -9,6 +9,7 @@ import copy from 'copy-to-clipboard';
|
|
|
9
9
|
import { XProvider } from '@ant-design/x';
|
|
10
10
|
import { ExclamationCircleFilled, ReloadOutlined, CopyOutlined, LikeFilled, LikeOutlined } from '@ant-design/icons';
|
|
11
11
|
import { MOBILE_MAX_WIDTH, API_SUCCESS_CODE } from "../../constants";
|
|
12
|
+
import { EventCode } from "../../types";
|
|
12
13
|
import XAdkChatbot from "../XAdkChatbot";
|
|
13
14
|
import DislikeFeedback from "../DislikeFeedback";
|
|
14
15
|
import useADKChat from "../../hooks/useADKChat";
|
|
@@ -27,6 +28,7 @@ var XAdkWebProvider = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
|
27
28
|
config = _ref.config,
|
|
28
29
|
_ref$providerId = _ref.providerId,
|
|
29
30
|
providerId = _ref$providerId === void 0 ? 'defaultId' : _ref$providerId,
|
|
31
|
+
onEvent = _ref.onEvent,
|
|
30
32
|
onSuccess = _ref.onSuccess,
|
|
31
33
|
onStream = _ref.onStream,
|
|
32
34
|
onMessage = _ref.onMessage,
|
|
@@ -431,9 +433,22 @@ var XAdkWebProvider = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
|
431
433
|
isNarrow: false,
|
|
432
434
|
sessionList: sessionList,
|
|
433
435
|
onActiveChange: function onActiveChange(key) {
|
|
434
|
-
|
|
436
|
+
setCurrentSessionDetail(key);
|
|
437
|
+
onEvent === null || onEvent === void 0 || onEvent({
|
|
438
|
+
code: EventCode.SESSION_SWITCH,
|
|
439
|
+
message: '切换会话',
|
|
440
|
+
data: {
|
|
441
|
+
sessionId: key
|
|
442
|
+
}
|
|
443
|
+
});
|
|
444
|
+
},
|
|
445
|
+
onNewChat: function onNewChat() {
|
|
446
|
+
clearChat === null || clearChat === void 0 || clearChat();
|
|
447
|
+
onEvent === null || onEvent === void 0 || onEvent({
|
|
448
|
+
code: EventCode.SESSION_CREATE,
|
|
449
|
+
message: '开启新会话'
|
|
450
|
+
});
|
|
435
451
|
},
|
|
436
|
-
onNewChat: clearChat,
|
|
437
452
|
activeKey: currentSessionId,
|
|
438
453
|
menu: menuConfig
|
|
439
454
|
}), /*#__PURE__*/_jsx("div", {
|