Merge remote-tracking branch 'origin/main' into profile-modal
This commit is contained in:
commit
83d4f02c3a
18 changed files with 147 additions and 73 deletions
|
@ -1,7 +1,7 @@
|
|||
<template>
|
||||
<div id="message-area">
|
||||
<div id="messages" ref="messagesElement">
|
||||
<Message v-for="(message, i) of messages" :username="getDisplayName(message.user)"
|
||||
<Message v-for="(message, i) of messages" :username="getDisplayName(message.user)" :key="message.uuid"
|
||||
:text="message.message" :timestamp="messageTimestamps[message.uuid]" :img="message.user.avatar"
|
||||
:format="timeFormat" :type="messagesType[message.uuid]"
|
||||
:margin-bottom="(messages[i + 1] && messagesType[messages[i + 1].uuid] == 'normal') ?? false"
|
||||
|
@ -224,6 +224,10 @@ function sendMessage(e: Event) {
|
|||
if (messageReply && messageReply.dataset.messageId) {
|
||||
console.log("[MSG] message is a reply");
|
||||
message.reply_to = messageReply.dataset.messageId;
|
||||
const replyToMessage = document.querySelector(`.message[data-message-id='${message.reply_to}']`);
|
||||
if (replyToMessage) {
|
||||
replyToMessage.classList.remove("replying-to");
|
||||
}
|
||||
}
|
||||
|
||||
console.log("[MSG] sent message:", message);
|
||||
|
@ -240,12 +244,8 @@ function sendMessage(e: Event) {
|
|||
}
|
||||
|
||||
function getReplyMessage(id: string) {
|
||||
console.log("[REPLYMSG] id:", id);
|
||||
const messagesValues = Object.values(messages.value);
|
||||
console.log("[REPLYMSG] messages values:", messagesValues);
|
||||
for (const message of messagesValues) {
|
||||
console.log("[REPLYMSG] message:", message);
|
||||
console.log("[REPLYMSG] IDs match?", message.uuid == id);
|
||||
if (message.uuid == id) return message;
|
||||
}
|
||||
}
|
||||
|
@ -269,21 +269,14 @@ onMounted(async () => {
|
|||
if (fetched) return;
|
||||
fetched = true;
|
||||
console.log("scroll height is at 10% or less");
|
||||
//console.log("current oldest:", currentOldestMessage);
|
||||
const olderMessages = await fetchMessages(route.params.channelId as string, { amount, offset });
|
||||
if (olderMessages) {
|
||||
if (olderMessages?.length) {
|
||||
olderMessages.reverse();
|
||||
console.log("older messages:", olderMessages);
|
||||
if (olderMessages.length == 0) return;
|
||||
olderMessages.reverse();
|
||||
for (const [i, oldMessage] of olderMessages.entries()) {
|
||||
console.log("old message:", oldMessage);
|
||||
messages.value.unshift(oldMessage);
|
||||
for (const message of messages.value) {
|
||||
groupMessage(message);
|
||||
}
|
||||
messages.value = [...olderMessages.map(msg => reactive(msg)), ...messages.value];
|
||||
for (const message of messages.value) {
|
||||
groupMessage(message);
|
||||
}
|
||||
offset += offset;
|
||||
offset += amount;
|
||||
}
|
||||
} else {
|
||||
fetched = false;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue