Skip to content

Commit 13f00cf

Browse files
allen-hsujnsdls
andauthored
fix: fix imToken wallet issue (#2562)
Signed-off-by: Jonas Daniels <jonas.daniels@outlook.com> Co-authored-by: Jonas Daniels <jonas.daniels@outlook.com>
1 parent 9e28754 commit 13f00cf

File tree

8 files changed

+31
-9
lines changed

8 files changed

+31
-9
lines changed

.changeset/hip-mice-approve.md

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
---
2+
"@thirdweb-dev/react": patch
3+
"@thirdweb-dev/wallets": patch
4+
---
5+
6+
fix: fix imToken wallet issue

legacy_packages/react/src/wallet/hooks/useInstalledWallets.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -20,7 +20,7 @@ export function useInstalledWallets() {
2020
isCoinbaseWalletInstalled = !!getInjectedCoinbaseProvider();
2121
isZerionWalletInstalled = !!window_.ethereum?.isZerion;
2222
isTrustWalletInstalled = !!window_.ethereum?.isTrust;
23-
isImTokenInstalled = !!window_.ethereum?.isToken;
23+
isImTokenInstalled = !!window_.ethereum?.isImToken;
2424
}
2525

2626
return {

legacy_packages/react/src/wallet/wallets/imtoken/imTokenWallet.tsx

Lines changed: 2 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -8,8 +8,8 @@ import { useTWLocale } from "../../../evm/providers/locale-provider";
88
import { ExtensionOrWCConnectionUI } from "../_common/ExtensionORWCConnectionUI";
99

1010
const imTokenWalletUris = {
11-
ios: "https://itunes.apple.com/us/app/imtoken2/id1384798940",
12-
android: "https://play.google.com/store/apps/details?id=im.token.app",
11+
ios: "imtokenv2://",
12+
android: "imtokenv2://",
1313
};
1414

1515
export type ImTokenWalletConfigOptions = {
@@ -25,8 +25,6 @@ export const imTokenWallet = (
2525
recommended: options?.recommended,
2626
meta: {
2727
...ImTokenWallet.meta,
28-
iconURL:
29-
"",
3028
},
3129
create: (walletOptions: WalletOptions) => {
3230
const wallet = new ImTokenWallet({

legacy_packages/wallets/src/evm/connectors/imtoken/index.ts

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -16,8 +16,8 @@ export class ImTokenConnector extends InjectedConnector {
1616
name: "imToken",
1717
getProvider() {
1818
function getReady(ethereum?: Ethereum) {
19-
const isToken = !!ethereum?.isToken;
20-
if (!isToken) {
19+
const isImToken = !!ethereum?.isImToken;
20+
if (!isImToken) {
2121
return;
2222
}
2323
return ethereum;

legacy_packages/wallets/src/evm/connectors/injected/types.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -57,7 +57,7 @@ type InjectedProviderFlags = {
5757
isRabbyWallet?: true;
5858
isCoin98Wallet?: true;
5959
// imToken
60-
isToken?: true;
60+
isImToken?: true;
6161
};
6262
type InjectedProviders = InjectedProviderFlags & {
6363
isMetaMask: true;

legacy_packages/wallets/src/evm/connectors/metamask/getInjectedMetamaskProvider.ts

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,10 @@ export function getInjectedMetamaskProvider(): Ethereum | undefined {
6565
return;
6666
}
6767

68+
if (ethereum.isImToken) {
69+
return;
70+
}
71+
6872
return ethereum;
6973
}
7074

legacy_packages/wallets/src/evm/utils/getInjectedName.ts

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,9 @@ export function getInjectedName(ethereum?: Ethereum) {
5454
if (provider.isMetaMask) {
5555
return "MetaMask";
5656
}
57+
if (provider.isImToken) {
58+
return "imToken";
59+
}
5760
};
5861

5962
// Some injected providers detect multiple other providers and create a list at `ethers.providers`

legacy_packages/wallets/src/evm/wallets/imtoken.ts

Lines changed: 12 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -26,10 +26,21 @@ export class ImTokenWallet extends AbstractClientWallet<ImTokenAdditionalOptions
2626
walletConnectConnector?: WalletConnectConnectorType;
2727
imtokenConnector?: ImTokenConnectorType;
2828
isInjected: boolean;
29+
30+
static meta = {
31+
name: "imToken",
32+
iconURL:
33+
"",
34+
urls: {
35+
ios: "https://itunes.apple.com/us/app/imtoken2/id1384798940",
36+
android: "https://play.google.com/store/apps/details?id=im.token.app",
37+
},
38+
};
39+
2940
static id = walletIds.imtoken as string;
3041

3142
public get walletName() {
32-
return "imToken Wallet" as const;
43+
return "imToken" as const;
3344
}
3445

3546
constructor(options: ImTokenWalletOptions) {

0 commit comments

Comments
 (0)