/* 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, parsePaytoUri } from "@gnu-taler/taler-util"; import { ErrorType, HttpResponsePaginated, useTranslationContext, } from "@gnu-taler/web-util/lib/index.browser"; import { Fragment, VNode, h } from "preact"; import { Transactions } from "../components/Transactions/index.js"; import { useBackendContext } from "../context/backend.js"; import { useAccountDetails } from "../hooks/access.js"; import { LoginForm } from "./LoginForm.js"; import { PaymentOptions } from "./PaymentOptions.js"; import { notifyError } from "../hooks/notification.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 backend = useBackendContext(); const { i18n } = useTranslationContext(); if (!result.ok) { if (result.loading || result.type === ErrorType.TIMEOUT) { return onLoadNotOk(result); } //logout if there is any error, not if loading backend.logOut(); if (result.status === HttpStatusCode.NotFound) { notifyError({ title: i18n.str`Username or account label "${account}" not found`, }); return ; } return onLoadNotOk(result); } const { data } = result; const balance = Amounts.parseOrThrow(data.balance.amount); const debitThreshold = Amounts.parseOrThrow(data.debitThreshold); 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"; const limit = balanceIsDebit ? Amounts.sub(debitThreshold, balance).amount : Amounts.add(balance, debitThreshold).amount; return (

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

{i18n.str`Bank account balance`}

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

{i18n.str`Payments`}

{i18n.str`Latest transactions`}

); }