thirdweb 5.55.0-nightly-8035923cdad943a47fc909e04522c351d06804f0-20240913000407 → 5.55.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (150) hide show
  1. package/dist/cjs/pay/buyWithFiat/getQuote.js +1 -0
  2. package/dist/cjs/pay/buyWithFiat/getQuote.js.map +1 -1
  3. package/dist/cjs/react/core/hooks/transaction/useSendTransaction.js.map +1 -1
  4. package/dist/cjs/react/core/utils/walletIcon.js +5 -1
  5. package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
  6. package/dist/cjs/react/native/ui/components/WalletImage.js +2 -0
  7. package/dist/cjs/react/native/ui/components/WalletImage.js.map +1 -1
  8. package/dist/cjs/react/native/ui/connect/InAppWalletUI.js +1 -0
  9. package/dist/cjs/react/native/ui/connect/InAppWalletUI.js.map +1 -1
  10. package/dist/cjs/react/native/ui/icons/svgs.js +5 -1
  11. package/dist/cjs/react/native/ui/icons/svgs.js.map +1 -1
  12. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js +1 -0
  13. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  14. package/dist/cjs/react/web/ui/ConnectWallet/Details.js +2 -2
  15. package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
  16. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +3 -2
  17. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  18. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.js +3 -1
  19. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.js.map +1 -1
  20. package/dist/cjs/react/web/ui/ConnectWallet/screens/Details/WalletManagerScreen.js +3 -1
  21. package/dist/cjs/react/web/ui/ConnectWallet/screens/Details/WalletManagerScreen.js.map +1 -1
  22. package/dist/cjs/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js.map +1 -1
  23. package/dist/cjs/react/web/ui/PayEmbed.js +1 -1
  24. package/dist/cjs/react/web/ui/PayEmbed.js.map +1 -1
  25. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -0
  26. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  27. package/dist/cjs/react/web/wallets/shared/oauthSignIn.js +1 -0
  28. package/dist/cjs/react/web/wallets/shared/oauthSignIn.js.map +1 -1
  29. package/dist/cjs/version.js +1 -1
  30. package/dist/cjs/version.js.map +1 -1
  31. package/dist/cjs/wallets/in-app/core/authentication/types.js +1 -0
  32. package/dist/cjs/wallets/in-app/core/authentication/types.js.map +1 -1
  33. package/dist/cjs/wallets/in-app/native/native-connector.js +2 -0
  34. package/dist/cjs/wallets/in-app/native/native-connector.js.map +1 -1
  35. package/dist/cjs/wallets/in-app/web/ecosystem.js +2 -0
  36. package/dist/cjs/wallets/in-app/web/ecosystem.js.map +1 -1
  37. package/dist/cjs/wallets/in-app/web/in-app.js +1 -0
  38. package/dist/cjs/wallets/in-app/web/in-app.js.map +1 -1
  39. package/dist/cjs/wallets/in-app/web/lib/web-connector.js +2 -0
  40. package/dist/cjs/wallets/in-app/web/lib/web-connector.js.map +1 -1
  41. package/dist/cjs/wallets/types.js +1 -0
  42. package/dist/cjs/wallets/types.js.map +1 -1
  43. package/dist/esm/pay/buyWithFiat/getQuote.js +1 -0
  44. package/dist/esm/pay/buyWithFiat/getQuote.js.map +1 -1
  45. package/dist/esm/react/core/hooks/transaction/useSendTransaction.js.map +1 -1
  46. package/dist/esm/react/core/utils/walletIcon.js +4 -0
  47. package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
  48. package/dist/esm/react/native/ui/components/WalletImage.js +3 -1
  49. package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -1
  50. package/dist/esm/react/native/ui/connect/InAppWalletUI.js +2 -1
  51. package/dist/esm/react/native/ui/connect/InAppWalletUI.js.map +1 -1
  52. package/dist/esm/react/native/ui/icons/svgs.js +4 -0
  53. package/dist/esm/react/native/ui/icons/svgs.js.map +1 -1
  54. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js +1 -0
  55. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  56. package/dist/esm/react/web/ui/ConnectWallet/Details.js +2 -2
  57. package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
  58. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js +3 -2
  59. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  60. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.js +3 -1
  61. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.js.map +1 -1
  62. package/dist/esm/react/web/ui/ConnectWallet/screens/Details/WalletManagerScreen.js +3 -1
  63. package/dist/esm/react/web/ui/ConnectWallet/screens/Details/WalletManagerScreen.js.map +1 -1
  64. package/dist/esm/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js.map +1 -1
  65. package/dist/esm/react/web/ui/PayEmbed.js +1 -1
  66. package/dist/esm/react/web/ui/PayEmbed.js.map +1 -1
  67. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -0
  68. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  69. package/dist/esm/react/web/wallets/shared/oauthSignIn.js +1 -0
  70. package/dist/esm/react/web/wallets/shared/oauthSignIn.js.map +1 -1
  71. package/dist/esm/version.js +1 -1
  72. package/dist/esm/version.js.map +1 -1
  73. package/dist/esm/wallets/in-app/core/authentication/types.js +1 -0
  74. package/dist/esm/wallets/in-app/core/authentication/types.js.map +1 -1
  75. package/dist/esm/wallets/in-app/native/native-connector.js +2 -0
  76. package/dist/esm/wallets/in-app/native/native-connector.js.map +1 -1
  77. package/dist/esm/wallets/in-app/web/ecosystem.js +2 -0
  78. package/dist/esm/wallets/in-app/web/ecosystem.js.map +1 -1
  79. package/dist/esm/wallets/in-app/web/in-app.js +1 -0
  80. package/dist/esm/wallets/in-app/web/in-app.js.map +1 -1
  81. package/dist/esm/wallets/in-app/web/lib/web-connector.js +2 -0
  82. package/dist/esm/wallets/in-app/web/lib/web-connector.js.map +1 -1
  83. package/dist/esm/wallets/types.js +1 -0
  84. package/dist/esm/wallets/types.js.map +1 -1
  85. package/dist/types/pay/buyWithFiat/getQuote.d.ts +7 -0
  86. package/dist/types/pay/buyWithFiat/getQuote.d.ts.map +1 -1
  87. package/dist/types/pay/utils/commonTypes.d.ts +1 -0
  88. package/dist/types/pay/utils/commonTypes.d.ts.map +1 -1
  89. package/dist/types/react/core/hooks/connection/ConnectButtonProps.d.ts +7 -0
  90. package/dist/types/react/core/hooks/connection/ConnectButtonProps.d.ts.map +1 -1
  91. package/dist/types/react/core/hooks/transaction/useSendTransaction.d.ts +2 -0
  92. package/dist/types/react/core/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  93. package/dist/types/react/core/utils/storage.d.ts +1 -1
  94. package/dist/types/react/core/utils/storage.d.ts.map +1 -1
  95. package/dist/types/react/core/utils/walletIcon.d.ts +3 -1
  96. package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
  97. package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -1
  98. package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts.map +1 -1
  99. package/dist/types/react/native/ui/icons/svgs.d.ts +1 -0
  100. package/dist/types/react/native/ui/icons/svgs.d.ts.map +1 -1
  101. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts +2 -0
  102. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
  103. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.d.ts +2 -0
  104. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.d.ts.map +1 -1
  105. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.d.ts +2 -0
  106. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.d.ts.map +1 -1
  107. package/dist/types/react/web/ui/ConnectWallet/screens/Details/WalletManagerScreen.d.ts.map +1 -1
  108. package/dist/types/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.d.ts +2 -0
  109. package/dist/types/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.d.ts.map +1 -1
  110. package/dist/types/react/web/ui/PayEmbed.d.ts +6 -1
  111. package/dist/types/react/web/ui/PayEmbed.d.ts.map +1 -1
  112. package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
  113. package/dist/types/react/web/wallets/shared/oauthSignIn.d.ts.map +1 -1
  114. package/dist/types/version.d.ts +1 -1
  115. package/dist/types/version.d.ts.map +1 -1
  116. package/dist/types/wallets/in-app/core/authentication/types.d.ts +1 -0
  117. package/dist/types/wallets/in-app/core/authentication/types.d.ts.map +1 -1
  118. package/dist/types/wallets/in-app/native/native-connector.d.ts.map +1 -1
  119. package/dist/types/wallets/in-app/web/ecosystem.d.ts +2 -0
  120. package/dist/types/wallets/in-app/web/ecosystem.d.ts.map +1 -1
  121. package/dist/types/wallets/in-app/web/in-app.d.ts +1 -0
  122. package/dist/types/wallets/in-app/web/in-app.d.ts.map +1 -1
  123. package/dist/types/wallets/in-app/web/lib/web-connector.d.ts.map +1 -1
  124. package/dist/types/wallets/types.d.ts +2 -2
  125. package/dist/types/wallets/types.d.ts.map +1 -1
  126. package/package.json +1 -1
  127. package/src/pay/buyWithFiat/getQuote.ts +9 -0
  128. package/src/pay/utils/commonTypes.ts +2 -0
  129. package/src/react/core/hooks/connection/ConnectButtonProps.ts +8 -0
  130. package/src/react/core/hooks/transaction/useSendTransaction.ts +2 -0
  131. package/src/react/core/utils/walletIcon.ts +6 -0
  132. package/src/react/native/ui/components/WalletImage.tsx +3 -0
  133. package/src/react/native/ui/connect/InAppWalletUI.tsx +2 -0
  134. package/src/react/native/ui/icons/svgs.ts +5 -0
  135. package/src/react/web/ui/ConnectWallet/ConnectButton.tsx +1 -0
  136. package/src/react/web/ui/ConnectWallet/Details.tsx +4 -0
  137. package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +6 -0
  138. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/WalletSwitcherDrawerContent.tsx +21 -17
  139. package/src/react/web/ui/ConnectWallet/screens/Details/WalletManagerScreen.tsx +17 -15
  140. package/src/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.tsx +2 -0
  141. package/src/react/web/ui/PayEmbed.tsx +8 -1
  142. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +1 -0
  143. package/src/react/web/wallets/shared/oauthSignIn.ts +1 -0
  144. package/src/version.ts +1 -1
  145. package/src/wallets/in-app/core/authentication/types.ts +1 -0
  146. package/src/wallets/in-app/native/native-connector.ts +2 -0
  147. package/src/wallets/in-app/web/ecosystem.ts +2 -0
  148. package/src/wallets/in-app/web/in-app.ts +1 -0
  149. package/src/wallets/in-app/web/lib/web-connector.ts +2 -0
  150. package/src/wallets/types.ts +1 -0
