[#1178] Slightly improve Update screen UI
This commit is contained in:
parent
0ad1477e1b
commit
b58d3069c2
|
@ -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
|
||||
|
||||
|
|
|
@ -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)
|
||||
) {
|
||||
|
|
|
@ -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 ->
|
||||
|
|
|
@ -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()
|
||||
}
|
||||
}
|
||||
|
|
|
@ -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()
|
||||
}
|
||||
|
|
|
@ -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 {
|
||||
|
|
|
@ -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) {
|
||||
|
@ -136,8 +133,6 @@ private fun UpdateTopAppBar(updateInfo: UpdateInfo) {
|
|||
}
|
||||
)
|
||||
)
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
@Composable
|
||||
|
@ -159,6 +154,8 @@ private fun UpdateBottomAppBar(
|
|||
outerPaddingValues = PaddingValues(all = ZcashTheme.dimens.spacingNone)
|
||||
)
|
||||
|
||||
Spacer(modifier = Modifier.height(ZcashTheme.dimens.spacingDefault))
|
||||
|
||||
TertiaryButton(
|
||||
onClick = onLater,
|
||||
text =
|
||||
|
|
|
@ -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>
|
||||
|
|
Loading…
Reference in New Issue