<!DOCTYPE html>
<html lang="en">
    <head>
            <meta charset="utf-8">
            <title>DEMO Websocket over HTML</title>
            <link rel="icon" type="image/png" href="favicon.png">
            <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no, shrink-to-fit=no">
            <meta name="author" content="Andros Fenollosa">
            <meta name="generator" content="Django">
            <meta name="keywords" content="html, css, javascript">
            <meta name="description" content="my description...">
            <link rel="stylesheet" href="https://unpkg.com/spectre.css/dist/spectre.min.css">
            <link rel="stylesheet" href="https://unpkg.com/spectre.css/dist/spectre-exp.min.css">
            <link rel="stylesheet" href="https://unpkg.com/spectre.css/dist/spectre-icons.min.css">
        </head>
    <body>
        <div class="container">
            <nav id="nav">
                <ul class="tab tab-block">
                    <li class="tab-item">
                        <a id="link-all" href="#">All</a>
                    </li>
                    <li class="tab-item">
                        <a id="link-about" href="#">About</a>
                    </li>
                </ul>
            </nav>
            <main id="main">
                {% include 'partials/blog/all_articles.html' %}
            </main>
        </div>
        <script>
            document.$CHAT_SOCKET = new WebSocket('ws://my-demo.localhost/ws/blog/{{ CHANNEL}}/');

              // Conectado
             document.$CHAT_SOCKET.addEventListener('open', () => {
                 console.log('Connect');
             });
             // Desconectado
             document.$CHAT_SOCKET.addEventListener('close', () => {
                  console.log('Disconnect');
              });

             // Recibir mensaje y dibujar
             document.$CHAT_SOCKET.addEventListener('message', (event) => {
                const NEW_DATA = JSON.parse(event.data);
                const rangeHTML = document.createRange().createContextualFragment(NEW_DATA.html);
                document.querySelector(NEW_DATA.selector).innerHTML = '';
                document.querySelector(NEW_DATA.selector).appendChild(rangeHTML);
            });


            document.querySelector('#link-about').addEventListener('click', (event) => {

                event.preventDefault();
                document.$CHAT_SOCKET.send(JSON.stringify({
                    selector: "#main",
                    template: "partials/website/about.html",
                    data: {}
                }));
             });

            document.querySelector('#link-all').addEventListener('click', (event) => {

                event.preventDefault();
                document.$CHAT_SOCKET.send(JSON.stringify({
                    selector: "#main",
                    template: "partials/blog/all_articles.html",
                    data: {}
                }));
             });
        </script>
    </body>
</html>