* Feat/537: Removed old contract and branching logic for collateral bridge * Feat/537: Renamed all 'new' name instances in functions, files and types. Regenerated types. * Feat/537: Added 'creation' field to withdraw-dialog.spec.tsx test
116 lines
2.8 KiB
TypeScript
116 lines
2.8 KiB
TypeScript
import { useQuery } from '@apollo/client';
|
|
import { determineId } from '@vegaprotocol/react-helpers';
|
|
import { useBridgeContract, useEthereumTransaction } from '@vegaprotocol/web3';
|
|
import { useVegaTransaction, useVegaWallet } from '@vegaprotocol/wallet';
|
|
import { useCallback, useEffect, useState } from 'react';
|
|
import { ERC20_APPROVAL_QUERY } from './queries';
|
|
import type {
|
|
Erc20Approval,
|
|
Erc20Approval_erc20WithdrawalApproval,
|
|
Erc20ApprovalVariables,
|
|
} from './__generated__/Erc20Approval';
|
|
import type { CollateralBridge } from '@vegaprotocol/smart-contracts';
|
|
|
|
export interface WithdrawalFields {
|
|
amount: string;
|
|
asset: string;
|
|
receiverAddress: string;
|
|
}
|
|
|
|
export const useWithdraw = (cancelled: boolean) => {
|
|
const [withdrawalId, setWithdrawalId] = useState<string | null>(null);
|
|
const [approval, setApproval] =
|
|
useState<Erc20Approval_erc20WithdrawalApproval | null>(null);
|
|
|
|
const contract = useBridgeContract();
|
|
const { keypair } = useVegaWallet();
|
|
const {
|
|
transaction: vegaTx,
|
|
send,
|
|
reset: resetVegaTx,
|
|
} = useVegaTransaction();
|
|
|
|
const {
|
|
transaction: ethTx,
|
|
perform,
|
|
reset: resetEthTx,
|
|
} = useEthereumTransaction<CollateralBridge, 'withdraw_asset'>(
|
|
contract,
|
|
'withdraw_asset'
|
|
);
|
|
|
|
const { data, stopPolling } = useQuery<Erc20Approval, Erc20ApprovalVariables>(
|
|
ERC20_APPROVAL_QUERY,
|
|
{
|
|
variables: { withdrawalId: withdrawalId || '' },
|
|
skip: !withdrawalId,
|
|
pollInterval: 1000,
|
|
}
|
|
);
|
|
|
|
const submit = useCallback(
|
|
async (withdrawal: WithdrawalFields) => {
|
|
if (!keypair) {
|
|
return;
|
|
}
|
|
|
|
const res = await send({
|
|
pubKey: keypair.pub,
|
|
propagate: true,
|
|
withdrawSubmission: {
|
|
amount: withdrawal.amount,
|
|
asset: withdrawal.asset,
|
|
ext: {
|
|
erc20: {
|
|
receiverAddress: withdrawal.receiverAddress,
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
if (res?.signature) {
|
|
setWithdrawalId(determineId(res.signature));
|
|
}
|
|
},
|
|
[keypair, send]
|
|
);
|
|
|
|
useEffect(() => {
|
|
if (
|
|
data?.erc20WithdrawalApproval &&
|
|
data.erc20WithdrawalApproval.signatures.length > 2
|
|
) {
|
|
stopPolling();
|
|
setApproval(data.erc20WithdrawalApproval);
|
|
}
|
|
}, [data, stopPolling]);
|
|
|
|
useEffect(() => {
|
|
if (approval && contract && !cancelled) {
|
|
perform(
|
|
approval.assetSource,
|
|
approval.amount,
|
|
approval.targetAddress,
|
|
approval.creation,
|
|
approval.nonce,
|
|
approval.signatures
|
|
);
|
|
}
|
|
// eslint-disable-next-line
|
|
}, [approval, contract]);
|
|
|
|
const reset = useCallback(() => {
|
|
resetVegaTx();
|
|
resetEthTx();
|
|
}, [resetVegaTx, resetEthTx]);
|
|
|
|
return {
|
|
submit,
|
|
reset,
|
|
approval,
|
|
withdrawalId,
|
|
vegaTx,
|
|
ethTx,
|
|
};
|
|
};
|