@swapkit/wallets 4.0.0-beta.54 → 4.0.0-beta.56

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (294) hide show
  1. package/dist/{chunk-e674mh4n.js → chunk-mcrgqfr9.js} +3 -3
  2. package/dist/{chunk-e674mh4n.js.map → chunk-mcrgqfr9.js.map} +1 -1
  3. package/dist/{chunk-mvbb9fwb.js → chunk-sbf0f2p4.js} +2 -2
  4. package/dist/{chunk-p2ca0j1v.js → chunk-yqaz2d25.js} +3 -3
  5. package/dist/{chunk-p2ca0j1v.js.map → chunk-yqaz2d25.js.map} +1 -1
  6. package/dist/src/bitget/index.cjs +2 -2
  7. package/dist/src/bitget/index.cjs.map +3 -3
  8. package/dist/src/bitget/index.js +2 -2
  9. package/dist/src/bitget/index.js.map +3 -3
  10. package/dist/src/coinbase/index.cjs +2 -2
  11. package/dist/src/coinbase/index.cjs.map +3 -3
  12. package/dist/src/coinbase/index.js +2 -2
  13. package/dist/src/coinbase/index.js.map +3 -3
  14. package/dist/src/cosmostation/index.cjs +2 -2
  15. package/dist/src/cosmostation/index.cjs.map +3 -3
  16. package/dist/src/cosmostation/index.js +2 -2
  17. package/dist/src/cosmostation/index.js.map +3 -3
  18. package/dist/src/ctrl/index.cjs +2 -2
  19. package/dist/src/ctrl/index.cjs.map +3 -3
  20. package/dist/src/ctrl/index.js +2 -2
  21. package/dist/src/ctrl/index.js.map +3 -3
  22. package/dist/src/evm-extensions/index.cjs +2 -2
  23. package/dist/src/evm-extensions/index.cjs.map +3 -3
  24. package/dist/src/evm-extensions/index.js +2 -2
  25. package/dist/src/evm-extensions/index.js.map +3 -3
  26. package/dist/src/exodus/index.cjs +2 -2
  27. package/dist/src/exodus/index.cjs.map +3 -3
  28. package/dist/src/exodus/index.js +2 -2
  29. package/dist/src/exodus/index.js.map +3 -3
  30. package/dist/src/index.cjs +2 -2
  31. package/dist/src/index.cjs.map +5 -3
  32. package/dist/src/index.js +2 -2
  33. package/dist/src/index.js.map +5 -3
  34. package/dist/src/keepkey-bex/index.cjs +2 -2
  35. package/dist/src/keepkey-bex/index.cjs.map +3 -3
  36. package/dist/src/keepkey-bex/index.js +2 -2
  37. package/dist/src/keepkey-bex/index.js.map +3 -3
  38. package/dist/src/keepkey.cjs +4 -0
  39. package/dist/src/keepkey.cjs.map +10 -0
  40. package/dist/src/keepkey.js +4 -0
  41. package/dist/src/keepkey.js.map +10 -0
  42. package/dist/src/keplr/index.cjs +2 -2
  43. package/dist/src/keplr/index.cjs.map +3 -3
  44. package/dist/src/keplr/index.js +2 -2
  45. package/dist/src/keplr/index.js.map +3 -3
  46. package/dist/src/keystore.cjs +4 -0
  47. package/dist/src/keystore.cjs.map +10 -0
  48. package/dist/src/keystore.js +4 -0
  49. package/dist/src/keystore.js.map +10 -0
  50. package/dist/src/ledger.cjs +4 -0
  51. package/dist/src/ledger.cjs.map +10 -0
  52. package/dist/src/ledger.js +4 -0
  53. package/dist/src/ledger.js.map +10 -0
  54. package/dist/src/okx/index.cjs +2 -2
  55. package/dist/src/okx/index.cjs.map +4 -4
  56. package/dist/src/okx/index.js +2 -2
  57. package/dist/src/okx/index.js.map +4 -4
  58. package/dist/src/onekey/index.cjs +2 -2
  59. package/dist/src/onekey/index.cjs.map +3 -3
  60. package/dist/src/onekey/index.js +2 -2
  61. package/dist/src/onekey/index.js.map +3 -3
  62. package/dist/src/phantom/index.cjs +2 -2
  63. package/dist/src/phantom/index.cjs.map +3 -3
  64. package/dist/src/phantom/index.js +2 -2
  65. package/dist/src/phantom/index.js.map +3 -3
  66. package/dist/src/polkadotjs/index.cjs +2 -2
  67. package/dist/src/polkadotjs/index.cjs.map +3 -3
  68. package/dist/src/polkadotjs/index.js +2 -2
  69. package/dist/src/polkadotjs/index.js.map +3 -3
  70. package/dist/src/radix/index.cjs +2 -2
  71. package/dist/src/radix/index.cjs.map +3 -3
  72. package/dist/src/radix/index.js +2 -2
  73. package/dist/src/radix/index.js.map +3 -3
  74. package/dist/src/talisman/index.cjs +2 -2
  75. package/dist/src/talisman/index.cjs.map +3 -3
  76. package/dist/src/talisman/index.js +2 -2
  77. package/dist/src/talisman/index.js.map +3 -3
  78. package/dist/src/trezor.cjs +4 -0
  79. package/dist/src/trezor.cjs.map +10 -0
  80. package/dist/src/trezor.js +4 -0
  81. package/dist/src/trezor.js.map +10 -0
  82. package/dist/src/tronlink/index.cjs +4 -0
  83. package/dist/src/tronlink/index.cjs.map +11 -0
  84. package/dist/src/tronlink/index.js +4 -0
  85. package/dist/src/tronlink/index.js.map +11 -0
  86. package/dist/src/vultisig/index.cjs +2 -2
  87. package/dist/src/vultisig/index.cjs.map +3 -3
  88. package/dist/src/vultisig/index.js +2 -2
  89. package/dist/src/vultisig/index.js.map +3 -3
  90. package/dist/src/walletconnect/index.cjs +2 -2
  91. package/dist/src/walletconnect/index.cjs.map +3 -3
  92. package/dist/src/walletconnect/index.js +2 -2
  93. package/dist/src/walletconnect/index.js.map +3 -3
  94. package/dist/src/xaman/index.cjs +2 -2
  95. package/dist/src/xaman/index.cjs.map +5 -5
  96. package/dist/src/xaman/index.js +2 -2
  97. package/dist/src/xaman/index.js.map +5 -5
  98. package/dist/types/bitget/helpers.d.ts +330 -0
  99. package/dist/types/bitget/helpers.d.ts.map +1 -0
  100. package/dist/types/bitget/index.d.ts +11 -0
  101. package/dist/types/bitget/index.d.ts.map +1 -0
  102. package/dist/types/coinbase/index.d.ts +11 -0
  103. package/dist/types/coinbase/index.d.ts.map +1 -0
  104. package/dist/types/coinbase/signer.d.ts +91 -0
  105. package/dist/types/coinbase/signer.d.ts.map +1 -0
  106. package/dist/types/cosmostation/index.d.ts +21 -0
  107. package/dist/types/cosmostation/index.d.ts.map +1 -0
  108. package/dist/types/ctrl/index.d.ts +11 -0
  109. package/dist/types/ctrl/index.d.ts.map +1 -0
  110. package/dist/types/ctrl/walletHelpers.d.ts +24 -0
  111. package/dist/types/ctrl/walletHelpers.d.ts.map +1 -0
  112. package/dist/types/evm-extensions/index.d.ts +101 -0
  113. package/dist/types/evm-extensions/index.d.ts.map +1 -0
  114. package/{src/evm-extensions/types.ts → dist/types/evm-extensions/types.d.ts} +11 -13
  115. package/dist/types/evm-extensions/types.d.ts.map +1 -0
  116. package/dist/types/exodus/index.d.ts +14 -0
  117. package/dist/types/exodus/index.d.ts.map +1 -0
  118. package/dist/types/helpers/near.d.ts +57 -0
  119. package/dist/types/helpers/near.d.ts.map +1 -0
  120. package/dist/types/index.d.ts +4 -0
  121. package/dist/types/index.d.ts.map +1 -0
  122. package/dist/types/keepkey-bex/index.d.ts +11 -0
  123. package/dist/types/keepkey-bex/index.d.ts.map +1 -0
  124. package/dist/types/keepkey-bex/walletHelpers.d.ts +45 -0
  125. package/dist/types/keepkey-bex/walletHelpers.d.ts.map +1 -0
  126. package/dist/types/keepkey.d.ts +2 -0
  127. package/dist/types/keepkey.d.ts.map +1 -0
  128. package/dist/types/keplr/chainRegistry.d.ts +4 -0
  129. package/dist/types/keplr/chainRegistry.d.ts.map +1 -0
  130. package/dist/types/keplr/index.d.ts +11 -0
  131. package/dist/types/keplr/index.d.ts.map +1 -0
  132. package/dist/types/keystore.d.ts +2 -0
  133. package/dist/types/keystore.d.ts.map +1 -0
  134. package/dist/types/ledger.d.ts +2 -0
  135. package/dist/types/ledger.d.ts.map +1 -0
  136. package/dist/types/okx/helpers.d.ts +227 -0
  137. package/dist/types/okx/helpers.d.ts.map +1 -0
  138. package/dist/types/okx/index.d.ts +11 -0
  139. package/dist/types/okx/index.d.ts.map +1 -0
  140. package/dist/types/okx/types.d.ts +104 -0
  141. package/dist/types/okx/types.d.ts.map +1 -0
  142. package/dist/types/onekey/evmSigner.d.ts +29 -0
  143. package/dist/types/onekey/evmSigner.d.ts.map +1 -0
  144. package/dist/types/onekey/index.d.ts +11 -0
  145. package/dist/types/onekey/index.d.ts.map +1 -0
  146. package/dist/types/phantom/index.d.ts +12 -0
  147. package/dist/types/phantom/index.d.ts.map +1 -0
  148. package/dist/types/polkadotjs/index.d.ts +11 -0
  149. package/dist/types/polkadotjs/index.d.ts.map +1 -0
  150. package/dist/types/radix/index.d.ts +11 -0
  151. package/dist/types/radix/index.d.ts.map +1 -0
  152. package/dist/types/talisman/index.d.ts +11 -0
  153. package/dist/types/talisman/index.d.ts.map +1 -0
  154. package/dist/types/trezor.d.ts +2 -0
  155. package/dist/types/trezor.d.ts.map +1 -0
  156. package/dist/types/tronlink/helpers.d.ts +24 -0
  157. package/dist/types/tronlink/helpers.d.ts.map +1 -0
  158. package/dist/types/tronlink/index.d.ts +11 -0
  159. package/dist/types/tronlink/index.d.ts.map +1 -0
  160. package/dist/types/tronlink/types.d.ts +59 -0
  161. package/dist/types/tronlink/types.d.ts.map +1 -0
  162. package/dist/types/types.d.ts +249 -0
  163. package/dist/types/types.d.ts.map +1 -0
  164. package/dist/types/utils.d.ts +4 -0
  165. package/dist/types/utils.d.ts.map +1 -0
  166. package/dist/types/vultisig/index.d.ts +11 -0
  167. package/dist/types/vultisig/index.d.ts.map +1 -0
  168. package/dist/types/vultisig/walletHelpers.d.ts +34 -0
  169. package/dist/types/vultisig/walletHelpers.d.ts.map +1 -0
  170. package/dist/types/walletconnect/constants.d.ts +85 -0
  171. package/dist/types/walletconnect/constants.d.ts.map +1 -0
  172. package/dist/types/walletconnect/evmSigner.d.ts +25 -0
  173. package/dist/types/walletconnect/evmSigner.d.ts.map +1 -0
  174. package/dist/types/walletconnect/helpers.d.ts +4 -0
  175. package/dist/types/walletconnect/helpers.d.ts.map +1 -0
  176. package/dist/types/walletconnect/index.d.ts +22 -0
  177. package/dist/types/walletconnect/index.d.ts.map +1 -0
  178. package/dist/types/walletconnect/namespaces.d.ts +7 -0
  179. package/dist/types/walletconnect/namespaces.d.ts.map +1 -0
  180. package/dist/types/walletconnect/types.d.ts +7 -0
  181. package/dist/types/walletconnect/types.d.ts.map +1 -0
  182. package/dist/types/xaman/helpers.d.ts +54 -0
  183. package/dist/types/xaman/helpers.d.ts.map +1 -0
  184. package/dist/types/xaman/index.d.ts +14 -0
  185. package/dist/types/xaman/index.d.ts.map +1 -0
  186. package/dist/types/xaman/types.d.ts +24 -0
  187. package/dist/types/xaman/types.d.ts.map +1 -0
  188. package/dist/types/xaman/walletMethods.d.ts +16 -0
  189. package/dist/types/xaman/walletMethods.d.ts.map +1 -0
  190. package/package.json +53 -74
  191. package/dist/chunk-2aa1w78q.js +0 -4
  192. package/dist/chunk-2aa1w78q.js.map +0 -10
  193. package/dist/chunk-31bmhjxx.js +0 -4
  194. package/dist/chunk-31bmhjxx.js.map +0 -10
  195. package/dist/chunk-3etn0w20.js +0 -4
  196. package/dist/chunk-3etn0w20.js.map +0 -10
  197. package/dist/chunk-bk58smyr.js +0 -4
  198. package/dist/chunk-bk58smyr.js.map +0 -10
  199. package/dist/chunk-etm8zfkk.js +0 -4
  200. package/dist/chunk-etm8zfkk.js.map +0 -10
  201. package/dist/chunk-h7myvxxm.js +0 -5
  202. package/dist/chunk-h7myvxxm.js.map +0 -10
  203. package/dist/chunk-htvthkj1.js +0 -5
  204. package/dist/chunk-htvthkj1.js.map +0 -10
  205. package/dist/chunk-nfas79hz.js +0 -4
  206. package/dist/chunk-nfas79hz.js.map +0 -10
  207. package/dist/src/keepkey/index.cjs +0 -4
  208. package/dist/src/keepkey/index.cjs.map +0 -15
  209. package/dist/src/keepkey/index.js +0 -4
  210. package/dist/src/keepkey/index.js.map +0 -15
  211. package/dist/src/keystore/index.cjs +0 -4
  212. package/dist/src/keystore/index.cjs.map +0 -11
  213. package/dist/src/keystore/index.js +0 -4
  214. package/dist/src/keystore/index.js.map +0 -11
  215. package/dist/src/ledger/index.cjs +0 -5
  216. package/dist/src/ledger/index.cjs.map +0 -25
  217. package/dist/src/ledger/index.js +0 -5
  218. package/dist/src/ledger/index.js.map +0 -25
  219. package/dist/src/trezor/index.cjs +0 -4
  220. package/dist/src/trezor/index.cjs.map +0 -10
  221. package/dist/src/trezor/index.js +0 -4
  222. package/dist/src/trezor/index.js.map +0 -10
  223. package/src/bitget/helpers.ts +0 -167
  224. package/src/bitget/index.ts +0 -34
  225. package/src/coinbase/index.ts +0 -52
  226. package/src/coinbase/signer.ts +0 -83
  227. package/src/cosmostation/index.ts +0 -142
  228. package/src/ctrl/index.ts +0 -248
  229. package/src/ctrl/walletHelpers.ts +0 -297
  230. package/src/evm-extensions/index.ts +0 -134
  231. package/src/exodus/index.ts +0 -179
  232. package/src/helpers/near-browser-provider.d.ts +0 -286
  233. package/src/helpers/near.ts +0 -206
  234. package/src/index.ts +0 -2
  235. package/src/keepkey/chains/cosmos.ts +0 -78
  236. package/src/keepkey/chains/evm.ts +0 -125
  237. package/src/keepkey/chains/mayachain.ts +0 -123
  238. package/src/keepkey/chains/ripple.ts +0 -118
  239. package/src/keepkey/chains/thorchain.ts +0 -118
  240. package/src/keepkey/chains/utxo.ts +0 -147
  241. package/src/keepkey/coins.ts +0 -71
  242. package/src/keepkey/index.ts +0 -153
  243. package/src/keepkey-bex/index.ts +0 -162
  244. package/src/keepkey-bex/walletHelpers.ts +0 -255
  245. package/src/keplr/chainRegistry.ts +0 -211
  246. package/src/keplr/index.ts +0 -55
  247. package/src/keystore/helpers.ts +0 -102
  248. package/src/keystore/index.ts +0 -73
  249. package/src/ledger/clients/cosmos.ts +0 -102
  250. package/src/ledger/clients/evm.ts +0 -183
  251. package/src/ledger/clients/near.ts +0 -86
  252. package/src/ledger/clients/thorchain/common.ts +0 -117
  253. package/src/ledger/clients/thorchain/helpers.ts +0 -149
  254. package/src/ledger/clients/thorchain/index.ts +0 -94
  255. package/src/ledger/clients/thorchain/lib.ts +0 -300
  256. package/src/ledger/clients/thorchain/utils.ts +0 -76
  257. package/src/ledger/clients/tron.ts +0 -92
  258. package/src/ledger/clients/utxo.ts +0 -148
  259. package/src/ledger/clients/xrp.ts +0 -66
  260. package/src/ledger/cosmosTypes.ts +0 -101
  261. package/src/ledger/helpers/getLedgerAddress.ts +0 -67
  262. package/src/ledger/helpers/getLedgerClient.ts +0 -124
  263. package/src/ledger/helpers/getLedgerTransport.ts +0 -80
  264. package/src/ledger/helpers/index.ts +0 -3
  265. package/src/ledger/index.ts +0 -311
  266. package/src/ledger/interfaces/CosmosLedgerInterface.ts +0 -65
  267. package/src/ledger/types.ts +0 -45
  268. package/src/okx/helpers.ts +0 -181
  269. package/src/okx/index.ts +0 -43
  270. package/src/okx/types.ts +0 -117
  271. package/src/onekey/evmSigner.ts +0 -133
  272. package/src/onekey/index.ts +0 -213
  273. package/src/phantom/index.ts +0 -126
  274. package/src/polkadotjs/index.ts +0 -67
  275. package/src/radix/index.ts +0 -202
  276. package/src/talisman/index.ts +0 -130
  277. package/src/trezor/evmSigner.ts +0 -197
  278. package/src/trezor/index.ts +0 -260
  279. package/src/types.ts +0 -280
  280. package/src/utils.ts +0 -60
  281. package/src/vultisig/index.ts +0 -199
  282. package/src/vultisig/walletHelpers.ts +0 -359
  283. package/src/walletconnect/constants.ts +0 -104
  284. package/src/walletconnect/evmSigner.ts +0 -147
  285. package/src/walletconnect/helpers.ts +0 -77
  286. package/src/walletconnect/index.ts +0 -460
  287. package/src/walletconnect/namespaces.ts +0 -87
  288. package/src/walletconnect/types.ts +0 -6
  289. package/src/xaman/README.md +0 -66
  290. package/src/xaman/helpers.ts +0 -59
  291. package/src/xaman/index.ts +0 -79
  292. package/src/xaman/types.ts +0 -26
  293. package/src/xaman/walletMethods.ts +0 -126
  294. /package/dist/{chunk-mvbb9fwb.js.map → chunk-sbf0f2p4.js.map} +0 -0
