@reown/appkit-core-react-native 0.0.0-feat-onramp-20250718200617 → 0.0.0-feat-coinbase-20250722173213

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 (195) hide show
  1. package/lib/commonjs/controllers/AccountController.js +20 -17
  2. package/lib/commonjs/controllers/AccountController.js.map +1 -1
  3. package/lib/commonjs/controllers/ApiController.js +28 -16
  4. package/lib/commonjs/controllers/ApiController.js.map +1 -1
  5. package/lib/commonjs/controllers/BlockchainApiController.js +166 -67
  6. package/lib/commonjs/controllers/BlockchainApiController.js.map +1 -1
  7. package/lib/commonjs/controllers/ConnectionController.js +8 -11
  8. package/lib/commonjs/controllers/ConnectionController.js.map +1 -1
  9. package/lib/commonjs/controllers/ConnectionsController.js +387 -0
  10. package/lib/commonjs/controllers/ConnectionsController.js.map +1 -0
  11. package/lib/commonjs/controllers/EnsController.js +4 -4
  12. package/lib/commonjs/controllers/EnsController.js.map +1 -1
  13. package/lib/commonjs/controllers/EventsController.js +4 -4
  14. package/lib/commonjs/controllers/EventsController.js.map +1 -1
  15. package/lib/commonjs/controllers/ModalController.js +6 -7
  16. package/lib/commonjs/controllers/ModalController.js.map +1 -1
  17. package/lib/commonjs/controllers/OnRampController.js +22 -70
  18. package/lib/commonjs/controllers/OnRampController.js.map +1 -1
  19. package/lib/commonjs/controllers/OptionsController.js +11 -3
  20. package/lib/commonjs/controllers/OptionsController.js.map +1 -1
  21. package/lib/commonjs/controllers/RouterController.js +1 -22
  22. package/lib/commonjs/controllers/RouterController.js.map +1 -1
  23. package/lib/commonjs/controllers/SendController.js +101 -101
  24. package/lib/commonjs/controllers/SendController.js.map +1 -1
  25. package/lib/commonjs/controllers/SnackController.js +29 -5
  26. package/lib/commonjs/controllers/SnackController.js.map +1 -1
  27. package/lib/commonjs/controllers/SwapController.js +151 -150
  28. package/lib/commonjs/controllers/SwapController.js.map +1 -1
  29. package/lib/commonjs/controllers/ThemeController.js +9 -1
  30. package/lib/commonjs/controllers/ThemeController.js.map +1 -1
  31. package/lib/commonjs/controllers/TransactionsController.js +25 -21
  32. package/lib/commonjs/controllers/TransactionsController.js.map +1 -1
  33. package/lib/commonjs/index.js +3 -24
  34. package/lib/commonjs/index.js.map +1 -1
  35. package/lib/commonjs/utils/AssetUtil.js +3 -15
  36. package/lib/commonjs/utils/AssetUtil.js.map +1 -1
  37. package/lib/commonjs/utils/ConstantsUtil.js +538 -9
  38. package/lib/commonjs/utils/ConstantsUtil.js.map +1 -1
  39. package/lib/commonjs/utils/CoreHelperUtil.js +12 -6
  40. package/lib/commonjs/utils/CoreHelperUtil.js.map +1 -1
  41. package/lib/commonjs/utils/FetchUtil.js +9 -28
  42. package/lib/commonjs/utils/FetchUtil.js.map +1 -1
  43. package/lib/commonjs/utils/StorageUtil.js +51 -42
  44. package/lib/commonjs/utils/StorageUtil.js.map +1 -1
  45. package/lib/commonjs/utils/SwapApiUtil.js +15 -21
  46. package/lib/commonjs/utils/SwapApiUtil.js.map +1 -1
  47. package/lib/module/controllers/AccountController.js +20 -17
  48. package/lib/module/controllers/AccountController.js.map +1 -1
  49. package/lib/module/controllers/ApiController.js +27 -16
  50. package/lib/module/controllers/ApiController.js.map +1 -1
  51. package/lib/module/controllers/BlockchainApiController.js +166 -67
  52. package/lib/module/controllers/BlockchainApiController.js.map +1 -1
  53. package/lib/module/controllers/ConnectionController.js +8 -11
  54. package/lib/module/controllers/ConnectionController.js.map +1 -1
  55. package/lib/module/controllers/ConnectionsController.js +382 -0
  56. package/lib/module/controllers/ConnectionsController.js.map +1 -0
  57. package/lib/module/controllers/EnsController.js +2 -2
  58. package/lib/module/controllers/EnsController.js.map +1 -1
  59. package/lib/module/controllers/EventsController.js +1 -1
  60. package/lib/module/controllers/EventsController.js.map +1 -1
  61. package/lib/module/controllers/ModalController.js +6 -7
  62. package/lib/module/controllers/ModalController.js.map +1 -1
  63. package/lib/module/controllers/OnRampController.js +22 -70
  64. package/lib/module/controllers/OnRampController.js.map +1 -1
  65. package/lib/module/controllers/OptionsController.js +11 -3
  66. package/lib/module/controllers/OptionsController.js.map +1 -1
  67. package/lib/module/controllers/RouterController.js +1 -22
  68. package/lib/module/controllers/RouterController.js.map +1 -1
  69. package/lib/module/controllers/SendController.js +98 -98
  70. package/lib/module/controllers/SendController.js.map +1 -1
  71. package/lib/module/controllers/SnackController.js +29 -5
  72. package/lib/module/controllers/SnackController.js.map +1 -1
  73. package/lib/module/controllers/SwapController.js +151 -150
  74. package/lib/module/controllers/SwapController.js.map +1 -1
  75. package/lib/module/controllers/ThemeController.js +9 -1
  76. package/lib/module/controllers/ThemeController.js.map +1 -1
  77. package/lib/module/controllers/TransactionsController.js +23 -19
  78. package/lib/module/controllers/TransactionsController.js.map +1 -1
  79. package/lib/module/index.js +1 -4
  80. package/lib/module/index.js.map +1 -1
  81. package/lib/module/utils/AssetUtil.js +3 -15
  82. package/lib/module/utils/AssetUtil.js.map +1 -1
  83. package/lib/module/utils/ConstantsUtil.js +538 -9
  84. package/lib/module/utils/ConstantsUtil.js.map +1 -1
  85. package/lib/module/utils/CoreHelperUtil.js +12 -6
  86. package/lib/module/utils/CoreHelperUtil.js.map +1 -1
  87. package/lib/module/utils/FetchUtil.js +9 -28
  88. package/lib/module/utils/FetchUtil.js.map +1 -1
  89. package/lib/module/utils/StorageUtil.js +51 -42
  90. package/lib/module/utils/StorageUtil.js.map +1 -1
  91. package/lib/module/utils/SwapApiUtil.js +15 -21
  92. package/lib/module/utils/SwapApiUtil.js.map +1 -1
  93. package/lib/typescript/controllers/AccountController.d.ts +4 -4
  94. package/lib/typescript/controllers/AccountController.d.ts.map +1 -1
  95. package/lib/typescript/controllers/ApiController.d.ts +3 -2
  96. package/lib/typescript/controllers/ApiController.d.ts.map +1 -1
  97. package/lib/typescript/controllers/BlockchainApiController.d.ts +28 -12
  98. package/lib/typescript/controllers/BlockchainApiController.d.ts.map +1 -1
  99. package/lib/typescript/controllers/ConnectionController.d.ts +3 -11
  100. package/lib/typescript/controllers/ConnectionController.d.ts.map +1 -1
  101. package/lib/typescript/controllers/ConnectionsController.d.ts +53 -0
  102. package/lib/typescript/controllers/ConnectionsController.d.ts.map +1 -0
  103. package/lib/typescript/controllers/ModalController.d.ts +1 -1
  104. package/lib/typescript/controllers/ModalController.d.ts.map +1 -1
  105. package/lib/typescript/controllers/NetworkController.d.ts +1 -1
  106. package/lib/typescript/controllers/NetworkController.d.ts.map +1 -1
  107. package/lib/typescript/controllers/OnRampController.d.ts +1 -3
  108. package/lib/typescript/controllers/OnRampController.d.ts.map +1 -1
  109. package/lib/typescript/controllers/OptionsController.d.ts +7 -2
  110. package/lib/typescript/controllers/OptionsController.d.ts.map +1 -1
  111. package/lib/typescript/controllers/PublicStateController.d.ts +1 -1
  112. package/lib/typescript/controllers/PublicStateController.d.ts.map +1 -1
  113. package/lib/typescript/controllers/RouterController.d.ts +4 -16
  114. package/lib/typescript/controllers/RouterController.d.ts.map +1 -1
  115. package/lib/typescript/controllers/SendController.d.ts +5 -7
  116. package/lib/typescript/controllers/SendController.d.ts.map +1 -1
  117. package/lib/typescript/controllers/SnackController.d.ts +3 -3
  118. package/lib/typescript/controllers/SnackController.d.ts.map +1 -1
  119. package/lib/typescript/controllers/SwapController.d.ts +12 -11
  120. package/lib/typescript/controllers/SwapController.d.ts.map +1 -1
  121. package/lib/typescript/controllers/ThemeController.d.ts +1 -1
  122. package/lib/typescript/controllers/ThemeController.d.ts.map +1 -1
  123. package/lib/typescript/controllers/TransactionsController.d.ts +3 -3
  124. package/lib/typescript/controllers/TransactionsController.d.ts.map +1 -1
  125. package/lib/typescript/index.d.ts +1 -4
  126. package/lib/typescript/index.d.ts.map +1 -1
  127. package/lib/typescript/utils/AssetUtil.d.ts +2 -3
  128. package/lib/typescript/utils/AssetUtil.d.ts.map +1 -1
  129. package/lib/typescript/utils/ConstantsUtil.d.ts +422 -3
  130. package/lib/typescript/utils/ConstantsUtil.d.ts.map +1 -1
  131. package/lib/typescript/utils/CoreHelperUtil.d.ts +5 -4
  132. package/lib/typescript/utils/CoreHelperUtil.d.ts.map +1 -1
  133. package/lib/typescript/utils/FetchUtil.d.ts +1 -1
  134. package/lib/typescript/utils/FetchUtil.d.ts.map +1 -1
  135. package/lib/typescript/utils/StorageUtil.d.ts +14 -7
  136. package/lib/typescript/utils/StorageUtil.d.ts.map +1 -1
  137. package/lib/typescript/utils/SwapApiUtil.d.ts +3 -3
  138. package/lib/typescript/utils/SwapApiUtil.d.ts.map +1 -1
  139. package/lib/typescript/utils/TypeUtil.d.ts +42 -191
  140. package/lib/typescript/utils/TypeUtil.d.ts.map +1 -1
  141. package/package.json +4 -4
  142. package/src/controllers/AccountController.ts +23 -27
  143. package/src/controllers/ApiController.ts +29 -10
  144. package/src/controllers/BlockchainApiController.ts +140 -55
  145. package/src/controllers/ConnectionController.ts +12 -24
  146. package/src/controllers/ConnectionsController.ts +509 -0
  147. package/src/controllers/EnsController.ts +2 -2
  148. package/src/controllers/EventsController.ts +1 -1
  149. package/src/controllers/ModalController.ts +8 -8
  150. package/src/controllers/NetworkController.ts +1 -1
  151. package/src/controllers/OnRampController.ts +34 -99
  152. package/src/controllers/OptionsController.ts +19 -13
  153. package/src/controllers/PublicStateController.ts +1 -1
  154. package/src/controllers/RouterController.ts +5 -54
  155. package/src/controllers/SendController.ts +124 -113
  156. package/src/controllers/SnackController.ts +31 -5
  157. package/src/controllers/SwapController.ts +174 -181
  158. package/src/controllers/ThemeController.ts +11 -2
  159. package/src/controllers/TransactionsController.ts +26 -20
  160. package/src/index.ts +3 -6
  161. package/src/utils/AssetUtil.ts +4 -20
  162. package/src/utils/ConstantsUtil.ts +544 -9
  163. package/src/utils/CoreHelperUtil.ts +34 -9
  164. package/src/utils/FetchUtil.ts +10 -31
  165. package/src/utils/StorageUtil.ts +60 -48
  166. package/src/utils/SwapApiUtil.ts +27 -38
  167. package/src/utils/TypeUtil.ts +43 -193
  168. package/lib/commonjs/controllers/ConnectorController.js +0 -49
  169. package/lib/commonjs/controllers/ConnectorController.js.map +0 -1
  170. package/lib/commonjs/controllers/WebviewController.js +0 -52
  171. package/lib/commonjs/controllers/WebviewController.js.map +0 -1
  172. package/lib/commonjs/utils/ConnectionUtil.js +0 -33
  173. package/lib/commonjs/utils/ConnectionUtil.js.map +0 -1
  174. package/lib/commonjs/utils/NetworkUtil.js +0 -46
  175. package/lib/commonjs/utils/NetworkUtil.js.map +0 -1
  176. package/lib/module/controllers/ConnectorController.js +0 -44
  177. package/lib/module/controllers/ConnectorController.js.map +0 -1
  178. package/lib/module/controllers/WebviewController.js +0 -47
  179. package/lib/module/controllers/WebviewController.js.map +0 -1
  180. package/lib/module/utils/ConnectionUtil.js +0 -27
  181. package/lib/module/utils/ConnectionUtil.js.map +0 -1
  182. package/lib/module/utils/NetworkUtil.js +0 -40
  183. package/lib/module/utils/NetworkUtil.js.map +0 -1
  184. package/lib/typescript/controllers/ConnectorController.d.ts +0 -18
  185. package/lib/typescript/controllers/ConnectorController.d.ts.map +0 -1
  186. package/lib/typescript/controllers/WebviewController.d.ts +0 -21
  187. package/lib/typescript/controllers/WebviewController.d.ts.map +0 -1
  188. package/lib/typescript/utils/ConnectionUtil.d.ts +0 -4
  189. package/lib/typescript/utils/ConnectionUtil.d.ts.map +0 -1
  190. package/lib/typescript/utils/NetworkUtil.d.ts +0 -8
  191. package/lib/typescript/utils/NetworkUtil.d.ts.map +0 -1
  192. package/src/controllers/ConnectorController.ts +0 -63
  193. package/src/controllers/WebviewController.ts +0 -63
  194. package/src/utils/ConnectionUtil.ts +0 -27
  195. package/src/utils/NetworkUtil.ts +0 -33
