@web3auth/modal 10.0.0-beta.0 → 10.0.0-beta.11

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 (419) hide show
  1. package/README.md +2 -2
  2. package/dist/lib.cjs/node_modules/style-inject/dist/style-inject.es.js +1 -1
  3. package/dist/lib.cjs/packages/modal/src/config.js +3 -3
  4. package/dist/lib.cjs/packages/modal/src/index.js +1 -0
  5. package/dist/lib.cjs/packages/modal/src/modalManager.js +278 -174
  6. package/dist/lib.cjs/packages/modal/src/react/Web3AuthProvider.js +9 -3
  7. package/dist/lib.cjs/packages/modal/src/react/context/WalletServicesInnerContext.js +72 -0
  8. package/dist/lib.cjs/packages/modal/src/react/context/Web3AuthInnerContext.js +51 -107
  9. package/dist/lib.cjs/packages/modal/src/react/hooks/useCheckout.js +34 -0
  10. package/dist/lib.cjs/packages/modal/src/react/hooks/useEnableMFA.js +30 -0
  11. package/dist/lib.cjs/packages/modal/src/react/hooks/useIdentityToken.js +42 -0
  12. package/dist/lib.cjs/packages/modal/src/react/hooks/useManageMFA.js +30 -0
  13. package/dist/lib.cjs/packages/modal/src/react/hooks/useSwap.js +34 -0
  14. package/dist/lib.cjs/packages/modal/src/react/hooks/useSwitchChain.js +32 -0
  15. package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletConnectScanner.js +34 -0
  16. package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletServicesPlugin.js +13 -0
  17. package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletUI.js +34 -0
  18. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3Auth.js +21 -8
  19. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthConnect.js +63 -0
  20. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthDisconnect.js +30 -0
  21. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthInner.js +15 -0
  22. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthUser.js +50 -0
  23. package/dist/lib.cjs/packages/modal/src/react/index.js +24 -3
  24. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignAndSendTransaction.js +36 -0
  25. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignMessage.js +37 -0
  26. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignTransaction.js +36 -0
  27. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSolanaWallet.js +43 -0
  28. package/dist/lib.cjs/packages/modal/src/react/solana/index.js +13 -0
  29. package/dist/lib.cjs/packages/modal/src/react/wagmi/constants.js +16 -0
  30. package/dist/lib.cjs/packages/modal/src/react/wagmi/index.js +7 -0
  31. package/dist/lib.cjs/packages/modal/src/react/wagmi/provider.js +195 -0
  32. package/dist/lib.cjs/packages/modal/src/ui/components/BottomSheet/BottomSheet.js +60 -0
  33. package/dist/lib.cjs/packages/modal/src/ui/components/Button/Button.js +47 -22
  34. package/dist/lib.cjs/packages/modal/src/ui/components/Button/Button.type.js +8 -0
  35. package/dist/lib.cjs/packages/modal/src/ui/components/Button/ButtonSocial/ButtonSocial.js +53 -0
  36. package/dist/lib.cjs/packages/modal/src/ui/components/Button/ButtonWallet/ButtonWallet.js +76 -0
  37. package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWallet.js +208 -0
  38. package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.js +65 -0
  39. package/dist/lib.cjs/packages/modal/src/ui/components/{ExternalWallet/ExternalWalletChainNamespace.js → ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js} +29 -30
  40. package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.js +49 -0
  41. package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.js +148 -0
  42. package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.js +99 -0
  43. package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.js +55 -0
  44. package/dist/lib.cjs/packages/modal/src/ui/components/Embed/Embed.js +70 -0
  45. package/dist/lib.cjs/packages/modal/src/ui/components/Footer/Footer.js +50 -0
  46. package/dist/lib.cjs/packages/modal/src/ui/components/Image/Image.js +90 -0
  47. package/dist/lib.cjs/packages/modal/src/ui/components/Loader/Loader.js +151 -0
  48. package/dist/lib.cjs/packages/modal/src/ui/components/Login/Login.js +527 -0
  49. package/dist/lib.cjs/packages/modal/src/ui/components/Login/LoginOtp/LoginOtp.js +119 -0
  50. package/dist/lib.cjs/packages/modal/src/ui/components/Login/LoginPasswordLess/LoginPasswordLess.js +122 -0
  51. package/dist/lib.cjs/packages/modal/src/ui/components/LoginHint/LoginHint.js +52 -0
  52. package/dist/lib.cjs/packages/modal/src/ui/components/Modal/Modal.js +87 -0
  53. package/dist/lib.cjs/packages/modal/src/ui/components/Otp/Otp.js +190 -0
  54. package/dist/lib.cjs/packages/modal/src/ui/components/PulseLoader/PulseLoader.js +18 -0
  55. package/dist/lib.cjs/packages/modal/src/ui/components/Root/Root.js +509 -0
  56. package/dist/lib.cjs/packages/modal/src/ui/components/SocialLoginList/SocialLoginList.js +137 -0
  57. package/dist/lib.cjs/packages/modal/src/ui/components/Toast/Toast.js +70 -0
  58. package/dist/lib.cjs/packages/modal/src/ui/components/Widget/Widget.js +242 -0
  59. package/dist/lib.cjs/packages/modal/src/ui/config.js +13 -1
  60. package/dist/lib.cjs/packages/modal/src/ui/constants.js +48 -0
  61. package/dist/lib.cjs/packages/modal/src/ui/context/RootContext.js +29 -0
  62. package/dist/lib.cjs/packages/modal/src/ui/context/ThemeContext.js +2 -2
  63. package/dist/lib.cjs/packages/modal/src/ui/css/index.css.js +8 -0
  64. package/dist/lib.cjs/packages/modal/src/ui/handlers/AbstractHandler.js +121 -0
  65. package/dist/lib.cjs/packages/modal/src/ui/handlers/EmailPasswordlessHandler.js +57 -0
  66. package/dist/lib.cjs/packages/modal/src/ui/handlers/SmsPasswordlessHandler.js +57 -0
  67. package/dist/lib.cjs/packages/modal/src/ui/handlers/factory.js +19 -0
  68. package/dist/lib.cjs/packages/modal/src/ui/i18n/dutch.json.js +41 -5
  69. package/dist/lib.cjs/packages/modal/src/ui/i18n/english.json.js +41 -5
  70. package/dist/lib.cjs/packages/modal/src/ui/i18n/french.json.js +41 -5
  71. package/dist/lib.cjs/packages/modal/src/ui/i18n/german.json.js +41 -5
  72. package/dist/lib.cjs/packages/modal/src/ui/i18n/japanese.json.js +41 -5
  73. package/dist/lib.cjs/packages/modal/src/ui/i18n/korean.json.js +41 -5
  74. package/dist/lib.cjs/packages/modal/src/ui/i18n/mandarin.json.js +41 -5
  75. package/dist/lib.cjs/packages/modal/src/ui/i18n/portuguese.json.js +41 -5
  76. package/dist/lib.cjs/packages/modal/src/ui/i18n/spanish.json.js +41 -5
  77. package/dist/lib.cjs/packages/modal/src/ui/i18n/turkish.json.js +41 -5
  78. package/dist/lib.cjs/packages/modal/src/ui/interfaces.js +7 -10
  79. package/dist/lib.cjs/packages/modal/src/ui/loginModal.js +99 -62
  80. package/dist/lib.cjs/packages/modal/src/ui/utils.js +123 -5
  81. package/dist/lib.cjs/packages/modal/src/vue/WalletServicesInnerProvider.js +70 -0
  82. package/dist/lib.cjs/packages/modal/src/vue/Web3AuthProvider.js +38 -78
  83. package/dist/lib.cjs/packages/modal/src/vue/composables/useCheckout.js +34 -0
  84. package/dist/lib.cjs/packages/modal/src/vue/composables/useEnableMFA.js +32 -0
  85. package/dist/lib.cjs/packages/modal/src/vue/composables/useIdentityToken.js +44 -0
  86. package/dist/lib.cjs/packages/modal/src/vue/composables/useManageMFA.js +32 -0
  87. package/dist/lib.cjs/packages/modal/src/vue/composables/useSwap.js +34 -0
  88. package/dist/lib.cjs/packages/modal/src/vue/composables/useSwitchChain.js +32 -0
  89. package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletConnectScanner.js +34 -0
  90. package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletServicesPlugin.js +13 -0
  91. package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletUI.js +34 -0
  92. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3Auth.js +2 -4
  93. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthConnect.js +66 -0
  94. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthDisconnect.js +32 -0
  95. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthInner.js +12 -0
  96. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthUser.js +53 -0
  97. package/dist/lib.cjs/packages/modal/src/vue/index.js +24 -0
  98. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignAndSendTransaction.js +36 -0
  99. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignMessage.js +38 -0
  100. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignTransaction.js +36 -0
  101. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSolanaWallet.js +53 -0
  102. package/dist/lib.cjs/packages/modal/src/vue/solana/index.js +13 -0
  103. package/dist/lib.cjs/packages/modal/src/vue/wagmi/constants.js +16 -0
  104. package/dist/lib.cjs/packages/modal/src/vue/wagmi/index.js +7 -0
  105. package/dist/lib.cjs/packages/modal/src/vue/wagmi/provider.js +233 -0
  106. package/dist/lib.cjs/types/config.d.ts +1 -0
  107. package/dist/lib.cjs/types/interface.d.ts +2 -3
  108. package/dist/lib.cjs/types/modalManager.d.ts +11 -4
  109. package/dist/lib.cjs/types/react/Web3AuthProvider.d.ts +1 -1
  110. package/dist/lib.cjs/types/react/context/WalletServicesInnerContext.d.ts +6 -0
  111. package/dist/lib.cjs/types/react/hooks/index.d.ts +13 -1
  112. package/dist/lib.cjs/types/react/hooks/useCheckout.d.ts +8 -0
  113. package/dist/lib.cjs/types/react/hooks/useEnableMFA.d.ts +7 -0
  114. package/dist/lib.cjs/types/react/hooks/useIdentityToken.d.ts +13 -0
  115. package/dist/lib.cjs/types/react/hooks/useManageMFA.d.ts +7 -0
  116. package/dist/lib.cjs/types/react/hooks/useSwap.d.ts +8 -0
  117. package/dist/lib.cjs/types/react/hooks/useSwitchChain.d.ts +7 -0
  118. package/dist/lib.cjs/types/react/hooks/useWalletConnectScanner.d.ts +8 -0
  119. package/dist/lib.cjs/types/react/hooks/useWalletServicesPlugin.d.ts +2 -0
  120. package/dist/lib.cjs/types/react/hooks/useWalletUI.d.ts +8 -0
  121. package/dist/lib.cjs/types/react/hooks/useWeb3Auth.d.ts +2 -1
  122. package/dist/lib.cjs/types/react/hooks/useWeb3AuthConnect.d.ts +10 -0
  123. package/dist/lib.cjs/types/react/hooks/useWeb3AuthDisconnect.d.ts +9 -0
  124. package/dist/lib.cjs/types/react/hooks/useWeb3AuthInner.d.ts +2 -0
  125. package/dist/lib.cjs/types/react/hooks/useWeb3AuthUser.d.ts +9 -0
  126. package/dist/lib.cjs/types/react/index.d.ts +0 -1
  127. package/dist/lib.cjs/types/react/interfaces.d.ts +7 -2
  128. package/dist/lib.cjs/types/react/solana/hooks/index.d.ts +4 -0
  129. package/dist/lib.cjs/types/react/solana/hooks/useSignAndSendTransaction.d.ts +8 -0
  130. package/dist/lib.cjs/types/react/solana/hooks/useSignMessage.d.ts +8 -0
  131. package/dist/lib.cjs/types/react/solana/hooks/useSignTransaction.d.ts +13 -0
  132. package/dist/lib.cjs/types/react/solana/hooks/useSolanaWallet.d.ts +8 -0
  133. package/dist/lib.cjs/types/react/solana/index.d.ts +1 -0
  134. package/dist/lib.cjs/types/react/wagmi/constants.d.ts +43 -0
  135. package/dist/lib.cjs/types/react/wagmi/index.d.ts +2 -0
  136. package/dist/lib.cjs/types/react/wagmi/interface.d.ts +4 -0
  137. package/dist/lib.cjs/types/react/wagmi/provider.d.ts +3 -0
  138. package/dist/lib.cjs/types/ui/components/BottomSheet/BottomSheet.d.ts +7 -0
  139. package/dist/lib.cjs/types/ui/components/BottomSheet/BottomSheet.type.d.ts +7 -0
  140. package/dist/lib.cjs/types/ui/components/BottomSheet/index.d.ts +2 -0
  141. package/dist/lib.cjs/types/ui/components/Button/Button.d.ts +2 -15
  142. package/dist/lib.cjs/types/ui/components/Button/Button.type.d.ts +12 -0
  143. package/dist/lib.cjs/types/ui/components/Button/ButtonSocial/ButtonSocial.d.ts +3 -0
  144. package/dist/lib.cjs/types/ui/components/Button/ButtonSocial/ButtonSocial.type.d.ts +14 -0
  145. package/dist/lib.cjs/types/ui/components/Button/ButtonSocial/index.d.ts +2 -0
  146. package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/ButtonWallet.d.ts +3 -0
  147. package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/ButtonWallet.type.d.ts +13 -0
  148. package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/index.d.ts +2 -0
  149. package/dist/lib.cjs/types/ui/components/Button/index.d.ts +1 -0
  150. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWallet.d.ts +3 -0
  151. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWallet.type.d.ts +25 -0
  152. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.d.ts +3 -0
  153. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.type.d.ts +13 -0
  154. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainFilter/index.d.ts +2 -0
  155. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.d.ts +3 -0
  156. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.type.d.ts +10 -0
  157. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainNamespaceSelect/index.d.ts +2 -0
  158. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.d.ts +3 -0
  159. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.type.d.ts +6 -0
  160. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletHeader/index.d.ts +2 -0
  161. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.d.ts +3 -0
  162. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.type.d.ts +19 -0
  163. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletList/index.d.ts +2 -0
  164. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.d.ts +3 -0
  165. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.type.d.ts +8 -0
  166. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletQrCode/index.d.ts +2 -0
  167. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.d.ts +3 -0
  168. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.type.d.ts +9 -0
  169. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletSearch/index.d.ts +2 -0
  170. package/dist/lib.cjs/types/ui/components/ConnectWallet/index.d.ts +2 -0
  171. package/dist/lib.cjs/types/ui/components/Embed/Embed.d.ts +8 -0
  172. package/dist/lib.cjs/types/ui/components/Embed/Embed.type.d.ts +12 -0
  173. package/dist/lib.cjs/types/ui/components/Embed/index.d.ts +2 -0
  174. package/dist/lib.cjs/types/ui/components/Footer/Footer.d.ts +7 -0
  175. package/dist/lib.cjs/types/ui/components/Footer/Footer.type.d.ts +4 -0
  176. package/dist/lib.cjs/types/ui/components/Footer/index.d.ts +2 -0
  177. package/dist/lib.cjs/types/ui/components/Image/Image.d.ts +7 -0
  178. package/dist/lib.cjs/types/ui/components/{Image.d.ts → Image/Image.type.d.ts} +2 -1
  179. package/dist/lib.cjs/types/ui/components/Image/index.d.ts +2 -0
  180. package/dist/lib.cjs/types/ui/components/Loader/Loader.d.ts +8 -0
  181. package/dist/lib.cjs/types/ui/components/Loader/Loader.type.d.ts +12 -0
  182. package/dist/lib.cjs/types/ui/components/Loader/index.d.ts +2 -0
  183. package/dist/lib.cjs/types/ui/components/Login/Login.d.ts +3 -0
  184. package/dist/lib.cjs/types/ui/components/Login/Login.type.d.ts +29 -0
  185. package/dist/lib.cjs/types/ui/components/Login/LoginOtp/LoginOtp.d.ts +8 -0
  186. package/dist/lib.cjs/types/ui/components/Login/LoginOtp/LoginOtp.type.d.ts +11 -0
  187. package/dist/lib.cjs/types/ui/components/Login/LoginOtp/index.d.ts +2 -0
  188. package/dist/lib.cjs/types/ui/components/Login/LoginPasswordLess/LoginPasswordLess.d.ts +3 -0
  189. package/dist/lib.cjs/types/ui/components/Login/LoginPasswordLess/LoginPasswordLess.type.d.ts +13 -0
  190. package/dist/lib.cjs/types/ui/components/Login/LoginPasswordLess/index.d.ts +2 -0
  191. package/dist/lib.cjs/types/ui/components/Login/index.d.ts +2 -0
  192. package/dist/lib.cjs/types/ui/components/LoginHint/LoginHint.d.ts +3 -0
  193. package/dist/lib.cjs/types/ui/components/LoginHint/LoginHint.type.d.ts +6 -0
  194. package/dist/lib.cjs/types/ui/components/LoginHint/index.d.ts +2 -0
  195. package/dist/lib.cjs/types/ui/components/Modal/Modal.d.ts +8 -0
  196. package/dist/lib.cjs/types/ui/components/Modal/Modal.type.d.ts +14 -0
  197. package/dist/lib.cjs/types/ui/components/Modal/index.d.ts +2 -0
  198. package/dist/lib.cjs/types/ui/components/Otp/Otp.d.ts +3 -0
  199. package/dist/lib.cjs/types/ui/components/Otp/Otp.type.d.ts +22 -0
  200. package/dist/lib.cjs/types/ui/components/Otp/index.d.ts +2 -0
  201. package/dist/lib.cjs/types/ui/components/PulseLoader/PulseLoader.d.ts +2 -0
  202. package/dist/lib.cjs/types/ui/components/PulseLoader/index.d.ts +1 -0
  203. package/dist/lib.cjs/types/ui/components/Root/Root.d.ts +3 -0
  204. package/dist/lib.cjs/types/ui/components/Root/Root.type.d.ts +27 -0
  205. package/dist/lib.cjs/types/ui/components/Root/index.d.ts +2 -0
  206. package/dist/lib.cjs/types/ui/components/SocialLoginList/SocialLoginList.d.ts +3 -0
  207. package/dist/lib.cjs/types/ui/components/SocialLoginList/SocialLoginList.type.d.ts +11 -0
  208. package/dist/lib.cjs/types/ui/components/SocialLoginList/index.d.ts +2 -0
  209. package/dist/lib.cjs/types/ui/components/Toast/Toast.d.ts +2 -0
  210. package/dist/lib.cjs/types/ui/components/Toast/index.d.ts +1 -0
  211. package/dist/lib.cjs/types/ui/components/Widget/Widget.d.ts +3 -0
  212. package/dist/lib.cjs/types/ui/components/{Modal.d.ts → Widget/Widget.type.d.ts} +4 -5
  213. package/dist/lib.cjs/types/ui/components/Widget/index.d.ts +1 -0
  214. package/dist/lib.cjs/types/ui/config.d.ts +5 -2
  215. package/dist/lib.cjs/types/ui/constants.d.ts +17 -0
  216. package/dist/lib.cjs/types/ui/context/RootContext.d.ts +27 -0
  217. package/dist/lib.cjs/types/ui/handlers/AbstractHandler.d.ts +21 -0
  218. package/dist/lib.cjs/types/ui/handlers/EmailPasswordlessHandler.d.ts +10 -0
  219. package/dist/lib.cjs/types/ui/handlers/SmsPasswordlessHandler.d.ts +9 -0
  220. package/dist/lib.cjs/types/ui/handlers/factory.d.ts +5 -0
  221. package/dist/lib.cjs/types/ui/interfaces.d.ts +127 -18
  222. package/dist/lib.cjs/types/ui/loginModal.d.ts +10 -8
  223. package/dist/lib.cjs/types/ui/utils.d.ts +18 -3
  224. package/dist/lib.cjs/types/vue/WalletServicesInnerProvider.d.ts +1 -0
  225. package/dist/lib.cjs/types/vue/composables/index.d.ts +12 -0
  226. package/dist/lib.cjs/types/vue/composables/useCheckout.d.ts +9 -0
  227. package/dist/lib.cjs/types/vue/composables/useEnableMFA.d.ts +8 -0
  228. package/dist/lib.cjs/types/vue/composables/useIdentityToken.d.ts +9 -0
  229. package/dist/lib.cjs/types/vue/composables/useManageMFA.d.ts +8 -0
  230. package/dist/lib.cjs/types/vue/composables/useSwap.d.ts +9 -0
  231. package/dist/lib.cjs/types/vue/composables/useSwitchChain.d.ts +10 -0
  232. package/dist/lib.cjs/types/vue/composables/useWalletConnectScanner.d.ts +9 -0
  233. package/dist/lib.cjs/types/vue/composables/useWalletServicesPlugin.d.ts +2 -0
  234. package/dist/lib.cjs/types/vue/composables/useWalletUI.d.ts +9 -0
  235. package/dist/lib.cjs/types/vue/composables/useWeb3Auth.d.ts +3 -2
  236. package/dist/lib.cjs/types/vue/composables/useWeb3AuthConnect.d.ts +11 -0
  237. package/dist/lib.cjs/types/vue/composables/useWeb3AuthDisconnect.d.ts +10 -0
  238. package/dist/lib.cjs/types/vue/composables/useWeb3AuthInner.d.ts +2 -0
  239. package/dist/lib.cjs/types/vue/composables/useWeb3AuthUser.d.ts +10 -0
  240. package/dist/lib.cjs/types/vue/interfaces.d.ts +10 -18
  241. package/dist/lib.cjs/types/vue/solana/composables/index.d.ts +4 -0
  242. package/dist/lib.cjs/types/vue/solana/composables/useSignAndSendTransaction.d.ts +9 -0
  243. package/dist/lib.cjs/types/vue/solana/composables/useSignMessage.d.ts +9 -0
  244. package/dist/lib.cjs/types/vue/solana/composables/useSignTransaction.d.ts +9 -0
  245. package/dist/lib.cjs/types/vue/solana/composables/useSolanaWallet.d.ts +9 -0
  246. package/dist/lib.cjs/types/vue/solana/index.d.ts +1 -0
  247. package/dist/lib.cjs/types/vue/wagmi/constants.d.ts +43 -0
  248. package/dist/lib.cjs/types/vue/wagmi/index.d.ts +2 -0
  249. package/dist/lib.cjs/types/vue/wagmi/interface.d.ts +4 -0
  250. package/dist/lib.cjs/types/vue/wagmi/provider.d.ts +17 -0
  251. package/dist/lib.esm/node_modules/style-inject/dist/style-inject.es.js +1 -1
  252. package/dist/lib.esm/packages/modal/src/config.js +3 -4
  253. package/dist/lib.esm/packages/modal/src/index.js +1 -1
  254. package/dist/lib.esm/packages/modal/src/modalManager.js +291 -178
  255. package/dist/lib.esm/packages/modal/src/react/Web3AuthProvider.js +9 -3
  256. package/dist/lib.esm/packages/modal/src/react/context/WalletServicesInnerContext.js +69 -0
  257. package/dist/lib.esm/packages/modal/src/react/context/Web3AuthInnerContext.js +42 -98
  258. package/dist/lib.esm/packages/modal/src/react/hooks/useCheckout.js +32 -0
  259. package/dist/lib.esm/packages/modal/src/react/hooks/useEnableMFA.js +28 -0
  260. package/dist/lib.esm/packages/modal/src/react/hooks/useIdentityToken.js +40 -0
  261. package/dist/lib.esm/packages/modal/src/react/hooks/useManageMFA.js +28 -0
  262. package/dist/lib.esm/packages/modal/src/react/hooks/useSwap.js +32 -0
  263. package/dist/lib.esm/packages/modal/src/react/hooks/useSwitchChain.js +30 -0
  264. package/dist/lib.esm/packages/modal/src/react/hooks/useWalletConnectScanner.js +32 -0
  265. package/dist/lib.esm/packages/modal/src/react/hooks/useWalletServicesPlugin.js +11 -0
  266. package/dist/lib.esm/packages/modal/src/react/hooks/useWalletUI.js +32 -0
  267. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3Auth.js +21 -8
  268. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthConnect.js +61 -0
  269. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthDisconnect.js +28 -0
  270. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthInner.js +13 -0
  271. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthUser.js +48 -0
  272. package/dist/lib.esm/packages/modal/src/react/index.js +12 -1
  273. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignAndSendTransaction.js +34 -0
  274. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignMessage.js +35 -0
  275. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignTransaction.js +34 -0
  276. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSolanaWallet.js +41 -0
  277. package/dist/lib.esm/packages/modal/src/react/solana/index.js +4 -0
  278. package/dist/lib.esm/packages/modal/src/react/wagmi/constants.js +14 -0
  279. package/dist/lib.esm/packages/modal/src/react/wagmi/index.js +1 -0
  280. package/dist/lib.esm/packages/modal/src/react/wagmi/provider.js +194 -0
  281. package/dist/lib.esm/packages/modal/src/ui/components/BottomSheet/BottomSheet.js +58 -0
  282. package/dist/lib.esm/packages/modal/src/ui/components/Button/Button.js +48 -24
  283. package/dist/lib.esm/packages/modal/src/ui/components/Button/Button.type.js +6 -0
  284. package/dist/lib.esm/packages/modal/src/ui/components/Button/ButtonSocial/ButtonSocial.js +51 -0
  285. package/dist/lib.esm/packages/modal/src/ui/components/Button/ButtonWallet/ButtonWallet.js +74 -0
  286. package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWallet.js +206 -0
  287. package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.js +63 -0
  288. package/dist/lib.esm/packages/modal/src/ui/components/{ExternalWallet/ExternalWalletChainNamespace.js → ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js} +29 -31
  289. package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.js +47 -0
  290. package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.js +146 -0
  291. package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.js +97 -0
  292. package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.js +56 -0
  293. package/dist/lib.esm/packages/modal/src/ui/components/Embed/Embed.js +68 -0
  294. package/dist/lib.esm/packages/modal/src/ui/components/Footer/Footer.js +48 -0
  295. package/dist/lib.esm/packages/modal/src/ui/components/Image/Image.js +88 -0
  296. package/dist/lib.esm/packages/modal/src/ui/components/Loader/Loader.js +152 -0
  297. package/dist/lib.esm/packages/modal/src/ui/components/Login/Login.js +531 -0
  298. package/dist/lib.esm/packages/modal/src/ui/components/Login/LoginOtp/LoginOtp.js +118 -0
  299. package/dist/lib.esm/packages/modal/src/ui/components/Login/LoginPasswordLess/LoginPasswordLess.js +120 -0
  300. package/dist/lib.esm/packages/modal/src/ui/components/LoginHint/LoginHint.js +50 -0
  301. package/dist/lib.esm/packages/modal/src/ui/components/Modal/Modal.js +85 -0
  302. package/dist/lib.esm/packages/modal/src/ui/components/Otp/Otp.js +188 -0
  303. package/dist/lib.esm/packages/modal/src/ui/components/PulseLoader/PulseLoader.js +16 -0
  304. package/dist/lib.esm/packages/modal/src/ui/components/Root/Root.js +520 -0
  305. package/dist/lib.esm/packages/modal/src/ui/components/SocialLoginList/SocialLoginList.js +135 -0
  306. package/dist/lib.esm/packages/modal/src/ui/components/Toast/Toast.js +68 -0
  307. package/dist/lib.esm/packages/modal/src/ui/components/Widget/Widget.js +245 -0
  308. package/dist/lib.esm/packages/modal/src/ui/config.js +11 -3
  309. package/dist/lib.esm/packages/modal/src/ui/constants.js +40 -0
  310. package/dist/lib.esm/packages/modal/src/ui/context/RootContext.js +27 -0
  311. package/dist/lib.esm/packages/modal/src/ui/css/index.css.js +6 -0
  312. package/dist/lib.esm/packages/modal/src/ui/handlers/AbstractHandler.js +119 -0
  313. package/dist/lib.esm/packages/modal/src/ui/handlers/EmailPasswordlessHandler.js +55 -0
  314. package/dist/lib.esm/packages/modal/src/ui/handlers/SmsPasswordlessHandler.js +55 -0
  315. package/dist/lib.esm/packages/modal/src/ui/handlers/factory.js +17 -0
  316. package/dist/lib.esm/packages/modal/src/ui/i18n/dutch.json.js +41 -6
  317. package/dist/lib.esm/packages/modal/src/ui/i18n/english.json.js +41 -6
  318. package/dist/lib.esm/packages/modal/src/ui/i18n/french.json.js +41 -6
  319. package/dist/lib.esm/packages/modal/src/ui/i18n/german.json.js +41 -6
  320. package/dist/lib.esm/packages/modal/src/ui/i18n/japanese.json.js +41 -6
  321. package/dist/lib.esm/packages/modal/src/ui/i18n/korean.json.js +41 -6
  322. package/dist/lib.esm/packages/modal/src/ui/i18n/mandarin.json.js +41 -6
  323. package/dist/lib.esm/packages/modal/src/ui/i18n/portuguese.json.js +41 -6
  324. package/dist/lib.esm/packages/modal/src/ui/i18n/spanish.json.js +41 -6
  325. package/dist/lib.esm/packages/modal/src/ui/i18n/turkish.json.js +41 -6
  326. package/dist/lib.esm/packages/modal/src/ui/interfaces.js +8 -9
  327. package/dist/lib.esm/packages/modal/src/ui/loginModal.js +100 -63
  328. package/dist/lib.esm/packages/modal/src/ui/utils.js +121 -7
  329. package/dist/lib.esm/packages/modal/src/vue/WalletServicesInnerProvider.js +69 -0
  330. package/dist/lib.esm/packages/modal/src/vue/Web3AuthProvider.js +40 -79
  331. package/dist/lib.esm/packages/modal/src/vue/composables/useCheckout.js +32 -0
  332. package/dist/lib.esm/packages/modal/src/vue/composables/useEnableMFA.js +30 -0
  333. package/dist/lib.esm/packages/modal/src/vue/composables/useIdentityToken.js +42 -0
  334. package/dist/lib.esm/packages/modal/src/vue/composables/useManageMFA.js +30 -0
  335. package/dist/lib.esm/packages/modal/src/vue/composables/useSwap.js +32 -0
  336. package/dist/lib.esm/packages/modal/src/vue/composables/useSwitchChain.js +30 -0
  337. package/dist/lib.esm/packages/modal/src/vue/composables/useWalletConnectScanner.js +32 -0
  338. package/dist/lib.esm/packages/modal/src/vue/composables/useWalletServicesPlugin.js +11 -0
  339. package/dist/lib.esm/packages/modal/src/vue/composables/useWalletUI.js +32 -0
  340. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3Auth.js +2 -4
  341. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthConnect.js +64 -0
  342. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthDisconnect.js +30 -0
  343. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthInner.js +10 -0
  344. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthUser.js +51 -0
  345. package/dist/lib.esm/packages/modal/src/vue/index.js +12 -0
  346. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignAndSendTransaction.js +34 -0
  347. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignMessage.js +36 -0
  348. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignTransaction.js +34 -0
  349. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSolanaWallet.js +51 -0
  350. package/dist/lib.esm/packages/modal/src/vue/solana/index.js +4 -0
  351. package/dist/lib.esm/packages/modal/src/vue/wagmi/constants.js +14 -0
  352. package/dist/lib.esm/packages/modal/src/vue/wagmi/index.js +1 -0
  353. package/dist/lib.esm/packages/modal/src/vue/wagmi/provider.js +234 -0
  354. package/dist/modal.umd.min.js +1 -1
  355. package/dist/modal.umd.min.js.LICENSE.txt +8 -34
  356. package/package.json +70 -19
  357. package/dist/lib.cjs/packages/modal/src/ui/assets/arrow-left-dark.svg.js +0 -7
  358. package/dist/lib.cjs/packages/modal/src/ui/assets/arrow-left-light.svg.js +0 -7
  359. package/dist/lib.cjs/packages/modal/src/ui/assets/x-dark.svg.js +0 -7
  360. package/dist/lib.cjs/packages/modal/src/ui/assets/x-light.svg.js +0 -7
  361. package/dist/lib.cjs/packages/modal/src/ui/components/AdapterLoader.js +0 -108
  362. package/dist/lib.cjs/packages/modal/src/ui/components/Button/styles.css.js +0 -8
  363. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletButton.js +0 -44
  364. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletConnect.js +0 -67
  365. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletDetails.js +0 -43
  366. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletHeader.js +0 -46
  367. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletInstall.js +0 -167
  368. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallets.js +0 -279
  369. package/dist/lib.cjs/packages/modal/src/ui/components/Footer.js +0 -20
  370. package/dist/lib.cjs/packages/modal/src/ui/components/Header.js +0 -81
  371. package/dist/lib.cjs/packages/modal/src/ui/components/Icon.js +0 -73
  372. package/dist/lib.cjs/packages/modal/src/ui/components/Image.js +0 -51
  373. package/dist/lib.cjs/packages/modal/src/ui/components/Loader.js +0 -59
  374. package/dist/lib.cjs/packages/modal/src/ui/components/Modal.js +0 -278
  375. package/dist/lib.cjs/packages/modal/src/ui/components/SelfCustodyViaWeb3Auth.js +0 -30
  376. package/dist/lib.cjs/packages/modal/src/ui/components/SocialLoginPasswordless.js +0 -150
  377. package/dist/lib.cjs/packages/modal/src/ui/components/SocialLogins.js +0 -153
  378. package/dist/lib.cjs/packages/modal/src/ui/components/WalletConnect.js +0 -84
  379. package/dist/lib.cjs/packages/modal/src/ui/css/web3auth.css.js +0 -8
  380. package/dist/lib.cjs/types/react/context/index.d.ts +0 -1
  381. package/dist/lib.cjs/types/ui/components/AdapterLoader.d.ts +0 -11
  382. package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletButton.d.ts +0 -7
  383. package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletChainNamespace.d.ts +0 -9
  384. package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletConnect.d.ts +0 -9
  385. package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletDetails.d.ts +0 -10
  386. package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletHeader.d.ts +0 -8
  387. package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletInstall.d.ts +0 -8
  388. package/dist/lib.cjs/types/ui/components/ExternalWallets.d.ts +0 -15
  389. package/dist/lib.cjs/types/ui/components/Footer.d.ts +0 -1
  390. package/dist/lib.cjs/types/ui/components/Header.d.ts +0 -8
  391. package/dist/lib.cjs/types/ui/components/Icon.d.ts +0 -9
  392. package/dist/lib.cjs/types/ui/components/Loader.d.ts +0 -10
  393. package/dist/lib.cjs/types/ui/components/SelfCustodyViaWeb3Auth.d.ts +0 -1
  394. package/dist/lib.cjs/types/ui/components/SocialLoginPasswordless.d.ts +0 -14
  395. package/dist/lib.cjs/types/ui/components/SocialLogins.d.ts +0 -10
  396. package/dist/lib.cjs/types/ui/components/WalletConnect.d.ts +0 -8
  397. package/dist/lib.esm/packages/modal/src/ui/assets/arrow-left-dark.svg.js +0 -5
  398. package/dist/lib.esm/packages/modal/src/ui/assets/arrow-left-light.svg.js +0 -5
  399. package/dist/lib.esm/packages/modal/src/ui/assets/x-dark.svg.js +0 -5
  400. package/dist/lib.esm/packages/modal/src/ui/assets/x-light.svg.js +0 -5
  401. package/dist/lib.esm/packages/modal/src/ui/components/AdapterLoader.js +0 -106
  402. package/dist/lib.esm/packages/modal/src/ui/components/Button/styles.css.js +0 -6
  403. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletButton.js +0 -42
  404. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletConnect.js +0 -65
  405. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletDetails.js +0 -44
  406. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletHeader.js +0 -44
  407. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletInstall.js +0 -165
  408. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallets.js +0 -281
  409. package/dist/lib.esm/packages/modal/src/ui/components/Footer.js +0 -18
  410. package/dist/lib.esm/packages/modal/src/ui/components/Header.js +0 -79
  411. package/dist/lib.esm/packages/modal/src/ui/components/Icon.js +0 -71
  412. package/dist/lib.esm/packages/modal/src/ui/components/Image.js +0 -49
  413. package/dist/lib.esm/packages/modal/src/ui/components/Loader.js +0 -57
  414. package/dist/lib.esm/packages/modal/src/ui/components/Modal.js +0 -277
  415. package/dist/lib.esm/packages/modal/src/ui/components/SelfCustodyViaWeb3Auth.js +0 -28
  416. package/dist/lib.esm/packages/modal/src/ui/components/SocialLoginPasswordless.js +0 -148
  417. package/dist/lib.esm/packages/modal/src/ui/components/SocialLogins.js +0 -152
  418. package/dist/lib.esm/packages/modal/src/ui/components/WalletConnect.js +0 -82
  419. package/dist/lib.esm/packages/modal/src/ui/css/web3auth.css.js +0 -6
@@ -0,0 +1,74 @@
1
+ import cn from 'classnames';
2
+ import { useContext, useMemo } from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import { ThemedContext } from '../../../context/ThemeContext.js';
5
+ import i18nInstance from '../../../localeImport.js';
6
+ import { formatIOSMobile, getIcons } from '../../../utils.js';
7
+ import Image from '../../Image/Image.js';
8
+ import { jsxs, jsx } from 'react/jsx-runtime';
9
+
10
+ function ButtonWallet(props) {
11
+ const [t] = useTranslation(undefined, {
12
+ i18n: i18nInstance
13
+ });
14
+ const {
15
+ deviceDetails,
16
+ button,
17
+ walletConnectUri,
18
+ onClick,
19
+ label,
20
+ buttonRadius
21
+ } = props;
22
+ const isDark = useContext(ThemedContext);
23
+ const isLink = useMemo(() => deviceDetails.platform !== "desktop" && button.href && button.hasWalletConnect && !button.hasInjectedWallet, [deviceDetails, button]);
24
+ const href = useMemo(() => button.href ? formatIOSMobile({
25
+ uri: walletConnectUri,
26
+ link: button.href
27
+ }) : walletConnectUri, [button, walletConnectUri]);
28
+ const handleBtnClick = () => {
29
+ if (href && isLink) {
30
+ window.open(href, "_blank");
31
+ } else if (onClick) {
32
+ onClick();
33
+ }
34
+ };
35
+ return /*#__PURE__*/jsxs("button", {
36
+ type: "button",
37
+ className: cn(`w3a--group w3a--relative w3a--overflow-hidden w3a--flex w3a--w-full w3a--items-center w3a--justify-between w3a--bg-app-gray-50 w3a--p-3 hover:w3a--bg-app-gray-200
38
+ hover:w3a--text-app-gray-900 dark:w3a--bg-app-gray-800 dark:hover:w3a--bg-app-gray-600 active:w3a--scale-95 w3a--transition-all w3a--duration-150`, {
39
+ "w3a--rounded-full": buttonRadius === "pill",
40
+ "w3a--rounded-lg": buttonRadius === "rounded",
41
+ "w3a--rounded-none": buttonRadius === "square"
42
+ }),
43
+ onClick: handleBtnClick,
44
+ children: [/*#__PURE__*/jsxs("div", {
45
+ className: "w3a--flex w3a--items-center w3a--gap-x-2",
46
+ children: [/*#__PURE__*/jsx("figure", {
47
+ className: "w3a--size-5",
48
+ children: /*#__PURE__*/jsx(Image, {
49
+ imageData: button.icon,
50
+ imageId: `login-${button.name}`,
51
+ hoverImageId: `login-${button.name}`,
52
+ fallbackImageId: "wallet",
53
+ height: "24",
54
+ width: "24",
55
+ isButton: true,
56
+ extension: button.imgExtension || "webp"
57
+ })
58
+ }), /*#__PURE__*/jsx("p", {
59
+ className: "w3a--max-w-[180px] w3a--truncate w3a--text-base w3a--font-normal w3a--text-app-gray-700 dark:w3a--text-app-white",
60
+ children: label
61
+ })]
62
+ }), button.hasInjectedWallet && /*#__PURE__*/jsx("span", {
63
+ className: "w3a--absolute w3a--right-4 w3a--top-1/2 w3a--flex w3a--w-auto -w3a--translate-y-1/2 w3a--items-center w3a--rounded-md w3a--bg-app-primary-100 w3a--px-2 w3a--py-1 w3a--text-xs w3a--font-medium w3a--text-app-primary-800 w3a--transition-all w3a--duration-300 group-hover:w3a--translate-x-6 group-hover:w3a--opacity-0 dark:w3a--border dark:w3a--border-app-primary-400 dark:w3a--bg-transparent dark:w3a--text-app-primary-400",
64
+ children: t("modal.external.installed")
65
+ }), /*#__PURE__*/jsx("img", {
66
+ id: "injected-wallet-arrow",
67
+ className: "w3a--absolute w3a--right-4 w3a--top-1/2 -w3a--translate-x-10 -w3a--translate-y-1/2 w3a--opacity-0 w3a--transition-all w3a--duration-300 group-hover:w3a--translate-x-0 group-hover:w3a--opacity-100",
68
+ src: getIcons(isDark ? "chevron-right-light" : "chevron-right-dark"),
69
+ alt: "arrow"
70
+ })]
71
+ });
72
+ }
73
+
74
+ export { ButtonWallet as default };
@@ -0,0 +1,206 @@
1
+ import _objectSpread from '@babel/runtime/helpers/objectSpread2';
2
+ import { WALLET_CONNECTORS } from '@web3auth/no-modal';
3
+ import { useContext, useState, useMemo } from 'react';
4
+ import { CONNECT_WALLET_PAGES } from '../../constants.js';
5
+ import { RootContext } from '../../context/RootContext.js';
6
+ import ConnectWalletChainFilter from './ConnectWalletChainFilter/ConnectWalletChainFilter.js';
7
+ import ConnectWalletHeader from './ConnectWalletHeader/ConnectWalletHeader.js';
8
+ import ConnectWalletList from './ConnectWalletList/ConnectWalletList.js';
9
+ import ConnectWalletQrCode from './ConnectWalletQrCode/ConnectWalletQrCode.js';
10
+ import ConnectWalletSearch from './ConnectWalletSearch/ConnectWalletSearch.js';
11
+ import { jsxs, jsx } from 'react/jsx-runtime';
12
+
13
+ function ConnectWallet(props) {
14
+ var _selectedButton$walle;
15
+ const {
16
+ isDark,
17
+ config,
18
+ walletConnectUri,
19
+ metamaskConnectUri,
20
+ walletRegistry,
21
+ allExternalButtons,
22
+ customConnectorButtons,
23
+ connectorVisibilityMap,
24
+ deviceDetails,
25
+ buttonRadius = "pill",
26
+ chainNamespace,
27
+ onBackClick,
28
+ handleExternalWalletClick,
29
+ handleWalletDetailsHeight
30
+ } = props;
31
+ const {
32
+ bodyState,
33
+ setBodyState
34
+ } = useContext(RootContext);
35
+ const [currentPage, setCurrentPage] = useState(CONNECT_WALLET_PAGES.CONNECT_WALLET);
36
+ const [selectedWallet, setSelectedWallet] = useState(false);
37
+ const [isLoading] = useState(false);
38
+ const [selectedButton, setSelectedButton] = useState(null);
39
+ const [walletSearch, setWalletSearch] = useState("");
40
+ const [selectedChain, setSelectedChain] = useState("all");
41
+ const [isShowAllWallets, setIsShowAllWallets] = useState(false);
42
+ const handleBack = () => {
43
+ if (!selectedWallet && currentPage === CONNECT_WALLET_PAGES.CONNECT_WALLET && onBackClick) {
44
+ onBackClick(false);
45
+ return;
46
+ }
47
+ if (selectedWallet) {
48
+ setCurrentPage(CONNECT_WALLET_PAGES.CONNECT_WALLET);
49
+ setSelectedWallet(false);
50
+ handleWalletDetailsHeight();
51
+ }
52
+ };
53
+ const walletDiscoverySupported = useMemo(() => {
54
+ const supported = walletRegistry && Object.keys(walletRegistry.default || {}).length > 0 && Object.keys(walletRegistry.others || {}).length > 0;
55
+ return supported;
56
+ }, [walletRegistry]);
57
+ const allUniqueButtons = useMemo(() => {
58
+ const uniqueButtonSet = new Set();
59
+ return customConnectorButtons.concat(allExternalButtons).filter(button => {
60
+ if (uniqueButtonSet.has(button.name)) return false;
61
+ uniqueButtonSet.add(button.name);
62
+ return true;
63
+ });
64
+ }, [allExternalButtons, customConnectorButtons]);
65
+ const defaultButtonKeys = useMemo(() => new Set(Object.keys(walletRegistry.default)), [walletRegistry]);
66
+ const defaultButtons = useMemo(() => {
67
+ // display order: default injected buttons > custom adapter buttons > default non-injected buttons
68
+ const buttons = [...allExternalButtons.filter(button => button.hasInjectedWallet && defaultButtonKeys.has(button.name)), ...customConnectorButtons, ...allExternalButtons.filter(button => !button.hasInjectedWallet && defaultButtonKeys.has(button.name))].sort((a, _) => a.name === WALLET_CONNECTORS.METAMASK ? -1 : 1);
69
+ const buttonSet = new Set();
70
+ return buttons.filter(button => {
71
+ if (buttonSet.has(button.name)) return false;
72
+ buttonSet.add(button.name);
73
+ return true;
74
+ }).filter(button => {
75
+ var _button$chainNamespac;
76
+ return selectedChain === "all" || ((_button$chainNamespac = button.chainNamespaces) === null || _button$chainNamespac === void 0 ? void 0 : _button$chainNamespac.includes(selectedChain));
77
+ });
78
+ }, [allExternalButtons, customConnectorButtons, defaultButtonKeys, selectedChain]);
79
+ const installedWalletButtons = useMemo(() => {
80
+ const visibilityMap = connectorVisibilityMap;
81
+ return Object.keys(config).reduce((acc, localConnector) => {
82
+ if (localConnector !== WALLET_CONNECTORS.WALLET_CONNECT_V2 && visibilityMap[localConnector]) {
83
+ acc.push({
84
+ name: localConnector,
85
+ displayName: config[localConnector].label || localConnector,
86
+ hasInjectedWallet: config[localConnector].isInjected,
87
+ hasWalletConnect: false,
88
+ hasInstallLinks: false
89
+ });
90
+ }
91
+ return acc;
92
+ }, []);
93
+ }, [connectorVisibilityMap, config]);
94
+ const handleWalletSearch = e => {
95
+ const searchValue = e.target.value;
96
+ setWalletSearch(searchValue);
97
+ };
98
+ const handleChainFilterChange = chain => {
99
+ setSelectedChain(chain);
100
+ setIsShowAllWallets(false);
101
+ };
102
+ const filteredButtons = useMemo(() => {
103
+ if (walletDiscoverySupported) {
104
+ return [...allUniqueButtons.filter(button => button.hasInjectedWallet), ...allUniqueButtons.filter(button => !button.hasInjectedWallet)].sort((a, _) => a.name === WALLET_CONNECTORS.METAMASK ? -1 : 1).filter(button => selectedChain === "all" || button.chainNamespaces.includes(selectedChain)).filter(button => button.name.toLowerCase().includes(walletSearch.toLowerCase()));
105
+ }
106
+ return installedWalletButtons;
107
+ }, [walletDiscoverySupported, installedWalletButtons, walletSearch, allUniqueButtons, selectedChain]);
108
+ const externalButtons = useMemo(() => {
109
+ if (walletDiscoverySupported && !walletSearch && !isShowAllWallets) {
110
+ return defaultButtons;
111
+ }
112
+ return filteredButtons;
113
+ }, [walletDiscoverySupported, walletSearch, filteredButtons, defaultButtons, isShowAllWallets]);
114
+ const totalExternalWalletsCount = useMemo(() => filteredButtons.length, [filteredButtons]);
115
+ const initialWalletCount = useMemo(() => {
116
+ if (isShowAllWallets) return totalExternalWalletsCount;
117
+ return walletDiscoverySupported ? defaultButtons.length : installedWalletButtons.length;
118
+ }, [walletDiscoverySupported, defaultButtons, installedWalletButtons, isShowAllWallets, totalExternalWalletsCount]);
119
+ const handleWalletClick = button => {
120
+ var _button$chainNamespac2, _button$chainNamespac3;
121
+ // show chain namespace selector if the button is an injected connector with multiple chain namespaces
122
+ const isChainNamespaceSelectorRequired = button.hasInjectedWallet && ((_button$chainNamespac2 = button.chainNamespaces) === null || _button$chainNamespac2 === void 0 ? void 0 : _button$chainNamespac2.length) > 1;
123
+ if (isChainNamespaceSelectorRequired) {
124
+ setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
125
+ multiChainSelector: {
126
+ show: true,
127
+ wallet: button
128
+ }
129
+ }));
130
+ return;
131
+ }
132
+ const isInjectedConnectorAndSingleChainNamespace = button.hasInjectedWallet && ((_button$chainNamespac3 = button.chainNamespaces) === null || _button$chainNamespac3 === void 0 ? void 0 : _button$chainNamespac3.length) === 1;
133
+ // if doesn't have wallet connect & doesn't have install links, must be a custom connector
134
+ const isCustomConnector = !button.hasInjectedWallet && !button.hasWalletConnect && !button.hasInstallLinks;
135
+ if (isInjectedConnectorAndSingleChainNamespace || isCustomConnector) {
136
+ return handleExternalWalletClick({
137
+ connector: button.name
138
+ });
139
+ }
140
+ if (button.hasWalletConnect || !isInjectedConnectorAndSingleChainNamespace) {
141
+ setSelectedButton(button);
142
+ setSelectedWallet(true);
143
+ setCurrentPage(CONNECT_WALLET_PAGES.SELECTED_WALLET);
144
+ handleWalletDetailsHeight();
145
+ } else {
146
+ setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
147
+ installLinks: {
148
+ show: true,
149
+ wallet: button
150
+ }
151
+ }));
152
+ }
153
+ };
154
+ const handleMoreWallets = () => {
155
+ setIsShowAllWallets(true);
156
+ };
157
+ const qrCodeValue = useMemo(() => {
158
+ if (!selectedWallet) return null;
159
+ if (selectedButton.name === WALLET_CONNECTORS.METAMASK && !selectedButton.hasInjectedWallet) {
160
+ return metamaskConnectUri;
161
+ }
162
+ return walletConnectUri;
163
+ }, [metamaskConnectUri, selectedButton, selectedWallet, walletConnectUri]);
164
+ return /*#__PURE__*/jsxs("div", {
165
+ className: "w3a--relative w3a--flex w3a--flex-1 w3a--flex-col w3a--gap-y-4",
166
+ children: [/*#__PURE__*/jsx(ConnectWalletHeader, {
167
+ onBackClick: handleBack,
168
+ currentPage: currentPage,
169
+ selectedButton: selectedButton
170
+ }), selectedWallet ? /*#__PURE__*/jsx(ConnectWalletQrCode, {
171
+ qrCodeValue: qrCodeValue,
172
+ isDark: isDark,
173
+ selectedButton: selectedButton,
174
+ primaryColor: (_selectedButton$walle = selectedButton.walletRegistryItem) === null || _selectedButton$walle === void 0 ? void 0 : _selectedButton$walle.primaryColor,
175
+ logoImage: `https://images.web3auth.io/login-${selectedButton.name}.${selectedButton.imgExtension}`
176
+ }) : /*#__PURE__*/jsxs("div", {
177
+ className: "w3a--flex w3a--flex-col w3a--gap-y-2",
178
+ children: [/*#__PURE__*/jsx(ConnectWalletChainFilter, {
179
+ isDark: isDark,
180
+ isLoading: isLoading,
181
+ selectedChain: selectedChain,
182
+ setSelectedChain: handleChainFilterChange,
183
+ chainNamespace: chainNamespace
184
+ }), /*#__PURE__*/jsx(ConnectWalletSearch, {
185
+ totalExternalWalletCount: totalExternalWalletsCount,
186
+ isLoading: isLoading,
187
+ walletSearch: walletSearch,
188
+ handleWalletSearch: handleWalletSearch,
189
+ buttonRadius: buttonRadius
190
+ }), /*#__PURE__*/jsx(ConnectWalletList, {
191
+ externalButtons: externalButtons,
192
+ isLoading: isLoading,
193
+ totalExternalWalletsCount: totalExternalWalletsCount,
194
+ initialWalletCount: initialWalletCount,
195
+ handleWalletClick: handleWalletClick,
196
+ handleMoreWallets: handleMoreWallets,
197
+ isDark: isDark,
198
+ deviceDetails: deviceDetails,
199
+ walletConnectUri: walletConnectUri,
200
+ buttonRadius: buttonRadius
201
+ })]
202
+ })]
203
+ });
204
+ }
205
+
206
+ export { ConnectWallet as default };
@@ -0,0 +1,63 @@
1
+ import { useMemo } from 'react';
2
+ import { useTranslation } from 'react-i18next';
3
+ import i18nInstance from '../../../localeImport.js';
4
+ import { cn, getIcons } from '../../../utils.js';
5
+ import { jsx, jsxs } from 'react/jsx-runtime';
6
+
7
+ function ConnectWalletChainFilter(props) {
8
+ const {
9
+ isDark,
10
+ isLoading,
11
+ selectedChain,
12
+ setSelectedChain,
13
+ chainNamespace
14
+ } = props;
15
+ const [t] = useTranslation(undefined, {
16
+ i18n: i18nInstance
17
+ });
18
+ const chains = useMemo(() => {
19
+ const chains = [{
20
+ id: "all",
21
+ name: "modal.allChains",
22
+ icon: ""
23
+ }];
24
+ for (const chain of chainNamespace) {
25
+ chains.push({
26
+ id: chain,
27
+ name: chain === "eip155" ? "EVM" : chain,
28
+ icon: chain === "eip155" ? "ethereum" : chain
29
+ });
30
+ }
31
+ return chains;
32
+ }, [chainNamespace]);
33
+ if (isLoading) {
34
+ return /*#__PURE__*/jsx("div", {
35
+ className: "w3a--flex w3a--items-center w3a--justify-between w3a--gap-x-2",
36
+ children: Array.from({
37
+ length: chains.length
38
+ }).map((_, index) => /*#__PURE__*/jsx("div", {
39
+ className: "w3a--h-12 w3a--w-[100px] w3a--animate-pulse w3a--rounded-2xl w3a--bg-app-gray-200 dark:w3a--bg-app-gray-700"
40
+ }, `chain-loader-${index}`))
41
+ });
42
+ }
43
+ return /*#__PURE__*/jsx("div", {
44
+ className: "w3a--flex w3a--items-center w3a--justify-items-start w3a--gap-x-4",
45
+ children: chains.map(chain => /*#__PURE__*/jsxs("button", {
46
+ type: "button",
47
+ className: cn("w3a--flex w3a--w-[104px] w3a--items-center w3a--justify-center w3a--gap-x-1 w3a--text-xs w3a--font-medium w3a--px-4 w3a--py-3 w3a--text-app-gray-500 dark:w3a--text-app-gray-300 hover:w3a--bg-app-gray-200 dark:hover:w3a--bg-app-gray-700 w3a--h-12 w3a--rounded-2xl w3a--border w3a--border-transparent", {
48
+ "w3a--bg-app-gray-100 dark:w3a--bg-app-gray-800 w3a--border-app-gray-200 dark:w3a--border-app-gray-700 w3a--text-app-gray-900 dark:w3a--text-app-white hover:!w3a--bg-app-gray-100 dark:hover:!w3a--bg-app-gray-800": selectedChain === chain.id
49
+ }),
50
+ onClick: () => setSelectedChain(chain.id),
51
+ children: [chain.icon && /*#__PURE__*/jsx("img", {
52
+ src: getIcons(isDark ? `${chain.icon}-dark` : `${chain.icon}-light`),
53
+ alt: chain.name,
54
+ className: "w3a--size-5 w3a--object-contain"
55
+ }), /*#__PURE__*/jsx("span", {
56
+ className: "first-letter:w3a--capitalize",
57
+ children: t(chain.name)
58
+ })]
59
+ }, chain.id))
60
+ });
61
+ }
62
+
63
+ export { ConnectWalletChainFilter as default };
@@ -1,23 +1,19 @@
1
1
  import { useTranslation } from 'react-i18next';
