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;
}