/* 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 ; }