/*
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 {
AbsoluteTime,
Amounts,
MerchantContractTerms as ContractTerms,
Duration,
PreparePayResultType,
TranslatedString,
} from "@gnu-taler/taler-util";
import { useTranslationContext } from "@gnu-taler/web-util/browser";
import { Fragment, VNode, h } from "preact";
import { Part } from "../../components/Part.js";
import { PaymentButtons } from "../../components/PaymentButtons.js";
import { ShowFullContractTermPopup } from "../../components/ShowFullContractTermPopup.js";
import { Time } from "../../components/Time.js";
import {
AgeSign,
SuccessBox,
WarningBox,
} from "../../components/styled/index.js";
import { MerchantDetails } from "../../wallet/Transaction.js";
import { State } from "./index.js";
import { EnabledBySettings } from "../../components/EnabledBySettings.js";
type SupportedStates =
| State.Ready
| State.Confirmed
| State.NoBalanceForCurrency
| State.NoEnoughBalance;
export function BaseView(state: SupportedStates): VNode {
const { i18n } = useTranslationContext();
const contractTerms: ContractTerms = state.payStatus.contractTerms;
const effective =
"amountEffective" in state.payStatus
? state.payStatus.amountEffective
? Amounts.parseOrThrow(state.payStatus.amountEffective)
: Amounts.zeroOfCurrency(state.amount.currency)
: state.amount;
const expiration = !contractTerms.pay_deadline
? undefined
: AbsoluteTime.fromProtocolTimestamp(contractTerms.pay_deadline);
const inFiveMinutes = AbsoluteTime.addDuration(
AbsoluteTime.now(),
Duration.fromSpec({ minutes: 5 }),
);
const willExpireSoon =
!expiration || expiration.t_ms === "never"
? undefined
: AbsoluteTime.cmp(expiration, inFiveMinutes) === -1;
return (
Purchase
{contractTerms.minimum_age}+
) : (
Purchase
)
}
text={contractTerms.summary as TranslatedString}
kind="neutral"
/>
}
kind="neutral"
/>
{willExpireSoon && (
}
kind="neutral"
/>
)}
);
}
function ShowImportantMessage({ state }: { state: SupportedStates }): VNode {
const { i18n } = useTranslationContext();
const { payStatus } = state;
if (payStatus.status === PreparePayResultType.AlreadyConfirmed) {
if (payStatus.paid) {
if (payStatus.contractTerms.fulfillment_url) {
return (
Already paid, you are going to be redirected to{" "}
{payStatus.contractTerms.fulfillment_url}
);
}
return (
Already paid
);
}
return (
Already claimed
);
}
return ;
}