2
- import i18nInstance from '../../localeImport.js';
3
- import Button from '../Button/Button.js';
4
- import Image from '../Image.js';
5
- import ExternalWalletHeader from './ExternalWalletHeader.js';
2
+ import i18nInstance from '../../../localeImport.js';
3
+ import { getIcons } from '../../../utils.js';
4
+ import Image from '../../Image/Image.js';
6
5
  import { jsxs, jsx } from 'react/jsx-runtime';
7
6
 
8
- function ExternalWalletChainNamespace(props) {
7
+ const ConnectWalletChainNamespaceSelect = props => {
9
8
  const {
10
- button,
11
- goBack,
12
- closeModal,
9
+ isDark,
10
+ wallet,
13
11
  handleExternalWalletClick
14
12
  } = props;
15
13
  const [t] = useTranslation(undefined, {
16
14
  i18n: i18nInstance
17
15
  });
18
-
19
- // chainNames should be available when selecting a chain namespace
20
- const chainNamespaces = button.chainNamespaces.map(chainNamespace => {
16
+ const chainNamespaces = wallet.chainNamespaces.map(chainNamespace => {
21
17
  const imageId = chainNamespace === "eip155" ? "evm" : chainNamespace;
22
18
  const displayName = chainNamespace === "eip155" ? "EVM" : chainNamespace;
23
19
  return {
@@ -27,25 +23,27 @@ function ExternalWalletChainNamespace(props) {
27
23
  };
28
24
  });
29
25
  return /*#__PURE__*/jsxs("div", {
30
- children: [/*#__PURE__*/jsx(ExternalWalletHeader, {
31
- title: `${t("modal.external.select-chain")}`,
32
- goBack: goBack,
33
- closeModal: closeModal
26
+ children: [/*#__PURE__*/jsx("div", {
27
+ className: "w3a--flex w3a--items-center w3a--justify-center",
28
+ children: /*#__PURE__*/jsx("p", {
29
+ className: "w3a--text-base w3a--font-medium w3a--text-app-gray-900 dark:w3a--text-app-white",
30
+ children: t("modal.external.select-chain")
31
+ })
34
32
  }), /*#__PURE__*/jsx("div", {
35
- className: "w3a--flex w3a--justify-center w3a--my-6",
33
+ className: "w3a--my-6 w3a--flex w3a--justify-center",
36
34
  children: /*#__PURE__*/jsx(Image, {
37
- imageId: `login-${button.name}`,
38
- hoverImageId: `login-${button.name}`,
35
+ imageId: `login-${wallet.name}`,
36
+ hoverImageId: `login-${wallet.name}`,
39
37
  fallbackImageId: "wallet",
40
38
  height: "100",
41
39
  width: "100",
42
40
  isButton: true,
43
- extension: button.imgExtension
41
+ extension: wallet.imgExtension
44
42
  })
45
43
  }), /*#__PURE__*/jsx("p", {
46
- className: "w3a--text-center w3a--text-sm w3a--text-app-gray-500 w3a--my-6",
44
+ className: "w3a--my-6 w3a--text-center w3a--text-sm w3a--text-app-gray-500",
47
45
  children: t("modal.external.select-chain-description", {
48
- wallet: button.displayName
46
+ wallet: wallet.displayName
49
47
  })
50
48
  }), /*#__PURE__*/jsx("ul", {
51
49
  className: "w3a--flex w3a--flex-col w3a--gap-3",
@@ -54,15 +52,13 @@ function ExternalWalletChainNamespace(props) {
54
52
  displayName,
55
53
  imageId
56
54
  }) => /*#__PURE__*/jsx("li", {
57
- children: /*#__PURE__*/jsxs(Button, {
58
- variant: "tertiary",
55
+ children: /*#__PURE__*/jsxs("button", {
59
56
  type: "button",
57
+ className: "w3a--btn w3a--group w3a--relative w3a--h-11 w3a--w-full w3a--items-center !w3a--justify-between w3a--overflow-hidden w3a--rounded-full",
60
58
  onClick: () => handleExternalWalletClick({
61
- connector: button.name,
59
+ connector: wallet.name,
62
60
  chainNamespace
63
61
  }),
64
- className: "w3a--w-full w3a--size-xl !w3a--justify-between w3a--items-center wallet-btn",
65
- title: displayName,
66
62
  children: [/*#__PURE__*/jsxs("div", {
67
63
  className: "w3a--flex w3a--items-center",
68
64
  children: [/*#__PURE__*/jsx(Image, {
@@ -77,14 +73,16 @@ function ExternalWalletChainNamespace(props) {
77
73
  className: "w3a--ml-2 w3a--text-left w3a--text-sm first-letter:w3a--capitalize",
78
74
  children: displayName
79
75
  })]
80
- }), /*#__PURE__*/jsx("span", {
81
- className: "w3a--inline-flex w3a--items-center w3a--rounded-lg w3a--px-2 w3a--py-1 w3a--text-xs w3a--font-medium w3a--bg-app-primary-100 w3a--text-app-primary-800",
82
- children: t("modal.external.installed")
76
+ }), /*#__PURE__*/jsx("img", {
77
+ id: "chain-namespace-arrow",
78
+ className: "w3a--absolute w3a--right-4 w3a--top-1/2 -w3a--translate-x-6 -w3a--translate-y-1/2 w3a--opacity-0 w3a--transition-all w3a--duration-300 group-hover:w3a--translate-x-0 group-hover:w3a--opacity-100",
79
+ src: getIcons(isDark ? "chevron-right-dark" : "chevron-right-light"),
80
+ alt: "arrow"
83
81
  })]
84
82
  })
85
83
  }, chainNamespace))
86
84
  })]
87
85
  });
88
- }
86
+ };
89
87
 
90
- export { ExternalWalletChainNamespace as default };
88
+ export { ConnectWalletChainNamespaceSelect as default };
@@ -0,0 +1,47 @@
1
+ import { useTranslation } from 'react-i18next';
2
+ import { CONNECT_WALLET_PAGES } from '../../../constants.js';
3
+ import i18nInstance from '../../../localeImport.js';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ function ConnectWalletHeader(props) {
7
+ const {
8
+ onBackClick,
9
+ currentPage,
10
+ selectedButton
11
+ } = props;
12
+ const [t] = useTranslation(undefined, {
13
+ i18n: i18nInstance
14
+ });
15
+ const handleBack = () => {
16
+ if (onBackClick) {
17
+ onBackClick();
18
+ }
19
+ };
20
+ return /*#__PURE__*/jsxs("div", {
21
+ className: "w3a--flex w3a--items-center w3a--justify-between",
22
+ children: [/*#__PURE__*/jsx("button", {
23
+ type: "button",
24
+ className: "w3a--z-20 w3a--flex w3a--size-5 w3a--cursor-pointer w3a--items-center w3a--justify-center w3a--rounded-full",
25
+ onClick: handleBack,
26
+ children: /*#__PURE__*/jsx("svg", {
27
+ xmlns: "http://www.w3.org/2000/svg",
28
+ fill: "none",
29
+ viewBox: "0 0 20 20",
30
+ className: "w3a--text-app-gray-500 hover:w3a--text-app-gray-900 dark:w3a--text-app-gray-200 dark:hover:w3a--text-app-white",
31
+ children: /*#__PURE__*/jsx("path", {
32
+ fill: "currentColor",
33
+ fillRule: "evenodd",
34
+ d: "M9.707 16.707a1 1 0 0 1-1.414 0l-6-6a1 1 0 0 1 0-1.414l6-6a1 1 0 0 1 1.414 1.414L5.414 9H17a1 1 0 1 1 0 2H5.414l4.293 4.293a1 1 0 0 1 0 1.414",
35
+ clipRule: "evenodd"
36
+ })
37
+ })
38
+ }), /*#__PURE__*/jsx("p", {
39
+ className: "w3a--text-base w3a--font-medium w3a--text-app-gray-900 dark:w3a--text-app-white",
40
+ children: currentPage === CONNECT_WALLET_PAGES.SELECTED_WALLET ? selectedButton === null || selectedButton === void 0 ? void 0 : selectedButton.displayName : currentPage === CONNECT_WALLET_PAGES.CONNECT_WALLET ? t("modal.connectYourWallet") : currentPage
41
+ }), /*#__PURE__*/jsx("div", {
42
+ className: "w3a--z-[-1] w3a--size-5"
43
+ })]
44
+ });
45
+ }
46
+
47
+ export { ConnectWalletHeader as default };
@@ -0,0 +1,146 @@
1
+ import { useState } from 'react';
2
+ import { useTranslation } from 'react-i18next';
3
+ import i18nInstance from '../../../localeImport.js';
4
+ import { cn, getIcons } from '../../../utils.js';
5
+ import Button from '../../Button/Button.js';
6
+ import { BUTTON_TYPE } from '../../Button/Button.type.js';
7
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
8
+
9
+ function NoWalletsFound() {
10
+ const [t] = useTranslation(undefined, {
11
+ i18n: i18nInstance
12
+ });
13
+ return /*#__PURE__*/jsx("div", {
14
+ className: "w3a--flex w3a--w-full w3a--items-center w3a--justify-center w3a--py-6 w3a--text-center w3a--text-app-gray-400 dark:w3a--text-app-gray-500",
15
+ children: t("modal.external.no-wallets-found")
16
+ });
17
+ }
18
+ function WalletsFound(props) {
19
+ const {
20
+ externalButtons,
21
+ isLoading,
22
+ handleWalletClick,
23
+ deviceDetails,
24
+ walletConnectUri,
25
+ buttonRadius
26
+ } = props;
27
+ if (isLoading) {
28
+ return /*#__PURE__*/jsx("div", {
29
+ className: "w3a--flex w3a--flex-col w3a--gap-y-2",
30
+ children: Array.from({
31
+ length: 6
32
+ }).map((_, index) => /*#__PURE__*/jsx("div", {
33
+ className: cn("w3a--h-12 w3a--w-full w3a--animate-pulse w3a--rounded-2xl w3a--bg-app-gray-200 dark:w3a--bg-app-gray-700", {
34
+ "w3a--rounded-full": buttonRadius === "pill",
35
+ "w3a--rounded-lg": buttonRadius === "rounded",
36
+ "w3a--rounded-none": buttonRadius === "square"
37
+ })
38
+ }, `loader-${index}`))
39
+ });
40
+ }
41
+ return /*#__PURE__*/jsx("div", {
42
+ className: "w3a--flex w3a--flex-col w3a--gap-y-2 w3a--pr-1.5",
43
+ children: externalButtons.map(button => /*#__PURE__*/jsx(Button, {
44
+ type: BUTTON_TYPE.WALLET,
45
+ props: {
46
+ label: button.displayName,
47
+ onClick: () => handleWalletClick(button),
48
+ button,
49
+ deviceDetails,
50
+ walletConnectUri,
51
+ buttonRadius
52
+ }
53
+ }, button.name))
54
+ });
55
+ }
56
+ function MoreWalletsButton(props) {
57
+ const {
58
+ totalExternalWalletsCount,
59
+ initialWalletCount,
60
+ handleMoreWallets,
61
+ isLoading,
62
+ isDark,
63
+ buttonRadius
64
+ } = props;
65
+ const [t] = useTranslation(undefined, {
66
+ i18n: i18nInstance
67
+ });
68
+ const onMoreWalletsClick = () => {
69
+ if (handleMoreWallets) {
70
+ handleMoreWallets();
71
+ }
72
+ };
73
+ if (isLoading && initialWalletCount < totalExternalWalletsCount) {
74
+ return /*#__PURE__*/jsx("div", {
75
+ className: cn("w3a--h-12 w3a--w-full w3a--animate-pulse w3a--bg-app-gray-200 dark:w3a--bg-app-gray-700", {
76
+ "w3a--rounded-full": buttonRadius === "pill",
77
+ "w3a--rounded-lg": buttonRadius === "rounded",
78
+ "w3a--rounded-none": buttonRadius === "square"
79
+ })
80
+ });
81
+ }
82
+ return /*#__PURE__*/jsxs("button", {
83
+ type: "button",
84
+ className: cn("w3a--flex w3a--items-center w3a--justify-start w3a--gap-x-2 w3a--bg-app-gray-50 w3a--p-3 hover:w3a--bg-app-gray-200 dark:w3a--bg-app-gray-800 dark:hover:w3a--bg-app-gray-600 active:w3a--scale-95 w3a--transition-all w3a--duration-150 w3a--mr-2.5", {
85
+ "w3a--rounded-full": buttonRadius === "pill",
86
+ "w3a--rounded-lg": buttonRadius === "rounded",
87
+ "w3a--rounded-none": buttonRadius === "square"
88
+ }),
89
+ onClick: onMoreWalletsClick,
90
+ children: [/*#__PURE__*/jsx("img", {
91
+ src: getIcons(isDark ? "view-dark" : "view-light"),
92
+ alt: "view",
93
+ height: "24",
94
+ width: "24"
95
+ }), /*#__PURE__*/jsx("p", {
96
+ className: "w3a--text-base w3a--font-normal w3a--text-app-gray-700 dark:w3a--text-app-white",
97
+ children: t("modal.connect-wallet.more-wallets")
98
+ }), /*#__PURE__*/jsx("span", {
99
+ className: "w3a--inline-flex w3a--items-center w3a--rounded-full w3a--bg-app-primary-100 w3a--px-2 w3a--py-1 w3a--text-xs w3a--font-medium w3a--text-app-primary-800 dark:w3a--border dark:w3a--border-app-primary-400 dark:w3a--bg-transparent dark:w3a--text-app-primary-400",
100
+ children: totalExternalWalletsCount - initialWalletCount
101
+ })]
102
+ });
103
+ }
104
+ function ConnectWalletList(props) {
105
+ const {
106
+ externalButtons,
107
+ isLoading,
108
+ totalExternalWalletsCount,
109
+ initialWalletCount,
110
+ handleWalletClick,
111
+ handleMoreWallets,
112
+ isDark,
113
+ deviceDetails,
114
+ walletConnectUri,
115
+ buttonRadius
116
+ } = props;
117
+ const [showMoreWallets, setShowMoreWallets] = useState(true);
118
+ const onShowMoreWalletsClick = () => {
119
+ setShowMoreWallets(false);
120
+ handleMoreWallets();
121
+ };
122
+ return /*#__PURE__*/jsxs(Fragment, {
123
+ children: [/*#__PURE__*/jsx("ul", {
124
+ className: cn("w3a--overflow-y-auto w3a--flex w3a--flex-col w3a--gap-y-2 w3a--h-[280px] w3a--social-container w3a--pr-2.5", {
125
+ "w3a--h-[328px]": !showMoreWallets
126
+ }),
127
+ children: externalButtons.length === 0 ? /*#__PURE__*/jsx(NoWalletsFound, {}) : /*#__PURE__*/jsx(WalletsFound, {
128
+ externalButtons: externalButtons,
129
+ isLoading: isLoading,
130
+ handleWalletClick: handleWalletClick,
131
+ deviceDetails: deviceDetails,
132
+ walletConnectUri: walletConnectUri,
133
+ buttonRadius: buttonRadius
134
+ })
135
+ }), showMoreWallets && totalExternalWalletsCount > 15 && !isLoading && initialWalletCount < totalExternalWalletsCount && /*#__PURE__*/jsx(MoreWalletsButton, {
136
+ totalExternalWalletsCount: totalExternalWalletsCount,
137
+ initialWalletCount: initialWalletCount,
138
+ handleMoreWallets: onShowMoreWalletsClick,
139
+ isLoading: isLoading,
140
+ isDark: isDark,
141
+ buttonRadius: buttonRadius
142
+ })]
143
+ });
144
+ }
145
+
146
+ export { ConnectWalletList as default };