24 lines
683 B
TypeScript
24 lines
683 B
TypeScript
import { useCallback, useContext } from 'react';
|
|
import { useVegaWalletDialogStore, VegaWalletContext } from '.';
|
|
|
|
export function useVegaWallet() {
|
|
const context = useContext(VegaWalletContext);
|
|
if (context === undefined) {
|
|
throw new Error('useVegaWallet must be used within VegaWalletProvider');
|
|
}
|
|
return context;
|
|
}
|
|
|
|
export function useReconnectVegaWallet() {
|
|
const openVegaWalletDialog = useVegaWalletDialogStore(
|
|
(store) => store.openVegaWalletDialog
|
|
);
|
|
const { disconnect } = useVegaWallet();
|
|
const reconnect = useCallback(async () => {
|
|
await disconnect();
|
|
openVegaWalletDialog();
|
|
}, [disconnect, openVegaWalletDialog]);
|
|
|
|
return reconnect;
|
|
}
|