@reown/appkit-core 1.7.0-rc.3.0 → 1.7.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.
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/dist/esm/exports/modal.js +0 -2
- package/dist/esm/exports/modal.js.map +0 -1
- package/dist/esm/src/controllers/AccountController.js +0 -160
- package/dist/esm/src/controllers/AccountController.js.map +0 -1
- package/dist/esm/src/controllers/AlertController.js +0 -35
- package/dist/esm/src/controllers/AlertController.js.map +0 -1
- package/dist/esm/src/controllers/ApiController.js +0 -246
- package/dist/esm/src/controllers/ApiController.js.map +0 -1
- package/dist/esm/src/controllers/AssetController.js +0 -43
- package/dist/esm/src/controllers/AssetController.js.map +0 -1
- package/dist/esm/src/controllers/BlockchainApiController.js +0 -472
- package/dist/esm/src/controllers/BlockchainApiController.js.map +0 -1
- package/dist/esm/src/controllers/ChainController.js +0 -486
- package/dist/esm/src/controllers/ChainController.js.map +0 -1
- package/dist/esm/src/controllers/ConnectionController.js +0 -195
- package/dist/esm/src/controllers/ConnectionController.js.map +0 -1
- package/dist/esm/src/controllers/ConnectorController.js +0 -218
- package/dist/esm/src/controllers/ConnectorController.js.map +0 -1
- package/dist/esm/src/controllers/EnsController.js +0 -144
- package/dist/esm/src/controllers/EnsController.js.map +0 -1
- package/dist/esm/src/controllers/EventsController.js +0 -76
- package/dist/esm/src/controllers/EventsController.js.map +0 -1
- package/dist/esm/src/controllers/ModalController.js +0 -102
- package/dist/esm/src/controllers/ModalController.js.map +0 -1
- package/dist/esm/src/controllers/OnRampController.js +0 -132
- package/dist/esm/src/controllers/OnRampController.js.map +0 -1
- package/dist/esm/src/controllers/OptionsController.js +0 -146
- package/dist/esm/src/controllers/OptionsController.js.map +0 -1
- package/dist/esm/src/controllers/PublicStateController.js +0 -20
- package/dist/esm/src/controllers/PublicStateController.js.map +0 -1
- package/dist/esm/src/controllers/RouterController.js +0 -125
- package/dist/esm/src/controllers/RouterController.js.map +0 -1
- package/dist/esm/src/controllers/SendController.js +0 -305
- package/dist/esm/src/controllers/SendController.js.map +0 -1
- package/dist/esm/src/controllers/SnackController.js +0 -62
- package/dist/esm/src/controllers/SnackController.js.map +0 -1
- package/dist/esm/src/controllers/SwapController.js +0 -674
- package/dist/esm/src/controllers/SwapController.js.map +0 -1
- package/dist/esm/src/controllers/ThemeController.js +0 -55
- package/dist/esm/src/controllers/ThemeController.js.map +0 -1
- package/dist/esm/src/controllers/TooltipController.js +0 -41
- package/dist/esm/src/controllers/TooltipController.js.map +0 -1
- package/dist/esm/src/controllers/TransactionsController.js +0 -113
- package/dist/esm/src/controllers/TransactionsController.js.map +0 -1
- package/dist/esm/src/utils/AssetUtil.js +0 -85
- package/dist/esm/src/utils/AssetUtil.js.map +0 -1
- package/dist/esm/src/utils/ConstantsUtil.js +0 -237
- package/dist/esm/src/utils/ConstantsUtil.js.map +0 -1
- package/dist/esm/src/utils/CoreHelperUtil.js +0 -354
- package/dist/esm/src/utils/CoreHelperUtil.js.map +0 -1
- package/dist/esm/src/utils/ERC7811Util.js +0 -111
- package/dist/esm/src/utils/ERC7811Util.js.map +0 -1
- package/dist/esm/src/utils/EnsUtil.js +0 -10
- package/dist/esm/src/utils/EnsUtil.js.map +0 -1
- package/dist/esm/src/utils/FetchUtil.js +0 -73
- package/dist/esm/src/utils/FetchUtil.js.map +0 -1
- package/dist/esm/src/utils/MobileWallet.js +0 -31
- package/dist/esm/src/utils/MobileWallet.js.map +0 -1
- package/dist/esm/src/utils/OptionsUtil.js +0 -29
- package/dist/esm/src/utils/OptionsUtil.js.map +0 -1
- package/dist/esm/src/utils/RouterUtil.js +0 -23
- package/dist/esm/src/utils/RouterUtil.js.map +0 -1
- package/dist/esm/src/utils/SIWXUtil.js +0 -258
- package/dist/esm/src/utils/SIWXUtil.js.map +0 -1
- package/dist/esm/src/utils/SendApiUtil.js +0 -65
- package/dist/esm/src/utils/SendApiUtil.js.map +0 -1
- package/dist/esm/src/utils/StorageUtil.js +0 -485
- package/dist/esm/src/utils/StorageUtil.js.map +0 -1
- package/dist/esm/src/utils/SwapApiUtil.js +0 -89
- package/dist/esm/src/utils/SwapApiUtil.js.map +0 -1
- package/dist/esm/src/utils/SwapCalculationUtil.js +0 -74
- package/dist/esm/src/utils/SwapCalculationUtil.js.map +0 -1
- package/dist/esm/src/utils/TypeUtil.js +0 -2
- package/dist/esm/src/utils/TypeUtil.js.map +0 -1
- package/dist/esm/tests/constants/OnrampTransactions.js +0 -151
- package/dist/esm/tests/constants/OnrampTransactions.js.map +0 -1
- package/dist/esm/tests/controllers/AccountController.test.js +0 -186
- package/dist/esm/tests/controllers/AccountController.test.js.map +0 -1
- package/dist/esm/tests/controllers/AlertController.test.js +0 -48
- package/dist/esm/tests/controllers/AlertController.test.js.map +0 -1
- package/dist/esm/tests/controllers/ApiController.test.js +0 -594
- package/dist/esm/tests/controllers/ApiController.test.js.map +0 -1
- package/dist/esm/tests/controllers/AssetController.test.js +0 -92
- package/dist/esm/tests/controllers/AssetController.test.js.map +0 -1
- package/dist/esm/tests/controllers/BlockchainApiController.test.js +0 -38
- package/dist/esm/tests/controllers/BlockchainApiController.test.js.map +0 -1
- package/dist/esm/tests/controllers/ChainController.test.js +0 -385
- package/dist/esm/tests/controllers/ChainController.test.js.map +0 -1
- package/dist/esm/tests/controllers/ConnectionController.test.js +0 -151
- package/dist/esm/tests/controllers/ConnectionController.test.js.map +0 -1
- package/dist/esm/tests/controllers/ConnectorController.test.js +0 -282
- package/dist/esm/tests/controllers/ConnectorController.test.js.map +0 -1
- package/dist/esm/tests/controllers/EnsController.test.js +0 -186
- package/dist/esm/tests/controllers/EnsController.test.js.map +0 -1
- package/dist/esm/tests/controllers/EventsController.test.js +0 -47
- package/dist/esm/tests/controllers/EventsController.test.js.map +0 -1
- package/dist/esm/tests/controllers/ModalController.test.js +0 -32
- package/dist/esm/tests/controllers/ModalController.test.js.map +0 -1
- package/dist/esm/tests/controllers/OnRampController.test.js +0 -118
- package/dist/esm/tests/controllers/OnRampController.test.js.map +0 -1
- package/dist/esm/tests/controllers/OptionsController.test.js +0 -42
- package/dist/esm/tests/controllers/OptionsController.test.js.map +0 -1
- package/dist/esm/tests/controllers/PublicStateController.test.js +0 -33
- package/dist/esm/tests/controllers/PublicStateController.test.js.map +0 -1
- package/dist/esm/tests/controllers/RouterController.test.js +0 -103
- package/dist/esm/tests/controllers/RouterController.test.js.map +0 -1
- package/dist/esm/tests/controllers/SendController.test.js +0 -136
- package/dist/esm/tests/controllers/SendController.test.js.map +0 -1
- package/dist/esm/tests/controllers/SnackController.test.js +0 -86
- package/dist/esm/tests/controllers/SnackController.test.js.map +0 -1
- package/dist/esm/tests/controllers/SwapController.test.js +0 -105
- package/dist/esm/tests/controllers/SwapController.test.js.map +0 -1
- package/dist/esm/tests/controllers/ThemeController.test.js +0 -26
- package/dist/esm/tests/controllers/ThemeController.test.js.map +0 -1
- package/dist/esm/tests/controllers/TooltipController.test.js +0 -40
- package/dist/esm/tests/controllers/TooltipController.test.js.map +0 -1
- package/dist/esm/tests/controllers/TransactionsController.test.js +0 -239
- package/dist/esm/tests/controllers/TransactionsController.test.js.map +0 -1
- package/dist/esm/tests/hooks/react.test.js +0 -149
- package/dist/esm/tests/hooks/react.test.js.map +0 -1
- package/dist/esm/tests/hooks/vue.test.js +0 -56
- package/dist/esm/tests/hooks/vue.test.js.map +0 -1
- package/dist/esm/tests/mocks/ChainController.js +0 -24
- package/dist/esm/tests/mocks/ChainController.js.map +0 -1
- package/dist/esm/tests/mocks/SwapController.js +0 -118
- package/dist/esm/tests/mocks/SwapController.js.map +0 -1
- package/dist/esm/tests/mocks/useAppKitAccount.js +0 -41
- package/dist/esm/tests/mocks/useAppKitAccount.js.map +0 -1
- package/dist/esm/tests/utils/AssetUtil.test.js +0 -108
- package/dist/esm/tests/utils/AssetUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/CoreHelperUtil.test.js +0 -67
- package/dist/esm/tests/utils/CoreHelperUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/ERC7811.test.js +0 -268
- package/dist/esm/tests/utils/ERC7811.test.js.map +0 -1
- package/dist/esm/tests/utils/EnsUtil.test.js +0 -23
- package/dist/esm/tests/utils/EnsUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/FetchUtil.test.js +0 -175
- package/dist/esm/tests/utils/FetchUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/MobileWallet.test.js +0 -72
- package/dist/esm/tests/utils/MobileWallet.test.js.map +0 -1
- package/dist/esm/tests/utils/OptionsUtil.test.js +0 -20
- package/dist/esm/tests/utils/OptionsUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/RouterUtil.test.js +0 -62
- package/dist/esm/tests/utils/RouterUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/SendApiUtil.test.js +0 -340
- package/dist/esm/tests/utils/SendApiUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/StorageUtil.test.js +0 -162
- package/dist/esm/tests/utils/StorageUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/SwapApiUtil.test.js +0 -213
- package/dist/esm/tests/utils/SwapApiUtil.test.js.map +0 -1
- package/dist/esm/tests/utils/SwapCalculationUtil.test.js +0 -80
- package/dist/esm/tests/utils/SwapCalculationUtil.test.js.map +0 -1
- package/dist/types/exports/modal.d.ts +0 -2
- package/dist/types/src/controllers/AccountController.d.ts +0 -56
- package/dist/types/src/controllers/AlertController.d.ts +0 -17
- package/dist/types/src/controllers/ApiController.d.ts +0 -51
- package/dist/types/src/controllers/AssetController.d.ts +0 -22
- package/dist/types/src/controllers/BlockchainApiController.d.ts +0 -76
- package/dist/types/src/controllers/ChainController.d.ts +0 -65
- package/dist/types/src/controllers/ConnectionController.d.ts +0 -86
- package/dist/types/src/controllers/ConnectorController.d.ts +0 -49
- package/dist/types/src/controllers/EnsController.d.ts +0 -26
- package/dist/types/src/controllers/EventsController.d.ts +0 -17
- package/dist/types/src/controllers/ModalController.d.ts +0 -22
- package/dist/types/src/controllers/OnRampController.d.ts +0 -55
- package/dist/types/src/controllers/OptionsController.d.ts +0 -364
- package/dist/types/src/controllers/PublicStateController.d.ts +0 -33
- package/dist/types/src/controllers/RouterController.d.ts +0 -56
- package/dist/types/src/controllers/SendController.d.ts +0 -52
- package/dist/types/src/controllers/SnackController.d.ts +0 -29
- package/dist/types/src/controllers/SwapController.d.ts +0 -127
- package/dist/types/src/controllers/ThemeController.d.ts +0 -30
- package/dist/types/src/controllers/TooltipController.d.ts +0 -25
- package/dist/types/src/controllers/TransactionsController.d.ts +0 -25
- package/dist/types/src/utils/AssetUtil.d.ts +0 -15
- package/dist/types/src/utils/ConstantsUtil.d.ts +0 -85
- package/dist/types/src/utils/CoreHelperUtil.d.ts +0 -56
- package/dist/types/src/utils/ERC7811Util.d.ts +0 -67
- package/dist/types/src/utils/EnsUtil.d.ts +0 -3
- package/dist/types/src/utils/FetchUtil.d.ts +0 -26
- package/dist/types/src/utils/MobileWallet.d.ts +0 -9
- package/dist/types/src/utils/OptionsUtil.d.ts +0 -5
- package/dist/types/src/utils/RouterUtil.d.ts +0 -4
- package/dist/types/src/utils/SIWXUtil.d.ts +0 -183
- package/dist/types/src/utils/SendApiUtil.d.ts +0 -13
- package/dist/types/src/utils/StorageUtil.d.ts +0 -99
- package/dist/types/src/utils/SwapApiUtil.d.ts +0 -27
- package/dist/types/src/utils/SwapCalculationUtil.d.ts +0 -22
- package/dist/types/src/utils/TypeUtil.d.ts +0 -981
- package/dist/types/tests/constants/OnrampTransactions.d.ts +0 -138
- package/dist/types/tests/controllers/AccountController.test.d.ts +0 -1
- package/dist/types/tests/controllers/AlertController.test.d.ts +0 -1
- package/dist/types/tests/controllers/ApiController.test.d.ts +0 -1
- package/dist/types/tests/controllers/AssetController.test.d.ts +0 -1
- package/dist/types/tests/controllers/BlockchainApiController.test.d.ts +0 -1
- package/dist/types/tests/controllers/ChainController.test.d.ts +0 -1
- package/dist/types/tests/controllers/ConnectionController.test.d.ts +0 -1
- package/dist/types/tests/controllers/ConnectorController.test.d.ts +0 -1
- package/dist/types/tests/controllers/EnsController.test.d.ts +0 -1
- package/dist/types/tests/controllers/EventsController.test.d.ts +0 -1
- package/dist/types/tests/controllers/ModalController.test.d.ts +0 -1
- package/dist/types/tests/controllers/OnRampController.test.d.ts +0 -1
- package/dist/types/tests/controllers/OptionsController.test.d.ts +0 -1
- package/dist/types/tests/controllers/PublicStateController.test.d.ts +0 -1
- package/dist/types/tests/controllers/RouterController.test.d.ts +0 -1
- package/dist/types/tests/controllers/SendController.test.d.ts +0 -1
- package/dist/types/tests/controllers/SnackController.test.d.ts +0 -1
- package/dist/types/tests/controllers/SwapController.test.d.ts +0 -1
- package/dist/types/tests/controllers/ThemeController.test.d.ts +0 -1
- package/dist/types/tests/controllers/TooltipController.test.d.ts +0 -1
- package/dist/types/tests/controllers/TransactionsController.test.d.ts +0 -1
- package/dist/types/tests/hooks/react.test.d.ts +0 -1
- package/dist/types/tests/hooks/vue.test.d.ts +0 -2
- package/dist/types/tests/mocks/ChainController.d.ts +0 -2
- package/dist/types/tests/mocks/SwapController.d.ts +0 -75
- package/dist/types/tests/mocks/useAppKitAccount.d.ts +0 -40
- package/dist/types/tests/utils/AssetUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/CoreHelperUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/ERC7811.test.d.ts +0 -1
- package/dist/types/tests/utils/EnsUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/FetchUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/MobileWallet.test.d.ts +0 -1
- package/dist/types/tests/utils/OptionsUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/RouterUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/SendApiUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/StorageUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/SwapApiUtil.test.d.ts +0 -1
- package/dist/types/tests/utils/SwapCalculationUtil.test.d.ts +0 -1
|
@@ -1,213 +0,0 @@
|
|
|
1
|
-
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
2
|
-
import { AccountController } from '../../src/controllers/AccountController';
|
|
3
|
-
import { BlockchainApiController } from '../../src/controllers/BlockchainApiController';
|
|
4
|
-
import { ChainController } from '../../src/controllers/ChainController';
|
|
5
|
-
import { ConnectionController } from '../../src/controllers/ConnectionController';
|
|
6
|
-
import { OptionsController } from '../../src/controllers/OptionsController';
|
|
7
|
-
import { SwapApiUtil } from '../../src/utils/SwapApiUtil';
|
|
8
|
-
// Mock the controllers
|
|
9
|
-
vi.mock('../../src/controllers/ChainController');
|
|
10
|
-
vi.mock('../../src/controllers/BlockchainApiController');
|
|
11
|
-
vi.mock('../../src/controllers/OptionsController');
|
|
12
|
-
vi.mock('../../src/controllers/ConnectionController');
|
|
13
|
-
vi.mock('../../src/controllers/AccountController');
|
|
14
|
-
vi.mock('../../src/controllers/ChainController');
|
|
15
|
-
const mockSolanaNetwork = {
|
|
16
|
-
id: '5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp',
|
|
17
|
-
caipNetworkId: 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp',
|
|
18
|
-
chainNamespace: 'solana',
|
|
19
|
-
name: 'Solana',
|
|
20
|
-
nativeCurrency: {
|
|
21
|
-
name: 'Solana',
|
|
22
|
-
decimals: 9,
|
|
23
|
-
symbol: 'SOL'
|
|
24
|
-
},
|
|
25
|
-
rpcUrls: {
|
|
26
|
-
default: {
|
|
27
|
-
http: ['https://api.mainnet-beta.solana.com']
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
const mockEthereumNetwork = {
|
|
32
|
-
id: '1',
|
|
33
|
-
chainNamespace: 'eip155',
|
|
34
|
-
caipNetworkId: 'eip155:1',
|
|
35
|
-
name: 'Ethereum',
|
|
36
|
-
nativeCurrency: {
|
|
37
|
-
name: 'Ethereum',
|
|
38
|
-
decimals: 18,
|
|
39
|
-
symbol: 'ETH'
|
|
40
|
-
},
|
|
41
|
-
rpcUrls: {
|
|
42
|
-
default: {
|
|
43
|
-
http: ['https://mainnet.infura.io/v3/YOUR-PROJECT-ID']
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
describe('SwapApiUtil', () => {
|
|
48
|
-
beforeEach(() => {
|
|
49
|
-
vi.resetAllMocks();
|
|
50
|
-
});
|
|
51
|
-
afterEach(() => {
|
|
52
|
-
vi.restoreAllMocks();
|
|
53
|
-
});
|
|
54
|
-
describe('getTokenList', () => {
|
|
55
|
-
it('should return a list of tokens', async () => {
|
|
56
|
-
const mockTokens = [{ address: '0x123', symbol: 'TEST', name: 'Test Token', decimals: 18 }];
|
|
57
|
-
ChainController.state.activeCaipNetwork = mockEthereumNetwork;
|
|
58
|
-
OptionsController.state.projectId = 'test-project-id';
|
|
59
|
-
BlockchainApiController.fetchSwapTokens = vi.fn().mockResolvedValue({ tokens: mockTokens });
|
|
60
|
-
const result = await SwapApiUtil.getTokenList();
|
|
61
|
-
expect(BlockchainApiController.fetchSwapTokens).toHaveBeenCalledWith({
|
|
62
|
-
chainId: 'eip155:1'
|
|
63
|
-
});
|
|
64
|
-
expect(result).toEqual([
|
|
65
|
-
{
|
|
66
|
-
...mockTokens[0],
|
|
67
|
-
eip2612: false,
|
|
68
|
-
quantity: { decimals: '0', numeric: '0' },
|
|
69
|
-
price: 0,
|
|
70
|
-
value: 0
|
|
71
|
-
}
|
|
72
|
-
]);
|
|
73
|
-
});
|
|
74
|
-
it('should return an empty array if no tokens are fetched', async () => {
|
|
75
|
-
BlockchainApiController.fetchSwapTokens = vi.fn().mockResolvedValue({ tokens: null });
|
|
76
|
-
const result = await SwapApiUtil.getTokenList();
|
|
77
|
-
expect(result).toEqual([]);
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
describe('fetchGasPrice', () => {
|
|
81
|
-
it('should fetch gas price for EVM chain', async () => {
|
|
82
|
-
ChainController.state.activeCaipNetwork = mockEthereumNetwork;
|
|
83
|
-
OptionsController.state.projectId = 'test-project-id';
|
|
84
|
-
BlockchainApiController.fetchGasPrice = vi
|
|
85
|
-
.fn()
|
|
86
|
-
.mockResolvedValue({ standard: '20', fast: '25', instant: '30' });
|
|
87
|
-
const result = await SwapApiUtil.fetchGasPrice();
|
|
88
|
-
expect(BlockchainApiController.fetchGasPrice).toHaveBeenCalledWith({
|
|
89
|
-
chainId: 'eip155:1'
|
|
90
|
-
});
|
|
91
|
-
expect(result).toEqual({ standard: '20', fast: '25', instant: '30' });
|
|
92
|
-
});
|
|
93
|
-
it('should fetch gas price for Solana chain', async () => {
|
|
94
|
-
ChainController.state.activeCaipNetwork = mockSolanaNetwork;
|
|
95
|
-
ConnectionController.estimateGas = vi.fn().mockResolvedValue(5000);
|
|
96
|
-
const result = await SwapApiUtil.fetchGasPrice();
|
|
97
|
-
expect(ConnectionController.estimateGas).toHaveBeenCalledWith({ chainNamespace: 'solana' });
|
|
98
|
-
expect(result).toEqual({ standard: '5000', fast: '5000', instant: '5000' });
|
|
99
|
-
});
|
|
100
|
-
it('should return null if there is an error', async () => {
|
|
101
|
-
ChainController.state.activeCaipNetwork = {
|
|
102
|
-
id: 1,
|
|
103
|
-
chainNamespace: 'eip155',
|
|
104
|
-
caipNetworkId: 'eip155:1',
|
|
105
|
-
name: 'Ethereum',
|
|
106
|
-
nativeCurrency: {
|
|
107
|
-
name: 'Ethereum',
|
|
108
|
-
decimals: 18,
|
|
109
|
-
symbol: 'ETH'
|
|
110
|
-
},
|
|
111
|
-
rpcUrls: {
|
|
112
|
-
default: {
|
|
113
|
-
http: ['https://mainnet.infura.io/v3/YOUR-PROJECT-ID']
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
};
|
|
117
|
-
BlockchainApiController.fetchGasPrice = vi.fn().mockRejectedValue(new Error('API Error'));
|
|
118
|
-
const result = await SwapApiUtil.fetchGasPrice();
|
|
119
|
-
expect(result).toBeNull();
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
describe('fetchSwapAllowance', () => {
|
|
123
|
-
it('should fetch and return swap allowance', async () => {
|
|
124
|
-
OptionsController.state.projectId = 'test-project-id';
|
|
125
|
-
BlockchainApiController.fetchSwapAllowance = vi
|
|
126
|
-
.fn()
|
|
127
|
-
.mockResolvedValue({ allowance: '1000000000000000000' });
|
|
128
|
-
ConnectionController.parseUnits = vi.fn().mockReturnValue(BigInt('500000000000000000'));
|
|
129
|
-
const result = await SwapApiUtil.fetchSwapAllowance({
|
|
130
|
-
tokenAddress: '0x123',
|
|
131
|
-
userAddress: '0x456',
|
|
132
|
-
sourceTokenAmount: '0.5',
|
|
133
|
-
sourceTokenDecimals: 18
|
|
134
|
-
});
|
|
135
|
-
expect(BlockchainApiController.fetchSwapAllowance).toHaveBeenCalledWith({
|
|
136
|
-
tokenAddress: '0x123',
|
|
137
|
-
userAddress: '0x456'
|
|
138
|
-
});
|
|
139
|
-
expect(result).toBe(true);
|
|
140
|
-
});
|
|
141
|
-
it('should return false if allowance is less than source token amount', async () => {
|
|
142
|
-
BlockchainApiController.fetchSwapAllowance = vi
|
|
143
|
-
.fn()
|
|
144
|
-
.mockResolvedValue({ allowance: '100000000000000000' });
|
|
145
|
-
ConnectionController.parseUnits = vi.fn().mockReturnValue(BigInt('500000000000000000'));
|
|
146
|
-
const result = await SwapApiUtil.fetchSwapAllowance({
|
|
147
|
-
tokenAddress: '0x123',
|
|
148
|
-
userAddress: '0x456',
|
|
149
|
-
sourceTokenAmount: '0.5',
|
|
150
|
-
sourceTokenDecimals: 18
|
|
151
|
-
});
|
|
152
|
-
expect(result).toBe(false);
|
|
153
|
-
});
|
|
154
|
-
});
|
|
155
|
-
describe('getMyTokensWithBalance', () => {
|
|
156
|
-
it('should fetch and return tokens with balance', async () => {
|
|
157
|
-
AccountController.state.address = '0x123';
|
|
158
|
-
ChainController.state.activeCaipNetwork = mockEthereumNetwork;
|
|
159
|
-
BlockchainApiController.getBalance = vi.fn().mockResolvedValue({
|
|
160
|
-
balances: [{ address: '0x456', quantity: { decimals: '18', numeric: '1.5' } }]
|
|
161
|
-
});
|
|
162
|
-
ChainController.getActiveNetworkTokenAddress = vi.fn().mockReturnValue('0x789');
|
|
163
|
-
const result = await SwapApiUtil.getMyTokensWithBalance();
|
|
164
|
-
expect(BlockchainApiController.getBalance).toHaveBeenCalledWith('0x123', 'eip155:1', undefined);
|
|
165
|
-
expect(AccountController.setTokenBalance).toHaveBeenCalled();
|
|
166
|
-
expect(result).toEqual([
|
|
167
|
-
{
|
|
168
|
-
address: '0x456',
|
|
169
|
-
quantity: { decimals: '18', numeric: '1.5' },
|
|
170
|
-
decimals: 18,
|
|
171
|
-
logoUri: undefined,
|
|
172
|
-
eip2612: false
|
|
173
|
-
}
|
|
174
|
-
]);
|
|
175
|
-
});
|
|
176
|
-
it('should return an empty array if no address or active network', async () => {
|
|
177
|
-
AccountController.state.address = undefined;
|
|
178
|
-
ChainController.state.activeCaipNetwork = undefined;
|
|
179
|
-
const result = await SwapApiUtil.getMyTokensWithBalance();
|
|
180
|
-
expect(result).toEqual([]);
|
|
181
|
-
});
|
|
182
|
-
});
|
|
183
|
-
describe('mapBalancesToSwapTokens', () => {
|
|
184
|
-
it('should map balances to swap tokens', () => {
|
|
185
|
-
const balances = [
|
|
186
|
-
{
|
|
187
|
-
address: '0x123',
|
|
188
|
-
quantity: { decimals: '18', numeric: '1.5' },
|
|
189
|
-
iconUrl: 'https://example.com/icon.png'
|
|
190
|
-
}
|
|
191
|
-
];
|
|
192
|
-
ChainController.getActiveNetworkTokenAddress = vi.fn().mockReturnValue('0x789');
|
|
193
|
-
const result = SwapApiUtil.mapBalancesToSwapTokens(balances);
|
|
194
|
-
expect(result).toEqual([
|
|
195
|
-
{
|
|
196
|
-
address: '0x123',
|
|
197
|
-
quantity: { decimals: '18', numeric: '1.5' },
|
|
198
|
-
decimals: 18,
|
|
199
|
-
logoUri: 'https://example.com/icon.png',
|
|
200
|
-
eip2612: false,
|
|
201
|
-
iconUrl: 'https://example.com/icon.png'
|
|
202
|
-
}
|
|
203
|
-
]);
|
|
204
|
-
});
|
|
205
|
-
it('should use network token address if balance address is undefined', () => {
|
|
206
|
-
const balances = [{ address: undefined, quantity: { decimals: '18', numeric: '1.5' } }];
|
|
207
|
-
ChainController.getActiveNetworkTokenAddress = vi.fn().mockReturnValue('0x789');
|
|
208
|
-
const result = SwapApiUtil.mapBalancesToSwapTokens(balances);
|
|
209
|
-
expect(result[0]?.address).toBe('0x789');
|
|
210
|
-
});
|
|
211
|
-
});
|
|
212
|
-
});
|
|
213
|
-
//# sourceMappingURL=SwapApiUtil.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SwapApiUtil.test.js","sourceRoot":"","sources":["../../../../tests/utils/SwapApiUtil.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import { NumberUtil } from '@reown/appkit-common';
|
|
3
|
-
import { INITIAL_GAS_LIMIT } from '../../src/controllers/SwapController.js';
|
|
4
|
-
import { SwapApiUtil } from '../../src/utils/SwapApiUtil.js';
|
|
5
|
-
import { SwapCalculationUtil } from '../../src/utils/SwapCalculationUtil.js';
|
|
6
|
-
import { balanceResponse, networkTokenPriceResponse } from '../mocks/SwapController.js';
|
|
7
|
-
// - Mocks ---------------------------------------------------------------------
|
|
8
|
-
const gasLimit = BigInt(INITIAL_GAS_LIMIT);
|
|
9
|
-
const gasFee = BigInt(455966887160);
|
|
10
|
-
const tokensWithBalance = SwapApiUtil.mapBalancesToSwapTokens(balanceResponse.balances);
|
|
11
|
-
// eslint-disable-next-line @typescript-eslint/non-nullable-type-assertion-style
|
|
12
|
-
const sourceToken = tokensWithBalance[0];
|
|
13
|
-
const sourceTokenAmount = '1';
|
|
14
|
-
// eslint-disable-next-line @typescript-eslint/non-nullable-type-assertion-style
|
|
15
|
-
const toToken = tokensWithBalance[1];
|
|
16
|
-
const networkPrice = networkTokenPriceResponse.fungibles[0]?.price.toString() || '0';
|
|
17
|
-
// -- Tests --------------------------------------------------------------------
|
|
18
|
-
describe('SwapCalculationUtil', () => {
|
|
19
|
-
it('should get gas price in Ether and USD as expected', () => {
|
|
20
|
-
const gasPriceInEther = SwapCalculationUtil.getGasPriceInEther(gasLimit, gasFee);
|
|
21
|
-
const gasPriceInUSD = SwapCalculationUtil.getGasPriceInUSD(networkPrice, gasLimit, gasFee);
|
|
22
|
-
expect(gasPriceInEther).toEqual(0.068395033074);
|
|
23
|
-
expect(gasPriceInUSD).toEqual(0.0492923003364318);
|
|
24
|
-
});
|
|
25
|
-
it('should return insufficient balance as expected', () => {
|
|
26
|
-
expect(SwapCalculationUtil.isInsufficientNetworkTokenForGas('0', 0.01)).toEqual(true);
|
|
27
|
-
});
|
|
28
|
-
it('should return insufficient balance for gas as expected', () => {
|
|
29
|
-
const gasPriceInUSD = SwapCalculationUtil.getGasPriceInUSD(networkPrice, gasLimit, gasFee);
|
|
30
|
-
const networkBalanceInUSD = NumberUtil.multiply(sourceToken.quantity.numeric, sourceToken.price).toString();
|
|
31
|
-
expect(SwapCalculationUtil.isInsufficientNetworkTokenForGas(networkBalanceInUSD, gasPriceInUSD)).toEqual(false);
|
|
32
|
-
});
|
|
33
|
-
it('should get the price impact as expected', () => {
|
|
34
|
-
const toTokenAmount = SwapCalculationUtil.getToTokenAmount({
|
|
35
|
-
sourceToken,
|
|
36
|
-
sourceTokenAmount,
|
|
37
|
-
sourceTokenPrice: sourceToken.price,
|
|
38
|
-
toToken,
|
|
39
|
-
toTokenPrice: toToken.price
|
|
40
|
-
});
|
|
41
|
-
const priceImpact = SwapCalculationUtil.getPriceImpact({
|
|
42
|
-
sourceTokenAmount,
|
|
43
|
-
sourceTokenPriceInUSD: sourceToken.price,
|
|
44
|
-
toTokenAmount,
|
|
45
|
-
toTokenPriceInUSD: toToken.price
|
|
46
|
-
});
|
|
47
|
-
expect(priceImpact).equal(0.8499999999999975);
|
|
48
|
-
});
|
|
49
|
-
it('should get to token amount with same decimals including provider fee as expected', () => {
|
|
50
|
-
const toTokenAmount = SwapCalculationUtil.getToTokenAmount({
|
|
51
|
-
sourceToken,
|
|
52
|
-
sourceTokenAmount,
|
|
53
|
-
sourceTokenPrice: sourceToken.price,
|
|
54
|
-
toToken,
|
|
55
|
-
toTokenPrice: toToken.price
|
|
56
|
-
});
|
|
57
|
-
expect(toTokenAmount).equal('0.017817571677266286');
|
|
58
|
-
});
|
|
59
|
-
it('should get to token amount with different decimals including provider fee as expected', () => {
|
|
60
|
-
// eslint-disable-next-line @typescript-eslint/non-nullable-type-assertion-style
|
|
61
|
-
const newToToken = tokensWithBalance[2];
|
|
62
|
-
const toTokenAmount = SwapCalculationUtil.getToTokenAmount({
|
|
63
|
-
sourceToken,
|
|
64
|
-
sourceTokenAmount,
|
|
65
|
-
sourceTokenPrice: sourceToken.price,
|
|
66
|
-
toToken: newToToken,
|
|
67
|
-
toTokenPrice: newToToken.price
|
|
68
|
-
});
|
|
69
|
-
expect(toTokenAmount).equal('0.714549');
|
|
70
|
-
});
|
|
71
|
-
it('should calculate the maximum slippage as expected', () => {
|
|
72
|
-
const maxSlippage = SwapCalculationUtil.getMaxSlippage(1, '1');
|
|
73
|
-
expect(maxSlippage).toEqual(0.01);
|
|
74
|
-
});
|
|
75
|
-
it('should calculate the provider fee as expected', () => {
|
|
76
|
-
const providerFee = SwapCalculationUtil.getProviderFee(sourceTokenAmount);
|
|
77
|
-
expect(providerFee).toEqual('0.0085');
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
//# sourceMappingURL=SwapCalculationUtil.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SwapCalculationUtil.test.js","sourceRoot":"","sources":["../../../../tests/utils/SwapCalculationUtil.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAE7C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yCAAyC,CAAA;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAA;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAA;AAE5E,OAAO,EAAE,eAAe,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAA;AAEvF,gFAAgF;AAChF,MAAM,QAAQ,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAA;AAC1C,MAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,CAAA;AAEnC,MAAM,iBAAiB,GAAG,WAAW,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;AAEvF,gFAAgF;AAChF,MAAM,WAAW,GAAG,iBAAiB,CAAC,CAAC,CAAyB,CAAA;AAChE,MAAM,iBAAiB,GAAG,GAAG,CAAA;AAC7B,gFAAgF;AAChF,MAAM,OAAO,GAAG,iBAAiB,CAAC,CAAC,CAAyB,CAAA;AAE5D,MAAM,YAAY,GAAG,yBAAyB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,GAAG,CAAA;AAEpF,gFAAgF;AAChF,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,eAAe,GAAG,mBAAmB,CAAC,kBAAkB,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAA;QAChF,MAAM,aAAa,GAAG,mBAAmB,CAAC,gBAAgB,CAAC,YAAY,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;QAE1F,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAA;QAC/C,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAA;IACnD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,CAAC,mBAAmB,CAAC,gCAAgC,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IACvF,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;QAChE,MAAM,aAAa,GAAG,mBAAmB,CAAC,gBAAgB,CAAC,YAAY,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;QAC1F,MAAM,mBAAmB,GAAG,UAAU,CAAC,QAAQ,CAC7C,WAAW,CAAC,QAAQ,CAAC,OAAO,EAC5B,WAAW,CAAC,KAAK,CAClB,CAAC,QAAQ,EAAE,CAAA;QAEZ,MAAM,CACJ,mBAAmB,CAAC,gCAAgC,CAAC,mBAAmB,EAAE,aAAa,CAAC,CACzF,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAClB,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,aAAa,GAAG,mBAAmB,CAAC,gBAAgB,CAAC;YACzD,WAAW;YACX,iBAAiB;YACjB,gBAAgB,EAAE,WAAW,CAAC,KAAK;YACnC,OAAO;YACP,YAAY,EAAE,OAAO,CAAC,KAAK;SAC5B,CAAC,CAAA;QAEF,MAAM,WAAW,GAAG,mBAAmB,CAAC,cAAc,CAAC;YACrD,iBAAiB;YACjB,qBAAqB,EAAE,WAAW,CAAC,KAAK;YACxC,aAAa;YACb,iBAAiB,EAAE,OAAO,CAAC,KAAK;SACjC,CAAC,CAAA;QACF,MAAM,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAA;IAC/C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,kFAAkF,EAAE,GAAG,EAAE;QAC1F,MAAM,aAAa,GAAG,mBAAmB,CAAC,gBAAgB,CAAC;YACzD,WAAW;YACX,iBAAiB;YACjB,gBAAgB,EAAE,WAAW,CAAC,KAAK;YACnC,OAAO;YACP,YAAY,EAAE,OAAO,CAAC,KAAK;SAC5B,CAAC,CAAA;QACF,MAAM,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAA;IACrD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,uFAAuF,EAAE,GAAG,EAAE;QAC/F,gFAAgF;QAChF,MAAM,UAAU,GAAG,iBAAiB,CAAC,CAAC,CAAyB,CAAA;QAE/D,MAAM,aAAa,GAAG,mBAAmB,CAAC,gBAAgB,CAAC;YACzD,WAAW;YACX,iBAAiB;YACjB,gBAAgB,EAAE,WAAW,CAAC,KAAK;YACnC,OAAO,EAAE,UAAU;YACnB,YAAY,EAAE,UAAU,CAAC,KAAK;SAC/B,CAAC,CAAA;QACF,MAAM,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;IACzC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,WAAW,GAAG,mBAAmB,CAAC,cAAc,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;QAC9D,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IACnC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,WAAW,GAAG,mBAAmB,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAA;QACzE,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IACvC,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import type { CaipAddress, ChainNamespace } from '@reown/appkit-common';
|
|
2
|
-
import type { Balance } from '@reown/appkit-common';
|
|
3
|
-
import type { W3mFrameTypes } from '@reown/appkit-wallet';
|
|
4
|
-
import type { AccountType, AccountTypeMap, ConnectedWalletInfo, SocialProvider, User } from '../utils/TypeUtil.js';
|
|
5
|
-
export interface AccountControllerState {
|
|
6
|
-
currentTab: number;
|
|
7
|
-
caipAddress?: CaipAddress;
|
|
8
|
-
user?: User;
|
|
9
|
-
address?: string;
|
|
10
|
-
addressLabels: Map<string, string>;
|
|
11
|
-
allAccounts: AccountType[];
|
|
12
|
-
balance?: string;
|
|
13
|
-
balanceSymbol?: string;
|
|
14
|
-
balanceLoading?: boolean;
|
|
15
|
-
profileName?: string | null;
|
|
16
|
-
profileImage?: string | null;
|
|
17
|
-
addressExplorerUrl?: string;
|
|
18
|
-
smartAccountDeployed?: boolean;
|
|
19
|
-
socialProvider?: SocialProvider;
|
|
20
|
-
tokenBalance?: Balance[];
|
|
21
|
-
shouldUpdateToAddress?: string;
|
|
22
|
-
connectedWalletInfo?: ConnectedWalletInfo;
|
|
23
|
-
preferredAccountType?: W3mFrameTypes.AccountType;
|
|
24
|
-
socialWindow?: Window;
|
|
25
|
-
farcasterUrl?: string;
|
|
26
|
-
status?: 'reconnecting' | 'connected' | 'disconnected' | 'connecting';
|
|
27
|
-
lastRetry?: number;
|
|
28
|
-
}
|
|
29
|
-
export declare const AccountController: {
|
|
30
|
-
state: AccountControllerState;
|
|
31
|
-
replaceState(newState: AccountControllerState | undefined): void;
|
|
32
|
-
subscribe(callback: (val: AccountControllerState) => void): () => void;
|
|
33
|
-
subscribeKey<K extends keyof AccountControllerState>(property: K, callback: (val: AccountControllerState[K]) => void, chain?: ChainNamespace): () => void;
|
|
34
|
-
setStatus(status: AccountControllerState["status"], chain: ChainNamespace | undefined): void;
|
|
35
|
-
getCaipAddress(chain: ChainNamespace | undefined): `eip155:${string}:${string}` | `eip155:${number}:${string}` | `solana:${string}:${string}` | `solana:${number}:${string}` | `polkadot:${string}:${string}` | `polkadot:${number}:${string}` | `bip122:${string}:${string}` | `bip122:${number}:${string}` | undefined;
|
|
36
|
-
setCaipAddress(caipAddress: AccountControllerState["caipAddress"], chain: ChainNamespace | undefined): void;
|
|
37
|
-
setBalance(balance: AccountControllerState["balance"], balanceSymbol: AccountControllerState["balanceSymbol"], chain: ChainNamespace): void;
|
|
38
|
-
setProfileName(profileName: AccountControllerState["profileName"], chain: ChainNamespace): void;
|
|
39
|
-
setProfileImage(profileImage: AccountControllerState["profileImage"], chain?: ChainNamespace): void;
|
|
40
|
-
setUser(user: AccountControllerState["user"], chain: ChainNamespace | undefined): void;
|
|
41
|
-
setAddressExplorerUrl(explorerUrl: AccountControllerState["addressExplorerUrl"], chain: ChainNamespace | undefined): void;
|
|
42
|
-
setSmartAccountDeployed(isDeployed: boolean, chain: ChainNamespace | undefined): void;
|
|
43
|
-
setCurrentTab(currentTab: AccountControllerState["currentTab"]): void;
|
|
44
|
-
setTokenBalance(tokenBalance: AccountControllerState["tokenBalance"], chain: ChainNamespace | undefined): void;
|
|
45
|
-
setShouldUpdateToAddress(address: string, chain: ChainNamespace | undefined): void;
|
|
46
|
-
setAllAccounts<N extends ChainNamespace>(accounts: AccountTypeMap[N][], namespace: N): void;
|
|
47
|
-
addAddressLabel(address: string, label: string, chain: ChainNamespace | undefined): void;
|
|
48
|
-
removeAddressLabel(address: string, chain: ChainNamespace | undefined): void;
|
|
49
|
-
setConnectedWalletInfo(connectedWalletInfo: AccountControllerState["connectedWalletInfo"], chain: ChainNamespace): void;
|
|
50
|
-
setPreferredAccountType(preferredAccountType: AccountControllerState["preferredAccountType"], chain: ChainNamespace): void;
|
|
51
|
-
setSocialProvider(socialProvider: AccountControllerState["socialProvider"], chain: ChainNamespace | undefined): void;
|
|
52
|
-
setSocialWindow(socialWindow: AccountControllerState["socialWindow"], chain: ChainNamespace | undefined): void;
|
|
53
|
-
setFarcasterUrl(farcasterUrl: AccountControllerState["farcasterUrl"], chain: ChainNamespace | undefined): void;
|
|
54
|
-
fetchTokenBalance(onError?: (error: unknown) => void): Promise<Balance[]>;
|
|
55
|
-
resetAccount(chain: ChainNamespace): void;
|
|
56
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
export interface AlertControllerState {
|
|
2
|
-
message: string;
|
|
3
|
-
variant: 'info' | 'success' | 'warning' | 'error';
|
|
4
|
-
open: boolean;
|
|
5
|
-
}
|
|
6
|
-
type StateKey = keyof AlertControllerState;
|
|
7
|
-
interface OpenMessageParameters {
|
|
8
|
-
shortMessage: string;
|
|
9
|
-
longMessage?: string | (() => void);
|
|
10
|
-
}
|
|
11
|
-
export declare const AlertController: {
|
|
12
|
-
state: AlertControllerState;
|
|
13
|
-
subscribeKey<K extends StateKey>(key: K, callback: (value: AlertControllerState[K]) => void): () => void;
|
|
14
|
-
open(message: OpenMessageParameters, variant: AlertControllerState["variant"]): void;
|
|
15
|
-
close(): void;
|
|
16
|
-
};
|
|
17
|
-
export {};
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { FetchUtil } from '../utils/FetchUtil.js';
|
|
2
|
-
import type { ApiGetWalletsRequest, WcWallet } from '../utils/TypeUtil.js';
|
|
3
|
-
export declare const api: FetchUtil;
|
|
4
|
-
export interface ApiControllerState {
|
|
5
|
-
prefetchPromise?: Promise<unknown>;
|
|
6
|
-
page: number;
|
|
7
|
-
count: number;
|
|
8
|
-
featured: WcWallet[];
|
|
9
|
-
recommended: WcWallet[];
|
|
10
|
-
wallets: WcWallet[];
|
|
11
|
-
search: WcWallet[];
|
|
12
|
-
isAnalyticsEnabled: boolean;
|
|
13
|
-
excludedRDNS: string[];
|
|
14
|
-
}
|
|
15
|
-
interface PrefetchParameters {
|
|
16
|
-
fetchConnectorImages?: boolean;
|
|
17
|
-
fetchFeaturedWallets?: boolean;
|
|
18
|
-
fetchRecommendedWallets?: boolean;
|
|
19
|
-
fetchNetworkImages?: boolean;
|
|
20
|
-
}
|
|
21
|
-
type StateKey = keyof ApiControllerState;
|
|
22
|
-
export declare const ApiController: {
|
|
23
|
-
state: ApiControllerState;
|
|
24
|
-
subscribeKey<K extends StateKey>(key: K, callback: (value: ApiControllerState[K]) => void): () => void;
|
|
25
|
-
_getSdkProperties(): {
|
|
26
|
-
projectId: string;
|
|
27
|
-
st: "appkit";
|
|
28
|
-
sv: import("../utils/TypeUtil.js").SdkVersion;
|
|
29
|
-
};
|
|
30
|
-
_filterOutExtensions(wallets: WcWallet[]): WcWallet[];
|
|
31
|
-
_fetchWalletImage(imageId: string): Promise<void>;
|
|
32
|
-
_fetchNetworkImage(imageId: string): Promise<void>;
|
|
33
|
-
_fetchConnectorImage(imageId: string): Promise<void>;
|
|
34
|
-
_fetchCurrencyImage(countryCode: string): Promise<void>;
|
|
35
|
-
_fetchTokenImage(symbol: string): Promise<void>;
|
|
36
|
-
fetchNetworkImages(): Promise<void>;
|
|
37
|
-
fetchConnectorImages(): Promise<void>;
|
|
38
|
-
fetchCurrencyImages(currencies?: string[]): Promise<void>;
|
|
39
|
-
fetchTokenImages(tokens?: string[]): Promise<void>;
|
|
40
|
-
fetchFeaturedWallets(): Promise<void>;
|
|
41
|
-
fetchRecommendedWallets(): Promise<void>;
|
|
42
|
-
fetchWallets({ page }: Pick<ApiGetWalletsRequest, "page">): Promise<void>;
|
|
43
|
-
initializeExcludedWalletRdns({ ids }: {
|
|
44
|
-
ids: string[];
|
|
45
|
-
}): Promise<void>;
|
|
46
|
-
searchWallet({ search, badge }: Pick<ApiGetWalletsRequest, "search" | "badge">): Promise<void>;
|
|
47
|
-
prefetch({ fetchConnectorImages, fetchFeaturedWallets, fetchRecommendedWallets, fetchNetworkImages }?: PrefetchParameters): Promise<unknown>;
|
|
48
|
-
prefetchAnalyticsConfig(): void;
|
|
49
|
-
fetchAnalyticsConfig(): Promise<void>;
|
|
50
|
-
};
|
|
51
|
-
export {};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
export interface AssetControllerState {
|
|
2
|
-
walletImages: Record<string, string>;
|
|
3
|
-
networkImages: Record<string, string>;
|
|
4
|
-
chainImages: Record<string, string>;
|
|
5
|
-
connectorImages: Record<string, string>;
|
|
6
|
-
tokenImages: Record<string, string>;
|
|
7
|
-
currencyImages: Record<string, string>;
|
|
8
|
-
}
|
|
9
|
-
type StateKey = keyof AssetControllerState;
|
|
10
|
-
export declare const AssetController: {
|
|
11
|
-
state: AssetControllerState;
|
|
12
|
-
subscribeNetworkImages(callback: (value: AssetControllerState["networkImages"]) => void): () => void;
|
|
13
|
-
subscribeKey<K extends StateKey>(key: K, callback: (value: AssetControllerState[K]) => void): () => void;
|
|
14
|
-
subscribe(callback: (newState: AssetControllerState) => void): () => void;
|
|
15
|
-
setWalletImage(key: string, value: string): void;
|
|
16
|
-
setNetworkImage(key: string, value: string): void;
|
|
17
|
-
setChainImage(key: string, value: string): void;
|
|
18
|
-
setConnectorImage(key: string, value: string): void;
|
|
19
|
-
setTokenImage(key: string, value: string): void;
|
|
20
|
-
setCurrencyImage(key: string, value: string): void;
|
|
21
|
-
};
|
|
22
|
-
export {};
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import type { CaipAddress, CaipNetworkId } from '@reown/appkit-common';
|
|
2
|
-
import { FetchUtil, type RequestArguments } from '../utils/FetchUtil.js';
|
|
3
|
-
import type { BlockchainApiBalanceResponse, BlockchainApiGasPriceRequest, BlockchainApiGasPriceResponse, BlockchainApiGenerateApproveCalldataRequest, BlockchainApiGenerateApproveCalldataResponse, BlockchainApiGenerateSwapCalldataRequest, BlockchainApiGenerateSwapCalldataResponse, BlockchainApiIdentityRequest, BlockchainApiIdentityResponse, BlockchainApiLookupEnsName, BlockchainApiRegisterNameParams, BlockchainApiSuggestionResponse, BlockchainApiSwapAllowanceRequest, BlockchainApiSwapQuoteRequest, BlockchainApiSwapQuoteResponse, BlockchainApiSwapTokensRequest, BlockchainApiSwapTokensResponse, BlockchainApiTokenPriceRequest, BlockchainApiTokenPriceResponse, BlockchainApiTransactionsRequest, BlockchainApiTransactionsResponse, GenerateOnRampUrlArgs, GetQuoteArgs, OnrampQuote } from '../utils/TypeUtil.js';
|
|
4
|
-
export interface BlockchainApiControllerState {
|
|
5
|
-
clientId: string | null;
|
|
6
|
-
api: FetchUtil;
|
|
7
|
-
supportedChains: {
|
|
8
|
-
http: CaipNetworkId[];
|
|
9
|
-
ws: CaipNetworkId[];
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
export declare const BlockchainApiController: {
|
|
13
|
-
state: BlockchainApiControllerState;
|
|
14
|
-
get<T>(request: RequestArguments): Promise<T>;
|
|
15
|
-
getSdkProperties(): {
|
|
16
|
-
st: "appkit";
|
|
17
|
-
sv: import("../utils/TypeUtil.js").SdkVersion;
|
|
18
|
-
};
|
|
19
|
-
isNetworkSupported(networkId?: CaipNetworkId): Promise<boolean>;
|
|
20
|
-
getSupportedNetworks(): Promise<{
|
|
21
|
-
http: CaipNetworkId[];
|
|
22
|
-
ws: CaipNetworkId[];
|
|
23
|
-
}>;
|
|
24
|
-
fetchIdentity({ address, caipNetworkId }: BlockchainApiIdentityRequest & {
|
|
25
|
-
caipNetworkId: CaipNetworkId;
|
|
26
|
-
}): Promise<BlockchainApiIdentityResponse>;
|
|
27
|
-
fetchTransactions({ account, cursor, onramp, signal, cache, chainId }: BlockchainApiTransactionsRequest): Promise<BlockchainApiTransactionsResponse | {
|
|
28
|
-
data: never[];
|
|
29
|
-
next: undefined;
|
|
30
|
-
}>;
|
|
31
|
-
fetchSwapQuote({ amount, userAddress, from, to, gasPrice }: BlockchainApiSwapQuoteRequest): Promise<BlockchainApiSwapQuoteResponse>;
|
|
32
|
-
fetchSwapTokens({ chainId }: BlockchainApiSwapTokensRequest): Promise<BlockchainApiSwapTokensResponse>;
|
|
33
|
-
fetchTokenPrice({ addresses }: BlockchainApiTokenPriceRequest): Promise<BlockchainApiTokenPriceResponse>;
|
|
34
|
-
fetchSwapAllowance({ tokenAddress, userAddress }: BlockchainApiSwapAllowanceRequest): Promise<{
|
|
35
|
-
allowance: string;
|
|
36
|
-
}>;
|
|
37
|
-
fetchGasPrice({ chainId }: BlockchainApiGasPriceRequest): Promise<BlockchainApiGasPriceResponse>;
|
|
38
|
-
generateSwapCalldata({ amount, from, to, userAddress }: BlockchainApiGenerateSwapCalldataRequest): Promise<BlockchainApiGenerateSwapCalldataResponse>;
|
|
39
|
-
generateApproveCalldata({ from, to, userAddress }: BlockchainApiGenerateApproveCalldataRequest): Promise<BlockchainApiGenerateApproveCalldataResponse>;
|
|
40
|
-
getBalance(address: string, chainId?: string, forceUpdate?: string): Promise<BlockchainApiBalanceResponse>;
|
|
41
|
-
lookupEnsName(name: string): Promise<BlockchainApiLookupEnsName | {
|
|
42
|
-
addresses: {};
|
|
43
|
-
attributes: never[];
|
|
44
|
-
}>;
|
|
45
|
-
reverseLookupEnsName({ address }: {
|
|
46
|
-
address: string;
|
|
47
|
-
}): Promise<BlockchainApiLookupEnsName[]>;
|
|
48
|
-
getEnsNameSuggestions(name: string): Promise<BlockchainApiSuggestionResponse>;
|
|
49
|
-
registerEnsName({ coinType, address, message, signature }: BlockchainApiRegisterNameParams): Promise<unknown>;
|
|
50
|
-
generateOnRampURL({ destinationWallets, partnerUserId, defaultNetwork, purchaseAmount, paymentAmount }: GenerateOnRampUrlArgs): Promise<string>;
|
|
51
|
-
getOnrampOptions(): Promise<{
|
|
52
|
-
purchaseCurrencies: {
|
|
53
|
-
id: string;
|
|
54
|
-
name: string;
|
|
55
|
-
symbol: string;
|
|
56
|
-
networks: {
|
|
57
|
-
name: string;
|
|
58
|
-
display_name: string;
|
|
59
|
-
chain_id: string;
|
|
60
|
-
contract_address: string;
|
|
61
|
-
}[];
|
|
62
|
-
}[];
|
|
63
|
-
paymentCurrencies: {
|
|
64
|
-
id: string;
|
|
65
|
-
payment_method_limits: {
|
|
66
|
-
id: string;
|
|
67
|
-
min: string;
|
|
68
|
-
max: string;
|
|
69
|
-
}[];
|
|
70
|
-
}[];
|
|
71
|
-
}>;
|
|
72
|
-
getOnrampQuote({ purchaseCurrency, paymentCurrency, amount, network }: GetQuoteArgs): Promise<OnrampQuote | null>;
|
|
73
|
-
getSmartSessions(caipAddress: CaipAddress): Promise<unknown>;
|
|
74
|
-
revokeSmartSession(address: `0x${string}`, pci: string, signature: string): Promise<unknown>;
|
|
75
|
-
setClientId(clientId: string | null): void;
|
|
76
|
-
};
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { type CaipAddress, type CaipNetwork, type CaipNetworkId, type ChainNamespace } from '@reown/appkit-common';
|
|
2
|
-
import type { AdapterNetworkState, ChainAdapter, NetworkControllerClient } from '../utils/TypeUtil.js';
|
|
3
|
-
import { type AccountControllerState } from './AccountController.js';
|
|
4
|
-
import { type ConnectionControllerClient } from './ConnectionController.js';
|
|
5
|
-
export type ChainControllerClients = {
|
|
6
|
-
networkControllerClient: NetworkControllerClient;
|
|
7
|
-
connectionControllerClient: ConnectionControllerClient;
|
|
8
|
-
};
|
|
9
|
-
export interface ChainControllerState {
|
|
10
|
-
activeChain: ChainNamespace | undefined;
|
|
11
|
-
activeCaipAddress: CaipAddress | undefined;
|
|
12
|
-
activeCaipNetwork?: CaipNetwork;
|
|
13
|
-
chains: Map<ChainNamespace, ChainAdapter>;
|
|
14
|
-
universalAdapter: Pick<ChainAdapter, 'networkControllerClient' | 'connectionControllerClient'>;
|
|
15
|
-
noAdapters: boolean;
|
|
16
|
-
isSwitchingNamespace: boolean;
|
|
17
|
-
}
|
|
18
|
-
type ChainControllerStateKey = keyof ChainControllerState;
|
|
19
|
-
export declare const ChainController: {
|
|
20
|
-
state: ChainControllerState;
|
|
21
|
-
subscribe(callback: (value: ChainControllerState) => void): () => void;
|
|
22
|
-
subscribeKey<K extends ChainControllerStateKey>(key: K, callback: (value: ChainControllerState[K]) => void): () => void;
|
|
23
|
-
subscribeChainProp<K extends keyof ChainAdapter>(property: K, callback: (value: ChainAdapter[K] | undefined) => void, chain?: ChainNamespace): () => void;
|
|
24
|
-
initialize(adapters: ChainAdapter[], caipNetworks: CaipNetwork[] | undefined, clients: {
|
|
25
|
-
connectionControllerClient: ConnectionControllerClient;
|
|
26
|
-
networkControllerClient: NetworkControllerClient;
|
|
27
|
-
}): void;
|
|
28
|
-
removeAdapter(namespace: ChainNamespace): void;
|
|
29
|
-
addAdapter(adapter: ChainAdapter, { networkControllerClient, connectionControllerClient }: ChainControllerClients, caipNetworks: [CaipNetwork, ...CaipNetwork[]]): void;
|
|
30
|
-
addNetwork(network: CaipNetwork): void;
|
|
31
|
-
removeNetwork(namespace: ChainNamespace, networkId: string | number): void;
|
|
32
|
-
setAdapterNetworkState(chain: ChainNamespace, props: Partial<AdapterNetworkState>): void;
|
|
33
|
-
setChainAccountData(chain: ChainNamespace | undefined, accountProps: Partial<AccountControllerState>, _unknown?: boolean): void;
|
|
34
|
-
setAccountProp(prop: keyof AccountControllerState, value: AccountControllerState[keyof AccountControllerState], chain: ChainNamespace | undefined, replaceState?: boolean): void;
|
|
35
|
-
setActiveNamespace(chain: ChainNamespace | undefined): void;
|
|
36
|
-
setActiveCaipNetwork(caipNetwork: AdapterNetworkState["caipNetwork"]): void;
|
|
37
|
-
addCaipNetwork(caipNetwork: AdapterNetworkState["caipNetwork"]): void;
|
|
38
|
-
switchActiveNetwork(network: CaipNetwork): Promise<void>;
|
|
39
|
-
getNetworkControllerClient(chainNamespace?: ChainNamespace): NetworkControllerClient;
|
|
40
|
-
getConnectionControllerClient(_chain?: ChainNamespace): ConnectionControllerClient;
|
|
41
|
-
getAccountProp<K extends keyof AccountControllerState>(key: K, _chain?: ChainNamespace): AccountControllerState[K] | undefined;
|
|
42
|
-
getNetworkProp<K extends keyof AdapterNetworkState>(key: K, namespace: ChainNamespace): AdapterNetworkState[K] | undefined;
|
|
43
|
-
getRequestedCaipNetworks(chainToFilter: ChainNamespace): CaipNetwork[];
|
|
44
|
-
getAllRequestedCaipNetworks(): CaipNetwork[];
|
|
45
|
-
setRequestedCaipNetworks(requestedCaipNetworks: CaipNetwork[], chain: ChainNamespace): void;
|
|
46
|
-
getAllApprovedCaipNetworkIds(): CaipNetworkId[];
|
|
47
|
-
getActiveCaipNetwork(): CaipNetwork | undefined;
|
|
48
|
-
getActiveCaipAddress(): `eip155:${string}:${string}` | `eip155:${number}:${string}` | `solana:${string}:${string}` | `solana:${number}:${string}` | `polkadot:${string}:${string}` | `polkadot:${number}:${string}` | `bip122:${string}:${string}` | `bip122:${number}:${string}` | undefined;
|
|
49
|
-
getApprovedCaipNetworkIds(namespace: ChainNamespace): CaipNetworkId[];
|
|
50
|
-
setApprovedCaipNetworksData(namespace: ChainNamespace): Promise<void>;
|
|
51
|
-
checkIfSupportedNetwork(namespace: ChainNamespace): boolean;
|
|
52
|
-
checkIfSupportedChainId(chainId: number | string): boolean;
|
|
53
|
-
setSmartAccountEnabledNetworks(smartAccountEnabledNetworks: number[], chain: ChainNamespace): void;
|
|
54
|
-
checkIfSmartAccountEnabled(): boolean;
|
|
55
|
-
getActiveNetworkTokenAddress(): string;
|
|
56
|
-
showUnsupportedChainUI(): void;
|
|
57
|
-
checkIfNamesSupported(): boolean;
|
|
58
|
-
resetNetwork(namespace: ChainNamespace): void;
|
|
59
|
-
resetAccount(chain: ChainNamespace | undefined): void;
|
|
60
|
-
disconnect(): Promise<void>;
|
|
61
|
-
setIsSwitchingNamespace(isSwitchingNamespace: boolean): void;
|
|
62
|
-
getFirstCaipNetworkSupportsAuthConnector(): CaipNetwork | undefined;
|
|
63
|
-
getAccountDataByChainNamespace(chainNamespace?: ChainNamespace): AccountControllerState | undefined;
|
|
64
|
-
};
|
|
65
|
-
export {};
|