/* 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 { Logger } from "@gnu-taler/taler-util"; import { useTranslationContext } from "@gnu-taler/web-util/lib/index.browser"; import { ComponentChildren, Fragment, h, VNode } from "preact"; import talerLogo from "../assets/logo-white.svg"; import { LangSelectorLikePy as LangSelector } from "../components/LangSelector.js"; import { useBackendContext } from "../context/backend.js"; import { ErrorMessage, PageStateType, usePageContext, } from "../context/pageState.js"; import { useBusinessAccountDetails } from "../hooks/circuit.js"; import { bankUiSettings } from "../settings.js"; const IS_PUBLIC_ACCOUNT_ENABLED = false; const logger = new Logger("BankFrame"); function MaybeBusinessButton({ account, onClick, }: { account: string; onClick: () => void; }): VNode { const { i18n } = useTranslationContext(); const result = useBusinessAccountDetails(account); if (!result.ok) return ; return ( ); } export function BankFrame({ children, goToBusinessAccount, }: { children: ComponentChildren; goToBusinessAccount?: () => void; }): VNode { const { i18n } = useTranslationContext(); const backend = useBackendContext(); const { pageState, pageStateSetter } = usePageContext(); logger.trace("state", pageState); const demo_sites = []; for (const i in bankUiSettings.demoSites) demo_sites.push( {bankUiSettings.demoSites[i][0]} , ); return (

{bankUiSettings.bankName}

{maybeDemoContent(

{IS_PUBLIC_ACCOUNT_ENABLED ? ( This part of the demo shows how a bank that supports Taler directly would work. In addition to using your own bank account, you can also see the transaction history of some{" "} Public Accounts. ) : ( This part of the demo shows how a bank that supports Taler directly would work. )}

, )}
{i18n.str`Taler
{pageState.error && ( { pageStateSetter((prev) => ({ ...prev, error: undefined })); }} /> )} {backend.state.status === "loggedIn" ? ( ) : null} {children}
); } function maybeDemoContent(content: VNode): VNode { if (bankUiSettings.showDemoNav) { return content; } return ; } export function ErrorBanner({ error, onClear, }: { error: ErrorMessage; onClear?: () => void; }): VNode | null { return (

{error.title}

{onClear && ( { e.preventDefault(); onClear(); }} /> )}

{error.description}

); } function StatusBanner(): VNode | null { const { pageState, pageStateSetter } = usePageContext(); if (!pageState.info) return null; const rval = (

{pageState.info}

{ pageStateSetter((prev) => ({ ...prev, info: undefined })); }} />
); return rval; }