-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
"Jump to first unread message" (read marker) is often wildly incorrect #12338
Comments
I received advice that it may require several seconds for a room to decide that I've read it. I am currently looking at the Servo room, and I've been talking in the room all afternoon. There's now a "Jump to first unread message" button showing that takes me back several hours, and when I scroll to the bottom and wait for multiple minutes it doesn't go away, even if I switch away to another room and back. |
It does seem like something has regressed here. We'll investigate. |
related: #10942 |
Largely I think this is indeed a problem with the timers. It might be as simple as changing the values a bit (I find that 2ms works great for me, but obviously not everyone is interested in clearing it as fast as possible). @vector-im/design will have to take a look at this, possibly with a partial product hat on. |
I don't see how those timers can be causing the issue that I originally reported, which involves me staring at rooms for minutes using the default values. Edit: unless I'm misunderstanding, and I actually need to be staring at where the "Jump to first unread message" takes me for several seconds? |
I can't reproduce that failure, but I do know the timer stops when the tab isn't focused. If you quite literally click on the room, take your hands away from your input devices, and count to 30 it should go away - this is obviously not ideal, which is why design is being pulled in. |
Ok, but that's not what happens for me. I see the button stay present in rooms that I'm actively focused on for minutes at a time. |
hmm, can you try again and send updated logs? I'll try to take a look. |
The following I commented in #syncronicity:mozilla.org earlier this week:
However, I've since discovered that the first time I run RiotX it hoses all my pointers again. After running RiotX, my pointers in Riot/desktop went back to the spot they keep jumping to in recent history. So the real problem may be a bad interaction between desktop and riotx/android. |
And I'm not even sure about that anymore, I'm failing to reproduce it purposely interacting between the two. Everything seems to update real time in both directions. So maybe I just had to stay logged out of both overnight to trigger it again? Dunno, it's all weird. |
Something for the design team to consider: #12506 |
I've had a similar issue to justdave a couple of times now. I've shutdown the Riot desktop app overnight, read messages on RiotX, and then when I open the desktop app again I hit this:
Going into settings -> help and clearing the cache and reloading seems to fix this. I'm not 100% sure, but I think RiotX isn't always picking up that I've read things on the desktop app as well. It could be happening when it is getting into this bad state. |
I'm back in the state where some channels aren't updating the read status. I'm using the defaults settings. I look at the room and scroll back to the unread line. I wait for the green line to disappear, then scroll down slowly (if I need to for that room). The green dot at the top does not reappear. Sometimes I'll wait in the room for more than 30 seconds with Riot focussed, I can even spend a minute or two typing in the room. I then go to another room, and come back again, and the unread green line status is where it was originally. I had this a bit earlier today, and did a clear cache and reload, and it didn't reset the unread marks as it had previously. |
From what I am reading in the feedback here so far, I don't believe we need design / product guidance here: instead, there's a bug we need to fix. It's true that the timer-based behaviour can be quite confusing, and we may eventually want a product decision to change that. What I am hearing in this issue though is a bug that goes something like:
I have observed this happening at various times as well. It seems like clearing the read marker "several" times (watching the green line) seems to make it progress as a workaround, but of course that is quite a bad experience. |
This is a problem that comes and goes for me. After days of working fine I observed it on Saturday on chat.mozilla.org. The issue resolved itself over the course of Sunday and Monday and is back to normal today. (It seems that after "something" happens the next message in a room will let that room get fixed.) And all along the unread counts seemed to be accurate, even when the pointer was off. What doesn't work (when the state is bad):
Should I report the problem if I see it again? Is there any useful information to collect? |
Thanks for your experience report above! If you do see it again, feel free to submit debug logs in Riot (Top left menu -> Settings -> Help -> Submit debug logs) and reference this issue. I do have some theories on what's going wrong here, and I'm hoping to have more to share here soon. |
The recent "groupers" which extracted out timeline grouping logic forgot to pass through the last event state for read marker computation. This causes the read marker to become visible when e.g. returning to room if it was last placed inside a grouped set of events (currently room creation and membership events). Regressed by #4059 Related to element-hq/element-web#12338
I've been testing this without the RiotX client running for the last week or so. Generally it feels like the markers behave better, however, towards the middle/end of day, they're getting messed up again. |
Without the RiotX android client this is still behaving badly, and it seems kinda random as to when it gets messed up or not. Is there any more information I can provide here to help this get resolved? |
Thanks for the updates on this, I know this is quite a painful issue once you notice it. 😖 I've been able to reproduce what I believe is the same issue locally. It's a complex area of the app, so the main challenge at the moment has been finding enough time to focus on this. I'll try to block off some time this week to work on it. |
The `TimelinePanel` uses two timers to coordinate read marker and read receipt updates. When the read receipt timer fires, we advance the receipt and send the latest state of both your receipt and marker to the server. When the read marker timer fires, we advance the marker visually, but do not send anything to the server: we were relying on the slightly different schedule of the read receipt to actually send the updated read marker. This means there's a time window where it's possible to visually advance the read marker without ever sending it to the server (if you change rooms before the receipt timer fires again). To simplify the behaviour here and ensure we always commit the updated marker when we move it, this change sends an update to the server at the same time as moving the marker. It's possible this may improve some of the behaviour reported in element-hq/element-web#12338.
The `TimelinePanel` uses two timers to coordinate read marker and read receipt updates. When the read receipt timer fires, we advance the receipt and send the latest state of both your receipt and marker to the server. When the read marker timer fires, we advance the marker visually, but do not send anything to the server: we were relying on the slightly different schedule of the read receipt to actually send the updated read marker. This means there's a time window where it's possible to visually advance the read marker without ever sending it to the server (if you change rooms before the receipt timer fires again). To simplify the behaviour here and ensure we always commit the updated marker when we move it, this change sends an update to the server at the same time as moving the marker. It's possible this may improve some of the behaviour reported in element-hq/element-web#12338.
The `TimelinePanel` uses two timers to coordinate read marker and read receipt updates. When the read receipt timer fires, we advance the receipt and send the latest state of both your receipt and marker to the server. When the read marker timer fires, we advance the marker visually, but do not send anything to the server: we were relying on the slightly different schedule of the read receipt to actually send the updated read marker. This means there's a time window where it's possible to visually advance the read marker without ever sending it to the server (if you change rooms before the receipt timer fires again). To simplify the behaviour here and ensure we always commit the updated marker when we move it, this change sends an update to the server at the same time as moving the marker. It's possible this may improve some of the behaviour reported in element-hq/element-web#12338.
Riot 1.6.6 (which is also now deployed to chat.mozilla.org) includes a potential fix for this. @Standard8 @bjherbison @justdave @jdm, please re-test over the next few days of use and let me know if anything might have improved. |
Thank you, @jryans, Riot 1.6.6 on chat.mozilla.org is behaving much better than the previous versions. I haven't spotted a glitch in the read marker, even when switching between computers. |
Haven't noticed any issues lately here... |
Thanks everyone for verifying, I'm very happy to hear this is now working for everyone. 😁 |
Description
When I read through the latest messages in a room in the Mozilla Riot instance, then close the tab and later reopen it and visit that room again, pressing the "Jump to first unread message" takes me back multiple days in the room history that I have already read.
Steps to reproduce
I expect to be taken to the last message that I read. Instead I'm usually taken to messages from several days ago.
It may help to mention that in rooms like DOM I find the "Jump to first unread message" button does not ever seem to go away even when I reach the newest messages in the room.
Logs being sent: yes
Version information
For the web app:
The text was updated successfully, but these errors were encountered: