File size: 4,011 Bytes
4f737fe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123

// sets the delay time for each request
const DELAYTIME = 500
 // Variable to store the backend server data
let DATA;


// Fetch data from the backend server
function postMessage(url="https://jacobinathanialpeterson-chatbox.hf.space/postMessage") {
	const controller = new AbortController();
	const abortSignal = controller.signal;
	fetch(url, { 
			method: 'POST',
			headers: {
				'Content-Type': 'application/json'
			},
			body: JSON.stringify({nameInput: document.getElementById("nameInputBox").value, messageInput: document.getElementById("messageInputBox").value}),
			signal: abortSignal
		})
		.then(response => { if (!response.ok) { throw new Error('Network response was not ok.') } return response.json() })
		.then(data => {
			controller.abort(); 
		})
		.catch(error => { if (error.name === 'AbortError') { console.log('Fetch aborted:', error.message) } else { console.error('Error fetching data:', error.message) }});
}

function getMessages(url="https://jacobinathanialpeterson-chatbox.hf.space/messages") {
	const controller = new AbortController();
	const abortSignal = controller.signal;
	fetch(url, {signal: abortSignal})
		.then(response => { if (!response.ok) { throw new Error('Network response was not ok.') } return response.json() })
		.then(data => {
			// Get the keys of the object
			const keys = Object.keys(data);

			// Sort the keys based on their natural order
			keys.sort((a, b) => {
			  // Extract numeric part of keys
			  const numA = parseInt(a.match(/\d+/)[0]);
			  const numB = parseInt(b.match(/\d+/)[0]);
			  return numA - numB;
			});

			// Create a new object with sorted keys
			DATA = {};
			keys.forEach(key => {
			  DATA[key] = data[key];
			});

			controller.abort(); 
		})
		.catch(error => { if (error.name === 'AbortError') { console.log('Fetch aborted:', error.message) } else { console.error('Error fetching data:', error.message) }});
}



// Variable to track if the user is at the bottom of the chat box
let atBottom = true;

// Update the UI with fetched messages
function updateUI() {
  const messagesContainer = document.getElementById("messages");
  const isAtBottom = messagesContainer.scrollHeight - messagesContainer.scrollTop === messagesContainer.clientHeight;

  let elementValue = '';
  if (DATA) {
    Object.entries(DATA).forEach(([key, value]) => {
      elementValue +=
        `<div class="msg" id="${key}">
          <div class="nme">${value.name}: </div>
          <div class="body">${value.message}</div>
        </div>`;
    });
  }
  messagesContainer.innerHTML = elementValue;

  if (atBottom || isAtBottom) {
    messagesContainer.scrollTop = messagesContainer.scrollHeight;
  }
  atBottom = isAtBottom;
}

// Your existing interval for getting messages and updating UI
setInterval(getMessages, 100);
setTimeout(() => {
  setInterval(updateUI, 100);
}, DELAYTIME);

// Listen for scroll events
document.getElementById("messages").addEventListener("scroll", () => {
  const messagesContainer = document.getElementById("messages");
  const isAtBottom = messagesContainer.scrollHeight - messagesContainer.scrollTop === messagesContainer.clientHeight;
  atBottom = isAtBottom;
});


// ... (your existing code)

// Function to handle sending message on "Enter" key press
function handleKeyPress(event) {
  if (event.keyCode === 13) {
    event.preventDefault(); // Prevent the default behavior (e.g., form submission)
    postMessage(); // Call the postMessage function when "Enter" is pressed
  }
}

// Add event listener to the message input field
document.getElementById("messageInputBox").addEventListener("keypress", handleKeyPress);

// ... (rest of your existing code)


// document.getElementById("nameInputBox").value
// document.getElementById(messageInputBox).value



// function updateUI() {
	// var targetElement = document.getElementById("messages"); // Replace "targetElementId" with the ID of the element
	// targetElement.innerHTML = "<p>"+JSON.stringify(DATA)+"</p>";
// }

// setInterval(updateUI, 1000);