@talken/talkenkit 2.3.5 → 2.3.7

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 (110) hide show
  1. package/dist/components/ChainIndicator/ChainIndicator.css.d.ts +4 -0
  2. package/dist/components/ChainIndicator/ChainIndicator.d.ts +53 -0
  3. package/dist/components/ChainIndicator/index.d.ts +2 -0
  4. package/dist/components/ChainSelector/ChainSelector.css.d.ts +5 -0
  5. package/dist/components/ChainSelector/ChainSelector.d.ts +38 -0
  6. package/dist/components/ChainSelector/index.d.ts +2 -0
  7. package/dist/components/ConnectButton/ConnectButtonRenderer.d.ts +9 -0
  8. package/dist/components/ConnectOptions/DesktopOptions.d.ts +5 -1
  9. package/dist/components/ConnectOptions/MultiChainConnectOptions.d.ts +31 -0
  10. package/dist/components/ConnectOptions/index.d.ts +3 -0
  11. package/dist/components/ModalSelection/ModalSelection.d.ts +2 -1
  12. package/dist/components/ProfileDetails/ProfileDetails.d.ts +1 -2
  13. package/dist/components/RainbowKitProvider/RainbowKitProvider.d.ts +8 -1
  14. package/dist/components/SolanaWalletList/SolanaWalletList.css.d.ts +7 -0
  15. package/dist/components/SolanaWalletList/SolanaWalletList.d.ts +32 -0
  16. package/dist/components/SolanaWalletList/index.d.ts +2 -0
  17. package/dist/contexts/MultiChainContext.d.ts +68 -0
  18. package/dist/contexts/index.d.ts +7 -0
  19. package/dist/index.css +105 -0
  20. package/dist/index.d.ts +12 -0
  21. package/dist/index.js +1445 -899
  22. package/dist/solana/SolanaWalletProvider.d.ts +38 -0
  23. package/dist/solana/config.d.ts +57 -0
  24. package/dist/solana/index.d.ts +11 -0
  25. package/dist/solana/utils/detection.d.ts +27 -0
  26. package/dist/solana/wallets/backpackWallet.d.ts +19 -0
  27. package/dist/solana/wallets/index.d.ts +8 -0
  28. package/dist/solana/wallets/phantomSolanaWallet.d.ts +17 -0
  29. package/dist/solana/wallets/solflareWallet.d.ts +17 -0
  30. package/dist/types/solana.d.ts +97 -0
  31. package/dist/wallets/recentSolanaWalletIds.d.ts +16 -0
  32. package/dist/wallets/walletConnectors/abcWallet/abcApi.js +1 -1
  33. package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +2 -2
  34. package/dist/wallets/walletConnectors/abcWallet/abcSolanaWallet.js +2 -2
  35. package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +3 -3
  36. package/dist/wallets/walletConnectors/abcWallet/index.js +4 -4
  37. package/dist/wallets/walletConnectors/chunk-3SVPZCA6.js +71 -0
  38. package/dist/wallets/walletConnectors/chunk-5QEUEPNY.js +94 -0
  39. package/dist/wallets/walletConnectors/chunk-B6JLYR3I.js +66 -0
  40. package/dist/wallets/walletConnectors/{chunk-6JKWIEGA.js → chunk-BHMMHU7Y.js} +1 -1
  41. package/dist/wallets/walletConnectors/chunk-HKWBR5B7.js +102 -0
  42. package/dist/wallets/walletConnectors/chunk-K4APJ4PE.js +96 -0
  43. package/dist/wallets/walletConnectors/chunk-LJ2B47VF.js +108 -0
  44. package/dist/wallets/walletConnectors/chunk-LXINMUQC.js +186 -0
  45. package/dist/wallets/walletConnectors/chunk-MORUEOYX.js +76 -0
  46. package/dist/wallets/walletConnectors/chunk-MQTXA63X.js +27 -0
  47. package/dist/wallets/walletConnectors/{chunk-G2IHR6PW.js → chunk-NLKL4KD2.js} +11 -11
  48. package/dist/wallets/walletConnectors/{chunk-KOT7JYJR.js → chunk-OEB7MRS5.js} +1 -1
  49. package/dist/wallets/walletConnectors/{chunk-RWIZ25FJ.js → chunk-P2E4LSYH.js} +17 -23
  50. package/dist/wallets/walletConnectors/chunk-PMZJGS7X.js +73 -0
  51. package/dist/wallets/walletConnectors/{chunk-BRM4ZVXZ.js → chunk-RSZS2RMC.js} +1 -1
  52. package/dist/wallets/walletConnectors/chunk-WZZVA3LW.js +101 -0
  53. package/dist/wallets/walletConnectors/chunk-XEIKWKH7.js +63 -0
  54. package/dist/wallets/walletConnectors/chunk-XOQNQKZE.js +98 -0
  55. package/dist/wallets/walletConnectors/chunk-ZAGAF6PO.js +63 -0
  56. package/dist/wallets/walletConnectors/chunk-ZJ6OFFD5.js +95 -0
  57. package/dist/wallets/walletConnectors/index.js +24 -24
  58. package/package.json +17 -11
  59. package/LICENSE +0 -9
  60. package/dist/wallets/walletConnectors/chunk-2J66VMY5.js +0 -152
  61. package/dist/wallets/walletConnectors/chunk-2ZPGPZCP.js +0 -228
  62. package/dist/wallets/walletConnectors/chunk-3DPCIDW6.js +0 -1730
  63. package/dist/wallets/walletConnectors/chunk-4HKJ53H3.js +0 -1742
  64. package/dist/wallets/walletConnectors/chunk-5EARL7FN.js +0 -39
  65. package/dist/wallets/walletConnectors/chunk-7SXCH5TL.js +0 -1752
  66. package/dist/wallets/walletConnectors/chunk-7UZBDZZZ.js +0 -599
  67. package/dist/wallets/walletConnectors/chunk-BUDWZAL7.js +0 -44
  68. package/dist/wallets/walletConnectors/chunk-CSWWNAYR.js +0 -44
  69. package/dist/wallets/walletConnectors/chunk-E4N7SPPU.js +0 -39
  70. package/dist/wallets/walletConnectors/chunk-ENU7XLF5.js +0 -44
  71. package/dist/wallets/walletConnectors/chunk-ESRU5KCF.js +0 -151
  72. package/dist/wallets/walletConnectors/chunk-FF7ZIXKD.js +0 -39
  73. package/dist/wallets/walletConnectors/chunk-FJCL2YPU.js +0 -1737
  74. package/dist/wallets/walletConnectors/chunk-FSU3WBH3.js +0 -63
  75. package/dist/wallets/walletConnectors/chunk-HD6YCICR.js +0 -228
  76. package/dist/wallets/walletConnectors/chunk-HDYBRMYW.js +0 -194
  77. package/dist/wallets/walletConnectors/chunk-HIZCIW5L.js +0 -228
  78. package/dist/wallets/walletConnectors/chunk-JRNBDHFL.js +0 -44
  79. package/dist/wallets/walletConnectors/chunk-KIQDE4N6.js +0 -39
  80. package/dist/wallets/walletConnectors/chunk-KZOSE2PI.js +0 -228
  81. package/dist/wallets/walletConnectors/chunk-LNZJLKFB.js +0 -39
  82. package/dist/wallets/walletConnectors/chunk-LV765WZL.js +0 -1748
  83. package/dist/wallets/walletConnectors/chunk-MSI2BPP5.js +0 -1722
  84. package/dist/wallets/walletConnectors/chunk-MX2IY5CD.js +0 -44
  85. package/dist/wallets/walletConnectors/chunk-NLX2EV7O.js +0 -44
  86. package/dist/wallets/walletConnectors/chunk-NVAZ3B3V.js +0 -228
  87. package/dist/wallets/walletConnectors/chunk-OEWU3ZMN.js +0 -39
  88. package/dist/wallets/walletConnectors/chunk-P2MTINFI.js +0 -280
  89. package/dist/wallets/walletConnectors/chunk-PNMSIVVT.js +0 -44
  90. package/dist/wallets/walletConnectors/chunk-PZNYT2HC.js +0 -1722
  91. package/dist/wallets/walletConnectors/chunk-QPAE4SDS.js +0 -39
  92. package/dist/wallets/walletConnectors/chunk-QZRNNI3E.js +0 -39
  93. package/dist/wallets/walletConnectors/chunk-R4UYVU5X.js +0 -1721
  94. package/dist/wallets/walletConnectors/chunk-RLBGBBIO.js +0 -309
  95. package/dist/wallets/walletConnectors/chunk-TUUNSVKZ.js +0 -345
  96. package/dist/wallets/walletConnectors/chunk-U2CUEL35.js +0 -240
  97. package/dist/wallets/walletConnectors/chunk-V6NRLREB.js +0 -44
  98. package/dist/wallets/walletConnectors/chunk-VM7AEC7H.js +0 -39
  99. package/dist/wallets/walletConnectors/chunk-W2VDZD74.js +0 -478
  100. package/dist/wallets/walletConnectors/chunk-WAO3KL5U.js +0 -285
  101. package/dist/wallets/walletConnectors/chunk-WPHTIILX.js +0 -228
  102. package/dist/wallets/walletConnectors/chunk-WSCJY2QD.js +0 -228
  103. package/dist/wallets/walletConnectors/chunk-X3JQB5QL.js +0 -44
  104. package/dist/wallets/walletConnectors/chunk-X4CDP7L7.js +0 -228
  105. package/dist/wallets/walletConnectors/chunk-XETOVXYM.js +0 -228
  106. package/dist/wallets/walletConnectors/chunk-XYPR4BAF.js +0 -436
  107. package/dist/wallets/walletConnectors/chunk-Z2ZRPTPX.js +0 -1726
  108. package/dist/wallets/walletConnectors/{chunk-VCBVYFLJ.js → chunk-6TLWAEJV.js} +7 -7
  109. package/dist/wallets/walletConnectors/{chunk-47TQ23J4.js → chunk-74ALNZG4.js} +8 -8
  110. package/dist/wallets/walletConnectors/{chunk-66SCJ77O.js → chunk-CM5OGUJV.js} +6 -6
