File size: 3,041 Bytes
2376116
 
 
 
 
 
 
 
 
 
 
41c8295
2376116
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
53ed7bb
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2376116
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
$(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();
    });

});