From 08ff0bac297dede8144f83a0b0aa3fc530943bcf Mon Sep 17 00:00:00 2001 From: Joffrey JAFFEUX Date: Sat, 20 Apr 2024 10:50:32 +0200 Subject: [PATCH] FIX: ensures last read is updated on exit (#26691) --- .../discourse/components/chat-channel.gjs | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/plugins/chat/assets/javascripts/discourse/components/chat-channel.gjs b/plugins/chat/assets/javascripts/discourse/components/chat-channel.gjs index ae604216918..62ca9e26c8c 100644 --- a/plugins/chat/assets/javascripts/discourse/components/chat-channel.gjs +++ b/plugins/chat/assets/javascripts/discourse/components/chat-channel.gjs @@ -111,6 +111,7 @@ export default class ChatChannel extends Component { this.#cancelHandlers(); removeOnPresenceChange(this.onPresenceChangeCallback); this.subscriptionManager.teardown(); + this.updateLastReadMessage(); } @action @@ -415,15 +416,12 @@ export default class ChatChannel extends Component { } schedule("afterRender", () => { - let lastFullyVisibleMessageNode = null; - - this.scrollable - .querySelectorAll(".chat-message-container") - .forEach((item) => { - if (checkMessageBottomVisibility(this.scrollable, item)) { - lastFullyVisibleMessageNode = item; - } - }); + const messages = this.scrollable.querySelectorAll( + ".chat-message-container" + ); + let lastFullyVisibleMessageNode = Array.from(messages) + .reverse() + .find((item) => checkMessageBottomVisibility(this.scrollable, item)); if (!lastFullyVisibleMessageNode) { return;