makerlab-bot / static /chatbot.js
rohan13's picture
widget minimizing
53ed7bb
raw
history blame
3.04 kB
$(document).ready(function() {
// Initialize variables
var $messages = $('.chat-messages');
var $input = $('.chat-input input');
var $submit = $('.chat_submit');
var session_id = '';
$messages.children().each(function() {
$(this).addClass('chat-message');
});
// Initialize SocketIO connection
var socket = io.connect('https://' + document.domain + ':' + location.port);
// Function to send message to Flask-SocketIO app
function sendMessage(message) {
console.log("message: " + message )
socket.emit('message', {'question': message});
}
// Function to display message
function displayMessage(message, isUser) {
var $message = $('<div>').addClass('chat-message round');
var $messageText = $('<p>').html(message.replace(/(https?:\/\/[^\s]+)/g, '<a href="$1">$1</a>'));
$message.append($messageText);
if (isUser) {
$message.addClass('user');
} else {
$message.addClass('bot')
}
if ($messages) {
$messages.append($message);
if ($messages[0]) {
$messages.animate({scrollTop: $messages[0].scrollHeight}, 300);
}
} else {
$('.chat-container').append($message);
$('.chat-container').animate({scrollTop: 0}, 300);
}
}
socket.on('response', function(data) {
console.log("Received response: " + data.response)
var response = data.response;
displayMessage(response, false);
});
// Send message on submit
$submit.click(function(event) {
event.preventDefault();
var message = $input.val().trim();
console.log("Submit clicked: " + message)
if (message !== '') {
displayMessage(message, true);
sendMessage(message);
$input.val('');
}
});
// Send message on enter key press
$input.keydown(function(event) {
if (event.keyCode === 13) {
event.preventDefault();
$submit.click();
}
});
// Initial message
displayMessage('Ask me anything');
// Function to minimize widget
function minimizeWidget() {
$chatContainer.toggleClass('minimized');
if ($chatContainer.hasClass('minimized')) {
$chatContainer.find('.chat-header h4').hide();
$chatContainer.find('.chat-input').hide();
$chatContainer.find('.chat-body').hide();
$chatContainer.find('.chat-header i.fa-close').removeClass('fa-close').addClass('fa-comment');
} else {
$chatContainer.find('.chat-header h4').show();
$chatContainer.find('.chat-input').show();
$chatContainer.find('.chat-body').show();
$chatContainer.find('.chat-header i.fa-comment').removeClass('fa-comment').addClass('fa-close');
}
}
// Minimize widget on close button click
$('.chat-close').click(function() {
minimizeWidget();
});
});