blob: 96d106121aee6197c964da7fd92c3ab3a7068176 (
plain)
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
|
"use strict";
function ready(callback) {
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', callback);
} else {
callback();
}
}
ready(() => {
let template = document.querySelector('#message').content;
document.querySelectorAll('link[rel=events]').forEach(elem => {
let url = elem.getAttribute("href");
let source = new EventSource(url);
source.addEventListener('message', message => {
let body = JSON.parse(message.data);
document.querySelectorAll('.messages').forEach(elem => {
let message = template.cloneNode(true);
message.querySelectorAll('.sender')
.forEach(elem => elem.textContent = body.sender.name);
message.querySelectorAll('.message')
.forEach(elem => elem.textContent = body.body);
message.querySelectorAll('.sent_at')
.forEach(elem => elem.textContent = body.sent_at);
message.childNodes.forEach(node => elem.appendChild(node));
});
});
});
})
|