/* This file is part of GNU Taler (C) 2020 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 */ /** * Main entry point for extension pages. * * @author Florian Dold */ import { setupI18n } from "@gnu-taler/taler-util"; import { createHashHistory } from "history"; import { h, render, VNode } from "preact"; import Router, { route, Route } from "preact-router"; import Match from "preact-router/match"; import { useEffect, useState } from "preact/hooks"; import { LogoHeader } from "./components/LogoHeader"; import { SuccessBox, WalletBox } from "./components/styled"; import { DevContextProvider } from "./context/devContext"; import { IoCProviderForRuntime } from "./context/iocContext"; import { PayPage } from "./cta/Pay"; import { RefundPage } from "./cta/Refund"; import { TipPage } from "./cta/Tip"; import { WithdrawPage } from "./cta/Withdraw"; import { strings } from "./i18n/strings"; import { NavBar, Pages } from "./NavigationBar"; import { DeveloperPage } from "./popup/DeveloperPage"; import { BackupPage } from "./wallet/BackupPage"; import { BalancePage } from "./wallet/BalancePage"; import { DepositPage } from "./wallet/DepositPage"; import { ExchangeAddPage } from "./wallet/ExchangeAddPage"; import { HistoryPage } from "./wallet/History"; import { LastActivityPage } from "./wallet/LastActivityPage"; import { ManualWithdrawPage } from "./wallet/ManualWithdrawPage"; import { ProviderAddPage } from "./wallet/ProviderAddPage"; import { ProviderDetailPage } from "./wallet/ProviderDetailPage"; import { SettingsPage } from "./wallet/Settings"; import { TransactionPage } from "./wallet/Transaction"; import { WelcomePage } from "./wallet/Welcome"; function main(): void { try { const container = document.getElementById("container"); if (!container) { throw Error("container not found, can't mount page contents"); } render(, container); } catch (e) { console.error("got error", e); if (e instanceof Error) { document.body.innerText = `Fatal error: "${e.message}". Please report this bug at https://bugs.gnunet.org/.`; } } } setupI18n("en-US", strings); if (document.readyState === "loading") { document.addEventListener("DOMContentLoaded", main); } else { main(); } function Application(): VNode { const [globalNotification, setGlobalNotification] = useState< string | undefined >(undefined); const hash_history = createHashHistory(); return (
{({ devMode }: { devMode: boolean }) => ( {/* won't work in the first render if is not called first */} {/* https://github.com/preactjs/preact-router/issues/415 */} {({ path }: { path: string }) => ( )} {globalNotification && ( setGlobalNotification(undefined)}>
{globalNotification}
)} route(Pages.manual_withdraw.replace(":currency?", "")) } goToWalletDeposit={(currency: string) => route(Pages.deposit.replace(":currency", currency)) } goToWalletHistory={(currency: string) => route(Pages.balance_history.replace(":currency", currency)) } /> route(Pages.deposit.replace(":currency", currency)) } goToWalletManualWithdraw={(currency?: string) => route( Pages.manual_withdraw.replace( ":currency?", currency || "", ), ) } /> { route(Pages.provider_add); }} /> { route(Pages.backup); }} /> { route(Pages.backup); }} /> { route(Pages.balance); }} /> { route(Pages.balance_history.replace(":currency", currency)); setGlobalNotification( "All done, your transaction is in progress", ); }} />
no yet implemented
} />
no yet implemented
} />
no yet implemented
} /> {/** call to action */} route( Pages.manual_withdraw.replace( ":currency?", currency || "", ), ) } goBack={() => route(Pages.balance)} /> route(Pages.balance)} />
)}
); } function Redirect({ to }: { to: string }): null { useEffect(() => { console.log("go some wrong route"); route(to, true); }); return null; }