Spaces:
Sleeping
Sleeping
File size: 2,077 Bytes
30201f2 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | let ws = null;
function uploadFile() {
const file = document.getElementById("fileInput").files[0];
if (!file) return alert("Choose a file!");
const formData = new FormData();
formData.append("file", file);
// Show spinner
document.getElementById("spinner").style.display = "block";
fetch("/upload", { method: "POST", body: formData })
.then(res => res.json())
.then(data => {
// Hide spinner
document.getElementById("spinner").style.display = "none";
if (data.status === "success") {
document.getElementById("uploadStatus").innerText = "Uploaded!";
startChat();
} else {
alert(data.message);
}
})
.catch(err => {
document.getElementById("spinner").style.display = "none";
alert("Upload failed");
});
}
function startChat() {
ws = new WebSocket(`ws://${location.host}/ws`);
// Show chat card
document.getElementById("chatCard").style.display = "block";
ws.onmessage = (e) => {
appendMessage("Bot: " + e.data);
};
}
function sendMessage() {
const input = document.getElementById("msg");
const text = input.value.trim();
if (!text) return;
appendMessage("You: " + text);
input.value = "";
// Show chat spinner
document.getElementById("chatSpinner").style.display = "block";
// Send message to WebSocket
ws.send(text);
// Wait for backend reply
ws.onmessage = (e) => {
// Hide spinner
document.getElementById("chatSpinner").style.display = "none";
appendMessage("Bot: " + e.data);
// Keep WebSocket listener alive for next message
ws.onmessage = (e) => {
document.getElementById("chatSpinner").style.display = "none";
appendMessage("Bot: " + e.data);
};
};
}
function appendMessage(msg) {
const box = document.getElementById("messages");
box.innerHTML += msg + "<br>";
box.scrollTop = box.scrollHeight;
}
|