/*
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 {
Amounts,
NotificationType,
TransactionPayment,
TransactionType,
} from "@gnu-taler/taler-util";
import { WalletApiOperation } from "@gnu-taler/taler-wallet-core";
import { useEffect, useState } from "preact/hooks";
import { alertFromError, useAlertContext } from "../../context/alert.js";
import { useBackendContext } from "../../context/backend.js";
import { useTranslationContext } from "@gnu-taler/web-util/browser";
import { useAsyncAsHook } from "../../hooks/useAsyncAsHook.js";
import { Props, State } from "./index.js";
export function useComponentState({
talerRefundUri,
cancel,
onSuccess,
}: Props): State {
const api = useBackendContext();
const { i18n } = useTranslationContext();
const [ignored, setIgnored] = useState(false);
const { pushAlertOnError } = useAlertContext();
const info = useAsyncAsHook(async () => {
if (!talerRefundUri) throw Error("ERROR_NO-URI-FOR-REFUND");
const refund = await api.wallet.call(
WalletApiOperation.StartRefundQueryForUri,
{
talerRefundUri,
},
);
const purchase = await api.wallet.call(
WalletApiOperation.GetTransactionById,
{
transactionId: refund.transactionId,
},
);
if (purchase.type !== TransactionType.Payment) {
throw Error("Refund of non purchase transaction is not handled");
}
return { refund, purchase, uri: talerRefundUri };
});
useEffect(() =>
api.listener.onUpdateNotification(
[NotificationType.TransactionStateTransition],
info?.retry,
),
);
if (!info) {
return { status: "loading", error: undefined };
}
if (info.hasError) {
return {
status: "error",
error: alertFromError(
i18n,
i18n.str`Could not load the refund status`,
info,
),
};
}
// if (info.hasError) {
// return {
// status: "loading-uri",
// error: info,
// };
// }
const { refund, purchase, uri } = info.response;
const doAccept = async (): Promise => {
const res = await api.wallet.call(
WalletApiOperation.StartRefundQueryForUri,
{
talerRefundUri: uri,
},
);
onSuccess(res.transactionId);
};
const doIgnore = async (): Promise => {
setIgnored(true);
};
const baseInfo = {
amount: Amounts.parseOrThrow(purchase.amountEffective),
// granted: Amounts.parseOrThrow(info.response.refund.granted),
// awaitingAmount: Amounts.parseOrThrow(refund.awaiting),
merchantName: purchase.info.merchant.name,
// products: purchase.info.products,
error: undefined,
};
if (ignored) {
return {
status: "ignored",
...baseInfo,
};
}
//FIXME: DD37 wallet-core is not returning this value
// if (refund.pending) {
// return {
// status: "in-progress",
// ...baseInfo,
// };
// }
return {
status: "ready",
...baseInfo,
orderId: purchase.info.orderId,
accept: {
onClick: pushAlertOnError(doAccept),
},
ignore: {
onClick: pushAlertOnError(doIgnore),
},
cancel,
};
}