@web3auth/modal 9.6.0 → 10.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (150) hide show
  1. package/dist/lib.cjs/node_modules/style-inject/dist/style-inject.es.js +28 -0
  2. package/dist/lib.cjs/{config.js → packages/modal/src/config.js} +14 -14
  3. package/dist/lib.cjs/{index.js → packages/modal/src/index.js} +7 -0
  4. package/dist/lib.cjs/{modalManager.js → packages/modal/src/modalManager.js} +92 -92
  5. package/dist/lib.cjs/packages/modal/src/react/Web3AuthProvider.js +15 -0
  6. package/dist/lib.cjs/packages/modal/src/react/context/Web3AuthInnerContext.js +225 -0
  7. package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3Auth.js +15 -0
  8. package/dist/lib.cjs/packages/modal/src/react/index.js +12 -0
  9. package/dist/lib.cjs/packages/modal/src/ui/assets/arrow-left-dark.svg.js +7 -0
  10. package/dist/lib.cjs/packages/modal/src/ui/assets/arrow-left-light.svg.js +7 -0
  11. package/dist/lib.cjs/packages/modal/src/ui/assets/x-dark.svg.js +7 -0
  12. package/dist/lib.cjs/packages/modal/src/ui/assets/x-light.svg.js +7 -0
  13. package/dist/lib.cjs/packages/modal/src/ui/components/AdapterLoader.js +108 -0
  14. package/dist/lib.cjs/packages/modal/src/ui/components/Button/Button.js +34 -0
  15. package/dist/lib.cjs/packages/modal/src/ui/components/Button/styles.css.js +8 -0
  16. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletButton.js +44 -0
  17. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletConnect.js +67 -0
  18. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletDetails.js +34 -0
  19. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletHeader.js +46 -0
  20. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletInstall.js +167 -0
  21. package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallets.js +273 -0
  22. package/dist/lib.cjs/packages/modal/src/ui/components/Footer.js +20 -0
  23. package/dist/lib.cjs/packages/modal/src/ui/components/Header.js +81 -0
  24. package/dist/lib.cjs/packages/modal/src/ui/components/Icon.js +73 -0
  25. package/dist/lib.cjs/packages/modal/src/ui/components/Image.js +51 -0
  26. package/dist/lib.cjs/packages/modal/src/ui/components/Loader.js +59 -0
  27. package/dist/lib.cjs/packages/modal/src/ui/components/Modal.js +244 -0
  28. package/dist/lib.cjs/packages/modal/src/ui/components/SelfCustodyViaWeb3Auth.js +30 -0
  29. package/dist/lib.cjs/packages/modal/src/ui/components/SocialLoginPasswordless.js +141 -0
  30. package/dist/lib.cjs/packages/modal/src/ui/components/SocialLogins.js +148 -0
  31. package/dist/lib.cjs/packages/modal/src/ui/components/WalletConnect.js +84 -0
  32. package/dist/lib.cjs/packages/modal/src/ui/config.js +17 -0
  33. package/dist/lib.cjs/packages/modal/src/ui/context/ThemeContext.js +9 -0
  34. package/dist/lib.cjs/packages/modal/src/ui/css/web3auth.css.js +8 -0
  35. package/dist/lib.cjs/packages/modal/src/ui/i18n/dutch.json.js +84 -0
  36. package/dist/lib.cjs/packages/modal/src/ui/i18n/english.json.js +84 -0
  37. package/dist/lib.cjs/packages/modal/src/ui/i18n/french.json.js +82 -0
  38. package/dist/lib.cjs/packages/modal/src/ui/i18n/german.json.js +84 -0
  39. package/dist/lib.cjs/packages/modal/src/ui/i18n/japanese.json.js +84 -0
  40. package/dist/lib.cjs/packages/modal/src/ui/i18n/korean.json.js +84 -0
  41. package/dist/lib.cjs/packages/modal/src/ui/i18n/mandarin.json.js +84 -0
  42. package/dist/lib.cjs/packages/modal/src/ui/i18n/portuguese.json.js +84 -0
  43. package/dist/lib.cjs/packages/modal/src/ui/i18n/spanish.json.js +84 -0
  44. package/dist/lib.cjs/packages/modal/src/ui/i18n/turkish.json.js +84 -0
  45. package/dist/lib.cjs/packages/modal/src/ui/interfaces.js +26 -0
  46. package/dist/lib.cjs/packages/modal/src/ui/localeImport.js +25 -0
  47. package/dist/lib.cjs/packages/modal/src/ui/loginModal.js +309 -0
  48. package/dist/lib.cjs/packages/modal/src/ui/utils.js +71 -0
  49. package/dist/lib.cjs/packages/modal/src/vue/Web3AuthProvider.js +234 -0
  50. package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3Auth.js +12 -0
  51. package/dist/lib.cjs/packages/modal/src/vue/index.js +9 -0
  52. package/dist/lib.esm/node_modules/style-inject/dist/style-inject.es.js +26 -0
  53. package/dist/lib.esm/{config.js → packages/modal/src/config.js} +1 -1
  54. package/dist/lib.esm/{index.js → packages/modal/src/index.js} +1 -0
  55. package/dist/lib.esm/{modalManager.js → packages/modal/src/modalManager.js} +5 -5
  56. package/dist/lib.esm/packages/modal/src/react/Web3AuthProvider.js +13 -0
  57. package/dist/lib.esm/packages/modal/src/react/context/Web3AuthInnerContext.js +222 -0
  58. package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3Auth.js +13 -0
  59. package/dist/lib.esm/packages/modal/src/react/index.js +3 -0
  60. package/dist/lib.esm/packages/modal/src/ui/assets/arrow-left-dark.svg.js +5 -0
  61. package/dist/lib.esm/packages/modal/src/ui/assets/arrow-left-light.svg.js +5 -0
  62. package/dist/lib.esm/packages/modal/src/ui/assets/x-dark.svg.js +5 -0
  63. package/dist/lib.esm/packages/modal/src/ui/assets/x-light.svg.js +5 -0
  64. package/dist/lib.esm/packages/modal/src/ui/components/AdapterLoader.js +106 -0
  65. package/dist/lib.esm/packages/modal/src/ui/components/Button/Button.js +32 -0
  66. package/dist/lib.esm/packages/modal/src/ui/components/Button/styles.css.js +6 -0
  67. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletButton.js +42 -0
  68. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletConnect.js +65 -0
  69. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletDetails.js +32 -0
  70. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletHeader.js +44 -0
  71. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletInstall.js +165 -0
  72. package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallets.js +271 -0
  73. package/dist/lib.esm/packages/modal/src/ui/components/Footer.js +18 -0
  74. package/dist/lib.esm/packages/modal/src/ui/components/Header.js +79 -0
  75. package/dist/lib.esm/packages/modal/src/ui/components/Icon.js +71 -0
  76. package/dist/lib.esm/packages/modal/src/ui/components/Image.js +49 -0
  77. package/dist/lib.esm/packages/modal/src/ui/components/Loader.js +57 -0
  78. package/dist/lib.esm/packages/modal/src/ui/components/Modal.js +242 -0
  79. package/dist/lib.esm/packages/modal/src/ui/components/SelfCustodyViaWeb3Auth.js +28 -0
  80. package/dist/lib.esm/packages/modal/src/ui/components/SocialLoginPasswordless.js +139 -0
  81. package/dist/lib.esm/packages/modal/src/ui/components/SocialLogins.js +146 -0
  82. package/dist/lib.esm/packages/modal/src/ui/components/WalletConnect.js +82 -0
  83. package/dist/lib.esm/packages/modal/src/ui/config.js +13 -0
  84. package/dist/lib.esm/packages/modal/src/ui/context/ThemeContext.js +7 -0
  85. package/dist/lib.esm/packages/modal/src/ui/css/web3auth.css.js +6 -0
  86. package/dist/lib.esm/packages/modal/src/ui/i18n/dutch.json.js +79 -0
  87. package/dist/lib.esm/packages/modal/src/ui/i18n/english.json.js +79 -0
  88. package/dist/lib.esm/packages/modal/src/ui/i18n/french.json.js +77 -0
  89. package/dist/lib.esm/packages/modal/src/ui/i18n/german.json.js +79 -0
  90. package/dist/lib.esm/packages/modal/src/ui/i18n/japanese.json.js +79 -0
  91. package/dist/lib.esm/packages/modal/src/ui/i18n/korean.json.js +79 -0
  92. package/dist/lib.esm/packages/modal/src/ui/i18n/mandarin.json.js +79 -0
  93. package/dist/lib.esm/packages/modal/src/ui/i18n/portuguese.json.js +79 -0
  94. package/dist/lib.esm/packages/modal/src/ui/i18n/spanish.json.js +79 -0
  95. package/dist/lib.esm/packages/modal/src/ui/i18n/turkish.json.js +79 -0
  96. package/dist/lib.esm/packages/modal/src/ui/interfaces.js +20 -0
  97. package/dist/lib.esm/packages/modal/src/ui/localeImport.js +23 -0
  98. package/dist/lib.esm/packages/modal/src/ui/loginModal.js +307 -0
  99. package/dist/lib.esm/packages/modal/src/ui/utils.js +65 -0
  100. package/dist/lib.esm/packages/modal/src/vue/Web3AuthProvider.js +232 -0
  101. package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3Auth.js +10 -0
  102. package/dist/lib.esm/packages/modal/src/vue/index.js +2 -0
  103. package/dist/modal.cjs.js +5703 -420
  104. package/dist/modal.umd.min.js +1 -1
  105. package/dist/modal.umd.min.js.LICENSE.txt +54 -0
  106. package/dist/types/index.d.ts +1 -0
  107. package/dist/types/interface.d.ts +1 -1
  108. package/dist/types/modalManager.d.ts +2 -3
  109. package/dist/types/react/Web3AuthProvider.d.ts +3 -0
  110. package/dist/types/react/context/Web3AuthInnerContext.d.ts +4 -0
  111. package/dist/types/react/context/index.d.ts +1 -0
  112. package/dist/types/react/hooks/index.d.ts +1 -0
  113. package/dist/types/react/hooks/useWeb3Auth.d.ts +2 -0
  114. package/dist/types/react/index.d.ts +4 -0
  115. package/dist/types/react/interfaces.d.ts +18 -0
  116. package/dist/types/ui/components/AdapterLoader.d.ts +11 -0
  117. package/dist/types/ui/components/Button/Button.d.ts +16 -0
  118. package/dist/types/ui/components/Button/index.d.ts +1 -0
  119. package/dist/types/ui/components/ExternalWallet/ExternalWalletButton.d.ts +7 -0
  120. package/dist/types/ui/components/ExternalWallet/ExternalWalletConnect.d.ts +9 -0
  121. package/dist/types/ui/components/ExternalWallet/ExternalWalletDetails.d.ts +9 -0
  122. package/dist/types/ui/components/ExternalWallet/ExternalWalletHeader.d.ts +8 -0
  123. package/dist/types/ui/components/ExternalWallet/ExternalWalletInstall.d.ts +8 -0
  124. package/dist/types/ui/components/ExternalWallets.d.ts +17 -0
  125. package/dist/types/ui/components/Footer.d.ts +1 -0
  126. package/dist/types/ui/components/Header.d.ts +8 -0
  127. package/dist/types/ui/components/Icon.d.ts +9 -0
  128. package/dist/types/ui/components/Image.d.ts +12 -0
  129. package/dist/types/ui/components/Loader.d.ts +10 -0
  130. package/dist/types/ui/components/Modal.d.ts +16 -0
  131. package/dist/types/ui/components/SelfCustodyViaWeb3Auth.d.ts +1 -0
  132. package/dist/types/ui/components/SocialLoginPasswordless.d.ts +16 -0
  133. package/dist/types/ui/components/SocialLogins.d.ts +14 -0
  134. package/dist/types/ui/components/WalletConnect.d.ts +8 -0
  135. package/dist/types/ui/config.d.ts +4 -0
  136. package/dist/types/ui/context/ThemeContext.d.ts +3 -0
  137. package/dist/types/ui/helper/countryData.d.ts +7 -0
  138. package/dist/types/ui/i18n/index.d.ts +11 -0
  139. package/dist/types/ui/index.d.ts +4 -0
  140. package/dist/types/ui/interfaces.d.ts +106 -0
  141. package/dist/types/ui/localeImport.d.ts +3 -0
  142. package/dist/types/ui/loginModal.d.ts +27 -0
  143. package/dist/types/ui/utils.d.ts +12 -0
  144. package/dist/types/vue/Web3AuthProvider.d.ts +13 -0
  145. package/dist/types/vue/composables/index.d.ts +1 -0
  146. package/dist/types/vue/composables/useWeb3Auth.d.ts +2 -0
  147. package/dist/types/vue/index.d.ts +3 -0
  148. package/dist/types/vue/interfaces.d.ts +45 -0
  149. package/package.json +100 -43
  150. package/dist/modal.esm.js +0 -513
