FIX: correctly updates last read on scroll arrow click (#25838)

Prior to this fix the scroll was ignored when clicking the arrow bottom which would prevent the call to update last read. This fix manually calls update last read in this case and adds a test for it.
This commit is contained in:
Joffrey JAFFEUX 2024-02-23 14:23:17 +01:00 committed by GitHub
parent 28fc4010b0
commit 9e08b45f9b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 29 additions and 13 deletions

View File

@ -255,9 +255,10 @@ export default class ChatChannel extends Component {
}
@action
scrollToBottom() {
async scrollToBottom() {
this._ignoreNextScroll = true;
scrollListToBottom(this.scrollable);
await scrollListToBottom(this.scrollable);
this.debouncedUpdateLastReadMessage();
}
scrollToMessageId(messageId, options = {}) {

View File

@ -520,6 +520,14 @@ export default class ChatMessage extends Component {
(if @message.highlighted "-highlighted")
(if @message.streaming "-streaming")
(if (eq @message.user.id this.currentUser.id) "is-by-current-user")
(if (eq @message.id this.currentUser.id) "is-by-current-user")
(if
(eq
@message.id
@message.channel.currentUserMembership.lastReadMessageId
)
"-last-read"
)
(if @message.staged "-staged" "-persisted")
(if @message.processed "-processed" "-not-processed")
(if this.hasActiveState "-active")

View File

@ -489,15 +489,15 @@ export default class ChatThread extends Component {
}
@action
scrollToBottom() {
async scrollToBottom() {
this._ignoreNextScroll = true;
scrollListToBottom(this.scrollable);
await scrollListToBottom(this.scrollable);
}
@action
scrollToTop() {
async scrollToTop() {
this._ignoreNextScroll = true;
scrollListToTop(this.scrollable);
await scrollListToTop(this.scrollable);
}
@action

View File

@ -1,15 +1,21 @@
import { schedule } from "@ember/runloop";
import { next, schedule } from "@ember/runloop";
import { stackingContextFix } from "discourse/plugins/chat/discourse/lib/chat-ios-hacks";
export function scrollListToBottom(list) {
export async function scrollListToBottom(list) {
await new Promise((resolve) => {
stackingContextFix(list, () => {
list.scrollTo({ top: 0, behavior: "auto" });
next(resolve);
});
});
}
export function scrollListToTop(list) {
export async function scrollListToTop(list) {
await new Promise((resolve) => {
stackingContextFix(list, () => {
list.scrollTo({ top: -list.scrollHeight, behavior: "auto" });
next(resolve);
});
});
}

View File

@ -141,6 +141,7 @@ RSpec.describe "Chat channel", type: :system do
expect(channel_page).to have_no_loading_skeleton
expect(page).to have_css("[data-id='#{unloaded_message.id}']")
expect(page).to have_css(".-last-read[data-id='#{unloaded_message.id}']")
end
end