@@ -8,7 +8,7 @@ interface Options {
8
8
 
9
9
  interface RequestArguments {
10
10
  path: string;
11
- headers?: HeadersInit_;
11
+ headers?: HeadersInit;
12
12
  params?: Record<string, string | undefined>;
13
13
  cache?: RequestCache;
14
14
  signal?: AbortSignal;
@@ -88,41 +88,20 @@ export class FetchUtil {
88
88
  }
89
89
 
90
90
  private createUrl({ path, params }: RequestArguments) {
91
- let fullUrl: string;
92
-
93
- const isAbsoluteUrl = path.startsWith('http://') || path.startsWith('https://');
94
-
95
- if (isAbsoluteUrl) {
96
- fullUrl = path;
97
- } else {
98
- const baseUrl = this.baseUrl.endsWith('/') ? this.baseUrl : `${this.baseUrl}/`;
99
- const pathUrl = path.startsWith('/') ? path.substring(1) : path;
100
- fullUrl = `${baseUrl}${pathUrl}`;
91
+ const url = new URL(path, this.baseUrl);
92
+ if (params) {
93
+ Object.entries(params).forEach(([key, value]) => {
94
+ if (value) {
95
+ url.searchParams.append(key, value);
96
+ }
97
+ });
101
98
  }
102
99
 
103
- const allParams: Record<string, string | undefined> = { ...params };
104
100
  if (this.clientId) {
105
- allParams['clientId'] = this.clientId;
106
- }
107
-
108
- const queryParams: string[] = [];
109
- for (const key in allParams) {
110
- const value = allParams[key];
111
- if (value !== undefined) {
112
- queryParams.push(`${encodeURIComponent(key)}=${encodeURIComponent(value)}`);
113
- }
114
- }
115
-
116
- if (queryParams.length > 0) {
117
- const queryString = queryParams.join('&');
118
- if (fullUrl.includes('?')) {
119
- fullUrl = `${fullUrl}&${queryString}`;
120
- } else {
121
- fullUrl = `${fullUrl}?${queryString}`;
122
- }
101
+ url.searchParams.append('clientId', this.clientId);
123
102
  }
124
103
 
125
- return fullUrl;
104
+ return url.toString();
126
105
  }
127
106
 
128
107
  private async processResponse<T>(response: Response) {
@@ -2,7 +2,6 @@
2
2
  import AsyncStorage from '@react-native-async-storage/async-storage';
3
3
  import type {
4
4
  OnRampCountry,
5
- OnRampCountryDefaults,
6
5
  OnRampFiatCurrency,
7
6
  OnRampFiatLimit,
8
7
  OnRampServiceProvider,
@@ -11,22 +10,24 @@ import type {
11
10
  import {
12
11
  DateUtil,
13
12
  type SocialProvider,
14
- type ConnectorType
13
+ type ConnectorType,
14
+ type ChainNamespace
15
15
  } from '@reown/appkit-common-react-native';
16
16
 
17
17
  // -- Helpers -----------------------------------------------------------------
18
18
  const WC_DEEPLINK = 'WALLETCONNECT_DEEPLINK_CHOICE';
19
19
  const RECENT_WALLET = '@w3m/recent';
20
20
  const CONNECTED_WALLET_IMAGE_URL = '@w3m/connected_wallet_image_url';
21
- const CONNECTED_CONNECTOR = '@w3m/connected_connector';
21
+ const CONNECTED_CONNECTORS = '@appkit/connected_connectors';
22
22
  const CONNECTED_SOCIAL = '@appkit/connected_social';
23
23
  const ONRAMP_PREFERRED_COUNTRY = '@appkit/onramp_preferred_country';
24
24
  const ONRAMP_COUNTRIES = '@appkit/onramp_countries';
25
- const ONRAMP_COUNTRIES_DEFAULTS = '@appkit/onramp_countries_defaults';
26
25
  const ONRAMP_SERVICE_PROVIDERS = '@appkit/onramp_service_providers';
27
26
  const ONRAMP_FIAT_LIMITS = '@appkit/onramp_fiat_limits';
28
27
  const ONRAMP_FIAT_CURRENCIES = '@appkit/onramp_fiat_currencies';
29
28
  const ONRAMP_PREFERRED_FIAT_CURRENCY = '@appkit/onramp_preferred_fiat_currency';
29
+ const ACTIVE_NAMESPACE = '@appkit/active_namespace';
30
+
30
31
  // -- Utility -----------------------------------------------------------------
31
32
  export const StorageUtil = {
32
33
  setWalletConnectDeepLink({ href, name }: { href: string; name: string }) {
@@ -101,29 +102,42 @@ export const StorageUtil = {
101
102
  return [];
102
103
  },
103
104
 
104
- async setConnectedConnector(connectorType: ConnectorType) {
105
+ async setConnectedConnectors({
106
+ type,
107
+ namespaces
108
+ }: {
109
+ type: ConnectorType;
110
+ namespaces: string[];
111
+ }) {
105
112
  try {
106
- await AsyncStorage.setItem(CONNECTED_CONNECTOR, JSON.stringify(connectorType));
113
+ const currentConnectors = (await StorageUtil.getConnectedConnectors()) || [];
114
+ // Only add if it doesn't exist already
115
+ if (!currentConnectors.some(c => c.type === type)) {
116
+ const updatedConnectors = [...currentConnectors, { type, namespaces }];
117
+ await AsyncStorage.setItem(CONNECTED_CONNECTORS, JSON.stringify(updatedConnectors));
118
+ }
107
119
  } catch {
108
120
  console.info('Unable to set Connected Connector');
109
121
  }
110
122
  },
111
123
 
112
- async getConnectedConnector(): Promise<ConnectorType | undefined> {
124
+ async getConnectedConnectors(): Promise<{ type: ConnectorType; namespaces: string[] }[]> {
113
125
  try {
114
- const connector = (await AsyncStorage.getItem(CONNECTED_CONNECTOR)) as ConnectorType;
126
+ const connectors = await AsyncStorage.getItem(CONNECTED_CONNECTORS);
115
127
 
116
- return connector ? JSON.parse(connector) : undefined;
128
+ return connectors ? JSON.parse(connectors) : [];
117
129
  } catch {
118
130
  console.info('Unable to get Connected Connector');
119
131
  }
120
132
 
121
- return undefined;
133
+ return [];
122
134
  },
123
135
 
124
- async removeConnectedConnector() {
136
+ async removeConnectedConnectors(type: ConnectorType) {
125
137
  try {
126
- await AsyncStorage.removeItem(CONNECTED_CONNECTOR);
138
+ const currentConnectors = await StorageUtil.getConnectedConnectors();
139
+ const updatedConnectors = currentConnectors.filter(c => c.type !== type);
140
+ await AsyncStorage.setItem(CONNECTED_CONNECTORS, JSON.stringify(updatedConnectors));
127
141
  } catch {
128
142
  console.info('Unable to remove Connected Connector');
129
143
  }
@@ -243,42 +257,6 @@ export const StorageUtil = {
243
257
  return [];
244
258
  },
245
259
 
246
- async setOnRampCountriesDefaults(countriesDefaults: OnRampCountryDefaults[]) {
247
- try {
248
- const timestamp = Date.now();
249
-
250
- await AsyncStorage.setItem(
251
- ONRAMP_COUNTRIES_DEFAULTS,
252
- JSON.stringify({ data: countriesDefaults, timestamp })
253
- );
254
- } catch {
255
- console.info('Unable to set OnRamp Countries Defaults');
256
- }
257
- },
258
-
259
- async getOnRampCountriesDefaults() {
260
- try {
261
- const result = await AsyncStorage.getItem(ONRAMP_COUNTRIES_DEFAULTS);
262
-
263
- if (!result) {
264
- return [];
265
- }
266
-
267
- const { data, timestamp } = JSON.parse(result);
268
-
269
- // Cache for 1 week
270
- if (timestamp && DateUtil.isMoreThanOneWeekAgo(timestamp)) {
271
- return [];
272
- }
273
-
274
- return data ? (data as OnRampCountryDefaults[]) : [];
275
- } catch {
276
- console.info('Unable to get OnRamp Countries Defaults');
277
- }
278
-
279
- return [];
280
- },
281
-
282
260
  async setOnRampServiceProviders(serviceProviders: OnRampServiceProvider[]) {
283
261
  try {
284
262
  const timestamp = Date.now();
@@ -386,5 +364,39 @@ export const StorageUtil = {
386
364
  }
387
365
 
388
366
  return [];
367
+ },
368
+
369
+ async setActiveNamespace(namespace?: ChainNamespace) {
370
+ try {
371
+ if (!namespace) {
372
+ await AsyncStorage.removeItem(ACTIVE_NAMESPACE);
373
+
374
+ return;
375
+ }
376
+
377
+ await AsyncStorage.setItem(ACTIVE_NAMESPACE, namespace);
378
+ } catch {
379
+ console.info('Unable to set Active Namespace');
380
+ }
381
+ },
382
+
383
+ async getActiveNamespace() {
384
+ try {
385
+ const namespace = (await AsyncStorage.getItem(ACTIVE_NAMESPACE)) as ChainNamespace;
386
+
387
+ return namespace ?? undefined;
388
+ } catch (err) {
389
+ console.info('Unable to get Active Namespace');
390
+ }
391
+
392
+ return undefined;
393
+ },
394
+
395
+ async removeActiveNamespace() {
396
+ try {
397
+ await AsyncStorage.removeItem(ACTIVE_NAMESPACE);
398
+ } catch {
399
+ console.info('Unable to remove Active Namespace');
400
+ }
389
401
  }
390
402
  };
@@ -1,19 +1,17 @@
1
+ import type { Balance, CaipNetworkId } from '@reown/appkit-common-react-native';
1
2
  import { BlockchainApiController } from '../controllers/BlockchainApiController';
2
3
  import { OptionsController } from '../controllers/OptionsController';
3
- import { NetworkController } from '../controllers/NetworkController';
4
- import type {
5
- BlockchainApiBalanceResponse,
6
- BlockchainApiSwapAllowanceRequest,
7
- SwapTokenWithBalance
8
- } from './TypeUtil';
9
- import { AccountController } from '../controllers/AccountController';
10
- import { ConnectionController } from '../controllers/ConnectionController';
4
+ import type { BlockchainApiSwapAllowanceRequest, SwapTokenWithBalance } from './TypeUtil';
5
+ import { ConnectionsController } from '../controllers/ConnectionsController';
6
+ import { ConstantsUtil } from './ConstantsUtil';
11
7
 
12
8
  export const SwapApiUtil = {
13
9
  async getTokenList() {
10
+ const chainId: CaipNetworkId =
11
+ ConnectionsController.state.activeNetwork?.caipNetworkId ?? 'eip155:1';
14
12
  const response = await BlockchainApiController.fetchSwapTokens({
15
13
  projectId: OptionsController.state.projectId,
16
- chainId: NetworkController.state.caipNetwork?.id
14
+ chainId
17
15
  });
18
16
  const tokens =
19
17
  response?.tokens?.map(
@@ -52,7 +50,7 @@ export const SwapApiUtil = {
52
50
 
53
51
  if (response?.allowance && sourceTokenAmount && sourceTokenDecimals) {
54
52
  const parsedValue =
55
- ConnectionController.parseUnits(sourceTokenAmount, sourceTokenDecimals) || 0;
53
+ ConnectionsController.parseUnits(sourceTokenAmount, sourceTokenDecimals) || 0;
56
54
  const hasAllowance = BigInt(response.allowance) >= parsedValue;
57
55
 
58
56
  return hasAllowance;
@@ -61,40 +59,31 @@ export const SwapApiUtil = {
61
59
  return false;
62
60
  },
63
61
 
64
- async getMyTokensWithBalance(forceUpdate?: string) {
65
- const address = AccountController.state.address;
66
- const chainId = NetworkController.state.caipNetwork?.id;
62
+ mapBalancesToSwapTokens(balances?: Balance[]) {
63
+ const { activeNamespace, activeCaipNetworkId } = ConnectionsController.state;
64
+ const address = activeNamespace
65
+ ? ConstantsUtil.NATIVE_TOKEN_ADDRESS[activeNamespace]
66
+ : undefined;
67
67
 
68
- if (!address) {
69
- return [];
70
- }
71
-
72
- const response = await BlockchainApiController.getBalance(address, chainId, forceUpdate);
73
- const balances = response?.balances.filter(balance => balance.quantity.decimals !== '0');
74
-
75
- AccountController.setTokenBalance(balances);
76
-
77
- return this.mapBalancesToSwapTokens(balances);
78
- },
79
-
80
- mapBalancesToSwapTokens(balances?: BlockchainApiBalanceResponse['balances']) {
81
68
  return (
82
- balances?.map(
83
- token =>
84
- ({
85
- ...token,
86
- address: token?.address || NetworkController.getActiveNetworkTokenAddress(),
87
- decimals: parseInt(token.quantity.decimals, 10),
88
- logoUri: token.iconUrl,
89
- eip2612: false
90
- }) as SwapTokenWithBalance
91
- ) || []
69
+ balances
70
+ ?.filter(balance => balance?.quantity?.numeric)
71
+ .map(
72
+ token =>
73
+ ({
74
+ ...token,
75
+ address: token?.address ?? `${token?.chainId ?? activeCaipNetworkId}:${address}`,
76
+ decimals: parseInt(token.quantity?.decimals ?? '0', 10),
77
+ logoUri: token.iconUrl,
78
+ eip2612: false
79
+ }) as SwapTokenWithBalance
80
+ ) || []
92
81
  );
93
82
  },
94
83
 
95
84
  async fetchGasPrice() {
96
85
  const projectId = OptionsController.state.projectId;
97
- const caipNetwork = NetworkController.state.caipNetwork;
86
+ const caipNetwork = ConnectionsController.state.activeNetwork;
98
87
 
99
88
  if (!caipNetwork) {
100
89
  return null;
@@ -102,7 +91,7 @@ export const SwapApiUtil = {
102
91
 
103
92
  return await BlockchainApiController.fetchGasPrice({
104
93
  projectId,
105
- chainId: caipNetwork.id
94
+ chainId: caipNetwork.caipNetworkId
106
95
  });
107
96
  }
108
97
  };