@swapkit/wallets 2.0.24 → 3.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/dist/chunk-5m175wfy.js +4 -0
  2. package/dist/chunk-5m175wfy.js.map +9 -0
  3. package/dist/chunk-bhfpfqc3.js +3 -0
  4. package/dist/chunk-bhfpfqc3.js.map +10 -0
  5. package/dist/chunk-f76hj57k.js +3 -0
  6. package/dist/chunk-f76hj57k.js.map +10 -0
  7. package/dist/chunk-ha78se5g.js +4 -0
  8. package/dist/chunk-ha78se5g.js.map +10 -0
  9. package/dist/chunk-vb4wtm2w.js +3 -0
  10. package/dist/chunk-vb4wtm2w.js.map +9 -0
  11. package/dist/chunk-yvbvzc0q.js +3 -0
  12. package/dist/chunk-yvbvzc0q.js.map +10 -0
  13. package/dist/src/bitget/index.cjs +3 -0
  14. package/dist/src/bitget/index.cjs.map +11 -0
  15. package/dist/src/bitget/index.js +3 -0
  16. package/dist/src/bitget/index.js.map +11 -0
  17. package/dist/src/coinbase/index.cjs +3 -0
  18. package/dist/src/coinbase/index.cjs.map +11 -0
  19. package/dist/src/coinbase/index.js +4 -0
  20. package/dist/src/coinbase/index.js.map +11 -0
  21. package/dist/src/ctrl/index.cjs +3 -0
  22. package/dist/src/ctrl/index.cjs.map +11 -0
  23. package/dist/src/ctrl/index.js +3 -0
  24. package/dist/src/ctrl/index.js.map +11 -0
  25. package/dist/src/evm-extensions/index.cjs +3 -0
  26. package/dist/src/evm-extensions/index.cjs.map +10 -0
  27. package/dist/src/evm-extensions/index.js +4 -0
  28. package/dist/src/evm-extensions/index.js.map +10 -0
  29. package/dist/src/exodus/index.cjs +3 -0
  30. package/dist/src/exodus/index.cjs.map +10 -0
  31. package/dist/src/exodus/index.js +4 -0
  32. package/dist/src/exodus/index.js.map +10 -0
  33. package/dist/src/index.cjs +3 -0
  34. package/dist/src/index.cjs.map +10 -0
  35. package/dist/src/index.js +3 -0
  36. package/dist/src/index.js.map +10 -0
  37. package/dist/src/keepkey/index.cjs +3 -0
  38. package/dist/src/keepkey/index.cjs.map +16 -0
  39. package/dist/src/keepkey/index.js +4 -0
  40. package/dist/src/keepkey/index.js.map +16 -0
  41. package/dist/src/keepkey-bex/index.cjs +3 -0
  42. package/dist/src/keepkey-bex/index.cjs.map +11 -0
  43. package/dist/src/keepkey-bex/index.js +4 -0
  44. package/dist/src/keepkey-bex/index.js.map +11 -0
  45. package/dist/src/keplr/index.cjs +3 -0
  46. package/dist/src/keplr/index.cjs.map +11 -0
  47. package/dist/src/keplr/index.js +4 -0
  48. package/dist/src/keplr/index.js.map +11 -0
  49. package/dist/src/keystore/index.cjs +3 -0
  50. package/dist/src/keystore/index.cjs.map +11 -0
  51. package/dist/src/keystore/index.js +4 -0
  52. package/dist/src/keystore/index.js.map +11 -0
  53. package/dist/src/ledger/index.cjs +4 -0
  54. package/dist/src/ledger/index.cjs.map +22 -0
  55. package/dist/src/ledger/index.js +5 -0
  56. package/dist/src/ledger/index.js.map +22 -0
  57. package/dist/src/okx/index.cjs +3 -0
  58. package/dist/src/okx/index.cjs.map +11 -0
  59. package/dist/src/okx/index.js +4 -0
  60. package/dist/src/okx/index.js.map +11 -0
  61. package/dist/src/phantom/index.cjs +3 -0
  62. package/dist/src/phantom/index.cjs.map +10 -0
  63. package/dist/src/phantom/index.js +4 -0
  64. package/dist/src/phantom/index.js.map +10 -0
  65. package/dist/src/polkadotjs/index.cjs +3 -0
  66. package/dist/src/polkadotjs/index.cjs.map +10 -0
  67. package/dist/src/polkadotjs/index.js +4 -0
  68. package/dist/src/polkadotjs/index.js.map +10 -0
  69. package/dist/src/radix/index.cjs +3 -0
  70. package/dist/src/radix/index.cjs.map +10 -0
  71. package/dist/src/radix/index.js +4 -0
  72. package/dist/src/radix/index.js.map +10 -0
  73. package/dist/src/talisman/index.cjs +3 -0
  74. package/dist/src/talisman/index.cjs.map +10 -0
  75. package/dist/src/talisman/index.js +4 -0
  76. package/dist/src/talisman/index.js.map +10 -0
  77. package/dist/src/trezor/index.cjs +3 -0
  78. package/dist/src/trezor/index.cjs.map +10 -0
  79. package/dist/src/trezor/index.js +4 -0
  80. package/dist/src/trezor/index.js.map +10 -0
  81. package/dist/src/walletconnect/index.cjs +3 -0
  82. package/dist/src/walletconnect/index.cjs.map +14 -0
  83. package/dist/src/walletconnect/index.js +4 -0
  84. package/dist/src/walletconnect/index.js.map +14 -0
  85. package/package.json +133 -25
  86. package/src/bitget/bitgetWallet.ts +32 -0
  87. package/src/bitget/helpers.ts +189 -0
  88. package/src/bitget/index.ts +56 -0
  89. package/src/coinbase/index.ts +52 -0
  90. package/src/coinbase/signer.ts +79 -0
  91. package/src/ctrl/ctrlWallet.ts +175 -0
  92. package/src/ctrl/index.ts +24 -0
  93. package/src/ctrl/walletHelpers.ts +315 -0
  94. package/src/evm-extensions/index.ts +152 -0
  95. package/src/evm-extensions/types.ts +20 -0
  96. package/src/exodus/index.ts +189 -0
  97. package/src/helpers.ts +8 -0
  98. package/src/index.ts +20 -18
  99. package/src/keepkey/chains/cosmos.ts +81 -0
  100. package/src/keepkey/chains/evm.ts +117 -0
  101. package/src/keepkey/chains/mayachain.ts +121 -0
  102. package/src/keepkey/chains/thorchain.ts +110 -0
  103. package/src/keepkey/chains/utxo.ts +148 -0
  104. package/src/keepkey/coins.ts +64 -0
  105. package/src/keepkey/index.ts +154 -0
  106. package/src/keepkey-bex/index.ts +164 -0
  107. package/src/keepkey-bex/walletHelpers.ts +283 -0
  108. package/src/keplr/chainRegistry.ts +211 -0
  109. package/src/keplr/index.ts +101 -0
  110. package/src/keystore/helpers.ts +125 -0
  111. package/src/keystore/index.ts +239 -0
  112. package/src/ledger/clients/cosmos.ts +95 -0
  113. package/src/ledger/clients/evm.ts +180 -0
  114. package/src/ledger/clients/thorchain/common.ts +117 -0
  115. package/src/ledger/clients/thorchain/helpers.ts +144 -0
  116. package/src/ledger/clients/thorchain/index.ts +94 -0
  117. package/src/ledger/clients/thorchain/lib.ts +318 -0
  118. package/src/ledger/clients/thorchain/utils.ts +65 -0
  119. package/src/ledger/clients/utxo.ts +149 -0
  120. package/src/ledger/cosmosTypes.ts +97 -0
  121. package/src/ledger/helpers/getLedgerAddress.ts +46 -0
  122. package/src/ledger/helpers/getLedgerClient.ts +95 -0
  123. package/src/ledger/helpers/getLedgerTransport.ts +78 -0
  124. package/src/ledger/helpers/index.ts +3 -0
  125. package/src/ledger/index.ts +274 -0
  126. package/src/ledger/interfaces/CosmosLedgerInterface.ts +66 -0
  127. package/src/ledger/ledgerLive.ts +429 -0
  128. package/src/ledger/types.ts +39 -0
  129. package/src/okx/helpers.ts +137 -0
  130. package/src/okx/index.ts +81 -0
  131. package/src/okx/types.ts +117 -0
  132. package/src/phantom/index.ts +150 -0
  133. package/src/polkadotjs/index.ts +69 -0
  134. package/src/radix/index.ts +218 -0
  135. package/src/talisman/index.ts +147 -0
  136. package/src/trezor/evmSigner.ts +197 -0
  137. package/src/trezor/index.ts +247 -0
  138. package/src/walletconnect/constants.ts +85 -0
  139. package/src/walletconnect/evmSigner.ts +143 -0
  140. package/src/walletconnect/helpers.ts +54 -0
  141. package/src/walletconnect/index.ts +309 -0
  142. package/src/walletconnect/namespaces.ts +81 -0
  143. package/src/walletconnect/types.ts +6 -0
  144. package/dist/index.js +0 -3
  145. package/dist/index.js.map +0 -10
