From da09f50253be12f91a6c48c636243992e27aa6f7 Mon Sep 17 00:00:00 2001 From: Louis Date: Wed, 4 Dec 2024 16:45:00 +0700 Subject: [PATCH] fix: react-markdown crash on code highlighting - threads switching do not take effect sometime --- web/package.json | 2 +- .../Thread/ThreadCenterPanel/ChatBody/index.tsx | 10 ++++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/web/package.json b/web/package.json index 6954a23bbc..e0f8558826 100644 --- a/web/package.json +++ b/web/package.json @@ -38,7 +38,7 @@ "react-icons": "^4.12.0", "react-markdown": "^9.0.1", "react-toastify": "^9.1.3", - "rehype-highlight": "^6.0.0", + "rehype-highlight": "^7.0.1", "rehype-highlight-code-lines": "^1.0.4", "rehype-katex": "^7.0.1", "rehype-raw": "^7.0.0", diff --git a/web/screens/Thread/ThreadCenterPanel/ChatBody/index.tsx b/web/screens/Thread/ThreadCenterPanel/ChatBody/index.tsx index ec5875bcb9..9077a351ac 100644 --- a/web/screens/Thread/ThreadCenterPanel/ChatBody/index.tsx +++ b/web/screens/Thread/ThreadCenterPanel/ChatBody/index.tsx @@ -14,9 +14,11 @@ import LoadModelError from '../LoadModelError' import EmptyThread from './EmptyThread' import { getCurrentChatMessagesAtom } from '@/helpers/atoms/ChatMessage.atom' +import { activeThreadAtom } from '@/helpers/atoms/Thread.atom' const ChatConfigurator = memo(() => { const messages = useAtomValue(getCurrentChatMessagesAtom) + const currentThread = useAtomValue(activeThreadAtom) const [current, setCurrent] = useState([]) const loadModelError = useAtomValue(loadModelErrorAtom) @@ -31,12 +33,12 @@ const ChatConfigurator = memo(() => { useEffect(() => { if ( - messages?.length !== current?.length || - !isMessagesIdentificial(messages, current) + !isMessagesIdentificial(messages, current) || + messages.some((e) => e.thread_id !== currentThread?.id) ) { setCurrent(messages) } - }, [messages, current, loadModelError]) + }, [messages, current, loadModelError, currentThread]) if (!messages.length) return return ( @@ -119,7 +121,7 @@ const ChatBody = memo( > {items.map((virtualRow) => (