/* This file is part of TALER (C) 2015-2016 GNUnet e.V. 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. 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 TALER; see the file COPYING. If not, see */ /** * Page that shows refund status for purchases. * * @author sebasjm */ import { amountFractionalBase, AmountJson, Amounts, ApplyRefundResponse, } from "@gnu-taler/taler-util"; import { h, VNode } from "preact"; import { useEffect, useState } from "preact/hooks"; import { SubTitle, Title } from "../components/styled/index.js"; import { useTranslationContext } from "../context/translation.js"; import * as wxApi from "../wxApi.js"; interface Props { talerRefundUri?: string; } export interface ViewProps { applyResult: ApplyRefundResponse; } export function View({ applyResult }: ViewProps): VNode { const { i18n } = useTranslationContext(); return (
GNU Taler Wallet
Refund Status

The product {applyResult.info.summary} has received a total effective refund of{" "} .

{applyResult.pendingAtExchange ? (

Refund processing is still in progress.

) : null} {!Amounts.isZero(applyResult.amountRefundGone) ? (

The refund amount of{" "} could not be applied.

) : null}
); } export function RefundPage({ talerRefundUri }: Props): VNode { const [applyResult, setApplyResult] = useState< ApplyRefundResponse | undefined >(undefined); const { i18n } = useTranslationContext(); const [errMsg, setErrMsg] = useState(undefined); useEffect(() => { if (!talerRefundUri) return; const doFetch = async (): Promise => { try { const result = await wxApi.applyRefund(talerRefundUri); setApplyResult(result); } catch (e) { if (e instanceof Error) { setErrMsg(e.message); console.log("err message", e.message); } } }; doFetch(); }, [talerRefundUri]); console.log("rendering"); if (!talerRefundUri) { return ( missing taler refund uri ); } if (errMsg) { return ( Error: {errMsg} ); } if (!applyResult) { return ( Updating refund status ); } return ; } export function renderAmount(amount: AmountJson | string): VNode { let a; if (typeof amount === "string") { a = Amounts.parse(amount); } else { a = amount; } if (!a) { return (invalid amount); } const x = a.value + a.fraction / amountFractionalBase; return ( {x} {a.currency} ); } function AmountView({ amount }: { amount: AmountJson | string }): VNode { return renderAmount(amount); }