@@ -1,4 +1,4 @@
1
- import{H as b}from"../../chunk-htvthkj1.js";import{J as B,K as H}from"../../chunk-p2ca0j1v.js";import{Chain as D,SwapKitError as M,UTXOChains as C,WalletOption as f,createWallet as p,filterSupportedChains as d}from"@swapkit/helpers";import{Chain as G,ChainToChainId as A,EVMChains as T,SwapKitError as _,WalletOption as S,providerRequest as g}from"@swapkit/helpers";import{erc20ABI as v}from"@swapkit/helpers/contracts";async function I(z){if(!window.vultisig)throw new _("wallet_vultisig_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(...T,()=>window.vultisig?.ethereum).with(G.Cosmos,G.Kujira,()=>window.vultisig?.cosmos).with(G.Bitcoin,()=>window.vultisig?.bitcoin).with(G.BitcoinCash,()=>window.vultisig?.bitcoincash).with(G.Dash,()=>window.vultisig?.dash).with(G.Dogecoin,()=>window.vultisig?.dogecoin).with(G.Litecoin,()=>window.vultisig?.litecoin).with(G.Solana,()=>window.vultisig?.solana).with(G.THORChain,()=>window.vultisig?.thorchain).with(G.Maya,()=>window.vultisig?.mayachain).with(G.Polkadot,()=>window.vultisig?.polkadot).with(G.Ripple,()=>window.vultisig?.ripple).with(G.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function w({method:z,params:Z,chain:J}){let F=await I(J),$=Z;if(J===G.Cosmos||J===G.Kujira||J===G.Ripple)$=Z.map((Q)=>({from:Q.from,to:Q.to,value:Q.amount.amount.toString(),data:Q.data}));return new Promise((Q,Y)=>{if(F&&"request"in F)F.request({method:z,params:$},(q,U)=>{q?Y(q):Q(U)})})}async function j(z){try{let Z=await I(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:S.VULTISIG,chain:z}});if([G.Cosmos,G.Kujira].includes(z)){let F=await I(G.Cosmos),$=A[z];await F.request({method:"wallet_switch_chain",params:[{chainId:$}]});let Q=await F.request({method:"get_accounts"});if(!Q)Q=(await F.request({method:"request_accounts"}))[0].address;return Q}if(T.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:F}=await import("ethers"),$=new F(Z,"any"),[Q]=await g({provider:$,method:"eth_requestAccounts",params:[]});return Q}if(z===G.Solana)return(await(await I(G.Solana)).connect()).publicKey.toString();return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:S.VULTISIG,chain:z}})}}async function y({assetValue:z,recipient:Z,memo:J,gasLimit:F},$="send_transaction"){if(!z)throw new _("wallet_vultisig_asset_not_defined");let Q=await j(z.chain),Y=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},data:J||"",from:Q,to:Z,gasLimit:F}];return w({method:$,params:Y,chain:z.chain})}function P(z,Z){return{call:async({contractAddress:J,abi:F,funcName:$,funcParams:Q=[],txOverrides:Y})=>{if(!J)throw new _("wallet_vultisig_contract_address_not_provided");let{createContract:q,getCreateContractTxObject:U,isStateChangingCall:X}=await import("@swapkit/toolboxes/evm");if(X({abi:F,funcName:$})){let K=U({provider:z,chain:Z}),{value:W,from:N,to:k,data:x}=await K({contractAddress:J,abi:F,funcName:$,funcParams:Q,txOverrides:Y});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:N,to:k,data:x||"0x"})).hash}let O=await q(J,F,z)[$]?.(...Q);return typeof O?.hash==="string"?O?.hash:O},approve:async({assetAddress:J,spenderAddress:F,amount:$,from:Q})=>{let{MAX_APPROVAL:Y,getCreateContractTxObject:q}=await import("@swapkit/toolboxes/evm"),U=[F,BigInt($||Y)],R={contractAddress:J,abi:v,funcName:"approve",funcParams:U,txOverrides:{from:Q}},L=q({provider:z,chain:Z}),{value:O,to:K,data:W}=await L(R);return(await(await z.getSigner()).sendTransaction({value:BigInt(O||0),from:Q,to:K,data:W||"0x"})).hash},sendTransaction:async(J)=>{let{from:F,to:$,data:Q,value:Y}=J;if(!$)throw new _("wallet_vultisig_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(Y||0),from:F,to:$,data:Q||"0x"})).hash}}}async function u(z,Z,J){try{await z.request({method:"wallet_switch_chain",params:[{chainId:A[Z]}]})}catch(F){if(!J)throw new _("helpers_failed_to_switch_network",{error:F,reason:"networkParams not provided"})}}function m(z,Z,J){return async(...F)=>{try{await u(Z,J)}catch($){throw new _({errorKey:"helpers_failed_to_switch_network",info:{error:$}})}return z(...F)}}function V({toolbox:z,chain:Z,provider:J=window.ethereum,methodNames:F=[]}){let Q=[...F,"transfer","getAddress","getBalance"].reduce((Y,q)=>{if(!z[q])return Y;let U=z[q];if(typeof U!=="function")return Y;let X=m(U,J,Z);return{...Y,[q]:X}},{});return{...z,...Q}}var l=p({name:"connectVultisig",walletType:f.VULTISIG,supportedChains:[D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Bitcoin,D.BitcoinCash,D.Cosmos,D.Dash,D.Dogecoin,D.Ethereum,D.Kujira,D.Litecoin,D.Maya,D.Optimism,D.Polkadot,D.Polygon,D.Ripple,D.Solana,D.THORChain,D.Zcash],connect:({addChain:z,walletType:Z,supportedChains:J})=>async function F($){let Q=d({chains:$,supportedChains:J,walletType:Z}),Y=Q.filter((X)=>X!==D.Cosmos&&X!==D.Kujira).map(async(X)=>{let R=await j(X),L=await E(X);z({...L,address:R,chain:X,walletType:Z})}),q=Q.includes(D.Cosmos),U=Q.includes(D.Kujira);if(q){let X=await j(D.Cosmos),R=await E(D.Cosmos);z({...R,address:X,chain:D.Cosmos,walletType:Z})}if(U){let X=await j(D.Kujira),R=await E(D.Kujira);z({...R,address:X,chain:D.Kujira,walletType:Z})}return await Promise.all(Y),!0}}),e=b(l);async function E(z){let{match:Z}=await import("ts-pattern");return Z(z).with(D.Solana,async()=>{let{getSolanaToolbox:J}=await import("@swapkit/toolboxes/solana"),F=window.vultisig?.solana;if(!F)throw new M("wallet_vultisig_not_found");return{...await J({signer:F})}}).with(D.Maya,D.THORChain,async()=>{let{getCosmosToolbox:J,THORCHAIN_GAS_VALUE:F,MAYA_GAS_VALUE:$}=await import("@swapkit/toolboxes/cosmos"),Q=z===D.Maya?$:F;return{...await J(z),deposit:(q)=>y({...q,recipient:""},"deposit_transaction"),transfer:(q)=>y({...q,gasLimit:Q},"send_transaction")}}).with(D.Cosmos,D.Kujira,async()=>{let{getCosmosToolbox:J}=await import("@swapkit/toolboxes/cosmos"),F=await I(z),$=await J(z);return V({provider:F,chain:z,toolbox:{...$,transfer:y}})}).with(...C,async()=>{let{getUtxoToolbox:J}=await import("@swapkit/toolboxes/utxo");return{...await J(z),transfer:y}}).with(D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Ethereum,D.Optimism,D.Polygon,async()=>{let{prepareNetworkSwitch:J,switchEVMWalletNetwork:F}=await import("@swapkit/helpers"),{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Q}=await import("ethers"),Y=await I(z);if(!Y)throw new M("wallet_vultisig_not_found");let q=new Q(Y,"any"),U=await q.getSigner(),X=await $(z,{provider:q,signer:U}),R=P(q,z);try{if(z!==D.Ethereum){let L=X.getNetworkParams();await F(q,z,L)}}catch(L){throw new M({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:f.VULTISIG,chain:z}})}return J({provider:q,chain:z,toolbox:{...X,...R}})}).with(D.Ripple,async()=>{let{getRippleToolbox:J}=await import("@swapkit/toolboxes/ripple");return{...await J(),transfer:y}}).with(D.Polkadot,async()=>{let{getSubstrateToolbox:J}=await import("@swapkit/toolboxes/substrate");return{...await J(z),transfer:y}}).otherwise(async()=>null)}export{l as vultisigWallet,e as VULTISIG_SUPPORTED_CHAINS};
1
+ import{F as B,G as H}from"../../chunk-yqaz2d25.js";import{Chain as D,SwapKitError as M,UTXOChains as m,WalletOption as f,filterSupportedChains as C}from"@swapkit/helpers";import{createWallet as p,getWalletSupportedChains as d}from"@swapkit/wallet-core";import{Chain as G,ChainToChainId as A,EVMChains as T,SwapKitError as _,WalletOption as k,providerRequest as x}from"@swapkit/helpers";import{erc20ABI as g}from"@swapkit/helpers/contracts";async function I(z){if(!window.vultisig)throw new _("wallet_vultisig_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(...T,()=>window.vultisig?.ethereum).with(G.Cosmos,G.Kujira,()=>window.vultisig?.cosmos).with(G.Bitcoin,()=>window.vultisig?.bitcoin).with(G.BitcoinCash,()=>window.vultisig?.bitcoincash).with(G.Dash,()=>window.vultisig?.dash).with(G.Dogecoin,()=>window.vultisig?.dogecoin).with(G.Litecoin,()=>window.vultisig?.litecoin).with(G.Solana,()=>window.vultisig?.solana).with(G.THORChain,()=>window.vultisig?.thorchain).with(G.Maya,()=>window.vultisig?.mayachain).with(G.Polkadot,()=>window.vultisig?.polkadot).with(G.Ripple,()=>window.vultisig?.ripple).with(G.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function v({method:z,params:Z,chain:J}){let F=await I(J),$=Z;if(J===G.Cosmos||J===G.Kujira||J===G.Ripple)$=Z.map((Q)=>({from:Q.from,to:Q.to,value:Q.amount.amount.toString(),data:Q.data}));return new Promise((Q,Y)=>{if(F&&"request"in F)F.request({method:z,params:$},(q,U)=>{q?Y(q):Q(U)})})}async function j(z){try{let Z=await I(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:k.VULTISIG,chain:z}});if([G.Cosmos,G.Kujira].includes(z)){let F=await I(G.Cosmos),$=A[z];await F.request({method:"wallet_switch_chain",params:[{chainId:$}]});let Q=await F.request({method:"get_accounts"});if(!Q)Q=(await F.request({method:"request_accounts"}))[0].address;return Q}if(T.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:F}=await import("ethers"),$=new F(Z,"any"),[Q]=await x({provider:$,method:"eth_requestAccounts",params:[]});return Q}if(z===G.Solana)return(await(await I(G.Solana)).connect()).publicKey.toString();return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:k.VULTISIG,chain:z}})}}async function y({assetValue:z,recipient:Z,memo:J,gasLimit:F},$="send_transaction"){if(!z)throw new _("wallet_vultisig_asset_not_defined");let Q=await j(z.chain),Y=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},data:J||"",from:Q,to:Z,gasLimit:F}];return v({method:$,params:Y,chain:z.chain})}function P(z,Z){return{call:async({contractAddress:J,abi:F,funcName:$,funcParams:Q=[],txOverrides:Y})=>{if(!J)throw new _("wallet_vultisig_contract_address_not_provided");let{createContract:q,getCreateContractTxObject:U,isStateChangingCall:X}=await import("@swapkit/toolboxes/evm");if(X({abi:F,funcName:$})){let K=U({provider:z,chain:Z}),{value:W,from:N,to:S,data:b}=await K({contractAddress:J,abi:F,funcName:$,funcParams:Q,txOverrides:Y});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:N,to:S,data:b||"0x"})).hash}let O=await q(J,F,z)[$]?.(...Q);return typeof O?.hash==="string"?O?.hash:O},approve:async({assetAddress:J,spenderAddress:F,amount:$,from:Q})=>{let{MAX_APPROVAL:Y,getCreateContractTxObject:q}=await import("@swapkit/toolboxes/evm"),U=[F,BigInt($||Y)],R={contractAddress:J,abi:g,funcName:"approve",funcParams:U,txOverrides:{from:Q}},L=q({provider:z,chain:Z}),{value:O,to:K,data:W}=await L(R);return(await(await z.getSigner()).sendTransaction({value:BigInt(O||0),from:Q,to:K,data:W||"0x"})).hash},sendTransaction:async(J)=>{let{from:F,to:$,data:Q,value:Y}=J;if(!$)throw new _("wallet_vultisig_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(Y||0),from:F,to:$,data:Q||"0x"})).hash}}}async function w(z,Z,J){try{await z.request({method:"wallet_switch_chain",params:[{chainId:A[Z]}]})}catch(F){if(!J)throw new _("helpers_failed_to_switch_network",{error:F,reason:"networkParams not provided"})}}function u(z,Z,J){return async(...F)=>{try{await w(Z,J)}catch($){throw new _({errorKey:"helpers_failed_to_switch_network",info:{error:$}})}return z(...F)}}function V({toolbox:z,chain:Z,provider:J=window.ethereum,methodNames:F=[]}){let Q=[...F,"transfer","getAddress","getBalance"].reduce((Y,q)=>{if(!z[q])return Y;let U=z[q];if(typeof U!=="function")return Y;let X=u(U,J,Z);return{...Y,[q]:X}},{});return{...z,...Q}}var l=p({name:"connectVultisig",walletType:f.VULTISIG,supportedChains:[D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Bitcoin,D.BitcoinCash,D.Cosmos,D.Dash,D.Dogecoin,D.Ethereum,D.Kujira,D.Litecoin,D.Maya,D.Optimism,D.Polkadot,D.Polygon,D.Ripple,D.Solana,D.THORChain,D.Zcash],connect:({addChain:z,walletType:Z,supportedChains:J})=>async function F($){let Q=C({chains:$,supportedChains:J,walletType:Z}),Y=Q.filter((X)=>X!==D.Cosmos&&X!==D.Kujira).map(async(X)=>{let R=await j(X),L=await E(X);z({...L,address:R,chain:X,walletType:Z})}),q=Q.includes(D.Cosmos),U=Q.includes(D.Kujira);if(q){let X=await j(D.Cosmos),R=await E(D.Cosmos);z({...R,address:X,chain:D.Cosmos,walletType:Z})}if(U){let X=await j(D.Kujira),R=await E(D.Kujira);z({...R,address:X,chain:D.Kujira,walletType:Z})}return await Promise.all(Y),!0}}),e=d(l);async function E(z){let{match:Z}=await import("ts-pattern");return Z(z).with(D.Solana,async()=>{let{getSolanaToolbox:J}=await import("@swapkit/toolboxes/solana"),F=window.vultisig?.solana;if(!F)throw new M("wallet_vultisig_not_found");return{...await J({signer:F})}}).with(D.Maya,D.THORChain,async()=>{let{getCosmosToolbox:J,THORCHAIN_GAS_VALUE:F,MAYA_GAS_VALUE:$}=await import("@swapkit/toolboxes/cosmos"),Q=z===D.Maya?$:F;return{...await J(z),deposit:(q)=>y({...q,recipient:""},"deposit_transaction"),transfer:(q)=>y({...q,gasLimit:Q},"send_transaction")}}).with(D.Cosmos,D.Kujira,async()=>{let{getCosmosToolbox:J}=await import("@swapkit/toolboxes/cosmos"),F=await I(z),$=await J(z);return V({provider:F,chain:z,toolbox:{...$,transfer:y}})}).with(...m,async()=>{let{getUtxoToolbox:J}=await import("@swapkit/toolboxes/utxo");return{...await J(z),transfer:y}}).with(D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Ethereum,D.Optimism,D.Polygon,async()=>{let{prepareNetworkSwitch:J,switchEVMWalletNetwork:F}=await import("@swapkit/helpers"),{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Q}=await import("ethers"),Y=await I(z);if(!Y)throw new M("wallet_vultisig_not_found");let q=new Q(Y,"any"),U=await q.getSigner(),X=await $(z,{provider:q,signer:U}),R=P(q,z);try{if(z!==D.Ethereum){let L=X.getNetworkParams();await F(q,z,L)}}catch(L){throw new M({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:f.VULTISIG,chain:z}})}return J({provider:q,chain:z,toolbox:{...X,...R}})}).with(D.Ripple,async()=>{let{getRippleToolbox:J}=await import("@swapkit/toolboxes/ripple");return{...await J(),transfer:y}}).with(D.Polkadot,async()=>{let{getSubstrateToolbox:J}=await import("@swapkit/toolboxes/substrate");return{...await J(z),transfer:y}}).otherwise(async()=>null)}export{l as vultisigWallet,e as VULTISIG_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=8A0E8DB3E8FB79EF64756E2164756E21
3
+ //# debugId=74264C5433F4518664756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/vultisig/index.ts", "../src/vultisig/walletHelpers.ts"],
4
4
  "sourcesContent": [
5
- "import {\n Chain,\n type EVMChain,\n type GenericTransferParams,\n SwapKitError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport {\n getVultisigAddress,\n getVultisigMethods,\n getVultisigProvider,\n prepareNetworkSwitchCosmos,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const vultisigWallet = createWallet({\n name: \"connectVultisig\",\n walletType: WalletOption.VULTISIG,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polkadot,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.Zcash,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectVultisig(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains\n .filter((chain) => chain !== Chain.Cosmos && chain !== Chain.Kujira)\n .map(async (chain) => {\n const address = await getVultisigAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n const cosmosIncluded = filteredChains.includes(Chain.Cosmos);\n const kujiraIncluded = filteredChains.includes(Chain.Kujira);\n\n // Race condition single cosmos provider exposed.\n if (cosmosIncluded) {\n const addressCosmos = await getVultisigAddress(Chain.Cosmos);\n const walletMethodsCosmos = await getWalletMethods(Chain.Cosmos);\n addChain({\n ...walletMethodsCosmos,\n address: addressCosmos,\n chain: Chain.Cosmos,\n walletType,\n });\n }\n if (kujiraIncluded) {\n const addressKujira = await getVultisigAddress(Chain.Kujira);\n const walletMethodsKujira = await getWalletMethods(Chain.Kujira);\n addChain({\n ...walletMethodsKujira,\n address: addressKujira,\n chain: Chain.Kujira,\n walletType,\n });\n }\n //--//\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const VULTISIG_SUPPORTED_CHAINS = getWalletSupportedChains(vultisigWallet);\n\nasync function getWalletMethods(chain: (typeof VULTISIG_SUPPORTED_CHAINS)[number]) {\n const { match } = await import(\"ts-pattern\");\n return match(chain)\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n return { ...toolbox };\n })\n\n .with(Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as Chain.Cosmos | Chain.Kujira);\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) =>\n walletTransfer({ ...tx, recipient: \"\" }, \"deposit_transaction\"),\n transfer: (tx: GenericTransferParams) =>\n walletTransfer({ ...tx, gasLimit }, \"send_transaction\"),\n };\n })\n\n .with(Chain.Cosmos, Chain.Kujira, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const provider = await getVultisigProvider(chain as Chain.Cosmos | Chain.Kujira);\n const toolbox = await getCosmosToolbox(chain as Chain.Cosmos | Chain.Kujira);\n return prepareNetworkSwitchCosmos({\n provider,\n chain,\n toolbox: {\n ...toolbox,\n transfer: walletTransfer,\n },\n });\n })\n\n .with(...UTXOChains, async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain as UTXOChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n async () => {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getVultisigProvider(chain as EVMChain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_vultisig_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain as EVMChain, { provider, signer });\n const vultisigMethods = getVultisigMethods(provider, chain as EVMChain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.VULTISIG, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider,\n chain,\n toolbox: {\n ...toolbox,\n ...vultisigMethods,\n },\n });\n },\n )\n\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const toolbox = await getRippleToolbox();\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const toolbox = await getSubstrateToolbox(chain as Chain.Polkadot);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .otherwise(async () => null);\n}\n",
5
+ "import {\n Chain,\n type EVMChain,\n type GenericTransferParams,\n SwapKitError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport {\n getVultisigAddress,\n getVultisigMethods,\n getVultisigProvider,\n prepareNetworkSwitchCosmos,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const vultisigWallet = createWallet({\n name: \"connectVultisig\",\n walletType: WalletOption.VULTISIG,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polkadot,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.Zcash,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectVultisig(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains\n .filter((chain) => chain !== Chain.Cosmos && chain !== Chain.Kujira)\n .map(async (chain) => {\n const address = await getVultisigAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n const cosmosIncluded = filteredChains.includes(Chain.Cosmos);\n const kujiraIncluded = filteredChains.includes(Chain.Kujira);\n\n // Race condition single cosmos provider exposed.\n if (cosmosIncluded) {\n const addressCosmos = await getVultisigAddress(Chain.Cosmos);\n const walletMethodsCosmos = await getWalletMethods(Chain.Cosmos);\n addChain({\n ...walletMethodsCosmos,\n address: addressCosmos,\n chain: Chain.Cosmos,\n walletType,\n });\n }\n if (kujiraIncluded) {\n const addressKujira = await getVultisigAddress(Chain.Kujira);\n const walletMethodsKujira = await getWalletMethods(Chain.Kujira);\n addChain({\n ...walletMethodsKujira,\n address: addressKujira,\n chain: Chain.Kujira,\n walletType,\n });\n }\n //--//\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const VULTISIG_SUPPORTED_CHAINS = getWalletSupportedChains(vultisigWallet);\n\nasync function getWalletMethods(chain: (typeof VULTISIG_SUPPORTED_CHAINS)[number]) {\n const { match } = await import(\"ts-pattern\");\n return match(chain)\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n return { ...toolbox };\n })\n\n .with(Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as Chain.Cosmos | Chain.Kujira);\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) =>\n walletTransfer({ ...tx, recipient: \"\" }, \"deposit_transaction\"),\n transfer: (tx: GenericTransferParams) =>\n walletTransfer({ ...tx, gasLimit }, \"send_transaction\"),\n };\n })\n\n .with(Chain.Cosmos, Chain.Kujira, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const provider = await getVultisigProvider(chain as Chain.Cosmos | Chain.Kujira);\n const toolbox = await getCosmosToolbox(chain as Chain.Cosmos | Chain.Kujira);\n return prepareNetworkSwitchCosmos({\n provider,\n chain,\n toolbox: {\n ...toolbox,\n transfer: walletTransfer,\n },\n });\n })\n\n .with(...UTXOChains, async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain as UTXOChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n async () => {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getVultisigProvider(chain as EVMChain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_vultisig_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain as EVMChain, { provider, signer });\n const vultisigMethods = getVultisigMethods(provider, chain as EVMChain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.VULTISIG, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider,\n chain,\n toolbox: {\n ...toolbox,\n ...vultisigMethods,\n },\n });\n },\n )\n\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const toolbox = await getRippleToolbox();\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const toolbox = await getSubstrateToolbox(chain as Chain.Polkadot);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .otherwise(async () => null);\n}\n",
6
6
  "import {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n type NetworkParams,\n SwapKitError,\n type UTXOChain,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport type { VultisigCosmosProvider } from \"../types\";\n\ntype TransactionMethod = \"send_transaction\" | \"deposit_transaction\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n to: string;\n data?: string;\n from?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype VultisigProviderType<T> = T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? VultisigCosmosProvider\n : T extends EVMChain\n ? Eip1193Provider\n : T extends Chain.Maya | Chain.THORChain | Chain.Ripple | Chain.Polkadot | UTXOChain\n ? Eip1193Provider\n : undefined;\n\nexport async function getVultisigProvider<T extends Chain>(\n chain: T,\n): Promise<VultisigProviderType<T>> {\n if (!window.vultisig) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .with(...EVMChains, () => window.vultisig?.ethereum as Eip1193Provider)\n .with(Chain.Cosmos, Chain.Kujira, () => window.vultisig?.cosmos as VultisigCosmosProvider)\n .with(Chain.Bitcoin, () => window.vultisig?.bitcoin as Eip1193Provider)\n .with(Chain.BitcoinCash, () => window.vultisig?.bitcoincash as Eip1193Provider)\n .with(Chain.Dash, () => window.vultisig?.dash as Eip1193Provider)\n .with(Chain.Dogecoin, () => window.vultisig?.dogecoin as Eip1193Provider)\n .with(Chain.Litecoin, () => window.vultisig?.litecoin as Eip1193Provider)\n .with(Chain.Solana, () => window.vultisig?.solana as SolanaProvider)\n .with(Chain.THORChain, () => window.vultisig?.thorchain as Eip1193Provider)\n .with(Chain.Maya, () => window.vultisig?.mayachain as Eip1193Provider)\n .with(Chain.Polkadot, () => window.vultisig?.polkadot as Eip1193Provider)\n .with(Chain.Ripple, () => window.vultisig?.ripple as Eip1193Provider)\n .with(Chain.Zcash, () => window.vultisig?.zcash as Eip1193Provider)\n .otherwise(() => undefined) as VultisigProviderType<T>;\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getVultisigProvider(chain);\n let finalParams:\n | TransactionParams[]\n | {\n from: string;\n to?: string;\n value: string;\n data?: string;\n }[] = params;\n\n if (chain === Chain.Cosmos || chain === Chain.Kujira || chain === Chain.Ripple) {\n finalParams = params.map((p) => ({\n from: p.from as string,\n to: p.to as string,\n value: (p.amount as { amount: number; decimals?: number }).amount.toString(),\n data: p.data as string,\n }));\n }\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params: finalParams }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getVultisigAddress(chain: Chain) {\n try {\n const eipProvider = (await getVultisigProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.VULTISIG, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getVultisigProvider(Chain.Cosmos);\n const chainId = ChainToChainId[chain];\n\n await provider.request({\n method: \"wallet_switch_chain\",\n params: [{ chainId }],\n });\n\n let account = await provider.request({\n method: \"get_accounts\",\n });\n if (!account) {\n const connectedAcount = await provider.request({\n method: \"request_accounts\",\n });\n account = connectedAcount[0].address;\n }\n return account;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getVultisigProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.VULTISIG, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"send_transaction\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_vultisig_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getVultisigAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n data: memo || \"\",\n from,\n to: recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getVultisigMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_vultisig_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n\nexport async function switchCosmosWalletNetwork(\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n networkParams?: NetworkParams,\n) {\n try {\n await provider.request({\n method: \"wallet_switch_chain\",\n params: [{ chainId: ChainToChainId[chain] }],\n });\n } catch (error) {\n if (!networkParams) {\n throw new SwapKitError(\"helpers_failed_to_switch_network\", {\n error: error,\n reason: \"networkParams not provided\",\n });\n }\n }\n}\n\nexport function wrapMethodWithNetworkSwitch<T extends (...args: any[]) => any>(\n func: T,\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n) {\n return (async (...args: any[]) => {\n try {\n await switchCosmosWalletNetwork(provider, chain);\n } catch (error) {\n throw new SwapKitError({\n errorKey: \"helpers_failed_to_switch_network\",\n info: { error },\n });\n }\n return func(...args);\n }) as unknown as T;\n}\n\nexport function prepareNetworkSwitchCosmos<\n T extends Awaited<ReturnType<typeof getCosmosToolbox>>,\n M extends keyof T,\n>({\n toolbox,\n chain,\n provider = window.ethereum,\n methodNames = [],\n}: { toolbox: T; chain: Chain; provider?: VultisigCosmosProvider; methodNames?: M[] }) {\n const methodsToWrap = [...methodNames, \"transfer\", \"getAddress\", \"getBalance\"] as M[];\n const wrappedMethods = methodsToWrap.reduce((object, methodName) => {\n if (!toolbox[methodName]) return object;\n\n const method = toolbox[methodName];\n\n if (typeof method !== \"function\") return object;\n\n // @ts-expect-error\n const wrappedMethod = wrapMethodWithNetworkSwitch(method, provider, chain);\n\n // biome-ignore lint/performance/noAccumulatingSpread: valid use case\n return { ...object, [methodName]: wrappedMethod };\n }, {});\n\n return { ...toolbox, ...wrappedMethods };\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "8A0E8DB3E8FB79EF64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "74264C5433F4518664756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var M5={};r5(M5,{walletconnectWallet:()=>q5,WC_SUPPORTED_CHAINS:()=>T5,TRON_MAINNET_ID:()=>o,THORCHAIN_MAINNET_ID:()=>k,POLYGON_MAINNET_ID:()=>I,OPTIMISM_MAINNET_ID:()=>s,NEAR_TESTNET_ID:()=>c,NEAR_MAINNET_ID:()=>t,MAYACHAIN_MAINNET_ID:()=>h,KUJIRA_MAINNET_ID:()=>d,ETHEREUM_MAINNET_ID:()=>A,DEFAULT_TRON_METHODS:()=>z5,DEFAULT_TRON_EVENTS:()=>Q5,DEFAULT_SOLANA_METHODS:()=>O5,DEFAULT_SOLANA_EVENTS:()=>j5,DEFAULT_RELAY_URL:()=>H,DEFAULT_POLKADOT_METHODS:()=>F5,DEFAULT_POLKADOT_EVENTS:()=>f5,DEFAULT_NEAR_METHODS:()=>V5,DEFAULT_NEAR_EVENTS:()=>U5,DEFAULT_LOGGER:()=>r,DEFAULT_EIP_155_EVENTS:()=>L5,DEFAULT_EIP155_METHODS:()=>R,DEFAULT_COSMOS_METHODS:()=>_,DEFAULT_COSMOS_EVENTS:()=>w5,DEFAULT_APP_METADATA:()=>Z5,COSMOS_HUB_MAINNET_ID:()=>C,BSC_MAINNET_ID:()=>N,BERACHAIN_MAINNET_ID:()=>a,BASE_MAINNET_ID:()=>e,AVALANCHE_MAINNET_ID:()=>g,AURORA_MAINNET_ID:()=>i,ARBITRUM_ONE_MAINNET_ID:()=>l});module.exports=H5(M5);var L=require("@swapkit/helpers");var b=require("@swapkit/helpers"),J5=require("ethers");var U=require("@swapkit/helpers");var D=(O,j)=>{return(j.find((Q)=>Q.startsWith(q(O)))||"")?.split(":")?.[2]||""},q=(O)=>{switch(O){case U.Chain.Avalanche:return g;case U.Chain.Aurora:return i;case U.Chain.Base:return e;case U.Chain.BinanceSmartChain:return N;case U.Chain.Berachain:return a;case U.Chain.Ethereum:return A;case U.Chain.THORChain:return k;case U.Chain.Arbitrum:return l;case U.Chain.Optimism:return s;case U.Chain.Polygon:return I;case U.Chain.Maya:return h;case U.Chain.Cosmos:return C;case U.Chain.Kujira:return d;case U.Chain.Near:{let{isStagenet:j}=U.SKConfig.get("envs");return j?c:t}case U.Chain.Tron:return o;default:return""}};class n extends J5.AbstractSigner{address;chain;walletconnect;provider;constructor({chain:O,provider:j,walletconnect:F}){super(j);this.chain=O,this.walletconnect=F,this.provider=j,this.address=""}getAddress=async()=>{if(!this.walletconnect)throw new b.SwapKitError("wallet_walletconnect_connection_not_established");if(!this.address)this.address=D(this.chain,this.walletconnect.accounts||[]);return this.address};signMessage=async(O)=>{let j=await this.walletconnect?.client.request({chainId:q(this.chain),topic:this.walletconnect.session.topic||"",request:{method:"eth_sign",params:[O]}});return j.startsWith("0x")?j:`0x${j}`};signTransaction=()=>{throw new b.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signTransaction"})};signTypedData=()=>{throw new b.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signTypedData"})};sendTransaction=async({from:O,to:j,value:F,data:V})=>{let{toHexString:Q}=await import("@swapkit/toolboxes/evm"),f={from:O,to:j,value:Q(BigInt(F||0)),data:V};return await this.walletconnect?.client.request({chainId:q(this.chain),topic:this.walletconnect.session.topic,request:{method:"eth_sendTransaction",params:[f]}})};connect=(O)=>{if(!O)throw new b.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:b.WalletOption.WALLETCONNECT,chain:this.chain}});return new n({chain:this.chain,walletconnect:this.walletconnect,provider:O})}}var K5=async({chain:O,walletconnect:j,provider:F})=>new n({chain:O,walletconnect:j,provider:F});var X5=require("@swapkit/helpers");var D5=(O)=>{let j=[];for(let F of O){let[V]=F.split(":");if(V&&!j.includes(V))j.push(V)}return j},R5=(O)=>{switch(O){case"eip155":return Object.values(R);case"cosmos":return Object.values(_);case"solana":return Object.values(O5);case"polkadot":return Object.values(F5);case"near":return Object.values(V5);case"tron":return Object.values(z5);default:throw new X5.SwapKitError({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:O}})}},_5=(O)=>{switch(O){case"eip155":return Object.values(L5);case"cosmos":return[];case"solana":return Object.values(j5);case"polkadot":return Object.values(f5);case"near":return Object.values(U5);case"tron":return Object.values(Q5);default:throw new X5.SwapKitError({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:O}})}},$5=(O)=>{let j=D5(O);return Object.fromEntries(j.map((F)=>[F,{methods:R5(F),chains:O.filter((V)=>V.startsWith(F)),events:_5(F)}]))};var q5=L.createWallet({name:"connectWalletconnect",walletType:L.WalletOption.WALLETCONNECT,supportedChains:[L.Chain.Arbitrum,L.Chain.Aurora,L.Chain.Avalanche,L.Chain.Base,L.Chain.Berachain,L.Chain.BinanceSmartChain,L.Chain.Cosmos,L.Chain.Ethereum,L.Chain.Kujira,L.Chain.Maya,L.Chain.Near,L.Chain.Optimism,L.Chain.Polygon,L.Chain.THORChain,L.Chain.Tron],connect:({addChain:O,supportedChains:j,walletType:F})=>async function V(Q,f){let z=L.filterSupportedChains({chains:Q,supportedChains:j,walletType:F}),{walletConnectProjectId:y}=L.SKConfig.get("apiKeys");if(!y)throw new L.SwapKitError("wallet_walletconnect_project_id_not_specified");let X=await x5(z,y,f);if(!X)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");let{accounts:K}=X;return await Promise.all(z.map(async(v)=>{let $=D(v,K||[]),Y=await S5({address:$,chain:v,walletconnect:X});O({...Y,address:$,chain:v,disconnect:X.disconnect,walletType:L.WalletOption.WALLETCONNECT})})),!0}}),T5=Y5(q5);async function S5({chain:O,walletconnect:j,address:F}){let V=j?.session;if(!V)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");switch(O){case L.Chain.Arbitrum:case L.Chain.Avalanche:case L.Chain.Base:case L.Chain.BinanceSmartChain:case L.Chain.Ethereum:case L.Chain.Optimism:case L.Chain.Polygon:{let{getProvider:Q,getEvmToolbox:f}=await import("@swapkit/toolboxes/evm"),z=await Q(O),y=await K5({walletconnect:j,chain:O,provider:z});return await f(O,{provider:z,signer:y})}case L.Chain.THORChain:{let{SignMode:Q}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:f}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),z=await import("@cosmjs/proto-signing"),y=z.encodePubkey??z.default?.encodePubkey,X=z.makeAuthInfoBytes??z.default?.makeAuthInfoBytes,v=(await import("@cosmjs/amino")).makeSignDoc??z.default?.makeSignDoc,{getCosmosToolbox:$,buildAminoMsg:Y,buildEncodedTxBody:W,createStargateClient:w,fromBase64:T,getDefaultChainFee:S,parseAminoMessageForDirectSigning:x}=await import("@swapkit/toolboxes/cosmos"),p=await $(L.Chain.THORChain);async function v5(G){let E=await p.getAccount(G);if(O!==L.Chain.THORChain)return E;let[{address:J,algo:M,pubkey:B}]=await j?.client.request({chainId:k,topic:V.topic,request:{method:"cosmos_getAccounts",params:{}}});return{...E,address:J,pubkey:{type:M,value:B}}}let P=S(O),b5=(G)=>j?.client.request({chainId:k,topic:V.topic,request:{method:"cosmos_signAmino",params:{signerAddress:F,signDoc:G}}});async function y5({assetValue:G,memo:u,...E}){let J=await p.getAccount(F);if(!J)throw new L.SwapKitError({errorKey:"wallet_missing_params",info:{account:J}});if(!J.pubkey)throw new L.SwapKitError({errorKey:"wallet_missing_params",info:{account:J,pubkey:J?.pubkey}});let{accountNumber:M,sequence:B=0}=J,G5=[Y({assetValue:G,memo:u,sender:F,...E})],p5=L.ChainId.THORChain,k5=v(G5,P,p5,u,M?.toString(),B?.toString()||"0"),m=await b5(k5),P5=await W({chain:L.Chain.THORChain,msgs:G5.map(x),memo:u||""}),W5=y(J.pubkey),u5=X([{pubkey:W5,sequence:B}],P.amount,Number.parseInt(P.gas),void 0,void 0,Q.SIGN_MODE_LEGACY_AMINO_JSON),E5=f.fromPartial({bodyBytes:P5,authInfoBytes:u5,signatures:[T(typeof m.signature==="string"?m.signature:m.signature.signature)]}),B5=f.encode(E5).finish();return(await(await w(L.SKConfig.get("rpcUrls")[L.Chain.THORChain])).broadcastTx(B5)).transactionHash}return{...p,transfer:(G)=>y5(G),deposit:(G)=>y5(G),getAccount:v5}}case L.Chain.Near:{let{getNearToolbox:Q}=await import("@swapkit/toolboxes/near"),{DEFAULT_NEAR_METHODS:f}=await import("../../chunk-x5n5v0h8.js");return await Q({signer:{getPublicKey(){return Promise.reject(new L.SwapKitError("wallet_walletconnect_method_not_supported",{method:"getPublicKey"}))},signNep413Message(X,K,v,$,Y){return Promise.reject(new L.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signNep413Message"}))},async signTransaction(X){if(!j)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");let K=await j.client.request({topic:V.topic,chainId:q(L.Chain.Near),request:{method:f.NEAR_SIGN_AND_SEND_TRANSACTION,params:{transaction:X}}});return[new Uint8Array(32),K]},signDelegateAction(X){return Promise.reject(new L.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signDelegateAction"}))},getAddress(){return Promise.resolve(F)}}})}case L.Chain.Tron:{let{createTronToolbox:Q}=await import("@swapkit/toolboxes/tron"),{DEFAULT_TRON_METHODS:f}=await import("../../chunk-x5n5v0h8.js");return await Q({signer:{getAddress(){return Promise.resolve(F)},async signTransaction(X){if(!j)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");return await j.client.request({topic:V.topic,chainId:q(L.Chain.Tron),request:{method:f.TRON_SIGN_TRANSACTION,params:{transaction:X}}})}}})}default:throw new L.SwapKitError({errorKey:"wallet_chain_not_supported",info:{chain:O,wallet:L.WalletOption.WALLETCONNECT}})}}async function x5(O,j,F){let V,Q,f,z;try{if(!j)throw new L.SwapKitError("wallet_walletconnect_project_id_not_specified");let y=$5(O.map(q)),{SignClient:X}=await import("@walletconnect/sign-client"),{WalletConnectModal:K}=await import("@walletconnect/modal"),v=new X({logger:r,relayUrl:H,projectId:j,metadata:F?.metadata||Z5,...F?.core}),$=new K({logger:r,relayUrl:H,projectId:j,...F?.core}),Y=await v.session.getAll()[0];if(Y)await v.disconnect({topic:Y.topic,reason:{code:0,message:"Resetting session"}});let{uri:W,approval:w}=await v.connect({requiredNamespaces:y});if(W){let S=function(x){let p=[];for(let[v5,P]of Object.entries(x.namespaces))p.push(...P.accounts);return p};$.openModal({uri:W}),f=await w(),$.closeModal(),z=S(f)}let T=async()=>{f&&await v.disconnect({topic:f.topic,reason:{code:0,message:"User disconnected"}})};if(!f)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");return{signer:Q,session:f,accounts:z,client:v,disconnect:T}}catch(y){}finally{if(V)V.closeModal()}return}
1
+ var M5={};r5(M5,{walletconnectWallet:()=>Y5,WC_SUPPORTED_CHAINS:()=>T5,TRON_MAINNET_ID:()=>i,THORCHAIN_MAINNET_ID:()=>k,POLYGON_MAINNET_ID:()=>e,OPTIMISM_MAINNET_ID:()=>I,NEAR_TESTNET_ID:()=>o,NEAR_MAINNET_ID:()=>c,MAYACHAIN_MAINNET_ID:()=>l,KUJIRA_MAINNET_ID:()=>h,ETHEREUM_MAINNET_ID:()=>N,DEFAULT_TRON_METHODS:()=>Q5,DEFAULT_TRON_EVENTS:()=>X5,DEFAULT_SOLANA_METHODS:()=>j5,DEFAULT_SOLANA_EVENTS:()=>F5,DEFAULT_RELAY_URL:()=>H,DEFAULT_POLKADOT_METHODS:()=>f5,DEFAULT_POLKADOT_EVENTS:()=>V5,DEFAULT_NEAR_METHODS:()=>U5,DEFAULT_NEAR_EVENTS:()=>z5,DEFAULT_LOGGER:()=>r,DEFAULT_EIP_155_EVENTS:()=>O5,DEFAULT_EIP155_METHODS:()=>R,DEFAULT_COSMOS_METHODS:()=>_,DEFAULT_COSMOS_EVENTS:()=>w5,DEFAULT_APP_METADATA:()=>v5,COSMOS_HUB_MAINNET_ID:()=>d,BSC_MAINNET_ID:()=>g,BERACHAIN_MAINNET_ID:()=>n,BASE_MAINNET_ID:()=>t,AVALANCHE_MAINNET_ID:()=>C,AURORA_MAINNET_ID:()=>a,ARBITRUM_ONE_MAINNET_ID:()=>s});module.exports=H5(M5);var L=require("@swapkit/helpers"),w=require("@swapkit/wallet-core");var b=require("@swapkit/helpers"),K5=require("ethers");var U=require("@swapkit/helpers");var D=(O,j)=>{return(j.find((Q)=>Q.startsWith(q(O)))||"")?.split(":")?.[2]||""},q=(O)=>{switch(O){case U.Chain.Avalanche:return C;case U.Chain.Aurora:return a;case U.Chain.Base:return t;case U.Chain.BinanceSmartChain:return g;case U.Chain.Berachain:return n;case U.Chain.Ethereum:return N;case U.Chain.THORChain:return k;case U.Chain.Arbitrum:return s;case U.Chain.Optimism:return I;case U.Chain.Polygon:return e;case U.Chain.Maya:return l;case U.Chain.Cosmos:return d;case U.Chain.Kujira:return h;case U.Chain.Near:{let{isStagenet:j}=U.SKConfig.get("envs");return j?o:c}case U.Chain.Tron:return i;default:return""}};class L5 extends K5.AbstractSigner{address;chain;walletconnect;provider;constructor({chain:O,provider:j,walletconnect:F}){super(j);this.chain=O,this.walletconnect=F,this.provider=j,this.address=""}getAddress=async()=>{if(!this.walletconnect)throw new b.SwapKitError("wallet_walletconnect_connection_not_established");if(!this.address)this.address=D(this.chain,this.walletconnect.accounts||[]);return this.address};signMessage=async(O)=>{let j=await this.walletconnect?.client.request({chainId:q(this.chain),topic:this.walletconnect.session.topic||"",request:{method:"eth_sign",params:[O]}});return j.startsWith("0x")?j:`0x${j}`};signTransaction=()=>{throw new b.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signTransaction"})};signTypedData=()=>{throw new b.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signTypedData"})};sendTransaction=async({from:O,to:j,value:F,data:V})=>{let{toHexString:Q}=await import("@swapkit/toolboxes/evm"),f={from:O,to:j,value:Q(BigInt(F||0)),data:V};return await this.walletconnect?.client.request({chainId:q(this.chain),topic:this.walletconnect.session.topic,request:{method:"eth_sendTransaction",params:[f]}})};connect=(O)=>{if(!O)throw new b.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:b.WalletOption.WALLETCONNECT,chain:this.chain}});return new L5({chain:this.chain,walletconnect:this.walletconnect,provider:O})}}var $5=async({chain:O,walletconnect:j,provider:F})=>new L5({chain:O,walletconnect:j,provider:F});var Z5=require("@swapkit/helpers");var D5=(O)=>{let j=[];for(let F of O){let[V]=F.split(":");if(V&&!j.includes(V))j.push(V)}return j},R5=(O)=>{switch(O){case"eip155":return Object.values(R);case"cosmos":return Object.values(_);case"solana":return Object.values(j5);case"polkadot":return Object.values(f5);case"near":return Object.values(U5);case"tron":return Object.values(Q5);default:throw new Z5.SwapKitError({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:O}})}},_5=(O)=>{switch(O){case"eip155":return Object.values(O5);case"cosmos":return[];case"solana":return Object.values(F5);case"polkadot":return Object.values(V5);case"near":return Object.values(z5);case"tron":return Object.values(X5);default:throw new Z5.SwapKitError({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:O}})}},q5=(O)=>{let j=D5(O);return Object.fromEntries(j.map((F)=>[F,{methods:R5(F),chains:O.filter((V)=>V.startsWith(F)),events:_5(F)}]))};var Y5=w.createWallet({name:"connectWalletconnect",walletType:L.WalletOption.WALLETCONNECT,supportedChains:[L.Chain.Arbitrum,L.Chain.Aurora,L.Chain.Avalanche,L.Chain.Base,L.Chain.Berachain,L.Chain.BinanceSmartChain,L.Chain.Cosmos,L.Chain.Ethereum,L.Chain.Kujira,L.Chain.Maya,L.Chain.Near,L.Chain.Optimism,L.Chain.Polygon,L.Chain.THORChain,L.Chain.Tron],connect:({addChain:O,supportedChains:j,walletType:F})=>async function V(Q,f){let z=L.filterSupportedChains({chains:Q,supportedChains:j,walletType:F}),{walletConnectProjectId:y}=L.SKConfig.get("apiKeys");if(!y)throw new L.SwapKitError("wallet_walletconnect_project_id_not_specified");let X=await x5(z,y,f);if(!X)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");let{accounts:K}=X;return await Promise.all(z.map(async(v)=>{let $=D(v,K||[]),Y=await S5({address:$,chain:v,walletconnect:X});O({...Y,address:$,chain:v,disconnect:X.disconnect,walletType:L.WalletOption.WALLETCONNECT})})),!0}}),T5=w.getWalletSupportedChains(Y5);async function S5({chain:O,walletconnect:j,address:F}){let V=j?.session;if(!V)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");switch(O){case L.Chain.Arbitrum:case L.Chain.Avalanche:case L.Chain.Base:case L.Chain.BinanceSmartChain:case L.Chain.Ethereum:case L.Chain.Optimism:case L.Chain.Polygon:{let{getProvider:Q,getEvmToolbox:f}=await import("@swapkit/toolboxes/evm"),z=await Q(O),y=await $5({walletconnect:j,chain:O,provider:z});return await f(O,{provider:z,signer:y})}case L.Chain.THORChain:{let{SignMode:Q}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:f}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),z=await import("@cosmjs/proto-signing"),y=z.encodePubkey??z.default?.encodePubkey,X=z.makeAuthInfoBytes??z.default?.makeAuthInfoBytes,v=(await import("@cosmjs/amino")).makeSignDoc??z.default?.makeSignDoc,{getCosmosToolbox:$,buildAminoMsg:Y,buildEncodedTxBody:W,createStargateClient:T,fromBase64:S,getDefaultChainFee:x,parseAminoMessageForDirectSigning:M}=await import("@swapkit/toolboxes/cosmos"),p=await $(L.Chain.THORChain);async function y5(G){let E=await p.getAccount(G);if(O!==L.Chain.THORChain)return E;let[{address:J,algo:m,pubkey:B}]=await j?.client.request({chainId:k,topic:V.topic,request:{method:"cosmos_getAccounts",params:{}}});return{...E,address:J,pubkey:{type:m,value:B}}}let P=x(O),b5=(G)=>j?.client.request({chainId:k,topic:V.topic,request:{method:"cosmos_signAmino",params:{signerAddress:F,signDoc:G}}});async function G5({assetValue:G,memo:u,...E}){let J=await p.getAccount(F);if(!J)throw new L.SwapKitError({errorKey:"wallet_missing_params",info:{account:J}});if(!J.pubkey)throw new L.SwapKitError({errorKey:"wallet_missing_params",info:{account:J,pubkey:J?.pubkey}});let{accountNumber:m,sequence:B=0}=J,J5=[Y({assetValue:G,memo:u,sender:F,...E})],p5=L.ChainId.THORChain,k5=v(J5,P,p5,u,m?.toString(),B?.toString()||"0"),A=await b5(k5),P5=await W({chain:L.Chain.THORChain,msgs:J5.map(M),memo:u||""}),W5=y(J.pubkey),u5=X([{pubkey:W5,sequence:B}],P.amount,Number.parseInt(P.gas),void 0,void 0,Q.SIGN_MODE_LEGACY_AMINO_JSON),E5=f.fromPartial({bodyBytes:P5,authInfoBytes:u5,signatures:[S(typeof A.signature==="string"?A.signature:A.signature.signature)]}),B5=f.encode(E5).finish();return(await(await T(L.SKConfig.get("rpcUrls")[L.Chain.THORChain])).broadcastTx(B5)).transactionHash}return{...p,transfer:(G)=>G5(G),deposit:(G)=>G5(G),getAccount:y5}}case L.Chain.Near:{let{getNearToolbox:Q}=await import("@swapkit/toolboxes/near"),{DEFAULT_NEAR_METHODS:f}=await import("../../chunk-x5n5v0h8.js");return await Q({signer:{getPublicKey(){return Promise.reject(new L.SwapKitError("wallet_walletconnect_method_not_supported",{method:"getPublicKey"}))},signNep413Message(X,K,v,$,Y){return Promise.reject(new L.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signNep413Message"}))},async signTransaction(X){if(!j)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");let K=await j.client.request({topic:V.topic,chainId:q(L.Chain.Near),request:{method:f.NEAR_SIGN_AND_SEND_TRANSACTION,params:{transaction:X}}});return[new Uint8Array(32),K]},signDelegateAction(X){return Promise.reject(new L.SwapKitError("wallet_walletconnect_method_not_supported",{method:"signDelegateAction"}))},getAddress(){return Promise.resolve(F)}}})}case L.Chain.Tron:{let{createTronToolbox:Q}=await import("@swapkit/toolboxes/tron"),{DEFAULT_TRON_METHODS:f}=await import("../../chunk-x5n5v0h8.js");return await Q({signer:{getAddress(){return Promise.resolve(F)},async signTransaction(X){if(!j)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");return await j.client.request({topic:V.topic,chainId:q(L.Chain.Tron),request:{method:f.TRON_SIGN_TRANSACTION,params:{transaction:X}}})}}})}default:throw new L.SwapKitError({errorKey:"wallet_chain_not_supported",info:{chain:O,wallet:L.WalletOption.WALLETCONNECT}})}}async function x5(O,j,F){let V,Q,f,z;try{if(!j)throw new L.SwapKitError("wallet_walletconnect_project_id_not_specified");let y=q5(O.map(q)),{SignClient:X}=await import("@walletconnect/sign-client"),{WalletConnectModal:K}=await import("@walletconnect/modal"),v=new X({logger:r,relayUrl:H,projectId:j,metadata:F?.metadata||v5,...F?.core}),$=new K({logger:r,relayUrl:H,projectId:j,...F?.core}),Y=await v.session.getAll()[0];if(Y)await v.disconnect({topic:Y.topic,reason:{code:0,message:"Resetting session"}});let{uri:W,approval:T}=await v.connect({requiredNamespaces:y});if(W){let x=function(M){let p=[];for(let[y5,P]of Object.entries(M.namespaces))p.push(...P.accounts);return p};$.openModal({uri:W}),f=await T(),$.closeModal(),z=x(f)}let S=async()=>{f&&await v.disconnect({topic:f.topic,reason:{code:0,message:"User disconnected"}})};if(!f)throw new L.SwapKitError("wallet_walletconnect_connection_not_established");return{signer:Q,session:f,accounts:z,client:v,disconnect:S}}catch(y){}finally{if(V)V.closeModal()}return}
2
2
 
3
- //# debugId=35CD9443B67F98E464756E2164756E21
3
+ //# debugId=F186B125A3AE36F964756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,12 +2,12 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/walletconnect/index.ts", "../src/walletconnect/evmSigner.ts", "../src/walletconnect/helpers.ts", "../src/walletconnect/namespaces.ts"],
4
4
  "sourcesContent": [
5
- "import type { StdSignDoc } from \"@cosmjs/amino\";\nimport {\n Chain,\n ChainId,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams, createThorchainToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { NearSigner } from \"@swapkit/toolboxes/near\";\nimport type { TronSignedTransaction, TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { WalletConnectModal } from \"@walletconnect/modal\";\nimport type { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport type { Transaction } from \"near-api-js/lib/transaction\";\n\nimport type { SignClient } from \"@walletconnect/sign-client\";\nimport { getWalletSupportedChains } from \"../utils\";\nimport {\n DEFAULT_APP_METADATA,\n DEFAULT_COSMOS_METHODS,\n DEFAULT_LOGGER,\n DEFAULT_RELAY_URL,\n THORCHAIN_MAINNET_ID,\n} from \"./constants\";\nimport { getEVMSigner } from \"./evmSigner\";\nimport { chainToChainId, getAddressByChain } from \"./helpers\";\nimport { getRequiredNamespaces } from \"./namespaces\";\n\nexport * from \"./constants\";\nexport * from \"./types\";\n\nexport const walletconnectWallet = createWallet({\n name: \"connectWalletconnect\",\n walletType: WalletOption.WALLETCONNECT,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Cosmos,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Maya,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectWalletconnect(\n chains: Chain[],\n walletconnectOptions?: SignClientTypes.Options,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { walletConnectProjectId } = SKConfig.get(\"apiKeys\");\n\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n\n const walletconnect = await getWalletconnect(\n filteredChains,\n walletConnectProjectId,\n walletconnectOptions,\n );\n\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const { accounts } = walletconnect;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const address = getAddressByChain(chain, accounts || []);\n const toolbox = await getToolbox({ address, chain, walletconnect });\n\n addChain({\n ...toolbox,\n address,\n chain,\n disconnect: walletconnect.disconnect,\n walletType: WalletOption.WALLETCONNECT,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const WC_SUPPORTED_CHAINS = getWalletSupportedChains(walletconnectWallet);\nexport type Walletconnect = Awaited<ReturnType<typeof getWalletconnect>>;\n\nasync function getToolbox<T extends (typeof WC_SUPPORTED_CHAINS)[number]>({\n chain,\n walletconnect,\n address,\n}: {\n walletconnect: Walletconnect;\n chain: T;\n address: string;\n}) {\n const session = walletconnect?.session;\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ walletconnect, chain, provider });\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return toolbox;\n }\n\n case Chain.THORChain: {\n const { SignMode } = await import(\"cosmjs-types/cosmos/tx/signing/v1beta1/signing.js\");\n const { TxRaw } = await import(\"cosmjs-types/cosmos/tx/v1beta1/tx.js\");\n\n const importedSigning = await import(\"@cosmjs/proto-signing\");\n const encodePubkey = importedSigning.encodePubkey ?? importedSigning.default?.encodePubkey;\n const makeAuthInfoBytes =\n importedSigning.makeAuthInfoBytes ?? importedSigning.default?.makeAuthInfoBytes;\n const importedAmino = await import(\"@cosmjs/amino\");\n const makeSignDoc = importedAmino.makeSignDoc ?? importedSigning.default?.makeSignDoc;\n\n const {\n getCosmosToolbox,\n buildAminoMsg,\n buildEncodedTxBody,\n createStargateClient,\n fromBase64,\n getDefaultChainFee,\n parseAminoMessageForDirectSigning,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n\n async function getAccount(accountAddress: string) {\n const cosmosToolbox = toolbox;\n const account = await (\n cosmosToolbox as Awaited<ReturnType<typeof createThorchainToolbox>>\n ).getAccount(accountAddress);\n\n if (chain !== Chain.THORChain) {\n return account;\n }\n\n const [{ address, algo, pubkey }] = (await walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n // @ts-ignore\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_GET_ACCOUNTS,\n params: {},\n },\n })) as [{ address: string; algo: string; pubkey: string }];\n\n return { ...account, address, pubkey: { type: algo, value: pubkey } };\n }\n\n const fee = getDefaultChainFee(chain);\n\n const signRequest = (signDoc: StdSignDoc) =>\n walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_SIGN_AMINO,\n params: { signerAddress: address, signDoc },\n },\n });\n\n async function thorchainTransfer({\n assetValue,\n memo,\n ...rest\n }: GenericTransferParams | ThorchainDepositParams) {\n const account = await toolbox.getAccount(address);\n if (!account) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { account } });\n }\n\n if (!account.pubkey) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { account, pubkey: account?.pubkey },\n });\n }\n\n const { accountNumber, sequence = 0 } = account;\n\n const msgs = [buildAminoMsg({ assetValue, memo, sender: address, ...rest })];\n\n const chainId = ChainId.THORChain;\n\n const signDoc = makeSignDoc(\n msgs,\n fee,\n chainId,\n memo,\n accountNumber?.toString(),\n sequence?.toString() || \"0\",\n );\n\n const signature: any = await signRequest(signDoc);\n\n const bodyBytes = await buildEncodedTxBody({\n chain: Chain.THORChain,\n msgs: msgs.map(parseAminoMessageForDirectSigning),\n memo: memo || \"\",\n });\n const pubkey = encodePubkey(account.pubkey);\n const authInfoBytes = makeAuthInfoBytes(\n [{ pubkey, sequence }],\n fee.amount,\n Number.parseInt(fee.gas),\n undefined,\n undefined,\n SignMode.SIGN_MODE_LEGACY_AMINO_JSON,\n );\n\n const txRaw = TxRaw.fromPartial({\n bodyBytes,\n authInfoBytes,\n signatures: [\n fromBase64(\n typeof signature.signature === \"string\"\n ? signature.signature\n : signature.signature.signature,\n ),\n ],\n });\n const txBytes = TxRaw.encode(txRaw).finish();\n\n const broadcaster = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const result = await broadcaster.broadcastTx(txBytes);\n return result.transactionHash;\n }\n\n return {\n ...toolbox,\n transfer: (params: GenericTransferParams) => thorchainTransfer(params),\n deposit: (params: ThorchainDepositParams) => thorchainTransfer(params),\n getAccount,\n };\n }\n\n case Chain.Near: {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const { DEFAULT_NEAR_METHODS } = await import(\"./constants\");\n\n // Create a NEAR signer that uses WalletConnect\n const signer = {\n getPublicKey() {\n // WalletConnect NEAR doesn't expose public key directly\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"getPublicKey\",\n }),\n );\n },\n\n signNep413Message(\n _message: string,\n _accountId: string,\n _recipient: string,\n _nonce: Uint8Array,\n _callbackUrl?: string,\n ) {\n // WalletConnect NEAR spec doesn't include NEP-413 message signing\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signNep413Message\",\n }),\n );\n },\n\n async signTransaction(transaction: Transaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n // WalletConnect signs and sends in one operation\n const result = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Near),\n request: {\n method: DEFAULT_NEAR_METHODS.NEAR_SIGN_AND_SEND_TRANSACTION,\n params: { transaction },\n },\n });\n // Return dummy hash and result\n return [new Uint8Array(32), result];\n },\n\n signDelegateAction(_delegateAction: any) {\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signDelegateAction\",\n }),\n );\n },\n\n getAddress() {\n return Promise.resolve(address);\n },\n } as NearSigner;\n\n const toolbox = await getNearToolbox({ signer });\n return toolbox;\n }\n\n case Chain.Tron: {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { DEFAULT_TRON_METHODS } = await import(\"./constants\");\n\n // Create a Tron signer that uses WalletConnect\n const signer: TronSigner = {\n getAddress() {\n return Promise.resolve(address);\n },\n\n async signTransaction(transaction: TronTransaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const signedTx = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Tron),\n request: {\n method: DEFAULT_TRON_METHODS.TRON_SIGN_TRANSACTION,\n params: { transaction },\n },\n });\n\n return signedTx as TronSignedTransaction;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n return toolbox;\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.WALLETCONNECT },\n });\n }\n}\n\nasync function getWalletconnect(\n chains: Chain[],\n walletConnectProjectId?: string,\n walletconnectOptions?: SignClientTypes.Options,\n) {\n let modal: WalletConnectModal | undefined;\n let signer: typeof SignClient | undefined;\n let session: SessionTypes.Struct | undefined;\n let accounts: string[] | undefined;\n try {\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n const requiredNamespaces = getRequiredNamespaces(chains.map(chainToChainId));\n\n const { SignClient } = await import(\"@walletconnect/sign-client\");\n const { WalletConnectModal } = await import(\"@walletconnect/modal\");\n\n const client = new SignClient({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n metadata: walletconnectOptions?.metadata || DEFAULT_APP_METADATA,\n ...walletconnectOptions?.core,\n });\n\n const modal = new WalletConnectModal({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n ...walletconnectOptions?.core,\n });\n\n const oldSession = await client.session.getAll()[0];\n\n // disconnect old Session cause we can't handle using it with current ui\n if (oldSession) {\n await client.disconnect({\n topic: oldSession.topic,\n reason: { code: 0, message: \"Resetting session\" },\n });\n }\n\n const { uri, approval } = await client.connect({\n // Optionally: pass a known prior pairing (e.g. from `client.core.pairing.getPairings()`) to skip the `uri` step.\n // pairingTopic: pairing?.topic,\n // Provide the namespaces and chains (e.g. `eip155` for EVM-based chains) we want to use in this session.\n requiredNamespaces,\n });\n\n if (uri) {\n modal.openModal({ uri });\n // Await session approval from the wallet.\n session = await approval();\n // Handle the returned session (e.g. update UI to \"connected\" state).\n // Close the QRCode modal in case it was open.\n modal.closeModal();\n\n function extractAccountsFromSession(session: SessionTypes.Struct) {\n const accounts: string[] = [];\n\n for (const [_namespace, data] of Object.entries(session.namespaces)) {\n accounts.push(...data.accounts);\n }\n\n return accounts;\n }\n\n accounts = extractAccountsFromSession(session);\n }\n\n const disconnect = async () => {\n session &&\n (await client.disconnect({\n topic: session.topic,\n reason: { code: 0, message: \"User disconnected\" },\n }));\n };\n\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n return { signer, session, accounts, client, disconnect };\n } catch (_e) {\n // Errors are handled by returning undefined\n } finally {\n if (modal) {\n modal.closeModal();\n }\n }\n return undefined;\n}\n",
5
+ "import type { StdSignDoc } from \"@cosmjs/amino\";\nimport {\n Chain,\n ChainId,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams, createThorchainToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { NearSigner } from \"@swapkit/toolboxes/near\";\nimport type { TronSignedTransaction, TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { WalletConnectModal } from \"@walletconnect/modal\";\nimport type { SignClient } from \"@walletconnect/sign-client\";\nimport type { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport type { Transaction } from \"near-api-js/lib/transaction\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport {\n DEFAULT_APP_METADATA,\n DEFAULT_COSMOS_METHODS,\n DEFAULT_LOGGER,\n DEFAULT_RELAY_URL,\n THORCHAIN_MAINNET_ID,\n} from \"./constants\";\nimport { getEVMSigner } from \"./evmSigner\";\nimport { chainToChainId, getAddressByChain } from \"./helpers\";\nimport { getRequiredNamespaces } from \"./namespaces\";\n\nexport * from \"./constants\";\nexport * from \"./types\";\n\nexport const walletconnectWallet = createWallet({\n name: \"connectWalletconnect\",\n walletType: WalletOption.WALLETCONNECT,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Cosmos,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Maya,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectWalletconnect(\n chains: Chain[],\n walletconnectOptions?: SignClientTypes.Options,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { walletConnectProjectId } = SKConfig.get(\"apiKeys\");\n\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n\n const walletconnect = await getWalletconnect(\n filteredChains,\n walletConnectProjectId,\n walletconnectOptions,\n );\n\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const { accounts } = walletconnect;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const address = getAddressByChain(chain, accounts || []);\n const toolbox = await getToolbox({ address, chain, walletconnect });\n\n addChain({\n ...toolbox,\n address,\n chain,\n disconnect: walletconnect.disconnect,\n walletType: WalletOption.WALLETCONNECT,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const WC_SUPPORTED_CHAINS = getWalletSupportedChains(walletconnectWallet);\nexport type Walletconnect = Awaited<ReturnType<typeof getWalletconnect>>;\n\nasync function getToolbox<T extends (typeof WC_SUPPORTED_CHAINS)[number]>({\n chain,\n walletconnect,\n address,\n}: {\n walletconnect: Walletconnect;\n chain: T;\n address: string;\n}) {\n const session = walletconnect?.session;\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ walletconnect, chain, provider });\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return toolbox;\n }\n\n case Chain.THORChain: {\n const { SignMode } = await import(\"cosmjs-types/cosmos/tx/signing/v1beta1/signing.js\");\n const { TxRaw } = await import(\"cosmjs-types/cosmos/tx/v1beta1/tx.js\");\n\n const importedSigning = await import(\"@cosmjs/proto-signing\");\n const encodePubkey = importedSigning.encodePubkey ?? importedSigning.default?.encodePubkey;\n const makeAuthInfoBytes =\n importedSigning.makeAuthInfoBytes ?? importedSigning.default?.makeAuthInfoBytes;\n const importedAmino = await import(\"@cosmjs/amino\");\n const makeSignDoc = importedAmino.makeSignDoc ?? importedSigning.default?.makeSignDoc;\n\n const {\n getCosmosToolbox,\n buildAminoMsg,\n buildEncodedTxBody,\n createStargateClient,\n fromBase64,\n getDefaultChainFee,\n parseAminoMessageForDirectSigning,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n\n async function getAccount(accountAddress: string) {\n const cosmosToolbox = toolbox;\n const account = await (\n cosmosToolbox as Awaited<ReturnType<typeof createThorchainToolbox>>\n ).getAccount(accountAddress);\n\n if (chain !== Chain.THORChain) {\n return account;\n }\n\n const [{ address, algo, pubkey }] = (await walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n // @ts-ignore\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_GET_ACCOUNTS,\n params: {},\n },\n })) as [{ address: string; algo: string; pubkey: string }];\n\n return { ...account, address, pubkey: { type: algo, value: pubkey } };\n }\n\n const fee = getDefaultChainFee(chain);\n\n const signRequest = (signDoc: StdSignDoc) =>\n walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_SIGN_AMINO,\n params: { signerAddress: address, signDoc },\n },\n });\n\n async function thorchainTransfer({\n assetValue,\n memo,\n ...rest\n }: GenericTransferParams | ThorchainDepositParams) {\n const account = await toolbox.getAccount(address);\n if (!account) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { account } });\n }\n\n if (!account.pubkey) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { account, pubkey: account?.pubkey },\n });\n }\n\n const { accountNumber, sequence = 0 } = account;\n\n const msgs = [buildAminoMsg({ assetValue, memo, sender: address, ...rest })];\n\n const chainId = ChainId.THORChain;\n\n const signDoc = makeSignDoc(\n msgs,\n fee,\n chainId,\n memo,\n accountNumber?.toString(),\n sequence?.toString() || \"0\",\n );\n\n const signature: any = await signRequest(signDoc);\n\n const bodyBytes = await buildEncodedTxBody({\n chain: Chain.THORChain,\n msgs: msgs.map(parseAminoMessageForDirectSigning),\n memo: memo || \"\",\n });\n const pubkey = encodePubkey(account.pubkey);\n const authInfoBytes = makeAuthInfoBytes(\n [{ pubkey, sequence }],\n fee.amount,\n Number.parseInt(fee.gas),\n undefined,\n undefined,\n SignMode.SIGN_MODE_LEGACY_AMINO_JSON,\n );\n\n const txRaw = TxRaw.fromPartial({\n bodyBytes,\n authInfoBytes,\n signatures: [\n fromBase64(\n typeof signature.signature === \"string\"\n ? signature.signature\n : signature.signature.signature,\n ),\n ],\n });\n const txBytes = TxRaw.encode(txRaw).finish();\n\n const broadcaster = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const result = await broadcaster.broadcastTx(txBytes);\n return result.transactionHash;\n }\n\n return {\n ...toolbox,\n transfer: (params: GenericTransferParams) => thorchainTransfer(params),\n deposit: (params: ThorchainDepositParams) => thorchainTransfer(params),\n getAccount,\n };\n }\n\n case Chain.Near: {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const { DEFAULT_NEAR_METHODS } = await import(\"./constants\");\n\n // Create a NEAR signer that uses WalletConnect\n const signer = {\n getPublicKey() {\n // WalletConnect NEAR doesn't expose public key directly\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"getPublicKey\",\n }),\n );\n },\n\n signNep413Message(\n _message: string,\n _accountId: string,\n _recipient: string,\n _nonce: Uint8Array,\n _callbackUrl?: string,\n ) {\n // WalletConnect NEAR spec doesn't include NEP-413 message signing\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signNep413Message\",\n }),\n );\n },\n\n async signTransaction(transaction: Transaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n // WalletConnect signs and sends in one operation\n const result = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Near),\n request: {\n method: DEFAULT_NEAR_METHODS.NEAR_SIGN_AND_SEND_TRANSACTION,\n params: { transaction },\n },\n });\n // Return dummy hash and result\n return [new Uint8Array(32), result];\n },\n\n signDelegateAction(_delegateAction: any) {\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signDelegateAction\",\n }),\n );\n },\n\n getAddress() {\n return Promise.resolve(address);\n },\n } as NearSigner;\n\n const toolbox = await getNearToolbox({ signer });\n return toolbox;\n }\n\n case Chain.Tron: {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { DEFAULT_TRON_METHODS } = await import(\"./constants\");\n\n // Create a Tron signer that uses WalletConnect\n const signer: TronSigner = {\n getAddress() {\n return Promise.resolve(address);\n },\n\n async signTransaction(transaction: TronTransaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const signedTx = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Tron),\n request: {\n method: DEFAULT_TRON_METHODS.TRON_SIGN_TRANSACTION,\n params: { transaction },\n },\n });\n\n return signedTx as TronSignedTransaction;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n return toolbox;\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.WALLETCONNECT },\n });\n }\n}\n\nasync function getWalletconnect(\n chains: Chain[],\n walletConnectProjectId?: string,\n walletconnectOptions?: SignClientTypes.Options,\n) {\n let modal: WalletConnectModal | undefined;\n let signer: typeof SignClient | undefined;\n let session: SessionTypes.Struct | undefined;\n let accounts: string[] | undefined;\n try {\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n const requiredNamespaces = getRequiredNamespaces(chains.map(chainToChainId));\n\n const { SignClient } = await import(\"@walletconnect/sign-client\");\n const { WalletConnectModal } = await import(\"@walletconnect/modal\");\n\n const client = new SignClient({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n metadata: walletconnectOptions?.metadata || DEFAULT_APP_METADATA,\n ...walletconnectOptions?.core,\n });\n\n const modal = new WalletConnectModal({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n ...walletconnectOptions?.core,\n });\n\n const oldSession = await client.session.getAll()[0];\n\n // disconnect old Session cause we can't handle using it with current ui\n if (oldSession) {\n await client.disconnect({\n topic: oldSession.topic,\n reason: { code: 0, message: \"Resetting session\" },\n });\n }\n\n const { uri, approval } = await client.connect({\n // Optionally: pass a known prior pairing (e.g. from `client.core.pairing.getPairings()`) to skip the `uri` step.\n // pairingTopic: pairing?.topic,\n // Provide the namespaces and chains (e.g. `eip155` for EVM-based chains) we want to use in this session.\n requiredNamespaces,\n });\n\n if (uri) {\n modal.openModal({ uri });\n // Await session approval from the wallet.\n session = await approval();\n // Handle the returned session (e.g. update UI to \"connected\" state).\n // Close the QRCode modal in case it was open.\n modal.closeModal();\n\n function extractAccountsFromSession(session: SessionTypes.Struct) {\n const accounts: string[] = [];\n\n for (const [_namespace, data] of Object.entries(session.namespaces)) {\n accounts.push(...data.accounts);\n }\n\n return accounts;\n }\n\n accounts = extractAccountsFromSession(session);\n }\n\n const disconnect = async () => {\n session &&\n (await client.disconnect({\n topic: session.topic,\n reason: { code: 0, message: \"User disconnected\" },\n }));\n };\n\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n return { signer, session, accounts, client, disconnect };\n } catch (_e) {\n // Errors are handled by returning undefined\n } finally {\n if (modal) {\n modal.closeModal();\n }\n }\n return undefined;\n}\n",
6
6
  "import { type EVMChain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest, TransactionResponse } from \"ethers\";\nimport { AbstractSigner } from \"ethers\";\n\nimport { DEFAULT_EIP155_METHODS } from \"./constants\";\nimport { chainToChainId, getAddressByChain } from \"./helpers\";\nimport type { Walletconnect } from \"./index\";\n\ninterface WalletconnectEVMSignerParams {\n chain: EVMChain;\n walletconnect: Walletconnect;\n provider: Provider | JsonRpcProvider;\n}\n\nclass WalletconnectSigner extends AbstractSigner {\n address: string;\n\n private chain: EVMChain;\n private walletconnect: Walletconnect;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ chain, provider, walletconnect }: WalletconnectEVMSignerParams) {\n super(provider);\n this.chain = chain;\n this.walletconnect = walletconnect;\n this.provider = provider;\n this.address = \"\";\n }\n\n // biome-ignore lint/suspicious/useAwait: fulfil implementation type\n getAddress = async () => {\n if (!this.walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n if (!this.address) {\n this.address = getAddressByChain(this.chain, this.walletconnect.accounts || []);\n }\n\n return this.address;\n };\n\n signMessage = async (message: string) => {\n // this is probably broken\n const txHash = (await this.walletconnect?.client.request({\n chainId: chainToChainId(this.chain),\n topic: this.walletconnect.session.topic || \"\",\n request: {\n method: DEFAULT_EIP155_METHODS.ETH_SIGN,\n params: [message],\n },\n })) as string;\n\n return txHash.startsWith(\"0x\") ? txHash : `0x${txHash}`;\n };\n\n signTransaction = () => {\n throw new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signTransaction\",\n });\n\n // const baseTx = {\n // from,\n // to,\n // value: BigNumber.from(value || 0).toHexString(),\n // data,\n // };\n\n // const txHash = (await this.walletconnect?.client.request({\n // chainId: chainToChainId(this.chain),\n // topic: this.walletconnect.session.topic,\n // request: {\n // method: DEFAULT_EIP155_METHODS.ETH_SIGN_TRANSACTION,\n // params: [baseTx],\n // },\n // })) as string;\n\n // return txHash.startsWith('0x') ? txHash : `0x${txHash}`;\n };\n\n // ANCHOR (@Towan) - Implement in future\n signTypedData = () => {\n throw new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signTypedData\",\n });\n\n // const { toHexString } = await import('@swapkit/toolboxes/evm');\n\n // const baseTx = {\n // from,\n // to,\n // value: toHexString(value || 0n),\n // data,\n // };\n\n // const txHash = (await this.walletconnect?.client.request({\n // chainId: chainToChainId(this.chain),\n // topic: this.walletconnect.session.topic,\n // request: {\n // method: DEFAULT_EIP155_METHODS.ETH_SIGN_TYPED_DATA,\n // params: [baseTx],\n // },\n // })) as string;\n\n // return txHash.startsWith('0x') ? txHash : `0x${txHash}`;\n };\n\n sendTransaction = async ({ from, to, value, data }: TransactionRequest) => {\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n const baseTx = {\n from,\n to,\n value: toHexString(BigInt(value || 0)),\n data,\n };\n const response = await this.walletconnect?.client.request({\n chainId: chainToChainId(this.chain),\n topic: this.walletconnect.session.topic,\n request: {\n method: DEFAULT_EIP155_METHODS.ETH_SEND_TRANSACTION,\n params: [baseTx],\n },\n });\n\n return response as TransactionResponse;\n };\n\n connect = (provider: Provider | null) => {\n if (!provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.WALLETCONNECT, chain: this.chain },\n });\n }\n\n return new WalletconnectSigner({\n chain: this.chain,\n walletconnect: this.walletconnect,\n provider,\n });\n };\n}\nexport const getEVMSigner = async ({\n chain,\n walletconnect,\n provider,\n}: WalletconnectEVMSignerParams) => new WalletconnectSigner({ chain, walletconnect, provider });\n",
7
7
  "import { Chain, type EVMChain, SKConfig } from \"@swapkit/helpers\";\n\nimport {\n ARBITRUM_ONE_MAINNET_ID,\n AURORA_MAINNET_ID,\n AVALANCHE_MAINNET_ID,\n BASE_MAINNET_ID,\n BERACHAIN_MAINNET_ID,\n BSC_MAINNET_ID,\n COSMOS_HUB_MAINNET_ID,\n ETHEREUM_MAINNET_ID,\n KUJIRA_MAINNET_ID,\n MAYACHAIN_MAINNET_ID,\n NEAR_MAINNET_ID,\n NEAR_TESTNET_ID,\n OPTIMISM_MAINNET_ID,\n POLYGON_MAINNET_ID,\n THORCHAIN_MAINNET_ID,\n TRON_MAINNET_ID,\n} from \"./constants\";\n\nexport const getAddressByChain = (\n chain:\n | EVMChain\n | Chain.THORChain\n | Chain.Maya\n | Chain.Kujira\n | Chain.Cosmos\n | Chain.Near\n | Chain.Tron,\n accounts: string[],\n) => {\n const account = accounts.find((account) => account.startsWith(chainToChainId(chain))) || \"\";\n const address = account?.split(\":\")?.[2];\n\n return address || \"\";\n};\n\nexport const chainToChainId = (chain: Chain) => {\n switch (chain) {\n case Chain.Avalanche:\n return AVALANCHE_MAINNET_ID;\n case Chain.Aurora:\n return AURORA_MAINNET_ID;\n case Chain.Base:\n return BASE_MAINNET_ID;\n case Chain.BinanceSmartChain:\n return BSC_MAINNET_ID;\n case Chain.Berachain:\n return BERACHAIN_MAINNET_ID;\n case Chain.Ethereum:\n return ETHEREUM_MAINNET_ID;\n case Chain.THORChain:\n return THORCHAIN_MAINNET_ID;\n case Chain.Arbitrum:\n return ARBITRUM_ONE_MAINNET_ID;\n case Chain.Optimism:\n return OPTIMISM_MAINNET_ID;\n case Chain.Polygon:\n return POLYGON_MAINNET_ID;\n case Chain.Maya:\n return MAYACHAIN_MAINNET_ID;\n case Chain.Cosmos:\n return COSMOS_HUB_MAINNET_ID;\n case Chain.Kujira:\n return KUJIRA_MAINNET_ID;\n case Chain.Near: {\n // Use testnet if stagenet is enabled\n const { isStagenet } = SKConfig.get(\"envs\");\n return isStagenet ? NEAR_TESTNET_ID : NEAR_MAINNET_ID;\n }\n case Chain.Tron:\n return TRON_MAINNET_ID;\n default:\n return \"\";\n }\n};\n",
8
8
  "import type { ProposalTypes } from \"@walletconnect/types\";\n\nimport { SwapKitError } from \"@swapkit/helpers\";\nimport {\n DEFAULT_COSMOS_METHODS,\n DEFAULT_EIP155_METHODS,\n DEFAULT_EIP_155_EVENTS,\n DEFAULT_NEAR_EVENTS,\n DEFAULT_NEAR_METHODS,\n DEFAULT_POLKADOT_EVENTS,\n DEFAULT_POLKADOT_METHODS,\n DEFAULT_SOLANA_EVENTS,\n DEFAULT_SOLANA_METHODS,\n DEFAULT_TRON_EVENTS,\n DEFAULT_TRON_METHODS,\n} from \"./constants\";\n\nexport const getNamespacesFromChains = (chains: string[]) => {\n const supportedNamespaces: string[] = [];\n for (const chainId of chains) {\n const [namespace] = chainId.split(\":\");\n if (namespace && !supportedNamespaces.includes(namespace)) {\n supportedNamespaces.push(namespace);\n }\n }\n\n return supportedNamespaces;\n};\n\nexport const getSupportedMethodsByNamespace = (namespace: string) => {\n switch (namespace) {\n case \"eip155\":\n return Object.values(DEFAULT_EIP155_METHODS);\n case \"cosmos\":\n return Object.values(DEFAULT_COSMOS_METHODS);\n case \"solana\":\n return Object.values(DEFAULT_SOLANA_METHODS);\n case \"polkadot\":\n return Object.values(DEFAULT_POLKADOT_METHODS);\n case \"near\":\n return Object.values(DEFAULT_NEAR_METHODS);\n case \"tron\":\n return Object.values(DEFAULT_TRON_METHODS);\n default:\n throw new SwapKitError({\n errorKey: \"wallet_walletconnect_namespace_not_supported\",\n info: { namespace },\n });\n }\n};\n\nexport const getSupportedEventsByNamespace = (namespace: string) => {\n switch (namespace) {\n case \"eip155\":\n return Object.values(DEFAULT_EIP_155_EVENTS);\n case \"cosmos\":\n return [];\n case \"solana\":\n return Object.values(DEFAULT_SOLANA_EVENTS);\n case \"polkadot\":\n return Object.values(DEFAULT_POLKADOT_EVENTS);\n case \"near\":\n return Object.values(DEFAULT_NEAR_EVENTS);\n case \"tron\":\n return Object.values(DEFAULT_TRON_EVENTS);\n default:\n throw new SwapKitError({\n errorKey: \"wallet_walletconnect_namespace_not_supported\",\n info: { namespace },\n });\n }\n};\n\nexport const getRequiredNamespaces = (chains: string[]): ProposalTypes.RequiredNamespaces => {\n const selectedNamespaces = getNamespacesFromChains(chains);\n\n return Object.fromEntries(\n selectedNamespaces.map((namespace) => [\n namespace,\n {\n methods: getSupportedMethodsByNamespace(namespace),\n chains: chains.filter((chain) => chain.startsWith(namespace)),\n events: getSupportedEventsByNamespace(namespace) as any[],\n },\n ]),\n );\n};\n"
9
9
  ],
10
- "mappings": "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",
11
- "debugId": "35CD9443B67F98E464756E2164756E21",
10
+ "mappings": "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",
11
+ "debugId": "F186B125A3AE36F964756E2164756E21",
12
12
  "names": []
13
13
  }
@@ -1,4 +1,4 @@
1
- import{A as v5,B as y5,C as G5,D as J5,E as K5,a as N,b as s,c as I,d as e,e as W,f as t,g as c,h as o,i,j as a,k as n,l as L5,m as O5,n as j5,o as F5,p as f5,q as V5,r as g,s as Y5,t as M,u as z5,v as A,w as ZL,x as Q5,y as X5,z as Z5}from"../../chunk-mvbb9fwb.js";import{H as p5}from"../../chunk-htvthkj1.js";import{J as Z,K as v}from"../../chunk-p2ca0j1v.js";import{Chain as j,ChainId as x5,SKConfig as b5,SwapKitError as y,WalletOption as C,createWallet as M5,filterSupportedChains as m5}from"@swapkit/helpers";import{SwapKitError as _,WalletOption as H5}from"@swapkit/helpers";import{AbstractSigner as r5}from"ethers";import{Chain as X,SKConfig as _5}from"@swapkit/helpers";var R=(L,O)=>{return(O.find((z)=>z.startsWith(b(L)))||"")?.split(":")?.[2]||""},b=(L)=>{switch(L){case X.Avalanche:return e;case X.Aurora:return f5;case X.Base:return L5;case X.BinanceSmartChain:return I;case X.Berachain:return V5;case X.Ethereum:return s;case X.THORChain:return W;case X.Arbitrum:return i;case X.Optimism:return a;case X.Polygon:return n;case X.Maya:return o;case X.Cosmos:return t;case X.Kujira:return c;case X.Near:{let{isStagenet:O}=_5.get("envs");return O?j5:O5}case X.Tron:return F5;default:return""}};class m extends r5{address;chain;walletconnect;provider;constructor({chain:L,provider:O,walletconnect:F}){super(O);this.chain=L,this.walletconnect=F,this.provider=O,this.address=""}getAddress=async()=>{if(!this.walletconnect)throw new _("wallet_walletconnect_connection_not_established");if(!this.address)this.address=R(this.chain,this.walletconnect.accounts||[]);return this.address};signMessage=async(L)=>{let O=await this.walletconnect?.client.request({chainId:b(this.chain),topic:this.walletconnect.session.topic||"",request:{method:"eth_sign",params:[L]}});return O.startsWith("0x")?O:`0x${O}`};signTransaction=()=>{throw new _("wallet_walletconnect_method_not_supported",{method:"signTransaction"})};signTypedData=()=>{throw new _("wallet_walletconnect_method_not_supported",{method:"signTypedData"})};sendTransaction=async({from:L,to:O,value:F,data:V})=>{let{toHexString:z}=await import("@swapkit/toolboxes/evm"),f={from:L,to:O,value:z(BigInt(F||0)),data:V};return await this.walletconnect?.client.request({chainId:b(this.chain),topic:this.walletconnect.session.topic,request:{method:"eth_sendTransaction",params:[f]}})};connect=(L)=>{if(!L)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:H5.WALLETCONNECT,chain:this.chain}});return new m({chain:this.chain,walletconnect:this.walletconnect,provider:L})}}var U5=async({chain:L,walletconnect:O,provider:F})=>new m({chain:L,walletconnect:O,provider:F});import{SwapKitError as $5}from"@swapkit/helpers";var w5=(L)=>{let O=[];for(let F of L){let[V]=F.split(":");if(V&&!O.includes(V))O.push(V)}return O},T5=(L)=>{switch(L){case"eip155":return Object.values(M);case"cosmos":return Object.values(A);case"solana":return Object.values(Q5);case"polkadot":return Object.values(Z5);case"near":return Object.values(y5);case"tron":return Object.values(J5);default:throw new $5({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:L}})}},S5=(L)=>{switch(L){case"eip155":return Object.values(z5);case"cosmos":return[];case"solana":return Object.values(X5);case"polkadot":return Object.values(v5);case"near":return Object.values(G5);case"tron":return Object.values(K5);default:throw new $5({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:L}})}},q5=(L)=>{let O=w5(L);return Object.fromEntries(O.map((F)=>[F,{methods:T5(F),chains:L.filter((V)=>V.startsWith(F)),events:S5(F)}]))};var A5=M5({name:"connectWalletconnect",walletType:C.WALLETCONNECT,supportedChains:[j.Arbitrum,j.Aurora,j.Avalanche,j.Base,j.Berachain,j.BinanceSmartChain,j.Cosmos,j.Ethereum,j.Kujira,j.Maya,j.Near,j.Optimism,j.Polygon,j.THORChain,j.Tron],connect:({addChain:L,supportedChains:O,walletType:F})=>async function V(z,f){let U=m5({chains:z,supportedChains:O,walletType:F}),{walletConnectProjectId:J}=b5.get("apiKeys");if(!J)throw new y("wallet_walletconnect_project_id_not_specified");let Q=await g5(U,J,f);if(!Q)throw new y("wallet_walletconnect_connection_not_established");let{accounts:q}=Q;return await Promise.all(U.map(async(G)=>{let Y=R(G,q||[]),p=await N5({address:Y,chain:G,walletconnect:Q});L({...p,address:Y,chain:G,disconnect:Q.disconnect,walletType:C.WALLETCONNECT})})),!0}}),UL=p5(A5);async function N5({chain:L,walletconnect:O,address:F}){let V=O?.session;if(!V)throw new y("wallet_walletconnect_connection_not_established");switch(L){case j.Arbitrum:case j.Avalanche:case j.Base:case j.BinanceSmartChain:case j.Ethereum:case j.Optimism:case j.Polygon:{let{getProvider:z,getEvmToolbox:f}=await import("@swapkit/toolboxes/evm"),U=await z(L),J=await U5({walletconnect:O,chain:L,provider:U});return await f(L,{provider:U,signer:J})}case j.THORChain:{let{SignMode:z}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:f}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),U=await import("@cosmjs/proto-signing"),J=U.encodePubkey??U.default?.encodePubkey,Q=U.makeAuthInfoBytes??U.default?.makeAuthInfoBytes,G=(await import("@cosmjs/amino")).makeSignDoc??U.default?.makeSignDoc,{getCosmosToolbox:Y,buildAminoMsg:p,buildEncodedTxBody:u,createStargateClient:H,fromBase64:r,getDefaultChainFee:w,parseAminoMessageForDirectSigning:T}=await import("@swapkit/toolboxes/cosmos"),k=await Y(j.THORChain);async function d(K){let B=await k.getAccount(K);if(L!==j.THORChain)return B;let[{address:$,algo:S,pubkey:D}]=await O?.client.request({chainId:W,topic:V.topic,request:{method:"cosmos_getAccounts",params:{}}});return{...B,address:$,pubkey:{type:S,value:D}}}let P=w(L),k5=(K)=>O?.client.request({chainId:W,topic:V.topic,request:{method:"cosmos_signAmino",params:{signerAddress:F,signDoc:K}}});async function h({assetValue:K,memo:E,...B}){let $=await k.getAccount(F);if(!$)throw new y({errorKey:"wallet_missing_params",info:{account:$}});if(!$.pubkey)throw new y({errorKey:"wallet_missing_params",info:{account:$,pubkey:$?.pubkey}});let{accountNumber:S,sequence:D=0}=$,l=[p({assetValue:K,memo:E,sender:F,...B})],P5=x5.THORChain,W5=G(l,P,P5,E,S?.toString(),D?.toString()||"0"),x=await k5(W5),u5=await u({chain:j.THORChain,msgs:l.map(T),memo:E||""}),E5=J($.pubkey),B5=Q([{pubkey:E5,sequence:D}],P.amount,Number.parseInt(P.gas),void 0,void 0,z.SIGN_MODE_LEGACY_AMINO_JSON),D5=f.fromPartial({bodyBytes:u5,authInfoBytes:B5,signatures:[r(typeof x.signature==="string"?x.signature:x.signature.signature)]}),R5=f.encode(D5).finish();return(await(await H(b5.get("rpcUrls")[j.THORChain])).broadcastTx(R5)).transactionHash}return{...k,transfer:(K)=>h(K),deposit:(K)=>h(K),getAccount:d}}case j.Near:{let{getNearToolbox:z}=await import("@swapkit/toolboxes/near"),{DEFAULT_NEAR_METHODS:f}=await import("../../chunk-mvbb9fwb.js");return await z({signer:{getPublicKey(){return Promise.reject(new y("wallet_walletconnect_method_not_supported",{method:"getPublicKey"}))},signNep413Message(Q,q,G,Y,p){return Promise.reject(new y("wallet_walletconnect_method_not_supported",{method:"signNep413Message"}))},async signTransaction(Q){if(!O)throw new y("wallet_walletconnect_connection_not_established");let q=await O.client.request({topic:V.topic,chainId:b(j.Near),request:{method:f.NEAR_SIGN_AND_SEND_TRANSACTION,params:{transaction:Q}}});return[new Uint8Array(32),q]},signDelegateAction(Q){return Promise.reject(new y("wallet_walletconnect_method_not_supported",{method:"signDelegateAction"}))},getAddress(){return Promise.resolve(F)}}})}case j.Tron:{let{createTronToolbox:z}=await import("@swapkit/toolboxes/tron"),{DEFAULT_TRON_METHODS:f}=await import("../../chunk-mvbb9fwb.js");return await z({signer:{getAddress(){return Promise.resolve(F)},async signTransaction(Q){if(!O)throw new y("wallet_walletconnect_connection_not_established");return await O.client.request({topic:V.topic,chainId:b(j.Tron),request:{method:f.TRON_SIGN_TRANSACTION,params:{transaction:Q}}})}}})}default:throw new y({errorKey:"wallet_chain_not_supported",info:{chain:L,wallet:C.WALLETCONNECT}})}}async function g5(L,O,F){let V,z,f,U;try{if(!O)throw new y("wallet_walletconnect_project_id_not_specified");let J=q5(L.map(b)),{SignClient:Q}=await import("@walletconnect/sign-client"),{WalletConnectModal:q}=await import("@walletconnect/modal"),G=new Q({logger:g,relayUrl:N,projectId:O,metadata:F?.metadata||Y5,...F?.core}),Y=new q({logger:g,relayUrl:N,projectId:O,...F?.core}),p=await G.session.getAll()[0];if(p)await G.disconnect({topic:p.topic,reason:{code:0,message:"Resetting session"}});let{uri:u,approval:H}=await G.connect({requiredNamespaces:J});if(u){let w=function(T){let k=[];for(let[d,P]of Object.entries(T.namespaces))k.push(...P.accounts);return k};Y.openModal({uri:u}),f=await H(),Y.closeModal(),U=w(f)}let r=async()=>{f&&await G.disconnect({topic:f.topic,reason:{code:0,message:"User disconnected"}})};if(!f)throw new y("wallet_walletconnect_connection_not_established");return{signer:z,session:f,accounts:U,client:G,disconnect:r}}catch(J){}finally{if(V)V.closeModal()}return}export{A5 as walletconnectWallet,UL as WC_SUPPORTED_CHAINS,F5 as TRON_MAINNET_ID,W as THORCHAIN_MAINNET_ID,n as POLYGON_MAINNET_ID,a as OPTIMISM_MAINNET_ID,j5 as NEAR_TESTNET_ID,O5 as NEAR_MAINNET_ID,o as MAYACHAIN_MAINNET_ID,c as KUJIRA_MAINNET_ID,s as ETHEREUM_MAINNET_ID,J5 as DEFAULT_TRON_METHODS,K5 as DEFAULT_TRON_EVENTS,Q5 as DEFAULT_SOLANA_METHODS,X5 as DEFAULT_SOLANA_EVENTS,N as DEFAULT_RELAY_URL,Z5 as DEFAULT_POLKADOT_METHODS,v5 as DEFAULT_POLKADOT_EVENTS,y5 as DEFAULT_NEAR_METHODS,G5 as DEFAULT_NEAR_EVENTS,g as DEFAULT_LOGGER,z5 as DEFAULT_EIP_155_EVENTS,M as DEFAULT_EIP155_METHODS,A as DEFAULT_COSMOS_METHODS,ZL as DEFAULT_COSMOS_EVENTS,Y5 as DEFAULT_APP_METADATA,t as COSMOS_HUB_MAINNET_ID,I as BSC_MAINNET_ID,V5 as BERACHAIN_MAINNET_ID,L5 as BASE_MAINNET_ID,e as AVALANCHE_MAINNET_ID,f5 as AURORA_MAINNET_ID,i as ARBITRUM_ONE_MAINNET_ID};
1
+ import{A as v5,B as y5,C as G5,D as J5,E as K5,a as N,b as s,c as I,d as e,e as W,f as t,g as c,h as o,i,j as a,k as n,l as L5,m as O5,n as j5,o as F5,p as f5,q as V5,r as g,s as Y5,t as M,u as z5,v as A,w as ZL,x as Q5,y as X5,z as Z5}from"../../chunk-sbf0f2p4.js";import{F as Z,G as v}from"../../chunk-yqaz2d25.js";import{Chain as j,ChainId as S5,SKConfig as b5,SwapKitError as y,WalletOption as C,filterSupportedChains as x5}from"@swapkit/helpers";import{createWallet as M5,getWalletSupportedChains as m5}from"@swapkit/wallet-core";import{SwapKitError as _,WalletOption as _5}from"@swapkit/helpers";import{AbstractSigner as H5}from"ethers";import{Chain as X,SKConfig as R5}from"@swapkit/helpers";var R=(L,O)=>{return(O.find((z)=>z.startsWith(b(L)))||"")?.split(":")?.[2]||""},b=(L)=>{switch(L){case X.Avalanche:return e;case X.Aurora:return f5;case X.Base:return L5;case X.BinanceSmartChain:return I;case X.Berachain:return V5;case X.Ethereum:return s;case X.THORChain:return W;case X.Arbitrum:return i;case X.Optimism:return a;case X.Polygon:return n;case X.Maya:return o;case X.Cosmos:return t;case X.Kujira:return c;case X.Near:{let{isStagenet:O}=R5.get("envs");return O?j5:O5}case X.Tron:return F5;default:return""}};class m extends H5{address;chain;walletconnect;provider;constructor({chain:L,provider:O,walletconnect:F}){super(O);this.chain=L,this.walletconnect=F,this.provider=O,this.address=""}getAddress=async()=>{if(!this.walletconnect)throw new _("wallet_walletconnect_connection_not_established");if(!this.address)this.address=R(this.chain,this.walletconnect.accounts||[]);return this.address};signMessage=async(L)=>{let O=await this.walletconnect?.client.request({chainId:b(this.chain),topic:this.walletconnect.session.topic||"",request:{method:"eth_sign",params:[L]}});return O.startsWith("0x")?O:`0x${O}`};signTransaction=()=>{throw new _("wallet_walletconnect_method_not_supported",{method:"signTransaction"})};signTypedData=()=>{throw new _("wallet_walletconnect_method_not_supported",{method:"signTypedData"})};sendTransaction=async({from:L,to:O,value:F,data:V})=>{let{toHexString:z}=await import("@swapkit/toolboxes/evm"),f={from:L,to:O,value:z(BigInt(F||0)),data:V};return await this.walletconnect?.client.request({chainId:b(this.chain),topic:this.walletconnect.session.topic,request:{method:"eth_sendTransaction",params:[f]}})};connect=(L)=>{if(!L)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:_5.WALLETCONNECT,chain:this.chain}});return new m({chain:this.chain,walletconnect:this.walletconnect,provider:L})}}var U5=async({chain:L,walletconnect:O,provider:F})=>new m({chain:L,walletconnect:O,provider:F});import{SwapKitError as $5}from"@swapkit/helpers";var r5=(L)=>{let O=[];for(let F of L){let[V]=F.split(":");if(V&&!O.includes(V))O.push(V)}return O},w5=(L)=>{switch(L){case"eip155":return Object.values(M);case"cosmos":return Object.values(A);case"solana":return Object.values(Q5);case"polkadot":return Object.values(Z5);case"near":return Object.values(y5);case"tron":return Object.values(J5);default:throw new $5({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:L}})}},T5=(L)=>{switch(L){case"eip155":return Object.values(z5);case"cosmos":return[];case"solana":return Object.values(X5);case"polkadot":return Object.values(v5);case"near":return Object.values(G5);case"tron":return Object.values(K5);default:throw new $5({errorKey:"wallet_walletconnect_namespace_not_supported",info:{namespace:L}})}},q5=(L)=>{let O=r5(L);return Object.fromEntries(O.map((F)=>[F,{methods:w5(F),chains:L.filter((V)=>V.startsWith(F)),events:T5(F)}]))};var A5=M5({name:"connectWalletconnect",walletType:C.WALLETCONNECT,supportedChains:[j.Arbitrum,j.Aurora,j.Avalanche,j.Base,j.Berachain,j.BinanceSmartChain,j.Cosmos,j.Ethereum,j.Kujira,j.Maya,j.Near,j.Optimism,j.Polygon,j.THORChain,j.Tron],connect:({addChain:L,supportedChains:O,walletType:F})=>async function V(z,f){let U=x5({chains:z,supportedChains:O,walletType:F}),{walletConnectProjectId:J}=b5.get("apiKeys");if(!J)throw new y("wallet_walletconnect_project_id_not_specified");let Q=await g5(U,J,f);if(!Q)throw new y("wallet_walletconnect_connection_not_established");let{accounts:q}=Q;return await Promise.all(U.map(async(G)=>{let Y=R(G,q||[]),p=await N5({address:Y,chain:G,walletconnect:Q});L({...p,address:Y,chain:G,disconnect:Q.disconnect,walletType:C.WALLETCONNECT})})),!0}}),UL=m5(A5);async function N5({chain:L,walletconnect:O,address:F}){let V=O?.session;if(!V)throw new y("wallet_walletconnect_connection_not_established");switch(L){case j.Arbitrum:case j.Avalanche:case j.Base:case j.BinanceSmartChain:case j.Ethereum:case j.Optimism:case j.Polygon:{let{getProvider:z,getEvmToolbox:f}=await import("@swapkit/toolboxes/evm"),U=await z(L),J=await U5({walletconnect:O,chain:L,provider:U});return await f(L,{provider:U,signer:J})}case j.THORChain:{let{SignMode:z}=await import("cosmjs-types/cosmos/tx/signing/v1beta1/signing.js"),{TxRaw:f}=await import("cosmjs-types/cosmos/tx/v1beta1/tx.js"),U=await import("@cosmjs/proto-signing"),J=U.encodePubkey??U.default?.encodePubkey,Q=U.makeAuthInfoBytes??U.default?.makeAuthInfoBytes,G=(await import("@cosmjs/amino")).makeSignDoc??U.default?.makeSignDoc,{getCosmosToolbox:Y,buildAminoMsg:p,buildEncodedTxBody:u,createStargateClient:H,fromBase64:r,getDefaultChainFee:w,parseAminoMessageForDirectSigning:T}=await import("@swapkit/toolboxes/cosmos"),k=await Y(j.THORChain);async function d(K){let B=await k.getAccount(K);if(L!==j.THORChain)return B;let[{address:$,algo:S,pubkey:D}]=await O?.client.request({chainId:W,topic:V.topic,request:{method:"cosmos_getAccounts",params:{}}});return{...B,address:$,pubkey:{type:S,value:D}}}let P=w(L),p5=(K)=>O?.client.request({chainId:W,topic:V.topic,request:{method:"cosmos_signAmino",params:{signerAddress:F,signDoc:K}}});async function h({assetValue:K,memo:E,...B}){let $=await k.getAccount(F);if(!$)throw new y({errorKey:"wallet_missing_params",info:{account:$}});if(!$.pubkey)throw new y({errorKey:"wallet_missing_params",info:{account:$,pubkey:$?.pubkey}});let{accountNumber:S,sequence:D=0}=$,l=[p({assetValue:K,memo:E,sender:F,...B})],k5=S5.THORChain,P5=G(l,P,k5,E,S?.toString(),D?.toString()||"0"),x=await p5(P5),W5=await u({chain:j.THORChain,msgs:l.map(T),memo:E||""}),u5=J($.pubkey),E5=Q([{pubkey:u5,sequence:D}],P.amount,Number.parseInt(P.gas),void 0,void 0,z.SIGN_MODE_LEGACY_AMINO_JSON),B5=f.fromPartial({bodyBytes:W5,authInfoBytes:E5,signatures:[r(typeof x.signature==="string"?x.signature:x.signature.signature)]}),D5=f.encode(B5).finish();return(await(await H(b5.get("rpcUrls")[j.THORChain])).broadcastTx(D5)).transactionHash}return{...k,transfer:(K)=>h(K),deposit:(K)=>h(K),getAccount:d}}case j.Near:{let{getNearToolbox:z}=await import("@swapkit/toolboxes/near"),{DEFAULT_NEAR_METHODS:f}=await import("../../chunk-sbf0f2p4.js");return await z({signer:{getPublicKey(){return Promise.reject(new y("wallet_walletconnect_method_not_supported",{method:"getPublicKey"}))},signNep413Message(Q,q,G,Y,p){return Promise.reject(new y("wallet_walletconnect_method_not_supported",{method:"signNep413Message"}))},async signTransaction(Q){if(!O)throw new y("wallet_walletconnect_connection_not_established");let q=await O.client.request({topic:V.topic,chainId:b(j.Near),request:{method:f.NEAR_SIGN_AND_SEND_TRANSACTION,params:{transaction:Q}}});return[new Uint8Array(32),q]},signDelegateAction(Q){return Promise.reject(new y("wallet_walletconnect_method_not_supported",{method:"signDelegateAction"}))},getAddress(){return Promise.resolve(F)}}})}case j.Tron:{let{createTronToolbox:z}=await import("@swapkit/toolboxes/tron"),{DEFAULT_TRON_METHODS:f}=await import("../../chunk-sbf0f2p4.js");return await z({signer:{getAddress(){return Promise.resolve(F)},async signTransaction(Q){if(!O)throw new y("wallet_walletconnect_connection_not_established");return await O.client.request({topic:V.topic,chainId:b(j.Tron),request:{method:f.TRON_SIGN_TRANSACTION,params:{transaction:Q}}})}}})}default:throw new y({errorKey:"wallet_chain_not_supported",info:{chain:L,wallet:C.WALLETCONNECT}})}}async function g5(L,O,F){let V,z,f,U;try{if(!O)throw new y("wallet_walletconnect_project_id_not_specified");let J=q5(L.map(b)),{SignClient:Q}=await import("@walletconnect/sign-client"),{WalletConnectModal:q}=await import("@walletconnect/modal"),G=new Q({logger:g,relayUrl:N,projectId:O,metadata:F?.metadata||Y5,...F?.core}),Y=new q({logger:g,relayUrl:N,projectId:O,...F?.core}),p=await G.session.getAll()[0];if(p)await G.disconnect({topic:p.topic,reason:{code:0,message:"Resetting session"}});let{uri:u,approval:H}=await G.connect({requiredNamespaces:J});if(u){let w=function(T){let k=[];for(let[d,P]of Object.entries(T.namespaces))k.push(...P.accounts);return k};Y.openModal({uri:u}),f=await H(),Y.closeModal(),U=w(f)}let r=async()=>{f&&await G.disconnect({topic:f.topic,reason:{code:0,message:"User disconnected"}})};if(!f)throw new y("wallet_walletconnect_connection_not_established");return{signer:z,session:f,accounts:U,client:G,disconnect:r}}catch(J){}finally{if(V)V.closeModal()}return}export{A5 as walletconnectWallet,UL as WC_SUPPORTED_CHAINS,F5 as TRON_MAINNET_ID,W as THORCHAIN_MAINNET_ID,n as POLYGON_MAINNET_ID,a as OPTIMISM_MAINNET_ID,j5 as NEAR_TESTNET_ID,O5 as NEAR_MAINNET_ID,o as MAYACHAIN_MAINNET_ID,c as KUJIRA_MAINNET_ID,s as ETHEREUM_MAINNET_ID,J5 as DEFAULT_TRON_METHODS,K5 as DEFAULT_TRON_EVENTS,Q5 as DEFAULT_SOLANA_METHODS,X5 as DEFAULT_SOLANA_EVENTS,N as DEFAULT_RELAY_URL,Z5 as DEFAULT_POLKADOT_METHODS,v5 as DEFAULT_POLKADOT_EVENTS,y5 as DEFAULT_NEAR_METHODS,G5 as DEFAULT_NEAR_EVENTS,g as DEFAULT_LOGGER,z5 as DEFAULT_EIP_155_EVENTS,M as DEFAULT_EIP155_METHODS,A as DEFAULT_COSMOS_METHODS,ZL as DEFAULT_COSMOS_EVENTS,Y5 as DEFAULT_APP_METADATA,t as COSMOS_HUB_MAINNET_ID,I as BSC_MAINNET_ID,V5 as BERACHAIN_MAINNET_ID,L5 as BASE_MAINNET_ID,e as AVALANCHE_MAINNET_ID,f5 as AURORA_MAINNET_ID,i as ARBITRUM_ONE_MAINNET_ID};
2
2
 
