import { FlutterWaveButton, closePaymentModal } from "flutterwave-react-v3"; import React, { useState } from "react"; import { useDispatch, useSelector } from "react-redux"; import { toast } from "react-toastify"; import debounce from "../../../hooks/debounce"; import usersService from "../../../services/UsersService"; import { tableReload } from "../../../store/TableReloads"; import LoadingSpinner from "../../Spinners/LoadingSpinner"; function ThePaymentText({ value, type }) { const cardDetails = value; value.description = type === "new" ? cardDetails.cardNum[0] === "4" ? "Visa" : cardDetails.cardNum[0] == "5" ? "Master" : "ATM" : value.description; value.digits = type === "new" ? cardDetails.cardNum.slice(-4) : value.digits; return (

{value.description} Card

Bank **************{value.digits}

); } function AmountSection({ currency, amount, country }) { const formattedAmount = Number(amount).toFixed(2); return (

Amount({currency})

{formattedAmount}
); } function TransactionFeeSection({ currency, fee, country }) { const formattedFee = Number(fee).toFixed(2); return (

Transaction Fee

{formattedFee}
); } function TotalSection({ currency, amount, fee, country }) { const total = Number(amount) + Number(fee); const formattedTotal = total.toFixed(2); return (

Total

{formattedTotal}
); } function ConfirmAddFund({ confirmCredit, onClose, walletItem, setConfirmCredit, }) { const __confirmData = confirmCredit?.data; const __confirmCountry = walletItem?.country; const __confirmCardDetails = __confirmData.cardType === "prev" ? JSON.parse(__confirmData.card) : __confirmData.card; const apiURL = new usersService(); const { userDetails } = useSelector((state) => state?.userDetails); const dispatch = useDispatch(); const [requestStatus, setRequestStatus] = useState({ message: "", loading: false, status: false, }); const config = { public_key: __confirmData?.flutterwave_key, tx_ref: __confirmData?.credit_reference, currency: "NGN", amount: Number(__confirmData.amount), payment_options: "card,mobilemoney,ussd", customer: { email: userDetails.email, phone_number: userDetails.phone, name: `${userDetails.lastname} ${userDetails.firstname}`, }, customizations: { title: "WrenchBoard", description: "Add Credit Payment", logo: "https://www.wrenchboard.com/assets/images/wrench-500-500-icon.png", }, }; //debugger; const fwConfig = { ...config, text: "Proceed", callback: (response) => { debouncedSuccessPayment(); //delays the call for 5 secs setTimeout(() => { closePaymentModal(); setConfirmCredit((prev) => ({ ...prev, show: { awaitConfirm: { loader: false, state: false }, acceptConfirm: { loader: false, state: true }, }, data: response, })); }, 1500); }, }; const onSuccessPayment = () => { setRequestStatus({ message: "", loading: true, status: false }); const reqData = { tx_ref: __confirmData?.credit_reference }; console.log("**** onSuccessPayment **** THIS WAS REACHED"); apiURL .resultTopUp(reqData) .then((res) => { if (res.data.internal_return < 0) { setRequestStatus({ message: "Could not finish transaction", loading: false, status: false, }); } return dispatch(tableReload({ type: "WALLETTABLE" })); }) .catch((err) => { setRequestStatus({ message: "Opps! An Error Occured", loading: false, status: false, }); setTimeout(() => { setConfirmCredit((prev) => ({ ...prev, show: { awaitConfirm: { loader: false, state: false }, acceptConfirm: { loader: false, state: true }, }, data: err, })); }, 1500); toast.success("Opps! something went wrong"); }); }; const debouncedSuccessPayment = debounce(onSuccessPayment, 5000); const handlePrevCard = async () => { const { amount, credit_reference, currency } = __confirmData; const { card_uid } = __confirmCardDetails; const reqData = { amount: amount * 100, card_uid, credit_reference, currency, }; try { setConfirmCredit((prev) => ({ ...prev, show: { acceptConfirm: { loader: true }, }, })); const res = await apiURL.getPaidPrevCard(reqData); const _response = res.data; if (res.data.internal_return < 0) { setConfirmCredit((prev) => ({ ...prev, show: { acceptConfirm: { loader: false }, }, })); return; } setTimeout(() => { setConfirmCredit((prev) => ({ ...prev, show: { awaitConfirm: { loader: false, state: false }, acceptConfirm: { loader: false, state: true }, }, data: _response, })); dispatch(tableReload({ type: "WALLETTABLE" })); }, 1500); } catch (error) { setConfirmCredit((prev) => ({ ...prev, show: { acceptConfirm: { loader: false }, }, })); console.log(error); } }; const handleNewCard = async () => { const { amount, credit_reference, uid } = __confirmData; const { address, cardNum, cvv, expirationMonth, expirationYear } = __confirmCardDetails; const reqData = { amount: amount * 100, cardnumber: cardNum.replace(/\s/g, ""), credit_reference, cvc: cvv, description: address, exp_month: expirationMonth, exp_year: expirationYear, paymenttype: 100, uid, }; try { setConfirmCredit((prev) => ({ ...prev, show: { acceptConfirm: { loader: true }, }, })); const res = await apiURL.getPaidNewCard(reqData); const _response = res.data; if (res.data.internal_return < 0) { setConfirmCredit((prev) => ({ ...prev, show: { awaitConfirm: { loader: false, state: false }, acceptConfirm: { loader: false, state: true }, }, data: _response, })); return; } setTimeout(() => { setConfirmCredit((prev) => ({ ...prev, show: { awaitConfirm: { loader: false, state: false }, acceptConfirm: { loader: false, state: true }, }, data: _response, })); dispatch(tableReload({ type: "WALLETTABLE" })); }, 1500); } catch (error) { setConfirmCredit((prev) => ({ ...prev, show: { acceptConfirm: { loader: false }, }, })); setTimeout(() => onClose, 10000); console.log(error); } }; const getBack = () => { setConfirmCredit((prev) => ({ ...prev, show: { awaitConfirm: { loader: false, state: false }, acceptConfirm: { loader: false, state: false }, }, data: {}, })); }; return (
{confirmCredit?.show?.awaitConfirm?.state && (
{__confirmCountry === "US" && (
)}

Reference No

{__confirmData?.credit_reference}
)}

{__confirmCountry === "US" && ( )} {__confirmCountry === "NG" && ( )}
); } export default ConfirmAddFund;