/* 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, TranslatedString } from "@gnu-taler/taler-util"; import { useTranslationContext } from "@gnu-taler/web-util/lib/index.browser"; import { ComponentChildren, Fragment, h, VNode } from "preact"; import { StateUpdater, useEffect, useState } from "preact/hooks"; import talerLogo from "../assets/logo-white.svg"; import { LangSelectorLikePy as LangSelector } from "../components/LangSelector.js"; import { useBackendContext } from "../context/backend.js"; import { ErrorMessage, PageStateProvider, PageStateType, errorListeners, infoListeners, 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(props: { children: ComponentChildren; goToBusinessAccount?: () => void; }): VNode { return ( {props.children} ); } function BankFrame2({ children, goToBusinessAccount, }: { children: ComponentChildren; goToBusinessAccount?: () => void; }): VNode { const { i18n } = useTranslationContext(); const backend = useBackendContext(); const { pageStateSetter } = usePageContext(); 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
{backend.state.status === "loggedIn" ? (
{goToBusinessAccount && !backend.state.isUserAdministrator ? ( ) : undefined}
) : null} {children}
); } function maybeDemoContent(content: VNode): VNode { if (bankUiSettings.showDemoNav) { return content; } return ; } export function ErrorBannerFloat({ error, onClear, }: { error: ErrorMessage; onClear?: () => void; }): VNode { return (
); } function ErrorBanner({ error, onClear, }: { error: ErrorMessage; onClear?: () => void; }): VNode { return (

{error.title}

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

{error.description}

); } function StatusBanner(): VNode | null { const [info, setInfo] = useState(); const [error, setError] = useState(); console.log("render", info, error); function listenError(e: ErrorMessage) { setError(e); } function listenInfo(m: TranslatedString) { console.log("update info", m, info); setInfo(m); } useEffect(() => { console.log("sadasdsad", infoListeners.length); errorListeners.push(listenError); infoListeners.push(listenInfo); console.log("sadasdsad", infoListeners.length); return function unsuscribe() { const idx = infoListeners.findIndex((d) => d === listenInfo); if (idx !== -1) { infoListeners.splice(idx, 1); } const idx2 = errorListeners.findIndex((d) => d === listenError); if (idx2 !== -1) { errorListeners.splice(idx2, 1); } console.log("unload", idx); }; }, []); return (
{!info ? undefined : (

{info}

{ setInfo(undefined); }} />
)} {!error ? undefined : ( { setError(undefined); }} /> )}
); }