3
- //# debugId=46B82982ED834F7964756E2164756E21
3
+ //# debugId=6ACC42B1DDF41FF364756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,12 +2,12 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/walletconnect/index.ts", "../src/walletconnect/evmSigner.ts", "../src/walletconnect/helpers.ts", "../src/walletconnect/namespaces.ts"],
4
4
  "sourcesContent": [
5
- "import type { StdSignDoc } from \"@cosmjs/amino\";\nimport {\n Chain,\n ChainId,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams, createThorchainToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { NearSigner } from \"@swapkit/toolboxes/near\";\nimport type { TronSignedTransaction, TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { WalletConnectModal } from \"@walletconnect/modal\";\nimport type { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport type { Transaction } from \"near-api-js/lib/transaction\";\n\nimport type { SignClient } from \"@walletconnect/sign-client\";\nimport { getWalletSupportedChains } from \"../utils\";\nimport {\n DEFAULT_APP_METADATA,\n DEFAULT_COSMOS_METHODS,\n DEFAULT_LOGGER,\n DEFAULT_RELAY_URL,\n THORCHAIN_MAINNET_ID,\n} from \"./constants\";\nimport { getEVMSigner } from \"./evmSigner\";\nimport { chainToChainId, getAddressByChain } from \"./helpers\";\nimport { getRequiredNamespaces } from \"./namespaces\";\n\nexport * from \"./constants\";\nexport * from \"./types\";\n\nexport const walletconnectWallet = createWallet({\n name: \"connectWalletconnect\",\n walletType: WalletOption.WALLETCONNECT,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Cosmos,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Maya,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectWalletconnect(\n chains: Chain[],\n walletconnectOptions?: SignClientTypes.Options,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { walletConnectProjectId } = SKConfig.get(\"apiKeys\");\n\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n\n const walletconnect = await getWalletconnect(\n filteredChains,\n walletConnectProjectId,\n walletconnectOptions,\n );\n\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const { accounts } = walletconnect;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const address = getAddressByChain(chain, accounts || []);\n const toolbox = await getToolbox({ address, chain, walletconnect });\n\n addChain({\n ...toolbox,\n address,\n chain,\n disconnect: walletconnect.disconnect,\n walletType: WalletOption.WALLETCONNECT,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const WC_SUPPORTED_CHAINS = getWalletSupportedChains(walletconnectWallet);\nexport type Walletconnect = Awaited<ReturnType<typeof getWalletconnect>>;\n\nasync function getToolbox<T extends (typeof WC_SUPPORTED_CHAINS)[number]>({\n chain,\n walletconnect,\n address,\n}: {\n walletconnect: Walletconnect;\n chain: T;\n address: string;\n}) {\n const session = walletconnect?.session;\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ walletconnect, chain, provider });\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return toolbox;\n }\n\n case Chain.THORChain: {\n const { SignMode } = await import(\"cosmjs-types/cosmos/tx/signing/v1beta1/signing.js\");\n const { TxRaw } = await import(\"cosmjs-types/cosmos/tx/v1beta1/tx.js\");\n\n const importedSigning = await import(\"@cosmjs/proto-signing\");\n const encodePubkey = importedSigning.encodePubkey ?? importedSigning.default?.encodePubkey;\n const makeAuthInfoBytes =\n importedSigning.makeAuthInfoBytes ?? importedSigning.default?.makeAuthInfoBytes;\n const importedAmino = await import(\"@cosmjs/amino\");\n const makeSignDoc = importedAmino.makeSignDoc ?? importedSigning.default?.makeSignDoc;\n\n const {\n getCosmosToolbox,\n buildAminoMsg,\n buildEncodedTxBody,\n createStargateClient,\n fromBase64,\n getDefaultChainFee,\n parseAminoMessageForDirectSigning,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n\n async function getAccount(accountAddress: string) {\n const cosmosToolbox = toolbox;\n const account = await (\n cosmosToolbox as Awaited<ReturnType<typeof createThorchainToolbox>>\n ).getAccount(accountAddress);\n\n if (chain !== Chain.THORChain) {\n return account;\n }\n\n const [{ address, algo, pubkey }] = (await walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n // @ts-ignore\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_GET_ACCOUNTS,\n params: {},\n },\n })) as [{ address: string; algo: string; pubkey: string }];\n\n return { ...account, address, pubkey: { type: algo, value: pubkey } };\n }\n\n const fee = getDefaultChainFee(chain);\n\n const signRequest = (signDoc: StdSignDoc) =>\n walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_SIGN_AMINO,\n params: { signerAddress: address, signDoc },\n },\n });\n\n async function thorchainTransfer({\n assetValue,\n memo,\n ...rest\n }: GenericTransferParams | ThorchainDepositParams) {\n const account = await toolbox.getAccount(address);\n if (!account) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { account } });\n }\n\n if (!account.pubkey) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { account, pubkey: account?.pubkey },\n });\n }\n\n const { accountNumber, sequence = 0 } = account;\n\n const msgs = [buildAminoMsg({ assetValue, memo, sender: address, ...rest })];\n\n const chainId = ChainId.THORChain;\n\n const signDoc = makeSignDoc(\n msgs,\n fee,\n chainId,\n memo,\n accountNumber?.toString(),\n sequence?.toString() || \"0\",\n );\n\n const signature: any = await signRequest(signDoc);\n\n const bodyBytes = await buildEncodedTxBody({\n chain: Chain.THORChain,\n msgs: msgs.map(parseAminoMessageForDirectSigning),\n memo: memo || \"\",\n });\n const pubkey = encodePubkey(account.pubkey);\n const authInfoBytes = makeAuthInfoBytes(\n [{ pubkey, sequence }],\n fee.amount,\n Number.parseInt(fee.gas),\n undefined,\n undefined,\n SignMode.SIGN_MODE_LEGACY_AMINO_JSON,\n );\n\n const txRaw = TxRaw.fromPartial({\n bodyBytes,\n authInfoBytes,\n signatures: [\n fromBase64(\n typeof signature.signature === \"string\"\n ? signature.signature\n : signature.signature.signature,\n ),\n ],\n });\n const txBytes = TxRaw.encode(txRaw).finish();\n\n const broadcaster = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const result = await broadcaster.broadcastTx(txBytes);\n return result.transactionHash;\n }\n\n return {\n ...toolbox,\n transfer: (params: GenericTransferParams) => thorchainTransfer(params),\n deposit: (params: ThorchainDepositParams) => thorchainTransfer(params),\n getAccount,\n };\n }\n\n case Chain.Near: {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const { DEFAULT_NEAR_METHODS } = await import(\"./constants\");\n\n // Create a NEAR signer that uses WalletConnect\n const signer = {\n getPublicKey() {\n // WalletConnect NEAR doesn't expose public key directly\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"getPublicKey\",\n }),\n );\n },\n\n signNep413Message(\n _message: string,\n _accountId: string,\n _recipient: string,\n _nonce: Uint8Array,\n _callbackUrl?: string,\n ) {\n // WalletConnect NEAR spec doesn't include NEP-413 message signing\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signNep413Message\",\n }),\n );\n },\n\n async signTransaction(transaction: Transaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n // WalletConnect signs and sends in one operation\n const result = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Near),\n request: {\n method: DEFAULT_NEAR_METHODS.NEAR_SIGN_AND_SEND_TRANSACTION,\n params: { transaction },\n },\n });\n // Return dummy hash and result\n return [new Uint8Array(32), result];\n },\n\n signDelegateAction(_delegateAction: any) {\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signDelegateAction\",\n }),\n );\n },\n\n getAddress() {\n return Promise.resolve(address);\n },\n } as NearSigner;\n\n const toolbox = await getNearToolbox({ signer });\n return toolbox;\n }\n\n case Chain.Tron: {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { DEFAULT_TRON_METHODS } = await import(\"./constants\");\n\n // Create a Tron signer that uses WalletConnect\n const signer: TronSigner = {\n getAddress() {\n return Promise.resolve(address);\n },\n\n async signTransaction(transaction: TronTransaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const signedTx = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Tron),\n request: {\n method: DEFAULT_TRON_METHODS.TRON_SIGN_TRANSACTION,\n params: { transaction },\n },\n });\n\n return signedTx as TronSignedTransaction;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n return toolbox;\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.WALLETCONNECT },\n });\n }\n}\n\nasync function getWalletconnect(\n chains: Chain[],\n walletConnectProjectId?: string,\n walletconnectOptions?: SignClientTypes.Options,\n) {\n let modal: WalletConnectModal | undefined;\n let signer: typeof SignClient | undefined;\n let session: SessionTypes.Struct | undefined;\n let accounts: string[] | undefined;\n try {\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n const requiredNamespaces = getRequiredNamespaces(chains.map(chainToChainId));\n\n const { SignClient } = await import(\"@walletconnect/sign-client\");\n const { WalletConnectModal } = await import(\"@walletconnect/modal\");\n\n const client = new SignClient({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n metadata: walletconnectOptions?.metadata || DEFAULT_APP_METADATA,\n ...walletconnectOptions?.core,\n });\n\n const modal = new WalletConnectModal({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n ...walletconnectOptions?.core,\n });\n\n const oldSession = await client.session.getAll()[0];\n\n // disconnect old Session cause we can't handle using it with current ui\n if (oldSession) {\n await client.disconnect({\n topic: oldSession.topic,\n reason: { code: 0, message: \"Resetting session\" },\n });\n }\n\n const { uri, approval } = await client.connect({\n // Optionally: pass a known prior pairing (e.g. from `client.core.pairing.getPairings()`) to skip the `uri` step.\n // pairingTopic: pairing?.topic,\n // Provide the namespaces and chains (e.g. `eip155` for EVM-based chains) we want to use in this session.\n requiredNamespaces,\n });\n\n if (uri) {\n modal.openModal({ uri });\n // Await session approval from the wallet.\n session = await approval();\n // Handle the returned session (e.g. update UI to \"connected\" state).\n // Close the QRCode modal in case it was open.\n modal.closeModal();\n\n function extractAccountsFromSession(session: SessionTypes.Struct) {\n const accounts: string[] = [];\n\n for (const [_namespace, data] of Object.entries(session.namespaces)) {\n accounts.push(...data.accounts);\n }\n\n return accounts;\n }\n\n accounts = extractAccountsFromSession(session);\n }\n\n const disconnect = async () => {\n session &&\n (await client.disconnect({\n topic: session.topic,\n reason: { code: 0, message: \"User disconnected\" },\n }));\n };\n\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n return { signer, session, accounts, client, disconnect };\n } catch (_e) {\n // Errors are handled by returning undefined\n } finally {\n if (modal) {\n modal.closeModal();\n }\n }\n return undefined;\n}\n",
5
+ "import type { StdSignDoc } from \"@cosmjs/amino\";\nimport {\n Chain,\n ChainId,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { ThorchainDepositParams, createThorchainToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { NearSigner } from \"@swapkit/toolboxes/near\";\nimport type { TronSignedTransaction, TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { WalletConnectModal } from \"@walletconnect/modal\";\nimport type { SignClient } from \"@walletconnect/sign-client\";\nimport type { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport type { Transaction } from \"near-api-js/lib/transaction\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport {\n DEFAULT_APP_METADATA,\n DEFAULT_COSMOS_METHODS,\n DEFAULT_LOGGER,\n DEFAULT_RELAY_URL,\n THORCHAIN_MAINNET_ID,\n} from \"./constants\";\nimport { getEVMSigner } from \"./evmSigner\";\nimport { chainToChainId, getAddressByChain } from \"./helpers\";\nimport { getRequiredNamespaces } from \"./namespaces\";\n\nexport * from \"./constants\";\nexport * from \"./types\";\n\nexport const walletconnectWallet = createWallet({\n name: \"connectWalletconnect\",\n walletType: WalletOption.WALLETCONNECT,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Cosmos,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Maya,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.THORChain,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectWalletconnect(\n chains: Chain[],\n walletconnectOptions?: SignClientTypes.Options,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { walletConnectProjectId } = SKConfig.get(\"apiKeys\");\n\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n\n const walletconnect = await getWalletconnect(\n filteredChains,\n walletConnectProjectId,\n walletconnectOptions,\n );\n\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const { accounts } = walletconnect;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const address = getAddressByChain(chain, accounts || []);\n const toolbox = await getToolbox({ address, chain, walletconnect });\n\n addChain({\n ...toolbox,\n address,\n chain,\n disconnect: walletconnect.disconnect,\n walletType: WalletOption.WALLETCONNECT,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const WC_SUPPORTED_CHAINS = getWalletSupportedChains(walletconnectWallet);\nexport type Walletconnect = Awaited<ReturnType<typeof getWalletconnect>>;\n\nasync function getToolbox<T extends (typeof WC_SUPPORTED_CHAINS)[number]>({\n chain,\n walletconnect,\n address,\n}: {\n walletconnect: Walletconnect;\n chain: T;\n address: string;\n}) {\n const session = walletconnect?.session;\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n switch (chain) {\n case Chain.Arbitrum:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getEVMSigner({ walletconnect, chain, provider });\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n return toolbox;\n }\n\n case Chain.THORChain: {\n const { SignMode } = await import(\"cosmjs-types/cosmos/tx/signing/v1beta1/signing.js\");\n const { TxRaw } = await import(\"cosmjs-types/cosmos/tx/v1beta1/tx.js\");\n\n const importedSigning = await import(\"@cosmjs/proto-signing\");\n const encodePubkey = importedSigning.encodePubkey ?? importedSigning.default?.encodePubkey;\n const makeAuthInfoBytes =\n importedSigning.makeAuthInfoBytes ?? importedSigning.default?.makeAuthInfoBytes;\n const importedAmino = await import(\"@cosmjs/amino\");\n const makeSignDoc = importedAmino.makeSignDoc ?? importedSigning.default?.makeSignDoc;\n\n const {\n getCosmosToolbox,\n buildAminoMsg,\n buildEncodedTxBody,\n createStargateClient,\n fromBase64,\n getDefaultChainFee,\n parseAminoMessageForDirectSigning,\n } = await import(\"@swapkit/toolboxes/cosmos\");\n const toolbox = await getCosmosToolbox(Chain.THORChain);\n\n async function getAccount(accountAddress: string) {\n const cosmosToolbox = toolbox;\n const account = await (\n cosmosToolbox as Awaited<ReturnType<typeof createThorchainToolbox>>\n ).getAccount(accountAddress);\n\n if (chain !== Chain.THORChain) {\n return account;\n }\n\n const [{ address, algo, pubkey }] = (await walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n // @ts-ignore\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_GET_ACCOUNTS,\n params: {},\n },\n })) as [{ address: string; algo: string; pubkey: string }];\n\n return { ...account, address, pubkey: { type: algo, value: pubkey } };\n }\n\n const fee = getDefaultChainFee(chain);\n\n const signRequest = (signDoc: StdSignDoc) =>\n walletconnect?.client.request({\n chainId: THORCHAIN_MAINNET_ID,\n topic: session.topic,\n request: {\n method: DEFAULT_COSMOS_METHODS.COSMOS_SIGN_AMINO,\n params: { signerAddress: address, signDoc },\n },\n });\n\n async function thorchainTransfer({\n assetValue,\n memo,\n ...rest\n }: GenericTransferParams | ThorchainDepositParams) {\n const account = await toolbox.getAccount(address);\n if (!account) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { account } });\n }\n\n if (!account.pubkey) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { account, pubkey: account?.pubkey },\n });\n }\n\n const { accountNumber, sequence = 0 } = account;\n\n const msgs = [buildAminoMsg({ assetValue, memo, sender: address, ...rest })];\n\n const chainId = ChainId.THORChain;\n\n const signDoc = makeSignDoc(\n msgs,\n fee,\n chainId,\n memo,\n accountNumber?.toString(),\n sequence?.toString() || \"0\",\n );\n\n const signature: any = await signRequest(signDoc);\n\n const bodyBytes = await buildEncodedTxBody({\n chain: Chain.THORChain,\n msgs: msgs.map(parseAminoMessageForDirectSigning),\n memo: memo || \"\",\n });\n const pubkey = encodePubkey(account.pubkey);\n const authInfoBytes = makeAuthInfoBytes(\n [{ pubkey, sequence }],\n fee.amount,\n Number.parseInt(fee.gas),\n undefined,\n undefined,\n SignMode.SIGN_MODE_LEGACY_AMINO_JSON,\n );\n\n const txRaw = TxRaw.fromPartial({\n bodyBytes,\n authInfoBytes,\n signatures: [\n fromBase64(\n typeof signature.signature === \"string\"\n ? signature.signature\n : signature.signature.signature,\n ),\n ],\n });\n const txBytes = TxRaw.encode(txRaw).finish();\n\n const broadcaster = await createStargateClient(SKConfig.get(\"rpcUrls\")[Chain.THORChain]);\n const result = await broadcaster.broadcastTx(txBytes);\n return result.transactionHash;\n }\n\n return {\n ...toolbox,\n transfer: (params: GenericTransferParams) => thorchainTransfer(params),\n deposit: (params: ThorchainDepositParams) => thorchainTransfer(params),\n getAccount,\n };\n }\n\n case Chain.Near: {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const { DEFAULT_NEAR_METHODS } = await import(\"./constants\");\n\n // Create a NEAR signer that uses WalletConnect\n const signer = {\n getPublicKey() {\n // WalletConnect NEAR doesn't expose public key directly\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"getPublicKey\",\n }),\n );\n },\n\n signNep413Message(\n _message: string,\n _accountId: string,\n _recipient: string,\n _nonce: Uint8Array,\n _callbackUrl?: string,\n ) {\n // WalletConnect NEAR spec doesn't include NEP-413 message signing\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signNep413Message\",\n }),\n );\n },\n\n async signTransaction(transaction: Transaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n // WalletConnect signs and sends in one operation\n const result = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Near),\n request: {\n method: DEFAULT_NEAR_METHODS.NEAR_SIGN_AND_SEND_TRANSACTION,\n params: { transaction },\n },\n });\n // Return dummy hash and result\n return [new Uint8Array(32), result];\n },\n\n signDelegateAction(_delegateAction: any) {\n return Promise.reject(\n new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signDelegateAction\",\n }),\n );\n },\n\n getAddress() {\n return Promise.resolve(address);\n },\n } as NearSigner;\n\n const toolbox = await getNearToolbox({ signer });\n return toolbox;\n }\n\n case Chain.Tron: {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { DEFAULT_TRON_METHODS } = await import(\"./constants\");\n\n // Create a Tron signer that uses WalletConnect\n const signer: TronSigner = {\n getAddress() {\n return Promise.resolve(address);\n },\n\n async signTransaction(transaction: TronTransaction) {\n if (!walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n const signedTx = await walletconnect.client.request({\n topic: session.topic,\n chainId: chainToChainId(Chain.Tron),\n request: {\n method: DEFAULT_TRON_METHODS.TRON_SIGN_TRANSACTION,\n params: { transaction },\n },\n });\n\n return signedTx as TronSignedTransaction;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n return toolbox;\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.WALLETCONNECT },\n });\n }\n}\n\nasync function getWalletconnect(\n chains: Chain[],\n walletConnectProjectId?: string,\n walletconnectOptions?: SignClientTypes.Options,\n) {\n let modal: WalletConnectModal | undefined;\n let signer: typeof SignClient | undefined;\n let session: SessionTypes.Struct | undefined;\n let accounts: string[] | undefined;\n try {\n if (!walletConnectProjectId) {\n throw new SwapKitError(\"wallet_walletconnect_project_id_not_specified\");\n }\n const requiredNamespaces = getRequiredNamespaces(chains.map(chainToChainId));\n\n const { SignClient } = await import(\"@walletconnect/sign-client\");\n const { WalletConnectModal } = await import(\"@walletconnect/modal\");\n\n const client = new SignClient({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n metadata: walletconnectOptions?.metadata || DEFAULT_APP_METADATA,\n ...walletconnectOptions?.core,\n });\n\n const modal = new WalletConnectModal({\n logger: DEFAULT_LOGGER,\n relayUrl: DEFAULT_RELAY_URL,\n projectId: walletConnectProjectId,\n ...walletconnectOptions?.core,\n });\n\n const oldSession = await client.session.getAll()[0];\n\n // disconnect old Session cause we can't handle using it with current ui\n if (oldSession) {\n await client.disconnect({\n topic: oldSession.topic,\n reason: { code: 0, message: \"Resetting session\" },\n });\n }\n\n const { uri, approval } = await client.connect({\n // Optionally: pass a known prior pairing (e.g. from `client.core.pairing.getPairings()`) to skip the `uri` step.\n // pairingTopic: pairing?.topic,\n // Provide the namespaces and chains (e.g. `eip155` for EVM-based chains) we want to use in this session.\n requiredNamespaces,\n });\n\n if (uri) {\n modal.openModal({ uri });\n // Await session approval from the wallet.\n session = await approval();\n // Handle the returned session (e.g. update UI to \"connected\" state).\n // Close the QRCode modal in case it was open.\n modal.closeModal();\n\n function extractAccountsFromSession(session: SessionTypes.Struct) {\n const accounts: string[] = [];\n\n for (const [_namespace, data] of Object.entries(session.namespaces)) {\n accounts.push(...data.accounts);\n }\n\n return accounts;\n }\n\n accounts = extractAccountsFromSession(session);\n }\n\n const disconnect = async () => {\n session &&\n (await client.disconnect({\n topic: session.topic,\n reason: { code: 0, message: \"User disconnected\" },\n }));\n };\n\n if (!session) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n\n return { signer, session, accounts, client, disconnect };\n } catch (_e) {\n // Errors are handled by returning undefined\n } finally {\n if (modal) {\n modal.closeModal();\n }\n }\n return undefined;\n}\n",
6
6
  "import { type EVMChain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest, TransactionResponse } from \"ethers\";\nimport { AbstractSigner } from \"ethers\";\n\nimport { DEFAULT_EIP155_METHODS } from \"./constants\";\nimport { chainToChainId, getAddressByChain } from \"./helpers\";\nimport type { Walletconnect } from \"./index\";\n\ninterface WalletconnectEVMSignerParams {\n chain: EVMChain;\n walletconnect: Walletconnect;\n provider: Provider | JsonRpcProvider;\n}\n\nclass WalletconnectSigner extends AbstractSigner {\n address: string;\n\n private chain: EVMChain;\n private walletconnect: Walletconnect;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ chain, provider, walletconnect }: WalletconnectEVMSignerParams) {\n super(provider);\n this.chain = chain;\n this.walletconnect = walletconnect;\n this.provider = provider;\n this.address = \"\";\n }\n\n // biome-ignore lint/suspicious/useAwait: fulfil implementation type\n getAddress = async () => {\n if (!this.walletconnect) {\n throw new SwapKitError(\"wallet_walletconnect_connection_not_established\");\n }\n if (!this.address) {\n this.address = getAddressByChain(this.chain, this.walletconnect.accounts || []);\n }\n\n return this.address;\n };\n\n signMessage = async (message: string) => {\n // this is probably broken\n const txHash = (await this.walletconnect?.client.request({\n chainId: chainToChainId(this.chain),\n topic: this.walletconnect.session.topic || \"\",\n request: {\n method: DEFAULT_EIP155_METHODS.ETH_SIGN,\n params: [message],\n },\n })) as string;\n\n return txHash.startsWith(\"0x\") ? txHash : `0x${txHash}`;\n };\n\n signTransaction = () => {\n throw new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signTransaction\",\n });\n\n // const baseTx = {\n // from,\n // to,\n // value: BigNumber.from(value || 0).toHexString(),\n // data,\n // };\n\n // const txHash = (await this.walletconnect?.client.request({\n // chainId: chainToChainId(this.chain),\n // topic: this.walletconnect.session.topic,\n // request: {\n // method: DEFAULT_EIP155_METHODS.ETH_SIGN_TRANSACTION,\n // params: [baseTx],\n // },\n // })) as string;\n\n // return txHash.startsWith('0x') ? txHash : `0x${txHash}`;\n };\n\n // ANCHOR (@Towan) - Implement in future\n signTypedData = () => {\n throw new SwapKitError(\"wallet_walletconnect_method_not_supported\", {\n method: \"signTypedData\",\n });\n\n // const { toHexString } = await import('@swapkit/toolboxes/evm');\n\n // const baseTx = {\n // from,\n // to,\n // value: toHexString(value || 0n),\n // data,\n // };\n\n // const txHash = (await this.walletconnect?.client.request({\n // chainId: chainToChainId(this.chain),\n // topic: this.walletconnect.session.topic,\n // request: {\n // method: DEFAULT_EIP155_METHODS.ETH_SIGN_TYPED_DATA,\n // params: [baseTx],\n // },\n // })) as string;\n\n // return txHash.startsWith('0x') ? txHash : `0x${txHash}`;\n };\n\n sendTransaction = async ({ from, to, value, data }: TransactionRequest) => {\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n const baseTx = {\n from,\n to,\n value: toHexString(BigInt(value || 0)),\n data,\n };\n const response = await this.walletconnect?.client.request({\n chainId: chainToChainId(this.chain),\n topic: this.walletconnect.session.topic,\n request: {\n method: DEFAULT_EIP155_METHODS.ETH_SEND_TRANSACTION,\n params: [baseTx],\n },\n });\n\n return response as TransactionResponse;\n };\n\n connect = (provider: Provider | null) => {\n if (!provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.WALLETCONNECT, chain: this.chain },\n });\n }\n\n return new WalletconnectSigner({\n chain: this.chain,\n walletconnect: this.walletconnect,\n provider,\n });\n };\n}\nexport const getEVMSigner = async ({\n chain,\n walletconnect,\n provider,\n}: WalletconnectEVMSignerParams) => new WalletconnectSigner({ chain, walletconnect, provider });\n",
7
7
  "import { Chain, type EVMChain, SKConfig } from \"@swapkit/helpers\";\n\nimport {\n ARBITRUM_ONE_MAINNET_ID,\n AURORA_MAINNET_ID,\n AVALANCHE_MAINNET_ID,\n BASE_MAINNET_ID,\n BERACHAIN_MAINNET_ID,\n BSC_MAINNET_ID,\n COSMOS_HUB_MAINNET_ID,\n ETHEREUM_MAINNET_ID,\n KUJIRA_MAINNET_ID,\n MAYACHAIN_MAINNET_ID,\n NEAR_MAINNET_ID,\n NEAR_TESTNET_ID,\n OPTIMISM_MAINNET_ID,\n POLYGON_MAINNET_ID,\n THORCHAIN_MAINNET_ID,\n TRON_MAINNET_ID,\n} from \"./constants\";\n\nexport const getAddressByChain = (\n chain:\n | EVMChain\n | Chain.THORChain\n | Chain.Maya\n | Chain.Kujira\n | Chain.Cosmos\n | Chain.Near\n | Chain.Tron,\n accounts: string[],\n) => {\n const account = accounts.find((account) => account.startsWith(chainToChainId(chain))) || \"\";\n const address = account?.split(\":\")?.[2];\n\n return address || \"\";\n};\n\nexport const chainToChainId = (chain: Chain) => {\n switch (chain) {\n case Chain.Avalanche:\n return AVALANCHE_MAINNET_ID;\n case Chain.Aurora:\n return AURORA_MAINNET_ID;\n case Chain.Base:\n return BASE_MAINNET_ID;\n case Chain.BinanceSmartChain:\n return BSC_MAINNET_ID;\n case Chain.Berachain:\n return BERACHAIN_MAINNET_ID;\n case Chain.Ethereum:\n return ETHEREUM_MAINNET_ID;\n case Chain.THORChain:\n return THORCHAIN_MAINNET_ID;\n case Chain.Arbitrum:\n return ARBITRUM_ONE_MAINNET_ID;\n case Chain.Optimism:\n return OPTIMISM_MAINNET_ID;\n case Chain.Polygon:\n return POLYGON_MAINNET_ID;\n case Chain.Maya:\n return MAYACHAIN_MAINNET_ID;\n case Chain.Cosmos:\n return COSMOS_HUB_MAINNET_ID;\n case Chain.Kujira:\n return KUJIRA_MAINNET_ID;\n case Chain.Near: {\n // Use testnet if stagenet is enabled\n const { isStagenet } = SKConfig.get(\"envs\");\n return isStagenet ? NEAR_TESTNET_ID : NEAR_MAINNET_ID;\n }\n case Chain.Tron:\n return TRON_MAINNET_ID;\n default:\n return \"\";\n }\n};\n",
8
8
  "import type { ProposalTypes } from \"@walletconnect/types\";\n\nimport { SwapKitError } from \"@swapkit/helpers\";\nimport {\n DEFAULT_COSMOS_METHODS,\n DEFAULT_EIP155_METHODS,\n DEFAULT_EIP_155_EVENTS,\n DEFAULT_NEAR_EVENTS,\n DEFAULT_NEAR_METHODS,\n DEFAULT_POLKADOT_EVENTS,\n DEFAULT_POLKADOT_METHODS,\n DEFAULT_SOLANA_EVENTS,\n DEFAULT_SOLANA_METHODS,\n DEFAULT_TRON_EVENTS,\n DEFAULT_TRON_METHODS,\n} from \"./constants\";\n\nexport const getNamespacesFromChains = (chains: string[]) => {\n const supportedNamespaces: string[] = [];\n for (const chainId of chains) {\n const [namespace] = chainId.split(\":\");\n if (namespace && !supportedNamespaces.includes(namespace)) {\n supportedNamespaces.push(namespace);\n }\n }\n\n return supportedNamespaces;\n};\n\nexport const getSupportedMethodsByNamespace = (namespace: string) => {\n switch (namespace) {\n case \"eip155\":\n return Object.values(DEFAULT_EIP155_METHODS);\n case \"cosmos\":\n return Object.values(DEFAULT_COSMOS_METHODS);\n case \"solana\":\n return Object.values(DEFAULT_SOLANA_METHODS);\n case \"polkadot\":\n return Object.values(DEFAULT_POLKADOT_METHODS);\n case \"near\":\n return Object.values(DEFAULT_NEAR_METHODS);\n case \"tron\":\n return Object.values(DEFAULT_TRON_METHODS);\n default:\n throw new SwapKitError({\n errorKey: \"wallet_walletconnect_namespace_not_supported\",\n info: { namespace },\n });\n }\n};\n\nexport const getSupportedEventsByNamespace = (namespace: string) => {\n switch (namespace) {\n case \"eip155\":\n return Object.values(DEFAULT_EIP_155_EVENTS);\n case \"cosmos\":\n return [];\n case \"solana\":\n return Object.values(DEFAULT_SOLANA_EVENTS);\n case \"polkadot\":\n return Object.values(DEFAULT_POLKADOT_EVENTS);\n case \"near\":\n return Object.values(DEFAULT_NEAR_EVENTS);\n case \"tron\":\n return Object.values(DEFAULT_TRON_EVENTS);\n default:\n throw new SwapKitError({\n errorKey: \"wallet_walletconnect_namespace_not_supported\",\n info: { namespace },\n });\n }\n};\n\nexport const getRequiredNamespaces = (chains: string[]): ProposalTypes.RequiredNamespaces => {\n const selectedNamespaces = getNamespacesFromChains(chains);\n\n return Object.fromEntries(\n selectedNamespaces.map((namespace) => [\n namespace,\n {\n methods: getSupportedMethodsByNamespace(namespace),\n chains: chains.filter((chain) => chain.startsWith(namespace)),\n events: getSupportedEventsByNamespace(namespace) as any[],\n },\n ]),\n );\n};\n"
9
9
  ],