@@ -0,0 +1,4 @@
1
+ var g=Object.create;var{getPrototypeOf:h,defineProperty:f,getOwnPropertyNames:i}=Object;var j=Object.prototype.hasOwnProperty;var k=(a,c,b)=>{b=a!=null?g(h(a)):{};let d=c||!a||!a.__esModule?f(b,"default",{value:a,enumerable:!0}):b;for(let e of i(a))if(!j.call(d,e))f(d,e,{get:()=>a[e],enumerable:!0});return d};var l=((a)=>typeof require!=="undefined"?require:typeof Proxy!=="undefined"?new Proxy(a,{get:(c,b)=>(typeof require!=="undefined"?require:c)[b]}):a)(function(a){if(typeof require!=="undefined")return require.apply(this,arguments);throw Error('Dynamic require of "'+a+'" is not supported')});
2
+ export{k as s,l as t};
3
+
4
+ //# debugId=937A680F428868A764756E2164756E21
@@ -0,0 +1,9 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [
5
+ ],
6
+ "mappings": "",
7
+ "debugId": "937A680F428868A764756E2164756E21",
8
+ "names": []
9
+ }
@@ -0,0 +1,3 @@
1
+ var j=require("@swapkit/helpers");async function w({chain:A,derivationPath:O,provider:W}){let{AbstractSigner:k,Signature:N}=await import("ethers");class X extends k{address;chain;derivationPath;provider;constructor({chain:q,derivationPath:B,provider:D}){super(D);this.address="",this.chain=q,this.derivationPath=B,this.provider=D}getAddress=async()=>{if(!this.address){let{default:q}=await import("@trezor/connect-web"),B=await q.ethereumGetAddress({path:j.derivationPathToString(this.derivationPath),showOnTrezor:!0});if(!B.success)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_get_address",info:{...B,chain:this.chain,derivationPath:this.derivationPath}});this.address=B.payload.address}return this.address};signMessage=async(q)=>{let{default:B}=await import("@trezor/connect-web"),D=await B.ethereumSignMessage({path:j.derivationPathToString(this.derivationPath),message:q});if(!D.success)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...D,message:q,chain:this.chain,derivationPath:this.derivationPath}});return D.payload.signature};signTypedData(){throw new Error("Not implemented")}signTransaction=async({to:q,gasLimit:B,value:D,data:f,nonce:_,maxFeePerGas:R,maxPriorityFeePerGas:U,gasPrice:V})=>{if(!q)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{to:q}});if(!B)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{gasLimit:B}});let Q=R&&U;if(Q&&!R)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{maxFeePerGas:R}});if(Q&&!U)throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{maxPriorityFeePerGas:U}});if(!(Q||V))throw new j.SwapKitError({errorKey:"wallet_missing_params",info:{gasPrice:V}});let{default:H}=await import("@trezor/connect-web"),{toHexString:J}=await import("@swapkit/toolboxes/evm"),{Transaction:I}=await import("ethers"),L=Q?{maxFeePerGas:J(BigInt(R?.toString()||0)),maxPriorityFeePerGas:J(BigInt(U?.toString()||0))}:V&&{gasPrice:J(BigInt(V?.toString()||0))}||{gasPrice:"0x0"},b=J(BigInt(_||await this.provider.getTransactionCount(await this.getAddress(),"pending"))),Y={chainId:Number.parseInt(j.ChainToChainId[this.chain]),to:q.toString(),value:J(BigInt(D?.toString()||0)),gasLimit:J(BigInt(B?.toString()||0)),nonce:b,data:f?.toString()||"0x",...L},{success:C,payload:Z}=await H.ethereumSignTransaction({path:j.derivationPathToString(this.derivationPath),transaction:Y});if(!C)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...Z,chain:this.chain,derivationPath:this.derivationPath}});let{r:K,s:u,v:z}=Z,y=N.from({r:K,s:u,v:new j.SwapKitNumber(BigInt(z)).getBaseValue("number")}),$=I.from({...Y,nonce:Number.parseInt(Y.nonce,16),type:Q?2:0,signature:y}).serialized;if(!$)throw new j.SwapKitError({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:this.chain,derivationPath:this.derivationPath}});return $};connect=(q)=>{if(!q)throw new j.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:j.WalletOption.TREZOR,chain:this.chain,derivationPath:this.derivationPath}});return new X({chain:this.chain,derivationPath:this.derivationPath,provider:q})}}return new X({chain:A,derivationPath:O,provider:W})}
2
+
3
+ //# debugId=F889E83D9CD533AF64756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/trezor/evmSigner.ts"],
4
+ "sourcesContent": [
5
+ "import {\n type Chain,\n ChainToChainId,\n type DerivationPathArray,\n SwapKitError,\n SwapKitNumber,\n WalletOption,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest } from \"ethers\";\n\ntype TrezorEVMSignerParams = {\n chain: Chain;\n derivationPath: DerivationPathArray;\n provider: Provider | JsonRpcProvider;\n};\n\nexport async function getEVMSigner({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n const { AbstractSigner, Signature } = await import(\"ethers\");\n\n class TrezorSigner extends AbstractSigner {\n address: string;\n chain: Chain;\n derivationPath: DerivationPathArray;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n super(provider);\n\n this.address = \"\";\n this.chain = chain;\n this.derivationPath = derivationPath;\n this.provider = provider;\n }\n\n getAddress = async () => {\n if (!this.address) {\n const { default: TrezorConnect } = await import(\"@trezor/connect-web\");\n\n const result = await TrezorConnect.ethereumGetAddress({\n path: derivationPathToString(this.derivationPath),\n showOnTrezor: true,\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { ...result, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n this.address = result.payload.address;\n }\n\n return this.address;\n };\n\n signMessage = async (message: string) => {\n const { default: TrezorConnect } = await import(\"@trezor/connect-web\");\n\n const result = await TrezorConnect.ethereumSignMessage({\n path: derivationPathToString(this.derivationPath),\n message,\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...result, message, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n return result.payload.signature;\n };\n\n signTypedData(): Promise<string> {\n throw new Error(\"Not implemented\");\n }\n\n signTransaction = async ({\n to,\n gasLimit,\n value,\n data,\n nonce,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasPrice,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: any: refactor\n }: TransactionRequest) => {\n if (!to) throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { to } });\n if (!gasLimit)\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasLimit } });\n\n const isEIP1559 = maxFeePerGas && maxPriorityFeePerGas;\n\n if (isEIP1559 && !maxFeePerGas) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { maxFeePerGas } });\n }\n if (isEIP1559 && !maxPriorityFeePerGas) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { maxPriorityFeePerGas },\n });\n }\n if (!(isEIP1559 || gasPrice)) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasPrice } });\n }\n\n const { default: TrezorConnect } = await import(\"@trezor/connect-web\");\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n const { Transaction } = await import(\"ethers\");\n\n const additionalFields = isEIP1559\n ? {\n maxFeePerGas: toHexString(BigInt(maxFeePerGas?.toString() || 0)),\n maxPriorityFeePerGas: toHexString(BigInt(maxPriorityFeePerGas?.toString() || 0)),\n }\n : (gasPrice && { gasPrice: toHexString(BigInt(gasPrice?.toString() || 0)) }) || {\n gasPrice: \"0x0\",\n };\n\n const hexifiedNonce = toHexString(\n BigInt(\n nonce || (await this.provider.getTransactionCount(await this.getAddress(), \"pending\")),\n ),\n );\n\n const formattedTx = {\n chainId: Number.parseInt(ChainToChainId[this.chain]),\n to: to.toString(),\n value: toHexString(BigInt(value?.toString() || 0)),\n gasLimit: toHexString(BigInt(gasLimit?.toString() || 0)),\n nonce: hexifiedNonce,\n data: data?.toString() || \"0x\",\n ...additionalFields,\n };\n\n const { success, payload } = await TrezorConnect.ethereumSignTransaction({\n path: derivationPathToString(this.derivationPath),\n transaction: formattedTx,\n });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...payload, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n const { r, s, v } = payload;\n\n const signature = Signature.from({\n r,\n s,\n v: new SwapKitNumber(BigInt(v)).getBaseValue(\"number\"),\n });\n\n const serializedTx = Transaction.from({\n ...formattedTx,\n nonce: Number.parseInt(formattedTx.nonce, 16),\n type: isEIP1559 ? 2 : 0,\n signature,\n }).serialized;\n\n if (!serializedTx) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n return serializedTx;\n };\n\n connect = (provider: Provider | null) => {\n if (!provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: {\n wallet: WalletOption.TREZOR,\n chain: this.chain,\n derivationPath: this.derivationPath,\n },\n });\n }\n\n return new TrezorSigner({\n chain: this.chain,\n derivationPath: this.derivationPath,\n provider,\n });\n };\n }\n\n return new TrezorSigner({ chain, derivationPath, provider });\n}\n"
6
+ ],
7
+ "mappings": "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",
8
+ "debugId": "F889E83D9CD533AF64756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,3 @@
1
+ import{s as M,t as Q}from"./chunk-5m175wfy.js";import{ChainToChainId as G,SwapKitError as B,SwapKitNumber as h,WalletOption as F,derivationPathToString as $}from"@swapkit/helpers";async function l({chain:W,derivationPath:k,provider:N}){let{AbstractSigner:f,Signature:_}=await import("ethers");class Y extends f{address;chain;derivationPath;provider;constructor({chain:j,derivationPath:q,provider:D}){super(D);this.address="",this.chain=j,this.derivationPath=q,this.provider=D}getAddress=async()=>{if(!this.address){let{default:j}=await import("@trezor/connect-web"),q=await j.ethereumGetAddress({path:$(this.derivationPath),showOnTrezor:!0});if(!q.success)throw new B({errorKey:"wallet_trezor_failed_to_get_address",info:{...q,chain:this.chain,derivationPath:this.derivationPath}});this.address=q.payload.address}return this.address};signMessage=async(j)=>{let{default:q}=await import("@trezor/connect-web"),D=await q.ethereumSignMessage({path:$(this.derivationPath),message:j});if(!D.success)throw new B({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...D,message:j,chain:this.chain,derivationPath:this.derivationPath}});return D.payload.signature};signTypedData(){throw new Error("Not implemented")}signTransaction=async({to:j,gasLimit:q,value:D,data:H,nonce:I,maxFeePerGas:U,maxPriorityFeePerGas:V,gasPrice:X})=>{if(!j)throw new B({errorKey:"wallet_missing_params",info:{to:j}});if(!q)throw new B({errorKey:"wallet_missing_params",info:{gasLimit:q}});let R=U&&V;if(R&&!U)throw new B({errorKey:"wallet_missing_params",info:{maxFeePerGas:U}});if(R&&!V)throw new B({errorKey:"wallet_missing_params",info:{maxPriorityFeePerGas:V}});if(!(R||X))throw new B({errorKey:"wallet_missing_params",info:{gasPrice:X}});let{default:L}=await import("@trezor/connect-web"),{toHexString:J}=await import("@swapkit/toolboxes/evm"),{Transaction:b}=await import("ethers"),C=R?{maxFeePerGas:J(BigInt(U?.toString()||0)),maxPriorityFeePerGas:J(BigInt(V?.toString()||0))}:X&&{gasPrice:J(BigInt(X?.toString()||0))}||{gasPrice:"0x0"},K=J(BigInt(I||await this.provider.getTransactionCount(await this.getAddress(),"pending"))),Z={chainId:Number.parseInt(G[this.chain]),to:j.toString(),value:J(BigInt(D?.toString()||0)),gasLimit:J(BigInt(q?.toString()||0)),nonce:K,data:H?.toString()||"0x",...C},{success:u,payload:A}=await L.ethereumSignTransaction({path:$(this.derivationPath),transaction:Z});if(!u)throw new B({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{...A,chain:this.chain,derivationPath:this.derivationPath}});let{r:z,s:y,v:w}=A,E=_.from({r:z,s:y,v:new h(BigInt(w)).getBaseValue("number")}),O=b.from({...Z,nonce:Number.parseInt(Z.nonce,16),type:R?2:0,signature:E}).serialized;if(!O)throw new B({errorKey:"wallet_trezor_failed_to_sign_transaction",info:{chain:this.chain,derivationPath:this.derivationPath}});return O};connect=(j)=>{if(!j)throw new B({errorKey:"wallet_provider_not_found",info:{wallet:F.TREZOR,chain:this.chain,derivationPath:this.derivationPath}});return new Y({chain:this.chain,derivationPath:this.derivationPath,provider:j})}}return new Y({chain:W,derivationPath:k,provider:N})}export{l as getEVMSigner};
2
+
3
+ //# debugId=814607CEF7106DB164756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/trezor/evmSigner.ts"],
4
+ "sourcesContent": [
5
+ "import {\n type Chain,\n ChainToChainId,\n type DerivationPathArray,\n SwapKitError,\n SwapKitNumber,\n WalletOption,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { JsonRpcProvider, Provider, TransactionRequest } from \"ethers\";\n\ntype TrezorEVMSignerParams = {\n chain: Chain;\n derivationPath: DerivationPathArray;\n provider: Provider | JsonRpcProvider;\n};\n\nexport async function getEVMSigner({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n const { AbstractSigner, Signature } = await import(\"ethers\");\n\n class TrezorSigner extends AbstractSigner {\n address: string;\n chain: Chain;\n derivationPath: DerivationPathArray;\n readonly provider: Provider | JsonRpcProvider;\n\n constructor({ chain, derivationPath, provider }: TrezorEVMSignerParams) {\n super(provider);\n\n this.address = \"\";\n this.chain = chain;\n this.derivationPath = derivationPath;\n this.provider = provider;\n }\n\n getAddress = async () => {\n if (!this.address) {\n const { default: TrezorConnect } = await import(\"@trezor/connect-web\");\n\n const result = await TrezorConnect.ethereumGetAddress({\n path: derivationPathToString(this.derivationPath),\n showOnTrezor: true,\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_get_address\",\n info: { ...result, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n this.address = result.payload.address;\n }\n\n return this.address;\n };\n\n signMessage = async (message: string) => {\n const { default: TrezorConnect } = await import(\"@trezor/connect-web\");\n\n const result = await TrezorConnect.ethereumSignMessage({\n path: derivationPathToString(this.derivationPath),\n message,\n });\n\n if (!result.success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...result, message, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n return result.payload.signature;\n };\n\n signTypedData(): Promise<string> {\n throw new Error(\"Not implemented\");\n }\n\n signTransaction = async ({\n to,\n gasLimit,\n value,\n data,\n nonce,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasPrice,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: any: refactor\n }: TransactionRequest) => {\n if (!to) throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { to } });\n if (!gasLimit)\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasLimit } });\n\n const isEIP1559 = maxFeePerGas && maxPriorityFeePerGas;\n\n if (isEIP1559 && !maxFeePerGas) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { maxFeePerGas } });\n }\n if (isEIP1559 && !maxPriorityFeePerGas) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { maxPriorityFeePerGas },\n });\n }\n if (!(isEIP1559 || gasPrice)) {\n throw new SwapKitError({ errorKey: \"wallet_missing_params\", info: { gasPrice } });\n }\n\n const { default: TrezorConnect } = await import(\"@trezor/connect-web\");\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n const { Transaction } = await import(\"ethers\");\n\n const additionalFields = isEIP1559\n ? {\n maxFeePerGas: toHexString(BigInt(maxFeePerGas?.toString() || 0)),\n maxPriorityFeePerGas: toHexString(BigInt(maxPriorityFeePerGas?.toString() || 0)),\n }\n : (gasPrice && { gasPrice: toHexString(BigInt(gasPrice?.toString() || 0)) }) || {\n gasPrice: \"0x0\",\n };\n\n const hexifiedNonce = toHexString(\n BigInt(\n nonce || (await this.provider.getTransactionCount(await this.getAddress(), \"pending\")),\n ),\n );\n\n const formattedTx = {\n chainId: Number.parseInt(ChainToChainId[this.chain]),\n to: to.toString(),\n value: toHexString(BigInt(value?.toString() || 0)),\n gasLimit: toHexString(BigInt(gasLimit?.toString() || 0)),\n nonce: hexifiedNonce,\n data: data?.toString() || \"0x\",\n ...additionalFields,\n };\n\n const { success, payload } = await TrezorConnect.ethereumSignTransaction({\n path: derivationPathToString(this.derivationPath),\n transaction: formattedTx,\n });\n\n if (!success) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { ...payload, chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n const { r, s, v } = payload;\n\n const signature = Signature.from({\n r,\n s,\n v: new SwapKitNumber(BigInt(v)).getBaseValue(\"number\"),\n });\n\n const serializedTx = Transaction.from({\n ...formattedTx,\n nonce: Number.parseInt(formattedTx.nonce, 16),\n type: isEIP1559 ? 2 : 0,\n signature,\n }).serialized;\n\n if (!serializedTx) {\n throw new SwapKitError({\n errorKey: \"wallet_trezor_failed_to_sign_transaction\",\n info: { chain: this.chain, derivationPath: this.derivationPath },\n });\n }\n\n return serializedTx;\n };\n\n connect = (provider: Provider | null) => {\n if (!provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: {\n wallet: WalletOption.TREZOR,\n chain: this.chain,\n derivationPath: this.derivationPath,\n },\n });\n }\n\n return new TrezorSigner({\n chain: this.chain,\n derivationPath: this.derivationPath,\n provider,\n });\n };\n }\n\n return new TrezorSigner({ chain, derivationPath, provider });\n}\n"
6
+ ],
7
+ "mappings": "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",
8
+ "debugId": "814607CEF7106DB164756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,4 @@
1
+ function a(e){let t=Object.keys(e)?.[0]||"";return e?.[t]?.supportedChains||[]}
2
+ export{a as r};
3
+
4
+ //# debugId=F206E598AB17CDC064756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/helpers.ts"],
4
+ "sourcesContent": [
5
+ "import type { createWallet } from \"@swapkit/helpers\";\n\nexport function getWalletSupportedChains<\n T extends ReturnType<typeof createWallet<any, any, any, any>>,\n>(wallet: T): T[keyof T][\"supportedChains\"] {\n const walletName = Object.keys(wallet)?.[0] || \"\";\n return wallet?.[walletName]?.supportedChains || [];\n}\n"
6
+ ],
7
+ "mappings": "AAEO,SAAS,CAEf,CAAC,EAA0C,CAC1C,IAAM,EAAa,OAAO,KAAK,CAAM,IAAI,IAAM,GAC/C,OAAO,IAAS,IAAa,iBAAmB,CAAC",
8
+ "debugId": "F206E598AB17CDC064756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,3 @@
1
+ var j=Object.create;var{getPrototypeOf:k,defineProperty:e,getOwnPropertyNames:f,getOwnPropertyDescriptor:l}=Object,g=Object.prototype.hasOwnProperty,m=(a,c,d)=>{for(let b of f(c))if(!g.call(a,b)&&b!=="default")e(a,b,{get:()=>c[b],enumerable:!0});if(d){for(let b of f(c))if(!g.call(d,b)&&b!=="default")e(d,b,{get:()=>c[b],enumerable:!0});return d}},n=(a,c,d)=>{d=a!=null?j(k(a)):{};let b=c||!a||!a.__esModule?e(d,"default",{value:a,enumerable:!0}):d;for(let h of f(a))if(!g.call(b,h))e(b,h,{get:()=>a[h],enumerable:!0});return b},i=new WeakMap,o=(a)=>{var c=i.get(a),d;if(c)return c;if(c=e({},"__esModule",{value:!0}),a&&typeof a==="object"||typeof a==="function")f(a).map((b)=>!g.call(c,b)&&e(c,b,{get:()=>a[b],enumerable:!(d=l(a,b))||d.enumerable}));return i.set(a,c),c};var p=(a,c)=>{for(var d in c)e(a,d,{get:c[d],enumerable:!0,configurable:!0,set:(b)=>c[d]=()=>b})};
2
+
3
+ //# debugId=5B7366231CF0CA5E64756E2164756E21
@@ -0,0 +1,9 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [
5
+ ],
6
+ "mappings": "",
7
+ "debugId": "5B7366231CF0CA5E64756E2164756E21",
8
+ "names": []
9
+ }
@@ -0,0 +1,3 @@
1
+ var p={};a(p,{getWalletSupportedChains:()=>n});function n(e){let t=Object.keys(e)?.[0]||"";return e?.[t]?.supportedChains||[]}
2
+
3
+ //# debugId=C48D3544860CE65864756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/helpers.ts"],
4
+ "sourcesContent": [
5
+ "import type { createWallet } from \"@swapkit/helpers\";\n\nexport function getWalletSupportedChains<\n T extends ReturnType<typeof createWallet<any, any, any, any>>,\n>(wallet: T): T[keyof T][\"supportedChains\"] {\n const walletName = Object.keys(wallet)?.[0] || \"\";\n return wallet?.[walletName]?.supportedChains || [];\n}\n"
6
+ ],
7
+ "mappings": "+CAEO,SAAS,CAEf,CAAC,EAA0C,CAC1C,IAAM,EAAa,OAAO,KAAK,CAAM,IAAI,IAAM,GAC/C,OAAO,IAAS,IAAa,iBAAmB,CAAC",
8
+ "debugId": "C48D3544860CE65864756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,3 @@
1
+ var E={};B(E,{bitgetWallet:()=>u,BITGET_SUPPORTED_CHAINS:()=>y});module.exports=v(E);var s=require("@swapkit/helpers");var t=require("@swapkit/helpers");function A(){return async({from:c,recipient:e,assetValue:o,memo:r})=>{let{getMsgSendDenom:i,createSigningStargateClient:a}=await import("@swapkit/toolboxes/cosmos");if(!(window.bitkeep&&("keplr"in window.bitkeep)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{keplr:n}=window.bitkeep,l=n.getOfflineSignerOnlyAmino(t.ChainId.Cosmos),g=await a(t.SKConfig.get("rpcUrls").GAIA,l),w=[{denom:i(o.symbol).toLowerCase(),amount:o.getBaseValue("string")}];try{let{transactionHash:m}=await g.sendTokens(c,e,w,2,r);return m}catch(m){throw new t.SwapKitError("core_transaction_failed",{error:m})}}}async function b(c){let e=window.bitkeep;switch(c){case t.Chain.Ethereum:case t.Chain.Base:case t.Chain.Avalanche:case t.Chain.Arbitrum:case t.Chain.Optimism:case t.Chain.Polygon:case t.Chain.BinanceSmartChain:{if(!(e&&("ethereum"in e)))throw new t.SwapKitError("wallet_bitkeep_not_found");let o=e.ethereum,{getProvider:r}=await import("@swapkit/toolboxes/evm"),i=await x({chain:c,walletProvider:o}),[a]=await o.send("eth_requestAccounts",[]);return{...i,getBalance:async(l,g=!0)=>i.getBalance(l||a,g,r(c)),address:a}}case t.Chain.Bitcoin:{let g=function(w){return n.transfer({...w,signTransaction:l})};if(!(e&&("unisat"in e)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{unisat:o}=e,{Psbt:r,BTCToolbox:i}=await import("@swapkit/toolboxes/utxo"),[a]=await o.requestAccounts(),n=i();async function l(w){let m=await o.signPsbt(w.toHex(),{autoFinalized:!1});return r.fromHex(m)}return{...n,transfer:g,address:a}}case t.Chain.Cosmos:{if(!(e&&("keplr"in e)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{keplr:o}=e;await o.enable(t.ChainId.Cosmos);let r=await o.getOfflineSignerOnlyAmino(t.ChainId.Cosmos).getAccounts();if(!r?.[0])throw new Error("No cosmos account found");let{GaiaToolbox:i}=await import("@swapkit/toolboxes/cosmos"),a=i(),[{address:n}]=r;return{...a,address:n,transfer:A()}}case t.Chain.Solana:{if(!(e&&("solana"in e)))throw new t.SwapKitError("wallet_bitkeep_not_found");let{SOLToolbox:o}=await import("@swapkit/toolboxes/solana"),r=e?.solana,a=(await r.connect()).publicKey.toString(),n=o();return{...n,transfer:async({recipient:g,assetValue:w,isProgramDerivedAddress:m,memo:S})=>{let P=await n.getAddressValidator();if(!(m||P(g)))throw new t.SwapKitError("core_transaction_invalid_recipient_address");let{PublicKey:T}=await import("@solana/web3.js"),f=new T(a),_=await n.getConnection(),d=await n.createSolanaTransaction({recipient:g,assetValue:w,memo:S,fromPublicKey:f,isProgramDerivedAddress:m}),k=await _.getLatestBlockhash();d.recentBlockhash=k.blockhash,d.feePayer=f;let C=await r.signTransaction(d);return n.broadcastTransaction(C)},address:a}}default:throw new t.SwapKitError("wallet_chain_not_supported")}}var x=async({walletProvider:c,chain:e})=>{let{getToolboxByChain:o}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:r}=await import("ethers");if(!c)throw new t.SwapKitError("wallet_provider_not_found");let i=new r(c,"any"),a=await i.getSigner(),n=o(e)({provider:i,signer:a});try{if(e!==t.Chain.Ethereum&&"getNetworkParams"in n)await t.switchEVMWalletNetwork(i,e,n.getNetworkParams())}catch(l){throw new Error(`Failed to add/switch ${e} network: ${e}`)}return t.prepareNetworkSwitch({toolbox:n,provider:i,chain:e})};var u=s.createWallet({name:"connectBitget",walletType:s.WalletOption.BITGET,supportedChains:[...s.EVMChains,s.Chain.Cosmos,s.Chain.Bitcoin,s.Chain.Solana],connect:({addChain:c,walletType:e,supportedChains:o})=>async function r(i){let a=s.filterSupportedChains({chains:i,supportedChains:o,walletType:e});return await Promise.all(a.map(async(n)=>{let l=await b(n);c({...l,chain:n,balance:[],walletType:e})})),!0}}),y=h(u);
2
+
3
+ //# debugId=63D620E4B5C014BF64756E2164756E21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/bitget/bitgetWallet.ts", "../src/bitget/helpers.ts"],
4
+ "sourcesContent": [
5
+ "import {\n Chain,\n EVMChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, balance: [], walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
6
+ "import {\n type AssetValue,\n Chain,\n ChainId,\n type EVMChain,\n SKConfig,\n SwapKitError,\n type WalletTxParams,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TransferParams } from \"@swapkit/toolboxes/cosmos\";\nimport type { Psbt, UTXOTransferParams } from \"@swapkit/toolboxes/utxo\";\nimport type { Eip1193Provider } from \"ethers\";\n\nfunction cosmosTransfer() {\n return async ({ from, recipient, assetValue, memo }: TransferParams) => {\n const { getMsgSendDenom, createSigningStargateClient } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n if (!(window.bitkeep && \"keplr\" in window.bitkeep)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { keplr: wallet } = window.bitkeep;\n\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const cosmJS = await createSigningStargateClient(SKConfig.get(\"rpcUrls\").GAIA, offlineSigner);\n\n const coins = [\n {\n denom: getMsgSendDenom(assetValue.symbol).toLowerCase(),\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n try {\n const { transactionHash } = await cosmJS.sendTokens(from, recipient, coins, 2, memo);\n return transactionHash;\n } catch (error) {\n throw new SwapKitError(\"core_transaction_failed\", { error });\n }\n };\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const bitget = window.bitkeep;\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const { getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: wallet });\n\n const [address]: [string, ...string[]] = await wallet.send(\"eth_requestAccounts\", []);\n\n const getBalance = async (addressOverwrite?: string, potentialScamFilter = true) =>\n evmWallet.getBalance(addressOverwrite || address, potentialScamFilter, getProvider(chain));\n\n return { ...evmWallet, getBalance, address };\n }\n\n case Chain.Bitcoin: {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { Psbt, BTCToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n const toolbox = BTCToolbox();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n function transfer(transferParams: UTXOTransferParams) {\n return toolbox.transfer({ ...transferParams, signTransaction });\n }\n\n return { ...toolbox, transfer, address };\n }\n\n case Chain.Cosmos: {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const accounts = await wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos).getAccounts();\n if (!accounts?.[0]) throw new Error(\"No cosmos account found\");\n\n const { GaiaToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const toolbox = GaiaToolbox();\n const [{ address }] = accounts;\n\n return { ...toolbox, address, transfer: cosmosTransfer() };\n }\n\n case Chain.Solana: {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { SOLToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n const toolbox = SOLToolbox();\n\n const transfer = async ({\n recipient,\n assetValue,\n isProgramDerivedAddress,\n memo,\n }: WalletTxParams & { assetValue: AssetValue; isProgramDerivedAddress?: boolean }) => {\n const validateAddress = await toolbox.getAddressValidator();\n\n if (!(isProgramDerivedAddress || validateAddress(recipient))) {\n throw new SwapKitError(\"core_transaction_invalid_recipient_address\");\n }\n const { PublicKey } = await import(\"@solana/web3.js\");\n const fromPublicKey = new PublicKey(address);\n\n const connection = await toolbox.getConnection();\n const transaction = await toolbox.createSolanaTransaction({\n recipient,\n assetValue,\n memo,\n fromPublicKey,\n isProgramDerivedAddress,\n });\n\n const blockHash = await connection.getLatestBlockhash();\n transaction.recentBlockhash = blockHash.blockhash;\n transaction.feePayer = fromPublicKey;\n\n const signedTransaction = await provider.signTransaction(transaction);\n\n return toolbox.broadcastTransaction(signedTransaction);\n };\n\n return { ...toolbox, transfer, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_chain_not_supported\");\n }\n}\n\nexport const getWeb3WalletMethods = async ({\n walletProvider,\n chain,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return prepareNetworkSwitch({ toolbox, provider, chain });\n};\n"
7
+ ],
8
+ "mappings": "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",
9
+ "debugId": "63D620E4B5C014BF64756E2164756E21",
10
+ "names": []
11
+ }
@@ -0,0 +1,3 @@
1
+ import{r as S}from"../../chunk-ha78se5g.js";import{s as p,t as w}from"../../chunk-5m175wfy.js";import{Chain as b,EVMChains as W,WalletOption as M,createWallet as U,filterSupportedChains as K}from"@swapkit/helpers";import{Chain as r,ChainId as f,SKConfig as v,SwapKitError as l,prepareNetworkSwitch as B,switchEVMWalletNetwork as E}from"@swapkit/helpers";function I(){return async({from:s,recipient:t,assetValue:n,memo:a})=>{let{getMsgSendDenom:o,createSigningStargateClient:i}=await import("@swapkit/toolboxes/cosmos");if(!(window.bitkeep&&("keplr"in window.bitkeep)))throw new l("wallet_bitkeep_not_found");let{keplr:e}=window.bitkeep,c=e.getOfflineSignerOnlyAmino(f.Cosmos),g=await i(v.get("rpcUrls").GAIA,c),d=[{denom:o(n.symbol).toLowerCase(),amount:n.getBaseValue("string")}];try{let{transactionHash:m}=await g.sendTokens(s,t,d,2,a);return m}catch(m){throw new l("core_transaction_failed",{error:m})}}}async function y(s){let t=window.bitkeep;switch(s){case r.Ethereum:case r.Base:case r.Avalanche:case r.Arbitrum:case r.Optimism:case r.Polygon:case r.BinanceSmartChain:{if(!(t&&("ethereum"in t)))throw new l("wallet_bitkeep_not_found");let n=t.ethereum,{getProvider:a}=await import("@swapkit/toolboxes/evm"),o=await O({chain:s,walletProvider:n}),[i]=await n.send("eth_requestAccounts",[]);return{...o,getBalance:async(c,g=!0)=>o.getBalance(c||i,g,a(s)),address:i}}case r.Bitcoin:{let g=function(d){return e.transfer({...d,signTransaction:c})};if(!(t&&("unisat"in t)))throw new l("wallet_bitkeep_not_found");let{unisat:n}=t,{Psbt:a,BTCToolbox:o}=await import("@swapkit/toolboxes/utxo"),[i]=await n.requestAccounts(),e=o();async function c(d){let m=await n.signPsbt(d.toHex(),{autoFinalized:!1});return a.fromHex(m)}return{...e,transfer:g,address:i}}case r.Cosmos:{if(!(t&&("keplr"in t)))throw new l("wallet_bitkeep_not_found");let{keplr:n}=t;await n.enable(f.Cosmos);let a=await n.getOfflineSignerOnlyAmino(f.Cosmos).getAccounts();if(!a?.[0])throw new Error("No cosmos account found");let{GaiaToolbox:o}=await import("@swapkit/toolboxes/cosmos"),i=o(),[{address:e}]=a;return{...i,address:e,transfer:I()}}case r.Solana:{if(!(t&&("solana"in t)))throw new l("wallet_bitkeep_not_found");let{SOLToolbox:n}=await import("@swapkit/toolboxes/solana"),a=t?.solana,i=(await a.connect()).publicKey.toString(),e=n();return{...e,transfer:async({recipient:g,assetValue:d,isProgramDerivedAddress:m,memo:T})=>{let _=await e.getAddressValidator();if(!(m||_(g)))throw new l("core_transaction_invalid_recipient_address");let{PublicKey:k}=await import("@solana/web3.js"),h=new k(i),C=await e.getConnection(),u=await e.createSolanaTransaction({recipient:g,assetValue:d,memo:T,fromPublicKey:h,isProgramDerivedAddress:m}),A=await C.getLatestBlockhash();u.recentBlockhash=A.blockhash,u.feePayer=h;let x=await a.signTransaction(u);return e.broadcastTransaction(x)},address:i}}default:throw new l("wallet_chain_not_supported")}}var O=async({walletProvider:s,chain:t})=>{let{getToolboxByChain:n}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:a}=await import("ethers");if(!s)throw new l("wallet_provider_not_found");let o=new a(s,"any"),i=await o.getSigner(),e=n(t)({provider:o,signer:i});try{if(t!==r.Ethereum&&"getNetworkParams"in e)await E(o,t,e.getNetworkParams())}catch(c){throw new Error(`Failed to add/switch ${t} network: ${t}`)}return B({toolbox:e,provider:o,chain:t})};var P=U({name:"connectBitget",walletType:M.BITGET,supportedChains:[...W,b.Cosmos,b.Bitcoin,b.Solana],connect:({addChain:s,walletType:t,supportedChains:n})=>async function a(o){let i=K({chains:o,supportedChains:n,walletType:t});return await Promise.all(i.map(async(e)=>{let c=await y(e);s({...c,chain:e,balance:[],walletType:t})})),!0}}),V=S(P);export{P as bitgetWallet,V as BITGET_SUPPORTED_CHAINS};export{P as k};
2
+
3
+ //# debugId=1CE92A2AF95829DD64756E2164756E21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/bitget/bitgetWallet.ts", "../src/bitget/helpers.ts"],
4
+ "sourcesContent": [
5
+ "import {\n Chain,\n EVMChains,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, balance: [], walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
6
+ "import {\n type AssetValue,\n Chain,\n ChainId,\n type EVMChain,\n SKConfig,\n SwapKitError,\n type WalletTxParams,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TransferParams } from \"@swapkit/toolboxes/cosmos\";\nimport type { Psbt, UTXOTransferParams } from \"@swapkit/toolboxes/utxo\";\nimport type { Eip1193Provider } from \"ethers\";\n\nfunction cosmosTransfer() {\n return async ({ from, recipient, assetValue, memo }: TransferParams) => {\n const { getMsgSendDenom, createSigningStargateClient } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n if (!(window.bitkeep && \"keplr\" in window.bitkeep)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { keplr: wallet } = window.bitkeep;\n\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const cosmJS = await createSigningStargateClient(SKConfig.get(\"rpcUrls\").GAIA, offlineSigner);\n\n const coins = [\n {\n denom: getMsgSendDenom(assetValue.symbol).toLowerCase(),\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n try {\n const { transactionHash } = await cosmJS.sendTokens(from, recipient, coins, 2, memo);\n return transactionHash;\n } catch (error) {\n throw new SwapKitError(\"core_transaction_failed\", { error });\n }\n };\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const bitget = window.bitkeep;\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const { getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: wallet });\n\n const [address]: [string, ...string[]] = await wallet.send(\"eth_requestAccounts\", []);\n\n const getBalance = async (addressOverwrite?: string, potentialScamFilter = true) =>\n evmWallet.getBalance(addressOverwrite || address, potentialScamFilter, getProvider(chain));\n\n return { ...evmWallet, getBalance, address };\n }\n\n case Chain.Bitcoin: {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { Psbt, BTCToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n const toolbox = BTCToolbox();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n function transfer(transferParams: UTXOTransferParams) {\n return toolbox.transfer({ ...transferParams, signTransaction });\n }\n\n return { ...toolbox, transfer, address };\n }\n\n case Chain.Cosmos: {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const accounts = await wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos).getAccounts();\n if (!accounts?.[0]) throw new Error(\"No cosmos account found\");\n\n const { GaiaToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const toolbox = GaiaToolbox();\n const [{ address }] = accounts;\n\n return { ...toolbox, address, transfer: cosmosTransfer() };\n }\n\n case Chain.Solana: {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { SOLToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n const toolbox = SOLToolbox();\n\n const transfer = async ({\n recipient,\n assetValue,\n isProgramDerivedAddress,\n memo,\n }: WalletTxParams & { assetValue: AssetValue; isProgramDerivedAddress?: boolean }) => {\n const validateAddress = await toolbox.getAddressValidator();\n\n if (!(isProgramDerivedAddress || validateAddress(recipient))) {\n throw new SwapKitError(\"core_transaction_invalid_recipient_address\");\n }\n const { PublicKey } = await import(\"@solana/web3.js\");\n const fromPublicKey = new PublicKey(address);\n\n const connection = await toolbox.getConnection();\n const transaction = await toolbox.createSolanaTransaction({\n recipient,\n assetValue,\n memo,\n fromPublicKey,\n isProgramDerivedAddress,\n });\n\n const blockHash = await connection.getLatestBlockhash();\n transaction.recentBlockhash = blockHash.blockhash;\n transaction.feePayer = fromPublicKey;\n\n const signedTransaction = await provider.signTransaction(transaction);\n\n return toolbox.broadcastTransaction(signedTransaction);\n };\n\n return { ...toolbox, transfer, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_chain_not_supported\");\n }\n}\n\nexport const getWeb3WalletMethods = async ({\n walletProvider,\n chain,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n\n return prepareNetworkSwitch({ toolbox, provider, chain });\n};\n"
7
+ ],
8
+ "mappings": "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",
9
+ "debugId": "1CE92A2AF95829DD64756E2164756E21",
10
+ "names": []
11
+ }
@@ -0,0 +1,3 @@
1
+ var S={};f(S,{coinbaseWallet:()=>C,COINBASE_SUPPORTED_CHAINS:()=>P});module.exports=y(S);var e=require("@swapkit/helpers");var a=require("@swapkit/helpers"),h=require("ethers");class d extends h.AbstractSigner{#e;constructor(t,o){super(o);this.#e=t}async getAddress(){let t=await this.#e.request({method:"eth_requestAccounts"});if(!t[0])throw new Error("No Account found");return t[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(t){return await this.#e.request({method:"personal_sign",params:[t,await this.getAddress()]})}signTypedData=()=>{throw new Error("this method is not implemented")};connect(t){return new d(this.#e,t)}}var u=async({chain:t,coinbaseSdk:o})=>{switch(t){case a.Chain.Ethereum:case a.Chain.Avalanche:case a.Chain.Arbitrum:case a.Chain.Optimism:case a.Chain.Polygon:case a.Chain.BinanceSmartChain:{let i=o.getProvider(),{getToolboxByChain:p,getProvider:c}=await import("@swapkit/toolboxes/evm"),n=c(t),r=new d(i,n),l=p(t)({provider:n,signer:r});return{address:await r.getAddress(),...l}}default:throw new Error(`No wallet for chain ${t}`)}};var C=e.createWallet({name:"connectCoinbaseWallet",walletType:e.WalletOption.COINBASE_MOBILE,supportedChains:[e.Chain.Arbitrum,e.Chain.Avalanche,e.Chain.Base,e.Chain.BinanceSmartChain,e.Chain.Ethereum,e.Chain.Optimism,e.Chain.Polygon],connect:({addChain:t,walletType:o,supportedChains:i})=>async function p(c){let{createCoinbaseWalletSDK:n}=await import("@coinbase/wallet-sdk"),r=e.filterSupportedChains({chains:c,supportedChains:i,walletType:o}),l=e.SKConfig.get("integrations").coinbase||{appName:"Swapkit Playground"},b=n({...l,appChainIds:r.map((s)=>Number(e.ChainToChainId[s]))});return await Promise.all(r.map(async(s)=>{let w=await u({chain:s,coinbaseSdk:b});t({...w,balance:[],chain:s,walletType:o})})),!0}}),P=g(C);
2
+
3
+ //# debugId=43849AB98B0861F664756E2164756E21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/coinbase/index.ts", "../src/coinbase/signer.ts"],
4
+ "sourcesContent": [
5
+ "import {\n Chain,\n ChainToChainId,\n SKConfig,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport { getWalletMethods } from \"./signer\";\n\nexport const coinbaseWallet = createWallet({\n name: \"connectCoinbaseWallet\",\n walletType: WalletOption.COINBASE_MOBILE,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCoinbaseWallet(chains: Chain[]) {\n const { createCoinbaseWalletSDK } = await import(\"@coinbase/wallet-sdk\");\n\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const coinbaseConfig = SKConfig.get(\"integrations\").coinbase || {\n appName: \"Swapkit Playground\",\n };\n\n const coinbaseSdk = createCoinbaseWalletSDK({\n ...coinbaseConfig,\n appChainIds: filteredChains.map((chain) => Number(ChainToChainId[chain])),\n });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({ chain, coinbaseSdk });\n\n addChain({ ...walletMethods, balance: [], chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const COINBASE_SUPPORTED_CHAINS = getWalletSupportedChains(coinbaseWallet);\n",
6
+ "import type { CoinbaseWalletProvider } from \"@coinbase/wallet-sdk\";\nimport { Chain } from \"@swapkit/helpers\";\nimport type { getToolboxByChain } from \"@swapkit/toolboxes/evm\";\nimport { AbstractSigner, type Provider } from \"ethers\";\n\nimport type { createCoinbaseWalletSDK } from \"@coinbase/wallet-sdk/dist/createCoinbaseWalletSDK.js\";\n\nclass CoinbaseMobileSigner extends AbstractSigner {\n #coinbaseProvider: CoinbaseWalletProvider;\n\n constructor(coinbaseProvider: CoinbaseWalletProvider, provider?: Provider) {\n super(provider);\n this.#coinbaseProvider = coinbaseProvider;\n }\n\n async getAddress() {\n const accounts = await this.#coinbaseProvider.request<string[]>({\n method: \"eth_requestAccounts\",\n });\n\n if (!accounts[0]) throw new Error(\"No Account found\");\n\n return accounts[0];\n }\n\n async signTransaction() {\n return await this.#coinbaseProvider.request<string>({\n method: \"eth_signTransaction\",\n });\n }\n\n async signMessage(message: string | Uint8Array) {\n return await this.#coinbaseProvider.request<string>({\n method: \"personal_sign\",\n params: [message, await this.getAddress()],\n });\n }\n\n signTypedData = () => {\n throw new Error(\"this method is not implemented\");\n };\n\n connect(provider: Provider) {\n return new CoinbaseMobileSigner(this.#coinbaseProvider, provider);\n }\n}\n\nexport const getWalletMethods = async ({\n chain,\n coinbaseSdk,\n}: {\n chain: Chain;\n coinbaseSdk: ReturnType<typeof createCoinbaseWalletSDK>;\n}): Promise<ReturnType<ReturnType<typeof getToolboxByChain>> & { address: string }> => {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n const walletProvider = coinbaseSdk.getProvider() as CoinbaseWalletProvider;\n\n const { getToolboxByChain, getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = getProvider(chain);\n const signer = new CoinbaseMobileSigner(walletProvider, provider);\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n return {\n address: await signer.getAddress(),\n ...toolbox,\n };\n }\n\n default:\n throw new Error(`No wallet for chain ${chain}`);\n }\n};\n"
7
+ ],
8
+ "mappings": "yFAOO,IAPP,8BCCsB,IAAtB,8BAEA,oBAIA,MAAM,UAA6B,gBAAe,CAChD,GAEA,WAAW,CAAC,EAA0C,EAAqB,CACzE,MAAM,CAAQ,EACd,KAAK,GAAoB,OAGrB,WAAU,EAAG,CACjB,IAAM,EAAW,MAAM,KAAK,GAAkB,QAAkB,CAC9D,OAAQ,qBACV,CAAC,EAED,IAAK,EAAS,GAAI,MAAM,IAAI,MAAM,kBAAkB,EAEpD,OAAO,EAAS,QAGZ,gBAAe,EAAG,CACtB,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,qBACV,CAAC,OAGG,YAAW,CAAC,EAA8B,CAC9C,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,gBACR,OAAQ,CAAC,EAAS,MAAM,KAAK,WAAW,CAAC,CAC3C,CAAC,EAGH,cAAgB,IAAM,CACpB,MAAM,IAAI,MAAM,gCAAgC,GAGlD,OAAO,CAAC,EAAoB,CAC1B,OAAO,IAAI,EAAqB,KAAK,GAAmB,CAAQ,EAEpE,CAEO,IAAM,EAAmB,OAC9B,QACA,iBAIqF,CACrF,OAAQ,QACD,QAAM,cACN,QAAM,eACN,QAAM,cACN,QAAM,cACN,QAAM,aACN,QAAM,kBAAmB,CAC5B,IAAM,EAAiB,EAAY,YAAY,GAEvC,oBAAmB,eAAgB,KAAa,kCAElD,EAAW,EAAY,CAAK,EAC5B,EAAS,IAAI,EAAqB,EAAgB,CAAQ,EAC1D,EAAU,EAAkB,CAAK,EAAE,CAAE,WAAU,QAAO,CAAC,EAE7D,MAAO,CACL,QAAS,MAAM,EAAO,WAAW,KAC9B,CACL,CACF,SAGE,MAAM,IAAI,MAAM,uBAAuB,GAAO,IDhE7C,IAAM,EAAiB,eAAa,CACzC,KAAM,wBACN,WAAY,eAAa,gBACzB,gBAAiB,CACf,QAAM,SACN,QAAM,UACN,QAAM,KACN,QAAM,kBACN,QAAM,SACN,QAAM,SACN,QAAM,OACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAqB,CAAC,EAAiB,CACpD,IAAQ,2BAA4B,KAAa,gCAE3C,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAiB,WAAS,IAAI,cAAc,EAAE,UAAY,CAC9D,QAAS,oBACX,EAEM,EAAc,EAAwB,IACvC,EACH,YAAa,EAAe,IAAI,CAAC,IAAU,OAAO,iBAAe,EAAM,CAAC,CAC1E,CAAC,EAUD,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAE,QAAO,aAAY,CAAC,EAEnE,EAAS,IAAK,EAAe,QAAS,CAAC,EAAG,QAAO,YAAW,CAAC,EAC9D,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,EAAyB,CAAc",
9
+ "debugId": "43849AB98B0861F664756E2164756E21",
10
+ "names": []
11
+ }
@@ -0,0 +1,4 @@
1
+ import{r as g}from"../../chunk-ha78se5g.js";import{s as m,t as h}from"../../chunk-5m175wfy.js";import{Chain as t,ChainToChainId as y,SKConfig as f,WalletOption as P,createWallet as S,filterSupportedChains as W}from"@swapkit/helpers";import{Chain as o}from"@swapkit/helpers";import{AbstractSigner as w}from"ethers";class d extends w{#e;constructor(e,a){super(a);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new Error("No Account found");return e[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(e){return await this.#e.request({method:"personal_sign",params:[e,await this.getAddress()]})}signTypedData=()=>{throw new Error("this method is not implemented")};connect(e){return new d(this.#e,e)}}var u=async({chain:e,coinbaseSdk:a})=>{switch(e){case o.Ethereum:case o.Avalanche:case o.Arbitrum:case o.Optimism:case o.Polygon:case o.BinanceSmartChain:{let i=a.getProvider(),{getToolboxByChain:p,getProvider:c}=await import("@swapkit/toolboxes/evm"),n=c(e),r=new d(i,n),l=p(e)({provider:n,signer:r});return{address:await r.getAddress(),...l}}default:throw new Error(`No wallet for chain ${e}`)}};var v=S({name:"connectCoinbaseWallet",walletType:P.COINBASE_MOBILE,supportedChains:[t.Arbitrum,t.Avalanche,t.Base,t.BinanceSmartChain,t.Ethereum,t.Optimism,t.Polygon],connect:({addChain:e,walletType:a,supportedChains:i})=>async function p(c){let{createCoinbaseWalletSDK:n}=await import("@coinbase/wallet-sdk"),r=W({chains:c,supportedChains:i,walletType:a}),l=f.get("integrations").coinbase||{appName:"Swapkit Playground"},C=n({...l,appChainIds:r.map((s)=>Number(y[s]))});return await Promise.all(r.map(async(s)=>{let b=await u({chain:s,coinbaseSdk:C});e({...b,balance:[],chain:s,walletType:a})})),!0}}),O=g(v);export{v as coinbaseWallet,O as COINBASE_SUPPORTED_CHAINS};
2
+ export{v as l};
3
+
4
+ //# debugId=B6D83EF0F6A812DC64756E2164756E21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/coinbase/index.ts", "../src/coinbase/signer.ts"],
4
+ "sourcesContent": [
5
+ "import {\n Chain,\n ChainToChainId,\n SKConfig,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport { getWalletMethods } from \"./signer\";\n\nexport const coinbaseWallet = createWallet({\n name: \"connectCoinbaseWallet\",\n walletType: WalletOption.COINBASE_MOBILE,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCoinbaseWallet(chains: Chain[]) {\n const { createCoinbaseWalletSDK } = await import(\"@coinbase/wallet-sdk\");\n\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const coinbaseConfig = SKConfig.get(\"integrations\").coinbase || {\n appName: \"Swapkit Playground\",\n };\n\n const coinbaseSdk = createCoinbaseWalletSDK({\n ...coinbaseConfig,\n appChainIds: filteredChains.map((chain) => Number(ChainToChainId[chain])),\n });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({ chain, coinbaseSdk });\n\n addChain({ ...walletMethods, balance: [], chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const COINBASE_SUPPORTED_CHAINS = getWalletSupportedChains(coinbaseWallet);\n",
6
+ "import type { CoinbaseWalletProvider } from \"@coinbase/wallet-sdk\";\nimport { Chain } from \"@swapkit/helpers\";\nimport type { getToolboxByChain } from \"@swapkit/toolboxes/evm\";\nimport { AbstractSigner, type Provider } from \"ethers\";\n\nimport type { createCoinbaseWalletSDK } from \"@coinbase/wallet-sdk/dist/createCoinbaseWalletSDK.js\";\n\nclass CoinbaseMobileSigner extends AbstractSigner {\n #coinbaseProvider: CoinbaseWalletProvider;\n\n constructor(coinbaseProvider: CoinbaseWalletProvider, provider?: Provider) {\n super(provider);\n this.#coinbaseProvider = coinbaseProvider;\n }\n\n async getAddress() {\n const accounts = await this.#coinbaseProvider.request<string[]>({\n method: \"eth_requestAccounts\",\n });\n\n if (!accounts[0]) throw new Error(\"No Account found\");\n\n return accounts[0];\n }\n\n async signTransaction() {\n return await this.#coinbaseProvider.request<string>({\n method: \"eth_signTransaction\",\n });\n }\n\n async signMessage(message: string | Uint8Array) {\n return await this.#coinbaseProvider.request<string>({\n method: \"personal_sign\",\n params: [message, await this.getAddress()],\n });\n }\n\n signTypedData = () => {\n throw new Error(\"this method is not implemented\");\n };\n\n connect(provider: Provider) {\n return new CoinbaseMobileSigner(this.#coinbaseProvider, provider);\n }\n}\n\nexport const getWalletMethods = async ({\n chain,\n coinbaseSdk,\n}: {\n chain: Chain;\n coinbaseSdk: ReturnType<typeof createCoinbaseWalletSDK>;\n}): Promise<ReturnType<ReturnType<typeof getToolboxByChain>> & { address: string }> => {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n const walletProvider = coinbaseSdk.getProvider() as CoinbaseWalletProvider;\n\n const { getToolboxByChain, getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = getProvider(chain);\n const signer = new CoinbaseMobileSigner(walletProvider, provider);\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n return {\n address: await signer.getAddress(),\n ...toolbox,\n };\n }\n\n default:\n throw new Error(`No wallet for chain ${chain}`);\n }\n};\n"
7
+ ],
8
+ "mappings": "iGAAA,cACE,oBACA,cACA,kBACA,kBACA,2BACA,yBCLF,gBAAS,yBAET,yBAAS,eAIT,MAAM,UAA6B,CAAe,CAChD,GAEA,WAAW,CAAC,EAA0C,EAAqB,CACzE,MAAM,CAAQ,EACd,KAAK,GAAoB,OAGrB,WAAU,EAAG,CACjB,IAAM,EAAW,MAAM,KAAK,GAAkB,QAAkB,CAC9D,OAAQ,qBACV,CAAC,EAED,IAAK,EAAS,GAAI,MAAM,IAAI,MAAM,kBAAkB,EAEpD,OAAO,EAAS,QAGZ,gBAAe,EAAG,CACtB,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,qBACV,CAAC,OAGG,YAAW,CAAC,EAA8B,CAC9C,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,gBACR,OAAQ,CAAC,EAAS,MAAM,KAAK,WAAW,CAAC,CAC3C,CAAC,EAGH,cAAgB,IAAM,CACpB,MAAM,IAAI,MAAM,gCAAgC,GAGlD,OAAO,CAAC,EAAoB,CAC1B,OAAO,IAAI,EAAqB,KAAK,GAAmB,CAAQ,EAEpE,CAEO,IAAM,EAAmB,OAC9B,QACA,iBAIqF,CACrF,OAAQ,QACD,EAAM,cACN,EAAM,eACN,EAAM,cACN,EAAM,cACN,EAAM,aACN,EAAM,kBAAmB,CAC5B,IAAM,EAAiB,EAAY,YAAY,GAEvC,oBAAmB,eAAgB,KAAa,kCAElD,EAAW,EAAY,CAAK,EAC5B,EAAS,IAAI,EAAqB,EAAgB,CAAQ,EAC1D,EAAU,EAAkB,CAAK,EAAE,CAAE,WAAU,QAAO,CAAC,EAE7D,MAAO,CACL,QAAS,MAAM,EAAO,WAAW,KAC9B,CACL,CACF,SAGE,MAAM,IAAI,MAAM,uBAAuB,GAAO,IDhE7C,IAAM,EAAiB,EAAa,CACzC,KAAM,wBACN,WAAY,EAAa,gBACzB,gBAAiB,CACf,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,OACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAqB,CAAC,EAAiB,CACpD,IAAQ,2BAA4B,KAAa,gCAE3C,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAiB,EAAS,IAAI,cAAc,EAAE,UAAY,CAC9D,QAAS,oBACX,EAEM,EAAc,EAAwB,IACvC,EACH,YAAa,EAAe,IAAI,CAAC,IAAU,OAAO,EAAe,EAAM,CAAC,CAC1E,CAAC,EAUD,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAE,QAAO,aAAY,CAAC,EAEnE,EAAS,IAAK,EAAe,QAAS,CAAC,EAAG,QAAO,YAAW,CAAC,EAC9D,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,EAAyB,CAAc",
9
+ "debugId": "B6D83EF0F6A812DC64756E2164756E21",
10
+ "names": []
11
+ }
@@ -0,0 +1,3 @@
1
+ var C={};A(C,{ctrlWallet:()=>x,CTRL_SUPPORTED_CHAINS:()=>H});module.exports=G(C);var o=require("@swapkit/helpers");var l=require("@swapkit/helpers"),c=require("@swapkit/helpers/contracts");function R(t){if(!window.xfi)throw new l.SwapKitError("wallet_ctrl_not_found");switch(t){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:return window.xfi.ethereum;case l.Chain.Cosmos:case l.Chain.Kujira:return window.xfi.keplr;case l.Chain.Bitcoin:return window.xfi.bitcoin;case l.Chain.BitcoinCash:return window.xfi.bitcoincash;case l.Chain.Dogecoin:return window.xfi.dogecoin;case l.Chain.Litecoin:return window.xfi.litecoin;case l.Chain.THORChain:return window.xfi.thorchain;case l.Chain.Maya:return window.xfi.mayachain;case l.Chain.Solana:return window.xfi.solana;default:return}}async function I({method:t,params:y,chain:w}){let n=R(w);return new Promise((_,p)=>{if(n&&"request"in n)n.request({method:t,params:y},(f,T)=>{f?p(f):_(T)})})}async function g(t){let y=R(t);if(!y)throw new l.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:l.WalletOption.CTRL,chain:t}});if([l.Chain.Cosmos,l.Chain.Kujira].includes(t)){let w=R(l.Chain.Cosmos);if(!w||"request"in w)throw new l.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:l.WalletOption.CTRL,chain:t}});let n=l.ChainToChainId[t];await w.enable(n);let _=w.getOfflineSigner(n),[p]=await _.getAccounts();return p?.address}if(l.EVMChains.includes(t)){let[w]=await y.request({method:"eth_requestAccounts",params:[]});return w}if(t===l.Chain.Solana)return(await R(l.Chain.Solana).connect()).publicKey.toString();return new Promise((w,n)=>y.request({method:"request_accounts",params:[]},(_,[p])=>_?n(_):w(p)))}async function b({assetValue:t,recipient:y,memo:w,gasLimit:n},_="transfer"){if(!t)throw new l.SwapKitError("wallet_ctrl_asset_not_defined");let p=await g(t.chain),f=[{amount:{amount:t.getBaseValue("number"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},memo:w||"",from:p,recipient:y,gasLimit:n}];return I({method:_,params:f,chain:t.chain})}function m(t,y){return async({recipient:w,assetValue:n,memo:_,isProgramDerivedAddress:p})=>{let f=await t.createSolanaTransaction({recipient:w,assetValue:n,memo:_,fromPublicKey:y,isProgramDerivedAddress:p}),T=await window.xfi?.solana.signTransaction(f);if(!T)throw new l.SwapKitError("core_transaction_failed");return t.broadcastTransaction(T)}}function e(t){return{call:async({contractAddress:y,abi:w,funcName:n,funcParams:_=[],txOverrides:p})=>{let f=t;if(!y)throw new l.SwapKitError("wallet_ctrl_contract_address_not_provided");let{createContract:T,createContractTxObject:B,isStateChangingCall:E,toHexString:S}=await import("@swapkit/toolboxes/evm");if(E(w,n)){let{value:M,from:D,to:O,data:U}=await B(f,{contractAddress:y,abi:w,funcName:n,funcParams:_,txOverrides:p});return t.send("eth_sendTransaction",[{value:S(BigInt(M||0)),from:D,to:O,data:U||"0x"}])}let W=await T(y,w,f)[n]?.(..._);return typeof W?.hash==="string"?W?.hash:W},approve:async({assetAddress:y,spenderAddress:w,amount:n,from:_})=>{let{MAX_APPROVAL:p,createContractTxObject:f,toHexString:T}=await import("@swapkit/toolboxes/evm"),B=[w,BigInt(n||p)],S={contractAddress:y,abi:c.erc20ABI,funcName:"approve",funcParams:B,txOverrides:{from:_}},{value:L,to:P,data:W}=await f(t,S);return t.send("eth_sendTransaction",[{value:T(BigInt(L||0)),from:_,to:P,data:W||"0x"}])},sendTransaction:async(y)=>{let{from:w,to:n,data:_,value:p}=y;if(!n)throw new l.SwapKitError("wallet_ctrl_send_transaction_no_address");let{toHexString:f}=await import("@swapkit/toolboxes/evm");return t.send("eth_sendTransaction",[{value:f(BigInt(p||0)),from:w,to:n,data:_||"0x"}])}}}var x=o.createWallet({name:"connectCtrl",walletType:o.WalletOption.CTRL,supportedChains:[o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Base,o.Chain.BinanceSmartChain,o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Cosmos,o.Chain.Dogecoin,o.Chain.Ethereum,o.Chain.Kujira,o.Chain.Litecoin,o.Chain.Maya,o.Chain.Optimism,o.Chain.Polygon,o.Chain.Solana,o.Chain.THORChain],connect:({addChain:t,walletType:y,supportedChains:w})=>async function n(_){let f=o.filterSupportedChains({chains:_,supportedChains:w,walletType:y}).map(async(T)=>{let B=await g(T),E=await N(T);t({...E,address:B,balance:[],chain:T,walletType:y})});return await Promise.all(f),!0}}),H=k(x);async function N(t){switch(t){case o.Chain.Solana:{let{SOLToolbox:y}=await import("@swapkit/toolboxes/solana"),w=y(),n=await window.xfi?.solana?.connect();if(!n)throw new o.SwapKitError("wallet_ctrl_not_found");return{...w,transfer:m(w,n.publicKey)}}case o.Chain.Maya:case o.Chain.THORChain:{let{getToolboxByChain:y,THORCHAIN_GAS_VALUE:w,MAYA_GAS_VALUE:n}=await import("@swapkit/toolboxes/cosmos"),_=t===o.Chain.Maya?n:w;return{...y(t)(),deposit:(f)=>b({...f,recipient:""},"deposit"),transfer:(f)=>b({...f,gasLimit:_},"transfer")}}case o.Chain.Cosmos:case o.Chain.Kujira:{let{getToolboxByChain:y}=await import("@swapkit/toolboxes/cosmos"),w=o.ChainToChainId[t];await window.xfi?.keplr?.enable(w);let n=window.xfi?.keplr?.getOfflineSignerOnlyAmino(w),_=y(t)();return{..._,transfer:(f)=>_.transfer({signer:n,...f})}}case o.Chain.Bitcoin:case o.Chain.BitcoinCash:case o.Chain.Dogecoin:case o.Chain.Litecoin:{let{getToolboxByChain:y}=await import("@swapkit/toolboxes/utxo");return{...y(t)(),transfer:b}}case o.Chain.Arbitrum:case o.Chain.Avalanche:case o.Chain.Base:case o.Chain.BinanceSmartChain:case o.Chain.Ethereum:case o.Chain.Optimism:case o.Chain.Polygon:{let{prepareNetworkSwitch:y,switchEVMWalletNetwork:w}=await import("@swapkit/helpers"),{getToolboxByChain:n}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:_}=await import("ethers"),p=R(t);if(!p)throw new o.SwapKitError("wallet_ctrl_not_found");let f=new _(p,"any"),T=await f.getSigner(),B=n(t)({provider:f,signer:T}),E=e(f);try{if(t!==o.Chain.Ethereum){let S=B.getNetworkParams();await w(f,t,S)}}catch(S){throw new o.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:o.WalletOption.CTRL,chain:t}})}return y({provider:window.xfi?.ethereum,chain:t,toolbox:{...B,...E}})}default:return null}}
2
+
3
+ //# debugId=5BCD1AE3F71FA0AD64756E2164756E21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/ctrl/ctrlWallet.ts", "../src/ctrl/walletHelpers.ts"],
4
+ "sourcesContent": [
5
+ "import {\n type AssetValue,\n Chain,\n ChainToChainId,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { NonETHToolbox } from \"@swapkit/toolboxes/evm\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport {\n type WalletTxParams,\n getCtrlAddress,\n getCtrlMethods,\n getCtrlProvider,\n solanaTransfer,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\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.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, balance: [], chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { SOLToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const toolbox = SOLToolbox();\n const pubKey = await window.xfi?.solana?.connect();\n\n if (!pubKey) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n return { ...toolbox, transfer: solanaTransfer(toolbox, pubKey.publicKey) };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getToolboxByChain, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = getToolboxByChain(chain);\n\n return {\n ...toolbox(),\n deposit: (tx: WalletTxParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: WalletTxParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const chainId = ChainToChainId[chain];\n\n await window.xfi?.keplr?.enable(chainId);\n // @ts-ignore\n const offlineSigner = window.xfi?.keplr?.getOfflineSignerOnlyAmino(chainId);\n\n const toolbox = getToolboxByChain(chain)();\n\n const transfer = (params: {\n from: string;\n recipient: string;\n assetValue: AssetValue;\n memo: string;\n }) => toolbox.transfer({ signer: offlineSigner, ...params });\n\n return {\n ...toolbox,\n\n transfer,\n };\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = getToolboxByChain(chain)();\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\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 { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n const ctrlMethods = getCtrlMethods(provider);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = (toolbox as NonETHToolbox).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.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n default:\n return null;\n }\n}\n",
6
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport type { PublicKey } from \"@solana/web3.js\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { TransferParams } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SOLToolbox, SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: 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\nexport function getCtrlProvider<T extends Chain>(\n chain: T,\n): T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\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 // @ts-expect-error\n return window.xfi.ethereum;\n\n case Chain.Cosmos:\n case Chain.Kujira:\n // @ts-expect-error\n return window.xfi.keplr;\n\n case Chain.Bitcoin:\n // @ts-expect-error\n return window.xfi.bitcoin;\n case Chain.BitcoinCash:\n // @ts-expect-error\n return window.xfi.bitcoincash;\n case Chain.Dogecoin:\n // @ts-expect-error\n return window.xfi.dogecoin;\n case Chain.Litecoin:\n // @ts-expect-error\n return window.xfi.litecoin;\n case Chain.THORChain:\n // @ts-expect-error\n return window.xfi.thorchain;\n case Chain.Maya:\n // @ts-expect-error\n return window.xfi.mayachain;\n case Chain.Solana:\n // @ts-expect-error\n return window.xfi.solana;\n\n default:\n // @ts-expect-error\n return undefined;\n }\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 = getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n const eipProvider = getCtrlProvider(chain) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const [response] = await eipProvider.request({ method: \"eth_requestAccounts\", params: [] });\n\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n return new Promise((resolve, reject) =>\n eipProvider.request(\n { method: \"request_accounts\", params: [] },\n // @ts-expect-error\n (error: any, [response]: string[]) => (error ? reject(error) : resolve(response)),\n ),\n );\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_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 getCtrlAddress(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 memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function solanaTransfer(\n solToolbox: ReturnType<typeof SOLToolbox>,\n walletPublicKey: PublicKey,\n) {\n return async ({\n recipient,\n assetValue,\n memo,\n isProgramDerivedAddress,\n }: TransferParams & { isProgramDerivedAddress?: boolean }) => {\n const transaction = await solToolbox.createSolanaTransaction({\n recipient,\n assetValue,\n memo,\n fromPublicKey: walletPublicKey,\n isProgramDerivedAddress,\n });\n\n const signedTransaction = await window.xfi?.solana.signTransaction(transaction);\n\n if (!signedTransaction) {\n throw new SwapKitError(\"core_transaction_failed\");\n }\n\n return solToolbox.broadcastTransaction(signedTransaction);\n };\n}\n\nexport function getCtrlMethods(provider: BrowserProvider) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n const contractProvider = provider;\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, createContractTxObject, isStateChangingCall, toHexString } =\n await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall(abi, funcName);\n\n if (isStateChanging) {\n const { value, from, to, data } = await createContractTxObject(contractProvider, {\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n }\n const contract = createContract(contractAddress, abi, contractProvider);\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, createContractTxObject, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\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 { value, to, data } = await createContractTxObject(provider, functionCallParams);\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n };\n}\n"
7
+ ],
8
+ "mappings": "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",
9
+ "debugId": "5BCD1AE3F71FA0AD64756E2164756E21",
10
+ "names": []
11
+ }
@@ -0,0 +1,3 @@
1
+ import{r as M}from"../../chunk-ha78se5g.js";import{s as i,t as B}from"../../chunk-5m175wfy.js";import{Chain as l,ChainToChainId as r,SwapKitError as P,WalletOption as D,createWallet as z,filterSupportedChains as J}from"@swapkit/helpers";import{Chain as p,ChainToChainId as A,EVMChains as C,SwapKitError as S,WalletOption as e}from"@swapkit/helpers";import{erc20ABI as F}from"@swapkit/helpers/contracts";function b(o){if(!window.xfi)throw new S("wallet_ctrl_not_found");switch(o){case p.Arbitrum:case p.Avalanche:case p.Base:case p.BinanceSmartChain:case p.Ethereum:case p.Optimism:case p.Polygon:return window.xfi.ethereum;case p.Cosmos:case p.Kujira:return window.xfi.keplr;case p.Bitcoin:return window.xfi.bitcoin;case p.BitcoinCash:return window.xfi.bitcoincash;case p.Dogecoin:return window.xfi.dogecoin;case p.Litecoin:return window.xfi.litecoin;case p.THORChain:return window.xfi.thorchain;case p.Maya:return window.xfi.mayachain;case p.Solana:return window.xfi.solana;default:return}}async function Y({method:o,params:n,chain:t}){let w=b(t);return new Promise((y,f)=>{if(w&&"request"in w)w.request({method:o,params:n},(_,T)=>{_?f(_):y(T)})})}async function L(o){let n=b(o);if(!n)throw new S({errorKey:"wallet_provider_not_found",info:{wallet:e.CTRL,chain:o}});if([p.Cosmos,p.Kujira].includes(o)){let t=b(p.Cosmos);if(!t||"request"in t)throw new S({errorKey:"wallet_provider_not_found",info:{wallet:e.CTRL,chain:o}});let w=A[o];await t.enable(w);let y=t.getOfflineSigner(w),[f]=await y.getAccounts();return f?.address}if(C.includes(o)){let[t]=await n.request({method:"eth_requestAccounts",params:[]});return t}if(o===p.Solana)return(await b(p.Solana).connect()).publicKey.toString();return new Promise((t,w)=>n.request({method:"request_accounts",params:[]},(y,[f])=>y?w(y):t(f)))}async function x({assetValue:o,recipient:n,memo:t,gasLimit:w},y="transfer"){if(!o)throw new S("wallet_ctrl_asset_not_defined");let f=await L(o.chain),_=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},memo:t||"",from:f,recipient:n,gasLimit:w}];return Y({method:y,params:_,chain:o.chain})}function k(o,n){return async({recipient:t,assetValue:w,memo:y,isProgramDerivedAddress:f})=>{let _=await o.createSolanaTransaction({recipient:t,assetValue:w,memo:y,fromPublicKey:n,isProgramDerivedAddress:f}),T=await window.xfi?.solana.signTransaction(_);if(!T)throw new S("core_transaction_failed");return o.broadcastTransaction(T)}}function H(o){return{call:async({contractAddress:n,abi:t,funcName:w,funcParams:y=[],txOverrides:f})=>{let _=o;if(!n)throw new S("wallet_ctrl_contract_address_not_provided");let{createContract:T,createContractTxObject:E,isStateChangingCall:R,toHexString:W}=await import("@swapkit/toolboxes/evm");if(R(t,w)){let{value:U,from:I,to:N,data:G}=await E(_,{contractAddress:n,abi:t,funcName:w,funcParams:y,txOverrides:f});return o.send("eth_sendTransaction",[{value:W(BigInt(U||0)),from:I,to:N,data:G||"0x"}])}let g=await T(n,t,_)[w]?.(...y);return typeof g?.hash==="string"?g?.hash:g},approve:async({assetAddress:n,spenderAddress:t,amount:w,from:y})=>{let{MAX_APPROVAL:f,createContractTxObject:_,toHexString:T}=await import("@swapkit/toolboxes/evm"),E=[t,BigInt(w||f)],W={contractAddress:n,abi:F,funcName:"approve",funcParams:E,txOverrides:{from:y}},{value:c,to:m,data:g}=await _(o,W);return o.send("eth_sendTransaction",[{value:T(BigInt(c||0)),from:y,to:m,data:g||"0x"}])},sendTransaction:async(n)=>{let{from:t,to:w,data:y,value:f}=n;if(!w)throw new S("wallet_ctrl_send_transaction_no_address");let{toHexString:_}=await import("@swapkit/toolboxes/evm");return o.send("eth_sendTransaction",[{value:_(BigInt(f||0)),from:t,to:w,data:y||"0x"}])}}}var O=z({name:"connectCtrl",walletType:D.CTRL,supportedChains:[l.Arbitrum,l.Avalanche,l.Base,l.BinanceSmartChain,l.Bitcoin,l.BitcoinCash,l.Cosmos,l.Dogecoin,l.Ethereum,l.Kujira,l.Litecoin,l.Maya,l.Optimism,l.Polygon,l.Solana,l.THORChain],connect:({addChain:o,walletType:n,supportedChains:t})=>async function w(y){let _=J({chains:y,supportedChains:t,walletType:n}).map(async(T)=>{let E=await L(T),R=await Z(T);o({...R,address:E,balance:[],chain:T,walletType:n})});return await Promise.all(_),!0}}),Q=M(O);async function Z(o){switch(o){case l.Solana:{let{SOLToolbox:n}=await import("@swapkit/toolboxes/solana"),t=n(),w=await window.xfi?.solana?.connect();if(!w)throw new P("wallet_ctrl_not_found");return{...t,transfer:k(t,w.publicKey)}}case l.Maya:case l.THORChain:{let{getToolboxByChain:n,THORCHAIN_GAS_VALUE:t,MAYA_GAS_VALUE:w}=await import("@swapkit/toolboxes/cosmos"),y=o===l.Maya?w:t;return{...n(o)(),deposit:(_)=>x({..._,recipient:""},"deposit"),transfer:(_)=>x({..._,gasLimit:y},"transfer")}}case l.Cosmos:case l.Kujira:{let{getToolboxByChain:n}=await import("@swapkit/toolboxes/cosmos"),t=r[o];await window.xfi?.keplr?.enable(t);let w=window.xfi?.keplr?.getOfflineSignerOnlyAmino(t),y=n(o)();return{...y,transfer:(_)=>y.transfer({signer:w,..._})}}case l.Bitcoin:case l.BitcoinCash:case l.Dogecoin:case l.Litecoin:{let{getToolboxByChain:n}=await import("@swapkit/toolboxes/utxo");return{...n(o)(),transfer:x}}case l.Arbitrum:case l.Avalanche:case l.Base:case l.BinanceSmartChain:case l.Ethereum:case l.Optimism:case l.Polygon:{let{prepareNetworkSwitch:n,switchEVMWalletNetwork:t}=await import("@swapkit/helpers"),{getToolboxByChain:w}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:y}=await import("ethers"),f=b(o);if(!f)throw new P("wallet_ctrl_not_found");let _=new y(f,"any"),T=await _.getSigner(),E=w(o)({provider:_,signer:T}),R=H(_);try{if(o!==l.Ethereum){let W=E.getNetworkParams();await t(_,o,W)}}catch(W){throw new P({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:D.CTRL,chain:o}})}return n({provider:window.xfi?.ethereum,chain:o,toolbox:{...E,...R}})}default:return null}}export{O as ctrlWallet,Q as CTRL_SUPPORTED_CHAINS};export{O as m};
2
+
3
+ //# debugId=124533DC3F2CE93964756E2164756E21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/ctrl/ctrlWallet.ts", "../src/ctrl/walletHelpers.ts"],
4
+ "sourcesContent": [
5
+ "import {\n type AssetValue,\n Chain,\n ChainToChainId,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { NonETHToolbox } from \"@swapkit/toolboxes/evm\";\n\nimport { getWalletSupportedChains } from \"../helpers\";\nimport {\n type WalletTxParams,\n getCtrlAddress,\n getCtrlMethods,\n getCtrlProvider,\n solanaTransfer,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\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.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, balance: [], chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { SOLToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const toolbox = SOLToolbox();\n const pubKey = await window.xfi?.solana?.connect();\n\n if (!pubKey) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n return { ...toolbox, transfer: solanaTransfer(toolbox, pubKey.publicKey) };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getToolboxByChain, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = getToolboxByChain(chain);\n\n return {\n ...toolbox(),\n deposit: (tx: WalletTxParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: WalletTxParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const chainId = ChainToChainId[chain];\n\n await window.xfi?.keplr?.enable(chainId);\n // @ts-ignore\n const offlineSigner = window.xfi?.keplr?.getOfflineSignerOnlyAmino(chainId);\n\n const toolbox = getToolboxByChain(chain)();\n\n const transfer = (params: {\n from: string;\n recipient: string;\n assetValue: AssetValue;\n memo: string;\n }) => toolbox.transfer({ signer: offlineSigner, ...params });\n\n return {\n ...toolbox,\n\n transfer,\n };\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = getToolboxByChain(chain)();\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\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 { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n const ctrlMethods = getCtrlMethods(provider);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = (toolbox as NonETHToolbox).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.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n default:\n return null;\n }\n}\n",
6
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport type { PublicKey } from \"@solana/web3.js\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { TransferParams } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SOLToolbox, SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: 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\nexport function getCtrlProvider<T extends Chain>(\n chain: T,\n): T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\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 // @ts-expect-error\n return window.xfi.ethereum;\n\n case Chain.Cosmos:\n case Chain.Kujira:\n // @ts-expect-error\n return window.xfi.keplr;\n\n case Chain.Bitcoin:\n // @ts-expect-error\n return window.xfi.bitcoin;\n case Chain.BitcoinCash:\n // @ts-expect-error\n return window.xfi.bitcoincash;\n case Chain.Dogecoin:\n // @ts-expect-error\n return window.xfi.dogecoin;\n case Chain.Litecoin:\n // @ts-expect-error\n return window.xfi.litecoin;\n case Chain.THORChain:\n // @ts-expect-error\n return window.xfi.thorchain;\n case Chain.Maya:\n // @ts-expect-error\n return window.xfi.mayachain;\n case Chain.Solana:\n // @ts-expect-error\n return window.xfi.solana;\n\n default:\n // @ts-expect-error\n return undefined;\n }\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 = getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n const eipProvider = getCtrlProvider(chain) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const [response] = await eipProvider.request({ method: \"eth_requestAccounts\", params: [] });\n\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n return new Promise((resolve, reject) =>\n eipProvider.request(\n { method: \"request_accounts\", params: [] },\n // @ts-expect-error\n (error: any, [response]: string[]) => (error ? reject(error) : resolve(response)),\n ),\n );\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_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 getCtrlAddress(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 memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function solanaTransfer(\n solToolbox: ReturnType<typeof SOLToolbox>,\n walletPublicKey: PublicKey,\n) {\n return async ({\n recipient,\n assetValue,\n memo,\n isProgramDerivedAddress,\n }: TransferParams & { isProgramDerivedAddress?: boolean }) => {\n const transaction = await solToolbox.createSolanaTransaction({\n recipient,\n assetValue,\n memo,\n fromPublicKey: walletPublicKey,\n isProgramDerivedAddress,\n });\n\n const signedTransaction = await window.xfi?.solana.signTransaction(transaction);\n\n if (!signedTransaction) {\n throw new SwapKitError(\"core_transaction_failed\");\n }\n\n return solToolbox.broadcastTransaction(signedTransaction);\n };\n}\n\nexport function getCtrlMethods(provider: BrowserProvider) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n const contractProvider = provider;\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, createContractTxObject, isStateChangingCall, toHexString } =\n await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall(abi, funcName);\n\n if (isStateChanging) {\n const { value, from, to, data } = await createContractTxObject(contractProvider, {\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n }\n const contract = createContract(contractAddress, abi, contractProvider);\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, createContractTxObject, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\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 { value, to, data } = await createContractTxObject(provider, functionCallParams);\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n {\n value: toHexString(BigInt(value || 0)),\n from,\n to,\n data: data || \"0x\",\n } as any,\n ]);\n },\n };\n}\n"
7
+ ],
8
+ "mappings": "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",
9
+ "debugId": "124533DC3F2CE93964756E2164756E21",
10
+ "names": []
11
+ }
@@ -0,0 +1,3 @@
1
+ var C={};A(C,{getWeb3WalletMethods:()=>E,evmWallet:()=>M,EVM_EXTENSIONS_SUPPORTED_CHAINS:()=>v});module.exports=P(C);var t=require("@swapkit/helpers");var B=(r)=>{switch(r){case t.WalletOption.COINBASE_WEB:return window.coinbaseWalletExtension;case t.WalletOption.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},E=async({walletProvider:r,chain:e,provider:n})=>{if(!r)throw new Error("Requested web3 wallet is not installed");let{getToolboxByChain:w}=await import("@swapkit/toolboxes/evm"),o=await n.getSigner(),a=w(e)({provider:n,signer:o});if(e!==t.Chain.Ethereum){if((await n.getNetwork()).chainId.toString()!==t.ChainToHexChainId[e])try{let s=a.getNetworkParams();await t.switchEVMWalletNetwork(n,e,s)}catch(s){throw new Error(`Failed to add/switch ${e} network: ${e}`)}}return t.prepareNetworkSwitch({toolbox:a,chain:e,provider:n})},M=t.createWallet({name:"connectEVMWallet",supportedChains:[...t.EVMChains],connect:({addChain:r,supportedChains:e})=>async function n(w,o=t.WalletOption.METAMASK,a){let p=t.filterSupportedChains({chains:w,supportedChains:e,walletType:o}),{getProvider:s}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:W}=await import("ethers");return await Promise.all(p.map(async(i)=>{if(o===t.WalletOption.EIP6963){if(!a)throw new Error("Missing provider");let l=new W(a,"any");await l.send("eth_requestAccounts",[]);let m=await(await l.getSigner()).getAddress(),h=await E({chain:i,provider:l,walletProvider:a});r({...h,address:m,balance:[],chain:i,getBalance:async(S=!0)=>h.getBalance(m,S,s(i)),walletType:o});return}let c=new W(B(o),"any");await c.send("eth_requestAccounts",[]);let u=await(await c.getSigner()).getAddress(),g=await E({chain:i,walletProvider:B(o),provider:c});r({...g,address:u,balance:[],chain:i,disconnect:()=>c.send("wallet_revokePermissions",[{eth_accounts:{}}]),getBalance:(l=!0)=>g.getBalance(u,l,s(i)),walletType:o})})),!0}}),v=O(M);
2
+
3
+ //# debugId=A58395CD767A6EC764756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/evm-extensions/index.ts"],
4
+ "sourcesContent": [
5
+ "import {\n Chain,\n ChainToHexChainId,\n type EVMChain,\n EVMChains,\n type EthereumWindowProvider,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NonETHToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport { getWalletSupportedChains } from \"../helpers\";\n\ndeclare const window: {\n ethereum: EthereumWindowProvider;\n trustwallet: EthereumWindowProvider;\n coinbaseWalletExtension: EthereumWindowProvider;\n braveSolana: any;\n} & Window;\n\nexport type EVMWalletOptions =\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963;\n\nconst getWalletForType = (\n walletType:\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB,\n) => {\n switch (walletType) {\n case WalletOption.COINBASE_WEB:\n return window.coinbaseWalletExtension;\n case WalletOption.TRUSTWALLET_WEB:\n return window.trustwallet;\n default:\n return window.ethereum;\n }\n};\n\nexport const getWeb3WalletMethods = async ({\n walletProvider,\n chain,\n provider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain; provider: BrowserProvider }) => {\n if (!walletProvider) throw new Error(\"Requested web3 wallet is not installed\");\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n if (chain !== Chain.Ethereum) {\n const currentNetwork = await provider.getNetwork();\n if (currentNetwork.chainId.toString() !== ChainToHexChainId[chain]) {\n try {\n const networkParams = (toolbox as NonETHToolbox).getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n }\n }\n\n return prepareNetworkSwitch<typeof toolbox>({ toolbox, chain, provider });\n};\n\nexport const evmWallet = createWallet({\n name: \"connectEVMWallet\",\n supportedChains: [...EVMChains] as EVMChain[],\n connect: ({ addChain, supportedChains }) =>\n async function connectEVMWallet(\n chains: Chain[],\n walletType: EVMWalletOptions = WalletOption.METAMASK,\n eip1193Provider?: Eip1193Provider,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { getProvider } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963) {\n if (!eip1193Provider) throw new Error(\"Missing provider\");\n const provider = new BrowserProvider(eip1193Provider, \"any\");\n await provider.send(\"eth_requestAccounts\", []);\n const signer = await provider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n chain,\n provider,\n walletProvider: eip1193Provider,\n });\n\n const getBalance = async (potentialScamFilter = true) =>\n walletMethods.getBalance(address, potentialScamFilter, getProvider(chain));\n\n addChain({\n ...walletMethods,\n address,\n balance: [],\n chain,\n getBalance,\n walletType,\n });\n return;\n }\n\n const web3provider = new BrowserProvider(getWalletForType(walletType), \"any\");\n await web3provider.send(\"eth_requestAccounts\", []);\n const signer = await web3provider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n chain,\n walletProvider: getWalletForType(walletType),\n provider: web3provider,\n });\n\n const getBalance = (potentialScamFilter = true) =>\n walletMethods.getBalance(address, potentialScamFilter, getProvider(chain));\n\n const disconnect = () =>\n web3provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n address,\n balance: [],\n chain,\n disconnect,\n getBalance,\n walletType,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
6
+ ],
7
+ "mappings": "qHAWO,IAXP,8BA+BA,IAAM,EAAmB,CACvB,IAMG,CACH,OAAQ,QACD,eAAa,aAChB,OAAO,OAAO,6BACX,eAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,iBACA,QACA,cACsF,CACtF,IAAK,EAAgB,MAAM,IAAI,MAAM,wCAAwC,EAC7E,IAAQ,qBAAsB,KAAa,kCAErC,EAAS,MAAM,EAAS,UAAU,EAElC,EAAU,EAAkB,CAAK,EAAE,CAAE,WAAU,QAAO,CAAC,EAE7D,GAAI,IAAU,QAAM,UAElB,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,oBAAkB,GAC1D,GAAI,CACF,IAAM,EAAiB,EAA0B,iBAAiB,EAClE,MAAM,yBAAuB,EAAU,EAAO,CAAa,QACpD,EAAP,CACA,MAAM,IAAI,MAAM,wBAAwB,cAAkB,GAAO,GAKvE,OAAO,uBAAqC,CAAE,UAAS,QAAO,UAAS,CAAC,GAG7D,EAAY,eAAa,CACpC,KAAM,mBACN,gBAAiB,CAAC,GAAG,WAAS,EAC9B,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAgB,CAC7B,EACA,EAA+B,eAAa,SAC5C,EACA,CACA,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,eAAgB,KAAa,mCAC7B,mBAAoB,KAAa,kBA4DzC,OA1DA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,eAAa,QAAS,CACvC,IAAK,EAAiB,MAAM,IAAI,MAAM,kBAAkB,EACxD,IAAM,EAAW,IAAI,EAAgB,EAAiB,KAAK,EAC3D,MAAM,EAAS,KAAK,sBAAuB,CAAC,CAAC,EAE7C,IAAM,EAAU,MADD,MAAM,EAAS,UAAU,GACX,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,QACA,WACA,eAAgB,CAClB,CAAC,EAKD,EAAS,IACJ,EACH,UACA,QAAS,CAAC,EACV,QACA,WARiB,MAAO,EAAsB,KAC9C,EAAc,WAAW,EAAS,EAAqB,EAAY,CAAK,CAAC,EAQzE,YACF,CAAC,EACD,OAGF,IAAM,EAAe,IAAI,EAAgB,EAAiB,CAAU,EAAG,KAAK,EAC5E,MAAM,EAAa,KAAK,sBAAuB,CAAC,CAAC,EAEjD,IAAM,EAAU,MADD,MAAM,EAAa,UAAU,GACf,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,QACA,eAAgB,EAAiB,CAAU,EAC3C,SAAU,CACZ,CAAC,EAQD,EAAS,IACJ,EACH,UACA,QAAS,CAAC,EACV,QACA,WARiB,IACjB,EAAa,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EAQpE,WAZiB,CAAC,EAAsB,KACxC,EAAc,WAAW,EAAS,EAAqB,EAAY,CAAK,CAAC,EAYzE,YACF,CAAC,EACF,CACH,EAEO,GAEb,CAAC,EAEY,EAAkC,EAAyB,CAAS",
8
+ "debugId": "A58395CD767A6EC764756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,4 @@
1
+ import{r as M}from"../../chunk-ha78se5g.js";import{s as d,t as E}from"../../chunk-5m175wfy.js";import{Chain as P,ChainToHexChainId as A,EVMChains as v,WalletOption as c,createWallet as C,filterSupportedChains as T,prepareNetworkSwitch as b,switchEVMWalletNetwork as f}from"@swapkit/helpers";var B=(o)=>{switch(o){case c.COINBASE_WEB:return window.coinbaseWalletExtension;case c.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},O=async({walletProvider:o,chain:t,provider:r})=>{if(!o)throw new Error("Requested web3 wallet is not installed");let{getToolboxByChain:w}=await import("@swapkit/toolboxes/evm"),e=await r.getSigner(),n=w(t)({provider:r,signer:e});if(t!==P.Ethereum){if((await r.getNetwork()).chainId.toString()!==A[t])try{let i=n.getNetworkParams();await f(r,t,i)}catch(i){throw new Error(`Failed to add/switch ${t} network: ${t}`)}}return b({toolbox:n,chain:t,provider:r})},N=C({name:"connectEVMWallet",supportedChains:[...v],connect:({addChain:o,supportedChains:t})=>async function r(w,e=c.METAMASK,n){let p=T({chains:w,supportedChains:t,walletType:e}),{getProvider:i}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:W}=await import("ethers");return await Promise.all(p.map(async(a)=>{if(e===c.EIP6963){if(!n)throw new Error("Missing provider");let s=new W(n,"any");await s.send("eth_requestAccounts",[]);let m=await(await s.getSigner()).getAddress(),h=await O({chain:a,provider:s,walletProvider:n});o({...h,address:m,balance:[],chain:a,getBalance:async(S=!0)=>h.getBalance(m,S,i(a)),walletType:e});return}let l=new W(B(e),"any");await l.send("eth_requestAccounts",[]);let u=await(await l.getSigner()).getAddress(),g=await O({chain:a,walletProvider:B(e),provider:l});o({...g,address:u,balance:[],chain:a,disconnect:()=>l.send("wallet_revokePermissions",[{eth_accounts:{}}]),getBalance:(s=!0)=>g.getBalance(u,s,i(a)),walletType:e})})),!0}}),R=M(N);export{O as getWeb3WalletMethods,N as evmWallet,R as EVM_EXTENSIONS_SUPPORTED_CHAINS};
2
+ export{N as n};
3
+
4
+ //# debugId=12F176EE0F2D01F164756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/evm-extensions/index.ts"],
4
+ "sourcesContent": [
5
+ "import {\n Chain,\n ChainToHexChainId,\n type EVMChain,\n EVMChains,\n type EthereumWindowProvider,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NonETHToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport { getWalletSupportedChains } from \"../helpers\";\n\ndeclare const window: {\n ethereum: EthereumWindowProvider;\n trustwallet: EthereumWindowProvider;\n coinbaseWalletExtension: EthereumWindowProvider;\n braveSolana: any;\n} & Window;\n\nexport type EVMWalletOptions =\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963;\n\nconst getWalletForType = (\n walletType:\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB,\n) => {\n switch (walletType) {\n case WalletOption.COINBASE_WEB:\n return window.coinbaseWalletExtension;\n case WalletOption.TRUSTWALLET_WEB:\n return window.trustwallet;\n default:\n return window.ethereum;\n }\n};\n\nexport const getWeb3WalletMethods = async ({\n walletProvider,\n chain,\n provider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain; provider: BrowserProvider }) => {\n if (!walletProvider) throw new Error(\"Requested web3 wallet is not installed\");\n const { getToolboxByChain } = await import(\"@swapkit/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n\n const toolbox = getToolboxByChain(chain)({ provider, signer });\n\n if (chain !== Chain.Ethereum) {\n const currentNetwork = await provider.getNetwork();\n if (currentNetwork.chainId.toString() !== ChainToHexChainId[chain]) {\n try {\n const networkParams = (toolbox as NonETHToolbox).getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch (_error) {\n throw new Error(`Failed to add/switch ${chain} network: ${chain}`);\n }\n }\n }\n\n return prepareNetworkSwitch<typeof toolbox>({ toolbox, chain, provider });\n};\n\nexport const evmWallet = createWallet({\n name: \"connectEVMWallet\",\n supportedChains: [...EVMChains] as EVMChain[],\n connect: ({ addChain, supportedChains }) =>\n async function connectEVMWallet(\n chains: Chain[],\n walletType: EVMWalletOptions = WalletOption.METAMASK,\n eip1193Provider?: Eip1193Provider,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { getProvider } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963) {\n if (!eip1193Provider) throw new Error(\"Missing provider\");\n const provider = new BrowserProvider(eip1193Provider, \"any\");\n await provider.send(\"eth_requestAccounts\", []);\n const signer = await provider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n chain,\n provider,\n walletProvider: eip1193Provider,\n });\n\n const getBalance = async (potentialScamFilter = true) =>\n walletMethods.getBalance(address, potentialScamFilter, getProvider(chain));\n\n addChain({\n ...walletMethods,\n address,\n balance: [],\n chain,\n getBalance,\n walletType,\n });\n return;\n }\n\n const web3provider = new BrowserProvider(getWalletForType(walletType), \"any\");\n await web3provider.send(\"eth_requestAccounts\", []);\n const signer = await web3provider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n chain,\n walletProvider: getWalletForType(walletType),\n provider: web3provider,\n });\n\n const getBalance = (potentialScamFilter = true) =>\n walletMethods.getBalance(address, potentialScamFilter, getProvider(chain));\n\n const disconnect = () =>\n web3provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n address,\n balance: [],\n chain,\n disconnect,\n getBalance,\n walletType,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
6
+ ],
7
+ "mappings": "iGAAA,cACE,uBACA,eAEA,kBAEA,kBACA,2BACA,0BACA,4BACA,yBAqBF,IAAM,EAAmB,CACvB,IAMG,CACH,OAAQ,QACD,EAAa,aAChB,OAAO,OAAO,6BACX,EAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,iBACA,QACA,cACsF,CACtF,IAAK,EAAgB,MAAM,IAAI,MAAM,wCAAwC,EAC7E,IAAQ,qBAAsB,KAAa,kCAErC,EAAS,MAAM,EAAS,UAAU,EAElC,EAAU,EAAkB,CAAK,EAAE,CAAE,WAAU,QAAO,CAAC,EAE7D,GAAI,IAAU,EAAM,UAElB,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,EAAkB,GAC1D,GAAI,CACF,IAAM,EAAiB,EAA0B,iBAAiB,EAClE,MAAM,EAAuB,EAAU,EAAO,CAAa,QACpD,EAAP,CACA,MAAM,IAAI,MAAM,wBAAwB,cAAkB,GAAO,GAKvE,OAAO,EAAqC,CAAE,UAAS,QAAO,UAAS,CAAC,GAG7D,EAAY,EAAa,CACpC,KAAM,mBACN,gBAAiB,CAAC,GAAG,CAAS,EAC9B,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAgB,CAC7B,EACA,EAA+B,EAAa,SAC5C,EACA,CACA,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,eAAgB,KAAa,mCAC7B,mBAAoB,KAAa,kBA4DzC,OA1DA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,EAAa,QAAS,CACvC,IAAK,EAAiB,MAAM,IAAI,MAAM,kBAAkB,EACxD,IAAM,EAAW,IAAI,EAAgB,EAAiB,KAAK,EAC3D,MAAM,EAAS,KAAK,sBAAuB,CAAC,CAAC,EAE7C,IAAM,EAAU,MADD,MAAM,EAAS,UAAU,GACX,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,QACA,WACA,eAAgB,CAClB,CAAC,EAKD,EAAS,IACJ,EACH,UACA,QAAS,CAAC,EACV,QACA,WARiB,MAAO,EAAsB,KAC9C,EAAc,WAAW,EAAS,EAAqB,EAAY,CAAK,CAAC,EAQzE,YACF,CAAC,EACD,OAGF,IAAM,EAAe,IAAI,EAAgB,EAAiB,CAAU,EAAG,KAAK,EAC5E,MAAM,EAAa,KAAK,sBAAuB,CAAC,CAAC,EAEjD,IAAM,EAAU,MADD,MAAM,EAAa,UAAU,GACf,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,QACA,eAAgB,EAAiB,CAAU,EAC3C,SAAU,CACZ,CAAC,EAQD,EAAS,IACJ,EACH,UACA,QAAS,CAAC,EACV,QACA,WARiB,IACjB,EAAa,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EAQpE,WAZiB,CAAC,EAAsB,KACxC,EAAc,WAAW,EAAS,EAAqB,EAAY,CAAK,CAAC,EAYzE,YACF,CAAC,EACF,CACH,EAEO,GAEb,CAAC,EAEY,EAAkC,EAAyB,CAAS",
8
+ "debugId": "12F176EE0F2D01F164756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,3 @@
1
+ var t={};T(t,{getWalletMethods:()=>b,exodusWallet:()=>B,EXODUS_SUPPORTED_CHAINS:()=>C});module.exports=E(t);var e=require("@swapkit/helpers"),a=require("sats-connect");o(t,require("@passkeys/react"),module.exports);o(t,require("@passkeys/core"),module.exports);var b=async({walletProvider:g,provider:u,chain:s})=>{switch(s){case e.Chain.Bitcoin:{let{BTCToolbox:P,Psbt:m}=await import("@swapkit/toolboxes/utxo"),d=P(),n="",c=()=>new Promise((r)=>r(u)),p={getProvider:c,payload:{purposes:[a.AddressPurpose.Payment],message:"Address for receiving and sending payments",network:{type:a.BitcoinNetworkType.Mainnet}},onFinish:(r)=>{if(!r.addresses[0])throw new Error("No address found");n=r.addresses[0].address},onCancel:()=>{throw new Error("Request canceled")}};await a.getAddress(p);async function i(r){let w,v={getProvider:c,payload:{message:"Sign transaction",network:{type:a.BitcoinNetworkType.Mainnet},psbtBase64:r.toBase64(),broadcast:!1,inputsToSign:[{address:n,signingIndexes:r.txInputs.map((f,y)=>y)}]},onFinish:(f)=>{w=m.fromBase64(f.psbtBase64)},onCancel:()=>{throw new Error("Signature canceled")}};if(await a.signTransaction(v),!w)throw new e.SwapKitError("wallet_exodus_sign_transaction_error");return w}return{...d,transfer:(r)=>{return d.transfer({...r,signTransaction:i})},address:n}}case e.Chain.Arbitrum:case e.Chain.Avalanche:case e.Chain.Base:case e.Chain.BinanceSmartChain:case e.Chain.Ethereum:case e.Chain.Optimism:case e.Chain.Polygon:{if(!g)throw new Error("Requested web3 wallet is not installed");let{getProvider:P,getToolboxByChain:m}=await import("@swapkit/toolboxes/evm"),d=P(s),n=u;await n.send("eth_requestAccounts",[]);let c=await n.getSigner(),p=await c.getAddress(),i=m(s)({provider:d,signer:c});try{if(s!==e.Chain.Ethereum){let l=i.getNetworkParams();await e.switchEVMWalletNetwork(n,s,l)}}catch(l){throw new Error(`Failed to add/switch ${s} network: ${s}`)}return{address:p,...e.prepareNetworkSwitch({toolbox:i,chain:s,provider:n})}}default:throw new Error(`Unsupported chain: ${s}`)}},B=e.createWallet({name:"connectExodusWallet",walletType:e.WalletOption.EXODUS,supportedChains:[...e.EVMChains,e.Chain.Bitcoin],connect:({addChain:g,walletType:u,supportedChains:s})=>async function P(m,d){if(!d)throw new Error("Missing Exodus Wallet instance");let n=e.filterSupportedChains({chains:m,supportedChains:s,walletType:u}),{BrowserProvider:c}=await import("ethers"),{providers:p}=d;return await Promise.all(n.map(async(i)=>{let l=i===e.Chain.Bitcoin?p.bitcoin:new c(p.ethereum,"any"),{address:r,...w}=await b({chain:i,provider:l,walletProvider:p.ethereum});g({...w,disconnect:()=>l.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:i,address:r,getBalance:async(y=!0)=>w.getBalance(r,y),balance:[],walletType:e.WalletOption.EXODUS})})),!0}}),C=x(B);
2
+
3
+ //# debugId=D04F8FD66B0591D564756E2164756E21