4ed623c84c
* feat: update connect dialog to handle api v2 * feat: better error handling * feat: update to only use strings for pubkey, add json rpc connector * feat: make json connector follow same patterns as rest connector * feat: add ability to change wallet location * feat: add chain id fetch * feat: improve types * feat: adjust send tx types * chore: remove dialog title and chain check temporarily * feat: additional UI and error handling * feat: rename keypair and keypairs to pubKey and pubKeys * feat: make rest and json rpc connectors return consistent data * feat: rename derived ids more clearly * feat: update send_transaction response type * chore: fix tests after context name change * feat: add utils for wallet, add encode tx func * feat: return null if tx is rejected * feat: fix up styles for connect buttons * feat: handle wallet version check * feat: add chain id check * chore: rename select pub key function to match, fix tests * fix: tests for rest connector form * feat: add tests for json rpc flow * feat: connect dialog changes * chore: change status to enum to avoid magic strings * feat: add custom icons and handle provided key name * chore: update global wallet connection e2d tests * chore: change zod validation to only expected required values * chore: ignore new generated code files * chore: fix typos and add translations * chore: set hosted wallet via env var and only show if not mainnet * feat: add functionality for try again button * test: fix failing tests * chore: fix lint and test * chore: remove double import * chore: make console-lite-e2e strict so json connector compiles correctly * chore: make token e2e tsconfig strict * chore: make stats-e2e tsconfig strict * feat: update json rpc request namespace * feat: simplify connector setup, support try again * chore: remove comment * fix: build errors * chore: make chainId check optional based on presence of appChainId, mock request for tests * chore: mock chain id request for all apps on all pages * fix: footer border on small screens * fix: use beforeEach for chainId query mock * chore: remove optional chain check, prevent rendering until fetch is complete * chore: update NX_VEGA_WALLET_URLs as the application now appends the base path, adjust token tests * fix: token e2e test that checks for pubkey name * chore: remove duplicated test, update wallet title assertion * fix: token tests * fix: token e2e assertions * fix: withdraw test * feat: enable json RPC for token * fix: sendTx command now accpets pubkey as separate arg * fix: test to use gui option temporarily Co-authored-by: Dexter <dexter.edwards93@gmail.com>
96 lines
2.4 KiB
TypeScript
96 lines
2.4 KiB
TypeScript
import { LocalStorage } from '@vegaprotocol/react-helpers';
|
|
import type { ReactNode } from 'react';
|
|
import { useCallback, useMemo, useRef, useState } from 'react';
|
|
import type { VegaWalletContextShape } from '.';
|
|
import type {
|
|
PubKey,
|
|
Transaction,
|
|
VegaConnector,
|
|
} from './connectors/vega-connector';
|
|
import { VegaWalletContext } from './context';
|
|
import { WALLET_KEY } from './storage';
|
|
|
|
interface VegaWalletProviderProps {
|
|
children: ReactNode;
|
|
}
|
|
|
|
export const VegaWalletProvider = ({ children }: VegaWalletProviderProps) => {
|
|
// Current selected pubKey
|
|
const [pubKey, setPubKey] = useState<string | null>(null);
|
|
|
|
// Arary of pubkeys retrieved from the connector
|
|
const [pubKeys, setPubKeys] = useState<PubKey[] | null>(null);
|
|
|
|
// Reference to the current connector instance
|
|
const connector = useRef<VegaConnector | null>(null);
|
|
|
|
const selectPubKey = useCallback((pk: string) => {
|
|
setPubKey(pk);
|
|
LocalStorage.setItem(WALLET_KEY, pk);
|
|
}, []);
|
|
|
|
const connect = useCallback(async (c: VegaConnector) => {
|
|
connector.current = c;
|
|
try {
|
|
const keys = await connector.current.connect();
|
|
|
|
if (keys?.length) {
|
|
setPubKeys(keys);
|
|
|
|
const lastUsedPubKey = LocalStorage.getItem(WALLET_KEY);
|
|
const foundKey = keys.find((key) => key.publicKey === lastUsedPubKey);
|
|
if (foundKey) {
|
|
setPubKey(foundKey.publicKey);
|
|
} else {
|
|
setPubKey(keys[0].publicKey);
|
|
}
|
|
|
|
return keys;
|
|
} else {
|
|
return null;
|
|
}
|
|
} catch (err) {
|
|
return null;
|
|
}
|
|
}, []);
|
|
|
|
const disconnect = useCallback(async () => {
|
|
try {
|
|
await connector.current?.disconnect();
|
|
setPubKeys(null);
|
|
setPubKey(null);
|
|
connector.current = null;
|
|
LocalStorage.removeItem(WALLET_KEY);
|
|
return true;
|
|
} catch (err) {
|
|
console.error(err);
|
|
return false;
|
|
}
|
|
}, []);
|
|
|
|
const sendTx = useCallback((pubkey: string, transaction: Transaction) => {
|
|
if (!connector.current) {
|
|
throw new Error('No connector');
|
|
}
|
|
|
|
return connector.current.sendTx(pubkey, transaction);
|
|
}, []);
|
|
|
|
const contextValue = useMemo<VegaWalletContextShape>(() => {
|
|
return {
|
|
pubKey,
|
|
pubKeys,
|
|
selectPubKey,
|
|
connect,
|
|
disconnect,
|
|
sendTx,
|
|
};
|
|
}, [pubKey, pubKeys, selectPubKey, connect, disconnect, sendTx]);
|
|
|
|
return (
|
|
<VegaWalletContext.Provider value={contextValue}>
|
|
{children}
|
|
</VegaWalletContext.Provider>
|
|
);
|
|
};
|