@@ -1,285 +0,0 @@
1
- "use client";
2
- import {
3
- secure_default
4
- } from "./chunk-G2LI5MVX.js";
5
- import {
6
- calculateExpiryTimestamp,
7
- createAbcError,
8
- isTokenExpired,
9
- loadFromStorage,
10
- parseApiError,
11
- removeFromStorage,
12
- saveToStorage
13
- } from "./chunk-W2VDZD74.js";
14
- import {
15
- ABC_ENDPOINTS,
16
- DEFAULT_HEADERS,
17
- REQUEST_TIMEOUT
18
- } from "./chunk-VETRBBA2.js";
19
-
20
- // src/wallets/walletConnectors/abcWallet/api/BaseApiClient.ts
21
- var BaseApiClient = class {
22
- constructor(config) {
23
- this.accessToken = null;
24
- this.refreshToken = null;
25
- this.expiresAt = null;
26
- this.isRefreshing = false;
27
- this.refreshPromise = null;
28
- this.config = config;
29
- this.baseURL = config.waasUrl;
30
- this.secure = new secure_default(this.baseURL);
31
- this.loadTokens();
32
- }
33
- /**
34
- * Load tokens from storage
35
- */
36
- loadTokens() {
37
- this.accessToken = loadFromStorage("access_token" /* ACCESS_TOKEN */);
38
- this.refreshToken = loadFromStorage("refresh_token" /* REFRESH_TOKEN */);
39
- this.expiresAt = loadFromStorage("expires_at" /* EXPIRES_AT */);
40
- }
41
- /**
42
- * Save tokens to storage
43
- */
44
- saveTokens(accessToken, refreshToken, expiresIn) {
45
- this.accessToken = accessToken;
46
- this.refreshToken = refreshToken;
47
- this.expiresAt = calculateExpiryTimestamp(expiresIn);
48
- saveToStorage("access_token" /* ACCESS_TOKEN */, accessToken);
49
- saveToStorage("refresh_token" /* REFRESH_TOKEN */, refreshToken);
50
- saveToStorage("expires_at" /* EXPIRES_AT */, this.expiresAt);
51
- }
52
- /**
53
- * Clear tokens
54
- */
55
- clearTokens() {
56
- this.accessToken = null;
57
- this.refreshToken = null;
58
- this.expiresAt = null;
59
- removeFromStorage("access_token" /* ACCESS_TOKEN */);
60
- removeFromStorage("refresh_token" /* REFRESH_TOKEN */);
61
- removeFromStorage("expires_at" /* EXPIRES_AT */);
62
- }
63
- /**
64
- * Check if access token is expired
65
- */
66
- isTokenExpired() {
67
- return isTokenExpired(this.expiresAt);
68
- }
69
- /**
70
- * Get current access token
71
- */
72
- getAccessToken() {
73
- return this.accessToken;
74
- }
75
- /**
76
- * Set access token manually
77
- */
78
- setAccessToken(token) {
79
- this.accessToken = token;
80
- }
81
- /**
82
- * Get base URL
83
- */
84
- getBaseURL() {
85
- return this.baseURL;
86
- }
87
- /**
88
- * Get configuration
89
- */
90
- getConfig() {
91
- return this.config;
92
- }
93
- /**
94
- * Refresh access token
95
- */
96
- async refreshAccessToken() {
97
- if (this.isRefreshing) {
98
- if (this.refreshPromise) {
99
- await this.refreshPromise;
100
- }
101
- return;
102
- }
103
- if (!this.refreshToken) {
104
- throw createAbcError(
105
- "TOKEN_EXPIRED" /* TOKEN_EXPIRED */,
106
- "No refresh token available"
107
- );
108
- }
109
- this.isRefreshing = true;
110
- this.refreshPromise = (async () => {
111
- try {
112
- const isIframe = typeof window !== "undefined" && window.self !== window.top;
113
- const talkenApiUrl = process.env.NEXT_PUBLIC_API_SERVER || "https://dev.walletapi.talken.io";
114
- const response = await fetch(
115
- `${talkenApiUrl}${ABC_ENDPOINTS.REFRESH_TOKEN}`,
116
- {
117
- method: "POST",
118
- headers: DEFAULT_HEADERS,
119
- credentials: "include",
120
- body: new URLSearchParams({
121
- refresh_token: this.refreshToken || "",
122
- isIframe: String(isIframe)
123
- }).toString()
124
- }
125
- );
126
- const text = await response.text();
127
- const data = text ? JSON.parse(text) : {};
128
- if (response.ok && data.access_token) {
129
- const expiresIn = data.expire_in || 3600;
130
- this.saveTokens(
131
- data.access_token,
132
- data.refresh_token || this.refreshToken,
133
- expiresIn
134
- );
135
- } else {
136
- throw createAbcError(
137
- "TOKEN_EXPIRED" /* TOKEN_EXPIRED */,
138
- "Failed to refresh token"
139
- );
140
- }
141
- } finally {
142
- this.isRefreshing = false;
143
- this.refreshPromise = null;
144
- }
145
- })();
146
- await this.refreshPromise;
147
- }
148
- /**
149
- * Make HTTP request with automatic token refresh
150
- */
151
- async request(endpoint, options = {}) {
152
- const {
153
- method = "GET",
154
- body,
155
- headers = {},
156
- skipAuth = false,
157
- isRetry = false,
158
- contentType = "form"
159
- // Default to form-encoded for backward compatibility
160
- } = options;
161
- if (!skipAuth && this.isTokenExpired() && this.refreshToken) {
162
- await this.refreshAccessToken();
163
- }
164
- const url = `${this.baseURL}${endpoint}`;
165
- const requestHeaders = {
166
- ...DEFAULT_HEADERS,
167
- ...headers
168
- };
169
- if (contentType === "json") {
170
- requestHeaders["Content-Type"] = "application/json";
171
- requestHeaders["Accept"] = "application/json";
172
- }
173
- if (!skipAuth && this.accessToken) {
174
- requestHeaders.Authorization = `Bearer ${this.accessToken}`;
175
- }
176
- if (this.config.apiKey) {
177
- requestHeaders["X-API-Key"] = this.config.apiKey;
178
- }
179
- try {
180
- const controller = new AbortController();
181
- const timeoutId = setTimeout(() => controller.abort(), REQUEST_TIMEOUT);
182
- const requestBody = body ? contentType === "json" ? JSON.stringify(body) : new URLSearchParams(body).toString() : void 0;
183
- const response = await fetch(url, {
184
- method,
185
- headers: requestHeaders,
186
- body: requestBody,
187
- signal: controller.signal
188
- });
189
- clearTimeout(timeoutId);
190
- const text = await response.text();
191
- let data;
192
- if (text) {
193
- try {
194
- data = JSON.parse(text);
195
- } catch (parseError) {
196
- console.error("[BaseApiClient] \u274C JSON parse error:", {
197
- url,
198
- method,
199
- status: response.status,
200
- responseText: text.substring(0, 200)
201
- });
202
- throw createAbcError(
203
- "UNKNOWN_ERROR" /* UNKNOWN_ERROR */,
204
- "Invalid JSON response from server",
205
- { text, parseError }
206
- );
207
- }
208
- } else {
209
- data = { status: "success" };
210
- }
211
- if (response.status === 401 && !skipAuth && this.refreshToken && !isRetry) {
212
- try {
213
- await this.refreshAccessToken();
214
- return await this.request(endpoint, {
215
- ...options,
216
- isRetry: true
217
- });
218
- } catch (refreshError) {
219
- console.error("Token refresh failed:", refreshError);
220
- throw parseApiError({
221
- response: {
222
- status: response.status,
223
- data
224
- }
225
- });
226
- }
227
- }
228
- if (!response.ok) {
229
- console.error("[BaseApiClient] \u274C API Error:", {
230
- url,
231
- method,
232
- status: response.status,
233
- statusText: response.statusText,
234
- data
235
- });
236
- throw parseApiError({
237
- response: {
238
- status: response.status,
239
- data
240
- }
241
- });
242
- }
243
- return data;
244
- } catch (error) {
245
- console.error("[BaseApiClient] \u274C Request failed:", {
246
- url,
247
- method,
248
- error: error.message
249
- });
250
- if (error.name === "AbortError") {
251
- throw createAbcError(
252
- "NETWORK_ERROR" /* NETWORK_ERROR */,
253
- "Request timeout",
254
- error
255
- );
256
- }
257
- if (error.code && error.message) {
258
- throw error;
259
- }
260
- throw parseApiError(error);
261
- }
262
- }
263
- /**
264
- * Check if user is authenticated
265
- */
266
- isAuthenticated() {
267
- return !!this.accessToken && !this.isTokenExpired();
268
- }
269
- /**
270
- * Logout (clear tokens)
271
- */
272
- async logout() {
273
- this.clearTokens();
274
- }
275
- /**
276
- * Get secure service instance
277
- */
278
- getSecureService() {
279
- return this.secure;
280
- }
281
- };
282
-
283
- export {
284
- BaseApiClient
285
- };
@@ -1,228 +0,0 @@
1
- "use client";
2
- import {
3
- createAbcWaasClient
4
- } from "./chunk-R4UYVU5X.js";
5
- import {
6
- createAbcEvmProvider
7
- } from "./chunk-XYPR4BAF.js";
8
- import {
9
- clearAuthState,
10
- clearEncryptedTokens,
11
- loadAuthState,
12
- saveAuthState
13
- } from "./chunk-W2VDZD74.js";
14
-
15
- // src/wallets/walletConnectors/abcWallet/abcConnector.ts
16
- import { createConnector } from "wagmi";
17
- function abcConnector(options) {
18
- const { config } = options;
19
- return createConnector((wagmiConfig) => {
20
- const client = createAbcWaasClient(config);
21
- const provider = createAbcEvmProvider(client);
22
- let accountsChangedHandler;
23
- let chainChangedHandler;
24
- let disconnectHandler;
25
- return {
26
- id: "abc",
27
- name: "ABC Wallet",
28
- type: "abc",
29
- /**
30
- * Connect wallet
31
- */
32
- async connect() {
33
- try {
34
- const authState = loadAuthState();
35
- console.log("\u{1F527} ABC Connector connect() called:", {
36
- hasAuthState: !!authState,
37
- isAuthenticated: authState?.isAuthenticated,
38
- hasWallet: !!authState?.wallet,
39
- walletAddress: authState?.wallet?.address
40
- });
41
- if (!authState || !authState.isAuthenticated || !authState.wallet) {
42
- throw new Error("ABC_LOGIN_REQUIRED");
43
- }
44
- provider.setWallet(authState.wallet);
45
- console.log("\u2705 Provider wallet set:", {
46
- address: authState.wallet.address,
47
- hasPIN: !!authState.pin
48
- });
49
- const accounts = await provider.request({
50
- method: "eth_requestAccounts"
51
- });
52
- const currentChainId = await provider.request({
53
- method: "eth_chainId"
54
- });
55
- if (accountsChangedHandler) {
56
- provider.removeListener("accountsChanged", accountsChangedHandler);
57
- }
58
- accountsChangedHandler = (accounts2) => {
59
- wagmiConfig.emitter.emit("change", {
60
- accounts: accounts2
61
- });
62
- };
63
- provider.on("accountsChanged", accountsChangedHandler);
64
- if (chainChangedHandler) {
65
- provider.removeListener("chainChanged", chainChangedHandler);
66
- }
67
- chainChangedHandler = (chainId) => {
68
- wagmiConfig.emitter.emit("change", {
69
- chainId: Number(chainId)
70
- });
71
- };
72
- provider.on("chainChanged", chainChangedHandler);
73
- if (disconnectHandler) {
74
- provider.removeListener("disconnect", disconnectHandler);
75
- }
76
- disconnectHandler = () => {
77
- wagmiConfig.emitter.emit("disconnect");
78
- this.onDisconnect();
79
- };
80
- provider.on("disconnect", disconnectHandler);
81
- return {
82
- accounts,
83
- chainId: Number(currentChainId)
84
- };
85
- } catch (error) {
86
- if (error.message === "ABC_LOGIN_REQUIRED") {
87
- throw error;
88
- }
89
- throw error;
90
- }
91
- },
92
- /**
93
- * Disconnect wallet
94
- */
95
- async disconnect() {
96
- if (accountsChangedHandler) {
97
- provider.removeListener("accountsChanged", accountsChangedHandler);
98
- accountsChangedHandler = void 0;
99
- }
100
- if (chainChangedHandler) {
101
- provider.removeListener("chainChanged", chainChangedHandler);
102
- chainChangedHandler = void 0;
103
- }
104
- if (disconnectHandler) {
105
- provider.removeListener("disconnect", disconnectHandler);
106
- disconnectHandler = void 0;
107
- }
108
- provider.clearWallet();
109
- await client.logout();
110
- let savedPinHash = null;
111
- let savedEmail = null;
112
- if (typeof window !== "undefined") {
113
- savedPinHash = localStorage.getItem("talkenkit_abc_pin_hash");
114
- savedEmail = localStorage.getItem("talkenkit_abc_saved_email");
115
- }
116
- clearAuthState();
117
- clearEncryptedTokens();
118
- if (typeof window !== "undefined") {
119
- localStorage.removeItem("talkenkit_abc_enc_salt");
120
- localStorage.removeItem("talkenkit_abc_enc_tokens");
121
- if (savedPinHash) {
122
- localStorage.setItem("talkenkit_abc_pin_hash", savedPinHash);
123
- }
124
- if (savedEmail) {
125
- localStorage.setItem("talkenkit_abc_saved_email", savedEmail);
126
- }
127
- }
128
- console.log("\u2705 ABC Wallet disconnected (PIN preserved)");
129
- },
130
- /**
131
- * Get accounts
132
- */
133
- async getAccounts() {
134
- const accounts = await provider.request({
135
- method: "eth_accounts"
136
- });
137
- return accounts.map((account) => account);
138
- },
139
- /**
140
- * Get chain ID
141
- */
142
- async getChainId() {
143
- const chainId = await provider.request({
144
- method: "eth_chainId"
145
- });
146
- return Number(chainId);
147
- },
148
- /**
149
- * Get provider
150
- */
151
- async getProvider() {
152
- return provider;
153
- },
154
- /**
155
- * Check if authorized (has valid session)
156
- */
157
- async isAuthorized() {
158
- try {
159
- const authState = loadAuthState();
160
- if (!authState || !authState.isAuthenticated) {
161
- return false;
162
- }
163
- return client.isAuthenticated();
164
- } catch {
165
- return false;
166
- }
167
- },
168
- /**
169
- * Switch chain
170
- */
171
- async switchChain({ chainId }) {
172
- await provider.request({
173
- method: "wallet_switchEthereumChain",
174
- params: [{ chainId: `0x${chainId.toString(16)}` }]
175
- });
176
- const newChainId = await this.getChainId();
177
- const authState = loadAuthState();
178
- if (authState?.wallet) {
179
- authState.wallet.chainId = newChainId;
180
- saveAuthState(authState);
181
- }
182
- return wagmiConfig.chains.find((x) => x.id === chainId) ?? {
183
- id: chainId,
184
- name: `Chain ${chainId}`,
185
- nativeCurrency: {
186
- name: "Ether",
187
- decimals: 18,
188
- symbol: "ETH"
189
- },
190
- rpcUrls: {
191
- default: { http: [""] }
192
- }
193
- };
194
- },
195
- /**
196
- * Handle accounts changed
197
- */
198
- onAccountsChanged(accounts) {
199
- if (accounts.length === 0) {
200
- this.onDisconnect();
201
- } else {
202
- wagmiConfig.emitter.emit("change", {
203
- accounts
204
- });
205
- }
206
- },
207
- /**
208
- * Handle chain changed
209
- */
210
- onChainChanged(chain) {
211
- const chainId = Number(chain);
212
- wagmiConfig.emitter.emit("change", { chainId });
213
- },
214
- /**
215
- * Handle disconnect
216
- */
217
- onDisconnect(_error) {
218
- provider.clearWallet();
219
- clearAuthState();
220
- wagmiConfig.emitter.emit("disconnect");
221
- }
222
- };
223
- });
224
- }
225
-
226
- export {
227
- abcConnector
228
- };