Fetching last messages is working
Signed-off-by: Emmy D'Anello <emmy.danello@animath.fr>
This commit is contained in:
parent
4a78e80399
commit
d59bb75dce
|
@ -62,6 +62,8 @@ class ChatConsumer(AsyncJsonWebsocketConsumer):
|
||||||
await self.fetch_channels()
|
await self.fetch_channels()
|
||||||
case 'send_message':
|
case 'send_message':
|
||||||
await self.receive_message(content)
|
await self.receive_message(content)
|
||||||
|
case 'fetch_messages':
|
||||||
|
await self.fetch_messages(content['channel_id'])
|
||||||
case unknown:
|
case unknown:
|
||||||
print("Unknown message type:", unknown)
|
print("Unknown message type:", unknown)
|
||||||
|
|
||||||
|
@ -101,11 +103,34 @@ class ChatConsumer(AsyncJsonWebsocketConsumer):
|
||||||
await self.channel_layer.group_send(f'chat-{channel.id}', {
|
await self.channel_layer.group_send(f'chat-{channel.id}', {
|
||||||
'type': 'chat.send_message',
|
'type': 'chat.send_message',
|
||||||
'id': message.id,
|
'id': message.id,
|
||||||
|
'channel_id': channel.id,
|
||||||
'timestamp': message.created_at.isoformat(),
|
'timestamp': message.created_at.isoformat(),
|
||||||
'author': await message.aget_author_name(),
|
'author': await message.aget_author_name(),
|
||||||
'content': message.content,
|
'content': message.content,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
async def fetch_messages(self, channel_id: int, offset: int = 0, limit: int = 50) -> None:
|
||||||
|
channel = await Channel.objects.aget(id=channel_id)
|
||||||
|
read_channels = await Channel.get_accessible_channels(self.scope['user'], 'read')
|
||||||
|
if not await read_channels.acontains(channel):
|
||||||
|
return
|
||||||
|
|
||||||
|
messages = Message.objects.filter(channel=channel).order_by('created_at')[offset:offset + limit].all()
|
||||||
|
await self.send_json({
|
||||||
|
'type': 'fetch_messages',
|
||||||
|
'channel_id': channel_id,
|
||||||
|
'messages': [
|
||||||
|
{
|
||||||
|
'id': message.id,
|
||||||
|
'timestamp': message.created_at.isoformat(),
|
||||||
|
'author': await message.aget_author_name(),
|
||||||
|
'content': message.content,
|
||||||
|
}
|
||||||
|
async for message in messages
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
async def chat_send_message(self, message) -> None:
|
async def chat_send_message(self, message) -> None:
|
||||||
await self.send_json({'type': 'send_message', 'id': message['id'], 'timestamp': message['timestamp'],
|
await self.send_json({'type': 'send_message', 'id': message['id'], 'channel_id': message['channel_id'],
|
||||||
'author': message['author'], 'content': message['content']})
|
'timestamp': message['timestamp'], 'author': message['author'],
|
||||||
|
'content': message['content']})
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
})()
|
})()
|
||||||
|
|
||||||
let channels = {}
|
let channels = {}
|
||||||
|
let messages = {}
|
||||||
let selected_channel_id = null
|
let selected_channel_id = null
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -35,6 +36,8 @@ function selectChannel(channel_id) {
|
||||||
|
|
||||||
let messageInput = document.getElementById('input-message')
|
let messageInput = document.getElementById('input-message')
|
||||||
messageInput.disabled = !channel['write_access']
|
messageInput.disabled = !channel['write_access']
|
||||||
|
|
||||||
|
redrawMessages()
|
||||||
}
|
}
|
||||||
|
|
||||||
function sendMessage() {
|
function sendMessage() {
|
||||||
|
@ -57,28 +60,84 @@ function setChannels(new_channels) {
|
||||||
channels = {}
|
channels = {}
|
||||||
for (let channel of new_channels) {
|
for (let channel of new_channels) {
|
||||||
channels[channel['id']] = channel
|
channels[channel['id']] = channel
|
||||||
|
if (!messages[channel['id']])
|
||||||
|
messages[channel['id']] = []
|
||||||
|
|
||||||
|
socket.send(JSON.stringify({
|
||||||
|
'type': 'fetch_messages',
|
||||||
|
'channel_id': channel['id'],
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
if (new_channels && (!selected_channel_id || !channels[selected_channel_id])) {
|
if (new_channels && (!selected_channel_id || !channels[selected_channel_id]))
|
||||||
selectChannel(Object.keys(channels)[0])
|
selectChannel(Object.keys(channels)[0])
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function receiveMessage(message) {
|
function receiveMessage(message) {
|
||||||
|
messages[message['channel_id']].push(message)
|
||||||
|
redrawMessages()
|
||||||
|
}
|
||||||
|
|
||||||
|
function fetchMessages(data) {
|
||||||
|
let channel_id = data['channel_id']
|
||||||
|
let new_messages = data['messages']
|
||||||
|
|
||||||
|
if (!messages[channel_id])
|
||||||
|
messages[channel_id] = []
|
||||||
|
|
||||||
|
for (let message of new_messages) {
|
||||||
|
messages[channel_id].push(message)
|
||||||
|
}
|
||||||
|
|
||||||
|
redrawMessages()
|
||||||
|
}
|
||||||
|
|
||||||
|
function redrawMessages() {
|
||||||
let messageList = document.getElementById('message-list')
|
let messageList = document.getElementById('message-list')
|
||||||
|
messageList.innerHTML = ''
|
||||||
|
|
||||||
let messageElement = document.createElement('li')
|
let lastMessage = null
|
||||||
messageElement.classList.add('list-group-item')
|
let lastContentDiv = null
|
||||||
messageList.appendChild(messageElement)
|
|
||||||
|
|
||||||
let authorDiv = document.createElement('div')
|
for (let message of messages[selected_channel_id]) {
|
||||||
authorDiv.classList.add('text-muted', 'fw-bold')
|
if (lastMessage && lastMessage['author'] === message['author']) {
|
||||||
authorDiv.innerText = message['author']
|
let lastTimestamp = new Date(lastMessage['timestamp'])
|
||||||
messageElement.appendChild(authorDiv)
|
let newTimestamp = new Date(message['timestamp'])
|
||||||
|
if ((newTimestamp - lastTimestamp) / 1000 < 60 * 10) {
|
||||||
|
let messageContentDiv = document.createElement('div')
|
||||||
|
messageContentDiv.innerText = message['content']
|
||||||
|
lastContentDiv.appendChild(messageContentDiv)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let contentDiv = document.createElement('div')
|
let messageElement = document.createElement('li')
|
||||||
contentDiv.innerText = message['content']
|
messageElement.classList.add('list-group-item')
|
||||||
messageElement.appendChild(contentDiv)
|
messageList.appendChild(messageElement)
|
||||||
|
|
||||||
|
let authorDiv = document.createElement('div')
|
||||||
|
messageElement.appendChild(authorDiv)
|
||||||
|
|
||||||
|
let authorSpan = document.createElement('span')
|
||||||
|
authorSpan.classList.add('text-muted', 'fw-bold')
|
||||||
|
authorSpan.innerText = message['author']
|
||||||
|
authorDiv.appendChild(authorSpan)
|
||||||
|
|
||||||
|
let dateSpan = document.createElement('span')
|
||||||
|
dateSpan.classList.add('text-muted', 'float-end')
|
||||||
|
dateSpan.innerText = new Date(message['timestamp']).toLocaleString()
|
||||||
|
authorDiv.appendChild(dateSpan)
|
||||||
|
|
||||||
|
let contentDiv = document.createElement('div')
|
||||||
|
messageElement.appendChild(contentDiv)
|
||||||
|
|
||||||
|
let messageContentDiv = document.createElement('div')
|
||||||
|
messageContentDiv.innerText = message['content']
|
||||||
|
contentDiv.appendChild(messageContentDiv)
|
||||||
|
|
||||||
|
lastMessage = message
|
||||||
|
lastContentDiv = contentDiv
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
document.addEventListener('DOMContentLoaded', () => {
|
document.addEventListener('DOMContentLoaded', () => {
|
||||||
|
@ -87,7 +146,6 @@ document.addEventListener('DOMContentLoaded', () => {
|
||||||
* @param data The received message
|
* @param data The received message
|
||||||
*/
|
*/
|
||||||
function processMessage(data) {
|
function processMessage(data) {
|
||||||
// TODO Implement chat protocol
|
|
||||||
switch (data['type']) {
|
switch (data['type']) {
|
||||||
case 'fetch_channels':
|
case 'fetch_channels':
|
||||||
setChannels(data['channels'])
|
setChannels(data['channels'])
|
||||||
|
@ -95,6 +153,9 @@ document.addEventListener('DOMContentLoaded', () => {
|
||||||
case 'send_message':
|
case 'send_message':
|
||||||
receiveMessage(data)
|
receiveMessage(data)
|
||||||
break
|
break
|
||||||
|
case 'fetch_messages':
|
||||||
|
fetchMessages(data)
|
||||||
|
break
|
||||||
default:
|
default:
|
||||||
console.log(data)
|
console.log(data)
|
||||||
console.error('Unknown message type:', data['type'])
|
console.error('Unknown message type:', data['type'])
|
||||||
|
|
Loading…
Reference in New Issue