@@ -28,6 +28,9 @@ export const telegramIconUri =
28
28
  export const microsoftIconUri =
29
29
  "";
30
30
 
31
+ export const xIcon =
32
+ "";
33
+
31
34
  export const emailIcon =
32
35
  "";
33
36
 
@@ -49,6 +52,7 @@ export const socialIcons = {
49
52
  facebook: facebookIconUri,
50
53
  discord: discordIconUri,
51
54
  line: lineIconUri,
55
+ x: xIcon,
52
56
  farcaster: farcasterIconUri,
53
57
  telegram: telegramIconUri,
54
58
  };
@@ -72,6 +76,8 @@ export function getWalletIcon(provider: string) {
72
76
  return discordIconUri;
73
77
  case "line":
74
78
  return lineIconUri;
79
+ case "x":
80
+ return xIcon;
75
81
  case "farcaster":
76
82
  return farcasterIconUri;
77
83
  case "telegram":
@@ -17,6 +17,7 @@ import {
17
17
  PHONE_ICON,
18
18
  TELEGRAM_ICON,
19
19
  WALLET_ICON,
20
+ X_ICON,
20
21
  } from "../icons/svgs.js";
21
22
  import { RNImage } from "./RNImage.js";
22
23
 
@@ -84,6 +85,8 @@ export function getAuthProviderImage(authProvider: string | null): string {
84
85
  return DISCORD_ICON;
85
86
  case "line":
86
87
  return LINE_ICON;
88
+ case "x":
89
+ return X_ICON;
87
90
  case "farcaster":
88
91
  return FARCASTER_ICON;
89
92
  case "telegram":
@@ -36,6 +36,7 @@ import {
36
36
  GOOGLE_ICON,
37
37
  LINE_ICON,
38
38
  TELEGRAM_ICON,
39
+ X_ICON,
39
40
  } from "../icons/svgs.js";
40
41
  import type { ModalState } from "./ConnectModal.js";
41
42
  import { LoadingView } from "./LoadingView.js";
@@ -55,6 +56,7 @@ const socialIcons = {
55
56
  apple: APPLE_ICON,
56
57
  discord: DISCORD_ICON,
57
58
  line: LINE_ICON,
59
+ x: X_ICON,
58
60
  farcaster: FARCASTER_ICON,
59
61
  telegram: TELEGRAM_ICON,
60
62
  };
@@ -93,6 +93,11 @@ export const RIGHT_ARROW = `<svg width="20" height="20" viewBox="0 0 20 20" fill
93
93
  </svg>
94
94
  `;
95
95
 
96
+ export const X_ICON = `<svg width="320" height="320" viewBox="0 0 320 320" fill="none" xmlns="http://www.w3.org/2000/svg">
97
+ <rect width="320" height="320" rx="24" fill="black"/>
98
+ <path d="M177.315 145.335L245.068 67H229.013L170.182 135.017L123.195 67H69L140.055 169.854L69 252H85.0563L147.183 180.172L196.805 252H251L177.311 145.335H177.315ZM155.323 170.76L148.124 160.518L90.8417 79.022H115.503L161.731 144.792L168.93 155.034L229.02 240.525H204.359L155.323 170.764V170.76Z" fill="white"/>
99
+ </svg>`;
100
+
96
101
  export const WALLET_ICON = `<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
97
102
  <path d="M12.6667 4.66667V2.66667C12.6667 2.48986 12.5964 2.32029 12.4714 2.19526C12.3464 2.07024 12.1768 2 12 2H3.33333C2.97971 2 2.64057 2.14048 2.39052 2.39052C2.14048 2.64057 2 2.97971 2 3.33333C2 3.68696 2.14048 4.02609 2.39052 4.27614C2.64057 4.52619 2.97971 4.66667 3.33333 4.66667H13.3333C13.5101 4.66667 13.6797 4.7369 13.8047 4.86193C13.9298 4.98695 14 5.15652 14 5.33333V8M14 8H12C11.6464 8 11.3072 8.14048 11.0572 8.39052C10.8071 8.64057 10.6667 8.97971 10.6667 9.33333C10.6667 9.68696 10.8071 10.0261 11.0572 10.2761C11.3072 10.5262 11.6464 10.6667 12 10.6667H14C14.1768 10.6667 14.3464 10.5964 14.4714 10.4714C14.5964 10.3464 14.6667 10.1768 14.6667 10V8.66667C14.6667 8.48986 14.5964 8.32029 14.4714 8.19526C14.3464 8.07024 14.1768 8 14 8Z" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"/>
98
103
  <path d="M2 3.3335V12.6668C2 13.0205 2.14048 13.3596 2.39052 13.6096C2.64057 13.8597 2.97971 14.0002 3.33333 14.0002H13.3333C13.5101 14.0002 13.6797 13.9299 13.8047 13.8049C13.9298 13.6799 14 13.5103 14 13.3335V10.6668" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"/>
@@ -544,6 +544,7 @@ function ConnectButtonInner(
544
544
  showAllWallets: props.showAllWallets,
545
545
  walletConnect: props.walletConnect,
546
546
  wallets: props.wallets,
547
+ hiddenWallets: props.detailsModal?.hiddenWallets,
547
548
  }}
548
549
  />
549
550
  );
@@ -19,6 +19,7 @@ import { formatNumber } from "../../../../utils/formatNumber.js";
19
19
  import type { Account, Wallet } from "../../../../wallets/interfaces/wallet.js";
20
20
  import type { SmartWalletOptions } from "../../../../wallets/smart/types.js";
21
21
  import type { AppMetadata } from "../../../../wallets/types.js";
22
+ import type { WalletId } from "../../../../wallets/wallet-types.js";
22
23
  import {
23
24
  CustomThemeProvider,
24
25
  parseTheme,
@@ -744,6 +745,7 @@ function DetailsModal(props: {
744
745
  chain={props.connectOptions?.chain}
745
746
  chains={props.connectOptions?.chains}
746
747
  client={client}
748
+ hiddenWallets={props.connectOptions?.hiddenWallets}
747
749
  connectLocale={locale}
748
750
  recommendedWallets={props.connectOptions?.recommendedWallets}
749
751
  showAllWallets={!!props.connectOptions?.showAllWallets}
@@ -924,6 +926,7 @@ function DetailsModal(props: {
924
926
  mode: "fund_wallet",
925
927
  }
926
928
  }
929
+ hiddenWallets={props.detailsModal?.hiddenWallets}
927
930
  theme={typeof props.theme === "string" ? props.theme : props.theme.type}
928
931
  onDone={closeModal}
929
932
  connectOptions={undefined}
@@ -1156,6 +1159,7 @@ export type DetailsModalConnectOptions = {
1156
1159
  chain?: Chain;
1157
1160
  chains?: Chain[];
1158
1161
  recommendedWallets?: Wallet[];
1162
+ hiddenWallets?: WalletId[];
1159
1163
  showAllWallets?: boolean;
1160
1164
  };
1161
1165
 
@@ -10,6 +10,7 @@ import type { BuyWithFiatStatus } from "../../../../../../pay/buyWithFiat/getSta
10
10
  import { isSwapRequiredPostOnramp } from "../../../../../../pay/buyWithFiat/isSwapRequiredPostOnramp.js";
11
11
  import { formatNumber } from "../../../../../../utils/formatNumber.js";
12
12
  import type { Account } from "../../../../../../wallets/interfaces/wallet.js";
13
+ import type { WalletId } from "../../../../../../wallets/wallet-types.js";
13
14
  import {
14
15
  type Theme,
15
16
  iconSize,
@@ -91,6 +92,7 @@ export type BuyScreenProps = {
91
92
  theme: "light" | "dark" | Theme;
92
93
  onDone: () => void;
93
94
  connectOptions: PayEmbedConnectOptions | undefined;
95
+ hiddenWallets?: WalletId[];
94
96
  isEmbed: boolean;
95
97
  };
96
98
 
@@ -128,6 +130,7 @@ type BuyScreenContentProps = {
128
130
  theme: "light" | "dark" | Theme;
129
131
  payOptions: PayUIOptions;
130
132
  onDone: () => void;
133
+ hiddenWallets?: WalletId[];
131
134
  connectOptions: PayEmbedConnectOptions | undefined;
132
135
  isEmbed: boolean;
133
136
  };
@@ -265,6 +268,7 @@ function BuyScreenContent(props: BuyScreenContentProps) {
265
268
  });
266
269
  }
267
270
  }}
271
+ hiddenWallets={props.hiddenWallets}
268
272
  recommendedWallets={props.connectOptions?.recommendedWallets}
269
273
  showAllWallets={
270
274
  props.connectOptions?.showAllWallets === undefined
@@ -541,6 +545,7 @@ function BuyScreenContent(props: BuyScreenContentProps) {
541
545
  {screen.id === "select-wallet" && (
542
546
  <WalletSwitcherDrawerContent
543
547
  client={client}
548
+ hiddenWallets={props.hiddenWallets}
544
549
  onSelect={(w) => {
545
550
  const chain = w.getChain();
546
551
  const account = w.getAccount();
@@ -1352,6 +1357,7 @@ function FiatScreenContent(props: {
1352
1357
  isTestMode: buyWithFiatOptions?.testMode,
1353
1358
  purchaseData: props.payOptions.purchaseData,
1354
1359
  fromAddress: payer.account.address,
1360
+ preferredProvider: buyWithFiatOptions?.preferredProvider,
1355
1361
  }
1356
1362
  : undefined,
1357
1363
  );
@@ -1,6 +1,7 @@
1
1
  import { PlusIcon } from "@radix-ui/react-icons";
2
2
  import type { ThirdwebClient } from "../../../../../../../client/client.js";
3
3
  import type { Wallet } from "../../../../../../../wallets/interfaces/wallet.js";
4
+ import type { WalletId } from "../../../../../../../wallets/wallet-types.js";
4
5
  import { useCustomTheme } from "../../../../../../core/design-system/CustomThemeProvider.js";
5
6
  import {
6
7
  iconSize,
@@ -22,6 +23,7 @@ export function WalletSwitcherDrawerContent(props: {
22
23
  onBack: () => void;
23
24
  onConnect: () => void;
24
25
  selectedAddress: string;
26
+ hiddenWallets?: WalletId[];
25
27
  }) {
26
28
  const theme = useCustomTheme();
27
29
  const connectedWallets = useConnectedWallets();
@@ -34,23 +36,25 @@ export function WalletSwitcherDrawerContent(props: {
34
36
  return (
35
37
  <Container>
36
38
  <Container flex="column" gap="xs">
37
- {connectedWallets.map((w) => {
38
- const address = w.getAccount()?.address;
39
- return (
40
- <WalletSelectorButton
41
- key={w.id}
42
- walletId={w.id}
43
- client={props.client}
44
- address={address || ""}
45
- onClick={() => {
46
- props.onSelect(w);
47
- props.onBack();
48
- }}
49
- disableChevron
50
- checked={false}
51
- />
52
- );
53
- })}
39
+ {connectedWallets
40
+ .filter((w) => !props.hiddenWallets?.includes(w.id))
41
+ .map((w) => {
42
+ const address = w.getAccount()?.address;
43
+ return (
44
+ <WalletSelectorButton
45
+ key={w.id}
46
+ walletId={w.id}
47
+ client={props.client}
48
+ address={address || ""}
49
+ onClick={() => {
50
+ props.onSelect(w);
51
+ props.onBack();
52
+ }}
53
+ disableChevron
54
+ checked={false}
55
+ />
56
+ );
57
+ })}
54
58
  {!hideConnectButton && (
55
59
  <Button
56
60
  variant="secondary"
@@ -80,21 +80,23 @@ export function WalletManagerScreen(
80
80
  }}
81
81
  >
82
82
  <Container flex="column" gap="xs">
83
- {connectedWallets.map((w) => {
84
- return (
85
- <WalletManangerButton
86
- key={w.id}
87
- client={props.client}
88
- // address={address || ""}
89
- onClick={() => {
90
- setActive(w);
91
- props.onBack();
92
- }}
93
- chain={props.activeChain}
94
- wallet={w}
95
- />
96
- );
97
- })}
83
+ {connectedWallets
84
+ .filter((w) => !props.hiddenWallets?.includes(w.id))
85
+ .map((w) => {
86
+ return (
87
+ <WalletManangerButton
88
+ key={w.id}
89
+ client={props.client}
90
+ // address={address || ""}
91
+ onClick={() => {
92
+ setActive(w);
93
+ props.onBack();
94
+ }}
95
+ chain={props.activeChain}
96
+ wallet={w}
97
+ />
98
+ );
99
+ })}
98
100
  </Container>
99
101
  </Container>
100
102
 
@@ -3,6 +3,7 @@ import type { ThirdwebClient } from "../../../../../client/client.js";
3
3
  import type { Wallet } from "../../../../../wallets/interfaces/wallet.js";
4
4
  import type { SmartWalletOptions } from "../../../../../wallets/smart/types.js";
5
5
  import type { AppMetadata } from "../../../../../wallets/types.js";
6
+ import type { WalletId } from "../../../../../wallets/wallet-types.js";
6
7
  import { useConnectedWallets } from "../../../../core/hooks/wallets/useConnectedWallets.js";
7
8
  import { getDefaultWallets } from "../../../wallets/defaultWallets.js";
8
9
  import { ConnectModalContent } from "../Modal/ConnectModalContent.js";
@@ -21,6 +22,7 @@ export type WalletSwitcherConnectionScreenProps = {
21
22
  onSelect: (wallet: Wallet) => void;
22
23
  recommendedWallets: Wallet[] | undefined;
23
24
  showAllWallets: boolean;
25
+ hiddenWallets?: WalletId[];
24
26
  walletConnect:
25
27
  | {
26
28
  projectId?: string;
@@ -6,6 +6,7 @@ import type { ThirdwebClient } from "../../../client/client.js";
6
6
  import type { Wallet } from "../../../wallets/interfaces/wallet.js";
7
7
  import type { SmartWalletOptions } from "../../../wallets/smart/types.js";
8
8
  import type { AppMetadata } from "../../../wallets/types.js";
9
+ import type { WalletId } from "../../../wallets/wallet-types.js";
9
10
  import { CustomThemeProvider } from "../../core/design-system/CustomThemeProvider.js";
10
11
  import type { Theme } from "../../core/design-system/index.js";
11
12
  import type { SiweAuthOptions } from "../../core/hooks/auth/useSiweAuth.js";
@@ -119,12 +120,17 @@ export type PayEmbedProps = {
119
120
  theme?: "light" | "dark" | Theme;
120
121
 
121
122
  /**
122
- * Customize the options for "Connect" Button showin in the PayEmbed UI when the user is not connected to a wallet.
123
+ * Customize the options for "Connect" Button showing in the PayEmbed UI when the user is not connected to a wallet.
123
124
  *
124
125
  * Refer to the [`PayEmbedConnectOptions`](https://portal.thirdweb.com/references/typescript/v5/PayEmbedConnectOptions) type for more details.
125
126
  */
126
127
  connectOptions?: PayEmbedConnectOptions;
127
128
 
129
+ /**
130
+ * All wallet IDs included in this array will be hidden from wallet selection when connected.
131
+ */
132
+ hiddenWallets?: WalletId[];
133
+
128
134
  style?: React.CSSProperties;
129
135
 
130
136
  className?: string;
@@ -201,6 +207,7 @@ export function PayEmbed(props: PayEmbedProps) {
201
207
  theme={theme}
202
208
  client={props.client}
203
209
  connectLocale={localeQuery.data}
210
+ hiddenWallets={props.hiddenWallets}
204
211
  payOptions={
205
212
  props.payOptions || {
206
213
  mode: "fund_wallet",
@@ -107,6 +107,7 @@ export const ConnectWalletSocialOptions = (
107
107
  apple: locale.signInWithApple,
108
108
  discord: locale.signInWithDiscord,
109
109
  line: "LINE",
110
+ x: "X",
110
111
  farcaster: "Farcaster",
111
112
  telegram: "Telegram",
112
113
  };
@@ -36,6 +36,7 @@ function getOauthLoginPath(
36
36
  case "farcaster":
37
37
  case "telegram":
38
38
  case "line":
39
+ case "x":
39
40
  case "discord":
40
41
  return getLoginUrl({ authOption, client, ecosystem });
41
42
  default:
package/src/version.ts CHANGED
@@ -1 +1 @@
1
- export const version = "5.55.0-nightly-8035923cdad943a47fc909e04522c351d06804f0-20240913000407";
1
+ export const version = "5.55.0";
@@ -76,6 +76,7 @@ export enum AuthProvider {
76
76
  APPLE = "Apple",
77
77
  PASSKEY = "Passkey",
78
78
  DISCORD = "Discord",
79
+ X = "X",
79
80
  LINE = "Line",
80
81
  FARCASTER = "Farcaster",
81
82
  TELEGRAM = "Telegram",
@@ -110,6 +110,7 @@ export class InAppNativeConnector implements InAppConnector {
110
110
  case "facebook":
111
111
  case "discord":
112
112
  case "line":
113
+ case "x":
113
114
  case "apple": {
114
115
  const ExpoLinking = require("expo-linking");
115
116
  const redirectUrl =
@@ -146,6 +147,7 @@ export class InAppNativeConnector implements InAppConnector {
146
147
  case "facebook":
147
148
  case "discord":
148
149
  case "line":
150
+ case "x":
149
151
  case "farcaster":
150
152
  case "telegram":
151
153
  case "apple": {
@@ -17,6 +17,8 @@ import { createEcosystemWallet } from "../core/wallet/ecosystem-core.js";
17
17
  * - Apple
18
18
  * - Facebook
19
19
  * - Discord
20
+ * - LINE
21
+ * - X
20
22
  * - Farcaster
21
23
  *
22
24
  * Can also be configured to use Account Abstraction to directly connect to a ERC4337 smart account based on those authentication methods.
@@ -16,6 +16,7 @@ import { createInAppWallet } from "../core/wallet/in-app-core.js";
16
16
  * - Discord
17
17
  * - Telegram
18
18
  * - LINE
19
+ * - X
19
20
  * - Farcaster
20
21
  *
21
22
  * Can also be configured to use Account Abstraction to directly connect to a ERC4337 smart account based on those authentication methods.
@@ -216,6 +216,7 @@ export class InAppWebConnector implements InAppConnector {
216
216
  case "telegram":
217
217
  case "farcaster":
218
218
  case "line":
219
+ case "x":
219
220
  case "discord": {
220
221
  return loginWithOauth({
221
222
  authOption: strategy,
@@ -277,6 +278,7 @@ export class InAppWebConnector implements InAppConnector {
277
278
  case "farcaster":
278
279
  case "telegram":
279
280
  case "line":
281
+ case "x":
280
282
  case "discord": {
281
283
  const authToken = await this.authenticate(args);
282
284
  return this.auth.loginWithAuthToken(authToken);
@@ -25,6 +25,7 @@ export const socialAuthOptions = [
25
25
  "facebook",
26
26
  "discord",
27
27
  "line",
28
+ "x",
28
29
  "farcaster",
29
30
  "telegram",
30
31
  ] as const;