[#1216] Home screen tabs UI improvements

Closing #1216
This commit is contained in:
Honza Rychnovský 2024-02-01 10:36:44 -08:00 committed by GitHub
parent 392689e676
commit c5efcabf4c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 39 additions and 14 deletions

View File

@ -11,7 +11,8 @@ directly impact users rather than highlighting other key architectural updates.*
### Fixed ### Fixed
- Fixed character replacement in Zcash addresses on the Receive screen caused by ligatures in the app's primary font - Fixed character replacement in Zcash addresses on the Receive screen caused by ligatures in the app's primary font
using the secondary font. This will be revisited once a proper font is added. using the secondary font. This will be revisited once a proper font is added.
- Improved spacing of titles of bottom navigation tabs so they work better on smaller screens
## [0.2.0 (541)] - 2024-01-30 ## [0.2.0 (541)] - 2024-01-30
- Update the Zcash SDK dependency to version 2.0.5, which improves the performance of block synchronization - Update the Zcash SDK dependency to version 2.0.5, which improves the performance of block synchronization

View File

@ -346,15 +346,34 @@ fun BodyWithFiatCurrencySymbol(
) )
} }
@Preview
@Composable
private fun NavigationTabTextPreview() {
ZcashTheme(forceDarkMode = false) {
GradientSurface {
Column {
NavigationTabText(
text = "Account",
selected = false,
modifier = Modifier,
onClick = {}
)
}
}
}
}
@Composable @Composable
fun NavigationTabText( fun NavigationTabText(
text: String, text: String,
selected: Boolean, selected: Boolean,
onClick: () -> Unit,
modifier: Modifier = Modifier modifier: Modifier = Modifier
) { ) {
Text( Text(
text = text, text = text,
style = ZcashTheme.extendedTypography.textNavTab, style = ZcashTheme.extendedTypography.textNavTab,
textAlign = TextAlign.Center,
fontWeight = fontWeight =
if (selected) { if (selected) {
FontWeight.Black FontWeight.Black
@ -364,6 +383,10 @@ fun NavigationTabText(
maxLines = 1, maxLines = 1,
overflow = TextOverflow.Visible, overflow = TextOverflow.Visible,
color = ZcashTheme.colors.tabTextColor, color = ZcashTheme.colors.tabTextColor,
modifier = modifier modifier =
Modifier
.clip(RoundedCornerShape(ZcashTheme.dimens.topAppBarActionRippleCorner))
.clickable { onClick() }
.then(modifier)
) )
} }

View File

@ -11,7 +11,6 @@ import androidx.compose.foundation.pager.PagerDefaults
import androidx.compose.foundation.pager.rememberPagerState import androidx.compose.foundation.pager.rememberPagerState
import androidx.compose.material3.Divider import androidx.compose.material3.Divider
import androidx.compose.material3.DividerDefaults import androidx.compose.material3.DividerDefaults
import androidx.compose.material3.Tab
import androidx.compose.material3.TabRow import androidx.compose.material3.TabRow
import androidx.compose.material3.TabRowDefaults import androidx.compose.material3.TabRowDefaults
import androidx.compose.material3.TabRowDefaults.tabIndicatorOffset import androidx.compose.material3.TabRowDefaults.tabIndicatorOffset
@ -146,23 +145,25 @@ fun Home(
modifier = modifier =
Modifier Modifier
.navigationBarsPadding() .navigationBarsPadding()
.padding(all = ZcashTheme.dimens.spacingDefault) .padding(
horizontal = ZcashTheme.dimens.spacingDefault,
vertical = ZcashTheme.dimens.spacingSmall
)
) { ) {
subScreens.forEachIndexed { index, item -> subScreens.forEachIndexed { index, item ->
val selected = index == pagerState.currentPage val selected = index == pagerState.currentPage
Tab(
NavigationTabText(
text = item.title,
selected = selected, selected = selected,
text = { onClick = { coroutineScope.launch { pagerState.animateScrollToPage(index) } },
NavigationTabText(
text = item.title,
selected = selected
)
},
modifier = modifier =
Modifier Modifier
.padding(all = 0.dp) .padding(
.testTag(item.testTag), horizontal = ZcashTheme.dimens.spacingXtiny,
onClick = { coroutineScope.launch { pagerState.animateScrollToPage(index) } }, vertical = ZcashTheme.dimens.spacingDefault
)
.testTag(item.testTag)
) )
} }
} }