mirror of
https://github.com/gradio-app/gradio.git
synced 2024-12-15 02:11:15 +08:00
Fix sharing on chatbot with spaces (#10125)
* changes * add changeset * add changeset --------- Co-authored-by: Ali Abid <aliabid94@gmail.com> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com>
This commit is contained in:
parent
8530b6e2f9
commit
b02c8b7d4f
6
.changeset/loose-toys-lie.md
Normal file
6
.changeset/loose-toys-lie.md
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
"@gradio/chatbot": patch
|
||||
"gradio": patch
|
||||
---
|
||||
|
||||
fix:Fix sharing on chatbot with spaces
|
@ -13,58 +13,52 @@ import type {
|
||||
import type { LoadedComponent } from "../../core/src/types";
|
||||
import { Gradio } from "@gradio/utils";
|
||||
export const format_chat_for_sharing = async (
|
||||
chat: [string | FileData | null, string | FileData | null][]
|
||||
chat: NormalisedMessage[]
|
||||
): Promise<string> => {
|
||||
let messages = await Promise.all(
|
||||
chat.map(async (message_pair) => {
|
||||
return await Promise.all(
|
||||
message_pair.map(async (message, i) => {
|
||||
if (message === null) return "";
|
||||
let speaker_emoji = i === 0 ? "😃" : "🤖";
|
||||
let html_content = "";
|
||||
chat.map(async (message) => {
|
||||
if (message.role === "system") return "";
|
||||
let speaker_emoji = message.role === "user" ? "😃" : "🤖";
|
||||
let html_content = "";
|
||||
|
||||
if (typeof message === "string") {
|
||||
const regexPatterns = {
|
||||
audio: /<audio.*?src="(\/file=.*?)"/g,
|
||||
video: /<video.*?src="(\/file=.*?)"/g,
|
||||
image: /<img.*?src="(\/file=.*?)".*?\/>|!\[.*?\]\((\/file=.*?)\)/g
|
||||
};
|
||||
if (message.type === "text") {
|
||||
const regexPatterns = {
|
||||
audio: /<audio.*?src="(\/file=.*?)"/g,
|
||||
video: /<video.*?src="(\/file=.*?)"/g,
|
||||
image: /<img.*?src="(\/file=.*?)".*?\/>|!\[.*?\]\((\/file=.*?)\)/g
|
||||
};
|
||||
|
||||
html_content = message;
|
||||
html_content = message.content;
|
||||
|
||||
for (let [_, regex] of Object.entries(regexPatterns)) {
|
||||
let match;
|
||||
for (let [_, regex] of Object.entries(regexPatterns)) {
|
||||
let match;
|
||||
|
||||
while ((match = regex.exec(message)) !== null) {
|
||||
const fileUrl = match[1] || match[2];
|
||||
const newUrl = await uploadToHuggingFace(fileUrl, "url");
|
||||
html_content = html_content.replace(fileUrl, newUrl);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (!message?.url) return "";
|
||||
const file_url = await uploadToHuggingFace(message.url, "url");
|
||||
if (message.mime_type?.includes("audio")) {
|
||||
html_content = `<audio controls src="${file_url}"></audio>`;
|
||||
} else if (message.mime_type?.includes("video")) {
|
||||
html_content = file_url;
|
||||
} else if (message.mime_type?.includes("image")) {
|
||||
html_content = `<img src="${file_url}" />`;
|
||||
}
|
||||
while ((match = regex.exec(message.content)) !== null) {
|
||||
const fileUrl = match[1] || match[2];
|
||||
const newUrl = await uploadToHuggingFace(fileUrl, "url");
|
||||
html_content = html_content.replace(fileUrl, newUrl);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (!message.content.value) return "";
|
||||
const url =
|
||||
message.content.component === "video"
|
||||
? message.content.value?.video.path
|
||||
: message.content.value;
|
||||
const file_url = await uploadToHuggingFace(url, "url");
|
||||
if (message.content.component === "audio") {
|
||||
html_content = `<audio controls src="${file_url}"></audio>`;
|
||||
} else if (message.content.component === "video") {
|
||||
html_content = file_url;
|
||||
} else if (message.content.component === "image") {
|
||||
html_content = `<img src="${file_url}" />`;
|
||||
}
|
||||
}
|
||||
|
||||
return `${speaker_emoji}: ${html_content}`;
|
||||
})
|
||||
);
|
||||
return `${speaker_emoji}: ${html_content}`;
|
||||
})
|
||||
);
|
||||
return messages
|
||||
.map((message_pair) =>
|
||||
message_pair.join(
|
||||
message_pair[0] !== "" && message_pair[1] !== "" ? "\n" : ""
|
||||
)
|
||||
)
|
||||
.join("\n");
|
||||
return messages.join("\n");
|
||||
};
|
||||
|
||||
export interface UndoRetryData {
|
||||
|
Loading…
Reference in New Issue
Block a user