var globals={ chatWindow:undefined, chatForm:undefined, userInput:undefined, stopGeneration:undefined, sendbtn:undefined, waitAnimation:undefined } function send_message(service_name, parameters){ var socket = io.connect('http://' + document.domain + ':' + location.port); globals.socket = socket socket.on('connect', function() { globals.sendbtn.style.display="block"; globals.waitAnimation.style.display="none"; globals.stopGeneration.style.display = "none"; entry_counter = 0; }); socket.on('disconnect', function() { console.log("disconnected") entry_counter = 0; }); socket.on('infos', function(msg) { if(globals.user_msg){ globals.user_msg.setSender(msg.user); globals.user_msg.setMessage(msg.message); globals.user_msg.setID(msg.id); } globals.bot_msg.setSender(msg.bot); globals.bot_msg.setID(msg.response_id); }); socket.on('waiter', function(msg) { globals.bot_msg.messageTextElement.innerHTML = `Remaining words ${Math.floor(msg.wait * 100)}%`; }); socket.on('message', function(msg) { text = msg.data; // For the other enrtries, these are just the text of the chatbot globals.bot_msg.messageTextElement.innerHTML = text; // scroll to bottom of chat window globals.chatWindow.scrollTop = globals.chatWindow.scrollHeight; }); socket.on('final',function(msg){ text = msg.data; globals.bot_msg.hiddenElement.innerHTML = text globals.bot_msg.messageTextElement.innerHTML = text globals.sendbtn.style.display="block"; globals.waitAnimation.style.display="none"; globals.stopGeneration.style.display = "none"; }); setTimeout(()=>{ globals.socket.emit(service_name, parameters); },1000); } function update_main(){ globals.chatWindow = document.getElementById('chat-window'); globals.chatForm = document.getElementById('chat-form'); globals.userInput = document.getElementById('user-input'); globals.stopGeneration = document.getElementById("stop-generation") globals.sendbtn = document.querySelector("#submit-input") globals.waitAnimation = document.querySelector("#wait-animation") globals.stopGeneration.addEventListener('click', (event) =>{ event.preventDefault(); console.log("Stop clicked"); fetch('/stop_gen') .then(response => response.json()) .then(data => { console.log(data); }); }) function submit_form(){ console.log("Submitting") // get user input and clear input field message = globals.userInput.value; globals.userInput.value = ''; globals.sendbtn.style.display="none"; globals.waitAnimation.style.display="block"; globals.stopGeneration.style.display = "block"; console.log("Sending message to bot") globals.user_msg = addMessage('',message, 0, 0, can_edit=true); globals.bot_msg = addMessage('', '', 0, 0, can_edit=true); // scroll to bottom of chat window globals.chatWindow.scrollTop = globals.chatWindow.scrollHeight; entry_counter = 0; send_message('generate_msg',{prompt: message}) //socket.emit('stream-text', {text: text}); } globals.chatForm.addEventListener('submit', event => { event.preventDefault(); submit_form(); }); globals.userInput.addEventListener("keyup", function(event) { // Check if Enter key was pressed while holding Shift // Also check if Shift + Ctrl keys were pressed while typing // These combinations override the submit action const shiftPressed = event.shiftKey; const ctrlPressed = event.ctrlKey && !event.metaKey; if ((!shiftPressed) && event.key === "Enter") { submit_form(); } // Restore original functionality for the remaining cases else if (!shiftPressed && ctrlPressed) { setTimeout(() => { globals.userInput.focus(); contentEditable.value += event.data; lastValue.innerHTML = globals.userInput.value; }, 0); } }); }