From 5969a44391f32d931d0b26416fb3e1528f4a32a2 Mon Sep 17 00:00:00 2001 From: Sebastian Date: Tue, 6 Dec 2022 11:25:05 -0300 Subject: using web-utils in demobank --- .../demobank-ui/src/pages/home/QrCodeSection.tsx | 55 ++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 packages/demobank-ui/src/pages/home/QrCodeSection.tsx (limited to 'packages/demobank-ui/src/pages/home/QrCodeSection.tsx') diff --git a/packages/demobank-ui/src/pages/home/QrCodeSection.tsx b/packages/demobank-ui/src/pages/home/QrCodeSection.tsx new file mode 100644 index 000000000..1d7b3db10 --- /dev/null +++ b/packages/demobank-ui/src/pages/home/QrCodeSection.tsx @@ -0,0 +1,55 @@ +/* + 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 { h, VNode } from "preact"; +import { useEffect } from "preact/hooks"; +import { QR } from "../../components/QR.js"; +import { useTranslationContext } from "../../context/translation.js"; + +export function QrCodeSection({ + talerWithdrawUri, + abortButton, +}: { + talerWithdrawUri: string; + abortButton: h.JSX.Element; +}): VNode { + const { i18n } = useTranslationContext(); + useEffect(() => { + //Taler Wallet WebExtension is listening to headers response and tab updates. + //In the SPA there is no header response with the Taler URI so + //this hack manually triggers the tab update after the QR is in the DOM. + window.location.hash = `/account/${new Date().getTime()}`; + }, []); + + return ( +
+

{i18n.str`Transfer to Taler Wallet`}

+
+
+

{i18n.str`Use this QR code to withdraw to your mobile wallet:`}

+ {QR({ text: talerWithdrawUri })} +

+ Click{" "} + {i18n.str`this link`} to + open your Taler wallet! +

+
+ {abortButton} +
+
+
+ ); +} -- cgit v1.2.3