Skip to content

Commit

Permalink
fix(ui): accessing listState on io thread causes app to crash
Browse files Browse the repository at this point in the history
  • Loading branch information
JunkFood02 authored and Ashinch committed Feb 6, 2024
1 parent 1dc906b commit 92f994f
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,16 @@ import android.util.Log
import androidx.compose.animation.*
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.lazy.LazyListState
import androidx.compose.foundation.lazy.rememberLazyListState
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.derivedStateOf
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.saveable.rememberSaveable
import androidx.compose.runtime.setValue
import androidx.compose.runtime.snapshotFlow
import androidx.compose.ui.Modifier
import androidx.compose.ui.unit.dp
Expand Down Expand Up @@ -36,8 +42,11 @@ fun ReadingPage(
val readingUiState = readingViewModel.readingUiState.collectAsStateValue()
val readerState = readingViewModel.readerStateStateFlow.collectAsStateValue()
val homeUiState = homeViewModel.homeUiState.collectAsStateValue()

var isReaderScrollingDown by remember { mutableStateOf(false) }

val isShowToolBar = if (LocalReadingAutoHideToolbar.current.value) {
readingUiState.articleId != null && !readingUiState.listState.isScrollDown()
readingUiState.articleId != null && !isReaderScrollingDown
} else {
true
}
Expand Down Expand Up @@ -100,9 +109,16 @@ fun ReadingPage(
initialContentExit = ExitTransition.None, sizeTransform = null
)
}
}
}, label = ""
) {
it.run {
val listState = rememberSaveable(
inputs = arrayOf(content),
saver = LazyListState.Saver
) { LazyListState() }

isReaderScrollingDown = listState.isScrollDown()

Content(
content = content.text ?: "",
feedName = feedName,
Expand All @@ -111,7 +127,7 @@ fun ReadingPage(
link = link,
publishedDate = publishedDate,
isLoading = content is ReaderState.Loading,
listState = readingUiState.listState,
listState = listState,
isShowToolBar = isShowToolBar,
)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,12 +71,6 @@ class ReadingViewModel @Inject constructor(
if (it.isFullContent) internalRenderFullContent()
else renderDescriptionContent()
}
// java.lang.NullPointerException: Attempt to invoke virtual method
// 'boolean androidx.compose.ui.node.LayoutNode.getNeedsOnPositionedDispatch$ui_release()'
// on a null object reference
if (_readingUiState.value.listState.firstVisibleItemIndex != 0) {
_readingUiState.value.listState.scrollToItem(0)
}
}
}

Expand Down Expand Up @@ -169,7 +163,6 @@ data class ReadingUiState(
val articleId: String? = null,
val isUnread: Boolean = false,
val isStarred: Boolean = false,
val listState: LazyListState = LazyListState(),
val nextArticleId: String? = null,
)

Expand Down

0 comments on commit 92f994f

Please sign in to comment.