summaryrefslogtreecommitdiff
path: root/packages/taler-wallet-webextension/src/walletEntryPoint.tsx
diff options
context:
space:
mode:
authorSebastian <sebasjm@gmail.com>2021-06-16 17:01:06 -0300
committerSebastian <sebasjm@gmail.com>2021-06-16 17:17:18 -0300
commit86636142a2e3fb3373363c2c0c87ce5167975b74 (patch)
tree0fcbe5e3c2a68ab21a5d9b6f65e443c1f2e4443b /packages/taler-wallet-webextension/src/walletEntryPoint.tsx
parent562b2cf8d29cf3392ddd1e1bd0793d92413d9658 (diff)
downloadwallet-core-86636142a2e3fb3373363c2c0c87ce5167975b74.tar.gz
wallet-core-86636142a2e3fb3373363c2c0c87ce5167975b74.tar.bz2
wallet-core-86636142a2e3fb3373363c2c0c87ce5167975b74.zip
split wallet,popup .html
Diffstat (limited to 'packages/taler-wallet-webextension/src/walletEntryPoint.tsx')
-rw-r--r--packages/taler-wallet-webextension/src/walletEntryPoint.tsx135
1 files changed, 135 insertions, 0 deletions
diff --git a/packages/taler-wallet-webextension/src/walletEntryPoint.tsx b/packages/taler-wallet-webextension/src/walletEntryPoint.tsx
new file mode 100644
index 000000000..607c87d39
--- /dev/null
+++ b/packages/taler-wallet-webextension/src/walletEntryPoint.tsx
@@ -0,0 +1,135 @@
+/*
+ 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 <http://www.gnu.org/licenses/>
+ */
+
+/**
+ * Main entry point for extension pages.
+ *
+ * @author Florian Dold <dold@taler.net>
+ */
+
+import { render } from "preact";
+import { setupI18n } from "@gnu-taler/taler-util";
+import { strings } from "./i18n/strings";
+import { createHashHistory } from 'history';
+
+import { WithdrawalDialog } from "./pages/withdraw";
+import { Welcome } from "./pages/welcome";
+import { TalerPayDialog } from "./pages/pay";
+import { RefundStatusView } from "./pages/refund";
+import { TalerTipDialog } from './pages/tip';
+import Router, { route, Route } from "preact-router";
+
+
+function main(): void {
+ try {
+ const container = document.getElementById("container");
+ if (!container) {
+ throw Error("container not found, can't mount page contents");
+ }
+ render(<Application />, container);
+ } catch (e) {
+ console.error("got error", e);
+ 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();
+}
+
+
+enum Pages {
+ welcome = '/welcome',
+ pay = '/pay',
+ payback = '/payback',
+ refund = '/refund',
+ reset_required = '/reset-required',
+ return_coins = '/return-coins',
+ tips = '/tips',
+ withdraw = '/withdraw',
+ // popup = '/popup/:rest*',
+}
+
+function Application() {
+ const sp = new URL(document.location.href).searchParams
+ const queryParams: any = {}
+ sp.forEach((v, k) => { queryParams[k] = v; });
+
+ return <Router history={createHashHistory()} >
+
+ <Route path={Pages.welcome} component={() => {
+ return <section id="main">
+ <div style="border-bottom: 3px dashed #aa3939; margin-bottom: 2em;">
+ <h1 style="font-family: monospace; font-size: 250%;">
+ <span style="color: #aa3939;">❰</span>Taler Wallet<span style="color: #aa3939;">❱</span>
+ </h1>
+ </div>
+ <h1>Browser Extension Installed!</h1>
+ <div>
+ <Welcome />
+ </div>
+ </section>
+ }} />
+
+ <Route path={Pages.pay} component={() => {
+ return <section id="main">
+ <h1>GNU Taler Wallet</h1>
+ <article class="fade">
+ <TalerPayDialog talerPayUri={queryParams.talerPayUri} />
+ </article>
+ </section>
+ }} />
+
+ <Route path={Pages.refund} component={() => {
+ return <section id="main">
+ <h1>GNU Taler Wallet</h1>
+ <article class="fade">
+ <RefundStatusView talerRefundUri={queryParams.talerRefundUri} />
+ </article>
+ </section>
+ }} />
+
+ <Route path={Pages.tips} component={() => {
+ return <section id="main">
+ <h1>GNU Taler Wallet</h1>
+ <div>
+ <TalerTipDialog talerTipUri={queryParams.talerTipUri} />
+ </div>
+ </section>
+ }} />
+ <Route path={Pages.withdraw} component={() => {
+ return <section id="main">
+ <div style="border-bottom: 3px dashed #aa3939; margin-bottom: 2em;">
+ <h1 style="font-family: monospace; font-size: 250%;">
+ <span style="color: #aa3939;">❰</span>Taler Wallet<span style="color: #aa3939;">❱</span>
+ </h1>
+ </div>
+ <div class="fade">
+ <WithdrawalDialog talerWithdrawUri={queryParams.talerWithdrawUri} />
+ </div>
+ </section>
+ }} />
+
+ <Route path={Pages.reset_required} component={() => <div>no yet implemented</div>} />
+ <Route path={Pages.payback} component={() => <div>no yet implemented</div>} />
+ <Route path={Pages.return_coins} component={() => <div>no yet implemented</div>} />
+
+ </Router>
+}