66c18a2b1b
* chore: improve assertions for deposits * test: validation test passing * test: withdrawal tests passing * fix: test failures in CI * fix: lint * chore: add env variables * fix: failing tests due to wallet service not running * ci: pass automatic cnsent * ci: init wallet in other directory * ci: pass home string everywhere * ci: config is already imported * fix: failing deposit and nightly run * ci: port over changes from pr run * fix: failing network param tests * fix: assertion * fix: assertion one last time Co-authored-by: Dexter <dexter.edwards93@gmail.com>
101 lines
2.4 KiB
TypeScript
101 lines
2.4 KiB
TypeScript
import { gql } from '@apollo/client';
|
|
import { t } from '@vegaprotocol/react-helpers';
|
|
import { Splash } from '@vegaprotocol/ui-toolkit';
|
|
import { useVegaWallet } from '@vegaprotocol/wallet';
|
|
import { WithdrawManager } from '@vegaprotocol/withdraws';
|
|
import { ASSET_FRAGMENT } from '../../../lib/query-fragments';
|
|
import Link from 'next/link';
|
|
import { PageQueryContainer } from '../../../components/page-query-container';
|
|
import type {
|
|
WithdrawPageQuery,
|
|
WithdrawPageQueryVariables,
|
|
} from './__generated__/WithdrawPageQuery';
|
|
|
|
const WITHDRAW_PAGE_QUERY = gql`
|
|
${ASSET_FRAGMENT}
|
|
query WithdrawPageQuery($partyId: ID!) {
|
|
party(id: $partyId) {
|
|
id
|
|
withdrawals {
|
|
id
|
|
txHash
|
|
}
|
|
accounts {
|
|
type
|
|
balance
|
|
asset {
|
|
id
|
|
symbol
|
|
}
|
|
}
|
|
}
|
|
assets {
|
|
...AssetFields
|
|
}
|
|
}
|
|
`;
|
|
|
|
interface WithdrawPageContainerProps {
|
|
assetId?: string;
|
|
}
|
|
|
|
/**
|
|
* Fetches data required for the Deposit page
|
|
*/
|
|
export const WithdrawPageContainer = ({
|
|
assetId,
|
|
}: WithdrawPageContainerProps) => {
|
|
const { keypair } = useVegaWallet();
|
|
|
|
if (!keypair) {
|
|
return (
|
|
<p data-testid="connect-vega-wallet-text">
|
|
{t('Please connect your Vega wallet')}
|
|
</p>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<PageQueryContainer<WithdrawPageQuery, WithdrawPageQueryVariables>
|
|
query={WITHDRAW_PAGE_QUERY}
|
|
options={{
|
|
variables: { partyId: keypair?.pub || '' },
|
|
skip: !keypair?.pub,
|
|
}}
|
|
render={(data) => {
|
|
if (!data.assets?.length) {
|
|
return (
|
|
<Splash>
|
|
<p>{t('No assets on this network')}</p>
|
|
</Splash>
|
|
);
|
|
}
|
|
|
|
const hasIncompleteWithdrawals = data.party?.withdrawals?.some(
|
|
(w) => w.txHash
|
|
);
|
|
|
|
return (
|
|
<>
|
|
{hasIncompleteWithdrawals ? (
|
|
<p className="mb-12">
|
|
{t('You have incomplete withdrawals.')}{' '}
|
|
<Link href="/portfolio/withdrawals">
|
|
<a className="underline">
|
|
{t('Click here to finish withdrawal')}
|
|
</a>
|
|
</Link>
|
|
</p>
|
|
) : null}
|
|
<WithdrawManager
|
|
assets={data.assets}
|
|
accounts={data.party?.accounts || []}
|
|
initialAssetId={assetId}
|
|
/>
|
|
</>
|
|
);
|
|
}}
|
|
/>
|
|
);
|
|
};
|