demo-HTML-over-WebSockets-i.../apps/front/templates/layouts/main.html

78 lines
3.2 KiB
HTML
Raw Permalink Normal View History

2021-03-11 21:58:29 +01:00
<!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>
2021-03-12 00:09:19 +01:00
<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">
2021-03-12 21:16:23 +01:00
{% include 'partials/blog/all_articles.html' %}
2021-03-12 00:09:19 +01:00
</main>
</div>
2021-03-11 21:58:29 +01:00
<script>
2021-03-21 12:53:47 +01:00
document.$CHAT_SOCKET = new WebSocket('ws://{{ DOMAIN }}/ws/blog/{{ CHANNEL}}/');
2021-03-11 21:58:29 +01:00
2021-03-12 00:09:19 +01:00
document.$CHAT_SOCKET.addEventListener('open', () => {
console.log('Connect');
2021-03-11 21:58:29 +01:00
});
2021-03-12 00:09:19 +01:00
document.$CHAT_SOCKET.addEventListener('close', () => {
console.log('Disconnect');
2021-03-11 21:58:29 +01:00
});
2021-03-12 00:09:19 +01:00
document.$CHAT_SOCKET.addEventListener('message', (event) => {
2021-03-21 14:24:02 +01:00
console.log(event);
2021-03-12 21:16:23 +01:00
const NEW_DATA = JSON.parse(event.data);
2021-03-21 14:24:02 +01:00
if (NEW_DATA.template === document.$CHAT_TEMPLATE) {
const rangeHTML = document.createRange().createContextualFragment(NEW_DATA.html);
document.querySelector(NEW_DATA.selector).innerHTML = '';
document.querySelector(NEW_DATA.selector).appendChild(rangeHTML);
}
2021-03-11 21:58:29 +01:00
});
2021-03-12 00:09:19 +01:00
document.querySelector('#link-about').addEventListener('click', (event) => {
event.preventDefault();
2021-03-21 14:24:02 +01:00
document.$CHAT_TEMPLATE = "partials/website/about.html";
2021-03-12 00:09:19 +01:00
document.$CHAT_SOCKET.send(JSON.stringify({
selector: "#main",
2021-03-21 14:24:02 +01:00
template: document.$CHAT_TEMPLATE,
2021-03-12 00:09:19 +01:00
data: {}
}));
});
2021-03-11 21:58:29 +01:00
2021-03-12 00:09:19 +01:00
document.querySelector('#link-all').addEventListener('click', (event) => {
event.preventDefault();
2021-03-21 14:24:02 +01:00
document.$CHAT_TEMPLATE = "partials/blog/all_articles.html";
2021-03-12 00:09:19 +01:00
document.$CHAT_SOCKET.send(JSON.stringify({
selector: "#main",
2021-03-21 14:24:02 +01:00
template: document.$CHAT_TEMPLATE,
2021-03-12 00:09:19 +01:00
data: {}
}));
});
2021-03-11 21:58:29 +01:00
</script>
</body>
</html>