@web3auth/modal 10.15.0 → 11.0.0-beta.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 (313) hide show
  1. package/dist/lib.cjs/node_modules/style-inject/dist/style-inject.es.js +1 -1
  2. package/dist/lib.cjs/packages/modal/src/config.js +1 -1
  3. package/dist/lib.cjs/packages/modal/src/modalManager.js +71 -35
  4. package/dist/lib.cjs/packages/modal/src/react/Web3AuthProvider.js +4 -2
  5. package/dist/lib.cjs/packages/modal/src/react/context/WalletServicesInnerContext.js +3 -56
  6. package/dist/lib.cjs/packages/modal/src/react/context/Web3AuthInnerContext.js +15 -152
  7. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3Auth.js +1 -22
  8. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthConnect.js +30 -43
  9. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthInner.js +8 -4
  10. package/dist/lib.cjs/packages/modal/src/react/index.js +57 -28
  11. package/dist/lib.cjs/packages/modal/src/react/solana/index.js +21 -8
  12. package/dist/lib.cjs/packages/modal/src/react/wagmi/provider.js +13 -11
  13. package/dist/lib.cjs/packages/modal/src/ui/components/BottomSheet/BottomSheet.js +2 -5
  14. package/dist/lib.cjs/packages/modal/src/ui/components/Button/Button.js +4 -2
  15. package/dist/lib.cjs/packages/modal/src/ui/components/Button/ButtonWallet/ButtonWallet.js +1 -2
  16. package/dist/lib.cjs/packages/modal/src/ui/components/Image/Image.js +2 -2
  17. package/dist/lib.cjs/packages/modal/src/ui/components/Loader/Loader.js +117 -29
  18. package/dist/lib.cjs/packages/modal/src/ui/components/Modal/Modal.js +1 -0
  19. package/dist/lib.cjs/packages/modal/src/ui/components/SocialLoginList/SocialLoginList.js +1 -3
  20. package/dist/lib.cjs/packages/modal/src/ui/components/SpinnerLoader/SpinnerLoader.css.js +6 -0
  21. package/dist/lib.cjs/packages/modal/src/ui/components/SpinnerLoader/SpinnerLoader.js +30 -0
  22. package/dist/lib.cjs/packages/modal/src/ui/components/Toast/Toast.js +1 -1
  23. package/dist/lib.cjs/packages/modal/src/ui/constants.js +5 -2
  24. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWallet.js +63 -26
  25. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.js +13 -4
  26. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js +1 -1
  27. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletList/ConnectWalletList.js +25 -17
  28. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.js +5 -3
  29. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.js +8 -2
  30. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/Embed/Embed.js +1 -0
  31. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/Login/Login.js +50 -39
  32. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/Login/LoginOtp/LoginOtp.js +1 -1
  33. package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/Login/LoginPasswordLess/LoginPasswordLess.js +1 -1
  34. package/dist/lib.cjs/packages/modal/src/ui/containers/Root/Root.js +235 -0
  35. package/dist/lib.cjs/packages/modal/src/ui/containers/Root/RootBodySheets/RootBodySheets.js +185 -0
  36. package/dist/lib.cjs/packages/modal/src/ui/containers/Widget/Widget.js +106 -0
  37. package/dist/lib.cjs/packages/modal/src/ui/context/ModalStateContext.js +157 -0
  38. package/dist/lib.cjs/packages/modal/src/ui/context/RootContext.js +64 -21
  39. package/dist/lib.cjs/packages/modal/src/ui/context/WidgetContext.js +52 -0
  40. package/dist/lib.cjs/packages/modal/src/ui/css/index.css.js +1 -1
  41. package/dist/lib.cjs/packages/modal/src/ui/interfaces.js +2 -1
  42. package/dist/lib.cjs/packages/modal/src/ui/loginModal.js +76 -45
  43. package/dist/lib.cjs/packages/modal/src/vue/WalletServicesInnerProvider.js +2 -50
  44. package/dist/lib.cjs/packages/modal/src/vue/Web3AuthProvider.js +7 -170
  45. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthConnect.js +31 -33
  46. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthInner.js +2 -5
  47. package/dist/lib.cjs/packages/modal/src/vue/index.js +57 -28
  48. package/dist/lib.cjs/packages/modal/src/vue/solana/index.js +29 -8
  49. package/dist/lib.cjs/packages/modal/src/vue/wagmi/provider.js +15 -14
  50. package/dist/lib.cjs/packages/modal/src/x402/index.js +12 -0
  51. package/dist/lib.cjs/packages/modal/src/x402/react.js +26 -0
  52. package/dist/lib.cjs/packages/modal/src/x402/vue.js +18 -0
  53. package/dist/lib.cjs/types/interface.d.ts +2 -2
  54. package/dist/lib.cjs/types/modalManager.d.ts +7 -3
  55. package/dist/lib.cjs/types/react/context/WalletServicesInnerContext.d.ts +12 -5
  56. package/dist/lib.cjs/types/react/context/Web3AuthInnerContext.d.ts +4 -3
  57. package/dist/lib.cjs/types/react/hooks/index.d.ts +15 -14
  58. package/dist/lib.cjs/types/react/hooks/useWeb3Auth.d.ts +1 -2
  59. package/dist/lib.cjs/types/react/hooks/useWeb3AuthConnect.d.ts +3 -3
  60. package/dist/lib.cjs/types/react/interfaces.d.ts +3 -2
  61. package/dist/lib.cjs/types/react/solana/hooks/index.d.ts +5 -4
  62. package/dist/lib.cjs/types/react/solana/index.d.ts +1 -0
  63. package/dist/lib.cjs/types/react/solana/provider.d.ts +1 -0
  64. package/dist/lib.cjs/types/ui/components/BottomSheet/BottomSheet.d.ts +1 -1
  65. package/dist/lib.cjs/types/ui/components/BottomSheet/BottomSheet.type.d.ts +4 -3
  66. package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/ButtonWallet.type.d.ts +1 -0
  67. package/dist/lib.cjs/types/ui/components/Loader/Loader.type.d.ts +7 -5
  68. package/dist/lib.cjs/types/ui/components/LoginHint/LoginHint.type.d.ts +2 -1
  69. package/dist/lib.cjs/types/ui/components/SpinnerLoader/SpinnerLoader.d.ts +4 -0
  70. package/dist/lib.cjs/types/ui/components/SpinnerLoader/SpinnerLoader.type.d.ts +9 -0
  71. package/dist/lib.cjs/types/ui/components/SpinnerLoader/index.d.ts +2 -0
  72. package/dist/lib.cjs/types/ui/constants.d.ts +7 -4
  73. package/dist/lib.cjs/types/ui/containers/ConnectWallet/ConnectWallet.type.d.ts +7 -0
  74. package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.type.d.ts +0 -2
  75. package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletList/ConnectWalletList.type.d.ts +3 -9
  76. package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.type.d.ts +0 -2
  77. package/dist/lib.cjs/types/ui/containers/Login/Login.type.d.ts +6 -0
  78. package/dist/lib.cjs/types/ui/containers/Root/Root.type.d.ts +3 -0
  79. package/dist/lib.cjs/types/ui/containers/Root/RootBodySheets/RootBodySheets.d.ts +1 -0
  80. package/dist/lib.cjs/types/ui/containers/Widget/Widget.type.d.ts +5 -0
  81. package/dist/lib.cjs/types/ui/context/ModalStateContext.d.ts +28 -0
  82. package/dist/lib.cjs/types/ui/context/RootContext.d.ts +19 -7
  83. package/dist/lib.cjs/types/ui/context/WidgetContext.d.ts +45 -0
  84. package/dist/lib.cjs/types/ui/interfaces.d.ts +18 -15
  85. package/dist/lib.cjs/types/ui/loginModal.d.ts +6 -4
  86. package/dist/lib.cjs/types/vue/composables/index.d.ts +2 -14
  87. package/dist/lib.cjs/types/vue/composables/useWeb3Auth.d.ts +1 -2
  88. package/dist/lib.cjs/types/vue/composables/useWeb3AuthConnect.d.ts +3 -3
  89. package/dist/lib.cjs/types/vue/interfaces.d.ts +3 -17
  90. package/dist/lib.cjs/types/vue/solana/composables/index.d.ts +3 -4
  91. package/dist/lib.cjs/types/vue/solana/composables/useSolanaClient.d.ts +1 -0
  92. package/dist/lib.cjs/types/vue/solana/constants.d.ts +1 -0
  93. package/dist/lib.cjs/types/vue/solana/index.d.ts +2 -0
  94. package/dist/lib.cjs/types/vue/solana/provider.d.ts +1 -0
  95. package/dist/lib.cjs/types/x402/index.d.ts +1 -0
  96. package/dist/lib.cjs/types/x402/react.d.ts +2 -0
  97. package/dist/lib.cjs/types/x402/vue.d.ts +2 -0
  98. package/dist/lib.esm/node_modules/style-inject/dist/style-inject.es.js +1 -1
  99. package/dist/lib.esm/packages/modal/src/config.js +1 -1
  100. package/dist/lib.esm/packages/modal/src/modalManager.js +72 -36
  101. package/dist/lib.esm/packages/modal/src/react/Web3AuthProvider.js +4 -2
  102. package/dist/lib.esm/packages/modal/src/react/context/WalletServicesInnerContext.js +4 -57
  103. package/dist/lib.esm/packages/modal/src/react/context/Web3AuthInnerContext.js +12 -151
  104. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3Auth.js +1 -22
  105. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthConnect.js +28 -41
  106. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthInner.js +7 -3
  107. package/dist/lib.esm/packages/modal/src/react/index.js +1 -14
  108. package/dist/lib.esm/packages/modal/src/react/solana/index.js +1 -4
  109. package/dist/lib.esm/packages/modal/src/react/wagmi/provider.js +12 -10
  110. package/dist/lib.esm/packages/modal/src/ui/components/BottomSheet/BottomSheet.js +2 -5
  111. package/dist/lib.esm/packages/modal/src/ui/components/Button/Button.js +4 -2
  112. package/dist/lib.esm/packages/modal/src/ui/components/Button/ButtonWallet/ButtonWallet.js +2 -3
  113. package/dist/lib.esm/packages/modal/src/ui/components/Image/Image.js +3 -3
  114. package/dist/lib.esm/packages/modal/src/ui/components/Loader/Loader.js +118 -30
  115. package/dist/lib.esm/packages/modal/src/ui/components/Modal/Modal.js +1 -0
  116. package/dist/lib.esm/packages/modal/src/ui/components/SocialLoginList/SocialLoginList.js +1 -3
  117. package/dist/lib.esm/packages/modal/src/ui/components/SpinnerLoader/SpinnerLoader.css.js +4 -0
  118. package/dist/lib.esm/packages/modal/src/ui/components/SpinnerLoader/SpinnerLoader.js +28 -0
  119. package/dist/lib.esm/packages/modal/src/ui/components/Toast/Toast.js +3 -3
  120. package/dist/lib.esm/packages/modal/src/ui/constants.js +5 -2
  121. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWallet.js +67 -29
  122. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.js +13 -4
  123. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js +1 -1
  124. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletList/ConnectWalletList.js +25 -17
  125. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.js +7 -5
  126. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.js +8 -2
  127. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/Embed/Embed.js +1 -0
  128. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/Login/Login.js +53 -41
  129. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/Login/LoginOtp/LoginOtp.js +1 -1
  130. package/dist/lib.esm/packages/modal/src/ui/{components → containers}/Login/LoginPasswordLess/LoginPasswordLess.js +1 -1
  131. package/dist/lib.esm/packages/modal/src/ui/containers/Root/Root.js +238 -0
  132. package/dist/lib.esm/packages/modal/src/ui/containers/Root/RootBodySheets/RootBodySheets.js +183 -0
  133. package/dist/lib.esm/packages/modal/src/ui/containers/Widget/Widget.js +104 -0
  134. package/dist/lib.esm/packages/modal/src/ui/context/ModalStateContext.js +160 -0
  135. package/dist/lib.esm/packages/modal/src/ui/context/RootContext.js +60 -22
  136. package/dist/lib.esm/packages/modal/src/ui/context/WidgetContext.js +49 -0
  137. package/dist/lib.esm/packages/modal/src/ui/css/index.css.js +1 -1
  138. package/dist/lib.esm/packages/modal/src/ui/interfaces.js +2 -1
  139. package/dist/lib.esm/packages/modal/src/ui/loginModal.js +76 -45
  140. package/dist/lib.esm/packages/modal/src/vue/WalletServicesInnerProvider.js +5 -54
  141. package/dist/lib.esm/packages/modal/src/vue/Web3AuthProvider.js +9 -176
  142. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthConnect.js +28 -30
  143. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthInner.js +2 -5
  144. package/dist/lib.esm/packages/modal/src/vue/index.js +1 -14
  145. package/dist/lib.esm/packages/modal/src/vue/solana/index.js +1 -4
  146. package/dist/lib.esm/packages/modal/src/vue/wagmi/provider.js +10 -9
  147. package/dist/lib.esm/packages/modal/src/x402/index.js +1 -0
  148. package/dist/lib.esm/packages/modal/src/x402/react.js +1 -0
  149. package/dist/lib.esm/packages/modal/src/x402/vue.js +1 -0
  150. package/package.json +68 -44
  151. package/dist/lib.cjs/packages/modal/src/providers/ethereum-mpc-provider/index.js +0 -12
  152. package/dist/lib.cjs/packages/modal/src/react/hooks/useChain.js +0 -16
  153. package/dist/lib.cjs/packages/modal/src/react/hooks/useCheckout.js +0 -34
  154. package/dist/lib.cjs/packages/modal/src/react/hooks/useEnableMFA.js +0 -30
  155. package/dist/lib.cjs/packages/modal/src/react/hooks/useFunding.js +0 -34
  156. package/dist/lib.cjs/packages/modal/src/react/hooks/useIdentityToken.js +0 -46
  157. package/dist/lib.cjs/packages/modal/src/react/hooks/useManageMFA.js +0 -30
  158. package/dist/lib.cjs/packages/modal/src/react/hooks/useReceive.js +0 -34
  159. package/dist/lib.cjs/packages/modal/src/react/hooks/useSwap.js +0 -34
  160. package/dist/lib.cjs/packages/modal/src/react/hooks/useSwitchChain.js +0 -32
  161. package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletConnectScanner.js +0 -34
  162. package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletServicesPlugin.js +0 -13
  163. package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletUI.js +0 -34
  164. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthDisconnect.js +0 -30
  165. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthUser.js +0 -50
  166. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignAndSendTransaction.js +0 -36
  167. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignMessage.js +0 -37
  168. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignTransaction.js +0 -36
  169. package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSolanaWallet.js +0 -68
  170. package/dist/lib.cjs/packages/modal/src/ui/components/CircularLoader/CircularLoader.js +0 -88
  171. package/dist/lib.cjs/packages/modal/src/ui/components/Root/Root.js +0 -513
  172. package/dist/lib.cjs/packages/modal/src/ui/components/Widget/Widget.js +0 -251
  173. package/dist/lib.cjs/packages/modal/src/ui/context/ThemeContext.js +0 -9
  174. package/dist/lib.cjs/packages/modal/src/vue/composables/useChain.js +0 -13
  175. package/dist/lib.cjs/packages/modal/src/vue/composables/useCheckout.js +0 -35
  176. package/dist/lib.cjs/packages/modal/src/vue/composables/useEnableMFA.js +0 -33
  177. package/dist/lib.cjs/packages/modal/src/vue/composables/useFunding.js +0 -35
  178. package/dist/lib.cjs/packages/modal/src/vue/composables/useIdentityToken.js +0 -51
  179. package/dist/lib.cjs/packages/modal/src/vue/composables/useManageMFA.js +0 -33
  180. package/dist/lib.cjs/packages/modal/src/vue/composables/useReceive.js +0 -35
  181. package/dist/lib.cjs/packages/modal/src/vue/composables/useSwap.js +0 -35
  182. package/dist/lib.cjs/packages/modal/src/vue/composables/useSwitchChain.js +0 -33
  183. package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletConnectScanner.js +0 -35
  184. package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletServicesPlugin.js +0 -13
  185. package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletUI.js +0 -35
  186. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthDisconnect.js +0 -33
  187. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthUser.js +0 -54
  188. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignAndSendTransaction.js +0 -37
  189. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignMessage.js +0 -39
  190. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignTransaction.js +0 -37
  191. package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSolanaWallet.js +0 -67
  192. package/dist/lib.cjs/types/providers/ethereum-mpc-provider/index.d.ts +0 -1
  193. package/dist/lib.cjs/types/react/hooks/useChain.d.ts +0 -6
  194. package/dist/lib.cjs/types/react/hooks/useCheckout.d.ts +0 -8
  195. package/dist/lib.cjs/types/react/hooks/useEnableMFA.d.ts +0 -7
  196. package/dist/lib.cjs/types/react/hooks/useFunding.d.ts +0 -8
  197. package/dist/lib.cjs/types/react/hooks/useIdentityToken.d.ts +0 -13
  198. package/dist/lib.cjs/types/react/hooks/useManageMFA.d.ts +0 -7
  199. package/dist/lib.cjs/types/react/hooks/useReceive.d.ts +0 -8
  200. package/dist/lib.cjs/types/react/hooks/useSwap.d.ts +0 -8
  201. package/dist/lib.cjs/types/react/hooks/useSwitchChain.d.ts +0 -7
  202. package/dist/lib.cjs/types/react/hooks/useWalletConnectScanner.d.ts +0 -8
  203. package/dist/lib.cjs/types/react/hooks/useWalletServicesPlugin.d.ts +0 -2
  204. package/dist/lib.cjs/types/react/hooks/useWalletUI.d.ts +0 -8
  205. package/dist/lib.cjs/types/react/hooks/useWeb3AuthDisconnect.d.ts +0 -9
  206. package/dist/lib.cjs/types/react/hooks/useWeb3AuthUser.d.ts +0 -9
  207. package/dist/lib.cjs/types/react/solana/hooks/useSignAndSendTransaction.d.ts +0 -8
  208. package/dist/lib.cjs/types/react/solana/hooks/useSignMessage.d.ts +0 -8
  209. package/dist/lib.cjs/types/react/solana/hooks/useSignTransaction.d.ts +0 -13
  210. package/dist/lib.cjs/types/react/solana/hooks/useSolanaWallet.d.ts +0 -8
  211. package/dist/lib.cjs/types/ui/components/CircularLoader/CircularLoader.d.ts +0 -3
  212. package/dist/lib.cjs/types/ui/components/CircularLoader/CircularLoader.type.d.ts +0 -19
  213. package/dist/lib.cjs/types/ui/components/CircularLoader/index.d.ts +0 -2
  214. package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWallet.type.d.ts +0 -27
  215. package/dist/lib.cjs/types/ui/components/Login/Login.type.d.ts +0 -35
  216. package/dist/lib.cjs/types/ui/components/Root/Root.type.d.ts +0 -36
  217. package/dist/lib.cjs/types/ui/components/Widget/Widget.type.d.ts +0 -24
  218. package/dist/lib.cjs/types/ui/context/ThemeContext.d.ts +0 -3
  219. package/dist/lib.cjs/types/vue/composables/useChain.d.ts +0 -7
  220. package/dist/lib.cjs/types/vue/composables/useCheckout.d.ts +0 -9
  221. package/dist/lib.cjs/types/vue/composables/useEnableMFA.d.ts +0 -8
  222. package/dist/lib.cjs/types/vue/composables/useFunding.d.ts +0 -9
  223. package/dist/lib.cjs/types/vue/composables/useIdentityToken.d.ts +0 -9
  224. package/dist/lib.cjs/types/vue/composables/useManageMFA.d.ts +0 -8
  225. package/dist/lib.cjs/types/vue/composables/useReceive.d.ts +0 -9
  226. package/dist/lib.cjs/types/vue/composables/useSwap.d.ts +0 -9
  227. package/dist/lib.cjs/types/vue/composables/useSwitchChain.d.ts +0 -10
  228. package/dist/lib.cjs/types/vue/composables/useWalletConnectScanner.d.ts +0 -9
  229. package/dist/lib.cjs/types/vue/composables/useWalletServicesPlugin.d.ts +0 -2
  230. package/dist/lib.cjs/types/vue/composables/useWalletUI.d.ts +0 -9
  231. package/dist/lib.cjs/types/vue/composables/useWeb3AuthDisconnect.d.ts +0 -10
  232. package/dist/lib.cjs/types/vue/composables/useWeb3AuthUser.d.ts +0 -10
  233. package/dist/lib.cjs/types/vue/solana/composables/useSignAndSendTransaction.d.ts +0 -9
  234. package/dist/lib.cjs/types/vue/solana/composables/useSignMessage.d.ts +0 -9
  235. package/dist/lib.cjs/types/vue/solana/composables/useSignTransaction.d.ts +0 -9
  236. package/dist/lib.cjs/types/vue/solana/composables/useSolanaWallet.d.ts +0 -9
  237. package/dist/lib.esm/packages/modal/src/providers/ethereum-mpc-provider/index.js +0 -1
  238. package/dist/lib.esm/packages/modal/src/react/hooks/useChain.js +0 -14
  239. package/dist/lib.esm/packages/modal/src/react/hooks/useCheckout.js +0 -32
  240. package/dist/lib.esm/packages/modal/src/react/hooks/useEnableMFA.js +0 -28
  241. package/dist/lib.esm/packages/modal/src/react/hooks/useFunding.js +0 -32
  242. package/dist/lib.esm/packages/modal/src/react/hooks/useIdentityToken.js +0 -44
  243. package/dist/lib.esm/packages/modal/src/react/hooks/useManageMFA.js +0 -28
  244. package/dist/lib.esm/packages/modal/src/react/hooks/useReceive.js +0 -32
  245. package/dist/lib.esm/packages/modal/src/react/hooks/useSwap.js +0 -32
  246. package/dist/lib.esm/packages/modal/src/react/hooks/useSwitchChain.js +0 -30
  247. package/dist/lib.esm/packages/modal/src/react/hooks/useWalletConnectScanner.js +0 -32
  248. package/dist/lib.esm/packages/modal/src/react/hooks/useWalletServicesPlugin.js +0 -11
  249. package/dist/lib.esm/packages/modal/src/react/hooks/useWalletUI.js +0 -32
  250. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthDisconnect.js +0 -28
  251. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthUser.js +0 -48
  252. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignAndSendTransaction.js +0 -34
  253. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignMessage.js +0 -35
  254. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignTransaction.js +0 -34
  255. package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSolanaWallet.js +0 -64
  256. package/dist/lib.esm/packages/modal/src/ui/components/CircularLoader/CircularLoader.js +0 -86
  257. package/dist/lib.esm/packages/modal/src/ui/components/Root/Root.js +0 -524
  258. package/dist/lib.esm/packages/modal/src/ui/components/Widget/Widget.js +0 -253
  259. package/dist/lib.esm/packages/modal/src/ui/context/ThemeContext.js +0 -7
  260. package/dist/lib.esm/packages/modal/src/vue/composables/useChain.js +0 -11
  261. package/dist/lib.esm/packages/modal/src/vue/composables/useCheckout.js +0 -33
  262. package/dist/lib.esm/packages/modal/src/vue/composables/useEnableMFA.js +0 -31
  263. package/dist/lib.esm/packages/modal/src/vue/composables/useFunding.js +0 -33
  264. package/dist/lib.esm/packages/modal/src/vue/composables/useIdentityToken.js +0 -49
  265. package/dist/lib.esm/packages/modal/src/vue/composables/useManageMFA.js +0 -31
  266. package/dist/lib.esm/packages/modal/src/vue/composables/useReceive.js +0 -33
  267. package/dist/lib.esm/packages/modal/src/vue/composables/useSwap.js +0 -33
  268. package/dist/lib.esm/packages/modal/src/vue/composables/useSwitchChain.js +0 -31
  269. package/dist/lib.esm/packages/modal/src/vue/composables/useWalletConnectScanner.js +0 -33
  270. package/dist/lib.esm/packages/modal/src/vue/composables/useWalletServicesPlugin.js +0 -11
  271. package/dist/lib.esm/packages/modal/src/vue/composables/useWalletUI.js +0 -33
  272. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthDisconnect.js +0 -31
  273. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthUser.js +0 -52
  274. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignAndSendTransaction.js +0 -35
  275. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignMessage.js +0 -37
  276. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignTransaction.js +0 -35
  277. package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSolanaWallet.js +0 -65
  278. package/dist/modal.umd.min.js +0 -2
  279. package/dist/modal.umd.min.js.LICENSE.txt +0 -104
  280. /package/dist/lib.cjs/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.js +0 -0
  281. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWallet.d.ts +0 -0
  282. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.d.ts +0 -0
  283. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletChainFilter/index.d.ts +0 -0
  284. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.d.ts +0 -0
  285. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.type.d.ts +0 -0
  286. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletChainNamespaceSelect/index.d.ts +0 -0
  287. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.d.ts +0 -0
  288. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.type.d.ts +0 -0
  289. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletHeader/index.d.ts +0 -0
  290. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletList/ConnectWalletList.d.ts +0 -0
  291. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletList/index.d.ts +0 -0
  292. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.d.ts +0 -0
  293. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.type.d.ts +0 -0
  294. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletQrCode/index.d.ts +0 -0
  295. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.d.ts +0 -0
  296. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/ConnectWalletSearch/index.d.ts +0 -0
  297. /package/dist/lib.cjs/types/ui/{components → containers}/ConnectWallet/index.d.ts +0 -0
  298. /package/dist/lib.cjs/types/ui/{components → containers}/Embed/Embed.d.ts +0 -0
  299. /package/dist/lib.cjs/types/ui/{components → containers}/Embed/Embed.type.d.ts +0 -0
  300. /package/dist/lib.cjs/types/ui/{components → containers}/Embed/index.d.ts +0 -0
  301. /package/dist/lib.cjs/types/ui/{components → containers}/Login/Login.d.ts +0 -0
  302. /package/dist/lib.cjs/types/ui/{components → containers}/Login/LoginOtp/LoginOtp.d.ts +0 -0
  303. /package/dist/lib.cjs/types/ui/{components → containers}/Login/LoginOtp/LoginOtp.type.d.ts +0 -0
  304. /package/dist/lib.cjs/types/ui/{components → containers}/Login/LoginOtp/index.d.ts +0 -0
  305. /package/dist/lib.cjs/types/ui/{components → containers}/Login/LoginPasswordLess/LoginPasswordLess.d.ts +0 -0
  306. /package/dist/lib.cjs/types/ui/{components → containers}/Login/LoginPasswordLess/LoginPasswordLess.type.d.ts +0 -0
  307. /package/dist/lib.cjs/types/ui/{components → containers}/Login/LoginPasswordLess/index.d.ts +0 -0
  308. /package/dist/lib.cjs/types/ui/{components → containers}/Login/index.d.ts +0 -0
  309. /package/dist/lib.cjs/types/ui/{components → containers}/Root/Root.d.ts +0 -0
  310. /package/dist/lib.cjs/types/ui/{components → containers}/Root/index.d.ts +0 -0
  311. /package/dist/lib.cjs/types/ui/{components → containers}/Widget/Widget.d.ts +0 -0
  312. /package/dist/lib.cjs/types/ui/{components → containers}/Widget/index.d.ts +0 -0
  313. /package/dist/lib.esm/packages/modal/src/ui/{components → containers}/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.js +0 -0
