Skip to content

Commit

Permalink
Merge branch 'master' into fix/torus
Browse files Browse the repository at this point in the history
  • Loading branch information
jordaaash committed Oct 22, 2021
2 parents 8827e32 + de489d9 commit a0da7e9
Show file tree
Hide file tree
Showing 16 changed files with 93 additions and 103 deletions.
62 changes: 31 additions & 31 deletions README.md

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion packages/core/react/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@solana/wallet-adapter-react",
"version": "0.13.0",
"version": "0.13.1",
"author": "Solana Maintainers <[email protected]>",
"repository": "https://github.com/solana-labs/wallet-adapter",
"license": "Apache-2.0",
Expand Down
82 changes: 41 additions & 41 deletions packages/core/react/src/WalletProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ export const WalletProvider: FC<WalletProviderProps> = ({
children,
wallets,
autoConnect = false,
onError = (error: WalletError) => console.error(error),
onError: _onError = (error: WalletError) => console.error(error),
localStorageKey = 'walletName',
}) => {
const [name, setName] = useLocalStorage<WalletName | null>(localStorageKey, null);
Expand All @@ -44,6 +44,7 @@ export const WalletProvider: FC<WalletProviderProps> = ({
const [disconnecting, setDisconnecting] = useState(false);
const isConnecting = useRef(false);
const isDisconnecting = useRef(false);
const isUnloading = useRef(false);

// Map of wallet names to wallets
const walletsByName = useMemo(
Expand Down Expand Up @@ -87,6 +88,16 @@ export const WalletProvider: FC<WalletProviderProps> = ({
})();
}, [isConnecting, connecting, connected, autoConnect, adapter, ready, setConnecting, setName]);

// If the window is closing or reloading, ignore disconnect and error events from the adapter
useEffect(() => {
function listener() {
isUnloading.current = true;
}

window.addEventListener('beforeunload', listener);
return () => window.removeEventListener('beforeunload', listener);
}, [isUnloading]);

// Select a wallet by name
const select = useCallback(
async (newName: WalletName | null) => {
Expand Down Expand Up @@ -114,36 +125,45 @@ export const WalletProvider: FC<WalletProviderProps> = ({
}, [adapter, setState]);

// Handle the adapter's disconnect event
const onDisconnect = useCallback(() => setName(null), [setName]);
const onDisconnect = useCallback(() => {
// Clear the selected wallet unless the window is unloading
if (!isUnloading.current) setName(null);
}, [isUnloading, setName]);

// Handle the adapter's error event, and local errors
const onError = useCallback(
(error: WalletError) => {
// Call the provided error handler unless the window is unloading
if (!isUnloading.current) _onError(error);
return error;
},
[isUnloading, _onError]
);

// Connect the adapter to the wallet
const connect = useCallback(async () => {
if (isConnecting.current || connecting || disconnecting || connected) return;

if (!wallet || !adapter) {
const error = new WalletNotSelectedError();
onError(error);
throw error;
}
if (!wallet || !adapter) throw onError(new WalletNotSelectedError());

if (!ready) {
// Clear the selected wallet
setName(null);

if (typeof window !== 'undefined') {
window.open(wallet.url, '_blank');
}

const error = new WalletNotReadyError();
onError(error);
throw error;
throw onError(new WalletNotReadyError());
}

isConnecting.current = true;
setConnecting(true);
try {
await adapter.connect();
} catch (error: any) {
// Clear the selected wallet
setName(null);
// Rethrow the error, and onError will also be called
throw error;
} finally {
setConnecting(false);
Expand All @@ -160,8 +180,12 @@ export const WalletProvider: FC<WalletProviderProps> = ({
setDisconnecting(true);
try {
await adapter.disconnect();
} finally {
} catch (error: any) {
// Clear the selected wallet
setName(null);
// Rethrow the error, and onError will also be called
throw error;
} finally {
setDisconnecting(false);
isDisconnecting.current = false;
}
Expand All @@ -170,17 +194,8 @@ export const WalletProvider: FC<WalletProviderProps> = ({
// Send a transaction using the provided connection
const sendTransaction = useCallback(
async (transaction: Transaction, connection: Connection, options?: SendTransactionOptions) => {
if (!adapter) {
const error = new WalletNotSelectedError();
onError(error);
throw error;
}
if (!connected) {
const error = new WalletNotConnectedError();
onError(error);
throw error;
}

if (!adapter) throw onError(new WalletNotSelectedError());
if (!connected) throw onError(new WalletNotConnectedError());
return await adapter.sendTransaction(transaction, connection, options);
},
[adapter, onError, connected]
Expand All @@ -191,12 +206,7 @@ export const WalletProvider: FC<WalletProviderProps> = ({
() =>
adapter && 'signTransaction' in adapter
? async (transaction: Transaction): Promise<Transaction> => {
if (!connected) {
const error = new WalletNotConnectedError();
onError(error);
throw error;
}

if (!connected) throw onError(new WalletNotConnectedError());
return await adapter.signTransaction(transaction);
}
: undefined,
Expand All @@ -208,12 +218,7 @@ export const WalletProvider: FC<WalletProviderProps> = ({
() =>
adapter && 'signAllTransactions' in adapter
? async (transactions: Transaction[]): Promise<Transaction[]> => {
if (!connected) {
const error = new WalletNotConnectedError();
onError(error);
throw error;
}

if (!connected) throw onError(new WalletNotConnectedError());
return await adapter.signAllTransactions(transactions);
}
: undefined,
Expand All @@ -225,12 +230,7 @@ export const WalletProvider: FC<WalletProviderProps> = ({
() =>
adapter && 'signMessage' in adapter
? async (message: Uint8Array): Promise<Uint8Array> => {
if (!connected) {
const error = new WalletNotConnectedError();
onError(error);
throw error;
}

if (!connected) throw onError(new WalletNotConnectedError());
return await adapter.signMessage(message);
}
: undefined,
Expand Down
2 changes: 1 addition & 1 deletion packages/core/react/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
export * from './useAnchorWallet';
export * from './ConnectionProvider';
export * from './errors';
export * from './useAnchorWallet';
export * from './useConnection';
export * from './useLocalStorage';
export * from './useWallet';
Expand Down
6 changes: 0 additions & 6 deletions packages/core/react/src/useLocalStorage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,6 @@ export function useLocalStorage<T>(key: string, defaultState: T): [T, (newValue:
if (newValue === value) return;
setValue(newValue);

if (newValue === null) {
localStorage.removeItem(key);
} else {
localStorage.setItem(key, JSON.stringify(newValue));
}

if (newValue === null) {
localStorage.removeItem(key);
} else {
Expand Down
3 changes: 2 additions & 1 deletion packages/core/wallets/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@solana/wallet-adapter-wallets",
"version": "0.11.0",
"version": "0.11.1",
"author": "Solana Maintainers <[email protected]>",
"repository": "https://github.com/solana-labs/wallet-adapter",
"license": "Apache-2.0",
Expand All @@ -25,6 +25,7 @@
"@solana/wallet-adapter-base": "^0.7.0"
},
"dependencies": {
"@solana/wallet-adapter-bitkeep": "^0.1.0",
"@solana/wallet-adapter-bitpie": "^0.3.0",
"@solana/wallet-adapter-blocto": "^0.3.0",
"@solana/wallet-adapter-clover": "^0.2.0",
Expand Down
20 changes: 8 additions & 12 deletions packages/core/wallets/src/bitkeep.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,9 @@
// import { BitKeepWalletAdapter, BitKeepWalletAdapterConfig } from '@solana/wallet-adapter-bitkeep';
// import { Wallet, WalletName } from './types';
//
// @solana/wallet-adapter-bitkeep isn't published to NPM yet
//
// export const getBitKeepWallet = (config: BitKeepWalletAdapterConfig = {}): Wallet => ({
// name: WalletName.BitKeep,
// url: 'https://www.bitkeep.org',
// icon: '',
// adapter: () => new BitKeepWalletAdapter(config),
// });
import { BitKeepWalletAdapter, BitKeepWalletAdapterConfig } from '@solana/wallet-adapter-bitkeep';
import { Wallet, WalletName } from './types';

export {}; // not published yet
export const getBitKeepWallet = (config: BitKeepWalletAdapterConfig = {}): Wallet => ({
name: WalletName.BitKeep,
url: 'https://bitkeep.com',
icon: '',
adapter: () => new BitKeepWalletAdapter(config),
});
2 changes: 1 addition & 1 deletion packages/core/wallets/src/blocto.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { Wallet, WalletName } from './types';

export const getBloctoWallet = (config: BloctoWalletAdapterConfig = {}): Wallet => ({
name: WalletName.Blocto,
url: 'https://wallet.blocto.app',
url: 'https://blocto.app',
icon: '',
adapter: () => new BloctoWalletAdapter(config),
});
2 changes: 1 addition & 1 deletion packages/core/wallets/src/ledger.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { Wallet, WalletName } from './types';

export const getLedgerWallet = (config: LedgerWalletAdapterConfig = {}): Wallet => ({
name: WalletName.Ledger,
url: 'https://www.ledger.com',
url: 'https://ledger.com',
icon: '',
adapter: () => new LedgerWalletAdapter(config),
});
2 changes: 1 addition & 1 deletion packages/core/wallets/src/phantom.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { Wallet, WalletName } from './types';

export const getPhantomWallet = (config: PhantomWalletAdapterConfig = {}): Wallet => ({
name: WalletName.Phantom,
url: 'https://www.phantom.app',
url: 'https://phantom.app',
icon: '',
adapter: () => new PhantomWalletAdapter(config),
});
2 changes: 1 addition & 1 deletion packages/core/wallets/src/safepal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { Wallet, WalletName } from './types';

export const getSafePalWallet = (config: SafePalWalletAdapterConfig = {}): Wallet => ({
name: WalletName.SafePal,
url: 'https://www.safepal.io',
url: 'https://safepal.io',
icon: '',
adapter: () => new SafePalWalletAdapter(config),
});
Loading

0 comments on commit a0da7e9

Please sign in to comment.