[#1178] Slightly improve Update screen UI

This commit is contained in:
Honza Rychnovský 2024-01-10 16:12:27 +01:00 committed by GitHub
parent 0ad1477e1b
commit b58d3069c2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 44 additions and 38 deletions

View File

@ -12,6 +12,8 @@ directly impact users rather than highlighting other key architectural updates.*
### Changed
- The Not Enough Space screen used for notifying about insufficient free device disk space now provides the light
theme by default
- The App Update screen's user interface was improved to align with the other implemented screens. Its final design
is still in progress.
## [0.2.0 (523)] - 2024-01-09

View File

@ -42,10 +42,11 @@ import co.electriccoin.zcash.ui.design.theme.ZcashTheme
private fun ButtonComposablePreview() {
ZcashTheme(forceDarkMode = false) {
GradientSurface {
Column {
Column(Modifier.padding(ZcashTheme.dimens.spacingDefault)) {
PrimaryButton(onClick = { }, text = "Primary")
SecondaryButton(onClick = { }, text = "Secondary")
TertiaryButton(onClick = { }, text = "Tertiary")
TertiaryButton(onClick = { }, text = "Tertiary", enabled = false)
NavigationButton(onClick = { }, text = "Navigation")
DangerousButton(onClick = { }, text = "Dangerous")
}
@ -165,7 +166,7 @@ fun NavigationButton(
modifier: Modifier = Modifier,
outerPaddingValues: PaddingValues =
PaddingValues(
horizontal = ZcashTheme.dimens.spacingDefault,
horizontal = ZcashTheme.dimens.spacingNone,
vertical = ZcashTheme.dimens.spacingSmall
),
) {
@ -195,7 +196,7 @@ fun TertiaryButton(
modifier: Modifier = Modifier,
outerPaddingValues: PaddingValues =
PaddingValues(
horizontal = ZcashTheme.dimens.spacingDefault,
horizontal = ZcashTheme.dimens.spacingNone,
vertical = ZcashTheme.dimens.spacingSmall
),
enabled: Boolean = true
@ -208,6 +209,7 @@ fun TertiaryButton(
Modifier
.fillMaxWidth()
.padding(outerPaddingValues)
.defaultMinSize(ZcashTheme.dimens.buttonWidth, ZcashTheme.dimens.buttonHeight)
),
enabled = enabled,
elevation = ButtonDefaults.buttonElevation(0.dp, 0.dp, 0.dp),
@ -229,7 +231,7 @@ fun DangerousButton(
modifier: Modifier = Modifier,
outerPaddingValues: PaddingValues =
PaddingValues(
horizontal = ZcashTheme.dimens.spacingDefault,
horizontal = ZcashTheme.dimens.spacingNone,
vertical = ZcashTheme.dimens.spacingSmall
),
) {
@ -241,6 +243,7 @@ fun DangerousButton(
Modifier
.fillMaxWidth()
.padding(outerPaddingValues)
.defaultMinSize(ZcashTheme.dimens.buttonWidth, ZcashTheme.dimens.buttonHeight)
),
colors = buttonColors(containerColor = ZcashTheme.colors.dangerous)
) {

View File

@ -11,7 +11,6 @@ import co.electriccoin.zcash.ui.screen.update.model.UpdateInfo
import co.electriccoin.zcash.ui.screen.update.model.UpdateState
import co.electriccoin.zcash.ui.test.getAppContext
import com.google.android.play.core.install.model.ActivityResult
import kotlinx.coroutines.ExperimentalCoroutinesApi
import kotlinx.coroutines.flow.Flow
import kotlinx.coroutines.test.runTest
import org.junit.Rule
@ -30,7 +29,6 @@ class AppUpdateCheckerImpTest {
}
private fun getAppUpdateInfoFlow(): Flow<UpdateInfo> {
@Suppress("MagicNumber")
return updateChecker.newCheckForUpdateAvailabilityFlow(
context
)
@ -38,7 +36,6 @@ class AppUpdateCheckerImpTest {
@Test
@MediumTest
@OptIn(ExperimentalCoroutinesApi::class)
fun check_for_update_availability_test() =
runTest {
assertNotNull(updateChecker)
@ -56,7 +53,6 @@ class AppUpdateCheckerImpTest {
@Test
@MediumTest
@OptIn(ExperimentalCoroutinesApi::class)
fun start_update_availability_test() =
runTest {
getAppUpdateInfoFlow().onFirst { updateInfo ->

View File

@ -41,13 +41,13 @@ class UpdateViewAndroidTest : UiTestPrerequisites() {
)
newTestSetup(updateInfo)
composeTestRule.onNodeWithText(getStringResource(R.string.update_header)).also {
composeTestRule.onNodeWithText(getStringResource(R.string.update_header), ignoreCase = true).also {
it.assertExists()
}
Espresso.pressBack()
composeTestRule.onNodeWithText(getStringResource(R.string.update_header)).also {
composeTestRule.onNodeWithText(getStringResource(R.string.update_header), ignoreCase = true).also {
it.assertDoesNotExist()
}
}
@ -64,13 +64,13 @@ class UpdateViewAndroidTest : UiTestPrerequisites() {
)
newTestSetup(updateInfo)
composeTestRule.onNodeWithText(getStringResource(R.string.update_critical_header)).also {
composeTestRule.onNodeWithText(getStringResource(R.string.update_critical_header), ignoreCase = true).also {
it.assertExists()
}
Espresso.pressBack()
composeTestRule.onNodeWithText(getStringResource(R.string.update_critical_header)).also {
composeTestRule.onNodeWithText(getStringResource(R.string.update_critical_header), ignoreCase = true).also {
it.assertExists()
}
}

View File

@ -15,7 +15,6 @@ import co.electriccoin.zcash.ui.screen.update.UpdateTag
import co.electriccoin.zcash.ui.screen.update.model.UpdateInfo
import co.electriccoin.zcash.ui.screen.update.model.UpdateState
import co.electriccoin.zcash.ui.test.getStringResource
import co.electriccoin.zcash.ui.test.getStringResourceWithArgs
import org.junit.Assert.assertEquals
import org.junit.Rule
import org.junit.Test
@ -38,13 +37,15 @@ class UpdateViewTest : UiTestPrerequisites() {
newTestSetup(updateInfo)
composeTestRule.onNodeWithText(
getStringResourceWithArgs(R.string.update_critical_header)
text = getStringResource(R.string.update_critical_header),
ignoreCase = true
).also {
it.assertExists()
}
composeTestRule.onNodeWithText(
getStringResourceWithArgs(R.string.update_later_disabled_button)
text = getStringResource(R.string.update_later_disabled_button),
ignoreCase = true
).also {
it.assertExists()
}
@ -82,12 +83,16 @@ class UpdateViewTest : UiTestPrerequisites() {
newTestSetup(updateInfo)
composeTestRule.onNodeWithText(getStringResourceWithArgs(R.string.update_header)).also {
composeTestRule.onNodeWithText(
text = getStringResource(R.string.update_header),
ignoreCase = true
).also {
it.assertExists()
}
composeTestRule.onNodeWithText(
getStringResourceWithArgs(R.string.update_later_enabled_button)
text = getStringResource(R.string.update_later_enabled_button),
ignoreCase = true
).also {
it.assertExists()
}

View File

@ -49,7 +49,7 @@ class AppUpdateCheckerImp private constructor() : AppUpdateChecker {
if (appUpdateInfo.updateAvailability() == UpdateAvailability.UPDATE_AVAILABLE &&
appUpdateInfo.isUpdateTypeAllowed(AppUpdateType.IMMEDIATE)
) {
// we force user to update immediately in case of high priority
// We force user to update immediately in case of high priority
// or in case of staleness days passed
if (isHighPriority(appUpdateInfo.updatePriority()) ||
(appUpdateInfo.clientVersionStalenessDays() ?: -1) >= stalenessDays
@ -58,6 +58,9 @@ class AppUpdateCheckerImp private constructor() : AppUpdateChecker {
} else {
emitSuccess(this, infoTask.result, UpdateState.Done)
}
} else {
// Return Done in case of no update available
emitSuccess(this, infoTask.result, UpdateState.Done)
}
}
awaitClose {

View File

@ -5,20 +5,19 @@ import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxHeight
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.wrapContentHeight
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.Update
import androidx.compose.material3.CircularProgressIndicator
import androidx.compose.material3.ExperimentalMaterial3Api
import androidx.compose.material3.Scaffold
import androidx.compose.material3.SnackbarHost
import androidx.compose.material3.SnackbarHostState
import androidx.compose.material3.Text
import androidx.compose.material3.TopAppBar
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
@ -30,6 +29,7 @@ import co.electriccoin.zcash.ui.design.component.Body
import co.electriccoin.zcash.ui.design.component.GradientSurface
import co.electriccoin.zcash.ui.design.component.PrimaryButton
import co.electriccoin.zcash.ui.design.component.Reference
import co.electriccoin.zcash.ui.design.component.SmallTopAppBar
import co.electriccoin.zcash.ui.design.component.TertiaryButton
import co.electriccoin.zcash.ui.design.theme.ZcashTheme
import co.electriccoin.zcash.ui.fixture.UpdateInfoFixture
@ -63,7 +63,7 @@ fun Update(
) {
Scaffold(
topBar = {
UpdateTopAppBar(updateInfo)
UpdateTopAppBar(updateInfo = updateInfo)
},
snackbarHost = {
SnackbarHost(snackbarHostState)
@ -120,12 +120,9 @@ fun UpdateOverlayRunning(updateInfo: UpdateInfo) {
}
@Composable
@OptIn(ExperimentalMaterial3Api::class)
private fun UpdateTopAppBar(updateInfo: UpdateInfo) {
TopAppBar(
title = {
Text(
text =
SmallTopAppBar(
titleText =
stringResource(
updateInfo.isForce.let { force ->
if (force) {
@ -137,8 +134,6 @@ private fun UpdateTopAppBar(updateInfo: UpdateInfo) {
)
)
}
)
}
@Composable
private fun UpdateBottomAppBar(
@ -159,6 +154,8 @@ private fun UpdateBottomAppBar(
outerPaddingValues = PaddingValues(all = ZcashTheme.dimens.spacingNone)
)
Spacer(modifier = Modifier.height(ZcashTheme.dimens.spacingDefault))
TertiaryButton(
onClick = onLater,
text =

View File

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="update_header">Update available!</string>
<string name="update_header">Update available</string>
<string name="update_critical_header">Critical update required!</string>
<string name="update_image_content_description"></string>
<string name="update_description">There is a new version of the app available.</string>