/* 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 { ComponentChildren, Fragment, h, VNode } from "preact"; import talerLogo from "../../assets/logo-white.svg"; import { LangSelectorLikePy as LangSelector } from "../../components/menu/LangSelector.js"; import { useBackendContext } from "../../context/backend.js"; import { PageStateType, usePageContext } from "../../context/pageState.js"; import { useTranslationContext } from "../../context/translation.js"; import { bankUiSettings } from "../../settings.js"; const logger = new Logger("BankFrame"); export function BankFrame({ children, }: { children: ComponentChildren; }): VNode { const { i18n } = useTranslationContext(); const backend = useBackendContext(); const { pageState, pageStateSetter } = usePageContext(); logger.trace("state", pageState); const logOut = (
{ pageStateSetter((prevState: PageStateType) => { const { talerWithdrawUri, withdrawalId, ...rest } = prevState; backend.clear(); return { ...rest, withdrawalInProgress: false, error: undefined, info: undefined, isRawPayto: false, }; }); }} >{i18n.str`Logout`}
); const demo_sites = []; for (const i in bankUiSettings.demoSites) demo_sites.push( {bankUiSettings.demoSites[i][0]} , ); return (

{bankUiSettings.bankName}

{maybeDemoContent(

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.

, )}
{i18n.str`Taler
{backend.state.status === "loggedIn" ? logOut : null} {children}
); } function maybeDemoContent(content: VNode): VNode { if (bankUiSettings.showDemoNav) { return content; } return ; } function ErrorBanner(): VNode | null { const { pageState, pageStateSetter } = usePageContext(); if (!pageState.error) return null; const rval = (

{pageState.error.title}

{ pageStateSetter((prev) => ({ ...prev, error: undefined })); }} />

{pageState.error.description}

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

{pageState.info}

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