10
- "mappings": "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",
11
- "debugId": "46B82982ED834F7964756E2164756E21",
10
+ "mappings": "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",
11
+ "debugId": "6ACC42B1DDF41FF364756E2164756E21",
12
12
  "names": []
13
13
  }
@@ -1,4 +1,4 @@
1
- var Z={};Q(Z,{xamanWallet:()=>j,XAMAN_SUPPORTED_CHAINS:()=>Y});module.exports=L(Z);var f=require("@swapkit/helpers"),U=require("xumm");var M=require("@swapkit/helpers");var A=require("@swapkit/helpers"),z=async(C)=>{if(!C)throw new A.SwapKitError("wallet_xaman_not_configured");try{let o=await(await C.user)?.account;if(o)return o;throw new A.SwapKitError("wallet_xaman_auth_failed")}catch(n){throw console.error("Xaman wallet connection failed:",n),new A.SwapKitError("wallet_xaman_connection_failed")}},h=async(C,n)=>{try{if(!(n.destination&&n.amount&&n.from))throw new A.SwapKitError("wallet_xaman_connection_failed");let o=(Number.parseFloat(n.amount)*1e6).toString(),O={TransactionType:"Payment",Destination:n.destination,Amount:o,Account:n.from,...n.destinationTag!==void 0&&{DestinationTag:n.destinationTag},...n.memo&&{Memos:[{Memo:{MemoData:Buffer.from(n.memo,"utf8").toString("hex").toUpperCase()}}]}},W=await C.payload?.createAndSubscribe(O,(g)=>{if("signed"in g.data)return g.data;return});if(!W)throw new A.SwapKitError("wallet_xaman_transaction_failed");let{created:y}=W;if(C.runtime?.xapp)C.xapp?.openSignRequest(y);else if(typeof window!=="undefined"){let g=y.pushed&&y.next?.no_push_msg_received?y.next.no_push_msg_received:y.next?.always;if(g)window.open(g)}let t=await W.resolved;if(!t||typeof t!=="object"||!("signed"in t)||!t.signed)throw new A.SwapKitError("wallet_xaman_transaction_failed");let _=await C.payload?.get(t.payload_uuidv4);if(!_)throw new A.SwapKitError("wallet_xaman_monitoring_failed");let l=_.response?.txid||"",X=_.response?.account||"";if(!l)throw new A.SwapKitError("wallet_xaman_transaction_failed");return{payloadId:y.uuid||"",qrCode:y.refs?.qr_png||"",deepLink:y.next?.always||"",websocketUrl:y.refs?.websocket_status||"",result:{success:!0,transactionId:l,account:X,reason:void 0}}}catch(o){if(console.error("Xaman payment creation and subscription failed:",o),o instanceof A.SwapKitError)throw o;throw new A.SwapKitError("wallet_xaman_transaction_failed")}};async function T({xumm:C,chain:n,address:o,rpcUrl:O}){switch(n){case M.Chain.Ripple:{let{getRippleToolbox:W}=await import("@swapkit/toolboxes/ripple");return{...await W({rpcUrl:O}),address:o,getAddress:()=>o,transfer:async(_)=>{let{recipient:l,assetValue:X,memo:g}=_,N=await h(C,{from:o,destination:l,amount:X.getValue("string"),memo:g});if(!(N.result.success&&N.result.transactionId))throw new M.SwapKitError("wallet_xaman_transaction_failed");return N.result.transactionId},createAndSubscribePayment:h,disconnect:C.logout}}default:throw new M.SwapKitError("wallet_chain_not_supported",{wallet:"Xaman",chain:n})}}var j=f.createWallet({name:"connectXaman",walletType:f.WalletOption.XAMAN,supportedChains:[f.Chain.Ripple],connect:({addChain:C,supportedChains:n,walletType:o})=>async function O(W,y){let t=f.filterSupportedChains({chains:W,supportedChains:n,walletType:o}),{xaman:_}=f.SKConfig.get("apiKeys"),l=y?.apiKey||_;if(!l)throw new f.SwapKitError("wallet_missing_api_key",{wallet:"Xaman"});let X=new U.Xumm(l);return new Promise((g,N)=>{X.on("success",async()=>{try{let P=await z(X),B=t.map(async(H)=>{let F=f.SKConfig.get("rpcUrls")[H],G=await T({xumm:X,chain:H,address:P,rpcUrl:F});C({...G,chain:H,balance:[],walletType:f.WalletOption.XAMAN,address:P,disconnect:X.logout})});await Promise.all(B),g(!0)}catch(P){N(P)}}),X.on("error",(P)=>{N(P)}),X.authorize()})}}),Y=q(j);
1
+ var $={};Y($,{xamanWallet:()=>B,XAMAN_SUPPORTED_CHAINS:()=>Z});module.exports=Q($);var y=require("@swapkit/helpers"),H=require("@swapkit/wallet-core"),q=require("xumm");var M=require("@swapkit/helpers");var A=require("@swapkit/helpers"),T=async(f)=>{if(!f)throw new A.SwapKitError("wallet_xaman_not_configured");try{let o=await(await f.user)?.account;if(o)return o;throw new A.SwapKitError("wallet_xaman_auth_failed")}catch(n){throw console.error("Xaman wallet connection failed:",n),new A.SwapKitError("wallet_xaman_connection_failed")}},z=async(f,n)=>{try{if(!(n.destination&&n.amount&&n.from))throw new A.SwapKitError("wallet_xaman_connection_failed");let o=(Number.parseFloat(n.amount)*1e6).toString(),O={TransactionType:"Payment",Destination:n.destination,Amount:o,Account:n.from,...n.destinationTag!==void 0&&{DestinationTag:n.destinationTag},...n.memo&&{Memos:[{Memo:{MemoData:Buffer.from(n.memo,"utf8").toString("hex").toUpperCase()}}]}},W=await f.payload?.createAndSubscribe(O,(g)=>{if("signed"in g.data)return g.data;return});if(!W)throw new A.SwapKitError("wallet_xaman_transaction_failed");let{created:C}=W;if(f.runtime?.xapp)f.xapp?.openSignRequest(C);else if(typeof window!=="undefined"){let g=C.pushed&&C.next?.no_push_msg_received?C.next.no_push_msg_received:C.next?.always;if(g)window.open(g)}let t=await W.resolved;if(!t||typeof t!=="object"||!("signed"in t)||!t.signed)throw new A.SwapKitError("wallet_xaman_transaction_failed");let _=await f.payload?.get(t.payload_uuidv4);if(!_)throw new A.SwapKitError("wallet_xaman_monitoring_failed");let l=_.response?.txid||"",X=_.response?.account||"";if(!l)throw new A.SwapKitError("wallet_xaman_transaction_failed");return{payloadId:C.uuid||"",qrCode:C.refs?.qr_png||"",deepLink:C.next?.always||"",websocketUrl:C.refs?.websocket_status||"",result:{success:!0,transactionId:l,account:X,reason:void 0}}}catch(o){if(console.error("Xaman payment creation and subscription failed:",o),o instanceof A.SwapKitError)throw o;throw new A.SwapKitError("wallet_xaman_transaction_failed")}};async function U({xumm:f,chain:n,address:o,rpcUrl:O}){switch(n){case M.Chain.Ripple:{let{getRippleToolbox:W}=await import("@swapkit/toolboxes/ripple");return{...await W({rpcUrl:O}),address:o,getAddress:()=>o,transfer:async(_)=>{let{recipient:l,assetValue:X,memo:g}=_,N=await z(f,{from:o,destination:l,amount:X.getValue("string"),memo:g});if(!(N.result.success&&N.result.transactionId))throw new M.SwapKitError("wallet_xaman_transaction_failed");return N.result.transactionId},createAndSubscribePayment:z,disconnect:f.logout}}default:throw new M.SwapKitError("wallet_chain_not_supported",{wallet:"Xaman",chain:n})}}var B=H.createWallet({name:"connectXaman",walletType:y.WalletOption.XAMAN,supportedChains:[y.Chain.Ripple],connect:({addChain:f,supportedChains:n,walletType:o})=>async function O(W,C){let t=y.filterSupportedChains({chains:W,supportedChains:n,walletType:o}),{xaman:_}=y.SKConfig.get("apiKeys"),l=C?.apiKey||_;if(!l)throw new y.SwapKitError("wallet_missing_api_key",{wallet:"Xaman"});let X=new q.Xumm(l);return new Promise((g,N)=>{X.on("success",async()=>{try{let P=await T(X),F=t.map(async(h)=>{let G=y.SKConfig.get("rpcUrls")[h],J=await U({xumm:X,chain:h,address:P,rpcUrl:G});f({...J,chain:h,balance:[],walletType:y.WalletOption.XAMAN,address:P,disconnect:X.logout})});await Promise.all(F),g(!0)}catch(P){N(P)}}),X.on("error",(P)=>{N(P)}),X.authorize()})}}),Z=H.getWalletSupportedChains(B);
2
2
 
3
- //# debugId=D90277FCFDE09F3C64756E2164756E21
3
+ //# debugId=AD81BBF097105CAA64756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map