package/dist/modal.esm.js DELETED
@@ -1,513 +0,0 @@
1
- import { CHAIN_NAMESPACES, SOLANA_ADAPTERS, EVM_ADAPTERS, cloneDeep, WalletInitializationError, fetchProjectConfig, log, fetchWalletRegistry, WALLET_ADAPTERS, ADAPTER_NAMES, getChainConfig, ADAPTER_CATEGORY, ADAPTER_STATUS, ADAPTER_EVENTS } from '@web3auth/base';
2
- import _objectSpread from '@babel/runtime/helpers/objectSpread2';
3
- import _defineProperty from '@babel/runtime/helpers/defineProperty';
4
- import { LOGIN_PROVIDER, getAuthDefaultOptions, AuthAdapter } from '@web3auth/auth-adapter';
5
- import { CommonJRPCProvider } from '@web3auth/base-provider';
6
- import { Web3AuthNoModal } from '@web3auth/no-modal';
7
- import { getUserLanguage, LoginModal, capitalizeFirstLetter, getAdapterSocialLogins, LOGIN_MODAL_EVENTS, AUTH_PROVIDERS } from '@web3auth/ui';
8
- import deepmerge from 'deepmerge';
9
-
10
- const defaultSolanaDappModalConfig = {
11
- chainNamespace: CHAIN_NAMESPACES.SOLANA,
12
- adapters: {
13
- [SOLANA_ADAPTERS.TORUS_SOLANA]: {
14
- label: "Torus Wallet",
15
- showOnModal: true,
16
- showOnMobile: true,
17
- showOnDesktop: true
18
- },
19
- [SOLANA_ADAPTERS.AUTH]: {
20
- label: "Auth",
21
- showOnModal: true,
22
- showOnMobile: true,
23
- showOnDesktop: true
24
- }
25
- }
26
- };
27
- const defaultEvmDappModalConfig = {
28
- chainNamespace: CHAIN_NAMESPACES.EIP155,
29
- adapters: {
30
- [EVM_ADAPTERS.TORUS_EVM]: {
31
- label: "Torus Wallet",
32
- showOnModal: true,
33
- showOnMobile: true,
34
- showOnDesktop: true
35
- },
36
- [EVM_ADAPTERS.AUTH]: {
37
- label: "Auth",
38
- showOnModal: true,
39
- showOnMobile: true,
40
- showOnDesktop: true
41
- },
42
- [EVM_ADAPTERS.WALLET_CONNECT_V2]: {
43
- label: "Wallet Connect",
44
- showOnModal: true,
45
- showOnMobile: true,
46
- showOnDesktop: true
47
- }
48
- }
49
- };
50
- const defaultSolanaWalletModalConfig = {
51
- chainNamespace: CHAIN_NAMESPACES.SOLANA,
52
- adapters: {
53
- [SOLANA_ADAPTERS.AUTH]: {
54
- label: "Auth",
55
- showOnModal: true,
56
- showOnMobile: true,
57
- showOnDesktop: true
58
- }
59
- }
60
- };
61
- const defaultEvmWalletModalConfig = {
62
- chainNamespace: CHAIN_NAMESPACES.EIP155,
63
- adapters: {
64
- [EVM_ADAPTERS.AUTH]: {
65
- label: "Auth",
66
- showOnModal: true,
67
- showOnMobile: true,
68
- showOnDesktop: true
69
- }
70
- }
71
- };
72
- const defaultOtherModalConfig = {
73
- chainNamespace: CHAIN_NAMESPACES.OTHER,
74
- adapters: {
75
- [EVM_ADAPTERS.AUTH]: {
76
- label: "Auth",
77
- showOnModal: true,
78
- showOnMobile: true,
79
- showOnDesktop: true
80
- }
81
- }
82
- };
83
- const walletRegistryUrl = "https://assets.web3auth.io/v1/wallet-registry.json";
84
-
85
- class Web3Auth extends Web3AuthNoModal {
86
- constructor(options) {
87
- super(options);
88
- _defineProperty(this, "loginModal", void 0);
89
- _defineProperty(this, "options", void 0);
90
- _defineProperty(this, "modalConfig", cloneDeep(defaultOtherModalConfig));
91
- this.options = _objectSpread({}, options);
92
- if (!this.options.uiConfig) this.options.uiConfig = {};
93
- if (!this.coreOptions.privateKeyProvider) throw WalletInitializationError.invalidParams("privateKeyProvider is required");
94
- }
95
- setModalConfig(modalConfig) {
96
- super.checkInitRequirements();
97
- this.modalConfig = modalConfig;
98
- }
99
- async initModal(params) {
100
- var _params;
101
- super.checkInitRequirements();
102
- let projectConfig;
103
- try {
104
- var _this$options$account;
105
- projectConfig = await fetchProjectConfig(this.options.clientId, this.options.web3AuthNetwork, (_this$options$account = this.options.accountAbstractionProvider) === null || _this$options$account === void 0 ? void 0 : _this$options$account.config.smartAccountInit.name);
106
- } catch (e) {
107
- log.error("Failed to fetch project configurations", e);
108
- throw WalletInitializationError.notReady("failed to fetch project configurations", e);
109
- }
110
- const {
111
- whitelabel
112
- } = projectConfig;
113
- this.options.uiConfig = deepmerge(cloneDeep(whitelabel || {}), this.options.uiConfig || {});
114
- if (!this.options.uiConfig.defaultLanguage) this.options.uiConfig.defaultLanguage = getUserLanguage(this.options.uiConfig.defaultLanguage);
115
- if (!this.options.uiConfig.mode) this.options.uiConfig.mode = "light";
116
- let walletRegistry = {
117
- others: {},
118
- default: {}
119
- };
120
- if (!((_params = params) !== null && _params !== void 0 && _params.hideWalletDiscovery)) {
121
- try {
122
- walletRegistry = await fetchWalletRegistry(walletRegistryUrl);
123
- } catch (e) {
124
- log.error("Failed to fetch wallet registry", e);
125
- }
126
- }
127
- this.loginModal = new LoginModal(_objectSpread(_objectSpread({}, this.options.uiConfig), {}, {
128
- adapterListener: this,
129
- chainNamespace: this.options.chainConfig.chainNamespace,
130
- walletRegistry
131
- }));
132
- this.subscribeToLoginModalEvents();
133
- const {
134
- sms_otp_enabled: smsOtpEnabled,
135
- whitelist,
136
- key_export_enabled: keyExportEnabled
137
- } = projectConfig;
138
- if (smsOtpEnabled !== undefined) {
139
- var _params2, _params$modalConfig$W;
140
- const adapterConfig = {
141
- [WALLET_ADAPTERS.AUTH]: {
142
- label: WALLET_ADAPTERS.AUTH,
143
- loginMethods: {
144
- [LOGIN_PROVIDER.SMS_PASSWORDLESS]: {
145
- name: LOGIN_PROVIDER.SMS_PASSWORDLESS,
146
- showOnModal: smsOtpEnabled,
147
- showOnDesktop: smsOtpEnabled,
148
- showOnMobile: smsOtpEnabled
149
- }
150
- }
151
- }
152
- };
153
- if (!((_params2 = params) !== null && _params2 !== void 0 && _params2.modalConfig)) params = {
154
- modalConfig: {}
155
- };
156
- const localSmsOtpEnabled = (_params$modalConfig$W = params.modalConfig[WALLET_ADAPTERS.AUTH]) === null || _params$modalConfig$W === void 0 || (_params$modalConfig$W = _params$modalConfig$W.loginMethods) === null || _params$modalConfig$W === void 0 || (_params$modalConfig$W = _params$modalConfig$W[LOGIN_PROVIDER.SMS_PASSWORDLESS]) === null || _params$modalConfig$W === void 0 ? void 0 : _params$modalConfig$W.showOnModal;
157
- if (localSmsOtpEnabled === true && smsOtpEnabled === false) {
158
- throw WalletInitializationError.invalidParams("must enable sms otp on dashboard in order to utilise it");
159
- }
160
- params.modalConfig = deepmerge(adapterConfig, cloneDeep(params.modalConfig));
161
- }
162
- await this.loginModal.initModal();
163
- const providedChainConfig = this.options.chainConfig;
164
- // merge default adapters with the custom configured adapters.
165
- const allAdapters = [...new Set([...Object.keys(this.modalConfig.adapters || {}), ...Object.keys(this.walletAdapters)])];
166
- const adapterConfigurationPromises = allAdapters.map(async adapterName => {
167
- var _this$modalConfig$ada, _params3, _this$modalConfig$ada2, _this$modalConfig$ada3;
168
- // start with the default config of adapter.
169
- let adapterConfig = ((_this$modalConfig$ada = this.modalConfig.adapters) === null || _this$modalConfig$ada === void 0 ? void 0 : _this$modalConfig$ada[adapterName]) || {
170
- label: ADAPTER_NAMES[adapterName] || adapterName.split("-").map(capitalizeFirstLetter).join(" "),
171
- showOnModal: true,
172
- showOnMobile: true,
173
- showOnDesktop: true
174
- };
175
-
176
- // override the default config of adapter if some config is being provided by the user.
177
- if ((_params3 = params) !== null && _params3 !== void 0 && (_params3 = _params3.modalConfig) !== null && _params3 !== void 0 && _params3[adapterName]) {
178
- adapterConfig = _objectSpread(_objectSpread({}, adapterConfig), params.modalConfig[adapterName]);
179
- }
180
- this.modalConfig.adapters[adapterName] = adapterConfig;
181
-
182
- // check if adapter is configured/added by user and exist in walletAdapters map.
183
- const adapter = this.walletAdapters[adapterName];
184
- log.debug("adapter config", adapterName, (_this$modalConfig$ada2 = this.modalConfig.adapters) === null || _this$modalConfig$ada2 === void 0 ? void 0 : _this$modalConfig$ada2[adapterName].showOnModal, adapter);
185
-
186
- // if adapter is not custom configured then check if it is available in default adapters.
187
- // and if adapter is not hidden by user
188
- if (!adapter && (_this$modalConfig$ada3 = this.modalConfig.adapters) !== null && _this$modalConfig$ada3 !== void 0 && _this$modalConfig$ada3[adapterName].showOnModal) {
189
- // Adapters to be shown on modal should be pre-configured.
190
- if (adapterName === WALLET_ADAPTERS.AUTH) {
191
- var _this$coreOptions$cha;
192
- const defaultOptions = getAuthDefaultOptions();
193
- const {
194
- clientId,
195
- useCoreKitKey,
196
- chainConfig,
197
- web3AuthNetwork,
198
- sessionTime,
199
- privateKeyProvider
200
- } = this.coreOptions;
201
- const finalChainConfig = _objectSpread(_objectSpread({}, getChainConfig(providedChainConfig.chainNamespace, (_this$coreOptions$cha = this.coreOptions.chainConfig) === null || _this$coreOptions$cha === void 0 ? void 0 : _this$coreOptions$cha.chainId)), chainConfig);
202
- if (!privateKeyProvider) {
203
- throw WalletInitializationError.invalidParams("privateKeyProvider is required");
204
- }
205
- const finalAuthAdapterSettings = _objectSpread(_objectSpread({}, defaultOptions.adapterSettings), {}, {
206
- clientId,
207
- network: web3AuthNetwork,
208
- whiteLabel: this.options.uiConfig
209
- });
210
- if (smsOtpEnabled !== undefined) {
211
- finalAuthAdapterSettings.loginConfig = {
212
- [LOGIN_PROVIDER.SMS_PASSWORDLESS]: {
213
- showOnModal: smsOtpEnabled,
214
- showOnDesktop: smsOtpEnabled,
215
- showOnMobile: smsOtpEnabled,
216
- showOnSocialBackupFactor: smsOtpEnabled
217
- }
218
- };
219
- }
220
- if (whitelist) {
221
- finalAuthAdapterSettings.originData = whitelist.signed_urls;
222
- }
223
- if (this.options.uiConfig.uxMode) {
224
- finalAuthAdapterSettings.uxMode = this.options.uiConfig.uxMode;
225
- }
226
- const authAdapter = new AuthAdapter(_objectSpread(_objectSpread({}, defaultOptions), {}, {
227
- clientId,
228
- useCoreKitKey,
229
- chainConfig: _objectSpread({}, finalChainConfig),
230
- adapterSettings: finalAuthAdapterSettings,
231
- sessionTime,
232
- web3AuthNetwork,
233
- privateKeyProvider
234
- }));
235
- this.walletAdapters[adapterName] = authAdapter;
236
- return adapterName;
237
- }
238
- throw WalletInitializationError.invalidParams(`Adapter ${adapterName} is not configured`);
239
- } else if ((adapter === null || adapter === void 0 ? void 0 : adapter.type) === ADAPTER_CATEGORY.IN_APP || (adapter === null || adapter === void 0 ? void 0 : adapter.type) === ADAPTER_CATEGORY.EXTERNAL || adapterName === this.cachedAdapter) {
240
- var _this$modalConfig$ada4;
241
- if (!((_this$modalConfig$ada4 = this.modalConfig.adapters) !== null && _this$modalConfig$ada4 !== void 0 && _this$modalConfig$ada4[adapterName].showOnModal)) return;
242
- // add client id to adapter, same web3auth client id can be used in adapter.
243
- // this id is being overridden if user is also passing client id in adapter's constructor.
244
- this.walletAdapters[adapterName].setAdapterSettings({
245
- clientId: this.options.clientId,
246
- sessionTime: this.options.sessionTime,
247
- web3AuthNetwork: this.options.web3AuthNetwork,
248
- useCoreKitKey: this.coreOptions.useCoreKitKey
249
- });
250
-
251
- // if adapter doesn't have any chainConfig then we will set the chainConfig based of passed chainNamespace
252
- // and chainNamespace.
253
- if (!adapter.chainConfigProxy) {
254
- var _this$coreOptions$cha2;
255
- const chainConfig = _objectSpread(_objectSpread({}, getChainConfig(providedChainConfig.chainNamespace, (_this$coreOptions$cha2 = this.coreOptions.chainConfig) === null || _this$coreOptions$cha2 === void 0 ? void 0 : _this$coreOptions$cha2.chainId)), this.coreOptions.chainConfig);
256
- this.walletAdapters[adapterName].setAdapterSettings({
257
- chainConfig
258
- });
259
- }
260
- if (adapterName === WALLET_ADAPTERS.AUTH) {
261
- var _this$options$uiConfi;
262
- const authAdapter = this.walletAdapters[adapterName];
263
- if (this.coreOptions.privateKeyProvider) {
264
- if (authAdapter.currentChainNamespace !== this.coreOptions.privateKeyProvider.currentChainConfig.chainNamespace) {
265
- throw WalletInitializationError.incompatibleChainNameSpace("private key provider is not compatible with provided chainNamespace for auth adapter");
266
- }
267
- authAdapter.setAdapterSettings({
268
- privateKeyProvider: this.coreOptions.privateKeyProvider
269
- });
270
- }
271
- if (smsOtpEnabled !== undefined) {
272
- authAdapter.setAdapterSettings({
273
- loginConfig: {
274
- [LOGIN_PROVIDER.SMS_PASSWORDLESS]: {
275
- showOnModal: smsOtpEnabled,
276
- showOnDesktop: smsOtpEnabled,
277
- showOnMobile: smsOtpEnabled,
278
- showOnSocialBackupFactor: smsOtpEnabled
279
- }
280
- }
281
- });
282
- }
283
- if (whitelist) {
284
- authAdapter.setAdapterSettings({
285
- originData: whitelist.signed_urls
286
- });
287
- }
288
- if ((_this$options$uiConfi = this.options.uiConfig) !== null && _this$options$uiConfi !== void 0 && _this$options$uiConfi.uxMode) {
289
- authAdapter.setAdapterSettings({
290
- uxMode: this.options.uiConfig.uxMode
291
- });
292
- }
293
- authAdapter.setAdapterSettings({
294
- whiteLabel: this.options.uiConfig
295
- });
296
- if (!authAdapter.privateKeyProvider) {
297
- throw WalletInitializationError.invalidParams("privateKeyProvider is required for auth adapter");
298
- }
299
- } else if (adapterName === WALLET_ADAPTERS.WALLET_CONNECT_V2) {
300
- const walletConnectAdapter = this.walletAdapters[adapterName];
301
- const {
302
- wallet_connect_enabled: walletConnectEnabled,
303
- wallet_connect_project_id: walletConnectProjectId
304
- } = projectConfig;
305
- if (walletConnectEnabled === false) {
306
- var _this$modalConfig$ada5, _this$modalConfig$ada6, _this$modalConfig$ada7;
307
- // override user specified config by hiding wallet connect
308
- this.modalConfig.adapters = _objectSpread(_objectSpread({}, (_this$modalConfig$ada5 = this.modalConfig.adapters) !== null && _this$modalConfig$ada5 !== void 0 ? _this$modalConfig$ada5 : {}), {}, {
309
- [WALLET_ADAPTERS.WALLET_CONNECT_V2]: _objectSpread(_objectSpread({}, (_this$modalConfig$ada6 = (_this$modalConfig$ada7 = this.modalConfig.adapters) === null || _this$modalConfig$ada7 === void 0 ? void 0 : _this$modalConfig$ada7[WALLET_ADAPTERS.WALLET_CONNECT_V2]) !== null && _this$modalConfig$ada6 !== void 0 ? _this$modalConfig$ada6 : {}), {}, {
310
- showOnModal: false
311
- })
312
- });
313
- this.modalConfig.adapters[WALLET_ADAPTERS.WALLET_CONNECT_V2].showOnModal = false;
314
- } else {
315
- var _walletConnectAdapter;
316
- if (!(walletConnectAdapter !== null && walletConnectAdapter !== void 0 && (_walletConnectAdapter = walletConnectAdapter.adapterOptions) !== null && _walletConnectAdapter !== void 0 && (_walletConnectAdapter = _walletConnectAdapter.adapterSettings) !== null && _walletConnectAdapter !== void 0 && (_walletConnectAdapter = _walletConnectAdapter.walletConnectInitOptions) !== null && _walletConnectAdapter !== void 0 && _walletConnectAdapter.projectId) && !walletConnectProjectId) throw WalletInitializationError.invalidParams("Invalid wallet connect project id. Please configure it on the dashboard");
317
- if (walletConnectProjectId) {
318
- walletConnectAdapter.setAdapterSettings({
319
- adapterSettings: {
320
- walletConnectInitOptions: {
321
- projectId: walletConnectProjectId
322
- }
323
- }
324
- });
325
- }
326
- }
327
- }
328
- return adapterName;
329
- }
330
- });
331
- const adapterNames = await Promise.all(adapterConfigurationPromises);
332
- const hasInAppWallets = Object.values(this.walletAdapters).some(adapter => {
333
- var _this$modalConfig$ada8, _this$modalConfig$ada9, _adapter$name;
334
- if (adapter.type !== ADAPTER_CATEGORY.IN_APP) return false;
335
- if (((_this$modalConfig$ada8 = this.modalConfig.adapters) === null || _this$modalConfig$ada8 === void 0 || (_this$modalConfig$ada8 = _this$modalConfig$ada8[adapter.name]) === null || _this$modalConfig$ada8 === void 0 ? void 0 : _this$modalConfig$ada8.showOnModal) !== true) return false;
336
- if (!((_this$modalConfig$ada9 = this.modalConfig.adapters) !== null && _this$modalConfig$ada9 !== void 0 && (_this$modalConfig$ada9 = _this$modalConfig$ada9[adapter.name]) !== null && _this$modalConfig$ada9 !== void 0 && _this$modalConfig$ada9.loginMethods)) return true;
337
- const mergedLoginMethods = getAdapterSocialLogins(adapter.name, (_adapter$name = this.modalConfig.adapters[adapter.name]) === null || _adapter$name === void 0 ? void 0 : _adapter$name.loginMethods);
338
- if (Object.values(mergedLoginMethods).some(method => method.showOnModal)) return true;
339
- return false;
340
- });
341
- log.debug(hasInAppWallets, this.walletAdapters, adapterNames, "hasInAppWallets");
342
-
343
- // Now, initialize the adapters.
344
- const initPromises = adapterNames.map(async adapterName => {
345
- if (!adapterName) return;
346
- try {
347
- const adapter = this.walletAdapters[adapterName];
348
- // only initialize a external adapter here if it is a cached adapter.
349
- if (this.cachedAdapter !== adapterName && adapter.type === ADAPTER_CATEGORY.EXTERNAL) {
350
- return;
351
- }
352
- // in-app wallets or cached wallet (being connected or already connected) are initialized first.
353
- // if adapter is configured then only initialize in app or cached adapter.
354
- // external wallets are initialized on INIT_EXTERNAL_WALLET event.
355
- this.subscribeToAdapterEvents(adapter);
356
- if (adapter.status === ADAPTER_STATUS.NOT_READY) await adapter.init({
357
- autoConnect: this.cachedAdapter === adapterName
358
- });
359
- // note: not adding cachedWallet to modal if it is external wallet.
360
- // adding it later if no in-app wallets are available.
361
- if (adapter.type === ADAPTER_CATEGORY.IN_APP) {
362
- this.initializeInAppWallet(adapterName);
363
- }
364
- } catch (error) {
365
- log.error(error, "error while initializing adapter ", adapterName);
366
- }
367
- });
368
- this.commonJRPCProvider = await CommonJRPCProvider.getProviderInstance({
369
- chainConfig: this.coreOptions.chainConfig
370
- });
371
- if (typeof keyExportEnabled === "boolean") {
372
- this.coreOptions.privateKeyProvider.setKeyExportFlag(keyExportEnabled);
373
- // dont know if we need to do this.
374
- this.commonJRPCProvider.setKeyExportFlag(keyExportEnabled);
375
- }
376
- await Promise.all(initPromises);
377
- if (this.status === ADAPTER_STATUS.NOT_READY) {
378
- this.status = ADAPTER_STATUS.READY;
379
- this.emit(ADAPTER_EVENTS.READY);
380
- }
381
- const hasExternalWallets = allAdapters.some(adapterName => {
382
- var _params4, _this$walletAdapters$, _this$modalConfig$ada10;
383
- // if wallet connect adapter is available but hideWalletDiscovery is true then don't consider it as external wallet
384
- if (adapterName === WALLET_ADAPTERS.WALLET_CONNECT_V2 && (_params4 = params) !== null && _params4 !== void 0 && _params4.hideWalletDiscovery) return false;
385
- return ((_this$walletAdapters$ = this.walletAdapters[adapterName]) === null || _this$walletAdapters$ === void 0 ? void 0 : _this$walletAdapters$.type) === ADAPTER_CATEGORY.EXTERNAL && ((_this$modalConfig$ada10 = this.modalConfig.adapters) === null || _this$modalConfig$ada10 === void 0 ? void 0 : _this$modalConfig$ada10[adapterName].showOnModal);
386
- });
387
- if (hasExternalWallets) {
388
- this.loginModal.initExternalWalletContainer();
389
- }
390
-
391
- // variable to check if we have any in app wallets
392
- // currently all default in app and external wallets can be hidden or shown based on config.
393
- if (!hasInAppWallets && hasExternalWallets) {
394
- // if no in app wallet is available then initialize external wallets in modal
395
- await this.initExternalWalletAdapters(false, {
396
- showExternalWalletsOnly: true
397
- });
398
- }
399
- }
400
- async connect() {
401
- if (!this.loginModal) throw WalletInitializationError.notReady("Login modal is not initialized");
402
- // if already connected return provider
403
- if (this.connectedAdapterName && this.status === ADAPTER_STATUS.CONNECTED && this.provider) return this.provider;
404
- this.loginModal.open();
405
- return new Promise((resolve, reject) => {
406
- this.once(ADAPTER_EVENTS.CONNECTED, () => {
407
- return resolve(this.provider);
408
- });
409
- this.once(ADAPTER_EVENTS.ERRORED, err => {
410
- return reject(err);
411
- });
412
- this.once(LOGIN_MODAL_EVENTS.MODAL_VISIBILITY, visibility => {
413
- // modal is closed but user is not connected to any wallet.
414
- if (!visibility && this.status !== ADAPTER_STATUS.CONNECTED) {
415
- return reject(new Error("User closed the modal"));
416
- }
417
- });
418
- });
419
- }
420
- async initExternalWalletAdapters(externalWalletsInitialized, options) {
421
- if (externalWalletsInitialized) return;
422
- const adaptersConfig = {};
423
- // we do it like this because we don't want one slow adapter to delay the load of the entire external wallet section.
424
- Object.keys(this.walletAdapters).forEach(async adapterName => {
425
- const adapter = this.walletAdapters[adapterName];
426
- if ((adapter === null || adapter === void 0 ? void 0 : adapter.type) === ADAPTER_CATEGORY.EXTERNAL) {
427
- log.debug("init external wallet", this.cachedAdapter, adapterName, adapter.status);
428
- this.subscribeToAdapterEvents(adapter);
429
- // we are not initializing cached adapter here as it is already being initialized in initModal before.
430
- if (this.cachedAdapter === adapterName) {
431
- return;
432
- }
433
- if (adapter.status === ADAPTER_STATUS.NOT_READY) {
434
- await adapter.init({
435
- autoConnect: this.cachedAdapter === adapterName
436
- }).then(() => {
437
- const adapterModalConfig = this.modalConfig.adapters[adapterName];
438
- adaptersConfig[adapterName] = _objectSpread(_objectSpread({}, adapterModalConfig), {}, {
439
- isInjected: adapter.isInjected
440
- });
441
- this.loginModal.addWalletLogins(adaptersConfig, {
442
- showExternalWalletsOnly: !!(options !== null && options !== void 0 && options.showExternalWalletsOnly)
443
- });
444
- return undefined;
445
- }).catch(error => log.error(error, "error while initializing adapter", adapterName));
446
- } else if (adapter.status === ADAPTER_STATUS.READY || adapter.status === ADAPTER_STATUS.CONNECTING) {
447
- // we use connecting status for wallet connect
448
- const adapterModalConfig = this.modalConfig.adapters[adapterName];
449
- adaptersConfig[adapterName] = _objectSpread(_objectSpread({}, adapterModalConfig), {}, {
450
- isInjected: adapter.isInjected
451
- });
452
- this.loginModal.addWalletLogins(adaptersConfig, {
453
- showExternalWalletsOnly: !!(options !== null && options !== void 0 && options.showExternalWalletsOnly)
454
- });
455
- }
456
- }
457
- });
458
- }
459
- initializeInAppWallet(adapterName) {
460
- log.info("adapterInitResults", adapterName);
461
- if (this.walletAdapters[adapterName].type === ADAPTER_CATEGORY.IN_APP) {
462
- var _adapterName, _this$options$uiConfi2, _this$options$uiConfi3, _this$options$uiConfi4;
463
- this.loginModal.addSocialLogins(adapterName, getAdapterSocialLogins(adapterName, (_adapterName = this.modalConfig.adapters[adapterName]) === null || _adapterName === void 0 ? void 0 : _adapterName.loginMethods), ((_this$options$uiConfi2 = this.options.uiConfig) === null || _this$options$uiConfi2 === void 0 ? void 0 : _this$options$uiConfi2.loginMethodsOrder) || AUTH_PROVIDERS, _objectSpread(_objectSpread({}, this.options.uiConfig), {}, {
464
- loginGridCol: ((_this$options$uiConfi3 = this.options.uiConfig) === null || _this$options$uiConfi3 === void 0 ? void 0 : _this$options$uiConfi3.loginGridCol) || 3,
465
- primaryButton: ((_this$options$uiConfi4 = this.options.uiConfig) === null || _this$options$uiConfi4 === void 0 ? void 0 : _this$options$uiConfi4.primaryButton) || "socialLogin"
466
- }));
467
- }
468
- }
469
- subscribeToLoginModalEvents() {
470
- this.loginModal.on(LOGIN_MODAL_EVENTS.LOGIN, async params => {
471
- try {
472
- await this.connectTo(params.adapter, params.loginParams);
473
- } catch (error) {
474
- log.error(`Error while connecting to adapter: ${params.adapter}`, error);
475
- }
476
- });
477
- this.loginModal.on(LOGIN_MODAL_EVENTS.INIT_EXTERNAL_WALLETS, async params => {
478
- await this.initExternalWalletAdapters(params.externalWalletsInitialized);
479
- });
480
- this.loginModal.on(LOGIN_MODAL_EVENTS.DISCONNECT, async () => {
481
- try {
482
- await this.logout();
483
- } catch (error) {
484
- log.error(`Error while disconnecting`, error);
485
- }
486
- });
487
- this.loginModal.on(LOGIN_MODAL_EVENTS.MODAL_VISIBILITY, async visibility => {
488
- log.debug("is login modal visible", visibility);
489
- this.emit(LOGIN_MODAL_EVENTS.MODAL_VISIBILITY, visibility);
490
- const adapter = this.walletAdapters[WALLET_ADAPTERS.WALLET_CONNECT_V2];
491
- if (adapter) {
492
- const walletConnectStatus = adapter === null || adapter === void 0 ? void 0 : adapter.status;
493
- log.debug("trying refreshing wc session", visibility, walletConnectStatus);
494
- if (visibility && (walletConnectStatus === ADAPTER_STATUS.READY || walletConnectStatus === ADAPTER_STATUS.CONNECTING)) {
495
- log.debug("refreshing wc session");
496
-
497
- // refreshing session for wallet connect whenever modal is opened.
498
- try {
499
- adapter.connect();
500
- } catch (error) {
501
- log.error(`Error while disconnecting to wallet connect in core`, error);
502
- }
503
- }
504
- if (!visibility && this.status === ADAPTER_STATUS.CONNECTED && (walletConnectStatus === ADAPTER_STATUS.READY || walletConnectStatus === ADAPTER_STATUS.CONNECTING)) {
505
- log.debug("this stops wc adapter from trying to reconnect once proposal expires");
506
- adapter.status = ADAPTER_STATUS.READY;
507
- }
508
- }
509
- });
510
- }
511
- }
512
-
513
- export { Web3Auth, defaultEvmDappModalConfig, defaultEvmWalletModalConfig, defaultOtherModalConfig, defaultSolanaDappModalConfig, defaultSolanaWalletModalConfig, walletRegistryUrl };