* feat: unhardcode contract addresses * fix: linting and tests * feat: switch contract usage in token app to use unhardcoded addresses * chore: remove other usage of hard coded contract addresses * feat: convert contracts to classes, update claim contract to fix circular dependency * feat: add hard coded contract addresses to contracts page * fix: misc tidy up * chore: rename ethers big num conversion func * fix: remove pending transactions modal * chore: add single toBigNum function that can accept number string or EthersBignNumber * chore: delete unused tranche helpers and decimals functions from smart contracts lib * feat: add faucetable token class * fix: reset tx state after early exit from approve tx * feat: re add transaction modal using zustand store * fix: loader colors for eth wallet * fix: pass ethereum config to gurantee existence before tx execution * chore: lint smart contracts lib * chore: fix web3container to use children and not render prop * chore: lint * fix: use background to mock ethereum wallet to avoid mocking globally for every test * chore: move web3 mock to common steps and call from withdrawals feature tests
114 lines
2.7 KiB
TypeScript
114 lines
2.7 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 { WithdrawTransactionArgs } from './use-complete-withdraw';
|
|
import type {
|
|
Erc20Approval,
|
|
Erc20ApprovalVariables,
|
|
Erc20Approval_erc20WithdrawalApproval,
|
|
} from './__generated__/Erc20Approval';
|
|
|
|
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<WithdrawTransactionArgs>((args) => {
|
|
if (!contract) {
|
|
return null;
|
|
}
|
|
return contract.withdrawAsset(
|
|
args.assetSource,
|
|
args.amount,
|
|
args.targetAddress,
|
|
args.nonce,
|
|
args.signatures
|
|
);
|
|
});
|
|
|
|
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) {
|
|
stopPolling();
|
|
setApproval(data.erc20WithdrawalApproval);
|
|
}
|
|
}, [data, stopPolling]);
|
|
|
|
useEffect(() => {
|
|
if (approval && !cancelled) {
|
|
perform(approval);
|
|
}
|
|
// eslint-disable-next-line
|
|
}, [approval]);
|
|
|
|
const reset = useCallback(() => {
|
|
resetVegaTx();
|
|
resetEthTx();
|
|
}, [resetVegaTx, resetEthTx]);
|
|
|
|
return {
|
|
submit,
|
|
reset,
|
|
approval,
|
|
withdrawalId,
|
|
vegaTx,
|
|
ethTx,
|
|
};
|
|
};
|