Skip to content

Commit 73e34c0

Browse files
Kien NgoMananTankjnsdls
authored
[wallet, react] Add Magic Eden wallet (#2347)
Co-authored-by: Manan Tank <[email protected]> Co-authored-by: Jonas Daniels <[email protected]>
1 parent cc22fa8 commit 73e34c0

File tree

19 files changed

+468
-1
lines changed

19 files changed

+468
-1
lines changed

.changeset/friendly-hairs-hope.md

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
---
2+
"@thirdweb-dev/react-core": patch
3+
"@thirdweb-dev/wallets": patch
4+
"@thirdweb-dev/react": patch
5+
---
6+
7+
Add Magic Eden wallet

packages/react-core/src/core/hooks/wallet-hooks.ts

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@ import type {
99
EmbeddedWallet,
1010
FrameWallet,
1111
LocalWallet,
12+
MagicEdenWallet,
1213
MagicLink,
1314
MetaMaskWallet,
1415
OKXWallet,
@@ -56,6 +57,7 @@ export type WalletIdToWalletTypeMap = {
5657
cryptoDefiWallet: CryptoDefiWallet;
5758
rabby: RabbyWallet;
5859
xdefi: XDEFIWallet;
60+
magicEden: MagicEdenWallet
5961
};
6062

6163
/**

packages/react/src/evm/locales/en.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -164,6 +164,7 @@ export function enDefault(): ThirdwebLocale {
164164
},
165165
},
166166
coinbaseWallet: extensionAndQRScanScreens("Coinbase"),
167+
magicEdenWallet: extensionAndQRScanScreens("Magic Eden"),
167168
metamaskWallet: extensionAndQRScanScreens("MetaMask"),
168169
okxWallet: extensionAndQRScanScreens("OKX"),
169170
phantomWallet: extensionAndQRScanScreens("Phantom"),

packages/react/src/evm/locales/es.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -167,6 +167,7 @@ export function esDefault(): ThirdwebLocale {
167167
},
168168
},
169169
coinbaseWallet: extensionAndQRScanScreens("Coinbase"),
170+
magicEdenWallet: extensionAndQRScanScreens("Magic Eden"),
170171
metamaskWallet: extensionAndQRScanScreens("MetaMask"),
171172
okxWallet: extensionAndQRScanScreens("OKX"),
172173
coreWallet: extensionAndQRScanScreens("Core"),

packages/react/src/evm/locales/ja.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -167,6 +167,7 @@ export function jaDefault(): ThirdwebLocale {
167167
},
168168
},
169169
coinbaseWallet: extensionAndQRScanScreens("Coinbase"),
170+
magicEdenWallet: extensionAndQRScanScreens("Magic Eden"),
170171
metamaskWallet: extensionAndQRScanScreens("MetaMask"),
171172
okxWallet: extensionAndQRScanScreens("OKX"),
172173
coreWallet: extensionAndQRScanScreens("Core"),

packages/react/src/evm/locales/tl.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -169,6 +169,7 @@ export function tlDefault(): ThirdwebLocale {
169169
},
170170
},
171171
coinbaseWallet: extensionAndQRScanScreens("Coinbase"),
172+
magicEdenWallet: extensionAndQRScanScreens("Magic Eden"),
172173
metamaskWallet: extensionAndQRScanScreens("MetaMask"),
173174
okxWallet: extensionAndQRScanScreens("OKX"),
174175
phantomWallet: extensionAndQRScanScreens("Phantom"),

packages/react/src/evm/locales/types.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -235,6 +235,7 @@ export type ThirdwebLocale = {
235235
signIn: string;
236236
submitEmail: string;
237237
};
238+
magicEdenWallet: ExtensionAndQRScreensLocale;
238239
metamaskWallet: ExtensionAndQRScreensLocale;
239240
okxWallet: ExtensionAndQRScreensLocale;
240241
oneKeyWallet: ExtensionAndQRScreensLocale;

packages/react/src/index.ts

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,11 @@ export {
2626
export { localWallet } from "./wallet/wallets/localWallet/localWallet";
2727
export type { LocalWalletConfigOptions } from "./wallet/wallets/localWallet/types";
2828

29+
export {
30+
magicEdenWallet,
31+
type MagicEdenWalletConfigOptions,
32+
} from "./wallet/wallets/magicEden/magicEdenWallet";
33+
2934
export {
3035
magicLink,
3136
type MagicWalletConfigOptions,
Lines changed: 101 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,101 @@
1+
import { ConnectUIProps } from "@thirdweb-dev/react-core";
2+
import { ConnectingScreen } from "../../ConnectWallet/screens/ConnectingScreen";
3+
import { useCallback, useEffect, useRef, useState } from "react";
4+
import { GetStartedScreen } from "../../ConnectWallet/screens/GetStartedScreen";
5+
import { MagicEdenWallet } from "@thirdweb-dev/wallets";
6+
import { wait } from "../../../utils/wait";
7+
import { useTWLocale } from "../../../evm/providers/locale-provider";
8+
9+
export const MagicEdenConnectUI = (props: ConnectUIProps<MagicEdenWallet>) => {
10+
const [screen, setScreen] = useState<"connecting" | "get-started">(
11+
"connecting",
12+
);
13+
const locale = useTWLocale().wallets.magicEdenWallet;
14+
const { walletConfig, connected } = props;
15+
const [errorConnecting, setErrorConnecting] = useState(false);
16+
const { connect } = props;
17+
18+
const hideBackButton = props.supportedWallets.length === 1;
19+
const { goBack } = props;
20+
21+
const connectToExtension = useCallback(async () => {
22+
try {
23+
connectPrompted.current = true;
24+
setScreen("connecting");
25+
setErrorConnecting(false);
26+
await wait(1000);
27+
await connect();
28+
connected();
29+
} catch (e) {
30+
setErrorConnecting(true);
31+
console.error(e);
32+
}
33+
}, [connected, connect]);
34+
35+
const connectPrompted = useRef(false);
36+
useEffect(() => {
37+
if (connectPrompted.current) {
38+
return;
39+
}
40+
41+
const isInstalled = walletConfig.isInstalled
42+
? walletConfig.isInstalled()
43+
: false;
44+
45+
(async () => {
46+
if (isInstalled) {
47+
connectToExtension();
48+
}
49+
50+
// if magic-eden wallet is not injected
51+
else {
52+
setScreen("get-started");
53+
}
54+
})();
55+
}, [walletConfig, connected, connect, goBack, connectToExtension]);
56+
57+
if (screen === "connecting") {
58+
return (
59+
<ConnectingScreen
60+
locale={{
61+
getStartedLink: locale.getStartedLink,
62+
instruction: locale.connectionScreen.instruction,
63+
tryAgain: locale.connectionScreen.retry,
64+
inProgress: locale.connectionScreen.inProgress,
65+
failed: locale.connectionScreen.failed,
66+
}}
67+
hideBackButton={hideBackButton}
68+
onBack={props.goBack}
69+
walletName={walletConfig.meta.name}
70+
walletIconURL={walletConfig.meta.iconURL}
71+
onGetStarted={() => {
72+
setScreen("get-started");
73+
}}
74+
onRetry={() => {
75+
connectToExtension();
76+
}}
77+
errorConnecting={errorConnecting}
78+
/>
79+
);
80+
}
81+
82+
if (screen === "get-started") {
83+
return (
84+
<GetStartedScreen
85+
locale={{
86+
scanToDownload: locale.getStartedScreen.instruction,
87+
}}
88+
walletIconURL={walletConfig.meta.iconURL}
89+
walletName={walletConfig.meta.name}
90+
chromeExtensionLink={walletConfig.meta.urls?.chrome}
91+
googlePlayStoreLink={walletConfig.meta.urls?.android}
92+
appleStoreLink={walletConfig.meta.urls?.ios}
93+
onBack={() => {
94+
props.goBack();
95+
}}
96+
/>
97+
);
98+
}
99+
100+
return null;
101+
};
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
import type { WalletOptions, WalletConfig } from "@thirdweb-dev/react-core";
2+
import { MagicEdenWallet } from "@thirdweb-dev/wallets";
3+
import { MagicEdenConnectUI } from "./MagicEdenConnectUI";
4+
import { getInjectedMagicEdenProvider } from "@thirdweb-dev/wallets";
5+
6+
/**
7+
* @wallet
8+
*/
9+
export type MagicEdenWalletConfigOptions = {
10+
/**
11+
* If `true`, the wallet will be tagged as "recommended" in ConnectWallet Modal. Default is `false`
12+
*/
13+
recommended?: boolean;
14+
};
15+
16+
/**
17+
* A wallet configurator for [Phantom Wallet](https://phantom.app/) which allows integrating the wallet with React.
18+
*
19+
* It returns a [`WalletConfig`](https://portal.thirdweb.com/references/react/v4/WalletConfig) object which can be used to connect the wallet to via [`ConnectWallet`](https://portal.thirdweb.com/react/v4/components/ConnectWallet) component or [`useConnect`](https://portal.thirdweb.com/references/react/v4/useConnect) hook as mentioned in [Connecting Wallets](https://portal.thirdweb.com/react/v4/connecting-wallets) guide
20+
*
21+
* @example
22+
* ```ts
23+
* phantomWallet({
24+
* recommended: true,
25+
* })
26+
* ```
27+
*
28+
* @param options -
29+
* Optional configuration options for the wallet
30+
*
31+
* ### recommended (optional)
32+
* If `true`, the wallet will be tagged as "recommended" in [`ConnectWallet`](https://portal.thirdweb.com/react/v4/components/ConnectWallet) Modal UI. Default is `false`
33+
*
34+
* @wallet
35+
*/
36+
export const magicEdenWallet = (
37+
options?: MagicEdenWalletConfigOptions,
38+
): WalletConfig<MagicEdenWallet> => {
39+
return {
40+
recommended: options?.recommended,
41+
id: "Magic Eden",
42+
meta: {
43+
name: "Magic Eden Wallet",
44+
urls: {
45+
chrome:
46+
"https://chromewebstore.google.com/detail/magic-eden-wallet/mkpegjkblkkefacfnmkajcjmabijhclg",
47+
},
48+
iconURL:
49+
"" },
50+
create: (walletOptions: WalletOptions) => new MagicEdenWallet(walletOptions),
51+
connectUI: MagicEdenConnectUI,
52+
isInstalled() {
53+
return !!getInjectedMagicEdenProvider();
54+
},
55+
};
56+
};

0 commit comments

Comments
 (0)