From dcfb6b8dfddda6f98865bbb7263e98d5829efa7e Mon Sep 17 00:00:00 2001 From: joragua Date: Fri, 29 Nov 2024 14:46:21 +0100 Subject: [PATCH] fix: created a new method in `DrawerViewModel` to avoid navigation when the quota is refreshed --- .../presentation/common/DrawerViewModel.kt | 10 ++++++++++ .../android/ui/activity/FileDisplayActivity.kt | 15 ++------------- 2 files changed, 12 insertions(+), 13 deletions(-) diff --git a/owncloudApp/src/main/java/com/owncloud/android/presentation/common/DrawerViewModel.kt b/owncloudApp/src/main/java/com/owncloud/android/presentation/common/DrawerViewModel.kt index f8301362dffa..d942a3add099 100644 --- a/owncloudApp/src/main/java/com/owncloud/android/presentation/common/DrawerViewModel.kt +++ b/owncloudApp/src/main/java/com/owncloud/android/presentation/common/DrawerViewModel.kt @@ -41,6 +41,8 @@ import com.owncloud.android.providers.ContextProvider import com.owncloud.android.providers.CoroutinesDispatcherProvider import com.owncloud.android.usecases.accounts.RemoveAccountUseCase import kotlinx.coroutines.launch +import kotlinx.coroutines.runBlocking +import kotlinx.coroutines.withContext import timber.log.Timber class DrawerViewModel( @@ -107,4 +109,12 @@ class DrawerViewModel( } } } + + fun checkUserLight(accountName: String): Boolean = runBlocking(CoroutinesDispatcherProvider().io) { + val quota = withContext(CoroutinesDispatcherProvider().io) { + getStoredQuotaUseCase(GetStoredQuotaUseCase.Params(accountName)) + } + quota.getDataOrNull()?.available == -4L + } + } diff --git a/owncloudApp/src/main/java/com/owncloud/android/ui/activity/FileDisplayActivity.kt b/owncloudApp/src/main/java/com/owncloud/android/ui/activity/FileDisplayActivity.kt index d4c8e5ca8a99..797399ff93de 100644 --- a/owncloudApp/src/main/java/com/owncloud/android/ui/activity/FileDisplayActivity.kt +++ b/owncloudApp/src/main/java/com/owncloud/android/ui/activity/FileDisplayActivity.kt @@ -73,7 +73,6 @@ import com.owncloud.android.domain.files.model.FileListOption import com.owncloud.android.domain.files.model.OCFile import com.owncloud.android.domain.files.model.OCFile.Companion.ROOT_PARENT_ID import com.owncloud.android.domain.spaces.model.OCSpace -import com.owncloud.android.domain.user.model.UserQuota import com.owncloud.android.domain.utils.Event import com.owncloud.android.extensions.checkPasscodeEnforced import com.owncloud.android.extensions.collectLatestLifecycleFlow @@ -324,10 +323,9 @@ class FileDisplayActivity : FileActivity(), capabilitiesViewModel.capabilities.observe(this, Event.EventObserver { onCapabilitiesOperationFinish(it) }) + isLightUser = drawerViewModel.checkUserLight(account.name) + navigateTo(fileListOption, initialState = true) - drawerViewModel.userQuota.observe(this, Event.EventObserver { - onUserQuotaOperationFinish(it) - }) } startListeningToOperations() @@ -1522,15 +1520,6 @@ class FileDisplayActivity : FileActivity(), } } - private fun onUserQuotaOperationFinish(uiResult: UIResult) { - if (uiResult is UIResult.Success) { - if (uiResult.data?.available == -4L) { - isLightUser = true - } - } - navigateTo(fileListOption, initialState = true) - } - override fun onSavedCertificate() { startSyncFolderOperation(currentDir, false) }