From 1c503ce50edda6d326839adc0c117330ab9e3fa4 Mon Sep 17 00:00:00 2001 From: Isira Seneviratne Date: Sun, 7 Jul 2024 04:58:35 +0530 Subject: [PATCH] Added loading indicator --- .../newpipe/compose/comment/CommentSection.kt | 41 ++++++++++--------- .../compose/status/LoadingIndicator.kt | 18 ++++++++ 2 files changed, 40 insertions(+), 19 deletions(-) create mode 100644 app/src/main/java/org/schabi/newpipe/compose/status/LoadingIndicator.kt diff --git a/app/src/main/java/org/schabi/newpipe/compose/comment/CommentSection.kt b/app/src/main/java/org/schabi/newpipe/compose/comment/CommentSection.kt index 8d1ef90ab..a26bab8b7 100644 --- a/app/src/main/java/org/schabi/newpipe/compose/comment/CommentSection.kt +++ b/app/src/main/java/org/schabi/newpipe/compose/comment/CommentSection.kt @@ -2,6 +2,7 @@ package org.schabi.newpipe.compose.comment import android.content.res.Configuration import androidx.compose.foundation.layout.Column +import androidx.compose.foundation.layout.padding import androidx.compose.foundation.lazy.LazyColumn import androidx.compose.foundation.lazy.rememberLazyListState import androidx.compose.material3.HorizontalDivider @@ -9,10 +10,8 @@ import androidx.compose.material3.MaterialTheme import androidx.compose.material3.Surface import androidx.compose.material3.Text import androidx.compose.runtime.Composable -import androidx.compose.runtime.derivedStateOf -import androidx.compose.runtime.getValue -import androidx.compose.runtime.remember import androidx.compose.ui.Alignment +import androidx.compose.ui.Modifier import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.tooling.preview.PreviewParameter @@ -26,8 +25,8 @@ import androidx.paging.compose.collectAsLazyPagingItems import kotlinx.coroutines.flow.Flow import kotlinx.coroutines.flow.flowOf import my.nanihadesuka.compose.LazyColumnScrollbar -import my.nanihadesuka.compose.ScrollbarSettings import org.schabi.newpipe.R +import org.schabi.newpipe.compose.status.LoadingIndicator import org.schabi.newpipe.compose.theme.AppTheme import org.schabi.newpipe.extractor.comments.CommentsInfoItem import org.schabi.newpipe.extractor.stream.Description @@ -38,26 +37,30 @@ fun CommentSection( parentComment: CommentsInfoItem? = null, commentsFlow: Flow> ) { - val comments = commentsFlow.collectAsLazyPagingItems() - val itemCount by remember { derivedStateOf { comments.itemCount } } - Surface(color = MaterialTheme.colorScheme.background) { + val comments = commentsFlow.collectAsLazyPagingItems() val refresh = comments.loadState.refresh - if (itemCount == 0 && refresh !is LoadState.Loading) { - NoCommentsMessage((refresh as? LoadState.Error)?.error) - } else { - val listState = rememberLazyListState() + val listState = rememberLazyListState() - LazyColumnScrollbar(state = listState, settings = ScrollbarSettings.Default) { - LazyColumn(state = listState) { - if (parentComment != null) { - item { - CommentRepliesHeader(comment = parentComment) - HorizontalDivider(thickness = 1.dp) + LazyColumnScrollbar(state = listState) { + LazyColumn(state = listState) { + if (parentComment != null) { + item { + CommentRepliesHeader(comment = parentComment) + HorizontalDivider(thickness = 1.dp) + } + } + + if (comments.itemCount == 0) { + item { + if (refresh is LoadState.Loading) { + LoadingIndicator(modifier = Modifier.padding(top = 8.dp)) + } else { + NoCommentsMessage((refresh as? LoadState.Error)?.error) } } - - items(itemCount) { + } else { + items(comments.itemCount) { Comment(comment = comments[it]!!) } } diff --git a/app/src/main/java/org/schabi/newpipe/compose/status/LoadingIndicator.kt b/app/src/main/java/org/schabi/newpipe/compose/status/LoadingIndicator.kt new file mode 100644 index 000000000..8bed6f8c8 --- /dev/null +++ b/app/src/main/java/org/schabi/newpipe/compose/status/LoadingIndicator.kt @@ -0,0 +1,18 @@ +package org.schabi.newpipe.compose.status + +import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.wrapContentSize +import androidx.compose.material3.CircularProgressIndicator +import androidx.compose.material3.MaterialTheme +import androidx.compose.runtime.Composable +import androidx.compose.ui.Alignment +import androidx.compose.ui.Modifier + +@Composable +fun LoadingIndicator(modifier: Modifier = Modifier) { + CircularProgressIndicator( + modifier = modifier.fillMaxSize().wrapContentSize(Alignment.Center), + color = MaterialTheme.colorScheme.primary, + trackColor = MaterialTheme.colorScheme.surfaceVariant, + ) +}