Skip to content
This repository has been archived by the owner on Nov 5, 2024. It is now read-only.

Fix issue 3473 #3489

Merged
merged 3 commits into from
Sep 9, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,11 @@ import androidx.compose.foundation.layout.systemBarsPadding
import androidx.compose.foundation.lazy.LazyColumn
import androidx.compose.foundation.lazy.LazyListScope
import androidx.compose.foundation.lazy.items
import androidx.compose.material3.Button
import androidx.compose.material3.ButtonDefaults
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.Add
import androidx.compose.material3.FloatingActionButton
import androidx.compose.material3.Icon
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
Expand Down Expand Up @@ -103,27 +106,25 @@ private fun BoxWithConstraintsScope.UI(
var addRateModalVisible by remember {
mutableStateOf(false)
}
Button(

FloatingActionButton(
modifier = Modifier
.systemBarsPadding()
.align(Alignment.BottomCenter)
.padding(bottom = 24.dp),
colors = ButtonDefaults.buttonColors(
containerColor = UI.colors.primary,
contentColor = White,
),
.align(Alignment.BottomEnd)
.padding(all = 24.dp),
containerColor = UI.colors.primary,
contentColor = White,
shape = RoundedCornerShape(100.dp),
onClick = {
addRateModalVisible = true
}
) {
Text(
modifier = Modifier.padding(vertical = 16.dp),
text = "Add rate",
style = UI.typo.b1.style(
color = White
)
Icon(
imageVector = Icons.Filled.Add,
contentDescription = "Add rate Icon",
)
}

AddRateModal(
visible = addRateModalVisible,
baseCurrency = state.baseCurrency,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,13 @@ package com.ivy.exchangerates.component

import androidx.compose.foundation.border
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.padding
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.ArrowForward
import androidx.compose.material3.Icon
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
Expand All @@ -26,32 +30,72 @@ fun RateItem(
rate: RateUi,
onDelete: (() -> Unit)?,
onClick: () -> Unit,
modifier: Modifier = Modifier
) {
Row(
modifier = Modifier
.fillMaxWidth()
.border(1.dp, UI.colors.primary)
modifier = modifier
.padding(
horizontal = 16.dp
)
.clickable(onClick = onClick)
.padding(horizontal = 16.dp, vertical = 12.dp),
verticalAlignment = Alignment.CenterVertically
.border(2.dp, UI.colors.medium, UI.shapes.r4)

) {
Row(
modifier = Modifier
.fillMaxWidth()
.padding(horizontal = 16.dp, vertical = 12.dp),
verticalAlignment = Alignment.CenterVertically

) {
val currencyValue: Double = 1.0
RateColumn(
label = "Sell",
rate = rate.from,
value = currencyValue.format(currencyCode = rate.from)
)

SpacerHor(width = 16.dp)
Icon(
imageVector = Icons.Filled.ArrowForward,
contentDescription = "arrow to next"
)
SpacerHor(width = 16.dp)
RateColumn(
label = "Buy",
rate = rate.to,
value = rate.rate.format(currencyCode = rate.to)
)

if (onDelete != null) {
SpacerWeight(weight = 1f)
DeleteButton(onClick = onDelete)
}
}
}
}

@Composable
private fun RateColumn(label: String, rate: String, value: String) {
Column {
Text(
text = "${rate.from}-${rate.to}:",
style = UI.typo.nB1.style(
text = label,
style = UI.typo.c.style(
fontWeight = FontWeight.Normal
)
)
SpacerHor(width = 8.dp)
Text(
text = rate.rate.format(currencyCode = rate.to),
text = rate,
style = UI.typo.nB1.style(
fontWeight = FontWeight.SemiBold
fontWeight = FontWeight.ExtraBold
)
)
Text(
text = value,
style = UI.typo.nB2.style(
fontWeight = FontWeight.Normal
)
)
if (onDelete != null) {
SpacerWeight(weight = 1f)
DeleteButton(onClick = onDelete)
}
}
}

Expand All @@ -62,10 +106,10 @@ private fun Preview() {
IvyWalletComponentPreview {
RateItem(
rate = RateUi(
from = "BGN",
to = "EUR",
rate = 1.95583
),
from = "BGN",
to = "EUR",
rate = 1.95583
),
onDelete = null,
onClick = {}
)
Expand All @@ -81,7 +125,7 @@ private fun Preview_Delete() {
from = "BGN",
to = "EUR",
rate = 1.95583
),
),
onDelete = { },
onClick = {}
)
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.