/* This file is part of GNU Taler (C) 2022 Taler Systems S.A. GNU Taler is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GNU Taler; see the file COPYING. If not, see */ import { Amounts, HttpStatusCode, Logger } from "@gnu-taler/taler-util"; import { RequestError, useTranslationContext, } from "@gnu-taler/web-util/lib/index.browser"; import { h, VNode } from "preact"; import { useEffect, useRef, useState } from "preact/hooks"; import { PageStateType } from "../context/pageState.js"; import { useAccessAPI } from "../hooks/access.js"; import { buildRequestErrorMessage, undefinedIfEmpty } from "../utils.js"; import { ShowInputErrorLabel } from "./ShowInputErrorLabel.js"; const logger = new Logger("WalletWithdrawForm"); export function WalletWithdrawForm({ focus, currency, onError, onSuccess, }: { currency: string; focus?: boolean; onError: (e: PageStateType["error"]) => void; onSuccess: ( data: SandboxBackend.Access.BankAccountCreateWithdrawalResponse, ) => void; }): VNode { // const backend = useBackendContext(); // const { pageState, pageStateSetter } = usePageContext(); const { i18n } = useTranslationContext(); const { createWithdrawal } = useAccessAPI(); const [amountStr, setAmountStr] = useState("5.00"); const ref = useRef(null); useEffect(() => { if (focus) ref.current?.focus(); }, [focus]); // 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: trimmedAmountStr == null ? i18n.str`required` : parsedAmount == null ? i18n.str`invalid` : undefined, }); return (
{ e.preventDefault(); }} autoCapitalize="none" autoCorrect="off" >

 

  { setAmountStr(e.currentTarget.value); }} />

{ e.preventDefault(); if (!parsedAmount) return; try { const result = await createWithdrawal({ amount: Amounts.stringify(parsedAmount), }); onSuccess(result.data); } catch (error) { if (error instanceof RequestError) { onError( buildRequestErrorMessage(i18n, error.cause, { onClientError: (status) => status === HttpStatusCode.Forbidden ? i18n.str`The operation was rejected due to insufficient funds` : undefined, }), ); } else { onError({ title: i18n.str`Operation failed, please report`, description: error instanceof Error ? error.message : JSON.stringify(error), }); } } }} />

); }