aboutsummaryrefslogtreecommitdiff
path: root/packages/demobank-ui
diff options
context:
space:
mode:
authorFlorian Dold <florian@dold.me>2023-02-26 19:16:42 +0100
committerFlorian Dold <florian@dold.me>2023-02-26 19:16:42 +0100
commit93dc842e9729c5bbd0eca8ed17359da9326f6dde (patch)
treebcffdae0263f3e713ebc560d2216ec48c99ae5f1 /packages/demobank-ui
parent3e8562456d6280184f4faf3c12c03c65f8a0a476 (diff)
demobank-ui: remove wrong and dangerous usage of float
Diffstat (limited to 'packages/demobank-ui')
-rw-r--r--packages/demobank-ui/src/pages/WalletWithdrawForm.tsx37
1 files changed, 20 insertions, 17 deletions
diff --git a/packages/demobank-ui/src/pages/WalletWithdrawForm.tsx b/packages/demobank-ui/src/pages/WalletWithdrawForm.tsx
index 2b2df3baa..02b389c6c 100644
--- a/packages/demobank-ui/src/pages/WalletWithdrawForm.tsx
+++ b/packages/demobank-ui/src/pages/WalletWithdrawForm.tsx
@@ -46,21 +46,27 @@ export function WalletWithdrawForm({
const { i18n } = useTranslationContext();
const { createWithdrawal } = useAccessAPI();
- const [amount, setAmount] = useState<string | undefined>("5.00");
+ const [amountStr, setAmountStr] = useState<string | undefined>("5.00");
const ref = useRef<HTMLInputElement>(null);
useEffect(() => {
if (focus) ref.current?.focus();
}, [focus]);
- const amountFloat = amount ? parseFloat(amount) : undefined;
+ // Beware: We never ever want to treat the amount as a float!
+
+ const trimmedAmountStr = amountStr?.trim();
+
+ const parsedAmount = trimmedAmountStr
+ ? Amounts.parse(`${currency}:${trimmedAmountStr}`)
+ : undefined;
+
const errors = undefinedIfEmpty({
- amount: !amountFloat
- ? i18n.str`required`
- : Number.isNaN(amountFloat)
- ? i18n.str`should be a number`
- : amountFloat < 0
- ? i18n.str`should be positive`
- : undefined,
+ amount:
+ trimmedAmountStr == null
+ ? i18n.str`required`
+ : parsedAmount == null
+ ? i18n.str`invalid`
+ : undefined,
});
return (
<form
@@ -92,14 +98,14 @@ export function WalletWithdrawForm({
ref={ref}
id="withdraw-amount"
name="withdraw-amount"
- value={amount ?? ""}
+ value={amountStr ?? ""}
onChange={(e): void => {
- setAmount(e.currentTarget.value);
+ setAmountStr(e.currentTarget.value);
}}
/>
<ShowInputErrorLabel
message={errors?.amount}
- isDirty={amount !== undefined}
+ isDirty={amountStr !== undefined}
/>
</div>
</p>
@@ -113,14 +119,11 @@ export function WalletWithdrawForm({
value={i18n.str`Withdraw`}
onClick={async (e) => {
e.preventDefault();
- if (!amountFloat) return;
+ if (!parsedAmount) return;
try {
const result = await createWithdrawal({
- amount: Amounts.stringify(
- Amounts.fromFloat(amountFloat, currency),
- ),
+ amount: Amounts.stringify(parsedAmount),
});
-
onSuccess(result.data);
} catch (error) {
if (error instanceof RequestError) {