From 8da42136c3f2cda54a0ed4919729743b77c1ac9a Mon Sep 17 00:00:00 2001 From: Omer Habib <30689349+omerhabib26@users.noreply.github.com> Date: Fri, 2 Aug 2024 15:18:21 +0500 Subject: [PATCH] fix: set dataValue to true for CourseOutline --- .../container/CourseContainerFragment.kt | 43 +++++------ .../container/CourseContainerViewModel.kt | 18 ++--- .../container/CourseContainerViewModelTest.kt | 72 ------------------- 3 files changed, 22 insertions(+), 111 deletions(-) diff --git a/course/src/main/java/org/openedx/course/presentation/container/CourseContainerFragment.kt b/course/src/main/java/org/openedx/course/presentation/container/CourseContainerFragment.kt index c6f452c10..e12004c73 100644 --- a/course/src/main/java/org/openedx/course/presentation/container/CourseContainerFragment.kt +++ b/course/src/main/java/org/openedx/course/presentation/container/CourseContainerFragment.kt @@ -56,12 +56,10 @@ import androidx.compose.ui.platform.ViewCompositionStrategy import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.text.style.TextAlign -import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.core.os.bundleOf import androidx.core.view.isVisible import androidx.fragment.app.Fragment -import androidx.fragment.app.FragmentActivity import androidx.fragment.app.FragmentManager import androidx.lifecycle.lifecycleScope import com.google.android.material.snackbar.Snackbar @@ -164,10 +162,7 @@ class CourseContainerFragment : Fragment(R.layout.fragment_course_container) { } } viewModel.errorMessage.observe(viewLifecycleOwner) { - snackBar = Snackbar.make(binding.root, it, Snackbar.LENGTH_INDEFINITE) - .setAction(org.openedx.core.R.string.core_error_try_again) { - viewModel.fetchCourseDetails() - } + snackBar = Snackbar.make(binding.root, it, Snackbar.LENGTH_SHORT) snackBar?.show() } @@ -181,6 +176,8 @@ class CourseContainerFragment : Fragment(R.layout.fragment_course_container) { private fun onRefresh(currentPage: Int) { if (viewModel.courseAccessStatus.value == CourseAccessError.NONE) { viewModel.onRefresh(CourseContainerTab.entries[currentPage]) + } else { + viewModel.fetchCourseDetails() } } @@ -391,7 +388,7 @@ fun CourseDashboard( isInternetConnectionShown = true }, onReloadClick = { - isInternetConnectionShown = true + isInternetConnectionShown = viewModel.hasInternetConnection onRefresh(pagerState.currentPage) } ) @@ -520,7 +517,7 @@ private fun DashboardPager( @Composable private fun CourseAccessErrorView( - viewModel: CourseContainerViewModel?, + viewModel: CourseContainerViewModel, accessError: CourseAccessError?, fragmentManager: FragmentManager, ) { @@ -532,7 +529,7 @@ private fun CourseAccessErrorView( R.string.course_error_expired_not_upgradeable_title, TimeUtils.getCourseAccessFormattedDate( LocalContext.current, - viewModel?.courseDetails?.courseAccessDetails?.auditAccessExpires ?: Date() + viewModel.courseDetails?.courseAccessDetails?.auditAccessExpires ?: Date() ) ) } @@ -541,7 +538,7 @@ private fun CourseAccessErrorView( icon = painterResource(id = R.drawable.course_ic_calendar) message = stringResource( R.string.course_error_not_started_title, - viewModel?.courseDetails?.courseInfoOverview?.startDisplay ?: "" + viewModel.courseDetails?.courseInfoOverview?.startDisplay ?: "" ) } @@ -596,6 +593,7 @@ private fun CourseAccessErrorView( ) } SetupCourseAccessErrorButtons( + viewModel = viewModel, accessError = accessError, fragmentManager = fragmentManager, ) @@ -605,13 +603,13 @@ private fun CourseAccessErrorView( @Composable private fun SetupCourseAccessErrorButtons( + viewModel: CourseContainerViewModel, accessError: CourseAccessError?, fragmentManager: FragmentManager, ) { when (accessError) { CourseAccessError.AUDIT_EXPIRED_NOT_UPGRADABLE, CourseAccessError.NOT_YET_STARTED, - CourseAccessError.UNKNOWN, -> { OpenEdXButton( text = stringResource(R.string.course_label_back), @@ -619,6 +617,15 @@ private fun SetupCourseAccessErrorButtons( ) } + CourseAccessError.UNKNOWN -> { + if (viewModel.hasInternetConnection) { + OpenEdXButton( + text = stringResource(R.string.course_label_back), + onClick = { fragmentManager.popBackStack() }, + ) + } + } + else -> {} } } @@ -629,17 +636,3 @@ private fun scrollToDates(scope: CoroutineScope, pagerState: PagerState) { pagerState.animateScrollToPage(CourseContainerTab.entries.indexOf(CourseContainerTab.DATES)) } } - -@Preview(uiMode = Configuration.UI_MODE_NIGHT_NO) -@Preview(uiMode = Configuration.UI_MODE_NIGHT_YES) -@Composable -private fun CourseAccessErrorViewPreview() { - val context = LocalContext.current - OpenEdXTheme { - CourseAccessErrorView( - viewModel = null, - accessError = CourseAccessError.AUDIT_EXPIRED_NOT_UPGRADABLE, - fragmentManager = (context as? FragmentActivity)?.supportFragmentManager!! - ) - } -} diff --git a/course/src/main/java/org/openedx/course/presentation/container/CourseContainerViewModel.kt b/course/src/main/java/org/openedx/course/presentation/container/CourseContainerViewModel.kt index a743730ec..98b46551d 100644 --- a/course/src/main/java/org/openedx/course/presentation/container/CourseContainerViewModel.kt +++ b/course/src/main/java/org/openedx/course/presentation/container/CourseContainerViewModel.kt @@ -22,7 +22,6 @@ import org.openedx.core.config.Config import org.openedx.core.data.storage.CorePreferences import org.openedx.core.domain.model.CourseAccessError import org.openedx.core.domain.model.CourseEnrollmentDetails -import org.openedx.core.exception.NoCachedDataException import org.openedx.core.extension.isFalse import org.openedx.core.extension.isTrue import org.openedx.core.presentation.settings.calendarsync.CalendarSyncDialogType @@ -201,18 +200,14 @@ class CourseContainerViewModel( delay(500L) courseNotifier.send(CourseOpenBlock(resumeBlockId)) } + _dataReady.value = true } } ?: run { _courseAccessStatus.value = CourseAccessError.UNKNOWN } } catch (e: Exception) { e.printStackTrace() - if (e.isInternetError() || e is NoCachedDataException) { - _errorMessage.value = - resourceManager.getString(CoreR.string.core_error_no_connection) - } else { - _courseAccessStatus.value = CourseAccessError.UNKNOWN - } + _courseAccessStatus.value = CourseAccessError.UNKNOWN _showProgress.value = false } } @@ -273,13 +268,8 @@ class CourseContainerViewModel( try { interactor.getCourseStructure(courseId, isNeedRefresh = true) } catch (e: Exception) { - if (e.isInternetError()) { - _errorMessage.value = - resourceManager.getString(CoreR.string.core_error_no_connection) - } else { - _errorMessage.value = - resourceManager.getString(CoreR.string.core_error_unknown_error) - } + _errorMessage.value = + resourceManager.getString(CoreR.string.core_error_unknown_error) } _refreshing.value = false courseNotifier.send(CourseStructureUpdated(courseId)) diff --git a/course/src/test/java/org/openedx/course/presentation/container/CourseContainerViewModelTest.kt b/course/src/test/java/org/openedx/course/presentation/container/CourseContainerViewModelTest.kt index 98cf58a8b..3d16c2490 100644 --- a/course/src/test/java/org/openedx/course/presentation/container/CourseContainerViewModelTest.kt +++ b/course/src/test/java/org/openedx/course/presentation/container/CourseContainerViewModelTest.kt @@ -190,49 +190,6 @@ class CourseContainerViewModelTest { Dispatchers.resetMain() } - @Test - fun `getCourseEnrollmentDetails internet connection exception`() = runTest { - val viewModel = CourseContainerViewModel( - "", - "", - "", - config, - interactor, - resourceManager, - courseNotifier, - networkConnection, - corePreferences, - analytics, - imageProcessor, - calendarSyncScheduler, - courseRouter, - ) - every { networkConnection.isOnline() } returns true - coEvery { interactor.getCourseStructure(any(), any()) } returns courseStructure - coEvery { interactor.getEnrollmentDetails(any()) } throws UnknownHostException() - every { - analytics.logScreenEvent( - CourseAnalyticsEvent.DASHBOARD.eventName, - any() - ) - } returns Unit - viewModel.fetchCourseDetails() - advanceUntilIdle() - - coVerify(exactly = 1) { interactor.getEnrollmentDetails(any()) } - verify(exactly = 1) { - analytics.logScreenEvent( - CourseAnalyticsEvent.DASHBOARD.eventName, - any() - ) - } - - val message = viewModel.errorMessage.value - assertEquals(noInternet, message) - assert(!viewModel.refreshing.value) - assert(viewModel.courseAccessStatus.value == null) - } - @Test fun `getCourseEnrollmentDetails unknown exception`() = runTest { val viewModel = CourseContainerViewModel( @@ -354,35 +311,6 @@ class CourseContainerViewModelTest { assert(viewModel.courseAccessStatus.value != null) } - @Test - fun `updateData no internet connection exception`() = runTest { - val viewModel = CourseContainerViewModel( - "", - "", - "", - config, - interactor, - resourceManager, - courseNotifier, - networkConnection, - corePreferences, - analytics, - imageProcessor, - calendarSyncScheduler, - courseRouter - ) - coEvery { interactor.getCourseStructure(any(), true) } throws UnknownHostException() - coEvery { courseNotifier.send(CourseStructureUpdated("")) } returns Unit - viewModel.updateData() - advanceUntilIdle() - - coVerify(exactly = 1) { interactor.getCourseStructure(any(), true) } - - val message = viewModel.errorMessage.value - assertEquals(noInternet, message) - assert(!viewModel.refreshing.value) - } - @Test fun `updateData unknown exception`() = runTest { val viewModel = CourseContainerViewModel(