From ee15c9915bd74e86b357da5e33c51afa64d0ad63 Mon Sep 17 00:00:00 2001 From: Sasikanth Miriyampalli Date: Thu, 25 Apr 2024 20:08:47 +0530 Subject: [PATCH] Update featured posts and normal posts separately in `HomeState` --- .../rss/reader/home/HomePresenter.kt | 41 +++++-------------- 1 file changed, 11 insertions(+), 30 deletions(-) diff --git a/shared/src/commonMain/kotlin/dev/sasikanth/rss/reader/home/HomePresenter.kt b/shared/src/commonMain/kotlin/dev/sasikanth/rss/reader/home/HomePresenter.kt index 37d8a25aa..5e7567259 100644 --- a/shared/src/commonMain/kotlin/dev/sasikanth/rss/reader/home/HomePresenter.kt +++ b/shared/src/commonMain/kotlin/dev/sasikanth/rss/reader/home/HomePresenter.kt @@ -41,6 +41,7 @@ import dev.sasikanth.rss.reader.repository.ObservableActiveSource import dev.sasikanth.rss.reader.repository.RssRepository import dev.sasikanth.rss.reader.repository.SettingsRepository import dev.sasikanth.rss.reader.util.DispatchersProvider +import dev.sasikanth.rss.reader.utils.NTuple4 import dev.sasikanth.rss.reader.utils.getLast24HourStart import dev.sasikanth.rss.reader.utils.getTodayStartInstant import io.ktor.client.network.sockets.ConnectTimeoutException @@ -270,41 +271,21 @@ class HomePresenter( unreadOnly = unreadOnly, after = postsAfter ) - .map { featuredPosts -> Triple(activeSource, postsType, featuredPosts) } - } - .distinctUntilChanged { old, new -> - old.third.map { it.id } == new.third.map { it.id } || - old.first == new.first || - old.second == new.second - } - .onEach { (activeSource, postsType, featuredPosts) -> - val featuredPostIds = featuredPosts.map { it.id } - - val unreadOnly = - when (postsType) { - PostsType.ALL, - PostsType.TODAY, - PostsType.LAST_24_HOURS -> null - PostsType.UNREAD -> true + .onEach { featuredPosts -> + _state.update { it.copy(featuredPosts = featuredPosts.toImmutableList()) } } - - val postsAfter = - when (postsType) { - PostsType.ALL, - PostsType.UNREAD -> Instant.DISTANT_PAST - PostsType.TODAY -> { - getTodayStartInstant() - } - PostsType.LAST_24_HOURS -> { - getLast24HourStart() - } + .map { featuredPosts -> + val featuredPostsIds = featuredPosts.map { it.id } + NTuple4(activeSource, postsAfter, unreadOnly, featuredPostsIds) } - + } + .distinctUntilChanged() + .onEach { (activeSource, postsAfter, unreadOnly, featuredPostsIds) -> val posts = createPager(config = createPagingConfig(pageSize = 20, enablePlaceholders = true)) { rssRepository.posts( selectedFeedId = activeSource?.id, - featuredPostsIds = featuredPostIds, + featuredPostsIds = featuredPostsIds, unreadOnly = unreadOnly, after = postsAfter, ) @@ -312,7 +293,7 @@ class HomePresenter( .flow .cachedIn(coroutineScope) - _state.update { it.copy(featuredPosts = featuredPosts.toImmutableList(), posts = posts) } + _state.update { it.copy(posts = posts) } } .launchIn(coroutineScope)