vybe/client/message.js

90 lines
2.5 KiB
JavaScript
Raw Normal View History

2024-04-15 21:52:21 -07:00
import { render, html } from '/uhtml.js';
let msg;
function sendMessage(e) {
e.preventDefault();
if (!msg.value)
return;
window.emit('send_message', {
message: msg.value,
2024-05-05 00:47:42 -07:00
thread: window.currentThread.id
2024-04-15 21:52:21 -07:00
});
msg.value = '';
}
let earliestMessage;
window.socket.on('new_message', message => {
2024-05-05 00:47:42 -07:00
if (message.thread !== window.currentThread.id)
2024-04-15 21:52:21 -07:00
return;
2024-04-29 21:05:45 -07:00
const messages = document.getElementById('messages');
let scroll = messages.scrollHeight - messages.scrollTop <= messages.clientHeight;
messages.appendChild(html.node`
2024-04-15 21:52:21 -07:00
<div class='message'>
<strong>${message.name}: </strong>
${message.message}
</div>`);
2024-04-29 21:05:45 -07:00
if (scroll)
messages.scroll(0, messages.scrollHeight - messages.clientHeight);
2024-04-15 21:52:21 -07:00
if (!earliestMessage)
earliestMessage = message.id;
});
2024-05-16 20:40:09 -07:00
function loadMessages(firstRender, callback) {
2024-04-15 21:52:21 -07:00
if (!msg) {
render(document.getElementById('message'), html`
<button id='loadmore' class='hidden' onclick=${loadMessages}>
load more messages
</button>
<div id='messages'></div>
<form id='msginput' onsubmit=${sendMessage}>
<input id='msg' placeholder='write a message...' />
<button type='submit' id='sendmsg'>send</button>
</form>
`);
msg = document.getElementById('msg');
}
const messages = document.getElementById('messages');
if (!this) { // called from chooseThread, initializing thread
messages.innerHTML = '';
earliestMessage = null;
2024-05-16 20:40:09 -07:00
if (window.currentThread.permissions.post)
document.getElementById('msginput').classList.remove('hidden');
else
document.getElementById('msginput').classList.add('hidden');
2024-04-15 21:52:21 -07:00
}
window.emit(
'get_history',
{
before: earliestMessage,
2024-05-05 00:47:42 -07:00
thread: window.currentThread.id
2024-04-15 21:52:21 -07:00
},
msg => {
2024-05-16 20:40:09 -07:00
if (!msg.success) {
2024-04-15 21:52:21 -07:00
console.log('get_history failed: ' + msg.message);
2024-05-16 20:40:09 -07:00
return;
}
callback && callback(msg.messages);
if (firstRender && messages.hasChildNodes())
return;
2024-04-15 21:52:21 -07:00
if (msg.messages.length > 0) {
earliestMessage = msg.messages[msg.messages.length - 1].id;
for (let message of msg.messages)
messages.prepend(html.node`
<div class='message'>
<strong>${message.name}: </strong>
${message.message}
</div>`);
}
2024-05-04 20:13:37 -07:00
if (msg.more)
2024-04-15 21:52:21 -07:00
document.getElementById('loadmore').classList.remove('hidden');
2024-05-04 20:13:37 -07:00
else
document.getElementById('loadmore').classList.add('hidden');
messages.scroll(0, messages.scrollHeight - messages.clientHeight);
2024-04-15 21:52:21 -07:00
}
);
}
export default loadMessages;