@@ -0,0 +1,183 @@
1
+ import _objectSpread from '@babel/runtime/helpers/objectSpread2';
2
+ import { useMemo } from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import BottomSheet from '../../../components/BottomSheet/BottomSheet.js';
5
+ import Image from '../../../components/Image/Image.js';
6
+ import { useModalState } from '../../../context/ModalStateContext.js';
7
+ import { useBodyState } from '../../../context/RootContext.js';
8
+ import { useWidget } from '../../../context/WidgetContext.js';
9
+ import i18nInstance from '../../../localeImport.js';
10
+ import { getMobileInstallLink, getOsName, getIcons, cn, getBrowserExtensionUrl, getBrowserName } from '../../../utils.js';
11
+ import ConnectWalletChainNamespaceSelect from '../../ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js';
12
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
13
+
14
+ function RootBodySheets() {
15
+ var _bodyState$installLin2, _bodyState$installLin4, _bodyState$multiChain, _bodyState$installLin5;
16
+ const [t] = useTranslation(undefined, {
17
+ i18n: i18nInstance
18
+ });
19
+ const {
20
+ preHandleExternalWalletClick
21
+ } = useModalState();
22
+ const {
23
+ bodyState,
24
+ setBodyState
25
+ } = useBodyState();
26
+ const {
27
+ isDark,
28
+ deviceDetails,
29
+ uiConfig
30
+ } = useWidget();
31
+ const {
32
+ buttonRadiusType
33
+ } = uiConfig;
34
+ const mobileInstallLinks = useMemo(() => {
35
+ var _bodyState$installLin;
36
+ if (deviceDetails.platform === "desktop") return [];
37
+ const installConfig = ((_bodyState$installLin = bodyState.installLinks) === null || _bodyState$installLin === void 0 || (_bodyState$installLin = _bodyState$installLin.wallet) === null || _bodyState$installLin === void 0 || (_bodyState$installLin = _bodyState$installLin.walletRegistryItem) === null || _bodyState$installLin === void 0 ? void 0 : _bodyState$installLin.app) || {};
38
+ const installLinks = Object.keys(installConfig).reduce((acc, osKey) => {
39
+ if (!["android", "ios"].includes(osKey)) return acc;
40
+ const appId = installConfig[osKey];
41
+ if (!appId) return acc;
42
+ const appUrl = getMobileInstallLink(osKey, appId);
43
+ if (!appUrl) return acc;
44
+ const logoLight = `${osKey}-light`;
45
+ const logoDark = `${osKey}-dark`;
46
+ acc.push(/*#__PURE__*/jsx("li", {
47
+ className: "w3a--w-full",
48
+ children: /*#__PURE__*/jsx("a", {
49
+ href: appUrl,
50
+ rel: "noopener noreferrer",
51
+ target: "_blank",
52
+ children: /*#__PURE__*/jsxs("button", {
53
+ type: "button",
54
+ className: cn("w3a--group w3a--relative w3a--overflow-hidden w3a--h-11 w3a--flex w3a--w-full w3a--items-center w3a--justify-start w3a--gap-x-2 w3a--border w3a--border-app-gray-200 w3a--bg-app-gray-50 w3a--px-5 w3a--py-2.5 hover:w3a--translate-y-[0.5px] hover:w3a--border-app-gray-50 dark:w3a--border-app-gray-500 dark:w3a--bg-app-gray-800 dark:hover:w3a--border-app-gray-800", {
55
+ "w3a--rounded-full": buttonRadiusType === "pill",
56
+ "w3a--rounded-lg": buttonRadiusType === "rounded",
57
+ "w3a--rounded-none": buttonRadiusType === "square"
58
+ }),
59
+ children: [/*#__PURE__*/jsx(Image, {
60
+ imageId: logoLight,
61
+ darkImageId: logoDark,
62
+ hoverImageId: logoLight,
63
+ darkHoverImageId: logoDark,
64
+ height: "28",
65
+ width: "28",
66
+ isButton: true
67
+ }), /*#__PURE__*/jsx("span", {
68
+ className: "w3a--text-sm w3a--font-medium w3a--text-app-gray-900 dark:w3a--text-app-white",
69
+ children: t("modal.external.install-mobile-app", {
70
+ os: getOsName(osKey)
71
+ })
72
+ }), /*#__PURE__*/jsx("img", {
73
+ id: "install-links-arrow",
74
+ 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",
75
+ src: getIcons(isDark ? "chevron-right-dark" : "chevron-right-light"),
76
+ alt: "arrow"
77
+ })]
78
+ })
79
+ })
80
+ }, appUrl));
81
+ return acc;
82
+ }, []);
83
+ return installLinks;
84
+ }, [(_bodyState$installLin2 = bodyState.installLinks) === null || _bodyState$installLin2 === void 0 || (_bodyState$installLin2 = _bodyState$installLin2.wallet) === null || _bodyState$installLin2 === void 0 || (_bodyState$installLin2 = _bodyState$installLin2.walletRegistryItem) === null || _bodyState$installLin2 === void 0 ? void 0 : _bodyState$installLin2.app, deviceDetails.platform, isDark, t, buttonRadiusType]);
85
+ const desktopInstallLinks = useMemo(() => {
86
+ var _bodyState$installLin3;
87
+ if (deviceDetails.platform !== "desktop") return [];
88
+ const browserType = deviceDetails.browser === "brave" ? "chrome" : deviceDetails.browser;
89
+ const browserExtensionConfig = ((_bodyState$installLin3 = bodyState.installLinks) === null || _bodyState$installLin3 === void 0 || (_bodyState$installLin3 = _bodyState$installLin3.wallet) === null || _bodyState$installLin3 === void 0 || (_bodyState$installLin3 = _bodyState$installLin3.walletRegistryItem) === null || _bodyState$installLin3 === void 0 ? void 0 : _bodyState$installLin3.app) || {};
90
+ const extensionForCurrentBrowser = browserExtensionConfig.browser && browserExtensionConfig.browser.includes(browserType) ? browserExtensionConfig.browser : undefined;
91
+ const browserExtensionId = browserExtensionConfig[browserType] || extensionForCurrentBrowser;
92
+ const browserExtensionUrl = browserExtensionId ? getBrowserExtensionUrl(browserType, browserExtensionId) : null;
93
+ const installLink = browserExtensionUrl ? /*#__PURE__*/jsx("li", {
94
+ children: /*#__PURE__*/jsx("a", {
95
+ href: browserExtensionUrl,
96
+ rel: "noopener noreferrer",
97
+ target: "_blank",
98
+ children: /*#__PURE__*/jsxs("button", {
99
+ type: "button",
100
+ className: cn("w3a--group w3a--relative w3a--overflow-hidden w3a--h-11 w3a--flex w3a--w-full w3a--items-center w3a--justify-start w3a--gap-x-2 w3a--border w3a--border-app-gray-200 w3a--bg-app-gray-50 w3a--px-5 w3a--py-2.5 hover:w3a--translate-y-[0.5px] hover:w3a--border-app-gray-50 dark:w3a--border-app-gray-500 dark:w3a--bg-app-gray-800 dark:hover:w3a--border-app-gray-800", {
101
+ "w3a--rounded-full": buttonRadiusType === "pill",
102
+ "w3a--rounded-lg": buttonRadiusType === "rounded",
103
+ "w3a--rounded-none": buttonRadiusType === "square"
104
+ }),
105
+ children: [/*#__PURE__*/jsx(Image, {
106
+ imageId: deviceDetails.browser,
107
+ darkImageId: deviceDetails.browser,
108
+ hoverImageId: deviceDetails.browser,
109
+ darkHoverImageId: deviceDetails.browser,
110
+ height: "30",
111
+ width: "30",
112
+ isButton: true
113
+ }), /*#__PURE__*/jsx("span", {
114
+ className: "w3a--text-sm w3a--font-medium w3a--text-app-gray-900 dark:w3a--text-app-white",
115
+ children: t("modal.external.install-browser-extension", {
116
+ browser: getBrowserName(deviceDetails.browser)
117
+ })
118
+ }), /*#__PURE__*/jsx("img", {
119
+ id: "install-links-arrow",
120
+ 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",
121
+ src: getIcons(isDark ? "chevron-right-dark" : "chevron-right-light"),
122
+ alt: "arrow"
123
+ })]
124
+ })
125
+ })
126
+ }, browserExtensionUrl) : null;
127
+ return [installLink, ...mobileInstallLinks];
128
+ }, [(_bodyState$installLin4 = bodyState.installLinks) === null || _bodyState$installLin4 === void 0 || (_bodyState$installLin4 = _bodyState$installLin4.wallet) === null || _bodyState$installLin4 === void 0 || (_bodyState$installLin4 = _bodyState$installLin4.walletRegistryItem) === null || _bodyState$installLin4 === void 0 ? void 0 : _bodyState$installLin4.app, deviceDetails.browser, deviceDetails.platform, isDark, mobileInstallLinks, buttonRadiusType, t]);
129
+ return /*#__PURE__*/jsxs(Fragment, {
130
+ children: [((_bodyState$multiChain = bodyState.multiChainSelector) === null || _bodyState$multiChain === void 0 ? void 0 : _bodyState$multiChain.show) && /*#__PURE__*/jsx(BottomSheet, {
131
+ borderRadiusType: uiConfig.borderRadiusType,
132
+ isShown: bodyState.multiChainSelector.show,
133
+ onClose: () => setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
134
+ multiChainSelector: {
135
+ show: false,
136
+ wallet: null
137
+ }
138
+ })),
139
+ children: /*#__PURE__*/jsx(ConnectWalletChainNamespaceSelect, {
140
+ isDark: isDark,
141
+ wallet: bodyState.multiChainSelector.wallet,
142
+ handleExternalWalletClick: params => {
143
+ preHandleExternalWalletClick(params);
144
+ setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
145
+ multiChainSelector: {
146
+ show: false,
147
+ wallet: null
148
+ }
149
+ }));
150
+ }
151
+ })
152
+ }), ((_bodyState$installLin5 = bodyState.installLinks) === null || _bodyState$installLin5 === void 0 ? void 0 : _bodyState$installLin5.show) && /*#__PURE__*/jsxs(BottomSheet, {
153
+ borderRadiusType: uiConfig.borderRadiusType,
154
+ isShown: bodyState.installLinks.show,
155
+ onClose: () => setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
156
+ installLinks: {
157
+ show: false,
158
+ wallet: null
159
+ }
160
+ })),
161
+ children: [/*#__PURE__*/jsx("p", {
162
+ className: "w3a--mb-2 w3a--text-center w3a--text-base w3a--font-semibold w3a--text-app-gray-900 dark:w3a--text-app-white",
163
+ children: t("modal.getWallet")
164
+ }), /*#__PURE__*/jsx("div", {
165
+ className: "w3a--my-4 w3a--flex w3a--justify-center",
166
+ children: /*#__PURE__*/jsx(Image, {
167
+ imageId: `login-${bodyState.installLinks.wallet.name}`,
168
+ hoverImageId: `login-${bodyState.installLinks.wallet.name}`,
169
+ fallbackImageId: "wallet",
170
+ height: "80",
171
+ width: "80",
172
+ isButton: true,
173
+ extension: bodyState.installLinks.wallet.imgExtension
174
+ })
175
+ }), /*#__PURE__*/jsx("ul", {
176
+ className: "w3a--flex w3a--flex-col w3a--gap-y-2",
177
+ children: deviceDetails.platform === "desktop" ? desktopInstallLinks : mobileInstallLinks
178
+ })]
179
+ })]
180
+ });
181
+ }
182
+
183
+ export { RootBodySheets as default };
@@ -0,0 +1,104 @@
1
+ import _objectSpread from '@babel/runtime/helpers/objectSpread2';
2
+ import { WALLET_CONNECTORS, WIDGET_TYPE } from '@web3auth/no-modal';
3
+ import { useMemo, useEffect } from 'react';
4
+ import Modal from '../../components/Modal/Modal.js';
5
+ import { PAGES } from '../../constants.js';
6
+ import { ModalStateProvider, useModalState } from '../../context/ModalStateContext.js';
7
+ import { useWidget } from '../../context/WidgetContext.js';
8
+ import { MODAL_STATUS } from '../../interfaces.js';
9
+ import Embed from '../Embed/Embed.js';
10
+ import Root from '../Root/Root.js';
11
+ import { jsx } from 'react/jsx-runtime';
12
+
13
+ function WidgetContent() {
14
+ const {
15
+ uiConfig,
16
+ handleExternalWalletClick,
17
+ closeModal,
18
+ isConnectAndSignAuthenticationMode
19
+ } = useWidget();
20
+ const {
21
+ modalState,
22
+ setModalState
23
+ } = useModalState();
24
+ const {
25
+ widgetType
26
+ } = uiConfig;
27
+ const onCloseModal = () => {
28
+ setModalState(prevState => _objectSpread(_objectSpread({}, prevState), {}, {
29
+ externalWalletsVisibility: false,
30
+ modalVisibility: false,
31
+ currentPage: PAGES.LOGIN_OPTIONS
32
+ }));
33
+ closeModal();
34
+ };
35
+ const onCloseLoader = () => {
36
+ if (!isConnectAndSignAuthenticationMode && modalState.status === MODAL_STATUS.CONNECTED) {
37
+ setModalState(_objectSpread(_objectSpread({}, modalState), {}, {
38
+ modalVisibility: false,
39
+ externalWalletsVisibility: false
40
+ }));
41
+ }
42
+ if (isConnectAndSignAuthenticationMode && modalState.status === MODAL_STATUS.AUTHORIZED) {
43
+ setModalState(_objectSpread(_objectSpread({}, modalState), {}, {
44
+ modalVisibility: false,
45
+ externalWalletsVisibility: false
46
+ }));
47
+ }
48
+ if (modalState.status === MODAL_STATUS.ERRORED) {
49
+ setModalState(_objectSpread(_objectSpread({}, modalState), {}, {
50
+ modalVisibility: true,
51
+ status: MODAL_STATUS.INITIALIZED
52
+ }));
53
+ }
54
+ };
55
+ const showCloseIcon = useMemo(() => {
56
+ return modalState.status === MODAL_STATUS.INITIALIZED || modalState.status === MODAL_STATUS.CONNECTED || modalState.status === MODAL_STATUS.ERRORED || modalState.status === MODAL_STATUS.AUTHORIZED;
57
+ }, [modalState.status]);
58
+ useEffect(() => {
59
+ // TODO: maybe move this inside root
60
+ if (!modalState.modalVisibility) return;
61
+ if (typeof modalState.externalWalletsConfig === "object") {
62
+ var _modalState$externalW;
63
+ // auto connect to WC if not injected to generate QR code URI for mobile connection
64
+ const wcAvailable = (((_modalState$externalW = modalState.externalWalletsConfig[WALLET_CONNECTORS.WALLET_CONNECT_V2]) === null || _modalState$externalW === void 0 ? void 0 : _modalState$externalW.showOnModal) || false) !== false;
65
+ if (wcAvailable && !modalState.walletConnectUri && typeof handleExternalWalletClick === "function") {
66
+ handleExternalWalletClick({
67
+ connector: WALLET_CONNECTORS.WALLET_CONNECT_V2
68
+ });
69
+ }
70
+ }
71
+ }, [modalState, handleExternalWalletClick]);
72
+ const rootElement = /*#__PURE__*/jsx(Root, {
73
+ onCloseLoader: onCloseLoader
74
+ });
75
+ if (widgetType === WIDGET_TYPE.MODAL) {
76
+ return /*#__PURE__*/jsx(Modal, {
77
+ open: modalState.modalVisibility,
78
+ placement: "center",
79
+ padding: false,
80
+ showCloseIcon: showCloseIcon,
81
+ onClose: onCloseModal,
82
+ borderRadius: uiConfig.borderRadiusType,
83
+ children: modalState.modalVisibility && rootElement
84
+ });
85
+ }
86
+ return /*#__PURE__*/jsx(Embed, {
87
+ open: modalState.modalVisibility,
88
+ padding: false,
89
+ onClose: onCloseModal,
90
+ borderRadius: uiConfig.borderRadiusType,
91
+ children: modalState.modalVisibility && rootElement
92
+ });
93
+ }
94
+ function Widget(props) {
95
+ const {
96
+ stateListener
97
+ } = props;
98
+ return /*#__PURE__*/jsx(ModalStateProvider, {
99
+ stateListener: stateListener,
100
+ children: /*#__PURE__*/jsx(WidgetContent, {})
101
+ });
102
+ }
103
+
104
+ export { Widget as default };
@@ -0,0 +1,160 @@
1
+ import _objectSpread from '@babel/runtime/helpers/objectSpread2';
2
+ import { AUTH_CONNECTION } from '@web3auth/auth';
3
+ import { WIDGET_TYPE, log, cloneDeep, WALLET_CONNECTORS, CONNECTOR_NAMES } from '@web3auth/no-modal';
4
+ import deepmerge from 'deepmerge';
5
+ import { useMemo, useState, useEffect, useCallback, createContext, useContext } from 'react';
6
+ import { PAGES } from '../constants.js';
7
+ import { MODAL_STATUS } from '../interfaces.js';
8
+ import { useWidget } from './WidgetContext.js';
9
+ import { jsx } from 'react/jsx-runtime';
10
+
11
+ const initialModalState = {
12
+ // UI State
13
+ status: MODAL_STATUS.INITIALIZED,
14
+ modalVisibility: false,
15
+ externalWalletsVisibility: false,
16
+ currentPage: PAGES.LOGIN_OPTIONS,
17
+ // Loading State
18
+ postLoadingMessage: "",
19
+ detailedLoaderConnector: "",
20
+ detailedLoaderConnectorName: "",
21
+ // External Wallets State
22
+ hasExternalWallets: false,
23
+ externalWalletsInitialized: false,
24
+ showExternalWalletsOnly: false,
25
+ walletConnectUri: "",
26
+ metamaskConnectUri: "",
27
+ // Config State
28
+ socialLoginsConfig: {
29
+ loginMethods: {},
30
+ loginMethodsOrder: [],
31
+ uiConfig: {}
32
+ },
33
+ externalWalletsConfig: {}
34
+ };
35
+ const ModalStateContext = /*#__PURE__*/createContext(undefined);
36
+ const ModalStateProvider = ({
37
+ children,
38
+ stateListener
39
+ }) => {
40
+ const {
41
+ uiConfig,
42
+ handleExternalWalletClick,
43
+ handleSocialLoginClick,
44
+ handleShowExternalWallets: onShowExternalWallets
45
+ } = useWidget();
46
+ const initialVisibility = useMemo(() => uiConfig.widgetType === WIDGET_TYPE.EMBED, [uiConfig.widgetType]);
47
+ const [modalState, setModalState] = useState(_objectSpread(_objectSpread({}, initialModalState), {}, {
48
+ modalVisibility: initialVisibility
49
+ }));
50
+
51
+ // Listen for external state updates
52
+ useEffect(() => {
53
+ stateListener.on("STATE_UPDATED", newModalState => {
54
+ log.debug("state updated", newModalState);
55
+ setModalState(prevState => {
56
+ const mergedState = cloneDeep(deepmerge(prevState, newModalState, {
57
+ arrayMerge: (_prevState, newState) => newState
58
+ }));
59
+ return mergedState;
60
+ });
61
+ });
62
+ stateListener.emit("MOUNTED");
63
+ }, [stateListener]);
64
+
65
+ // Update visibility when initialVisibility changes
66
+ useEffect(() => {
67
+ // eslint-disable-next-line react-hooks/set-state-in-effect -- intentional
68
+ setModalState(prev => _objectSpread(_objectSpread({}, prev), {}, {
69
+ modalVisibility: initialVisibility
70
+ }));
71
+ }, [initialVisibility]);
72
+ const isEmailPrimary = useMemo(() => {
73
+ var _modalState$socialLog;
74
+ return ((_modalState$socialLog = modalState.socialLoginsConfig) === null || _modalState$socialLog === void 0 || (_modalState$socialLog = _modalState$socialLog.uiConfig) === null || _modalState$socialLog === void 0 ? void 0 : _modalState$socialLog.primaryButton) === "emailLogin";
75
+ }, [modalState.socialLoginsConfig]);
76
+ const isExternalPrimary = useMemo(() => {
77
+ var _modalState$socialLog2;
78
+ return ((_modalState$socialLog2 = modalState.socialLoginsConfig) === null || _modalState$socialLog2 === void 0 || (_modalState$socialLog2 = _modalState$socialLog2.uiConfig) === null || _modalState$socialLog2 === void 0 ? void 0 : _modalState$socialLog2.primaryButton) === "externalLogin";
79
+ }, [modalState.socialLoginsConfig]);
80
+
81
+ // Memo for checking if social logins are visible
82
+ const areSocialLoginsVisible = useMemo(() => {
83
+ var _modalState$socialLog3, _modalState$socialLog4;
84
+ if (modalState.showExternalWalletsOnly) return false;
85
+ if (Object.keys(((_modalState$socialLog3 = modalState.socialLoginsConfig) === null || _modalState$socialLog3 === void 0 ? void 0 : _modalState$socialLog3.loginMethods) || {}).length === 0) return false;
86
+ const isAnySocialLoginVisible = Object.entries(((_modalState$socialLog4 = modalState.socialLoginsConfig) === null || _modalState$socialLog4 === void 0 ? void 0 : _modalState$socialLog4.loginMethods) || {}).some(([k, v]) => ![AUTH_CONNECTION.EMAIL_PASSWORDLESS, AUTH_CONNECTION.SMS_PASSWORDLESS].includes(k) && v.showOnModal !== false);
87
+ return isAnySocialLoginVisible;
88
+ }, [modalState.showExternalWalletsOnly, modalState.socialLoginsConfig]);
89
+
90
+ // Memo for checking if email passwordless login is visible
91
+ const isEmailPasswordLessLoginVisible = useMemo(() => {
92
+ var _modalState$socialLog5;
93
+ return (_modalState$socialLog5 = modalState.socialLoginsConfig) === null || _modalState$socialLog5 === void 0 || (_modalState$socialLog5 = _modalState$socialLog5.loginMethods[AUTH_CONNECTION.EMAIL_PASSWORDLESS]) === null || _modalState$socialLog5 === void 0 ? void 0 : _modalState$socialLog5.showOnModal;
94
+ }, [modalState.socialLoginsConfig]);
95
+
96
+ // Memo for checking if SMS passwordless login is visible
97
+ const isSmsPasswordLessLoginVisible = useMemo(() => {
98
+ var _modalState$socialLog6;
99
+ return (_modalState$socialLog6 = modalState.socialLoginsConfig) === null || _modalState$socialLog6 === void 0 || (_modalState$socialLog6 = _modalState$socialLog6.loginMethods[AUTH_CONNECTION.SMS_PASSWORDLESS]) === null || _modalState$socialLog6 === void 0 ? void 0 : _modalState$socialLog6.showOnModal;
100
+ }, [modalState.socialLoginsConfig]);
101
+ const showPasswordLessInput = useMemo(() => isEmailPasswordLessLoginVisible || isSmsPasswordLessLoginVisible, [isEmailPasswordLessLoginVisible, isSmsPasswordLessLoginVisible]);
102
+ const showExternalWalletButton = useMemo(() => modalState.hasExternalWallets || !!modalState.externalWalletsConfig[WALLET_CONNECTORS.METAMASK], [modalState.hasExternalWallets, modalState.externalWalletsConfig]);
103
+ const preHandleExternalWalletClick = useCallback(params => {
104
+ const {
105
+ connector
106
+ } = params;
107
+ setModalState(prevState => _objectSpread(_objectSpread({}, prevState), {}, {
108
+ detailedLoaderConnector: connector,
109
+ detailedLoaderConnectorName: CONNECTOR_NAMES[connector]
110
+ }));
111
+ handleExternalWalletClick === null || handleExternalWalletClick === void 0 || handleExternalWalletClick(params);
112
+ }, [handleExternalWalletClick]);
113
+ const preHandleSocialLoginClick = useCallback(params => {
114
+ const {
115
+ loginParams
116
+ } = params;
117
+ setModalState(prevState => _objectSpread(_objectSpread({}, prevState), {}, {
118
+ detailedLoaderConnector: loginParams.authConnection,
119
+ detailedLoaderConnectorName: loginParams.name
120
+ }));
121
+ handleSocialLoginClick === null || handleSocialLoginClick === void 0 || handleSocialLoginClick(params);
122
+ }, [handleSocialLoginClick]);
123
+ const handleShowExternalWallets = useCallback(flag => {
124
+ setModalState(prevState => _objectSpread(_objectSpread({}, prevState), {}, {
125
+ externalWalletsVisibility: flag
126
+ }));
127
+ if (flag && onShowExternalWallets) onShowExternalWallets(modalState.externalWalletsInitialized);
128
+ }, [onShowExternalWallets, modalState.externalWalletsInitialized]);
129
+
130
+ // TODO: check if can further refactor this logic
131
+ const shouldShowLoginPage = useMemo(() => (areSocialLoginsVisible || showPasswordLessInput || !!modalState.externalWalletsConfig[WALLET_CONNECTORS.METAMASK]) && !modalState.externalWalletsVisibility, [areSocialLoginsVisible, showPasswordLessInput, modalState.externalWalletsVisibility, modalState.externalWalletsConfig]);
132
+ const value = useMemo(() => ({
133
+ modalState,
134
+ setModalState,
135
+ preHandleExternalWalletClick,
136
+ preHandleSocialLoginClick,
137
+ handleShowExternalWallets,
138
+ areSocialLoginsVisible,
139
+ isEmailPrimary,
140
+ isExternalPrimary,
141
+ isEmailPasswordLessLoginVisible,
142
+ isSmsPasswordLessLoginVisible,
143
+ showPasswordLessInput,
144
+ showExternalWalletButton,
145
+ shouldShowLoginPage
146
+ }), [modalState, preHandleExternalWalletClick, preHandleSocialLoginClick, handleShowExternalWallets, isEmailPrimary, isExternalPrimary, areSocialLoginsVisible, isEmailPasswordLessLoginVisible, isSmsPasswordLessLoginVisible, showPasswordLessInput, showExternalWalletButton, shouldShowLoginPage]);
147
+ return /*#__PURE__*/jsx(ModalStateContext.Provider, {
148
+ value: value,
149
+ children: children
150
+ });
151
+ };
152
+ const useModalState = () => {
153
+ const context = useContext(ModalStateContext);
154
+ if (!context) {
155
+ throw new Error("useModalState must be used within a ModalStateProvider");
156
+ }
157
+ return context;
158
+ };
159
+
160
+ export { ModalStateProvider, useModalState };
@@ -1,27 +1,65 @@
1
- import { createContext } from 'react';
1
+ import { useState, useMemo, createContext, useContext } from 'react';
2
2
  import { TOAST_TYPE } from '../interfaces.js';
