@reown/appkit-core-react-native 0.0.0-refactor-modal-migration-20241004184043 → 1.0.1
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 +1 -25
- package/lib/commonjs/controllers/AccountController.js.map +1 -1
- package/lib/commonjs/controllers/ApiController.js +3 -3
- package/lib/commonjs/controllers/ApiController.js.map +1 -1
- package/lib/commonjs/controllers/BlockchainApiController.js +0 -84
- package/lib/commonjs/controllers/BlockchainApiController.js.map +1 -1
- package/lib/commonjs/controllers/ConnectionController.js +0 -29
- package/lib/commonjs/controllers/ConnectionController.js.map +1 -1
- package/lib/commonjs/controllers/EventsController.js +15 -1
- package/lib/commonjs/controllers/EventsController.js.map +1 -1
- package/lib/commonjs/controllers/ModalController.js +1 -3
- package/lib/commonjs/controllers/ModalController.js.map +1 -1
- package/lib/commonjs/controllers/NetworkController.js +0 -3
- package/lib/commonjs/controllers/NetworkController.js.map +1 -1
- package/lib/commonjs/controllers/OptionsController.js +2 -10
- package/lib/commonjs/controllers/OptionsController.js.map +1 -1
- package/lib/commonjs/controllers/RouterController.js +1 -22
- package/lib/commonjs/controllers/RouterController.js.map +1 -1
- package/lib/commonjs/index.js +0 -42
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/utils/ConstantsUtil.js +1 -8
- package/lib/commonjs/utils/ConstantsUtil.js.map +1 -1
- package/lib/commonjs/utils/CoreHelperUtil.js +0 -33
- package/lib/commonjs/utils/CoreHelperUtil.js.map +1 -1
- package/lib/commonjs/utils/FetchUtil.js.map +1 -1
- package/lib/commonjs/utils/StorageUtil.js +0 -24
- package/lib/commonjs/utils/StorageUtil.js.map +1 -1
- package/lib/commonjs/utils/TypeUtil.js +0 -4
- package/lib/module/controllers/AccountController.js +1 -25
- package/lib/module/controllers/AccountController.js.map +1 -1
- package/lib/module/controllers/ApiController.js +3 -3
- package/lib/module/controllers/ApiController.js.map +1 -1
- package/lib/module/controllers/BlockchainApiController.js +0 -84
- package/lib/module/controllers/BlockchainApiController.js.map +1 -1
- package/lib/module/controllers/ConnectionController.js +0 -29
- package/lib/module/controllers/ConnectionController.js.map +1 -1
- package/lib/module/controllers/EventsController.js +15 -1
- package/lib/module/controllers/EventsController.js.map +1 -1
- package/lib/module/controllers/ModalController.js +1 -3
- package/lib/module/controllers/ModalController.js.map +1 -1
- package/lib/module/controllers/NetworkController.js +0 -3
- package/lib/module/controllers/NetworkController.js.map +1 -1
- package/lib/module/controllers/OptionsController.js +2 -10
- package/lib/module/controllers/OptionsController.js.map +1 -1
- package/lib/module/controllers/RouterController.js +1 -22
- package/lib/module/controllers/RouterController.js.map +1 -1
- package/lib/module/index.js +0 -7
- package/lib/module/index.js.map +1 -1
- package/lib/module/utils/ConstantsUtil.js +1 -8
- package/lib/module/utils/ConstantsUtil.js.map +1 -1
- package/lib/module/utils/CoreHelperUtil.js +0 -33
- package/lib/module/utils/CoreHelperUtil.js.map +1 -1
- package/lib/module/utils/FetchUtil.js.map +1 -1
- package/lib/module/utils/StorageUtil.js +0 -24
- package/lib/module/utils/StorageUtil.js.map +1 -1
- package/lib/module/utils/TypeUtil.js +1 -1
- package/lib/typescript/controllers/AccountController.d.ts +0 -4
- package/lib/typescript/controllers/AccountController.d.ts.map +1 -1
- package/lib/typescript/controllers/ApiController.d.ts.map +1 -1
- package/lib/typescript/controllers/BlockchainApiController.d.ts +1 -6
- package/lib/typescript/controllers/BlockchainApiController.d.ts.map +1 -1
- package/lib/typescript/controllers/ConnectionController.d.ts +1 -16
- package/lib/typescript/controllers/ConnectionController.d.ts.map +1 -1
- package/lib/typescript/controllers/EventsController.d.ts +6 -0
- package/lib/typescript/controllers/EventsController.d.ts.map +1 -1
- package/lib/typescript/controllers/ModalController.d.ts.map +1 -1
- package/lib/typescript/controllers/NetworkController.d.ts +0 -1
- package/lib/typescript/controllers/NetworkController.d.ts.map +1 -1
- package/lib/typescript/controllers/OptionsController.d.ts +1 -3
- package/lib/typescript/controllers/OptionsController.d.ts.map +1 -1
- package/lib/typescript/controllers/RouterController.d.ts +1 -15
- package/lib/typescript/controllers/RouterController.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +26 -19
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/utils/ConstantsUtil.d.ts +0 -3
- package/lib/typescript/utils/ConstantsUtil.d.ts.map +1 -1
- package/lib/typescript/utils/CoreHelperUtil.d.ts +0 -6
- package/lib/typescript/utils/CoreHelperUtil.d.ts.map +1 -1
- package/lib/typescript/utils/FetchUtil.d.ts +0 -3
- package/lib/typescript/utils/FetchUtil.d.ts.map +1 -1
- package/lib/typescript/utils/StorageUtil.d.ts +0 -4
- package/lib/typescript/utils/StorageUtil.d.ts.map +1 -1
- package/lib/typescript/utils/TypeUtil.d.ts +2 -178
- package/lib/typescript/utils/TypeUtil.d.ts.map +1 -1
- package/package.json +5 -5
- package/readme.md +1 -1
- package/src/controllers/AccountController.ts +1 -35
- package/src/controllers/ApiController.ts +7 -3
- package/src/controllers/BlockchainApiController.ts +1 -88
- package/src/controllers/ConnectionController.ts +1 -51
- package/src/controllers/EventsController.ts +13 -1
- package/src/controllers/ModalController.ts +1 -3
- package/src/controllers/NetworkController.ts +0 -6
- package/src/controllers/OptionsController.ts +3 -17
- package/src/controllers/RouterController.ts +10 -57
- package/src/index.ts +30 -43
- package/src/utils/ConstantsUtil.ts +1 -13
- package/src/utils/CoreHelperUtil.ts +1 -38
- package/src/utils/FetchUtil.ts +0 -4
- package/src/utils/StorageUtil.ts +0 -30
- package/src/utils/TypeUtil.ts +2 -207
- package/lib/commonjs/controllers/EnsController.js +0 -35
- package/lib/commonjs/controllers/EnsController.js.map +0 -1
- package/lib/commonjs/controllers/SendController.js +0 -176
- package/lib/commonjs/controllers/SendController.js.map +0 -1
- package/lib/commonjs/controllers/SwapController.js +0 -91
- package/lib/commonjs/controllers/SwapController.js.map +0 -1
- package/lib/commonjs/controllers/TransactionsController.js +0 -111
- package/lib/commonjs/controllers/TransactionsController.js.map +0 -1
- package/lib/commonjs/controllers/WebviewController.js +0 -40
- package/lib/commonjs/controllers/WebviewController.js.map +0 -1
- package/lib/commonjs/utils/ApiUtil.js +0 -18
- package/lib/commonjs/utils/ApiUtil.js.map +0 -1
- package/lib/commonjs/utils/SwapApiUtil.js +0 -23
- package/lib/commonjs/utils/SwapApiUtil.js.map +0 -1
- package/lib/commonjs/utils/SwapCalculationUtil.js +0 -24
- package/lib/commonjs/utils/SwapCalculationUtil.js.map +0 -1
- package/lib/module/controllers/EnsController.js +0 -30
- package/lib/module/controllers/EnsController.js.map +0 -1
- package/lib/module/controllers/SendController.js +0 -171
- package/lib/module/controllers/SendController.js.map +0 -1
- package/lib/module/controllers/SwapController.js +0 -86
- package/lib/module/controllers/SwapController.js.map +0 -1
- package/lib/module/controllers/TransactionsController.js +0 -106
- package/lib/module/controllers/TransactionsController.js.map +0 -1
- package/lib/module/controllers/WebviewController.js +0 -35
- package/lib/module/controllers/WebviewController.js.map +0 -1
- package/lib/module/utils/ApiUtil.js +0 -12
- package/lib/module/utils/ApiUtil.js.map +0 -1
- package/lib/module/utils/SwapApiUtil.js +0 -17
- package/lib/module/utils/SwapApiUtil.js.map +0 -1
- package/lib/module/utils/SwapCalculationUtil.js +0 -19
- package/lib/module/utils/SwapCalculationUtil.js.map +0 -1
- package/lib/typescript/controllers/EnsController.d.ts +0 -10
- package/lib/typescript/controllers/EnsController.d.ts.map +0 -1
- package/lib/typescript/controllers/SendController.d.ts +0 -41
- package/lib/typescript/controllers/SendController.d.ts.map +0 -1
- package/lib/typescript/controllers/SwapController.d.ts +0 -29
- package/lib/typescript/controllers/SwapController.d.ts.map +0 -1
- package/lib/typescript/controllers/TransactionsController.d.ts +0 -21
- package/lib/typescript/controllers/TransactionsController.d.ts.map +0 -1
- package/lib/typescript/controllers/WebviewController.d.ts +0 -18
- package/lib/typescript/controllers/WebviewController.d.ts.map +0 -1
- package/lib/typescript/utils/ApiUtil.d.ts +0 -5
- package/lib/typescript/utils/ApiUtil.d.ts.map +0 -1
- package/lib/typescript/utils/SwapApiUtil.d.ts +0 -4
- package/lib/typescript/utils/SwapApiUtil.d.ts.map +0 -1
- package/lib/typescript/utils/SwapCalculationUtil.d.ts +0 -5
- package/lib/typescript/utils/SwapCalculationUtil.d.ts.map +0 -1
- package/src/controllers/EnsController.ts +0 -39
- package/src/controllers/SendController.ts +0 -234
- package/src/controllers/SwapController.ts +0 -108
- package/src/controllers/TransactionsController.ts +0 -141
- package/src/controllers/WebviewController.ts +0 -48
- package/src/utils/ApiUtil.ts +0 -18
- package/src/utils/SwapApiUtil.ts +0 -19
- package/src/utils/SwapCalculationUtil.ts +0 -21
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { proxy } from 'valtio';
|
|
2
2
|
import { subscribeKey as subKey } from 'valtio/utils';
|
|
3
|
-
import type { Balance } from '@reown/appkit-common-react-native';
|
|
4
3
|
|
|
5
4
|
import { CoreHelperUtil } from '../utils/CoreHelperUtil';
|
|
6
5
|
import type { CaipAddress, ConnectedWalletInfo } from '../utils/TypeUtil';
|
|
7
|
-
import { NetworkController } from './NetworkController';
|
|
8
|
-
import { BlockchainApiController } from './BlockchainApiController';
|
|
9
|
-
import { SnackController } from './SnackController';
|
|
10
6
|
|
|
11
7
|
// -- Types --------------------------------------------- //
|
|
12
8
|
export interface AccountControllerState {
|
|
@@ -15,7 +11,6 @@ export interface AccountControllerState {
|
|
|
15
11
|
address?: string;
|
|
16
12
|
balance?: string;
|
|
17
13
|
balanceSymbol?: string;
|
|
18
|
-
tokenBalance?: Balance[];
|
|
19
14
|
profileName?: string;
|
|
20
15
|
profileImage?: string;
|
|
21
16
|
addressExplorerUrl?: string;
|
|
@@ -26,8 +21,7 @@ type StateKey = keyof AccountControllerState;
|
|
|
26
21
|
|
|
27
22
|
// -- State --------------------------------------------- //
|
|
28
23
|
const state = proxy<AccountControllerState>({
|
|
29
|
-
isConnected: false
|
|
30
|
-
tokenBalance: []
|
|
24
|
+
isConnected: false
|
|
31
25
|
});
|
|
32
26
|
|
|
33
27
|
// -- Controller ---------------------------------------- //
|
|
@@ -56,10 +50,6 @@ export const AccountController = {
|
|
|
56
50
|
state.balanceSymbol = balanceSymbol;
|
|
57
51
|
},
|
|
58
52
|
|
|
59
|
-
setTokenBalance(tokenBalance: AccountControllerState['tokenBalance']) {
|
|
60
|
-
state.tokenBalance = tokenBalance;
|
|
61
|
-
},
|
|
62
|
-
|
|
63
53
|
setProfileName(profileName: AccountControllerState['profileName']) {
|
|
64
54
|
state.profileName = profileName;
|
|
65
55
|
},
|
|
@@ -76,29 +66,6 @@ export const AccountController = {
|
|
|
76
66
|
state.addressExplorerUrl = explorerUrl;
|
|
77
67
|
},
|
|
78
68
|
|
|
79
|
-
async fetchTokenBalance() {
|
|
80
|
-
const chainId = NetworkController.state.caipNetwork?.id;
|
|
81
|
-
const address = AccountController.state.address;
|
|
82
|
-
|
|
83
|
-
try {
|
|
84
|
-
if (address && chainId) {
|
|
85
|
-
const response = await BlockchainApiController.getBalance(address, chainId);
|
|
86
|
-
|
|
87
|
-
if (!response) {
|
|
88
|
-
throw new Error('Failed to fetch token balance');
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
const filteredBalances = response.balances.filter(
|
|
92
|
-
balance => balance.quantity.decimals !== '0'
|
|
93
|
-
);
|
|
94
|
-
|
|
95
|
-
this.setTokenBalance(filteredBalances);
|
|
96
|
-
}
|
|
97
|
-
} catch (error) {
|
|
98
|
-
SnackController.showError('Failed to fetch token balance');
|
|
99
|
-
}
|
|
100
|
-
},
|
|
101
|
-
|
|
102
69
|
resetAccount() {
|
|
103
70
|
state.isConnected = false;
|
|
104
71
|
state.caipAddress = undefined;
|
|
@@ -108,7 +75,6 @@ export const AccountController = {
|
|
|
108
75
|
state.profileName = undefined;
|
|
109
76
|
state.profileImage = undefined;
|
|
110
77
|
state.addressExplorerUrl = undefined;
|
|
111
|
-
state.tokenBalance = [];
|
|
112
78
|
state.connectedWalletInfo = undefined;
|
|
113
79
|
}
|
|
114
80
|
};
|
|
@@ -16,7 +16,6 @@ import { NetworkController } from './NetworkController';
|
|
|
16
16
|
import { OptionsController } from './OptionsController';
|
|
17
17
|
import { ConnectorController } from './ConnectorController';
|
|
18
18
|
import { ConnectionController } from './ConnectionController';
|
|
19
|
-
import { ApiUtil } from '../utils/ApiUtil';
|
|
20
19
|
|
|
21
20
|
// -- Helpers ------------------------------------------- //
|
|
22
21
|
const baseUrl = CoreHelperUtil.getApiUrl();
|
|
@@ -63,13 +62,18 @@ export const ApiController = {
|
|
|
63
62
|
|
|
64
63
|
_getApiHeaders() {
|
|
65
64
|
const { projectId, sdkType, sdkVersion } = OptionsController.state;
|
|
65
|
+
const reactNativeVersion = [
|
|
66
|
+
Platform.constants.reactNativeVersion.major,
|
|
67
|
+
Platform.constants.reactNativeVersion.minor,
|
|
68
|
+
Platform.constants.reactNativeVersion.patch
|
|
69
|
+
].join('.');
|
|
66
70
|
|
|
67
71
|
return {
|
|
68
72
|
'x-project-id': projectId,
|
|
69
73
|
'x-sdk-type': sdkType,
|
|
70
74
|
'x-sdk-version': sdkVersion,
|
|
71
|
-
'User-Agent':
|
|
72
|
-
'Origin':
|
|
75
|
+
'User-Agent': `${Platform.OS}-${Platform.Version}@rn-${reactNativeVersion}`,
|
|
76
|
+
'Origin': CoreHelperUtil.getBundleId()
|
|
73
77
|
};
|
|
74
78
|
},
|
|
75
79
|
|
|
@@ -3,16 +3,8 @@ import { proxy } from 'valtio';
|
|
|
3
3
|
import { CoreHelperUtil } from '../utils/CoreHelperUtil';
|
|
4
4
|
import { FetchUtil } from '../utils/FetchUtil';
|
|
5
5
|
import type {
|
|
6
|
-
BlockchainApiBalanceResponse,
|
|
7
|
-
BlockchainApiGasPriceRequest,
|
|
8
|
-
BlockchainApiGasPriceResponse,
|
|
9
6
|
BlockchainApiIdentityRequest,
|
|
10
|
-
BlockchainApiIdentityResponse
|
|
11
|
-
BlockchainApiLookupEnsName,
|
|
12
|
-
BlockchainApiTokenPriceRequest,
|
|
13
|
-
BlockchainApiTokenPriceResponse,
|
|
14
|
-
BlockchainApiTransactionsRequest,
|
|
15
|
-
BlockchainApiTransactionsResponse
|
|
7
|
+
BlockchainApiIdentityResponse
|
|
16
8
|
} from '../utils/TypeUtil';
|
|
17
9
|
import { OptionsController } from './OptionsController';
|
|
18
10
|
|
|
@@ -44,85 +36,6 @@ export const BlockchainApiController = {
|
|
|
44
36
|
});
|
|
45
37
|
},
|
|
46
38
|
|
|
47
|
-
fetchTransactions({
|
|
48
|
-
account,
|
|
49
|
-
projectId,
|
|
50
|
-
cursor,
|
|
51
|
-
onramp,
|
|
52
|
-
signal,
|
|
53
|
-
cache
|
|
54
|
-
}: BlockchainApiTransactionsRequest) {
|
|
55
|
-
return state.api.get<BlockchainApiTransactionsResponse>({
|
|
56
|
-
path: `/v1/account/${account}/history`,
|
|
57
|
-
params: {
|
|
58
|
-
projectId,
|
|
59
|
-
cursor,
|
|
60
|
-
onramp
|
|
61
|
-
},
|
|
62
|
-
signal,
|
|
63
|
-
cache
|
|
64
|
-
});
|
|
65
|
-
},
|
|
66
|
-
|
|
67
|
-
fetchTokenPrice({ projectId, addresses }: BlockchainApiTokenPriceRequest) {
|
|
68
|
-
return state.api.post<BlockchainApiTokenPriceResponse>({
|
|
69
|
-
path: '/v1/fungible/price',
|
|
70
|
-
body: {
|
|
71
|
-
projectId,
|
|
72
|
-
currency: 'usd',
|
|
73
|
-
addresses
|
|
74
|
-
},
|
|
75
|
-
headers: {
|
|
76
|
-
'Content-Type': 'application/json'
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
},
|
|
80
|
-
|
|
81
|
-
fetchGasPrice({ projectId, chainId }: BlockchainApiGasPriceRequest) {
|
|
82
|
-
const { sdkType, sdkVersion } = OptionsController.state;
|
|
83
|
-
|
|
84
|
-
return state.api.get<BlockchainApiGasPriceResponse>({
|
|
85
|
-
path: `/v1/convert/gas-price`,
|
|
86
|
-
headers: {
|
|
87
|
-
'Content-Type': 'application/json',
|
|
88
|
-
'x-sdk-type': sdkType,
|
|
89
|
-
'x-sdk-version': sdkVersion
|
|
90
|
-
},
|
|
91
|
-
params: {
|
|
92
|
-
projectId,
|
|
93
|
-
chainId
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
},
|
|
97
|
-
|
|
98
|
-
async getBalance(address: string, chainId?: string, forceUpdate?: string) {
|
|
99
|
-
const { sdkType, sdkVersion } = OptionsController.state;
|
|
100
|
-
|
|
101
|
-
return state.api.get<BlockchainApiBalanceResponse>({
|
|
102
|
-
path: `/v1/account/${address}/balance`,
|
|
103
|
-
headers: {
|
|
104
|
-
'x-sdk-type': sdkType,
|
|
105
|
-
'x-sdk-version': sdkVersion
|
|
106
|
-
},
|
|
107
|
-
params: {
|
|
108
|
-
currency: 'usd',
|
|
109
|
-
projectId: OptionsController.state.projectId,
|
|
110
|
-
chainId,
|
|
111
|
-
forceUpdate
|
|
112
|
-
}
|
|
113
|
-
});
|
|
114
|
-
},
|
|
115
|
-
|
|
116
|
-
async lookupEnsName(name: string) {
|
|
117
|
-
return state.api.get<BlockchainApiLookupEnsName>({
|
|
118
|
-
path: `/v1/profile/account/${name}`,
|
|
119
|
-
params: {
|
|
120
|
-
projectId: OptionsController.state.projectId,
|
|
121
|
-
apiVersion: '2'
|
|
122
|
-
}
|
|
123
|
-
});
|
|
124
|
-
},
|
|
125
|
-
|
|
126
39
|
setClientId(clientId: string | null) {
|
|
127
40
|
state.clientId = clientId;
|
|
128
41
|
state.api = new FetchUtil({ baseUrl, clientId });
|
|
@@ -2,15 +2,9 @@ import { subscribeKey as subKey } from 'valtio/utils';
|
|
|
2
2
|
import { proxy, ref } from 'valtio';
|
|
3
3
|
import { CoreHelperUtil } from '../utils/CoreHelperUtil';
|
|
4
4
|
import { StorageUtil } from '../utils/StorageUtil';
|
|
5
|
-
import type {
|
|
6
|
-
Connector,
|
|
7
|
-
SendTransactionArgs,
|
|
8
|
-
WcWallet,
|
|
9
|
-
WriteContractArgs
|
|
10
|
-
} from '../utils/TypeUtil';
|
|
5
|
+
import type { Connector, WcWallet } from '../utils/TypeUtil';
|
|
11
6
|
import { RouterController } from './RouterController';
|
|
12
7
|
import { ConnectorController } from './ConnectorController';
|
|
13
|
-
import type { SocialProvider } from '@reown/appkit-common-react-native';
|
|
14
8
|
|
|
15
9
|
// -- Types --------------------------------------------- //
|
|
16
10
|
export interface ConnectExternalOptions {
|
|
@@ -27,13 +21,7 @@ export interface ConnectionControllerClient {
|
|
|
27
21
|
) => Promise<void>;
|
|
28
22
|
connectExternal?: (options: ConnectExternalOptions) => Promise<void>;
|
|
29
23
|
signMessage: (message: string) => Promise<string>;
|
|
30
|
-
sendTransaction: (args: SendTransactionArgs) => Promise<`0x${string}` | null>;
|
|
31
|
-
parseUnits: (value: string, decimals: number) => bigint;
|
|
32
|
-
formatUnits: (value: bigint, decimals: number) => string;
|
|
33
|
-
writeContract: (args: WriteContractArgs) => Promise<`0x${string}` | null>;
|
|
34
24
|
disconnect: () => Promise<void>;
|
|
35
|
-
getEnsAddress: (value: string) => Promise<false | string>;
|
|
36
|
-
getEnsAvatar: (value: string) => Promise<false | string>;
|
|
37
25
|
}
|
|
38
26
|
|
|
39
27
|
export interface ConnectionControllerState {
|
|
@@ -49,7 +37,6 @@ export interface ConnectionControllerState {
|
|
|
49
37
|
pressedWallet?: WcWallet;
|
|
50
38
|
recentWallets?: WcWallet[];
|
|
51
39
|
connectedWalletImageUrl?: string;
|
|
52
|
-
connectedSocialProvider?: SocialProvider;
|
|
53
40
|
}
|
|
54
41
|
|
|
55
42
|
type StateKey = keyof ConnectionControllerState;
|
|
@@ -135,40 +122,6 @@ export const ConnectionController = {
|
|
|
135
122
|
}
|
|
136
123
|
},
|
|
137
124
|
|
|
138
|
-
setConnectedSocialProvider(provider: ConnectionControllerState['connectedSocialProvider']) {
|
|
139
|
-
state.connectedSocialProvider = provider;
|
|
140
|
-
|
|
141
|
-
if (provider) {
|
|
142
|
-
StorageUtil.setConnectedSocialProvider(provider);
|
|
143
|
-
} else {
|
|
144
|
-
StorageUtil.removeConnectedSocialProvider();
|
|
145
|
-
}
|
|
146
|
-
},
|
|
147
|
-
|
|
148
|
-
parseUnits(value: string, decimals: number) {
|
|
149
|
-
return this._getClient().parseUnits(value, decimals);
|
|
150
|
-
},
|
|
151
|
-
|
|
152
|
-
formatUnits(value: bigint, decimals: number) {
|
|
153
|
-
return this._getClient().formatUnits(value, decimals);
|
|
154
|
-
},
|
|
155
|
-
|
|
156
|
-
async sendTransaction(args: SendTransactionArgs) {
|
|
157
|
-
return this._getClient().sendTransaction(args);
|
|
158
|
-
},
|
|
159
|
-
|
|
160
|
-
async writeContract(args: WriteContractArgs) {
|
|
161
|
-
return this._getClient().writeContract(args);
|
|
162
|
-
},
|
|
163
|
-
|
|
164
|
-
async getEnsAddress(value: string) {
|
|
165
|
-
return this._getClient().getEnsAddress(value);
|
|
166
|
-
},
|
|
167
|
-
|
|
168
|
-
async getEnsAvatar(value: string) {
|
|
169
|
-
return this._getClient().getEnsAvatar(value);
|
|
170
|
-
},
|
|
171
|
-
|
|
172
125
|
clearUri() {
|
|
173
126
|
state.wcUri = undefined;
|
|
174
127
|
state.wcPairingExpiry = undefined;
|
|
@@ -180,18 +133,15 @@ export const ConnectionController = {
|
|
|
180
133
|
this.clearUri();
|
|
181
134
|
state.pressedWallet = undefined;
|
|
182
135
|
state.connectedWalletImageUrl = undefined;
|
|
183
|
-
state.connectedSocialProvider = undefined;
|
|
184
136
|
ConnectorController.setConnectedConnector(undefined);
|
|
185
137
|
StorageUtil.removeWalletConnectDeepLink();
|
|
186
138
|
StorageUtil.removeConnectedWalletImageUrl();
|
|
187
139
|
StorageUtil.removeConnectedConnector();
|
|
188
|
-
StorageUtil.removeConnectedSocialProvider();
|
|
189
140
|
},
|
|
190
141
|
|
|
191
142
|
async disconnect() {
|
|
192
143
|
await this._getClient().disconnect();
|
|
193
144
|
this.resetWcConnection();
|
|
194
|
-
// remove transactions
|
|
195
145
|
RouterController.reset('Connect');
|
|
196
146
|
}
|
|
197
147
|
};
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Platform } from 'react-native';
|
|
1
2
|
import { proxy, subscribe as sub } from 'valtio/vanilla';
|
|
2
3
|
import { ApiController } from './ApiController';
|
|
3
4
|
import { OptionsController } from './OptionsController';
|
|
@@ -33,6 +34,17 @@ export const EventsController = {
|
|
|
33
34
|
return sub(state, () => callback(state));
|
|
34
35
|
},
|
|
35
36
|
|
|
37
|
+
_getApiHeaders() {
|
|
38
|
+
const { projectId, sdkType, sdkVersion } = OptionsController.state;
|
|
39
|
+
|
|
40
|
+
return {
|
|
41
|
+
'x-project-id': projectId,
|
|
42
|
+
'x-sdk-type': sdkType,
|
|
43
|
+
'x-sdk-version': sdkVersion,
|
|
44
|
+
'User-Agent': `${Platform.OS}-${Platform.Version}`
|
|
45
|
+
};
|
|
46
|
+
},
|
|
47
|
+
|
|
36
48
|
async _sendAnalyticsEvent(data: EventsControllerState['data'], timestamp: number) {
|
|
37
49
|
if (excluded.includes(data.event)) {
|
|
38
50
|
return;
|
|
@@ -41,7 +53,7 @@ export const EventsController = {
|
|
|
41
53
|
try {
|
|
42
54
|
await api.post({
|
|
43
55
|
path: '/e',
|
|
44
|
-
headers:
|
|
56
|
+
headers: this._getApiHeaders(),
|
|
45
57
|
body: {
|
|
46
58
|
eventId: CoreHelperUtil.getUUID(),
|
|
47
59
|
bundleId: CoreHelperUtil.getBundleId(),
|
|
@@ -5,7 +5,6 @@ import { RouterController } from './RouterController';
|
|
|
5
5
|
import { PublicStateController } from './PublicStateController';
|
|
6
6
|
import { EventsController } from './EventsController';
|
|
7
7
|
import { ApiController } from './ApiController';
|
|
8
|
-
import { ConnectorController } from './ConnectorController';
|
|
9
8
|
|
|
10
9
|
// -- Types --------------------------------------------- //
|
|
11
10
|
export interface ModalControllerState {
|
|
@@ -35,8 +34,7 @@ export const ModalController = {
|
|
|
35
34
|
if (options?.view) {
|
|
36
35
|
RouterController.reset(options.view);
|
|
37
36
|
} else if (AccountController.state.isConnected) {
|
|
38
|
-
|
|
39
|
-
RouterController.reset(isUniversalWallet ? 'Account' : 'AccountDefault');
|
|
37
|
+
RouterController.reset('Account');
|
|
40
38
|
} else {
|
|
41
39
|
RouterController.reset('Connect');
|
|
42
40
|
}
|
|
@@ -63,12 +63,6 @@ export const NetworkController = {
|
|
|
63
63
|
state.approvedCaipNetworkIds = data.approvedCaipNetworkIds;
|
|
64
64
|
},
|
|
65
65
|
|
|
66
|
-
getApprovedCaipNetworks() {
|
|
67
|
-
return state.approvedCaipNetworkIds
|
|
68
|
-
?.map(id => state.requestedCaipNetworks?.find(network => network.id === id))
|
|
69
|
-
.filter(Boolean) as CaipNetwork[];
|
|
70
|
-
},
|
|
71
|
-
|
|
72
66
|
async switchActiveNetwork(network: NetworkControllerState['caipNetwork']) {
|
|
73
67
|
await this._getClient().switchCaipNetwork(network);
|
|
74
68
|
state.caipNetwork = network;
|
|
@@ -1,13 +1,5 @@
|
|
|
1
1
|
import { proxy, ref } from 'valtio';
|
|
2
|
-
import type {
|
|
3
|
-
CustomWallet,
|
|
4
|
-
Features,
|
|
5
|
-
Metadata,
|
|
6
|
-
ProjectId,
|
|
7
|
-
SdkVersion,
|
|
8
|
-
Tokens
|
|
9
|
-
} from '../utils/TypeUtil';
|
|
10
|
-
import { ConstantsUtil } from '../utils/ConstantsUtil';
|
|
2
|
+
import type { CustomWallet, Metadata, ProjectId, SdkVersion, Tokens } from '../utils/TypeUtil';
|
|
11
3
|
|
|
12
4
|
// -- Types --------------------------------------------- //
|
|
13
5
|
export interface ClipboardClient {
|
|
@@ -27,15 +19,13 @@ export interface OptionsControllerState {
|
|
|
27
19
|
sdkVersion: SdkVersion;
|
|
28
20
|
metadata?: Metadata;
|
|
29
21
|
isSiweEnabled?: boolean;
|
|
30
|
-
features?: Features;
|
|
31
22
|
}
|
|
32
23
|
|
|
33
24
|
// -- State --------------------------------------------- //
|
|
34
25
|
const state = proxy<OptionsControllerState>({
|
|
35
26
|
projectId: '',
|
|
36
27
|
sdkType: 'appkit',
|
|
37
|
-
sdkVersion: 'react-native-wagmi-undefined'
|
|
38
|
-
features: ConstantsUtil.DEFAULT_FEATURES
|
|
28
|
+
sdkVersion: 'react-native-wagmi-undefined'
|
|
39
29
|
});
|
|
40
30
|
|
|
41
31
|
// -- Controller ---------------------------------------- //
|
|
@@ -86,10 +76,6 @@ export const OptionsController = {
|
|
|
86
76
|
state.isSiweEnabled = isSiweEnabled;
|
|
87
77
|
},
|
|
88
78
|
|
|
89
|
-
setFeatures(features: OptionsControllerState['features']) {
|
|
90
|
-
state.features = { ...ConstantsUtil.DEFAULT_FEATURES, ...features };
|
|
91
|
-
},
|
|
92
|
-
|
|
93
79
|
isClipboardAvailable() {
|
|
94
80
|
return !!state._clipboardClient;
|
|
95
81
|
},
|
|
@@ -97,7 +83,7 @@ export const OptionsController = {
|
|
|
97
83
|
copyToClipboard(value: string) {
|
|
98
84
|
const client = state._clipboardClient;
|
|
99
85
|
if (client) {
|
|
100
|
-
client
|
|
86
|
+
client.setString(value);
|
|
101
87
|
}
|
|
102
88
|
}
|
|
103
89
|
};
|
|
@@ -1,46 +1,26 @@
|
|
|
1
1
|
import { proxy } from 'valtio';
|
|
2
2
|
import type { WcWallet, CaipNetwork, Connector } from '../utils/TypeUtil';
|
|
3
|
-
import type { SocialProvider } from '@reown/appkit-common-react-native';
|
|
4
3
|
|
|
5
4
|
// -- Types --------------------------------------------- //
|
|
6
|
-
type TransactionAction = {
|
|
7
|
-
goBack: boolean;
|
|
8
|
-
view: RouterControllerState['view'] | null;
|
|
9
|
-
close?: boolean;
|
|
10
|
-
replace?: boolean;
|
|
11
|
-
onSuccess?: () => void;
|
|
12
|
-
onCancel?: () => void;
|
|
13
|
-
};
|
|
14
|
-
|
|
15
5
|
export interface RouterControllerState {
|
|
16
6
|
view:
|
|
17
7
|
| 'Account'
|
|
18
|
-
| 'AccountDefault'
|
|
19
|
-
| 'AllWallets'
|
|
20
8
|
| 'Connect'
|
|
21
|
-
| 'ConnectSocials'
|
|
22
|
-
| 'ConnectingExternal'
|
|
23
|
-
| 'ConnectingSiwe'
|
|
24
|
-
| 'ConnectingSocial'
|
|
25
|
-
| 'ConnectingFarcaster'
|
|
26
9
|
| 'ConnectingWalletConnect'
|
|
27
|
-
| '
|
|
28
|
-
| 'EmailVerifyOtp'
|
|
29
|
-
| 'GetWallet'
|
|
10
|
+
| 'ConnectingExternal'
|
|
30
11
|
| 'Networks'
|
|
31
12
|
| 'SwitchNetwork'
|
|
32
|
-
| '
|
|
13
|
+
| 'AllWallets'
|
|
14
|
+
| 'WhatIsAWallet'
|
|
15
|
+
| 'WhatIsANetwork'
|
|
16
|
+
| 'GetWallet'
|
|
17
|
+
| 'EmailVerifyDevice'
|
|
18
|
+
| 'EmailVerifyOtp'
|
|
19
|
+
| 'UpdateEmailWallet'
|
|
33
20
|
| 'UpdateEmailPrimaryOtp'
|
|
34
21
|
| 'UpdateEmailSecondaryOtp'
|
|
35
|
-
| 'UpdateEmailWallet'
|
|
36
22
|
| 'UpgradeEmailWallet'
|
|
37
|
-
| '
|
|
38
|
-
| 'WalletReceive'
|
|
39
|
-
| 'WalletSend'
|
|
40
|
-
| 'WalletSendPreview'
|
|
41
|
-
| 'WalletSendSelectToken'
|
|
42
|
-
| 'WhatIsANetwork'
|
|
43
|
-
| 'WhatIsAWallet';
|
|
23
|
+
| 'ConnectingSiwe';
|
|
44
24
|
history: RouterControllerState['view'][];
|
|
45
25
|
data?: {
|
|
46
26
|
connector?: Connector;
|
|
@@ -48,16 +28,13 @@ export interface RouterControllerState {
|
|
|
48
28
|
network?: CaipNetwork;
|
|
49
29
|
email?: string;
|
|
50
30
|
newEmail?: string;
|
|
51
|
-
socialProvider?: SocialProvider;
|
|
52
31
|
};
|
|
53
|
-
transactionStack: TransactionAction[];
|
|
54
32
|
}
|
|
55
33
|
|
|
56
34
|
// -- State --------------------------------------------- //
|
|
57
35
|
const state = proxy<RouterControllerState>({
|
|
58
36
|
view: 'Connect',
|
|
59
|
-
history: ['Connect']
|
|
60
|
-
transactionStack: []
|
|
37
|
+
history: ['Connect']
|
|
61
38
|
});
|
|
62
39
|
|
|
63
40
|
// -- Controller ---------------------------------------- //
|
|
@@ -72,30 +49,6 @@ export const RouterController = {
|
|
|
72
49
|
}
|
|
73
50
|
},
|
|
74
51
|
|
|
75
|
-
pushTransactionStack(action: TransactionAction) {
|
|
76
|
-
state.transactionStack.push(action);
|
|
77
|
-
},
|
|
78
|
-
|
|
79
|
-
popTransactionStack(cancel?: boolean) {
|
|
80
|
-
const action = state.transactionStack.pop();
|
|
81
|
-
|
|
82
|
-
if (!action) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
if (cancel) {
|
|
87
|
-
this.goBack();
|
|
88
|
-
action?.onCancel?.();
|
|
89
|
-
} else {
|
|
90
|
-
if (action.goBack) {
|
|
91
|
-
this.goBack();
|
|
92
|
-
} else if (action.view) {
|
|
93
|
-
this.reset(action.view);
|
|
94
|
-
}
|
|
95
|
-
action?.onSuccess?.();
|
|
96
|
-
}
|
|
97
|
-
},
|
|
98
|
-
|
|
99
52
|
reset(view: RouterControllerState['view']) {
|
|
100
53
|
state.view = view;
|
|
101
54
|
state.history = [view];
|
package/src/index.ts
CHANGED
|
@@ -1,65 +1,52 @@
|
|
|
1
1
|
// -- Controllers -------------------------------------------------------------
|
|
2
|
-
export {
|
|
3
|
-
|
|
4
|
-
type ModalControllerArguments,
|
|
5
|
-
type ModalControllerState
|
|
6
|
-
} from './controllers/ModalController';
|
|
2
|
+
export { ModalController } from './controllers/ModalController';
|
|
3
|
+
export type { ModalControllerArguments, ModalControllerState } from './controllers/ModalController';
|
|
7
4
|
|
|
8
|
-
export { RouterController
|
|
5
|
+
export { RouterController } from './controllers/RouterController';
|
|
6
|
+
export type { RouterControllerState } from './controllers/RouterController';
|
|
9
7
|
|
|
10
|
-
export { AccountController
|
|
8
|
+
export { AccountController } from './controllers/AccountController';
|
|
9
|
+
export type { AccountControllerState } from './controllers/AccountController';
|
|
11
10
|
|
|
12
|
-
export {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
11
|
+
export { NetworkController } from './controllers/NetworkController';
|
|
12
|
+
export type {
|
|
13
|
+
NetworkControllerClient,
|
|
14
|
+
NetworkControllerState
|
|
16
15
|
} from './controllers/NetworkController';
|
|
17
16
|
|
|
18
|
-
export {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
17
|
+
export { ConnectionController } from './controllers/ConnectionController';
|
|
18
|
+
export type {
|
|
19
|
+
ConnectionControllerClient,
|
|
20
|
+
ConnectionControllerState
|
|
22
21
|
} from './controllers/ConnectionController';
|
|
23
22
|
|
|
24
|
-
export {
|
|
25
|
-
|
|
26
|
-
type ConnectorControllerState
|
|
27
|
-
} from './controllers/ConnectorController';
|
|
23
|
+
export { ConnectorController } from './controllers/ConnectorController';
|
|
24
|
+
export type { ConnectorControllerState } from './controllers/ConnectorController';
|
|
28
25
|
|
|
29
|
-
export { SnackController
|
|
26
|
+
export { SnackController } from './controllers/SnackController';
|
|
27
|
+
export type { SnackControllerState } from './controllers/SnackController';
|
|
30
28
|
|
|
31
|
-
export { ApiController
|
|
29
|
+
export { ApiController } from './controllers/ApiController';
|
|
30
|
+
export type { ApiControllerState } from './controllers/ApiController';
|
|
32
31
|
|
|
33
|
-
export { AssetController
|
|
32
|
+
export { AssetController } from './controllers/AssetController';
|
|
33
|
+
export type { AssetControllerState } from './controllers/AssetController';
|
|
34
34
|
|
|
35
|
-
export { ThemeController
|
|
35
|
+
export { ThemeController } from './controllers/ThemeController';
|
|
36
|
+
export type { ThemeControllerState } from './controllers/ThemeController';
|
|
36
37
|
|
|
37
|
-
export { OptionsController
|
|
38
|
+
export { OptionsController } from './controllers/OptionsController';
|
|
39
|
+
export type { OptionsControllerState } from './controllers/OptionsController';
|
|
38
40
|
|
|
39
|
-
export {
|
|
40
|
-
|
|
41
|
-
type PublicStateControllerState
|
|
42
|
-
} from './controllers/PublicStateController';
|
|
41
|
+
export { PublicStateController } from './controllers/PublicStateController';
|
|
42
|
+
export type { PublicStateControllerState } from './controllers/PublicStateController';
|
|
43
43
|
|
|
44
44
|
export { BlockchainApiController } from './controllers/BlockchainApiController';
|
|
45
45
|
|
|
46
|
-
export {
|
|
47
|
-
|
|
48
|
-
export { EventsController, type EventsControllerState } from './controllers/EventsController';
|
|
49
|
-
|
|
50
|
-
export { EnsController, type EnsControllerState } from './controllers/EnsController';
|
|
51
|
-
|
|
52
|
-
export {
|
|
53
|
-
TransactionsController,
|
|
54
|
-
type TransactionsControllerState
|
|
55
|
-
} from './controllers/TransactionsController';
|
|
56
|
-
|
|
57
|
-
export { SendController, type SendControllerState } from './controllers/SendController';
|
|
58
|
-
|
|
59
|
-
export { WebviewController, type WebviewControllerState } from './controllers/WebviewController';
|
|
46
|
+
export { EventsController } from './controllers/EventsController';
|
|
47
|
+
export type { EventsControllerState } from './controllers/EventsController';
|
|
60
48
|
|
|
61
49
|
// -- Utils -------------------------------------------------------------------
|
|
62
|
-
export { ApiUtil } from './utils/ApiUtil';
|
|
63
50
|
export { AssetUtil } from './utils/AssetUtil';
|
|
64
51
|
export { ConstantsUtil } from './utils/ConstantsUtil';
|
|
65
52
|
export { CoreHelperUtil } from './utils/CoreHelperUtil';
|
|
@@ -1,11 +1,3 @@
|
|
|
1
|
-
import type { Features } from './TypeUtil';
|
|
2
|
-
|
|
3
|
-
const defaultFeatures: Features = {
|
|
4
|
-
email: true,
|
|
5
|
-
emailShowWallets: true,
|
|
6
|
-
socials: ['x', 'discord', 'github', 'apple', 'facebook', 'farcaster']
|
|
7
|
-
};
|
|
8
|
-
|
|
9
1
|
export const ConstantsUtil = {
|
|
10
2
|
FOUR_MINUTES_MS: 240000,
|
|
11
3
|
|
|
@@ -15,9 +7,5 @@ export const ConstantsUtil = {
|
|
|
15
7
|
|
|
16
8
|
EMAIL_REGEX: /^[a-zA-Z0-9.!#$%&’*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)+$/,
|
|
17
9
|
|
|
18
|
-
LINKING_ERROR: 'LINKING_ERROR'
|
|
19
|
-
|
|
20
|
-
NATIVE_TOKEN_ADDRESS: '0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee',
|
|
21
|
-
|
|
22
|
-
DEFAULT_FEATURES: defaultFeatures
|
|
10
|
+
LINKING_ERROR: 'LINKING_ERROR'
|
|
23
11
|
};
|