From a8394deff30bc303b7b110624987f20ec8396f05 Mon Sep 17 00:00:00 2001 From: Hasib Prince Date: Tue, 24 May 2022 17:36:35 +0600 Subject: [PATCH 1/2] App Lounge: DownloadProgressFlow added --- .../apps/manager/download/data/DownloadProgressFlow.kt | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt diff --git a/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt b/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt new file mode 100644 index 000000000..c1d48732d --- /dev/null +++ b/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt @@ -0,0 +1,10 @@ +package foundation.e.apps.manager.download.data + +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.FlowCollector + +class DownloadProgressFlow : Flow { + override suspend fun collect(collector: FlowCollector) { + + } +} \ No newline at end of file -- GitLab From f8448a521f087fb23d7f2dea51efc1360d4500a8 Mon Sep 17 00:00:00 2001 From: Hasib Prince Date: Thu, 26 May 2022 00:03:29 +0600 Subject: [PATCH 2/2] App Lounge: fixed progress update Fixed progress update after coming back from background --- .../e/apps/application/ApplicationFragment.kt | 7 ++- .../ApplicationListFragment.kt | 8 ++-- .../foundation/e/apps/home/HomeFragment.kt | 10 ++--- .../download/data/DownloadProgressFlow.kt | 10 ----- .../download/data/DownloadProgressLD.kt | 8 ++-- .../e/apps/search/SearchFragment.kt | 45 ++++++++++--------- .../e/apps/updates/UpdatesFragment.kt | 10 +++-- 7 files changed, 48 insertions(+), 50 deletions(-) delete mode 100644 app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt diff --git a/app/src/main/java/foundation/e/apps/application/ApplicationFragment.kt b/app/src/main/java/foundation/e/apps/application/ApplicationFragment.kt index 14aef8e72..7cbe70d99 100644 --- a/app/src/main/java/foundation/e/apps/application/ApplicationFragment.kt +++ b/app/src/main/java/foundation/e/apps/application/ApplicationFragment.kt @@ -259,8 +259,6 @@ class ApplicationFragment : Fragment(R.layout.fragment_application) { if (appInfoFetchViewModel.isAppInBlockedList(it)) { binding.snackbarLayout.visibility = View.VISIBLE } - - observeDownloadStatus(view) fetchAppTracker(it) } @@ -323,6 +321,11 @@ class ApplicationFragment : Fragment(R.layout.fragment_application) { } } + override fun onResume() { + super.onResume() + observeDownloadStatus(binding.root) + } + private fun handleInstallingIssue( installButton: MaterialButton, fusedApp: FusedApp, diff --git a/app/src/main/java/foundation/e/apps/applicationlist/ApplicationListFragment.kt b/app/src/main/java/foundation/e/apps/applicationlist/ApplicationListFragment.kt index e0b206aa5..7041ea372 100644 --- a/app/src/main/java/foundation/e/apps/applicationlist/ApplicationListFragment.kt +++ b/app/src/main/java/foundation/e/apps/applicationlist/ApplicationListFragment.kt @@ -143,10 +143,6 @@ class ApplicationListFragment : Fragment(R.layout.fragment_application_list), Fu layoutManager = LinearLayoutManager(view?.context) } - appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { - updateProgressOfDownloadingItems(recyclerView, it) - } - viewModel.appListLiveData.observe(viewLifecycleOwner) { listAdapter?.setData(it) if (!isDownloadObserverAdded) { @@ -184,6 +180,10 @@ class ApplicationListFragment : Fragment(R.layout.fragment_application_list), Fu } } } + + appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { + updateProgressOfDownloadingItems(recyclerView, it) + } } private fun updateProgressOfDownloadingItems( diff --git a/app/src/main/java/foundation/e/apps/home/HomeFragment.kt b/app/src/main/java/foundation/e/apps/home/HomeFragment.kt index 0516c3469..7f0e34340 100644 --- a/app/src/main/java/foundation/e/apps/home/HomeFragment.kt +++ b/app/src/main/java/foundation/e/apps/home/HomeFragment.kt @@ -51,6 +51,7 @@ import javax.inject.Inject @AndroidEntryPoint class HomeFragment : Fragment(R.layout.fragment_home), FusedAPIInterface { + private lateinit var homeParentRVAdapter: HomeParentRVAdapter private var _binding: FragmentHomeBinding? = null private val binding get() = _binding!! @@ -83,7 +84,7 @@ class HomeFragment : Fragment(R.layout.fragment_home), FusedAPIInterface { } } - val homeParentRVAdapter = HomeParentRVAdapter( + homeParentRVAdapter = HomeParentRVAdapter( this, pkgManagerModule, pwaManagerModule, @@ -123,10 +124,6 @@ class HomeFragment : Fragment(R.layout.fragment_home), FusedAPIInterface { }, it.second) } } - - appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { - updateProgressOfDownloadingAppItemViews(homeParentRVAdapter, it) - } } /* @@ -190,6 +187,9 @@ class HomeFragment : Fragment(R.layout.fragment_home), FusedAPIInterface { override fun onResume() { super.onResume() binding.shimmerLayout.startShimmer() + appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { + updateProgressOfDownloadingAppItemViews(homeParentRVAdapter, it) + } } override fun onPause() { diff --git a/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt b/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt deleted file mode 100644 index c1d48732d..000000000 --- a/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressFlow.kt +++ /dev/null @@ -1,10 +0,0 @@ -package foundation.e.apps.manager.download.data - -import kotlinx.coroutines.flow.Flow -import kotlinx.coroutines.flow.FlowCollector - -class DownloadProgressFlow : Flow { - override suspend fun collect(collector: FlowCollector) { - - } -} \ No newline at end of file diff --git a/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressLD.kt b/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressLD.kt index f461c1b56..b606f3b9b 100644 --- a/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressLD.kt +++ b/app/src/main/java/foundation/e/apps/manager/download/data/DownloadProgressLD.kt @@ -31,12 +31,11 @@ class DownloadProgressLD @Inject constructor( override fun observe(owner: LifecycleOwner, observer: Observer) { job = Job() super.observe(owner, observer) - } - override fun onActive() { - super.onActive() + val hasActiveObservers = hasActiveObservers() + launch { - while (isActive) { + while (hasActiveObservers) { val downloads = fusedManagerRepository.getDownloadList() val downloadingList = downloads.map { it.downloadIdMap }.filter { it.values.contains(false) } @@ -80,7 +79,6 @@ class DownloadProgressLD @Inject constructor( } if (downloadingIds.isEmpty()) { - clearDownload() cancel() } cursor.moveToNext() diff --git a/app/src/main/java/foundation/e/apps/search/SearchFragment.kt b/app/src/main/java/foundation/e/apps/search/SearchFragment.kt index 7cf486ab4..91e0ba2ad 100644 --- a/app/src/main/java/foundation/e/apps/search/SearchFragment.kt +++ b/app/src/main/java/foundation/e/apps/search/SearchFragment.kt @@ -49,6 +49,7 @@ import foundation.e.apps.api.fused.data.FusedApp import foundation.e.apps.application.subFrags.ApplicationDialogFragment import foundation.e.apps.applicationlist.model.ApplicationListRVAdapter import foundation.e.apps.databinding.FragmentSearchBinding +import foundation.e.apps.manager.download.data.DownloadProgress import foundation.e.apps.manager.pkg.PkgManagerModule import foundation.e.apps.utils.enums.Status import foundation.e.apps.utils.enums.User @@ -151,26 +152,6 @@ class SearchFragment : layoutManager = LinearLayoutManager(view.context) } - appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { - val adapter = recyclerView?.adapter as ApplicationListRVAdapter - lifecycleScope.launch { - adapter.currentList.forEach { fusedApp -> - if (fusedApp.status == Status.DOWNLOADING) { - val progress = appProgressViewModel.calculateProgress(fusedApp, it) - val downloadProgress = - ((progress.second / progress.first.toDouble()) * 100).toInt() - val viewHolder = recyclerView?.findViewHolderForAdapterPosition( - adapter.currentList.indexOf(fusedApp) - ) - viewHolder?.let { - (viewHolder as ApplicationListRVAdapter.ViewHolder).binding.installButton.text = - "$downloadProgress%" - } - } - } - } - } - mainActivityViewModel.downloadList.observe(viewLifecycleOwner) { list -> val searchList = searchViewModel.searchResult.value?.toMutableList() @@ -199,9 +180,33 @@ class SearchFragment : } } + private fun updateProgressOfInstallingApps(downloadProgress: DownloadProgress) { + val adapter = recyclerView?.adapter as ApplicationListRVAdapter + lifecycleScope.launch { + adapter.currentList.forEach { fusedApp -> + if (fusedApp.status == Status.DOWNLOADING) { + val progress = + appProgressViewModel.calculateProgress(fusedApp, downloadProgress) + val downloadProgress = + ((progress.second / progress.first.toDouble()) * 100).toInt() + val viewHolder = recyclerView?.findViewHolderForAdapterPosition( + adapter.currentList.indexOf(fusedApp) + ) + viewHolder?.let { + (viewHolder as ApplicationListRVAdapter.ViewHolder).binding.installButton.text = + "$downloadProgress%" + } + } + } + } + } + override fun onResume() { super.onResume() binding.shimmerLayout.startShimmer() + appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { + updateProgressOfInstallingApps(it) + } } override fun onPause() { diff --git a/app/src/main/java/foundation/e/apps/updates/UpdatesFragment.kt b/app/src/main/java/foundation/e/apps/updates/UpdatesFragment.kt index eb03b02d9..65a116ba1 100644 --- a/app/src/main/java/foundation/e/apps/updates/UpdatesFragment.kt +++ b/app/src/main/java/foundation/e/apps/updates/UpdatesFragment.kt @@ -121,10 +121,6 @@ class UpdatesFragment : Fragment(R.layout.fragment_updates), FusedAPIInterface { layoutManager = LinearLayoutManager(view.context) } - appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { - updateProgressOfDownloadingItems(recyclerView, it) - } - updatesViewModel.updatesList.observe(viewLifecycleOwner) { listAdapter?.setData(it) if (!isDownloadObserverAdded) { @@ -143,6 +139,12 @@ class UpdatesFragment : Fragment(R.layout.fragment_updates), FusedAPIInterface { } } + override fun onResume() { + super.onResume() + appProgressViewModel.downloadProgress.observe(viewLifecycleOwner) { + updateProgressOfDownloadingItems(binding.recyclerView, it) + } + } private fun observeDownloadList() { mainActivityViewModel.downloadList.observe(viewLifecycleOwner) { list -> val appList = updatesViewModel.updatesList.value?.toMutableList() -- GitLab