From f0fa0111bab0adde01c72b290f4b9ee6d55dc1ae Mon Sep 17 00:00:00 2001 From: Jan Cortiel Date: Mon, 22 Jul 2024 11:09:32 +0200 Subject: [PATCH] #262: Fixed the placement of the error view and the start/pause observation button --- .../activities/tasks/TaskDetailsView.kt | 105 ++++++++++-------- 1 file changed, 60 insertions(+), 45 deletions(-) diff --git a/androidApp/src/main/java/io/redlink/more/app/android/activities/tasks/TaskDetailsView.kt b/androidApp/src/main/java/io/redlink/more/app/android/activities/tasks/TaskDetailsView.kt index bcb53fa0..a49e7d50 100644 --- a/androidApp/src/main/java/io/redlink/more/app/android/activities/tasks/TaskDetailsView.kt +++ b/androidApp/src/main/java/io/redlink/more/app/android/activities/tasks/TaskDetailsView.kt @@ -138,61 +138,76 @@ fun TaskDetailsView( hasPreview = false ) Spacer(modifier = Modifier.height(8.dp)) - scheduleId?.let { - if (!viewModel.taskDetailsModel.value.state.completed()) { - DatapointCollectionView( - viewModel.dataPointCount.value, - viewModel.taskDetailsModel.value.state - ) - } + + } + } + + Column( + modifier = Modifier.weight(1f), + verticalArrangement = Arrangement.Center, + horizontalAlignment = Alignment.CenterHorizontally + ) { + scheduleId?.let { + if (!viewModel.taskDetailsModel.value.state.completed()) { + DatapointCollectionView( + viewModel.dataPointCount.value, + viewModel.taskDetailsModel.value.state + ) } } } - Spacer(modifier = Modifier.height(20.dp)) + Column( + modifier = Modifier.weight(1f), + verticalArrangement = Arrangement.Bottom, + horizontalAlignment = Alignment.CenterHorizontally + ) { - ObservationErrorListView( - errors = viewModel.taskObservationErrors, - errorActions = viewModel.taskObservationErrorActions - ) - if (!viewModel.taskDetailsModel.value.hidden) { - SmallTextButton( - text = if (viewModel.taskDetailsModel.value.state == ScheduleState.RUNNING) getStringResource( - id = R.string.more_observation_pause - ) - else if (viewModel.taskDetailsModel.value.observationType == SimpleQuestionType().observationType) getStringResource( - id = R.string.more_questionnaire_start - ) - else if (viewModel.taskDetailsModel.value.observationType == LimeSurveyType().observationType) getStringResource( - id = R.string.more_limesurvey_start - ) - else getStringResource( - id = R.string.more_observation_start - ), - enabled = viewModel.isEnabled.value && if (viewModel.taskDetailsModel.value.observationType == PolarVerityHeartRateType( - emptySet() - ).observationType - ) viewModel.polarHrReady.value else true - ) { - if (viewModel.taskDetailsModel.value.observationType == SimpleQuestionType().observationType) { - navController.navigate( - NavigationScreen.SIMPLE_QUESTION.navigationRoute( - "scheduleId" to scheduleId - ) + ObservationErrorListView( + errors = viewModel.taskObservationErrors, + errorActions = viewModel.taskObservationErrorActions + ) + + if (!viewModel.taskDetailsModel.value.hidden) { + SmallTextButton( + text = if (viewModel.taskDetailsModel.value.state == ScheduleState.RUNNING) getStringResource( + id = R.string.more_observation_pause ) - } else if (viewModel.taskDetailsModel.value.observationType == LimeSurveyType().observationType) { - navController.navigate( - NavigationScreen.LIMESURVEY.navigationRoute( - "scheduleId" to scheduleId - ) + else if (viewModel.taskDetailsModel.value.observationType == SimpleQuestionType().observationType) getStringResource( + id = R.string.more_questionnaire_start + ) + else if (viewModel.taskDetailsModel.value.observationType == LimeSurveyType().observationType) getStringResource( + id = R.string.more_limesurvey_start ) - } else if (viewModel.taskDetailsModel.value.state == ScheduleState.RUNNING) { - viewModel.pauseObservation() - } else { - viewModel.startObservation() + else getStringResource( + id = R.string.more_observation_start + ), + enabled = viewModel.isEnabled.value && if (viewModel.taskDetailsModel.value.observationType == PolarVerityHeartRateType( + emptySet() + ).observationType + ) viewModel.polarHrReady.value else true + ) { + if (viewModel.taskDetailsModel.value.observationType == SimpleQuestionType().observationType) { + navController.navigate( + NavigationScreen.SIMPLE_QUESTION.navigationRoute( + "scheduleId" to scheduleId + ) + ) + } else if (viewModel.taskDetailsModel.value.observationType == LimeSurveyType().observationType) { + navController.navigate( + NavigationScreen.LIMESURVEY.navigationRoute( + "scheduleId" to scheduleId + ) + ) + } else if (viewModel.taskDetailsModel.value.state == ScheduleState.RUNNING) { + viewModel.pauseObservation() + } else { + viewModel.startObservation() + } } } } + } } \ No newline at end of file