@reown/appkit-core-react-native 0.0.0-feat-coinbase-20250722202925 → 0.0.0-feat-onramp-20250722205908
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.
- package/lib/commonjs/controllers/AccountController.js +17 -20
- package/lib/commonjs/controllers/AccountController.js.map +1 -1
- package/lib/commonjs/controllers/ApiController.js +16 -28
- package/lib/commonjs/controllers/ApiController.js.map +1 -1
- package/lib/commonjs/controllers/BlockchainApiController.js +74 -204
- package/lib/commonjs/controllers/BlockchainApiController.js.map +1 -1
- package/lib/commonjs/controllers/ConnectionController.js +11 -8
- package/lib/commonjs/controllers/ConnectionController.js.map +1 -1
- package/lib/commonjs/controllers/ConnectorController.js +49 -0
- package/lib/commonjs/controllers/ConnectorController.js.map +1 -0
- package/lib/commonjs/controllers/EnsController.js +4 -4
- package/lib/commonjs/controllers/EnsController.js.map +1 -1
- package/lib/commonjs/controllers/EventsController.js +4 -4
- package/lib/commonjs/controllers/EventsController.js.map +1 -1
- package/lib/commonjs/controllers/ModalController.js +7 -6
- package/lib/commonjs/controllers/ModalController.js.map +1 -1
- package/lib/commonjs/controllers/OnRampController.js +69 -22
- package/lib/commonjs/controllers/OnRampController.js.map +1 -1
- package/lib/commonjs/controllers/OptionsController.js +3 -11
- package/lib/commonjs/controllers/OptionsController.js.map +1 -1
- package/lib/commonjs/controllers/RouterController.js +22 -1
- package/lib/commonjs/controllers/RouterController.js.map +1 -1
- package/lib/commonjs/controllers/SendController.js +101 -101
- package/lib/commonjs/controllers/SendController.js.map +1 -1
- package/lib/commonjs/controllers/SnackController.js +5 -29
- package/lib/commonjs/controllers/SnackController.js.map +1 -1
- package/lib/commonjs/controllers/SwapController.js +150 -151
- package/lib/commonjs/controllers/SwapController.js.map +1 -1
- package/lib/commonjs/controllers/ThemeController.js +1 -9
- package/lib/commonjs/controllers/ThemeController.js.map +1 -1
- package/lib/commonjs/controllers/TransactionsController.js +21 -25
- package/lib/commonjs/controllers/TransactionsController.js.map +1 -1
- package/lib/commonjs/controllers/WebviewController.js +52 -0
- package/lib/commonjs/controllers/WebviewController.js.map +1 -0
- package/lib/commonjs/index.js +24 -3
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/utils/AssetUtil.js +15 -3
- package/lib/commonjs/utils/AssetUtil.js.map +1 -1
- package/lib/commonjs/utils/ConnectionUtil.js +33 -0
- package/lib/commonjs/utils/ConnectionUtil.js.map +1 -0
- package/lib/commonjs/utils/ConstantsUtil.js +9 -538
- package/lib/commonjs/utils/ConstantsUtil.js.map +1 -1
- package/lib/commonjs/utils/CoreHelperUtil.js +6 -12
- package/lib/commonjs/utils/CoreHelperUtil.js.map +1 -1
- package/lib/commonjs/utils/FetchUtil.js +28 -9
- package/lib/commonjs/utils/FetchUtil.js.map +1 -1
- package/lib/commonjs/utils/NetworkUtil.js +46 -0
- package/lib/commonjs/utils/NetworkUtil.js.map +1 -0
- package/lib/commonjs/utils/StorageUtil.js +42 -51
- package/lib/commonjs/utils/StorageUtil.js.map +1 -1
- package/lib/commonjs/utils/SwapApiUtil.js +21 -15
- package/lib/commonjs/utils/SwapApiUtil.js.map +1 -1
- package/lib/module/controllers/AccountController.js +17 -20
- package/lib/module/controllers/AccountController.js.map +1 -1
- package/lib/module/controllers/ApiController.js +16 -27
- package/lib/module/controllers/ApiController.js.map +1 -1
- package/lib/module/controllers/BlockchainApiController.js +73 -203
- package/lib/module/controllers/BlockchainApiController.js.map +1 -1
- package/lib/module/controllers/ConnectionController.js +11 -8
- package/lib/module/controllers/ConnectionController.js.map +1 -1
- package/lib/module/controllers/ConnectorController.js +44 -0
- package/lib/module/controllers/ConnectorController.js.map +1 -0
- package/lib/module/controllers/EnsController.js +2 -2
- package/lib/module/controllers/EnsController.js.map +1 -1
- package/lib/module/controllers/EventsController.js +1 -1
- package/lib/module/controllers/EventsController.js.map +1 -1
- package/lib/module/controllers/ModalController.js +7 -6
- package/lib/module/controllers/ModalController.js.map +1 -1
- package/lib/module/controllers/OnRampController.js +70 -23
- package/lib/module/controllers/OnRampController.js.map +1 -1
- package/lib/module/controllers/OptionsController.js +3 -11
- package/lib/module/controllers/OptionsController.js.map +1 -1
- package/lib/module/controllers/RouterController.js +22 -1
- package/lib/module/controllers/RouterController.js.map +1 -1
- package/lib/module/controllers/SendController.js +98 -98
- package/lib/module/controllers/SendController.js.map +1 -1
- package/lib/module/controllers/SnackController.js +5 -29
- package/lib/module/controllers/SnackController.js.map +1 -1
- package/lib/module/controllers/SwapController.js +150 -151
- package/lib/module/controllers/SwapController.js.map +1 -1
- package/lib/module/controllers/ThemeController.js +1 -9
- package/lib/module/controllers/ThemeController.js.map +1 -1
- package/lib/module/controllers/TransactionsController.js +19 -23
- package/lib/module/controllers/TransactionsController.js.map +1 -1
- package/lib/module/controllers/WebviewController.js +47 -0
- package/lib/module/controllers/WebviewController.js.map +1 -0
- package/lib/module/index.js +4 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/utils/AssetUtil.js +15 -3
- package/lib/module/utils/AssetUtil.js.map +1 -1
- package/lib/module/utils/ConnectionUtil.js +27 -0
- package/lib/module/utils/ConnectionUtil.js.map +1 -0
- package/lib/module/utils/ConstantsUtil.js +9 -538
- package/lib/module/utils/ConstantsUtil.js.map +1 -1
- package/lib/module/utils/CoreHelperUtil.js +6 -12
- package/lib/module/utils/CoreHelperUtil.js.map +1 -1
- package/lib/module/utils/FetchUtil.js +28 -9
- package/lib/module/utils/FetchUtil.js.map +1 -1
- package/lib/module/utils/NetworkUtil.js +40 -0
- package/lib/module/utils/NetworkUtil.js.map +1 -0
- package/lib/module/utils/StorageUtil.js +42 -51
- package/lib/module/utils/StorageUtil.js.map +1 -1
- package/lib/module/utils/SwapApiUtil.js +21 -15
- package/lib/module/utils/SwapApiUtil.js.map +1 -1
- package/lib/typescript/controllers/AccountController.d.ts +4 -4
- package/lib/typescript/controllers/AccountController.d.ts.map +1 -1
- package/lib/typescript/controllers/ApiController.d.ts +2 -3
- package/lib/typescript/controllers/ApiController.d.ts.map +1 -1
- package/lib/typescript/controllers/BlockchainApiController.d.ts +15 -29
- package/lib/typescript/controllers/BlockchainApiController.d.ts.map +1 -1
- package/lib/typescript/controllers/ConnectionController.d.ts +11 -3
- package/lib/typescript/controllers/ConnectionController.d.ts.map +1 -1
- package/lib/typescript/controllers/ConnectorController.d.ts +18 -0
- package/lib/typescript/controllers/ConnectorController.d.ts.map +1 -0
- package/lib/typescript/controllers/ModalController.d.ts +1 -1
- package/lib/typescript/controllers/ModalController.d.ts.map +1 -1
- package/lib/typescript/controllers/NetworkController.d.ts +1 -1
- package/lib/typescript/controllers/NetworkController.d.ts.map +1 -1
- package/lib/typescript/controllers/OnRampController.d.ts +3 -1
- package/lib/typescript/controllers/OnRampController.d.ts.map +1 -1
- package/lib/typescript/controllers/OptionsController.d.ts +2 -7
- package/lib/typescript/controllers/OptionsController.d.ts.map +1 -1
- package/lib/typescript/controllers/PublicStateController.d.ts +1 -1
- package/lib/typescript/controllers/PublicStateController.d.ts.map +1 -1
- package/lib/typescript/controllers/RouterController.d.ts +16 -4
- package/lib/typescript/controllers/RouterController.d.ts.map +1 -1
- package/lib/typescript/controllers/SendController.d.ts +7 -5
- package/lib/typescript/controllers/SendController.d.ts.map +1 -1
- package/lib/typescript/controllers/SnackController.d.ts +3 -3
- package/lib/typescript/controllers/SnackController.d.ts.map +1 -1
- package/lib/typescript/controllers/SwapController.d.ts +11 -12
- package/lib/typescript/controllers/SwapController.d.ts.map +1 -1
- package/lib/typescript/controllers/ThemeController.d.ts +1 -1
- package/lib/typescript/controllers/ThemeController.d.ts.map +1 -1
- package/lib/typescript/controllers/TransactionsController.d.ts +3 -3
- package/lib/typescript/controllers/TransactionsController.d.ts.map +1 -1
- package/lib/typescript/controllers/WebviewController.d.ts +21 -0
- package/lib/typescript/controllers/WebviewController.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +4 -1
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/utils/AssetUtil.d.ts +3 -2
- package/lib/typescript/utils/AssetUtil.d.ts.map +1 -1
- package/lib/typescript/utils/ConnectionUtil.d.ts +4 -0
- package/lib/typescript/utils/ConnectionUtil.d.ts.map +1 -0
- package/lib/typescript/utils/ConstantsUtil.d.ts +3 -422
- package/lib/typescript/utils/ConstantsUtil.d.ts.map +1 -1
- package/lib/typescript/utils/CoreHelperUtil.d.ts +4 -5
- package/lib/typescript/utils/CoreHelperUtil.d.ts.map +1 -1
- package/lib/typescript/utils/FetchUtil.d.ts +1 -1
- package/lib/typescript/utils/FetchUtil.d.ts.map +1 -1
- package/lib/typescript/utils/NetworkUtil.d.ts +8 -0
- package/lib/typescript/utils/NetworkUtil.d.ts.map +1 -0
- package/lib/typescript/utils/StorageUtil.d.ts +7 -14
- package/lib/typescript/utils/StorageUtil.d.ts.map +1 -1
- package/lib/typescript/utils/SwapApiUtil.d.ts +3 -3
- package/lib/typescript/utils/SwapApiUtil.d.ts.map +1 -1
- package/lib/typescript/utils/TypeUtil.d.ts +191 -42
- package/lib/typescript/utils/TypeUtil.d.ts.map +1 -1
- package/package.json +4 -4
- package/src/controllers/AccountController.ts +27 -23
- package/src/controllers/ApiController.ts +10 -29
- package/src/controllers/BlockchainApiController.ts +65 -179
- package/src/controllers/ConnectionController.ts +24 -12
- package/src/controllers/ConnectorController.ts +63 -0
- package/src/controllers/EnsController.ts +2 -2
- package/src/controllers/EventsController.ts +1 -1
- package/src/controllers/ModalController.ts +8 -8
- package/src/controllers/NetworkController.ts +1 -1
- package/src/controllers/OnRampController.ts +99 -35
- package/src/controllers/OptionsController.ts +13 -19
- package/src/controllers/PublicStateController.ts +1 -1
- package/src/controllers/RouterController.ts +54 -5
- package/src/controllers/SendController.ts +113 -124
- package/src/controllers/SnackController.ts +5 -31
- package/src/controllers/SwapController.ts +181 -174
- package/src/controllers/ThemeController.ts +2 -11
- package/src/controllers/TransactionsController.ts +20 -26
- package/src/controllers/WebviewController.ts +63 -0
- package/src/index.ts +6 -3
- package/src/utils/AssetUtil.ts +20 -4
- package/src/utils/ConnectionUtil.ts +27 -0
- package/src/utils/ConstantsUtil.ts +9 -544
- package/src/utils/CoreHelperUtil.ts +9 -34
- package/src/utils/FetchUtil.ts +31 -10
- package/src/utils/NetworkUtil.ts +33 -0
- package/src/utils/StorageUtil.ts +48 -60
- package/src/utils/SwapApiUtil.ts +38 -27
- package/src/utils/TypeUtil.ts +193 -43
- package/lib/commonjs/controllers/ConnectionsController.js +0 -387
- package/lib/commonjs/controllers/ConnectionsController.js.map +0 -1
- package/lib/module/controllers/ConnectionsController.js +0 -382
- package/lib/module/controllers/ConnectionsController.js.map +0 -1
- package/lib/typescript/controllers/ConnectionsController.d.ts +0 -53
- package/lib/typescript/controllers/ConnectionsController.d.ts.map +0 -1
- package/src/controllers/ConnectionsController.ts +0 -509
package/src/utils/FetchUtil.ts
CHANGED
|
@@ -8,7 +8,7 @@ interface Options {
|
|
|
8
8
|
|
|
9
9
|
interface RequestArguments {
|
|
10
10
|
path: string;
|
|
11
|
-
headers?:
|
|
11
|
+
headers?: HeadersInit_;
|
|
12
12
|
params?: Record<string, string | undefined>;
|
|
13
13
|
cache?: RequestCache;
|
|
14
14
|
signal?: AbortSignal;
|
|
@@ -88,20 +88,41 @@ export class FetchUtil {
|
|
|
88
88
|
}
|
|
89
89
|
|
|
90
90
|
private createUrl({ path, params }: RequestArguments) {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
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}`;
|
|
98
101
|
}
|
|
99
102
|
|
|
103
|
+
const allParams: Record<string, string | undefined> = { ...params };
|
|
100
104
|
if (this.clientId) {
|
|
101
|
-
|
|
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
|
+
}
|
|
102
123
|
}
|
|
103
124
|
|
|
104
|
-
return
|
|
125
|
+
return fullUrl;
|
|
105
126
|
}
|
|
106
127
|
|
|
107
128
|
private async processResponse<T>(response: Response) {
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { RouterUtil } from './RouterUtil';
|
|
2
|
+
import { RouterController } from '../controllers/RouterController';
|
|
3
|
+
import { NetworkController } from '../controllers/NetworkController';
|
|
4
|
+
import { AccountController } from '../controllers/AccountController';
|
|
5
|
+
import { ConnectorController } from '../controllers/ConnectorController';
|
|
6
|
+
import { SwapController } from '../controllers/SwapController';
|
|
7
|
+
import type { CaipNetwork } from '../utils/TypeUtil';
|
|
8
|
+
|
|
9
|
+
export const NetworkUtil = {
|
|
10
|
+
async handleNetworkSwitch(network: CaipNetwork) {
|
|
11
|
+
const { isConnected } = AccountController.state;
|
|
12
|
+
const { caipNetwork, approvedCaipNetworkIds, supportsAllNetworks } = NetworkController.state;
|
|
13
|
+
const isAuthConnected = ConnectorController.state.connectedConnector === 'AUTH';
|
|
14
|
+
let eventData = null;
|
|
15
|
+
|
|
16
|
+
if (isConnected && caipNetwork?.id !== network.id) {
|
|
17
|
+
if (approvedCaipNetworkIds?.includes(network.id) && !isAuthConnected) {
|
|
18
|
+
await NetworkController.switchActiveNetwork(network);
|
|
19
|
+
RouterUtil.navigateAfterNetworkSwitch(['ConnectingSiwe']);
|
|
20
|
+
eventData = { type: 'SWITCH_NETWORK', networkId: network.id };
|
|
21
|
+
} else if (supportsAllNetworks || isAuthConnected) {
|
|
22
|
+
RouterController.push('SwitchNetwork', { network });
|
|
23
|
+
}
|
|
24
|
+
} else if (!isConnected) {
|
|
25
|
+
NetworkController.setCaipNetwork(network);
|
|
26
|
+
RouterController.push('Connect');
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
SwapController.resetState();
|
|
30
|
+
|
|
31
|
+
return eventData;
|
|
32
|
+
}
|
|
33
|
+
};
|
package/src/utils/StorageUtil.ts
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
import AsyncStorage from '@react-native-async-storage/async-storage';
|
|
3
3
|
import type {
|
|
4
4
|
OnRampCountry,
|
|
5
|
+
OnRampCountryDefaults,
|
|
5
6
|
OnRampFiatCurrency,
|
|
6
7
|
OnRampFiatLimit,
|
|
7
8
|
OnRampServiceProvider,
|
|
@@ -10,24 +11,22 @@ import type {
|
|
|
10
11
|
import {
|
|
11
12
|
DateUtil,
|
|
12
13
|
type SocialProvider,
|
|
13
|
-
type ConnectorType
|
|
14
|
-
type ChainNamespace
|
|
14
|
+
type ConnectorType
|
|
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
|
|
21
|
+
const CONNECTED_CONNECTOR = '@w3m/connected_connector';
|
|
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';
|
|
25
26
|
const ONRAMP_SERVICE_PROVIDERS = '@appkit/onramp_service_providers';
|
|
26
27
|
const ONRAMP_FIAT_LIMITS = '@appkit/onramp_fiat_limits';
|
|
27
28
|
const ONRAMP_FIAT_CURRENCIES = '@appkit/onramp_fiat_currencies';
|
|
28
29
|
const ONRAMP_PREFERRED_FIAT_CURRENCY = '@appkit/onramp_preferred_fiat_currency';
|
|
29
|
-
const ACTIVE_NAMESPACE = '@appkit/active_namespace';
|
|
30
|
-
|
|
31
30
|
// -- Utility -----------------------------------------------------------------
|
|
32
31
|
export const StorageUtil = {
|
|
33
32
|
setWalletConnectDeepLink({ href, name }: { href: string; name: string }) {
|
|
@@ -102,42 +101,29 @@ export const StorageUtil = {
|
|
|
102
101
|
return [];
|
|
103
102
|
},
|
|
104
103
|
|
|
105
|
-
async
|
|
106
|
-
type,
|
|
107
|
-
namespaces
|
|
108
|
-
}: {
|
|
109
|
-
type: ConnectorType;
|
|
110
|
-
namespaces: string[];
|
|
111
|
-
}) {
|
|
104
|
+
async setConnectedConnector(connectorType: ConnectorType) {
|
|
112
105
|
try {
|
|
113
|
-
|
|
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
|
-
}
|
|
106
|
+
await AsyncStorage.setItem(CONNECTED_CONNECTOR, JSON.stringify(connectorType));
|
|
119
107
|
} catch {
|
|
120
108
|
console.info('Unable to set Connected Connector');
|
|
121
109
|
}
|
|
122
110
|
},
|
|
123
111
|
|
|
124
|
-
async
|
|
112
|
+
async getConnectedConnector(): Promise<ConnectorType | undefined> {
|
|
125
113
|
try {
|
|
126
|
-
const
|
|
114
|
+
const connector = (await AsyncStorage.getItem(CONNECTED_CONNECTOR)) as ConnectorType;
|
|
127
115
|
|
|
128
|
-
return
|
|
116
|
+
return connector ? JSON.parse(connector) : undefined;
|
|
129
117
|
} catch {
|
|
130
118
|
console.info('Unable to get Connected Connector');
|
|
131
119
|
}
|
|
132
120
|
|
|
133
|
-
return
|
|
121
|
+
return undefined;
|
|
134
122
|
},
|
|
135
123
|
|
|
136
|
-
async
|
|
124
|
+
async removeConnectedConnector() {
|
|
137
125
|
try {
|
|
138
|
-
|
|
139
|
-
const updatedConnectors = currentConnectors.filter(c => c.type !== type);
|
|
140
|
-
await AsyncStorage.setItem(CONNECTED_CONNECTORS, JSON.stringify(updatedConnectors));
|
|
126
|
+
await AsyncStorage.removeItem(CONNECTED_CONNECTOR);
|
|
141
127
|
} catch {
|
|
142
128
|
console.info('Unable to remove Connected Connector');
|
|
143
129
|
}
|
|
@@ -257,6 +243,42 @@ export const StorageUtil = {
|
|
|
257
243
|
return [];
|
|
258
244
|
},
|
|
259
245
|
|
|
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
|
+
|
|
260
282
|
async setOnRampServiceProviders(serviceProviders: OnRampServiceProvider[]) {
|
|
261
283
|
try {
|
|
262
284
|
const timestamp = Date.now();
|
|
@@ -364,39 +386,5 @@ export const StorageUtil = {
|
|
|
364
386
|
}
|
|
365
387
|
|
|
366
388
|
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
|
-
}
|
|
401
389
|
}
|
|
402
390
|
};
|
package/src/utils/SwapApiUtil.ts
CHANGED
|
@@ -1,17 +1,19 @@
|
|
|
1
|
-
import type { Balance, CaipNetworkId } from '@reown/appkit-common-react-native';
|
|
2
1
|
import { BlockchainApiController } from '../controllers/BlockchainApiController';
|
|
3
2
|
import { OptionsController } from '../controllers/OptionsController';
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
|
|
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';
|
|
7
11
|
|
|
8
12
|
export const SwapApiUtil = {
|
|
9
13
|
async getTokenList() {
|
|
10
|
-
const chainId: CaipNetworkId =
|
|
11
|
-
ConnectionsController.state.activeNetwork?.caipNetworkId ?? 'eip155:1';
|
|
12
14
|
const response = await BlockchainApiController.fetchSwapTokens({
|
|
13
15
|
projectId: OptionsController.state.projectId,
|
|
14
|
-
chainId
|
|
16
|
+
chainId: NetworkController.state.caipNetwork?.id
|
|
15
17
|
});
|
|
16
18
|
const tokens =
|
|
17
19
|
response?.tokens?.map(
|
|
@@ -50,7 +52,7 @@ export const SwapApiUtil = {
|
|
|
50
52
|
|
|
51
53
|
if (response?.allowance && sourceTokenAmount && sourceTokenDecimals) {
|
|
52
54
|
const parsedValue =
|
|
53
|
-
|
|
55
|
+
ConnectionController.parseUnits(sourceTokenAmount, sourceTokenDecimals) || 0;
|
|
54
56
|
const hasAllowance = BigInt(response.allowance) >= parsedValue;
|
|
55
57
|
|
|
56
58
|
return hasAllowance;
|
|
@@ -59,31 +61,40 @@ export const SwapApiUtil = {
|
|
|
59
61
|
return false;
|
|
60
62
|
},
|
|
61
63
|
|
|
62
|
-
|
|
63
|
-
const
|
|
64
|
-
const
|
|
65
|
-
? ConstantsUtil.NATIVE_TOKEN_ADDRESS[activeNamespace]
|
|
66
|
-
: undefined;
|
|
64
|
+
async getMyTokensWithBalance(forceUpdate?: string) {
|
|
65
|
+
const address = AccountController.state.address;
|
|
66
|
+
const chainId = NetworkController.state.caipNetwork?.id;
|
|
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']) {
|
|
68
81
|
return (
|
|
69
|
-
balances
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
(
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
}) as SwapTokenWithBalance
|
|
80
|
-
) || []
|
|
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
|
+
) || []
|
|
81
92
|
);
|
|
82
93
|
},
|
|
83
94
|
|
|
84
95
|
async fetchGasPrice() {
|
|
85
96
|
const projectId = OptionsController.state.projectId;
|
|
86
|
-
const caipNetwork =
|
|
97
|
+
const caipNetwork = NetworkController.state.caipNetwork;
|
|
87
98
|
|
|
88
99
|
if (!caipNetwork) {
|
|
89
100
|
return null;
|
|
@@ -91,7 +102,7 @@ export const SwapApiUtil = {
|
|
|
91
102
|
|
|
92
103
|
return await BlockchainApiController.fetchGasPrice({
|
|
93
104
|
projectId,
|
|
94
|
-
chainId: caipNetwork.
|
|
105
|
+
chainId: caipNetwork.id
|
|
95
106
|
});
|
|
96
107
|
}
|
|
97
108
|
};
|