diff --git a/web/components/chat/chat-container.tsx b/web/components/chat/chat-container.tsx
index a178299f7..a38ea6771 100644
--- a/web/components/chat/chat-container.tsx
+++ b/web/components/chat/chat-container.tsx
@@ -33,7 +33,7 @@ const ChatContainer = () => {
const contextTemp = list[list.length - 1]?.context;
if (contextTemp) {
try {
- const contextObj = JSON.parse(contextTemp);
+ const contextObj = typeof contextTemp === 'string' ? JSON.parse(contextTemp) : contextTemp;
setChartsData(contextObj?.template_name === 'report' ? contextObj?.charts : undefined);
} catch (e) {
setChartsData(undefined);
diff --git a/web/components/chat/db-editor.tsx b/web/components/chat/db-editor.tsx
index 8c4994bdb..a1fdf153a 100644
--- a/web/components/chat/db-editor.tsx
+++ b/web/components/chat/db-editor.tsx
@@ -516,7 +516,7 @@ function DbEditor() {
key: i + '',
label: item?.title,
children: (
-
+
{
diff --git a/web/hooks/use-chat.ts b/web/hooks/use-chat.ts
index 937947ee8..c7c7f2fa5 100644
--- a/web/hooks/use-chat.ts
+++ b/web/hooks/use-chat.ts
@@ -1,7 +1,8 @@
import { EventStreamContentType, fetchEventSource } from '@microsoft/fetch-event-source';
import { message } from 'antd';
-import { useCallback, useEffect, useMemo } from 'react';
+import { useCallback, useContext, useEffect, useMemo } from 'react';
import i18n from '@/app/i18n';
+import { ChatContext } from '@/app/chat-context';
type Props = {
queryAgentURL?: string;
@@ -19,6 +20,7 @@ type ChatParams = {
const useChat = ({ queryAgentURL = '/api/v1/chat/completions' }: Props) => {
const ctrl = useMemo(() => new AbortController(), []);
+ const { scene } = useContext(ChatContext);
const chat = useCallback(
async ({ data, chatId, onMessage, onClose, onDone, onError }: ChatParams) => {
@@ -61,16 +63,25 @@ const useChat = ({ queryAgentURL = '/api/v1/chat/completions' }: Props) => {
onmessage: (event) => {
let message = event.data;
try {
- message = JSON.parse(message).vis;
+ if (scene === 'chat_agent') {
+ message = JSON.parse(message).vis;
+ } else {
+ message = JSON.parse(message);
+ }
} catch (e) {
message.replaceAll('\\n', '\n');
}
- if (message === '[DONE]') {
- onDone?.();
- } else if (message?.startsWith('[ERROR]')) {
- onError?.(message?.replace('[ERROR]', ''));
+ if (typeof message === 'string') {
+ if (message === '[DONE]') {
+ onDone?.();
+ } else if (message?.startsWith('[ERROR]')) {
+ onError?.(message?.replace('[ERROR]', ''));
+ } else {
+ onMessage?.(message);
+ }
} else {
onMessage?.(message);
+ onDone?.();
}
},
});