hide time card if no instances
This commit is contained in:
parent
bf240c4203
commit
2ead3c054a
1 changed files with 86 additions and 70 deletions
|
@ -72,85 +72,101 @@ fun DashboardScreen(dashboardViewModel: DashboardViewModel) {
|
|||
horizontalArrangement = Arrangement.Center
|
||||
) {
|
||||
// balance card
|
||||
Card(
|
||||
modifier = Modifier
|
||||
.padding(16.dp),
|
||||
colors = CardDefaults.cardColors(
|
||||
containerColor = balanceCardColor(user.credit)
|
||||
)
|
||||
) {
|
||||
Row(
|
||||
modifier = Modifier.padding(16.dp, 8.dp),
|
||||
verticalAlignment = Alignment.CenterVertically
|
||||
) {
|
||||
Icon(
|
||||
modifier = Modifier.size(24.dp),
|
||||
painter = painterResource(id = R.drawable.baseline_monetization_on_24),
|
||||
contentDescription = stringResource(id = R.string.balance)
|
||||
)
|
||||
Spacer(
|
||||
modifier = Modifier.width(12.dp)
|
||||
)
|
||||
Text(
|
||||
text = "$%.2f".format(user.credit),
|
||||
fontSize = 22.sp,
|
||||
color = balanceColor(user.credit, user.balanceThreshold)
|
||||
)
|
||||
}
|
||||
}
|
||||
BalanceCard(balance = user.credit, balanceWarning = user.balanceThreshold)
|
||||
|
||||
// time card
|
||||
Card(
|
||||
modifier = Modifier
|
||||
.padding(16.dp)
|
||||
) {
|
||||
Row(
|
||||
modifier = Modifier.padding(16.dp, 8.dp),
|
||||
verticalAlignment = Alignment.CenterVertically
|
||||
) {
|
||||
Icon(
|
||||
modifier = Modifier.size(24.dp),
|
||||
painter = painterResource(id = R.drawable.baseline_access_time_filled_24),
|
||||
contentDescription = stringResource(id = R.string.time_left)
|
||||
)
|
||||
Spacer(
|
||||
modifier = Modifier.width(12.dp)
|
||||
)
|
||||
Text(
|
||||
text = formatTime(remainingTime),
|
||||
fontSize = 22.sp
|
||||
)
|
||||
}
|
||||
}
|
||||
if (rentedInstances.isNotEmpty())
|
||||
RemainingTimeCard(remainingTime = remainingTime)
|
||||
|
||||
// instances
|
||||
Card(
|
||||
modifier = Modifier
|
||||
.padding(16.dp)
|
||||
) {
|
||||
Row(
|
||||
modifier = Modifier.padding(16.dp, 8.dp),
|
||||
verticalAlignment = Alignment.CenterVertically
|
||||
) {
|
||||
Icon(
|
||||
modifier = Modifier.size(24.dp),
|
||||
painter = painterResource(id = R.drawable.server_solid),
|
||||
contentDescription = stringResource(id = R.string.rented_instances)
|
||||
)
|
||||
Spacer(
|
||||
modifier = Modifier.width(12.dp)
|
||||
)
|
||||
Text(
|
||||
text = rentedInstances.size.toString(),
|
||||
fontSize = 22.sp
|
||||
)
|
||||
}
|
||||
}
|
||||
InstancesCard(rentedInstancesCount = rentedInstances.size)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
fun RemainingTimeCard(remainingTime: Int) {
|
||||
Card(
|
||||
modifier = Modifier
|
||||
.padding(16.dp)
|
||||
) {
|
||||
Row(
|
||||
modifier = Modifier.padding(16.dp, 8.dp),
|
||||
verticalAlignment = Alignment.CenterVertically
|
||||
) {
|
||||
Icon(
|
||||
modifier = Modifier.size(24.dp),
|
||||
painter = painterResource(id = R.drawable.baseline_access_time_filled_24),
|
||||
contentDescription = stringResource(id = R.string.time_left)
|
||||
)
|
||||
Spacer(
|
||||
modifier = Modifier.width(12.dp)
|
||||
)
|
||||
Text(
|
||||
text = formatTime(remainingTime),
|
||||
fontSize = 22.sp
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
fun BalanceCard(balance: Double, balanceWarning: Double) {
|
||||
Card(
|
||||
modifier = Modifier
|
||||
.padding(16.dp),
|
||||
colors = CardDefaults.cardColors(
|
||||
containerColor = balanceCardColor(balance)
|
||||
)
|
||||
) {
|
||||
Row(
|
||||
modifier = Modifier.padding(16.dp, 8.dp),
|
||||
verticalAlignment = Alignment.CenterVertically
|
||||
) {
|
||||
Icon(
|
||||
modifier = Modifier.size(24.dp),
|
||||
painter = painterResource(id = R.drawable.baseline_monetization_on_24),
|
||||
contentDescription = stringResource(id = R.string.balance)
|
||||
)
|
||||
Spacer(
|
||||
modifier = Modifier.width(12.dp)
|
||||
)
|
||||
Text(
|
||||
text = "$%.2f".format(balance),
|
||||
fontSize = 22.sp,
|
||||
color = balanceColor(balance, balanceWarning)
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
fun InstancesCard(rentedInstancesCount: Int) {
|
||||
Card(
|
||||
modifier = Modifier
|
||||
.padding(16.dp)
|
||||
) {
|
||||
Row(
|
||||
modifier = Modifier.padding(16.dp, 8.dp),
|
||||
verticalAlignment = Alignment.CenterVertically
|
||||
) {
|
||||
Icon(
|
||||
modifier = Modifier.size(24.dp),
|
||||
painter = painterResource(id = R.drawable.server_solid),
|
||||
contentDescription = stringResource(id = R.string.rented_instances)
|
||||
)
|
||||
Spacer(
|
||||
modifier = Modifier.width(12.dp)
|
||||
)
|
||||
Text(
|
||||
text = rentedInstancesCount.toString(),
|
||||
fontSize = 22.sp
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
fun balanceCardColor(balance: Double): Color {
|
||||
return if (balance > 0) Color.Unspecified else MaterialTheme.colorScheme.errorContainer
|
||||
|
|
Loading…
Reference in a new issue