2022-12-07 16:38:50 +01:00
|
|
|
/*
|
|
|
|
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 <http://www.gnu.org/licenses/>
|
|
|
|
*/
|
|
|
|
|
2023-04-07 22:30:01 +02:00
|
|
|
import { Amounts, HttpStatusCode, parsePaytoUri } from "@gnu-taler/taler-util";
|
2023-02-08 21:41:19 +01:00
|
|
|
import {
|
2023-04-07 22:30:01 +02:00
|
|
|
ErrorType,
|
2023-02-08 21:41:19 +01:00
|
|
|
HttpResponsePaginated,
|
|
|
|
useTranslationContext,
|
|
|
|
} from "@gnu-taler/web-util/lib/index.browser";
|
|
|
|
import { Fragment, h, VNode } from "preact";
|
2023-04-07 22:30:01 +02:00
|
|
|
import { Loading } from "../components/Loading.js";
|
2022-12-14 19:35:28 +01:00
|
|
|
import { Transactions } from "../components/Transactions/index.js";
|
2023-04-07 22:30:01 +02:00
|
|
|
import { PageStateType, notifyError } from "../context/pageState.js";
|
2023-02-08 21:41:19 +01:00
|
|
|
import { useAccountDetails } from "../hooks/access.js";
|
2023-04-07 22:30:01 +02:00
|
|
|
import { LoginForm } from "./LoginForm.js";
|
2023-02-08 21:41:19 +01:00
|
|
|
import { PaymentOptions } from "./PaymentOptions.js";
|
2023-04-07 22:30:01 +02:00
|
|
|
import { StateUpdater } from "preact/hooks";
|
|
|
|
import { useBackendContext } from "../context/backend.js";
|
2022-12-07 16:38:50 +01:00
|
|
|
|
2023-02-08 21:41:19 +01:00
|
|
|
interface Props {
|
|
|
|
account: string;
|
2023-02-25 23:43:45 +01:00
|
|
|
onLoadNotOk: <T>(
|
|
|
|
error: HttpResponsePaginated<T, SandboxBackend.SandboxError>,
|
|
|
|
) => VNode;
|
2022-12-07 16:38:50 +01:00
|
|
|
}
|
|
|
|
/**
|
2023-02-08 21:41:19 +01:00
|
|
|
* Query account information and show QR code if there is pending withdrawal
|
2022-12-07 16:38:50 +01:00
|
|
|
*/
|
2023-02-08 21:41:19 +01:00
|
|
|
export function AccountPage({ account, onLoadNotOk }: Props): VNode {
|
|
|
|
const result = useAccountDetails(account);
|
2023-04-07 22:30:01 +02:00
|
|
|
const backend = useBackendContext();
|
2022-12-07 16:38:50 +01:00
|
|
|
const { i18n } = useTranslationContext();
|
|
|
|
|
2023-02-08 21:41:19 +01:00
|
|
|
if (!result.ok) {
|
2023-04-07 22:30:01 +02:00
|
|
|
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 <LoginForm />;
|
|
|
|
}
|
2023-02-08 21:41:19 +01:00
|
|
|
return onLoadNotOk(result);
|
2022-12-07 16:38:50 +01:00
|
|
|
}
|
|
|
|
|
2023-02-08 21:41:19 +01:00
|
|
|
const { data } = result;
|
2023-03-11 22:19:38 +01:00
|
|
|
const balance = Amounts.parseOrThrow(data.balance.amount);
|
|
|
|
const debitThreshold = Amounts.parseOrThrow(data.debitThreshold);
|
2023-02-08 21:41:19 +01:00
|
|
|
const payto = parsePaytoUri(data.paytoUri);
|
|
|
|
if (!payto || !payto.isKnown || payto.targetType !== "iban") {
|
2022-12-07 16:38:50 +01:00
|
|
|
return (
|
2023-02-08 21:41:19 +01:00
|
|
|
<div>Payto from server is not valid "{data.paytoUri}"</div>
|
2022-12-07 16:38:50 +01:00
|
|
|
);
|
|
|
|
}
|
2023-02-08 21:41:19 +01:00
|
|
|
const accountNumber = payto.iban;
|
|
|
|
const balanceIsDebit = data.balance.credit_debit_indicator == "debit";
|
2023-03-11 22:19:38 +01:00
|
|
|
const limit = balanceIsDebit
|
|
|
|
? Amounts.sub(debitThreshold, balance).amount
|
|
|
|
: Amounts.add(balance, debitThreshold).amount;
|
2022-12-07 16:38:50 +01:00
|
|
|
return (
|
2023-02-08 21:41:19 +01:00
|
|
|
<Fragment>
|
2022-12-07 16:38:50 +01:00
|
|
|
<div>
|
|
|
|
<h1 class="nav welcome-text">
|
|
|
|
<i18n.Translate>
|
|
|
|
Welcome,
|
2023-02-08 21:41:19 +01:00
|
|
|
{accountNumber ? `${account} (${accountNumber})` : account}!
|
2022-12-07 16:38:50 +01:00
|
|
|
</i18n.Translate>
|
|
|
|
</h1>
|
|
|
|
</div>
|
2022-12-20 14:16:39 +01:00
|
|
|
|
2023-03-11 22:19:38 +01:00
|
|
|
<section id="assets">
|
|
|
|
<div class="asset-summary">
|
|
|
|
<h2>{i18n.str`Bank account balance`}</h2>
|
|
|
|
{!balance ? (
|
|
|
|
<div class="large-amount" style={{ color: "gray" }}>
|
|
|
|
Waiting server response...
|
2022-12-07 16:38:50 +01:00
|
|
|
</div>
|
2023-03-11 22:19:38 +01:00
|
|
|
) : (
|
|
|
|
<div class="large-amount amount">
|
|
|
|
{balanceIsDebit ? <b>-</b> : null}
|
|
|
|
<span class="value">{`${Amounts.stringifyValue(balance)}`}</span>
|
|
|
|
|
|
|
|
<span class="currency">{`${balance.currency}`}</span>
|
2022-12-07 16:38:50 +01:00
|
|
|
</div>
|
2023-03-11 22:19:38 +01:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
<section id="payments">
|
|
|
|
<div class="payments">
|
|
|
|
<h2>{i18n.str`Payments`}</h2>
|
|
|
|
<PaymentOptions limit={limit} />
|
|
|
|
</div>
|
|
|
|
</section>
|
2023-02-08 21:41:19 +01:00
|
|
|
|
|
|
|
<section style={{ marginTop: "2em" }}>
|
2023-02-10 13:51:37 +01:00
|
|
|
<div class="active">
|
|
|
|
<h3>{i18n.str`Latest transactions`}</h3>
|
|
|
|
<Transactions account={account} />
|
|
|
|
</div>
|
2022-12-07 16:38:50 +01:00
|
|
|
</section>
|
2023-02-08 21:41:19 +01:00
|
|
|
</Fragment>
|
2022-12-07 16:38:50 +01:00
|
|
|
);
|
|
|
|
}
|