-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
94 lines (74 loc) · 2.31 KB
/
script.js
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
const apiUrl = "https://worker-green-forest-c926.neealdon3-3f0.workers.dev/:API";
let uuid = '';
function generateUUID() {
let newUUID = '';
const chars = 'abcdef0123456789';
for (let i = 0; i < 32; i++) {
const charIndex = Math.floor(Math.random() * chars.length);
newUUID += chars[charIndex];
if (i === 7 || i === 11 || i === 15 || i === 19) {
newUUID += '-';
}
}
return newUUID;
}
function renderChatHistory(messages) {
const chatHistoryDiv = document.getElementById('chat-history');
chatHistoryDiv.innerHTML = '';
let userMessageSeen = false;
messages.forEach(message => {
const role = message.role;
let content = '';
if (message.content) {
if (typeof message.content === 'string') {
content = message.content;
} else if (message.content.response) {
content = message.content.response;
}
}
if (role === 'user') {
userMessageSeen = true;
}
if (userMessageSeen || role === 'user') {
let messageText;
if (role === 'system') {
messageText = `Bot: ${content}`;
} else {
messageText = `You: ${content}`;
}
const pElement = document.createElement('p');
pElement.textContent = messageText;
chatHistoryDiv.appendChild(pElement);
}
});
}
async function sendMessage(event) {
event.preventDefault();
const userInputField = document.getElementById('user-message');
const userQuery = userInputField.value.trim();
if (userQuery === '') {
return;
}
const chatHistoryDiv = document.getElementById('chat-history');
const loadingMessage = document.createElement('p');
loadingMessage.textContent = 'Loading...';
chatHistoryDiv.appendChild(loadingMessage);
try {
const response = await fetch(`${apiUrl}/${uuid}?q=${encodeURIComponent(userQuery)}`);
if (!response.ok) {
throw new Error('Error occurred while fetching data from API');
}
const jsonResponse = await response.json();
const messages = jsonResponse[0].response;
chatHistoryDiv.removeChild(loadingMessage);
renderChatHistory(messages);
userInputField.value = '';
} catch (error) {
console.log(error);
}
}
const messageForm = document.getElementById('message-form');
if (!uuid) {
uuid = generateUUID();
}
messageForm.addEventListener('submit', sendMessage);