/* 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, parsePaytoUri } from "@gnu-taler/taler-util"; import { HttpResponsePaginated, useTranslationContext, } from "@gnu-taler/web-util/lib/index.browser"; import { Fragment, h, VNode } from "preact"; import { useState } from "preact/hooks"; import { Cashouts } from "../components/Cashouts/index.js"; import { Transactions } from "../components/Transactions/index.js"; import { useAccountDetails } from "../hooks/access.js"; import { PaymentOptions } from "./PaymentOptions.js"; interface Props { account: string; onLoadNotOk: (error: HttpResponsePaginated) => VNode; } /** * Query account information and show QR code if there is pending withdrawal */ export function AccountPage({ account, onLoadNotOk }: Props): VNode { const result = useAccountDetails(account); const { i18n } = useTranslationContext(); if (!result.ok) { return onLoadNotOk(result); } const { data } = result; const balance = Amounts.parse(data.balance.amount); const errorParsingBalance = !balance; const payto = parsePaytoUri(data.paytoUri); if (!payto || !payto.isKnown || payto.targetType !== "iban") { return (
Payto from server is not valid "{data.paytoUri}"
); } const accountNumber = payto.iban; const balanceIsDebit = data.balance.credit_debit_indicator == "debit"; return (

Welcome, {accountNumber ? `${account} (${accountNumber})` : account}!

{errorParsingBalance ? (

Server Error: invalid balance

Your account is in an invalid state.

) : (

{i18n.str`Bank account balance`}

{!balance ? (
Waiting server response...
) : (
{balanceIsDebit ? - : null} {`${Amounts.stringifyValue( balance, )}`}   {`${balance.currency}`}
)}

{i18n.str`Payments`}

)}
); } function Moves({ account }: { account: string }): VNode { const [tab, setTab] = useState<"transactions" | "cashouts">("transactions"); const { i18n } = useTranslationContext(); return (
{tab === "transactions" && (

{i18n.str`Latest transactions`}

)} {tab === "cashouts" && (

{i18n.str`Latest cashouts`}

)}
); }