useSendWithdrawals
Description
Withdraws funds from Smart Account to a recipient (defaults to EOA)
Usage
import {
useSendWithdrawals,
useUserOpWait,
useSmartAccount,
Options
} from "@biconomy/use-aa";
import { polygonAmoy } from "viem/chains";
import { NATIVE_TOKEN_ALIAS } from "@biconomy/account";
import React, { useEffect } from "react"
export const Withdraw = () => {
const { smartAccountAddress } = useSmartAccount();
const {
mutate,
data: userOpResponse,
error,
isPending,
} = useSendWithdrawals();
const {
isLoading: waitIsLoading,
isSuccess: waitIsSuccess,
error: waitError,
data: waitData,
} = useUserOpWait(userOpResponse);
useEffect(() => {
if (waitData?.success === "true") {
console.log(waitData?.receipt?.transactionHash);
}
}, [waitData]);
const withdrawalHandler = () =>
mutate({
withdrawalRequests: [
{ address: "0x747A4168DB14F57871fa8cda8B5455D8C2a8e90a" }, // omit the amount to withdraw the full balance
{ address: NATIVE_TOKEN_ALIAS, amount: BigInt(1) },
],
options: Options.Sponsored,
});
return (
<button
title={isPending || waitIsLoading ? "Loading..." : "Withdraw"}
onClick={withdrawalHandler}
/>
);
};
Parameters
type WithdrawalRequest = {
/** The address of the asset */
address: Hex;
/** The amount to withdraw. Expects unformatted amount. Will use max amount if unset */
amount?: bigint;
/** The destination address of the funds. The second argument from the `withdraw(...)` function will be used as the default if left unset. */
recipient?: Hex;
};
type UseSendWithdrawalsProps = {
/** The BuildUserOpOptions options. See https://bcnmy.github.io/biconomy-client-sdk/types/BuildUserOpOptions.html for further detail */
options?: BuildUserOpOptions;
/** Withdrawal requests */
withdrawalRequests?: WithdrawalRequest[] | null;
};
Returns
type UserOpResponse = {
userOpHash: string;
wait(_confirmations?: number): Promise<UserOpReceipt>;
waitForTxHash(): Promise<UserOpStatus>;
};