Jump to unread: removes unnecessary check which can cause scroll issue

This commit is contained in:
ganfra 2021-06-24 18:46:32 +02:00
parent ab37984beb
commit cccf5de015

View File

@ -20,7 +20,6 @@ import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView import androidx.recyclerview.widget.RecyclerView
import im.vector.app.core.platform.DefaultListUpdateCallback import im.vector.app.core.platform.DefaultListUpdateCallback
import im.vector.app.features.home.room.detail.timeline.TimelineEventController import im.vector.app.features.home.room.detail.timeline.TimelineEventController
import timber.log.Timber
import java.util.concurrent.atomic.AtomicReference import java.util.concurrent.atomic.AtomicReference
/** /**
@ -42,20 +41,11 @@ class ScrollOnHighlightedEventCallback(private val recyclerView: RecyclerView,
private fun scrollIfNeeded() { private fun scrollIfNeeded() {
val eventId = scheduledEventId.get() ?: return val eventId = scheduledEventId.get() ?: return
val positionToScroll = timelineEventController.searchPositionOfEvent(eventId) val positionToScroll = timelineEventController.searchPositionOfEvent(eventId) ?: return
if (positionToScroll != null) {
val firstVisibleItem = layoutManager.findFirstCompletelyVisibleItemPosition()
val lastVisibleItem = layoutManager.findLastCompletelyVisibleItemPosition()
// Do not scroll it item is already visible
if (positionToScroll !in firstVisibleItem..lastVisibleItem) {
Timber.v("Scroll to $positionToScroll")
recyclerView.stopScroll() recyclerView.stopScroll()
layoutManager.scrollToPosition(positionToScroll) layoutManager.scrollToPosition(positionToScroll)
}
scheduledEventId.set(null) scheduledEventId.set(null)
} }
}
fun scheduleScrollTo(eventId: String?) { fun scheduleScrollTo(eventId: String?) {
scheduledEventId.set(eventId) scheduledEventId.set(eventId)