Skip to content

Commit cf7b6fc

Browse files
feat: createWalletAdapter for interop with other libraries (#2997)
Co-authored-by: Manan Tank <manantankm@gmail.com>
1 parent 523cd1e commit cf7b6fc

File tree

6 files changed

+71
-2
lines changed

6 files changed

+71
-2
lines changed

.changeset/three-news-melt.md

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
---
2+
"thirdweb": minor
3+
---
4+
5+
added `createWalletAdapter` helper for interop with diff libraries
Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
import type { Chain } from "../chains/types.js";
2+
import type { ThirdwebClient } from "../client/client.js";
3+
import type { Account, Wallet } from "../wallets/interfaces/wallet.js";
4+
import { createWalletEmitter } from "../wallets/wallet-emitter.js";
5+
6+
export type AdapterWalletOptions = {
7+
client: ThirdwebClient;
8+
adaptedAccount: Account;
9+
chain: Chain;
10+
onDisconnect: () => Promise<void> | void;
11+
switchChain: (chain: Chain) => Promise<void> | void;
12+
};
13+
14+
export function createWalletAdapter(
15+
options: AdapterWalletOptions,
16+
): Wallet<"adapter"> {
17+
const emitter = createWalletEmitter<"adapter">();
18+
let _chain = options.chain;
19+
return {
20+
id: "adapter",
21+
subscribe: emitter.subscribe,
22+
connect: async () => {
23+
emitter.emit("onConnect", options);
24+
return options.adaptedAccount;
25+
},
26+
autoConnect: async () => {
27+
emitter.emit("onConnect", options);
28+
return options.adaptedAccount;
29+
},
30+
disconnect: async () => {
31+
await options.onDisconnect();
32+
emitter.emit("disconnect", undefined);
33+
},
34+
getAccount() {
35+
return options.adaptedAccount;
36+
},
37+
getChain() {
38+
return _chain;
39+
},
40+
getConfig() {
41+
return options;
42+
},
43+
switchChain: async (chain) => {
44+
await options.switchChain(chain);
45+
_chain = chain;
46+
emitter.emit("chainChanged", chain);
47+
},
48+
};
49+
}

packages/thirdweb/src/exports/wallets.ts

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -96,3 +96,5 @@ export type {
9696

9797
export { getAllWalletsList } from "../wallets/getAllWalletsList.js";
9898
export { getWalletInfo } from "../wallets/__generated__/getWalletInfo.js";
99+
100+
export { createWalletAdapter } from "../adapters/wallet-adapter.js";

packages/thirdweb/src/react/web/ui/ConnectWallet/icons/dataUris.ts

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -12,3 +12,6 @@ export const smartWalletIcon =
1212

1313
export const genericTokenIcon =
1414
"";
15+
16+
export const genericWalletIcon =
17+
"";

packages/thirdweb/src/react/web/ui/components/WalletImage.tsx

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,11 @@ import type { WalletId } from "../../../../wallets/wallet-types.js";
77
import { useActiveWallet } from "../../../core/hooks/wallets/wallet-hooks.js";
88
import { getStorage } from "../../../core/storage.js";
99
import { getLastAuthProvider } from "../../wallets/in-app/storage.js";
10-
import { emailIcon, phoneIcon } from "../ConnectWallet/icons/dataUris.js";
10+
import {
11+
emailIcon,
12+
genericWalletIcon,
13+
phoneIcon,
14+
} from "../ConnectWallet/icons/dataUris.js";
1115
import {
1216
appleIconUri,
1317
facebookIconUri,
@@ -81,6 +85,7 @@ export function WalletImage(props: {
8185
return (
8286
<Img
8387
src={image}
88+
fallbackImage={genericWalletIcon}
8489
width={props.size}
8590
height={props.size}
8691
loading="eager"
@@ -108,6 +113,7 @@ function WalletImageQuery(props: {
108113
<Img
109114
client={props.client}
110115
src={walletImage.data}
116+
fallbackImage={genericWalletIcon}
111117
width={props.size}
112118
height={props.size}
113119
loading="eager"

packages/thirdweb/src/wallets/wallet-types.ts

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,4 @@
1+
import type { AdapterWalletOptions } from "../adapters/wallet-adapter.js";
12
import type { Chain } from "../chains/types.js";
23
import type { ThirdwebClient } from "../client/client.js";
34
import type {
@@ -28,6 +29,7 @@ export type WalletId =
2829
| "inApp"
2930
| "embedded" // deprecated
3031
| "smart"
32+
| "adapter"
3133
| WCSupportedWalletIds
3234
| InjectedSupportedWalletIds;
3335

@@ -116,7 +118,9 @@ export type WalletCreationOptions<T extends WalletId> = T extends "smart"
116118
? InAppWalletCreationOptions
117119
: T extends typeof COINBASE
118120
? CoinbaseWalletCreationOptions
119-
: undefined;
121+
: T extends "adapter"
122+
? AdapterWalletOptions
123+
: undefined;
120124

121125
/**
122126
* Generic type for getting the tuple type of arguments that the `createWallet` function takes.

0 commit comments

Comments
 (0)