@talken/talkenkit 2.4.20 → 2.4.22
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/LICENSE +9 -0
- package/dist/abcWallet-4RS3B4ZG.js +188 -0
- package/dist/abcWallet-EBOW2RJB.js +188 -0
- package/dist/abcWallet-RS4EOJ4I.js +188 -0
- package/dist/abcWallet-SNEZVK7V.js +188 -0
- package/dist/abcWallet-TC7M2JYX.js +188 -0
- package/dist/abcWallet-VZMW2DR3.js +188 -0
- package/dist/abcWallet-XJ3WSUVI.js +188 -0
- package/dist/abcWallet-XNCBZAIQ.js +188 -0
- package/dist/chunk-6FLQAAC4.js +7213 -0
- package/dist/chunk-7GIIMIPN.js +7213 -0
- package/dist/chunk-IBFA37SC.js +7228 -0
- package/dist/chunk-O5ZOC4NJ.js +7215 -0
- package/dist/chunk-OPOAKGEX.js +7216 -0
- package/dist/chunk-OTIHVCVR.js +7213 -0
- package/dist/chunk-P77BVZZF.js +7369 -0
- package/dist/chunk-RFLXXSQH.js +7139 -0
- package/dist/components/ConfirmationModal/NonEvmConfirmationModal.css.d.ts +11 -0
- package/dist/components/ConfirmationModal/NonEvmSignConfirmationModal.d.ts +9 -0
- package/dist/components/ConfirmationModal/NonEvmTransferConfirmationModal.d.ts +9 -0
- package/dist/components/ConfirmationModal/SignConfirmationModal.css.d.ts +1 -19
- package/dist/components/ConfirmationModal/TransactionConfirmationModal.css.d.ts +1 -20
- package/dist/components/ConfirmationModal/commonStyles.css.d.ts +19 -0
- package/dist/components/ConfirmationModal/index.d.ts +2 -0
- package/dist/components/ConfirmationModal/utils.d.ts +2 -1
- package/dist/hooks/useWalletCapabilities.d.ts +2 -0
- package/dist/index.css +227 -307
- package/dist/index.d.ts +4 -2
- package/dist/index.js +2007 -1067
- package/dist/providers/SignConfirmationProvider/NonEvmConfirmationContext.d.ts +6 -0
- package/dist/providers/SignConfirmationProvider/index.d.ts +2 -1
- package/dist/providers/SignConfirmationProvider/requestParsers.d.ts +6 -1
- package/dist/providers/SignConfirmationProvider/types.d.ts +35 -1
- package/dist/wallets/capabilities/detectCapabilities.d.ts +7 -0
- package/dist/wallets/capabilities/requestWalletAction.d.ts +8 -0
- package/dist/wallets/capabilities/types.d.ts +50 -0
- package/dist/wallets/walletConnectors/abcWallet/abcApi.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.d.ts +10 -0
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +5 -5
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.d.ts +9 -0
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.d.ts +10 -0
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.d.ts +16 -0
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +115 -33
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.d.ts +16 -0
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +7 -7
- package/dist/wallets/walletConnectors/abcWallet/api/AuthApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/BaseApiClient.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/api/BitcoinApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/GasApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +9 -4
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/TransactionApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/TronApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/WalletApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/index.js +17 -17
- package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +5 -4
- package/dist/wallets/walletConnectors/abcWallet/constants.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/index.js +21 -21
- package/dist/wallets/walletConnectors/abcWallet/types.d.ts +31 -1
- package/dist/wallets/walletConnectors/abcWallet/utils.js +2 -2
- package/dist/wallets/walletConnectors/berasigWallet/berasigWallet.js +2 -2
- package/dist/wallets/walletConnectors/bifrostWallet/bifrostWallet.js +2 -2
- package/dist/wallets/walletConnectors/binanceWallet/binanceWallet.js +2 -2
- package/dist/wallets/walletConnectors/bitgetWallet/bitgetWallet.js +2 -2
- package/dist/wallets/walletConnectors/bybitWallet/bybitWallet.js +2 -2
- package/dist/wallets/walletConnectors/chunk-2IZBLAHI.js +52 -0
- package/dist/wallets/walletConnectors/chunk-32IJ3ILH.js +71 -0
- package/dist/wallets/walletConnectors/chunk-3AX66UHT.js +479 -0
- package/dist/wallets/walletConnectors/chunk-3BVPV64G.js +36 -0
- package/dist/wallets/walletConnectors/chunk-3DGFHWI3.js +302 -0
- package/dist/wallets/walletConnectors/chunk-4FKUVQCM.js +655 -0
- package/dist/wallets/walletConnectors/chunk-56SF4VRC.js +640 -0
- package/dist/wallets/walletConnectors/chunk-5KOE7NJW.js +52 -0
- package/dist/wallets/walletConnectors/chunk-6CVXZ3ZW.js +771 -0
- package/dist/wallets/walletConnectors/chunk-6GCWEPU7.js +643 -0
- package/dist/wallets/walletConnectors/chunk-6YFP3Q2I.js +118 -0
- package/dist/wallets/walletConnectors/chunk-7EEPPULA.js +118 -0
- package/dist/wallets/walletConnectors/chunk-7QL42XTB.js +302 -0
- package/dist/wallets/walletConnectors/chunk-A7ZSPSFX.js +577 -0
- package/dist/wallets/walletConnectors/chunk-AI3CT254.js +302 -0
- package/dist/wallets/walletConnectors/chunk-AMNVH7CZ.js +151 -0
- package/dist/wallets/walletConnectors/chunk-AOREXGRM.js +350 -0
- package/dist/wallets/walletConnectors/chunk-BLO7E54F.js +302 -0
- package/dist/wallets/walletConnectors/chunk-BNRH5PYS.js +52 -0
- package/dist/wallets/walletConnectors/chunk-BOV5FXU6.js +151 -0
- package/dist/wallets/walletConnectors/chunk-BR25RFNF.js +260 -0
- package/dist/wallets/walletConnectors/chunk-BXQ2UWJ3.js +91 -0
- package/dist/wallets/walletConnectors/chunk-CAMPW7O2.js +874 -0
- package/dist/wallets/walletConnectors/chunk-CLMFCNP7.js +52 -0
- package/dist/wallets/walletConnectors/chunk-DSZOE65L.js +107 -0
- package/dist/wallets/walletConnectors/chunk-DU6RCLWT.js +272 -0
- package/dist/wallets/walletConnectors/chunk-ENN6UGGA.js +421 -0
- package/dist/wallets/walletConnectors/chunk-EXWDLN5V.js +204 -0
- package/dist/wallets/walletConnectors/chunk-FFU26Y5Y.js +272 -0
- package/dist/wallets/walletConnectors/chunk-FGS2WHVA.js +118 -0
- package/dist/wallets/walletConnectors/chunk-FJJ3QI4R.js +91 -0
- package/dist/wallets/walletConnectors/chunk-FS2OOQYF.js +204 -0
- package/dist/wallets/walletConnectors/chunk-G5X3COSW.js +205 -0
- package/dist/wallets/walletConnectors/chunk-H53R4SFZ.js +204 -0
- package/dist/wallets/walletConnectors/chunk-J4QGDATF.js +71 -0
- package/dist/wallets/walletConnectors/chunk-JIJNCMJR.js +874 -0
- package/dist/wallets/walletConnectors/chunk-JSGZYU4A.js +52 -0
- package/dist/wallets/walletConnectors/chunk-JVT7R2GZ.js +771 -0
- package/dist/wallets/walletConnectors/chunk-K3JNN5UK.js +71 -0
- package/dist/wallets/walletConnectors/chunk-KBHPY3NA.js +302 -0
- package/dist/wallets/walletConnectors/chunk-KEX6WS23.js +640 -0
- package/dist/wallets/walletConnectors/chunk-KHYKVVR7.js +52 -0
- package/dist/wallets/walletConnectors/chunk-LOL7ZZ3S.js +302 -0
- package/dist/wallets/walletConnectors/chunk-LOSXI36Y.js +479 -0
- package/dist/wallets/walletConnectors/chunk-M2U5QGM7.js +260 -0
- package/dist/wallets/walletConnectors/chunk-M73AWLIV.js +107 -0
- package/dist/wallets/walletConnectors/chunk-MAUC46AE.js +302 -0
- package/dist/wallets/walletConnectors/chunk-MBRXYEQC.js +272 -0
- package/dist/wallets/walletConnectors/chunk-MDDD4LG2.js +874 -0
- package/dist/wallets/walletConnectors/chunk-MMR2QAEU.js +642 -0
- package/dist/wallets/walletConnectors/chunk-MNZZRFUC.js +302 -0
- package/dist/wallets/walletConnectors/chunk-OIRY24PH.js +302 -0
- package/dist/wallets/walletConnectors/chunk-ORBX4JE2.js +52 -0
- package/dist/wallets/walletConnectors/chunk-OXJFFDW7.js +761 -0
- package/dist/wallets/walletConnectors/chunk-QD3PPWTN.js +272 -0
- package/dist/wallets/walletConnectors/chunk-RCIABMG5.js +259 -0
- package/dist/wallets/walletConnectors/chunk-RHC4SVLB.js +71 -0
- package/dist/wallets/walletConnectors/chunk-S2CB4KFC.js +71 -0
- package/dist/wallets/walletConnectors/chunk-S6HZD4XZ.js +302 -0
- package/dist/wallets/walletConnectors/chunk-S72LCNVX.js +272 -0
- package/dist/wallets/walletConnectors/chunk-SCWE5EEX.js +91 -0
- package/dist/wallets/walletConnectors/chunk-TKEL4D4E.js +151 -0
- package/dist/wallets/walletConnectors/chunk-TKJEMEBZ.js +71 -0
- package/dist/wallets/walletConnectors/chunk-TZ44ZREA.js +302 -0
- package/dist/wallets/walletConnectors/chunk-UGQSI3US.js +547 -0
- package/dist/wallets/walletConnectors/chunk-UU4JYY3C.js +205 -0
- package/dist/wallets/walletConnectors/chunk-V5P5BL6Z.js +302 -0
- package/dist/wallets/walletConnectors/chunk-VH6DIRPF.js +71 -0
- package/dist/wallets/walletConnectors/chunk-VPNZAMW5.js +205 -0
- package/dist/wallets/walletConnectors/chunk-W6QN6QXO.js +52 -0
- package/dist/wallets/walletConnectors/chunk-WDULICVN.js +302 -0
- package/dist/wallets/walletConnectors/chunk-WGGHGODM.js +272 -0
- package/dist/wallets/walletConnectors/chunk-XUCMTLM3.js +52 -0
- package/dist/wallets/walletConnectors/chunk-Y5WAX6WO.js +52 -0
- package/dist/wallets/walletConnectors/chunk-Y62PFBWE.js +640 -0
- package/dist/wallets/walletConnectors/chunk-Z6ABK6G6.js +107 -0
- package/dist/wallets/walletConnectors/chunk-ZCA5QSIM.js +71 -0
- package/dist/wallets/walletConnectors/chunk-ZJDZJW55.js +479 -0
- package/dist/wallets/walletConnectors/chunk-ZOF7ZDGU.js +52 -0
- package/dist/wallets/walletConnectors/chunk-ZUU57RHO.js +36 -0
- package/dist/wallets/walletConnectors/chunk-ZWFGRREM.js +36 -0
- package/dist/wallets/walletConnectors/chunk-ZY5BCHP2.js +302 -0
- package/dist/wallets/walletConnectors/clvWallet/clvWallet.js +2 -2
- package/dist/wallets/walletConnectors/coin98Wallet/coin98Wallet.js +2 -2
- package/dist/wallets/walletConnectors/coreWallet/coreWallet.js +2 -2
- package/dist/wallets/walletConnectors/foxWallet/foxWallet.js +2 -2
- package/dist/wallets/walletConnectors/frontierWallet/frontierWallet.js +2 -2
- package/dist/wallets/walletConnectors/gateWallet/gateWallet.js +2 -2
- package/dist/wallets/walletConnectors/index.js +88 -88
- package/dist/wallets/walletConnectors/iopayWallet/iopayWallet.js +2 -2
- package/dist/wallets/walletConnectors/kaiaWallet/kaiaWallet.js +2 -2
- package/dist/wallets/walletConnectors/kaikasWallet/kaikasWallet.js +2 -2
- package/dist/wallets/walletConnectors/metaMaskWallet/metaMaskWallet.js +2 -2
- package/dist/wallets/walletConnectors/okxWallet/okxWallet.js +2 -2
- package/dist/wallets/walletConnectors/rainbowWallet/rainbowWallet.js +2 -2
- package/dist/wallets/walletConnectors/roninWallet/roninWallet.js +2 -2
- package/dist/wallets/walletConnectors/safepalWallet/safepalWallet.js +2 -2
- package/dist/wallets/walletConnectors/subWallet/subWallet.js +2 -2
- package/dist/wallets/walletConnectors/tokenPocketWallet/tokenPocketWallet.js +2 -2
- package/dist/wallets/walletConnectors/trustWallet/trustWallet.js +2 -2
- package/dist/wallets/walletConnectors/zealWallet/zealWallet.js +2 -2
- package/dist/wallets/walletConnectors/zerionWallet/zerionWallet.js +2 -2
- package/package.json +11 -12
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
// src/wallets/walletConnectors/abcWallet/constants.ts
|
|
4
|
+
var DEFAULT_ABC_CONFIG = {
|
|
5
|
+
environment: "development",
|
|
6
|
+
waasUrl: ""
|
|
7
|
+
// All operations routed through TalkenApiClient
|
|
8
|
+
};
|
|
9
|
+
var TOKEN_EXPIRY = {
|
|
10
|
+
ACCESS_TOKEN: 10 * 60 * 1e3,
|
|
11
|
+
// 10 minutes
|
|
12
|
+
REFRESH_TOKEN: 60 * 60 * 1e3,
|
|
13
|
+
// 60 minutes
|
|
14
|
+
REFRESH_BUFFER: 60 * 1e3
|
|
15
|
+
// Refresh 60s before expiry (increased for network latency tolerance)
|
|
16
|
+
};
|
|
17
|
+
var ABC_ENDPOINTS = {
|
|
18
|
+
// Authentication
|
|
19
|
+
SNS_LOGIN: "/abc/snsLogin",
|
|
20
|
+
// Legacy - may need to update
|
|
21
|
+
REGISTER_SNS_USER: "/abc/registerSnsUser",
|
|
22
|
+
// Legacy - may need to update
|
|
23
|
+
// Secure channel
|
|
24
|
+
SECURE_CHANNEL_CREATE: "/secure/channel/create",
|
|
25
|
+
// Email OTP
|
|
26
|
+
SEND_OTP: "/member/mail-service/{email}/sendcode",
|
|
27
|
+
// {email} placeholder
|
|
28
|
+
VERIFY_OTP: "/member/mail-service/{email}/verifycode",
|
|
29
|
+
// {email} placeholder
|
|
30
|
+
// Wallet operations (EVM)
|
|
31
|
+
// Based on tg-wallet-frontend reference
|
|
32
|
+
MPC_WALLETS: "/wapi/v2/mpc/wallets",
|
|
33
|
+
// EVM wallet generation/recovery
|
|
34
|
+
MPC_WALLETS_INFO: "/wapi/v2/mpc/wallets/info",
|
|
35
|
+
// Get wallet info
|
|
36
|
+
// Signing operations
|
|
37
|
+
// Based on tg-wallet-frontend reference implementation
|
|
38
|
+
SIGN_HASH: "/wapi/v2/sign/hash",
|
|
39
|
+
// Personal sign with hash (EIP-191)
|
|
40
|
+
SIGN_TYPED: "/wapi/v2/sign/typed-data",
|
|
41
|
+
// Typed data sign (EIP-712)
|
|
42
|
+
SIGN_TRANSACTION: "/wapi/v2/sign",
|
|
43
|
+
// EVM transaction sign (LEGACY, EIP1559, PERSONAL)
|
|
44
|
+
// Transaction operations
|
|
45
|
+
SEND_RAW_TX: "/wapi/v2/transactions/raw-tx/send",
|
|
46
|
+
// Send signed transaction
|
|
47
|
+
TRANSACTION_COUNT: "/wapi/v2/transactions/count",
|
|
48
|
+
// Get transaction count (nonce)
|
|
49
|
+
// Gas estimation and fee data
|
|
50
|
+
GAS_SUGGESTED_FEES: "/wapi/v2/gas/suggestedGasFees",
|
|
51
|
+
// Get suggested gas fees for EIP-1559
|
|
52
|
+
GAS_ESTIMATE_EIP1559: "/wapi/v2/gas/estimate/eip1559",
|
|
53
|
+
// Estimate gas limit for EIP-1559
|
|
54
|
+
// Token info (Walletscan)
|
|
55
|
+
WALLETSCAN_TOKEN: "/wapi/v2/walletscan/token",
|
|
56
|
+
// GET /{contractAddress}?networks=xxx
|
|
57
|
+
WALLETSCAN_NATIVES: "/wapi/v2/walletscan/natives",
|
|
58
|
+
// GET ?walletAddress=xxx&networks=xxx
|
|
59
|
+
WALLETSCAN_NFTS: "/wapi/v2/walletscan/nfts",
|
|
60
|
+
// GET /{contractAddress}?walletAddress=xxx&networks=xxx
|
|
61
|
+
// Token refresh (based on tg-wallet-frontend reference)
|
|
62
|
+
REFRESH_TOKEN: "/abc/abcRefresh",
|
|
63
|
+
// Token refresh endpoint
|
|
64
|
+
// Legacy endpoints (kept for compatibility)
|
|
65
|
+
WALLETS_V3: "/abc/wallets/v3",
|
|
66
|
+
// Solana only
|
|
67
|
+
INFO: "/abc/info"
|
|
68
|
+
};
|
|
69
|
+
var AUTH_PROVIDERS = {
|
|
70
|
+
EMAIL: "email",
|
|
71
|
+
GOOGLE: "google",
|
|
72
|
+
APPLE: "apple",
|
|
73
|
+
TELEGRAM: "telegram",
|
|
74
|
+
TWITTER: "twitter"
|
|
75
|
+
};
|
|
76
|
+
var CHAIN_TYPES = {
|
|
77
|
+
EVM: "evm",
|
|
78
|
+
SOLANA: "solana",
|
|
79
|
+
BITCOIN: "bitcoin"
|
|
80
|
+
};
|
|
81
|
+
var SOLANA_CHAIN_ID = 900;
|
|
82
|
+
var BITCOIN_CHAIN_ID = 800;
|
|
83
|
+
var EVM_CHAINS = {
|
|
84
|
+
ETHEREUM_MAINNET: 1,
|
|
85
|
+
ETHEREUM_GOERLI: 5,
|
|
86
|
+
ETHEREUM_SEPOLIA: 11155111,
|
|
87
|
+
POLYGON_MAINNET: 137,
|
|
88
|
+
POLYGON_MUMBAI: 80001,
|
|
89
|
+
BSC_MAINNET: 56,
|
|
90
|
+
BSC_TESTNET: 97,
|
|
91
|
+
ARBITRUM_MAINNET: 42161,
|
|
92
|
+
ARBITRUM_GOERLI: 421613,
|
|
93
|
+
OPTIMISM_MAINNET: 10,
|
|
94
|
+
OPTIMISM_GOERLI: 420,
|
|
95
|
+
AVALANCHE_MAINNET: 43114,
|
|
96
|
+
AVALANCHE_FUJI: 43113,
|
|
97
|
+
KLAYTN_MAINNET: 8217,
|
|
98
|
+
KLAYTN_BAOBAB: 1001
|
|
99
|
+
};
|
|
100
|
+
var ABC_AUDIENCE = "https://mw.myabcwallet.com";
|
|
101
|
+
var PIN_CONFIG = {
|
|
102
|
+
MIN_LENGTH: 6,
|
|
103
|
+
MAX_LENGTH: 6,
|
|
104
|
+
MAX_ATTEMPTS: 5,
|
|
105
|
+
LOCKOUT_DURATION: 15 * 60 * 1e3
|
|
106
|
+
// 15 minutes
|
|
107
|
+
};
|
|
108
|
+
var STORAGE_VERSION = "1.0.0";
|
|
109
|
+
var REQUEST_TIMEOUT = 3e4;
|
|
110
|
+
var RETRY_CONFIG = {
|
|
111
|
+
MAX_RETRIES: 3,
|
|
112
|
+
RETRY_DELAY: 1e3,
|
|
113
|
+
// 1 second
|
|
114
|
+
BACKOFF_MULTIPLIER: 2
|
|
115
|
+
};
|
|
116
|
+
var ABC_WALLET_METADATA = {
|
|
117
|
+
id: "abc",
|
|
118
|
+
name: "ABC Wallet",
|
|
119
|
+
iconBackground: "#ffffff",
|
|
120
|
+
rdns: "com.abcwallet"
|
|
121
|
+
};
|
|
122
|
+
var MODAL_CONFIG = {
|
|
123
|
+
WIDTH: 400,
|
|
124
|
+
MAX_WIDTH: "90vw",
|
|
125
|
+
BORDER_RADIUS: 16,
|
|
126
|
+
PADDING: 24
|
|
127
|
+
};
|
|
128
|
+
var SOCIAL_BUTTONS = [
|
|
129
|
+
{
|
|
130
|
+
provider: AUTH_PROVIDERS.GOOGLE,
|
|
131
|
+
label: "Google",
|
|
132
|
+
iconName: "google"
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
provider: AUTH_PROVIDERS.APPLE,
|
|
136
|
+
label: "Apple",
|
|
137
|
+
iconName: "apple"
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
provider: AUTH_PROVIDERS.TELEGRAM,
|
|
141
|
+
label: "Telegram",
|
|
142
|
+
iconName: "telegram"
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
provider: AUTH_PROVIDERS.TWITTER,
|
|
146
|
+
label: "X (Twitter)",
|
|
147
|
+
iconName: "twitter"
|
|
148
|
+
}
|
|
149
|
+
];
|
|
150
|
+
var ERROR_MESSAGES = {
|
|
151
|
+
INVALID_CREDENTIALS: "Invalid email or password",
|
|
152
|
+
TOKEN_EXPIRED: "Your session has expired. Please login again.",
|
|
153
|
+
WALLET_NOT_FOUND: "Wallet not found. Please create a new wallet.",
|
|
154
|
+
INVALID_PIN: "Invalid PIN code",
|
|
155
|
+
NETWORK_ERROR: "Network error. Please check your connection.",
|
|
156
|
+
SIGNATURE_FAILED: "Failed to sign transaction",
|
|
157
|
+
USER_CANCELLED: "User cancelled the operation",
|
|
158
|
+
UNKNOWN_ERROR: "An unknown error occurred",
|
|
159
|
+
INVALID_OTP: "Invalid or expired OTP code",
|
|
160
|
+
EMAIL_REQUIRED: "Email address is required",
|
|
161
|
+
PIN_REQUIRED: "PIN code is required",
|
|
162
|
+
WALLET_GENERATION_FAILED: "Failed to generate wallet"
|
|
163
|
+
};
|
|
164
|
+
var SUCCESS_MESSAGES = {
|
|
165
|
+
LOGIN_SUCCESS: "Successfully logged in",
|
|
166
|
+
WALLET_CREATED: "Wallet created successfully",
|
|
167
|
+
TRANSACTION_SENT: "Transaction sent successfully",
|
|
168
|
+
OTP_SENT: "OTP code sent to your email"
|
|
169
|
+
};
|
|
170
|
+
var ABC_EVENTS = {
|
|
171
|
+
CONNECT: "abc:connect",
|
|
172
|
+
DISCONNECT: "abc:disconnect",
|
|
173
|
+
ACCOUNTS_CHANGED: "abc:accountsChanged",
|
|
174
|
+
CHAIN_CHANGED: "abc:chainChanged",
|
|
175
|
+
ERROR: "abc:error",
|
|
176
|
+
AUTH_STATE_CHANGED: "abc:authStateChanged"
|
|
177
|
+
};
|
|
178
|
+
var STORAGE_PREFIX = "talkenkit_abc_";
|
|
179
|
+
var DEBUG_MODE = true;
|
|
180
|
+
var DEFAULT_HEADERS = {
|
|
181
|
+
"Content-Type": "application/x-www-form-urlencoded",
|
|
182
|
+
Accept: "application/json"
|
|
183
|
+
};
|
|
184
|
+
var ABC_FEATURES = {
|
|
185
|
+
EMAIL_LOGIN: true,
|
|
186
|
+
SOCIAL_LOGIN: true,
|
|
187
|
+
MULTI_CHAIN: true,
|
|
188
|
+
EVM_SUPPORT: true,
|
|
189
|
+
SOLANA_SUPPORT: true,
|
|
190
|
+
BITCOIN_SUPPORT: false,
|
|
191
|
+
// Future feature
|
|
192
|
+
GASLESS_TRANSACTIONS: false,
|
|
193
|
+
// Future feature
|
|
194
|
+
SOCIAL_RECOVERY: false
|
|
195
|
+
// Future feature
|
|
196
|
+
};
|
|
197
|
+
var DEFAULT_TALKEN_API_CONFIG = {
|
|
198
|
+
baseUrl: void 0,
|
|
199
|
+
timeout: REQUEST_TIMEOUT
|
|
200
|
+
};
|
|
201
|
+
var TALKEN_API_ENDPOINTS = {
|
|
202
|
+
// ── Auth (single action-based endpoint) ─────────────────────────────
|
|
203
|
+
AUTH: "/wallet/auth",
|
|
204
|
+
// ── Wallet ──────────────────────────────────────────────────────────
|
|
205
|
+
WALLET_MPC: "/wallet/mpc",
|
|
206
|
+
WALLET_ADDRESS: "/wallet/address",
|
|
207
|
+
WALLET_SCAN: "/wallet/scan",
|
|
208
|
+
WALLET_BTC: "/wallet/btc",
|
|
209
|
+
// ── EVM Sign (WaaS proxy) ───────────────────────────────────────────
|
|
210
|
+
SIGN_EVM: "/wallet/sign/evm",
|
|
211
|
+
SIGN_TYPED: "/wallet/sign/typed",
|
|
212
|
+
SIGN_PERSONAL: "/wallet/sign/personal",
|
|
213
|
+
SIGN_AUTHORIZATION: "/wallet/sign/authorization",
|
|
214
|
+
// ── Hash Sign (secp256k1, universal: EVM/BTC/TVM) ───────────────────
|
|
215
|
+
SIGN_HASH: "/wallet/sign/hash",
|
|
216
|
+
// ── SOL Sign (WaaS proxy) ───────────────────────────────────────────
|
|
217
|
+
SIGN_SVM: "/wallet/sign/sol",
|
|
218
|
+
// ── TX ──────────────────────────────────────────────────────────────
|
|
219
|
+
TX_RAW: "/wallet/tx/raw",
|
|
220
|
+
TX_EVM: "/wallet/tx/evm",
|
|
221
|
+
TX_SOL: "/wallet/tx/sol",
|
|
222
|
+
TX_BTC: "/wallet/tx/btc",
|
|
223
|
+
TX_TVM: "/wallet/tx/tvm",
|
|
224
|
+
// ── Gas (WaaS proxy) ───────────────────────────────────────────────
|
|
225
|
+
GAS_PRICE: "/wallet/gas/price",
|
|
226
|
+
GAS_SUGGESTED: "/wallet/gas/suggested",
|
|
227
|
+
GAS_ESTIMATE: "/wallet/gas/estimate",
|
|
228
|
+
// ── Nonce (WaaS proxy) ─────────────────────────────────────────────
|
|
229
|
+
NONCE: "/wallet/nonce",
|
|
230
|
+
// ── Relayer ────────────────────────────────────────────────────────
|
|
231
|
+
RELAYER_FEE_ESTIMATE: "/relayer/estimate-fee"
|
|
232
|
+
};
|
|
233
|
+
|
|
234
|
+
export {
|
|
235
|
+
DEFAULT_ABC_CONFIG,
|
|
236
|
+
TOKEN_EXPIRY,
|
|
237
|
+
ABC_ENDPOINTS,
|
|
238
|
+
AUTH_PROVIDERS,
|
|
239
|
+
CHAIN_TYPES,
|
|
240
|
+
SOLANA_CHAIN_ID,
|
|
241
|
+
BITCOIN_CHAIN_ID,
|
|
242
|
+
EVM_CHAINS,
|
|
243
|
+
ABC_AUDIENCE,
|
|
244
|
+
PIN_CONFIG,
|
|
245
|
+
STORAGE_VERSION,
|
|
246
|
+
REQUEST_TIMEOUT,
|
|
247
|
+
RETRY_CONFIG,
|
|
248
|
+
ABC_WALLET_METADATA,
|
|
249
|
+
MODAL_CONFIG,
|
|
250
|
+
SOCIAL_BUTTONS,
|
|
251
|
+
ERROR_MESSAGES,
|
|
252
|
+
SUCCESS_MESSAGES,
|
|
253
|
+
ABC_EVENTS,
|
|
254
|
+
STORAGE_PREFIX,
|
|
255
|
+
DEBUG_MODE,
|
|
256
|
+
DEFAULT_HEADERS,
|
|
257
|
+
ABC_FEATURES,
|
|
258
|
+
DEFAULT_TALKEN_API_CONFIG,
|
|
259
|
+
TALKEN_API_ENDPOINTS
|
|
260
|
+
};
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
BaseApiClient
|
|
4
|
+
} from "./chunk-QD3PPWTN.js";
|
|
5
|
+
|
|
6
|
+
// src/wallets/walletConnectors/abcWallet/api/GasApi.ts
|
|
7
|
+
import { getTalkenApiClient } from "@talken/talkenkit";
|
|
8
|
+
var GasApi = class extends BaseApiClient {
|
|
9
|
+
parseGasFees(data) {
|
|
10
|
+
return {
|
|
11
|
+
...data,
|
|
12
|
+
networkCongestion: data.networkCongestion != null ? Number(data.networkCongestion) : void 0
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Get suggested gas fees for EIP-1559 transactions via TalkenApiClient
|
|
17
|
+
*
|
|
18
|
+
* @param network - Network name (ethereum, polygon, klaytn, etc.)
|
|
19
|
+
* @returns Suggested gas fees or null if failed
|
|
20
|
+
*/
|
|
21
|
+
async getSuggestedGasFees(network) {
|
|
22
|
+
const api = getTalkenApiClient();
|
|
23
|
+
if (!api)
|
|
24
|
+
throw new Error("TalkenApiClient not initialized");
|
|
25
|
+
try {
|
|
26
|
+
const gasFees = await api.evm.getGasSuggested(network);
|
|
27
|
+
return this.parseGasFees(gasFees);
|
|
28
|
+
} catch (error) {
|
|
29
|
+
console.warn(
|
|
30
|
+
"[GasApi] TalkenApi getGasSuggested failed:",
|
|
31
|
+
network,
|
|
32
|
+
error
|
|
33
|
+
);
|
|
34
|
+
return null;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Estimate gas limit for EIP-1559 transaction via TalkenApiClient
|
|
39
|
+
*
|
|
40
|
+
* @param params - Transaction parameters
|
|
41
|
+
* @returns Gas limit (hex string) or null if failed
|
|
42
|
+
*/
|
|
43
|
+
async estimateGas(params) {
|
|
44
|
+
const api = getTalkenApiClient();
|
|
45
|
+
if (!api)
|
|
46
|
+
throw new Error("TalkenApiClient not initialized");
|
|
47
|
+
try {
|
|
48
|
+
const response = await api.evm.estimateGas({
|
|
49
|
+
network: params.network,
|
|
50
|
+
from: params.from || "",
|
|
51
|
+
to: params.to,
|
|
52
|
+
value: params.value || "0x0",
|
|
53
|
+
data: params.data || "0x"
|
|
54
|
+
});
|
|
55
|
+
return response.result ?? null;
|
|
56
|
+
} catch (error) {
|
|
57
|
+
console.warn("[GasApi] TalkenApi estimateGas failed:", error);
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Get suggested gas fees with timeout
|
|
63
|
+
*
|
|
64
|
+
* @param network - Network name
|
|
65
|
+
* @param timeoutMs - Timeout in milliseconds (default: 5000)
|
|
66
|
+
* @returns Suggested gas fees or null if timeout/failed
|
|
67
|
+
*/
|
|
68
|
+
async getSuggestedGasFeesWithTimeout(network, timeoutMs = 5e3) {
|
|
69
|
+
try {
|
|
70
|
+
const result = await Promise.race([
|
|
71
|
+
this.getSuggestedGasFees(network),
|
|
72
|
+
new Promise(
|
|
73
|
+
(resolve) => setTimeout(() => resolve(null), timeoutMs)
|
|
74
|
+
)
|
|
75
|
+
]);
|
|
76
|
+
return result;
|
|
77
|
+
} catch (_error) {
|
|
78
|
+
console.warn("[GasApi] Gas fees request timed out:", network);
|
|
79
|
+
return null;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Estimate gas with timeout
|
|
84
|
+
*
|
|
85
|
+
* @param params - Transaction parameters
|
|
86
|
+
* @param timeoutMs - Timeout in milliseconds (default: 5000)
|
|
87
|
+
* @returns Gas limit (hex string) or null if timeout/failed
|
|
88
|
+
*/
|
|
89
|
+
async estimateGasWithTimeout(params, timeoutMs = 5e3) {
|
|
90
|
+
try {
|
|
91
|
+
const result = await Promise.race([
|
|
92
|
+
this.estimateGas(params),
|
|
93
|
+
new Promise(
|
|
94
|
+
(resolve) => setTimeout(() => resolve(null), timeoutMs)
|
|
95
|
+
)
|
|
96
|
+
]);
|
|
97
|
+
return result;
|
|
98
|
+
} catch (_error) {
|
|
99
|
+
console.warn("[GasApi] Gas estimate request timed out");
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
export {
|
|
106
|
+
GasApi
|
|
107
|
+
};
|
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
createAbcWaasClient
|
|
4
|
+
} from "./chunk-JIJNCMJR.js";
|
|
5
|
+
import {
|
|
6
|
+
setGlobalDefaultBitcoinNetwork,
|
|
7
|
+
setGlobalDefaultChainId,
|
|
8
|
+
setGlobalDefaultSolanaNetwork
|
|
9
|
+
} from "./chunk-O4AU63LK.js";
|
|
10
|
+
import {
|
|
11
|
+
createAbcEvmProvider
|
|
12
|
+
} from "./chunk-4FKUVQCM.js";
|
|
13
|
+
import {
|
|
14
|
+
clearAuthState,
|
|
15
|
+
clearEncryptedTokens,
|
|
16
|
+
clearStorage,
|
|
17
|
+
loadAuthState,
|
|
18
|
+
loadFromStorage,
|
|
19
|
+
saveAuthState
|
|
20
|
+
} from "./chunk-LOSXI36Y.js";
|
|
21
|
+
|
|
22
|
+
// src/wallets/walletConnectors/abcWallet/abcConnector.ts
|
|
23
|
+
import { getTalkenApiClient } from "@talken/talkenkit";
|
|
24
|
+
import { createConnector } from "wagmi";
|
|
25
|
+
function abcConnector(options) {
|
|
26
|
+
const { config } = options;
|
|
27
|
+
if (config.defaultChainId) {
|
|
28
|
+
setGlobalDefaultChainId(config.defaultChainId);
|
|
29
|
+
}
|
|
30
|
+
if (config.defaultSolanaNetwork) {
|
|
31
|
+
setGlobalDefaultSolanaNetwork(config.defaultSolanaNetwork);
|
|
32
|
+
}
|
|
33
|
+
if (config.defaultBitcoinNetwork) {
|
|
34
|
+
setGlobalDefaultBitcoinNetwork(config.defaultBitcoinNetwork);
|
|
35
|
+
}
|
|
36
|
+
return createConnector((wagmiConfig) => {
|
|
37
|
+
const client = createAbcWaasClient(config);
|
|
38
|
+
const provider = createAbcEvmProvider(client);
|
|
39
|
+
let accountsChangedHandler;
|
|
40
|
+
let chainChangedHandler;
|
|
41
|
+
let disconnectHandler;
|
|
42
|
+
return {
|
|
43
|
+
id: "abc",
|
|
44
|
+
name: "ABC Wallet",
|
|
45
|
+
type: "abc",
|
|
46
|
+
/**
|
|
47
|
+
* Connect wallet
|
|
48
|
+
*/
|
|
49
|
+
async connect() {
|
|
50
|
+
try {
|
|
51
|
+
const authState = loadAuthState();
|
|
52
|
+
if (!authState || !authState.isAuthenticated || !authState.wallet) {
|
|
53
|
+
throw new Error("ABC_LOGIN_REQUIRED");
|
|
54
|
+
}
|
|
55
|
+
provider.setWallet(authState.wallet);
|
|
56
|
+
if (authState.accessToken && authState.refreshToken && authState.expiresAt) {
|
|
57
|
+
client.setTokens(
|
|
58
|
+
authState.accessToken,
|
|
59
|
+
authState.refreshToken,
|
|
60
|
+
authState.expiresAt
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
const accounts = await provider.request({
|
|
64
|
+
method: "eth_requestAccounts"
|
|
65
|
+
});
|
|
66
|
+
let currentChainId = await provider.request({
|
|
67
|
+
method: "eth_chainId"
|
|
68
|
+
});
|
|
69
|
+
const currentChainIdNumber = Number(currentChainId);
|
|
70
|
+
const isChainSupported = wagmiConfig.chains.some(
|
|
71
|
+
(c) => c.id === currentChainIdNumber
|
|
72
|
+
);
|
|
73
|
+
if (!isChainSupported && wagmiConfig.chains.length > 0) {
|
|
74
|
+
const fallbackChainId = wagmiConfig.chains[0].id;
|
|
75
|
+
await provider.request({
|
|
76
|
+
method: "wallet_switchEthereumChain",
|
|
77
|
+
params: [{ chainId: `0x${fallbackChainId.toString(16)}` }]
|
|
78
|
+
});
|
|
79
|
+
currentChainId = `0x${fallbackChainId.toString(16)}`;
|
|
80
|
+
if (authState.wallet) {
|
|
81
|
+
authState.wallet.chainId = fallbackChainId;
|
|
82
|
+
saveAuthState(authState);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (accountsChangedHandler) {
|
|
86
|
+
provider.removeListener("accountsChanged", accountsChangedHandler);
|
|
87
|
+
}
|
|
88
|
+
accountsChangedHandler = (accounts2) => {
|
|
89
|
+
wagmiConfig.emitter.emit("change", {
|
|
90
|
+
accounts: accounts2
|
|
91
|
+
});
|
|
92
|
+
};
|
|
93
|
+
provider.on("accountsChanged", accountsChangedHandler);
|
|
94
|
+
if (chainChangedHandler) {
|
|
95
|
+
provider.removeListener("chainChanged", chainChangedHandler);
|
|
96
|
+
}
|
|
97
|
+
chainChangedHandler = (chainId) => {
|
|
98
|
+
wagmiConfig.emitter.emit("change", {
|
|
99
|
+
chainId: Number(chainId)
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
provider.on("chainChanged", chainChangedHandler);
|
|
103
|
+
if (disconnectHandler) {
|
|
104
|
+
provider.removeListener("disconnect", disconnectHandler);
|
|
105
|
+
}
|
|
106
|
+
disconnectHandler = () => {
|
|
107
|
+
wagmiConfig.emitter.emit("disconnect");
|
|
108
|
+
this.onDisconnect();
|
|
109
|
+
};
|
|
110
|
+
provider.on("disconnect", disconnectHandler);
|
|
111
|
+
wagmiConfig.emitter.emit("connect", {
|
|
112
|
+
accounts,
|
|
113
|
+
chainId: Number(currentChainId)
|
|
114
|
+
});
|
|
115
|
+
return {
|
|
116
|
+
accounts,
|
|
117
|
+
chainId: Number(currentChainId)
|
|
118
|
+
};
|
|
119
|
+
} catch (error) {
|
|
120
|
+
console.error("\u274C ABC Connector connect() failed:", {
|
|
121
|
+
message: error.message,
|
|
122
|
+
code: error.code,
|
|
123
|
+
error
|
|
124
|
+
});
|
|
125
|
+
if (error.message === "ABC_LOGIN_REQUIRED") {
|
|
126
|
+
throw error;
|
|
127
|
+
}
|
|
128
|
+
throw error;
|
|
129
|
+
}
|
|
130
|
+
},
|
|
131
|
+
/**
|
|
132
|
+
* Disconnect wallet
|
|
133
|
+
*/
|
|
134
|
+
async disconnect() {
|
|
135
|
+
if (accountsChangedHandler) {
|
|
136
|
+
provider.removeListener("accountsChanged", accountsChangedHandler);
|
|
137
|
+
accountsChangedHandler = void 0;
|
|
138
|
+
}
|
|
139
|
+
if (chainChangedHandler) {
|
|
140
|
+
provider.removeListener("chainChanged", chainChangedHandler);
|
|
141
|
+
chainChangedHandler = void 0;
|
|
142
|
+
}
|
|
143
|
+
if (disconnectHandler) {
|
|
144
|
+
provider.removeListener("disconnect", disconnectHandler);
|
|
145
|
+
disconnectHandler = void 0;
|
|
146
|
+
}
|
|
147
|
+
provider.clearWallet();
|
|
148
|
+
await client.logout();
|
|
149
|
+
let savedPinHash = null;
|
|
150
|
+
let savedEmail = null;
|
|
151
|
+
if (typeof window !== "undefined") {
|
|
152
|
+
savedPinHash = localStorage.getItem("talkenkit_abc_pin_hash");
|
|
153
|
+
savedEmail = localStorage.getItem("talkenkit_abc_saved_email");
|
|
154
|
+
}
|
|
155
|
+
clearAuthState();
|
|
156
|
+
clearEncryptedTokens();
|
|
157
|
+
if (typeof window !== "undefined") {
|
|
158
|
+
localStorage.removeItem("talkenkit_abc_enc_salt");
|
|
159
|
+
localStorage.removeItem("talkenkit_abc_enc_tokens");
|
|
160
|
+
if (savedPinHash) {
|
|
161
|
+
localStorage.setItem("talkenkit_abc_pin_hash", savedPinHash);
|
|
162
|
+
}
|
|
163
|
+
if (savedEmail) {
|
|
164
|
+
localStorage.setItem("talkenkit_abc_saved_email", savedEmail);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
},
|
|
168
|
+
/**
|
|
169
|
+
* Get accounts
|
|
170
|
+
*/
|
|
171
|
+
async getAccounts() {
|
|
172
|
+
const accounts = await provider.request({
|
|
173
|
+
method: "eth_accounts"
|
|
174
|
+
});
|
|
175
|
+
return accounts.map((account) => account);
|
|
176
|
+
},
|
|
177
|
+
/**
|
|
178
|
+
* Get chain ID
|
|
179
|
+
*/
|
|
180
|
+
async getChainId() {
|
|
181
|
+
const chainId = await provider.request({
|
|
182
|
+
method: "eth_chainId"
|
|
183
|
+
});
|
|
184
|
+
return Number(chainId);
|
|
185
|
+
},
|
|
186
|
+
/**
|
|
187
|
+
* Get provider
|
|
188
|
+
*/
|
|
189
|
+
async getProvider() {
|
|
190
|
+
return provider;
|
|
191
|
+
},
|
|
192
|
+
/**
|
|
193
|
+
* Check if authorized (has valid session)
|
|
194
|
+
* Auto-refreshes access token if expired but refresh token is valid
|
|
195
|
+
*/
|
|
196
|
+
async isAuthorized() {
|
|
197
|
+
try {
|
|
198
|
+
const authState = loadAuthState();
|
|
199
|
+
if (!authState || !authState.isAuthenticated) {
|
|
200
|
+
return false;
|
|
201
|
+
}
|
|
202
|
+
if (!authState.wallet) {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
205
|
+
if (client.isAuthenticated()) {
|
|
206
|
+
return true;
|
|
207
|
+
}
|
|
208
|
+
const refreshToken = loadFromStorage(
|
|
209
|
+
"refresh_token" /* REFRESH_TOKEN */
|
|
210
|
+
);
|
|
211
|
+
if (!refreshToken) {
|
|
212
|
+
clearStorage();
|
|
213
|
+
return false;
|
|
214
|
+
}
|
|
215
|
+
try {
|
|
216
|
+
const api = getTalkenApiClient();
|
|
217
|
+
if (!api) {
|
|
218
|
+
clearStorage();
|
|
219
|
+
return false;
|
|
220
|
+
}
|
|
221
|
+
const res = await api.auth.refresh();
|
|
222
|
+
client.setTokens(
|
|
223
|
+
res.accessToken,
|
|
224
|
+
res.refreshToken,
|
|
225
|
+
Date.now() + res.expiresIn * 1e3
|
|
226
|
+
);
|
|
227
|
+
const updatedState = loadAuthState();
|
|
228
|
+
return updatedState?.isAuthenticated ?? false;
|
|
229
|
+
} catch (error) {
|
|
230
|
+
console.error("[AbcConnector] Token refresh failed:", error);
|
|
231
|
+
clearStorage();
|
|
232
|
+
return false;
|
|
233
|
+
}
|
|
234
|
+
} catch (error) {
|
|
235
|
+
console.error(
|
|
236
|
+
"[AbcConnector] Unexpected error in isAuthorized:",
|
|
237
|
+
error
|
|
238
|
+
);
|
|
239
|
+
return false;
|
|
240
|
+
}
|
|
241
|
+
},
|
|
242
|
+
/**
|
|
243
|
+
* Switch chain
|
|
244
|
+
*/
|
|
245
|
+
async switchChain({ chainId }) {
|
|
246
|
+
await provider.request({
|
|
247
|
+
method: "wallet_switchEthereumChain",
|
|
248
|
+
params: [{ chainId: `0x${chainId.toString(16)}` }]
|
|
249
|
+
});
|
|
250
|
+
const newChainId = await this.getChainId();
|
|
251
|
+
const authState = loadAuthState();
|
|
252
|
+
if (authState?.wallet) {
|
|
253
|
+
authState.wallet.chainId = newChainId;
|
|
254
|
+
saveAuthState(authState);
|
|
255
|
+
}
|
|
256
|
+
return wagmiConfig.chains.find((x) => x.id === chainId) ?? {
|
|
257
|
+
id: chainId,
|
|
258
|
+
name: `Chain ${chainId}`,
|
|
259
|
+
nativeCurrency: {
|
|
260
|
+
name: "Ether",
|
|
261
|
+
decimals: 18,
|
|
262
|
+
symbol: "ETH"
|
|
263
|
+
},
|
|
264
|
+
rpcUrls: {
|
|
265
|
+
default: { http: [""] }
|
|
266
|
+
}
|
|
267
|
+
};
|
|
268
|
+
},
|
|
269
|
+
/**
|
|
270
|
+
* Handle accounts changed
|
|
271
|
+
*/
|
|
272
|
+
onAccountsChanged(accounts) {
|
|
273
|
+
if (accounts.length === 0) {
|
|
274
|
+
this.onDisconnect();
|
|
275
|
+
} else {
|
|
276
|
+
wagmiConfig.emitter.emit("change", {
|
|
277
|
+
accounts
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
},
|
|
281
|
+
/**
|
|
282
|
+
* Handle chain changed
|
|
283
|
+
*/
|
|
284
|
+
onChainChanged(chain) {
|
|
285
|
+
const chainId = Number(chain);
|
|
286
|
+
wagmiConfig.emitter.emit("change", { chainId });
|
|
287
|
+
},
|
|
288
|
+
/**
|
|
289
|
+
* Handle disconnect
|
|
290
|
+
*/
|
|
291
|
+
onDisconnect(_error) {
|
|
292
|
+
provider.clearWallet();
|
|
293
|
+
clearAuthState();
|
|
294
|
+
wagmiConfig.emitter.emit("disconnect");
|
|
295
|
+
}
|
|
296
|
+
};
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
export {
|
|
301
|
+
abcConnector
|
|
302
|
+
};
|