Skip to content

Commit

Permalink
Adapt Vllm response format (opea-project#379)
Browse files Browse the repository at this point in the history
Signed-off-by: Yue, Wenjiao <[email protected]>
  • Loading branch information
WenjiaoYue authored Jul 5, 2024
1 parent 26d4ff1 commit 0345414
Showing 1 changed file with 38 additions and 30 deletions.
68 changes: 38 additions & 30 deletions ChatQnA/docker/ui/svelte/src/routes/+page.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -32,12 +32,10 @@
} from "$lib/shared/Utils";
import { fetchTextStream } from "$lib/network/chat/Network";
import LoadingAnimation from "$lib/shared/components/loading/Loading.svelte";
import { browser } from "$app/environment";
import "driver.js/dist/driver.css";
import "$lib/assets/layout/css/driver.css";
import UploadFile from "$lib/shared/components/upload/uploadFile.svelte";
import PaperAirplane from "$lib/assets/chat/svelte/PaperAirplane.svelte";
import Gallery from "$lib/shared/components/chat/gallery.svelte";
import Scrollbar from "$lib/shared/components/scrollbar/Scrollbar.svelte";
import ChatMessage from "$lib/modules/chat/ChatMessage.svelte";
Expand Down Expand Up @@ -90,43 +88,42 @@
const eventSource = await fetchTextStream(query, knowledge_1);
eventSource.addEventListener("message", (e: any) => {
let Msg = e.data;
if (Msg.startsWith("b")) {
let currentMsg = Msg.slice(2, -1);
const containsNewLine = /\\n/.test(currentMsg);
let requiresDecoding = false;
let msg = e.data;
console.log("msg", msg);
currentMsg = currentMsg.replace(/\\n/g, "\n");
const handleDecodedMessage = (decodedMsg: string) => {
if (decodedMsg !== "</s>") {
decodedMsg = decodedMsg.replace(/\\n/g, "\n");
}
if (chatMessages[chatMessages.length - 1].role === MessageRole.User) {
chatMessages.push({
role: MessageRole.Assistant,
type: MessageType.Text,
content: decodedMsg,
time: startSendTime,
});
} else {
chatMessages[chatMessages.length - 1].content += decodedMsg;
}
scrollToBottom(scrollToDiv);
};
if (msg.startsWith("b")) {
let currentMsg = msg.slice(2, -1);
if (/\\x[\dA-Fa-f]{2}/.test(currentMsg)) {
currentMsg = decodeEscapedBytes(currentMsg);
requiresDecoding = true;
} else if (/\\u[\dA-Fa-f]{4}/.test(currentMsg)) {
currentMsg = decodeUnicode(currentMsg);
requiresDecoding = true;
}
if (containsNewLine && requiresDecoding) {
currentMsg += "\n";
}
if (chatMessages[chatMessages.length - 1].role == MessageRole.User) {
chatMessages = [
...chatMessages,
{
role: MessageRole.Assistant,
type: MessageType.Text,
content: currentMsg,
time: startSendTime,
},
];
} else {
let content = chatMessages[chatMessages.length - 1].content as string;
chatMessages[chatMessages.length - 1].content = content + currentMsg;
}
scrollToBottom(scrollToDiv);
} else if (Msg === "[DONE]") {
let startTime = chatMessages[chatMessages.length - 1].time;
handleDecodedMessage(currentMsg);
} else if (msg === "[DONE]") {
console.log("Done");
let startTime = chatMessages[chatMessages.length - 1].time;
loading = false;
let totalTime = parseFloat(
((getCurrentTimeStamp() - startTime) / 1000).toFixed(2)
Expand All @@ -137,8 +134,19 @@
}
storeMessages();
} else {
if (/\\x[\dA-Fa-f]{2}/.test(msg)) {
msg = decodeEscapedBytes(msg);
} else if (/\\u[\dA-Fa-f]{4}/.test(msg)) {
msg = decodeUnicode(msg);
}
let currentMsg = msg.replace(/"/g, "").replace(/\\n/g, "\n");
handleDecodedMessage(currentMsg);
}
});
eventSource.stream();
};
Expand Down

0 comments on commit 0345414

Please sign in to comment.