3
+ import { jsx } from 'react/jsx-runtime';
3
4
 
4
- const RootContext = /*#__PURE__*/createContext({
5
- bodyState: {
6
- metamaskQrCode: {
7
- show: false,
8
- wallet: null
9
- },
10
- installLinks: {
11
- show: false,
12
- wallet: null
13
- },
14
- multiChainSelector: {
15
- show: false,
16
- wallet: null
17
- }
5
+ const initialBodyState = {
6
+ installLinks: {
7
+ show: false,
8
+ wallet: null
18
9
  },
19
- toast: {
20
- message: "",
21
- type: TOAST_TYPE.SUCCESS
10
+ multiChainSelector: {
11
+ show: false,
12
+ wallet: null
22
13
  },
23
- setBodyState: () => {},
24
- setToast: () => {}
25
- });
14
+ preSelectedWallet: null
15
+ };
16
+ const initialToastState = {
17
+ message: "",
18
+ type: TOAST_TYPE.SUCCESS
19
+ };
20
+ const RootContext = /*#__PURE__*/createContext(undefined);
21
+ const RootProvider = ({
22
+ children
23
+ }) => {
24
+ const [bodyState, setBodyState] = useState(initialBodyState);
25
+ const [toast, setToast] = useState(initialToastState);
26
+ const value = useMemo(() => ({
27
+ bodyState,
28
+ setBodyState,
29
+ toast,
30
+ setToast
31
+ }), [bodyState, toast]);
32
+ return /*#__PURE__*/jsx(RootContext.Provider, {
33
+ value: value,
34
+ children: children
35
+ });
36
+ };
37
+ const useRoot = () => {
38
+ const context = useContext(RootContext);
39
+ if (!context) {
40
+ throw new Error("useRoot must be used within a RootProvider");
41
+ }
42
+ return context;
43
+ };
44
+ const useBodyState = () => {
45
+ const {
46
+ bodyState,
47
+ setBodyState
48
+ } = useRoot();
49
+ return {
50
+ bodyState,
51
+ setBodyState
52
+ };
53
+ };
54
+ const useToast = () => {
55
+ const {
56
+ toast,
57
+ setToast
58
+ } = useRoot();
59
+ return {
60
+ toast,
61
+ setToast
62
+ };
63
+ };
26
64
 
27
- export { RootContext };
65
+ export { RootProvider, initialBodyState, initialToastState, useBodyState, useRoot, useToast };
@@ -0,0 +1,49 @@
1
+ import { CONNECTOR_INITIAL_AUTHENTICATION_MODE } from '@web3auth/no-modal';
2
+ import { useMemo, createContext, useContext } from 'react';
3
+ import { jsx } from 'react/jsx-runtime';
4
+
5
+ const WidgetContext = /*#__PURE__*/createContext(undefined);
6
+ const WidgetProvider = ({
7
+ children,
8
+ isDark = true,
9
+ deviceDetails,
10
+ uiConfig,
11
+ handleSocialLoginClick,
12
+ handleExternalWalletClick,
13
+ handleMobileVerifyConnect,
14
+ handleShowExternalWallets,
15
+ handleAcceptConsent,
16
+ handleDeclineConsent,
17
+ closeModal
18
+ }) => {
19
+ const appLogo = useMemo(() => {
20
+ return isDark ? uiConfig.logoDark : uiConfig.logoLight;
21
+ }, [isDark, uiConfig.logoDark, uiConfig.logoLight]);
22
+ const isConnectAndSignAuthenticationMode = useMemo(() => uiConfig.initialAuthenticationMode === CONNECTOR_INITIAL_AUTHENTICATION_MODE.CONNECT_AND_SIGN, [uiConfig.initialAuthenticationMode]);
23
+ return /*#__PURE__*/jsx(WidgetContext.Provider, {
24
+ value: {
25
+ isDark,
26
+ appLogo,
27
+ deviceDetails,
28
+ uiConfig,
29
+ isConnectAndSignAuthenticationMode,
30
+ handleSocialLoginClick,
31
+ handleExternalWalletClick,
32
+ handleMobileVerifyConnect,
33
+ handleShowExternalWallets,
34
+ handleAcceptConsent,
35
+ handleDeclineConsent,
36
+ closeModal
37
+ },
38
+ children: children
39
+ });
40
+ };
41
+ const useWidget = () => {
42
+ const context = useContext(WidgetContext);
43
+ if (!context) {
44
+ throw new Error("useWidget must be used within a WidgetProvider");
45
+ }
46
+ return context;
47
+ };
48
+
49
+ export { WidgetProvider, useWidget };