diff --git a/CHANGELOG.md b/CHANGELOG.md index a3b71937..75d0e4c8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ and this application adheres to [Semantic Versioning](https://semver.org/spec/v2 ### Changed - The About screen has been redesigned to align with the new design guidelines +- `StyledBalance` text styles have been refactored from `Pair` into `BalanceTextStyle` ## [1.1.3 (682)] - 2024-07-03 diff --git a/ui-design-lib/src/main/java/co/electriccoin/zcash/ui/design/component/Balance.kt b/ui-design-lib/src/main/java/co/electriccoin/zcash/ui/design/component/Balance.kt index 086e7be4..79e182e6 100644 --- a/ui-design-lib/src/main/java/co/electriccoin/zcash/ui/design/component/Balance.kt +++ b/ui-design-lib/src/main/java/co/electriccoin/zcash/ui/design/component/Balance.kt @@ -8,6 +8,8 @@ import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.height import androidx.compose.material3.Text import androidx.compose.runtime.Composable +import androidx.compose.runtime.Immutable +import androidx.compose.runtime.Stable import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.Color import androidx.compose.ui.res.stringResource @@ -31,11 +33,6 @@ private fun StyledBalanceComposablePreview() { StyledBalance( balanceParts = ZecAmountTriple(main = "1,234.56789012"), isHideBalances = false, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceWidgetStyles.first, - ZcashTheme.extendedTypography.balanceWidgetStyles.second - ), modifier = Modifier ) @@ -44,11 +41,6 @@ private fun StyledBalanceComposablePreview() { StyledBalance( balanceParts = ZecAmountTriple(main = "1,234.56789012"), isHideBalances = true, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceWidgetStyles.first, - ZcashTheme.extendedTypography.balanceWidgetStyles.second - ), modifier = Modifier ) } @@ -63,8 +55,8 @@ private fun StyledBalanceComposablePreview() { * @param balanceParts [ZecAmountTriple] class that holds balance parts * @param isHideBalances Flag referring about the balance being hidden or not * @param hiddenBalancePlaceholder String holding the placeholder for the hidden balance - * @param textStyles Styles for the first and second part of the balance - * @param textColor Optional color to modify the default font color from [textStyles] + * @param textStyle Styles for the integer and floating part of the balance + * @param textColor Optional color to modify the default font color from [textStyle] * @param modifier Modifier to modify the Text UI element as needed */ @OptIn(ExperimentalFoundationApi::class) @@ -72,17 +64,17 @@ private fun StyledBalanceComposablePreview() { @Composable fun StyledBalance( balanceParts: ZecAmountTriple, - textStyles: Pair, modifier: Modifier = Modifier, isHideBalances: Boolean = false, hiddenBalancePlaceholder: String = stringResource(id = R.string.hide_balance_placeholder), - textColor: Color? = null, + textColor: Color = Color.Unspecified, + textStyle: BalanceTextStyle = StyledBalanceDefaults.textStyles(), ) { val content = if (isHideBalances) { buildAnnotatedString { withStyle( - style = textStyles.first.toSpanStyle() + style = textStyle.mostSignificantPart.toSpanStyle() ) { append(hiddenBalancePlaceholder) } @@ -92,12 +84,12 @@ fun StyledBalance( buildAnnotatedString { withStyle( - style = textStyles.first.toSpanStyle() + style = textStyle.mostSignificantPart.toSpanStyle() ) { append(balanceSplit.first) } withStyle( - style = textStyles.second.toSpanStyle() + style = textStyle.leastSignificantPart.toSpanStyle() ) { append(balanceSplit.second) } @@ -110,20 +102,12 @@ fun StyledBalance( .animateContentSize() .then(modifier) - if (textColor != null) { - Text( - text = content, - color = textColor, - maxLines = 1, - modifier = resultModifier - ) - } else { - Text( - text = content, - maxLines = 1, - modifier = resultModifier - ) - } + Text( + text = content, + color = textColor, + maxLines = 1, + modifier = resultModifier + ) } private const val CUT_POSITION_OFFSET = 4 @@ -171,3 +155,18 @@ data class ZecAmountTriple( val prefix: String? = null, val suffix: String? = null ) + +@Immutable +data class BalanceTextStyle(val mostSignificantPart: TextStyle, val leastSignificantPart: TextStyle) + +object StyledBalanceDefaults { + @Stable + @Composable + fun textStyles( + mostSignificantPart: TextStyle = ZcashTheme.extendedTypography.balanceWidgetStyles.first, + leastSignificantPart: TextStyle = ZcashTheme.extendedTypography.balanceWidgetStyles.second, + ) = BalanceTextStyle( + mostSignificantPart = mostSignificantPart, + leastSignificantPart = leastSignificantPart + ) +} diff --git a/ui-lib/src/main/java/co/electriccoin/zcash/ui/common/compose/BalanceWidget.kt b/ui-lib/src/main/java/co/electriccoin/zcash/ui/common/compose/BalanceWidget.kt index 39b7bc8b..aaea65df 100644 --- a/ui-lib/src/main/java/co/electriccoin/zcash/ui/common/compose/BalanceWidget.kt +++ b/ui-lib/src/main/java/co/electriccoin/zcash/ui/common/compose/BalanceWidget.kt @@ -27,6 +27,7 @@ import co.electriccoin.zcash.ui.design.component.Body import co.electriccoin.zcash.ui.design.component.CircularSmallProgressIndicator import co.electriccoin.zcash.ui.design.component.Reference import co.electriccoin.zcash.ui.design.component.StyledBalance +import co.electriccoin.zcash.ui.design.component.StyledBalanceDefaults import co.electriccoin.zcash.ui.design.component.ZecAmountTriple import co.electriccoin.zcash.ui.design.theme.ZcashTheme @@ -153,14 +154,15 @@ fun BalanceWidget( BalanceState.None, is BalanceState.Loading -> { CircularSmallProgressIndicator(color = ZcashTheme.colors.circularProgressBarSmallDark) } + is BalanceState.Available -> { StyledBalance( balanceParts = balanceState.spendableBalance.toZecStringFull().asZecAmountTriple(), isHideBalances = isHideBalances, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceWidgetStyles.third, - ZcashTheme.extendedTypography.balanceWidgetStyles.fourth + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceWidgetStyles.third, + leastSignificantPart = ZcashTheme.extendedTypography.balanceWidgetStyles.fourth ) ) } @@ -189,10 +191,10 @@ fun BalanceWidgetBigLineOnly( StyledBalance( balanceParts = parts, isHideBalances = isHideBalances, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceWidgetStyles.first, - ZcashTheme.extendedTypography.balanceWidgetStyles.second + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceWidgetStyles.first, + leastSignificantPart = ZcashTheme.extendedTypography.balanceWidgetStyles.second ) ) diff --git a/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/account/view/HistoryView.kt b/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/account/view/HistoryView.kt index 2706aa21..bddd8bc9 100644 --- a/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/account/view/HistoryView.kt +++ b/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/account/view/HistoryView.kt @@ -59,6 +59,7 @@ import co.electriccoin.zcash.ui.design.component.BubbleArrowAlignment import co.electriccoin.zcash.ui.design.component.BubbleMessage import co.electriccoin.zcash.ui.design.component.CircularMidProgressIndicator import co.electriccoin.zcash.ui.design.component.StyledBalance +import co.electriccoin.zcash.ui.design.component.StyledBalanceDefaults import co.electriccoin.zcash.ui.design.component.TextWithIcon import co.electriccoin.zcash.ui.design.theme.ZcashTheme import co.electriccoin.zcash.ui.fixture.WalletSnapshotFixture @@ -159,6 +160,7 @@ internal fun HistoryContainer( TransactionUiState.Loading -> { LoadingTransactionHistory() } + TransactionUiState.SyncingEmpty -> { if (walletRestoringState == WalletRestoringState.INITIATING) { // In case we are syncing a new wallet, it's empty @@ -167,6 +169,7 @@ internal fun HistoryContainer( // Intentionally leaving the UI empty otherwise } } + is TransactionUiState.Prepared -> { HistoryList( transactions = transactionState.transactions, @@ -174,6 +177,7 @@ internal fun HistoryContainer( onAction = onTransactionItemAction, ) } + is TransactionUiState.DoneEmpty -> { EmptyTransactionHistory() } @@ -320,12 +324,14 @@ private fun HistoryItem( textColor = MaterialTheme.colorScheme.onBackground textStyle = ZcashTheme.extendedTypography.transactionItemStyles.titleRegular } + TransactionExtendedState.SENDING -> { typeText = stringResource(id = R.string.account_history_item_sending) typeIcon = ImageVector.vectorResource(R.drawable.ic_trx_send_icon) textColor = ZcashTheme.colors.textDescription textStyle = ZcashTheme.extendedTypography.transactionItemStyles.titleRunning } + TransactionExtendedState.SEND_FAILED -> { typeText = stringResource(id = R.string.account_history_item_send_failed) typeIcon = ImageVector.vectorResource(R.drawable.ic_trx_send_icon) @@ -339,12 +345,14 @@ private fun HistoryItem( textColor = MaterialTheme.colorScheme.onBackground textStyle = ZcashTheme.extendedTypography.transactionItemStyles.titleRegular } + TransactionExtendedState.RECEIVING -> { typeText = stringResource(id = R.string.account_history_item_receiving) typeIcon = ImageVector.vectorResource(R.drawable.ic_trx_receive_icon) textColor = ZcashTheme.colors.textDescription textStyle = ZcashTheme.extendedTypography.transactionItemStyles.titleRunning } + TransactionExtendedState.RECEIVE_FAILED -> { typeText = stringResource(id = R.string.account_history_item_receive_failed) typeIcon = ImageVector.vectorResource(R.drawable.ic_trx_receive_icon) @@ -489,10 +497,10 @@ private fun HistoryItemCollapsedMainPart( ).asZecAmountTriple(prefix) }, isHideBalances = isHideBalances, - textStyles = - Pair( - first = valueTextStyle, - second = ZcashTheme.extendedTypography.transactionItemStyles.valueSecondPart + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = valueTextStyle, + leastSignificantPart = ZcashTheme.extendedTypography.transactionItemStyles.valueSecondPart ), textColor = valueTextColor, ) @@ -510,6 +518,7 @@ private fun HistoryItemCollapsedAddressPart( TrxItemState.EXPANDED_ADDRESS, TrxItemState.EXPANDED_ALL -> { // No address displayed in the top row } + else -> { val clickModifier = modifier.then( @@ -828,10 +837,10 @@ private fun HistoryItemTransactionFeePart( balanceParts = fee.toZecStringFull().asZecAmountTriple(), // Fees are always visible isHideBalances = false, - textStyles = - Pair( - first = ZcashTheme.extendedTypography.transactionItemStyles.feeFirstPart, - second = ZcashTheme.extendedTypography.transactionItemStyles.feeSecondPart + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.transactionItemStyles.feeFirstPart, + leastSignificantPart = ZcashTheme.extendedTypography.transactionItemStyles.feeSecondPart ), textColor = ZcashTheme.colors.textDescription ) @@ -936,6 +945,7 @@ private fun TransactionOverview.getExtendedState(): TransactionExtendedState { TransactionExtendedState.RECEIVE_FAILED } } + TransactionState.Confirmed -> { if (isSentTransaction) { TransactionExtendedState.SENT @@ -943,6 +953,7 @@ private fun TransactionOverview.getExtendedState(): TransactionExtendedState { TransactionExtendedState.RECEIVED } } + TransactionState.Pending -> { if (isSentTransaction) { TransactionExtendedState.SENDING @@ -950,6 +961,7 @@ private fun TransactionOverview.getExtendedState(): TransactionExtendedState { TransactionExtendedState.RECEIVING } } + else -> { error("Unexpected transaction state found while calculating its extended state.") } diff --git a/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/balances/view/BalancesView.kt b/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/balances/view/BalancesView.kt index e5ae4c90..6c115d45 100644 --- a/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/balances/view/BalancesView.kt +++ b/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/balances/view/BalancesView.kt @@ -79,6 +79,7 @@ import co.electriccoin.zcash.ui.design.component.Reference import co.electriccoin.zcash.ui.design.component.Small import co.electriccoin.zcash.ui.design.component.SmallTopAppBar import co.electriccoin.zcash.ui.design.component.StyledBalance +import co.electriccoin.zcash.ui.design.component.StyledBalanceDefaults import co.electriccoin.zcash.ui.design.component.TopAppBarHideBalancesNavigation import co.electriccoin.zcash.ui.design.theme.ZcashTheme import co.electriccoin.zcash.ui.fixture.BalanceStateFixture @@ -393,8 +394,6 @@ private fun BalancesMainContent( } } -const val DEFAULT_LESS_THAN_FEE = 100_000L - @Composable fun TransparentBalancePanel( isHideBalances: Boolean, @@ -501,10 +500,10 @@ fun TransparentBalanceRow( StyledBalance( balanceParts = walletSnapshot.transparentBalance.toZecStringFull().asZecAmountTriple(), isHideBalances = isHideBalances, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceSingleStyles.first, - ZcashTheme.extendedTypography.balanceSingleStyles.second + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.first, + leastSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.second ), textColor = ZcashTheme.colors.textDescriptionDark ) @@ -628,10 +627,10 @@ fun SpendableBalanceRow( StyledBalance( balanceParts = walletSnapshot.spendableBalance().toZecStringFull().asZecAmountTriple(), isHideBalances = isHideBalances, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceSingleStyles.first, - ZcashTheme.extendedTypography.balanceSingleStyles.second + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.first, + leastSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.second ), textColor = ZcashTheme.colors.textPrimary ) @@ -667,10 +666,10 @@ fun ChangePendingRow( StyledBalance( balanceParts = walletSnapshot.changePendingBalance().toZecStringFull().asZecAmountTriple(), isHideBalances = isHideBalances, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceSingleStyles.first, - ZcashTheme.extendedTypography.balanceSingleStyles.second + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.first, + leastSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.second ), textColor = ZcashTheme.colors.textDescriptionDark ) @@ -705,10 +704,10 @@ fun PendingTransactionsRow( StyledBalance( balanceParts = walletSnapshot.valuePendingBalance().toZecStringFull().asZecAmountTriple(), isHideBalances = isHideBalances, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceSingleStyles.first, - ZcashTheme.extendedTypography.balanceSingleStyles.second + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.first, + leastSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.second ), textColor = ZcashTheme.colors.textDescriptionDark ) diff --git a/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/sendconfirmation/view/SendConfirmationView.kt b/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/sendconfirmation/view/SendConfirmationView.kt index 28bf620e..6bf6d4f4 100644 --- a/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/sendconfirmation/view/SendConfirmationView.kt +++ b/ui-lib/src/main/java/co/electriccoin/zcash/ui/screen/sendconfirmation/view/SendConfirmationView.kt @@ -54,6 +54,7 @@ import co.electriccoin.zcash.ui.design.component.SecondaryButton import co.electriccoin.zcash.ui.design.component.Small import co.electriccoin.zcash.ui.design.component.SmallTopAppBar import co.electriccoin.zcash.ui.design.component.StyledBalance +import co.electriccoin.zcash.ui.design.component.StyledBalanceDefaults import co.electriccoin.zcash.ui.design.component.Tiny import co.electriccoin.zcash.ui.design.component.TopAppBarBackNavigation import co.electriccoin.zcash.ui.design.theme.ZcashTheme @@ -400,11 +401,11 @@ private fun SendConfirmationContent( balanceParts = zecSend.proposal!!.totalFeeRequired().toZecStringFull().asZecAmountTriple(), // We don't hide any balance in confirmation screen isHideBalances = false, - textStyles = - Pair( - ZcashTheme.extendedTypography.balanceSingleStyles.first, - ZcashTheme.extendedTypography.balanceSingleStyles.second - ) + textStyle = + StyledBalanceDefaults.textStyles( + mostSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.first, + leastSignificantPart = ZcashTheme.extendedTypography.balanceSingleStyles.second + ), ) Spacer(modifier = Modifier.height(ZcashTheme.dimens.spacingUpLarge))