@swapkit/wallets 3.0.0-beta.22 → 3.0.0-beta.23

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 (82) hide show
  1. package/dist/{chunk-x5hgx9x9.js → chunk-0qaxr89s.js} +2 -2
  2. package/dist/{chunk-x5hgx9x9.js.map → chunk-0qaxr89s.js.map} +1 -1
  3. package/dist/chunk-bexr8da2.js +4 -0
  4. package/dist/chunk-bexr8da2.js.map +10 -0
  5. package/dist/chunk-dcj9twam.js +3 -0
  6. package/dist/chunk-dcj9twam.js.map +10 -0
  7. package/dist/{chunk-38ztynv0.js → chunk-qwd1kp32.js} +2 -2
  8. package/dist/{chunk-38ztynv0.js.map → chunk-qwd1kp32.js.map} +1 -1
  9. package/dist/chunk-sn6pgje5.js +3 -0
  10. package/dist/chunk-sn6pgje5.js.map +10 -0
  11. package/dist/chunk-wfattb4a.js +3 -0
  12. package/dist/chunk-wfattb4a.js.map +10 -0
  13. package/dist/{chunk-ebfkk1jn.js → chunk-zfnkndsr.js} +3 -3
  14. package/dist/{chunk-ebfkk1jn.js.map → chunk-zfnkndsr.js.map} +1 -1
  15. package/dist/src/bitget/index.js +2 -2
  16. package/dist/src/bitget/index.js.map +1 -1
  17. package/dist/src/coinbase/index.js +2 -2
  18. package/dist/src/coinbase/index.js.map +1 -1
  19. package/dist/src/cosmostation/index.js +2 -2
  20. package/dist/src/cosmostation/index.js.map +1 -1
  21. package/dist/src/ctrl/index.cjs +2 -2
  22. package/dist/src/ctrl/index.cjs.map +4 -4
  23. package/dist/src/ctrl/index.js +2 -2
  24. package/dist/src/ctrl/index.js.map +4 -4
  25. package/dist/src/evm-extensions/index.js +2 -2
  26. package/dist/src/evm-extensions/index.js.map +1 -1
  27. package/dist/src/exodus/index.js +2 -2
  28. package/dist/src/exodus/index.js.map +1 -1
  29. package/dist/src/index.js +2 -2
  30. package/dist/src/index.js.map +1 -1
  31. package/dist/src/keepkey/index.js +2 -2
  32. package/dist/src/keepkey/index.js.map +1 -1
  33. package/dist/src/keepkey-bex/index.js +2 -2
  34. package/dist/src/keepkey-bex/index.js.map +1 -1
  35. package/dist/src/keplr/index.js +2 -2
  36. package/dist/src/keplr/index.js.map +1 -1
  37. package/dist/src/keystore/index.cjs +2 -2
  38. package/dist/src/keystore/index.cjs.map +3 -3
  39. package/dist/src/keystore/index.js +2 -2
  40. package/dist/src/keystore/index.js.map +3 -3
  41. package/dist/src/ledger/index.cjs +3 -3
  42. package/dist/src/ledger/index.cjs.map +7 -6
  43. package/dist/src/ledger/index.js +3 -3
  44. package/dist/src/ledger/index.js.map +7 -6
  45. package/dist/src/okx/index.cjs +2 -2
  46. package/dist/src/okx/index.cjs.map +4 -4
  47. package/dist/src/okx/index.js +2 -2
  48. package/dist/src/okx/index.js.map +4 -4
  49. package/dist/src/onekey/index.js +2 -2
  50. package/dist/src/onekey/index.js.map +1 -1
  51. package/dist/src/phantom/index.js +2 -2
  52. package/dist/src/phantom/index.js.map +2 -2
  53. package/dist/src/polkadotjs/index.js +2 -2
  54. package/dist/src/polkadotjs/index.js.map +1 -1
  55. package/dist/src/radix/index.js +2 -2
  56. package/dist/src/radix/index.js.map +1 -1
  57. package/dist/src/talisman/index.js +2 -2
  58. package/dist/src/talisman/index.js.map +1 -1
  59. package/dist/src/trezor/index.js +2 -2
  60. package/dist/src/trezor/index.js.map +1 -1
  61. package/dist/src/walletconnect/index.cjs +2 -2
  62. package/dist/src/walletconnect/index.cjs.map +5 -6
  63. package/dist/src/walletconnect/index.js +2 -2
  64. package/dist/src/walletconnect/index.js.map +5 -6
  65. package/package.json +5 -3
  66. package/src/ctrl/index.ts +83 -0
  67. package/src/ctrl/walletHelpers.ts +16 -0
  68. package/src/helpers/near-browser-provider.d.ts +286 -0
  69. package/src/helpers/near.ts +206 -0
  70. package/src/keystore/index.ts +1 -0
  71. package/src/ledger/clients/near.ts +86 -0
  72. package/src/ledger/helpers/getLedgerAddress.ts +5 -0
  73. package/src/ledger/helpers/getLedgerClient.ts +7 -0
  74. package/src/ledger/index.ts +10 -0
  75. package/src/okx/helpers.ts +16 -0
  76. package/src/okx/index.ts +1 -0
  77. package/src/types.ts +11 -0
  78. package/src/walletconnect/constants.ts +2 -0
  79. package/src/walletconnect/helpers.ts +9 -2
  80. package/src/walletconnect/index.ts +68 -0
  81. /package/dist/{chunk-k9q04afa.js → chunk-ad832c7c.js} +0 -0
  82. /package/dist/{chunk-k9q04afa.js.map → chunk-ad832c7c.js.map} +0 -0
@@ -1,3 +1,3 @@
1
- import{a as F}from"../../chunk-ebfkk1jn.js";import{c as S,d as x}from"../../chunk-38ztynv0.js";import{Chain as t,ChainToChainId as m,SwapKitError as D,WalletOption as A,createWallet as s,filterSupportedChains as j}from"@swapkit/helpers";import{Chain as g,ChainToChainId as N,EVMChains as Q,SwapKitError as R,WalletOption as k,providerRequest as Z}from"@swapkit/helpers";import{erc20ABI as $}from"@swapkit/helpers/contracts";async function b(o){if(!window.xfi)throw new R("wallet_ctrl_not_found");let{match:l}=await import("ts-pattern");return l(o).with(g.Arbitrum,g.Avalanche,g.Base,g.BinanceSmartChain,g.Ethereum,g.Optimism,g.Polygon,()=>window.xfi?.ethereum).with(g.Cosmos,g.Kujira,()=>window.xfi?.keplr).with(g.Bitcoin,()=>window.xfi?.bitcoin).with(g.BitcoinCash,()=>window.xfi?.bitcoincash).with(g.Dogecoin,()=>window.xfi?.dogecoin).with(g.Litecoin,()=>window.xfi?.litecoin).with(g.Solana,()=>window.xfi?.solana).with(g.THORChain,()=>window.xfi?.thorchain).with(g.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function c({method:o,params:l,chain:y}){let w=await b(y);return new Promise((_,T)=>{if(w&&"request"in w)w.request({method:o,params:l},(n,f)=>{n?T(n):_(f)})})}async function E(o){try{let l=await b(o);if(!l)throw new R({errorKey:"wallet_provider_not_found",info:{wallet:k.CTRL,chain:o}});if([g.Cosmos,g.Kujira].includes(o)){let w=await b(g.Cosmos);if(!w||"request"in w)throw new R({errorKey:"wallet_provider_not_found",info:{wallet:k.CTRL,chain:o}});let _=N[o];await w.enable(_);let T=w.getOfflineSigner(_),[n]=await T.getAccounts();return n?.address}if(Q.includes(o)){if("request"in l&&typeof l.request==="function")return(await l.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:w}=await import("ethers"),_=new w(l,"any"),[T]=await Z({provider:_,method:"eth_requestAccounts",params:[]});return T}if(o===g.Solana)return(await(await b(g.Solana)).connect()).publicKey.toString();return(await l.request({method:"request_accounts",params:[]}))[0]}catch(l){throw new R({errorKey:"wallet_provider_not_found",info:{wallet:k.CTRL,chain:o}})}}async function G({assetValue:o,recipient:l,memo:y,gasLimit:w},_="transfer"){if(!o)throw new R("wallet_ctrl_asset_not_defined");let T=await E(o.chain),n=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},memo:y||"",from:T,recipient:l,gasLimit:w}];return c({method:_,params:n,chain:o.chain})}function z(o,l){return{call:async({contractAddress:y,abi:w,funcName:_,funcParams:T=[],txOverrides:n})=>{if(!y)throw new R("wallet_ctrl_contract_address_not_provided");let{createContract:f,getCreateContractTxObject:B,isStateChangingCall:H}=await import("@swapkit/toolboxes/evm");if(H({abi:w,funcName:_})){let U=B({provider:o,chain:l}),{value:W,from:O,to:Y,data:J}=await U({contractAddress:y,abi:w,funcName:_,funcParams:T,txOverrides:n});return(await(await o.getSigner()).sendTransaction({value:BigInt(W||0),from:O,to:Y,data:J||"0x"})).hash}let M=await f(y,w,o)[_]?.(...T);return typeof M?.hash==="string"?M?.hash:M},approve:async({assetAddress:y,spenderAddress:w,amount:_,from:T})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:f}=await import("@swapkit/toolboxes/evm"),B=[w,BigInt(_||n)],L={contractAddress:y,abi:$,funcName:"approve",funcParams:B,txOverrides:{from:T}},I=f({provider:o,chain:l}),{value:M,to:U,data:W}=await I(L);return(await(await o.getSigner()).sendTransaction({value:BigInt(M||0),from:T,to:U,data:W||"0x"})).hash},sendTransaction:async(y)=>{let{from:w,to:_,data:T,value:n}=y;if(!_)throw new R("wallet_ctrl_send_transaction_no_address");return(await(await o.getSigner()).sendTransaction({value:BigInt(n||0),from:w,to:_,data:T||"0x"})).hash}}}var X=s({name:"connectCtrl",walletType:A.CTRL,supportedChains:[t.Arbitrum,t.Avalanche,t.Base,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Cosmos,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],connect:({addChain:o,walletType:l,supportedChains:y})=>async function w(_){let n=j({chains:_,supportedChains:y,walletType:l}).map(async(f)=>{let B=await E(f),H=await q(f);o({...H,address:B,chain:f,walletType:l})});return await Promise.all(n),!0}}),i=F(X);async function q(o){switch(o){case t.Solana:{let{getSolanaToolbox:l}=await import("@swapkit/toolboxes/solana"),y=window.xfi?.solana;if(!y)throw new D("wallet_ctrl_not_found");return{...l({signer:y})}}case t.Maya:case t.THORChain:{let{getCosmosToolbox:l,THORCHAIN_GAS_VALUE:y,MAYA_GAS_VALUE:w}=await import("@swapkit/toolboxes/cosmos"),_=o===t.Maya?w:y;return{...await l(o),deposit:(n)=>G({...n,recipient:""},"deposit"),transfer:(n)=>G({...n,gasLimit:_},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:l}=await import("@swapkit/toolboxes/cosmos"),y=m[o],w=await b(o);await w?.enable(y);let _=w?.getOfflineSignerOnlyAmino(y);if(!_)throw new D("wallet_ctrl_not_found");return l(o,{signer:_})}case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:l}=await import("@swapkit/toolboxes/utxo");return{...await l(o),transfer:G}}case t.Arbitrum:case t.Avalanche:case t.Base:case t.BinanceSmartChain:case t.Ethereum:case t.Optimism:case t.Polygon:{let{prepareNetworkSwitch:l,switchEVMWalletNetwork:y}=await import("@swapkit/helpers"),{getEvmToolbox:w}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:_}=await import("ethers"),T=await b(o);if(!T)throw new D("wallet_ctrl_not_found");let n=new _(T,"any"),f=await n.getSigner(),B=await w(o,{provider:n,signer:f}),H=z(n,o);try{if(o!==t.Ethereum){let L=B.getNetworkParams();await y(n,o,L)}}catch(L){throw new D({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:A.CTRL,chain:o}})}return l({provider:window.xfi?.ethereum,chain:o,toolbox:{...B,...H}})}default:return null}}export{X as ctrlWallet,i as CTRL_SUPPORTED_CHAINS};
1
+ import{A}from"../../chunk-zfnkndsr.js";import{C as G,D as H}from"../../chunk-qwd1kp32.js";import{Chain as J,ChainToChainId as w,SwapKitError as I,WalletOption as T,createWallet as v,filterSupportedChains as u}from"@swapkit/helpers";import{Chain as q,ChainToChainId as b,EVMChains as P,SwapKitError as _,WalletOption as E,providerRequest as f}from"@swapkit/helpers";import{erc20ABI as g}from"@swapkit/helpers/contracts";async function L(z){if(!window.xfi)throw new _("wallet_ctrl_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(q.Arbitrum,q.Avalanche,q.Base,q.BinanceSmartChain,q.Ethereum,q.Optimism,q.Polygon,()=>window.xfi?.ethereum).with(q.Cosmos,q.Kujira,()=>window.xfi?.keplr).with(q.Bitcoin,()=>window.xfi?.bitcoin).with(q.BitcoinCash,()=>window.xfi?.bitcoincash).with(q.Dogecoin,()=>window.xfi?.dogecoin).with(q.Litecoin,()=>window.xfi?.litecoin).with(q.Solana,()=>window.xfi?.solana).with(q.THORChain,()=>window.xfi?.thorchain).with(q.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function x({method:z,params:Z,chain:D}){let Q=await L(D);return new Promise(($,F)=>{if(Q&&"request"in Q)Q.request({method:z,params:Z},(X,Y)=>{X?F(X):$(Y)})})}async function V(z){try{let Z=await L(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});if([q.Cosmos,q.Kujira].includes(z)){let Q=await L(q.Cosmos);if(!Q||"request"in Q)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});let $=b[z];await Q.enable($);let F=Q.getOfflineSigner($),[X]=await F.getAccounts();return X?.address}if(P.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Q}=await import("ethers"),$=new Q(Z,"any"),[F]=await f({provider:$,method:"eth_requestAccounts",params:[]});return F}if(z===q.Solana)return(await(await L(q.Solana)).connect()).publicKey.toString();if(z===q.Near){if(!window.xfi?.near)throw new _("wallet_ctrl_not_found",{chain:q.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}})}}async function O({assetValue:z,recipient:Z,memo:D,gasLimit:Q},$="transfer"){if(!z)throw new _("wallet_ctrl_asset_not_defined");let F=await V(z.chain),X=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},memo:D||"",from:F,recipient:Z,gasLimit:Q}];return x({method:$,params:X,chain:z.chain})}function S(z,Z){return{call:async({contractAddress:D,abi:Q,funcName:$,funcParams:F=[],txOverrides:X})=>{if(!D)throw new _("wallet_ctrl_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Q,funcName:$})){let j=y({provider:z,chain:Z}),{value:W,from:K,to:N,data:k}=await j({contractAddress:D,abi:Q,funcName:$,funcParams:F,txOverrides:X});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:K,to:N,data:k||"0x"})).hash}let R=await Y(D,Q,z)[$]?.(...F);return typeof R?.hash==="string"?R?.hash:R},approve:async({assetAddress:D,spenderAddress:Q,amount:$,from:F})=>{let{MAX_APPROVAL:X,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),y=[Q,BigInt($||X)],U={contractAddress:D,abi:g,funcName:"approve",funcParams:y,txOverrides:{from:F}},M=Y({provider:z,chain:Z}),{value:R,to:j,data:W}=await M(U);return(await(await z.getSigner()).sendTransaction({value:BigInt(R||0),from:F,to:j,data:W||"0x"})).hash},sendTransaction:async(D)=>{let{from:Q,to:$,data:F,value:X}=D;if(!$)throw new _("wallet_ctrl_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(X||0),from:Q,to:$,data:F||"0x"})).hash}}}var m=v({name:"connectCtrl",walletType:T.CTRL,supportedChains:[J.Arbitrum,J.Avalanche,J.Base,J.BinanceSmartChain,J.Bitcoin,J.BitcoinCash,J.Cosmos,J.Dogecoin,J.Ethereum,J.Kujira,J.Litecoin,J.Maya,J.Near,J.Optimism,J.Polygon,J.Solana,J.THORChain],connect:({addChain:z,walletType:Z,supportedChains:D})=>async function Q($){let X=u({chains:$,supportedChains:D,walletType:Z}).map(async(Y)=>{let y=await V(Y),B=await C(Y);z({...B,address:y,chain:Y,walletType:Z})});return await Promise.all(X),!0}}),t=A(m);async function C(z){switch(z){case J.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),D=window.xfi?.solana;if(!D)throw new I("wallet_ctrl_not_found");return{...Z({signer:D})}}case J.Maya:case J.THORChain:{let{getCosmosToolbox:Z,THORCHAIN_GAS_VALUE:D,MAYA_GAS_VALUE:Q}=await import("@swapkit/toolboxes/cosmos"),$=z===J.Maya?Q:D;return{...await Z(z),deposit:(X)=>O({...X,recipient:""},"deposit"),transfer:(X)=>O({...X,gasLimit:$},"transfer")}}case J.Cosmos:case J.Kujira:{let{getCosmosToolbox:Z}=await import("@swapkit/toolboxes/cosmos"),D=w[z],Q=await L(z);await Q?.enable(D);let $=Q?.getOfflineSignerOnlyAmino(D);if(!$)throw new I("wallet_ctrl_not_found");return Z(z,{signer:$})}case J.Bitcoin:case J.BitcoinCash:case J.Dogecoin:case J.Litecoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo");return{...await Z(z),transfer:O}}case J.Arbitrum:case J.Avalanche:case J.Base:case J.BinanceSmartChain:case J.Ethereum:case J.Optimism:case J.Polygon:{let{prepareNetworkSwitch:Z,switchEVMWalletNetwork:D}=await import("@swapkit/helpers"),{getEvmToolbox:Q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),F=await L(z);if(!F)throw new I("wallet_ctrl_not_found");let X=new $(F,"any"),Y=await X.getSigner(),y=await Q(z,{provider:X,signer:Y}),B=S(X,z);try{if(z!==J.Ethereum){let U=y.getNetworkParams();await D(X,z,U)}}catch(U){throw new I({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:T.CTRL,chain:z}})}return Z({provider:window.xfi?.ethereum,chain:z,toolbox:{...y,...B}})}case J.Near:{if(!window.xfi?.near)throw new I("wallet_ctrl_not_found",{chain:J.Near});let{createNearSignerFromProvider:Z}=await import("../../chunk-dcj9twam.js"),{getNearToolbox:D}=await import("@swapkit/toolboxes/near"),Q=window.xfi.near,$=await Z(Q,"CTRL"),F=await $.getAddress();return{...await D({signer:$}),transfer:async(B)=>{let{transfer:U}=await import("near-api-js/lib/transaction"),M=B.assetValue.getBaseValue("string"),R=U(BigInt(M)),j={signerId:F,receiverId:B.recipient,actions:[R]};return await Q.request({method:"signAndSendTransaction",params:{transaction:j}})},createTransaction:async(B)=>{let{functionCall:U,transfer:M}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:W,args:K,attachedDeposit:N}=B.functionCall,k=U(W,K,BigInt("30000000000000"),BigInt(N||"0"));return{signerId:F,receiverId:B.recipient,actions:[k]}}let R=B.assetValue.getBaseValue("string"),j=M(BigInt(R));return{signerId:F,receiverId:B.recipient,actions:[j]}}}}default:return null}}export{m as ctrlWallet,t as CTRL_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=DB4D2C259521794F64756E2164756E21
3
+ //# debugId=62BD16C82F053DB864756E2164756E21
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
4
4
  "sourcesContent": [
5
- "import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport { getWalletSupportedChains } from \"../utils\";\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } 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, 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 { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, 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 = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(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 { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await 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 = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.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 {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { 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 async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\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> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await 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 try {\n const eipProvider = (await 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 = await 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 // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\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 getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n"
5
+ "import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\n\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { getWalletSupportedChains } from \"../utils\";\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } 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.Near,\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, 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 { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, 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 = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(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 { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await 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 = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.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 case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n // Override transfer method to use CTRL's direct API\n const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n // Convert AssetValue to NEAR amount (yoctoNEAR)\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n\n // Create transfer action\n const action = transferAction(BigInt(amountInYocto));\n\n // Create transaction object for CTRL\n const transaction = {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n\n const txHash: string = await provider.request({\n method: \"signAndSendTransaction\",\n params: {\n transaction,\n },\n });\n\n return txHash;\n };\n\n // Override createTransaction to build NEAR transactions for CTRL\n const createTransaction = async (params: NearCreateTransactionParams) => {\n const { functionCall, transfer: transferAction } = await import(\n \"near-api-js/lib/transaction\"\n );\n\n if (params.functionCall) {\n // Function call transaction\n const { methodName, args, attachedDeposit } = params.functionCall;\n const action = functionCall(\n methodName,\n args,\n BigInt(\"30000000000000\"), // 30 TGas default\n BigInt(attachedDeposit || \"0\"),\n );\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n };\n\n return {\n ...toolbox,\n transfer,\n createTransaction,\n };\n }\n\n default:\n return null;\n }\n}\n",
6
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { 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 async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\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> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await 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\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await 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 = await 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 // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({\n method: \"connect\",\n });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\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 getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n"
7
7
  ],
8
- "mappings": "iGAAA,cACE,oBACA,kBAEA,kBACA,kBACA,2BACA,yBCNF,gBAEE,oBACA,eAEA,kBAEA,kBACA,qBACA,yBAEF,mBAAS,mCAwBT,eAAsB,CAAgC,CACpD,EASA,CACA,IAAK,OAAO,IAAK,MAAM,IAAI,EAAa,uBAAuB,EAC/D,IAAQ,SAAU,KAAa,sBAG/B,OAAO,EAAM,CAAc,EACxB,KACC,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,QACN,IAAM,OAAO,KAAK,QACpB,EACC,KAAK,EAAM,OAAQ,EAAM,OAAQ,IAAM,OAAO,KAAK,KAAK,EACxD,KAAK,EAAM,QAAS,IAAM,OAAO,KAAK,OAAO,EAC7C,KAAK,EAAM,YAAa,IAAM,OAAO,KAAK,WAAW,EACrD,KAAK,EAAM,SAAU,IAAM,OAAO,KAAK,QAAQ,EAC/C,KAAK,EAAM,SAAU,IAAM,OAAO,KAAK,QAAQ,EAC/C,KAAK,EAAM,OAAQ,IAAM,OAAO,KAAK,MAAM,EAC3C,KAAK,EAAM,UAAW,IAAM,OAAO,KAAK,SAAS,EACjD,KAAK,EAAM,KAAM,IAAM,OAAO,KAAK,SAAS,EAC5C,UAAU,IAAG,CAAG,OAAS,EAG9B,eAAe,CAAW,EACxB,SACA,SACA,SAKkB,CAClB,IAAM,EAAS,MAAM,EAAgB,CAAK,EAE1C,OAAO,IAAI,QAAgB,CAAC,EAAS,IAAW,CAC9C,GAAI,GAAU,YAAa,EAEzB,EAAO,QAAQ,CAAE,SAAQ,QAAO,EAAG,CAAC,EAAa,IAAe,CAC9D,EAAM,EAAO,CAAG,EAAI,EAAQ,CAAE,EAC/B,EAEJ,EAGH,eAAsB,CAAc,CAAC,EAAc,CACjD,GAAI,CACF,IAAM,EAAe,MAAM,EAAgB,CAAK,EAChD,IAAK,EACH,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAGH,GAAI,CAAC,EAAM,OAAQ,EAAM,MAAM,EAAE,SAAS,CAAK,EAAG,CAChD,IAAM,EAAW,MAAM,EAAgB,EAAM,MAAM,EACnD,IAAK,GAAY,YAAa,EAC5B,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAMH,IAAM,EAAU,EAAe,GAC/B,MAAM,EAAS,OAAO,CAAO,EAE7B,IAAM,EAAgB,EAAS,iBAAiB,CAAO,GAEhD,GAAQ,MAAM,EAAc,YAAY,EAC/C,OAAO,GAAM,QAGf,GAAI,EAAU,SAAS,CAAiB,EAAG,CAEzC,GAAI,YAAa,GAAe,OAAO,EAAY,UAAY,WAE7D,OADiB,MAAM,EAAY,QAAQ,CAAE,OAAQ,qBAAsB,CAAC,GAC5D,GAElB,IAAQ,mBAAoB,KAAa,kBACnC,EAAW,IAAI,EAAgB,EAAa,KAAK,GAChD,GAAY,MAAM,EAAgB,CACvC,WACA,OAAQ,sBACR,OAAQ,CAAC,CACX,CAAC,EACD,OAAO,EAGT,GAAI,IAAU,EAAM,OAIlB,OADiB,MAFA,MAAM,EAAgB,EAAM,MAAM,GAEnB,QAAQ,GACxB,UAAU,SAAS,EAIrC,OADiB,MAAM,EAAY,QAAQ,CAAE,OAAQ,mBAAoB,OAAQ,CAAC,CAAE,CAAC,GACrE,GAChB,MAAO,EAAQ,CACf,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,GAIL,eAAsB,CAAc,EAChC,aAAY,YAAW,OAAM,YAC/B,EAA4B,WAC5B,CACA,IAAK,EACH,MAAM,IAAI,EAAa,+BAA+B,EAQxD,IAAM,EAAO,MAAM,EAAe,EAAW,KAAK,EAC5C,EAAS,CACb,CACE,OAAQ,CACN,OAAQ,EAAW,aAAa,QAAQ,EACxC,SAAU,EAAW,OACvB,EACA,MAAO,CACL,MAAO,EAAW,MAClB,OAAQ,EAAW,OAAO,YAAY,EACtC,OAAQ,EAAW,OAAO,YAAY,CACxC,EACA,KAAM,GAAQ,GACd,OACA,YACA,UACF,CACF,EAEA,OAAO,EAAY,CAAE,SAAQ,SAAQ,MAAO,EAAW,KAAM,CAAC,EAGzD,SAAS,CAAc,CAAC,EAA2B,EAAiB,CACzE,MAAO,CACL,KAAM,OACJ,kBACA,MACA,WACA,aAAa,CAAC,EACd,iBAC4B,CAC5B,IAAK,EACH,MAAM,IAAI,EAAa,2CAA2C,EAEpE,IAAQ,iBAAgB,4BAA2B,uBAAwB,KACzE,kCAKF,GAFwB,EAAoB,CAAE,MAAK,UAAS,CAAC,EAExC,CACnB,IAAM,EAAW,EAA0B,CAAE,WAAU,OAAM,CAAC,GACtD,QAAO,OAAM,KAAI,QAAS,MAAM,EAAS,CAC/C,kBACA,MACA,WACA,aACA,aACF,CAAC,EASD,OANW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CACtC,MAAO,OAAO,GAAS,CAAC,EACxB,OACA,KACA,KAAM,GAAQ,IAChB,CAAC,GACS,KAIZ,IAAM,EAAS,MAFE,EAAe,EAAiB,EAAK,CAAQ,EAEhC,KAAY,GAAG,CAAU,EAEvD,OAAO,OAAO,GAAQ,OAAS,SAAW,GAAQ,KAAO,GAE3D,QAAS,OAAS,eAAc,iBAAgB,SAAQ,UAA0B,CAChF,IAAQ,eAAc,6BAA8B,KAAa,kCAC3D,EAAa,CAAC,EAAgB,OAAO,GAAU,CAAY,CAAC,EAG5D,EAAqB,CACzB,gBAAiB,EACjB,IAAK,EACL,SAAU,UACV,aACA,YAPkB,CAAE,MAAK,CAQ3B,EAEM,EAAW,EAA0B,CAAE,WAAU,OAAM,CAAC,GACtD,QAAO,KAAI,QAAS,MAAM,EAAS,CAAkB,EAS7D,OANW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CACtC,MAAO,OAAO,GAAS,CAAC,EACxB,OACA,KACA,KAAM,GAAQ,IAChB,CAAC,GACS,MAEZ,gBAAiB,MAAO,IAA0B,CAChD,IAAQ,OAAM,KAAI,OAAM,SAAU,EAClC,IAAK,EACH,MAAM,IAAI,EAAa,yCAAyC,EAUlE,OANW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CACtC,MAAO,OAAO,GAAS,CAAC,EACxB,OACA,KACA,KAAM,GAAQ,IAChB,CAAC,GACS,KAEd,EDvQK,IAAM,EAAa,EAAa,CACrC,KAAM,cACN,WAAY,EAAa,KACzB,gBAAiB,CACf,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,QACN,EAAM,YACN,EAAM,OACN,EAAM,SACN,EAAM,SACN,EAAM,OACN,EAAM,SACN,EAAM,KACN,EAAM,SACN,EAAM,QACN,EAAM,OACN,EAAM,SACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAW,CAAC,EAAiB,CAG1C,IAAM,EAFiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAEpD,IAAI,MAAO,IAAU,CACnD,IAAM,EAAU,MAAM,EAAe,CAAK,EACpC,EAAgB,MAAM,EAAiB,CAAK,EAElD,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EAC1D,EAID,OAFA,MAAM,QAAQ,IAAI,CAAQ,EAEnB,GAEb,CAAC,EAEY,EAAwB,EAAyB,CAAU,EAExE,eAAe,CAAgB,CAAC,EAA+C,CAC7E,OAAQ,QACD,EAAM,OAAQ,CACjB,IAAQ,oBAAqB,KAAa,qCAEpC,EAAiB,OAAO,KAAK,OAEnC,IAAK,EACH,MAAM,IAAI,EAAa,uBAAuB,EAIhD,MAAO,IAFS,EAAiB,CAAE,OAAQ,CAAe,CAAC,CAEvC,CACtB,MAEK,EAAM,UACN,EAAM,UAAW,CACpB,IAAQ,mBAAkB,sBAAqB,kBAAmB,KAChE,qCAGI,EAAW,IAAU,EAAM,KAAO,EAAiB,EAGzD,MAAO,IAFS,MAAM,EAAiB,CAAK,EAI1C,QAAS,CAAC,IAA8B,EAAe,IAAK,EAAI,UAAW,EAAG,EAAG,SAAS,EAC1F,SAAU,CAAC,IAA8B,EAAe,IAAK,EAAI,UAAS,EAAG,UAAU,CACzF,CACF,MAEK,EAAM,YACN,EAAM,OAAQ,CACjB,IAAQ,oBAAqB,KAAa,qCACpC,EAAU,EAAe,GACzB,EAAW,MAAM,EAAgB,CAAK,EAE5C,MAAM,GAAU,OAAO,CAAO,EAC9B,IAAM,EAAS,GAAU,0BAA0B,CAAO,EAE1D,IAAK,EACH,MAAM,IAAI,EAAa,uBAAuB,EAKhD,OAFgB,EAAiB,EAAO,CAAE,QAAO,CAAC,CAGpD,MAEK,EAAM,aACN,EAAM,iBACN,EAAM,cACN,EAAM,SAAU,CACnB,IAAQ,kBAAmB,KAAa,mCAGxC,MAAO,IAFS,MAAM,EAAe,CAAK,EAErB,SAAU,CAAe,CAChD,MAEK,EAAM,cACN,EAAM,eACN,EAAM,UACN,EAAM,uBACN,EAAM,cACN,EAAM,cACN,EAAM,QAAS,CAClB,IAAQ,uBAAsB,0BAA2B,KAAa,6BAC9D,iBAAkB,KAAa,mCAC/B,mBAAoB,KAAa,kBACnC,EAAyB,MAAM,EAAgB,CAAK,EAE1D,IAAK,EACH,MAAM,IAAI,EAAa,uBAAuB,EAGhD,IAAM,EAAW,IAAI,EAAgB,EAAwB,KAAK,EAC5D,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EACzD,EAAc,EAAe,EAAU,CAAK,EAElD,GAAI,CACF,GAAI,IAAU,EAAM,SAAU,CAC5B,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAU,EAAO,CAAa,GAE7D,MAAO,EAAQ,CACf,MAAM,IAAI,EAAa,CACrB,SAAU,yCACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAGH,OAAO,EAAqB,CAC1B,SAAU,OAAO,KAAK,SACtB,QACA,QAAS,IACJ,KACA,CACL,CACF,CAAC,CACH,SAGE,OAAO",
9
- "debugId": "DB4D2C259521794F64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "62BD16C82F053DB864756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,3 +1,3 @@
1
- import{a as h}from"../../chunk-ebfkk1jn.js";import{c as u,d as O}from"../../chunk-38ztynv0.js";import{Chain as S,ChainToHexChainId as A,EVMChains as B,SwapKitError as d,WalletOption as l,createWallet as C,filterSupportedChains as P,prepareNetworkSwitch as f,switchEVMWalletNetwork as v}from"@swapkit/helpers";var _=(r)=>{switch(r){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},g=async({address:r,walletProvider:w,chain:e,provider:o})=>{if(!w)throw new d("wallet_evm_extensions_not_found");let{getEvmToolbox:t}=await import("@swapkit/toolboxes/evm"),a=await o.getSigner(),i=await t(e,{provider:o,signer:a});if(e!==S.Ethereum){if((await o.getNetwork()).chainId.toString()!==A[e])try{let n=i.getNetworkParams();await v(o,e,n)}catch(n){throw new d("wallet_evm_extensions_failed_to_switch_network",{chain:e})}}return f({toolbox:{...i,getBalance:()=>i.getBalance(r)},chain:e,provider:o})},x=C({name:"connectEVMWallet",supportedChains:[...B],connect:({addChain:r,supportedChains:w})=>async function e(o,t=l.METAMASK,a){let i=P({chains:o,supportedChains:w,walletType:t}),{BrowserProvider:c}=await import("ethers");return await Promise.all(i.map(async(n)=>{if(t===l.EIP6963){if(!a)throw new d("wallet_evm_extensions_no_provider");let E=new c(a,"any");await E.send("eth_requestAccounts",[]);let W=await(await E.getSigner()).getAddress(),M=await g({address:W,chain:n,provider:E,walletProvider:a});r({...M,address:W,chain:n,walletType:t});return}let s=new c(_(t),"any");await s.send("eth_requestAccounts",[]);let p=await(await s.getSigner()).getAddress(),m=await g({address:p,chain:n,walletProvider:_(t),provider:s});r({...m,address:p,chain:n,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:t})})),!0}}),L=h(x);export{g as getWeb3WalletMethods,x as evmWallet,L as EVM_EXTENSIONS_SUPPORTED_CHAINS};
1
+ import{A as h}from"../../chunk-zfnkndsr.js";import{C as u,D as O}from"../../chunk-qwd1kp32.js";import{Chain as S,ChainToHexChainId as A,EVMChains as B,SwapKitError as d,WalletOption as l,createWallet as C,filterSupportedChains as P,prepareNetworkSwitch as f,switchEVMWalletNetwork as v}from"@swapkit/helpers";var _=(r)=>{switch(r){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},g=async({address:r,walletProvider:w,chain:e,provider:o})=>{if(!w)throw new d("wallet_evm_extensions_not_found");let{getEvmToolbox:t}=await import("@swapkit/toolboxes/evm"),a=await o.getSigner(),i=await t(e,{provider:o,signer:a});if(e!==S.Ethereum){if((await o.getNetwork()).chainId.toString()!==A[e])try{let n=i.getNetworkParams();await v(o,e,n)}catch(n){throw new d("wallet_evm_extensions_failed_to_switch_network",{chain:e})}}return f({toolbox:{...i,getBalance:()=>i.getBalance(r)},chain:e,provider:o})},x=C({name:"connectEVMWallet",supportedChains:[...B],connect:({addChain:r,supportedChains:w})=>async function e(o,t=l.METAMASK,a){let i=P({chains:o,supportedChains:w,walletType:t}),{BrowserProvider:c}=await import("ethers");return await Promise.all(i.map(async(n)=>{if(t===l.EIP6963){if(!a)throw new d("wallet_evm_extensions_no_provider");let E=new c(a,"any");await E.send("eth_requestAccounts",[]);let W=await(await E.getSigner()).getAddress(),M=await g({address:W,chain:n,provider:E,walletProvider:a});r({...M,address:W,chain:n,walletType:t});return}let s=new c(_(t),"any");await s.send("eth_requestAccounts",[]);let p=await(await s.getSigner()).getAddress(),m=await g({address:p,chain:n,walletProvider:_(t),provider:s});r({...m,address:p,chain:n,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:t})})),!0}}),L=h(x);export{g as getWeb3WalletMethods,x as evmWallet,L as EVM_EXTENSIONS_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=1F0B6DFCC8CA12B064756E2164756E21
3
+ //# debugId=BE8AD4EE99FDBC2364756E2164756E21
@@ -5,6 +5,6 @@
5
5
  "import {\n Chain,\n ChainToHexChainId,\n type EVMChain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport { getWalletSupportedChains } from \"../utils\";\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 address,\n walletProvider,\n chain,\n provider,\n}: {\n address: string;\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n provider: BrowserProvider;\n}) => {\n if (!walletProvider) throw new SwapKitError(\"wallet_evm_extensions_not_found\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(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.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch (_error) {\n throw new SwapKitError(\"wallet_evm_extensions_failed_to_switch_network\", { chain });\n }\n }\n }\n\n return prepareNetworkSwitch({\n toolbox: { ...toolbox, getBalance: () => toolbox.getBalance(address) },\n chain,\n provider,\n });\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 { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963) {\n if (!eip1193Provider) throw new SwapKitError(\"wallet_evm_extensions_no_provider\");\n\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 address,\n chain,\n provider,\n walletProvider: eip1193Provider,\n });\n\n addChain({ ...walletMethods, address, chain, walletType });\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 address,\n chain,\n walletProvider: getWalletForType(walletType),\n provider: web3provider,\n });\n\n const disconnect = () =>\n web3provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({ ...walletMethods, address, chain, disconnect, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
6
6
  ],
7
7
  "mappings": "iGAAA,cACE,uBACA,eAEA,kBACA,kBACA,kBACA,2BACA,0BACA,4BACA,yBAaF,IAAM,EAAmB,CACvB,IAMG,CACH,OAAQ,QACD,EAAa,aAChB,OAAO,OAAO,6BACX,EAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,UACA,iBACA,QACA,cAMI,CACJ,IAAK,EAAgB,MAAM,IAAI,EAAa,iCAAiC,EAC7E,IAAQ,iBAAkB,KAAa,kCAEjC,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EAE/D,GAAI,IAAU,EAAM,UAElB,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,EAAkB,GAC1D,GAAI,CACF,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAU,EAAO,CAAa,EAC3D,MAAO,EAAQ,CACf,MAAM,IAAI,EAAa,iDAAkD,CAAE,OAAM,CAAC,GAKxF,OAAO,EAAqB,CAC1B,QAAS,IAAK,EAAS,WAAY,IAAM,EAAQ,WAAW,CAAO,CAAE,EACrE,QACA,UACF,CAAC,GAGU,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,mBAAoB,KAAa,kBA0CzC,OAxCA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,EAAa,QAAS,CACvC,IAAK,EAAiB,MAAM,IAAI,EAAa,mCAAmC,EAEhF,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,UACA,QACA,WACA,eAAgB,CAClB,CAAC,EAED,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EACzD,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,UACA,QACA,eAAgB,EAAiB,CAAU,EAC3C,SAAU,CACZ,CAAC,EAKD,EAAS,IAAK,EAAe,UAAS,QAAO,WAH1B,IACjB,EAAa,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EAEb,YAAW,CAAC,EACtE,CACH,EAEO,GAEb,CAAC,EAEY,EAAkC,EAAyB,CAAS",
8
- "debugId": "1F0B6DFCC8CA12B064756E2164756E21",
8
+ "debugId": "BE8AD4EE99FDBC2364756E2164756E21",
9
9
  "names": []
10
10
  }
@@ -1,3 +1,3 @@
1
- import{a as m}from"../../chunk-ebfkk1jn.js";import{c as U,d as f}from"../../chunk-38ztynv0.js";import{Chain as F,EVMChains as B,SwapKitError as I,WalletOption as j,createWallet as M,filterSupportedChains as N,prepareNetworkSwitch as O,switchEVMWalletNetwork as y}from"@swapkit/helpers";import{Psbt as W}from"bitcoinjs-lib";import{AddressPurpose as u,BitcoinNetworkType as V,getAddress as K,signTransaction as k}from"sats-connect";export*from"@passkeys/react";export*from"@passkeys/core";async function T({walletProvider:$,provider:Z,chain:z}){switch(z){case F.Bitcoin:{let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo"),G="",J=()=>new Promise((q)=>q(Z)),H={getProvider:J,payload:{purposes:[u.Payment],message:"Address for receiving and sending payments",network:{type:V.Mainnet}},onFinish:(q)=>{if(!q.addresses[0])throw new I("wallet_exodus_no_address");G=q.addresses[0].address},onCancel:()=>{throw new I("wallet_exodus_request_canceled")}};await K(H);async function Q(q){let Y,D={getProvider:J,payload:{message:"Sign transaction",network:{type:V.Mainnet},psbtBase64:q.toBase64(),broadcast:!1,inputsToSign:[{address:G,signingIndexes:q.txInputs.map((R,A)=>A)}]},onFinish:(R)=>{Y=W.fromBase64(R.psbtBase64)},onCancel:()=>{throw new I("wallet_exodus_signature_canceled")}};if(await k(D),!Y)throw new I("wallet_exodus_sign_transaction_error");return Y}return{...await _(z,{signer:{signTransaction:Q,getAddress:()=>Promise.resolve(G)}}),address:G}}case F.Arbitrum:case F.Avalanche:case F.Base:case F.BinanceSmartChain:case F.Ethereum:case F.Optimism:case F.Polygon:{if(!$)throw new I("wallet_exodus_not_found");let{getProvider:_,getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),J=await _(z),H=Z;await H.send("eth_requestAccounts",[]);let Q=await H.getSigner(),X=await Q.getAddress(),L=await G(z,{provider:J,signer:Q});try{if(z!==F.Ethereum){let q=L.getNetworkParams();await y(H,z,q)}}catch(q){throw new I("wallet_exodus_failed_to_switch_network",{chain:z})}return{...O({toolbox:L,chain:z,provider:H}),address:X}}default:throw new I("wallet_exodus_chain_not_supported",{chain:z})}}var x=M({name:"connectExodusWallet",walletType:j.EXODUS,supportedChains:[...B,F.Bitcoin],connect:({addChain:$,walletType:Z,supportedChains:z})=>async function _(G,J){if(!J)throw new I("wallet_exodus_instance_missing");let H=N({chains:G,supportedChains:z,walletType:Z}),{BrowserProvider:Q}=await import("ethers"),{providers:X}=J;return await Promise.all(H.map(async(L)=>{let q=L===F.Bitcoin?X.bitcoin:new Q(X.ethereum,"any"),{address:Y,...D}=await T({chain:L,provider:q,walletProvider:X.ethereum});$({...D,disconnect:()=>q.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:L,address:Y,walletType:j.EXODUS})})),!0}}),C=m(x);export{x as exodusWallet,C as EXODUS_SUPPORTED_CHAINS};
1
+ import{A as m}from"../../chunk-zfnkndsr.js";import{C as U,D as f}from"../../chunk-qwd1kp32.js";import{Chain as F,EVMChains as B,SwapKitError as I,WalletOption as j,createWallet as M,filterSupportedChains as N,prepareNetworkSwitch as O,switchEVMWalletNetwork as y}from"@swapkit/helpers";import{Psbt as W}from"bitcoinjs-lib";import{AddressPurpose as u,BitcoinNetworkType as V,getAddress as K,signTransaction as k}from"sats-connect";export*from"@passkeys/react";export*from"@passkeys/core";async function T({walletProvider:$,provider:Z,chain:z}){switch(z){case F.Bitcoin:{let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo"),G="",J=()=>new Promise((q)=>q(Z)),H={getProvider:J,payload:{purposes:[u.Payment],message:"Address for receiving and sending payments",network:{type:V.Mainnet}},onFinish:(q)=>{if(!q.addresses[0])throw new I("wallet_exodus_no_address");G=q.addresses[0].address},onCancel:()=>{throw new I("wallet_exodus_request_canceled")}};await K(H);async function Q(q){let Y,D={getProvider:J,payload:{message:"Sign transaction",network:{type:V.Mainnet},psbtBase64:q.toBase64(),broadcast:!1,inputsToSign:[{address:G,signingIndexes:q.txInputs.map((R,A)=>A)}]},onFinish:(R)=>{Y=W.fromBase64(R.psbtBase64)},onCancel:()=>{throw new I("wallet_exodus_signature_canceled")}};if(await k(D),!Y)throw new I("wallet_exodus_sign_transaction_error");return Y}return{...await _(z,{signer:{signTransaction:Q,getAddress:()=>Promise.resolve(G)}}),address:G}}case F.Arbitrum:case F.Avalanche:case F.Base:case F.BinanceSmartChain:case F.Ethereum:case F.Optimism:case F.Polygon:{if(!$)throw new I("wallet_exodus_not_found");let{getProvider:_,getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),J=await _(z),H=Z;await H.send("eth_requestAccounts",[]);let Q=await H.getSigner(),X=await Q.getAddress(),L=await G(z,{provider:J,signer:Q});try{if(z!==F.Ethereum){let q=L.getNetworkParams();await y(H,z,q)}}catch(q){throw new I("wallet_exodus_failed_to_switch_network",{chain:z})}return{...O({toolbox:L,chain:z,provider:H}),address:X}}default:throw new I("wallet_exodus_chain_not_supported",{chain:z})}}var x=M({name:"connectExodusWallet",walletType:j.EXODUS,supportedChains:[...B,F.Bitcoin],connect:({addChain:$,walletType:Z,supportedChains:z})=>async function _(G,J){if(!J)throw new I("wallet_exodus_instance_missing");let H=N({chains:G,supportedChains:z,walletType:Z}),{BrowserProvider:Q}=await import("ethers"),{providers:X}=J;return await Promise.all(H.map(async(L)=>{let q=L===F.Bitcoin?X.bitcoin:new Q(X.ethereum,"any"),{address:Y,...D}=await T({chain:L,provider:q,walletProvider:X.ethereum});$({...D,disconnect:()=>q.send("wallet_revokePermissions",[{eth_accounts:{}}]),chain:L,address:Y,walletType:j.EXODUS})})),!0}}),C=m(x);export{x as exodusWallet,C as EXODUS_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=14A193D740DB1D5B64756E2164756E21
3
+ //# debugId=CC0047348829D7C664756E2164756E21
@@ -5,6 +5,6 @@
5
5
  "import type { Wallet } from \"@passkeys/core\";\nimport {\n Chain,\n EVMChains,\n SwapKitError,\n WalletOption,\n createWallet,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport {\n AddressPurpose,\n BitcoinNetworkType,\n type BitcoinProvider,\n type GetAddressOptions,\n type GetAddressResponse,\n type SignTransactionOptions,\n getAddress,\n signTransaction as satsSignTransaction,\n} from \"sats-connect\";\nimport { getWalletSupportedChains } from \"../utils\";\n\nasync function getWalletMethods({\n walletProvider,\n provider,\n chain,\n}: {\n walletProvider?: Eip1193Provider;\n provider: BrowserProvider | BitcoinProvider;\n chain: Chain;\n}) {\n switch (chain) {\n case Chain.Bitcoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n let address = \"\";\n\n const getProvider: () => Promise<BitcoinProvider | undefined> = () =>\n new Promise((res) => res(provider as BitcoinProvider));\n\n const getAddressOptions: GetAddressOptions = {\n getProvider,\n payload: {\n purposes: [AddressPurpose.Payment],\n message: \"Address for receiving and sending payments\",\n network: { type: BitcoinNetworkType.Mainnet },\n },\n onFinish: (response: GetAddressResponse) => {\n if (!response.addresses[0]) throw new SwapKitError(\"wallet_exodus_no_address\");\n address = response.addresses[0].address;\n },\n onCancel: () => {\n throw new SwapKitError(\"wallet_exodus_request_canceled\");\n },\n };\n\n // TODO: Towan - probably not needed ?\n await getAddress(getAddressOptions);\n\n async function signTransaction(psbt: Psbt) {\n let signedPsbt: Psbt | undefined;\n const signPsbtOptions: SignTransactionOptions = {\n getProvider,\n payload: {\n message: \"Sign transaction\",\n network: {\n type: BitcoinNetworkType.Mainnet,\n },\n psbtBase64: psbt.toBase64(),\n broadcast: false,\n inputsToSign: [\n { address: address, signingIndexes: psbt.txInputs.map((_, index) => index) },\n ],\n },\n onFinish: (response) => {\n signedPsbt = Psbt.fromBase64(response.psbtBase64);\n },\n onCancel: () => {\n throw new SwapKitError(\"wallet_exodus_signature_canceled\");\n },\n };\n\n await satsSignTransaction(signPsbtOptions);\n if (!signedPsbt) throw new SwapKitError(\"wallet_exodus_sign_transaction_error\");\n return signedPsbt;\n }\n\n const signer = {\n signTransaction,\n getAddress: () => Promise.resolve(address),\n };\n const toolbox = await getUtxoToolbox(chain, { signer });\n\n return { ...toolbox, address };\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 if (!walletProvider) throw new SwapKitError(\"wallet_exodus_not_found\");\n const { getProvider, getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n const jsonRpcProvider = await getProvider(chain);\n const browserProvider = provider as BrowserProvider;\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n const toolbox = await getEvmToolbox(chain, { provider: jsonRpcProvider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(browserProvider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_exodus_failed_to_switch_network\", { chain });\n }\n\n return { ...prepareNetworkSwitch({ toolbox, chain, provider: browserProvider }), address };\n }\n default:\n throw new SwapKitError(\"wallet_exodus_chain_not_supported\", { chain });\n }\n}\n\nexport const exodusWallet = createWallet({\n name: \"connectExodusWallet\",\n walletType: WalletOption.EXODUS,\n supportedChains: [...EVMChains, Chain.Bitcoin],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectExodusWallet(chains: Chain[], wallet: Wallet) {\n if (!wallet) throw new SwapKitError(\"wallet_exodus_instance_missing\");\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n const { providers } = wallet;\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const provider =\n chain === Chain.Bitcoin\n ? providers.bitcoin\n : new BrowserProvider(providers.ethereum, \"any\");\n\n const { address, ...walletMethods } = await getWalletMethods({\n chain,\n provider,\n walletProvider: providers.ethereum,\n });\n\n const disconnect = () =>\n provider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n\n addChain({\n ...walletMethods,\n disconnect,\n chain,\n address,\n walletType: WalletOption.EXODUS,\n });\n }),\n );\n\n return true;\n },\n});\n\nexport const EXODUS_SUPPORTED_CHAINS = getWalletSupportedChains(exodusWallet);\nexport * from \"@passkeys/react\";\nexport * from \"@passkeys/core\";\n"
6
6
  ],
7
7
  "mappings": "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",
8
- "debugId": "14A193D740DB1D5B64756E2164756E21",
8
+ "debugId": "CC0047348829D7C664756E2164756E21",
9
9
  "names": []
10
10
  }
package/dist/src/index.js CHANGED
@@ -1,3 +1,3 @@
1
- import{a as l,b as n}from"../chunk-ebfkk1jn.js";import"../chunk-38ztynv0.js";export{n as loadWallet,l as getWalletSupportedChains};
1
+ import{A as l,B as n}from"../chunk-zfnkndsr.js";import"../chunk-qwd1kp32.js";export{n as loadWallet,l as getWalletSupportedChains};
2
2
 
3
- //# debugId=83059F908E6CD5F764756E2164756E21
3
+ //# debugId=A65C19099338DCD964756E2164756E21
@@ -4,6 +4,6 @@
4
4
  "sourcesContent": [
5
5
  ],
6
6
  "mappings": "",
7
- "debugId": "83059F908E6CD5F764756E2164756E21",
7
+ "debugId": "A65C19099338DCD964756E2164756E21",
8
8
  "names": []
9
9
  }
@@ -1,3 +1,3 @@
1
- import{a as i}from"../../chunk-ebfkk1jn.js";import{c as b,d as A}from"../../chunk-38ztynv0.js";import{Chain as X,NetworkDerivationPath as Iz,SKConfig as C,SwapKitError as Vz,WalletOption as n,createWallet as Hz,filterSupportedChains as Fz}from"@swapkit/helpers";import{KeepKeySdk as Nz}from"@keepkey/keepkey-sdk";import{Chain as l,ChainId as p,DerivationPath as zz,SKConfig as Jz,derivationPathToString as Qz}from"@swapkit/helpers";import{SwapKitError as T}from"@swapkit/helpers";var g=2147483648,x;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(x||={});function e(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function N(z){let J=z;if(!e(J))throw new T("wallet_keepkey_invalid_params",{reason:`Not a bip32 path: '${J}'`});if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let W=/(\d+)([hH']?)/.exec(Y);if(W===null)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid input"});let[,$="",q=""]=W;if(R[Z]=Number.parseInt($,10),R[Z]>=g)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid child index"});if(q==="h"||q==="H"||q==="'")R[Z]+=g;else if(q.length>0)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid modifier"})}}return R}var m=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos"),W=J?Qz(J):`${zz.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:N(W)}),q=await R(l.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(p.Cosmos,500));return{...q,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=M.getBaseValue("string"),B=await q.getAccount($),_=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:B?.sequence.toString()??"",chain_id:p.Cosmos,account_number:B?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:G}],to_address:j,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),I=atob(_.serialized),O=new Uint8Array(I.length).map((D,F)=>I.charCodeAt(F));return(await(await Y(Jz.get("rpcUrls")[l.Cosmos])).broadcastTx(O)).transactionHash},address:$}};import{ChainToChainId as Xz,NetworkDerivationPath as Yz,SwapKitError as w,derivationPathToString as Zz}from"@swapkit/helpers";import{AbstractSigner as $z}from"ethers";class v extends $z{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||Yz.ETH,this.address="",this.provider=R}signTypedData(){throw new w("wallet_keepkey_method_not_supported",{method:"signTypedData"})}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:N(Zz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:W,gasPrice:$})=>{if(!z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing to address"});if(!Q)throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasLimit"});if(!Z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing data"});let q=!!((Y||W)&&!$);if(q&&!Y)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxFeePerGas"});if(q&&!W)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxPriorityFeePerGas"});if(!(q||$))throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasPrice"});let{toHexString:U}=await import("@swapkit/toolboxes/evm"),M=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),j={gas:U(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:U(BigInt(Xz[this.chain])),to:z.toString(),value:U(BigInt(J||0)),nonce:U(M),data:Z,...q&&{maxFeePerGas:U(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:U(BigInt(W?.toString()||"0"))},...!q&&{gasPrice:U(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(j)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new w("wallet_keepkey_no_provider");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new v({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as u,ChainId as qz,DerivationPath as jz,SKConfig as c,SwapKitError as Uz,derivationPathToString as Bz}from"@swapkit/helpers";var h=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(u.Maya),Y=J?Bz(J):`${jz.MAYA}/0`,{address:W}=await z.address.mayachainGetAddress({address_n:N(Y)}),$=async({assetValue:M,recipient:j,sender:L,memo:G})=>{let{makeSignDoc:B}=(await import("@cosmjs/amino")).default,{getDenomWithChain:_}=await import("@swapkit/toolboxes/cosmos"),I=await Z.getAccount(L);if(!I)throw new Uz("wallet_keepkey_account_not_found");let{accountNumber:O,sequence:V=0}=I,H=M.getBaseValue("string"),D=j&&j!=="",F=D?{type:"mayachain/MsgSend",value:{amount:[{amount:H,denom:M.symbol.toLowerCase()}],from_address:L,to_address:j}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:H,asset:_(M)}],memo:G,signer:L}},E=B([F],{gas:"500000000",amount:[]},qz.Maya,G,O?.toString(),V),y=await(D?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:E,signerAddress:L}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...Z,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=await Q(c.get("rpcUrls")[u.Maya]),B=await $({assetValue:M,recipient:j,memo:L,sender:W}),{transactionHash:_}=await G.broadcastTx(B);return _},deposit:async({assetValue:M,memo:j})=>{let L=await Q(c.get("rpcUrls")[u.Maya]),G=await $({assetValue:M,memo:j,sender:W}),{transactionHash:B}=await L.broadcastTx(G);return B},address:W}};import{Chain as S,ChainId as Rz,DerivationPath as Wz,SKConfig as d,SwapKitError as Gz,derivationPathToString as Lz}from"@swapkit/helpers";var o=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=(await import("@cosmjs/amino")).default,{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:W}=await import("@swapkit/toolboxes/cosmos"),$=await W(S.THORChain),q=J?Lz(J):`${Wz.THOR}/0`,{address:U}=await z.address.thorchainGetAddress({address_n:N(q)}),M=async({assetValue:G,recipient:B,sender:_,memo:I})=>{let O=await $.getAccount(_);if(!O)throw new Gz("wallet_keepkey_account_not_found");let{accountNumber:V,sequence:H=0}=O,D=B&&B!=="",F=R({sender:_,recipient:B,assetValue:G,memo:I}),E=Rz.THORChain,f=Q([F],Z(S.THORChain),E,I,V?.toString(),H),y=D?await z.thorchain.thorchainSignAminoTransfer({signDoc:f,signerAddress:_}):await z.thorchain.thorchainSignAminoDeposit({signDoc:f,signerAddress:_}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...$,transfer:async({assetValue:G,recipient:B,memo:_})=>{let I=await Y(d.get("rpcUrls")[S.THORChain]),O=await M({assetValue:G,recipient:B,memo:_,sender:U}),{transactionHash:V}=await I.broadcastTx(O);return V},deposit:async({assetValue:G,memo:B})=>{let _=await Y(d.get("rpcUrls")[S.THORChain]),I=await M({assetValue:G,memo:B,sender:U}),{transactionHash:O}=await _.broadcastTx(I);return O},address:U}};import{Chain as P,DerivationPath as _z,FeeOption as Mz,SwapKitError as r,derivationPathToString as Oz}from"@swapkit/helpers";var s=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[P.Bitcoin,P.Litecoin].includes(J)?"p2wpkh":"p2pkh",W=Q?Oz(Q):`${_z[J]}/0`,$={coin:x[J],script_type:Y,address_n:N(W)},q=(await z.address.utxoGetAddress($)).address,U=async(j,L,G="")=>{let B=j.txOutputs.map((O)=>{let{value:V,address:H,change:D}=O,F=J===P.BitcoinCash?Z.stripToCashAddress(H):H;if(D||H===q)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:V,scriptType:Y};if(F)return{address:F,amount:V,addressType:"spend"};return null}).filter(Boolean),_=(O)=>{return O.filter((V)=>V!==null&&typeof V==="object"&&Object.keys(V).length>0)};return(await z.utxo.utxoSignTransaction({coin:x[J],inputs:L,outputs:_(B),opReturnData:G})).serializedTx?.toString()};return{...Z,signTransaction:U,transfer:async({recipient:j,feeOptionKey:L,feeRate:G,memo:B,..._})=>{if(!q)throw new r("wallet_keepkey_invalid_params",{reason:"From address must be provided"});if(!j)throw new r("wallet_keepkey_invalid_params",{reason:"Recipient address must be provided"});let I=J===P.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:O,inputs:V}=await I({..._,memo:B,recipient:j,feeRate:G||(await Z.getFeeRates())[L||Mz.Fast],sender:q,fetchTxHex:!0}),H=V.map(({value:F,index:E,hash:f,txHex:y})=>({addressNList:$.address_n,amount:F.toString(),hex:y||"",scriptType:Y,txid:f,vout:E})),D=await U(O,H,B);return Z.broadcastTx(D)},address:q}};var Dz=Hz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:n.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let W=Fz({chains:Z,supportedChains:J,walletType:Q}),$=C.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");let q=C.get("apiKeys").keepKey||"1234";await t();let U={apiKey:q,pairingInfo:$},M=await Nz.create(U);if(U.apiKey&&U.apiKey!==q)C.setApiKey("keepKey",U.apiKey);return await Promise.all(W.map(async(j)=>{let L=await bz({chain:j,derivationPath:Y?.[j]||Iz[j],sdk:M}),G=await L.getAddress()||"";z({...L,address:G,chain:j,walletType:n.KEEPKEY})})),!0}}),az=i(Dz);async function bz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Base:case X.Ethereum:{let Y=await R(J),W=new v({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:W})}case X.Cosmos:return m({sdk:z,derivationPath:Q});case X.THORChain:return o({sdk:z,derivationPath:Q});case X.Maya:return h({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return s({sdk:z,chain:J,derivationPath:Q});default:throw new Vz("wallet_keepkey_chain_not_supported",{chain:J})}}async function t(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Az())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),t(z+1)}async function Az(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return!1}}export{Dz as keepkeyWallet,az as KEEPKEY_SUPPORTED_CHAINS};
1
+ import{A as i}from"../../chunk-zfnkndsr.js";import{C as b,D as A}from"../../chunk-qwd1kp32.js";import{Chain as X,NetworkDerivationPath as Iz,SKConfig as C,SwapKitError as Vz,WalletOption as n,createWallet as Hz,filterSupportedChains as Fz}from"@swapkit/helpers";import{KeepKeySdk as Nz}from"@keepkey/keepkey-sdk";import{Chain as l,ChainId as p,DerivationPath as zz,SKConfig as Jz,derivationPathToString as Qz}from"@swapkit/helpers";import{SwapKitError as T}from"@swapkit/helpers";var g=2147483648,x;((Y)=>{Y.BTC="Bitcoin";Y.BCH="BitcoinCash";Y.DOGE="Dogecoin";Y.LTC="Litecoin";Y.DASH="Dash"})(x||={});function e(z){if(z==="m/")return!0;return/^m(((\/[0-9]+h)+|(\/[0-9]+H)+|(\/[0-9]+')*)((\/[0-9]+)*))$/.test(z)}function N(z){let J=z;if(!e(J))throw new T("wallet_keepkey_invalid_params",{reason:`Not a bip32 path: '${J}'`});if(/^m\//i.test(J))J=J.slice(2);let Q=J.split("/");if(Q.length===1&&Q[0]==="")return[];let R=new Array(Q.length);for(let Z=0;Z<Q.length;Z++){let Y=Q[Z];if(Y){let W=/(\d+)([hH']?)/.exec(Y);if(W===null)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid input"});let[,$="",q=""]=W;if(R[Z]=Number.parseInt($,10),R[Z]>=g)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid child index"});if(q==="h"||q==="H"||q==="'")R[Z]+=g;else if(q.length>0)throw new T("wallet_keepkey_invalid_params",{reason:"Invalid modifier"})}}return R}var m=async({sdk:z,derivationPath:J})=>{let{DEFAULT_COSMOS_FEE_MAINNET:Q,getCosmosToolbox:R,getFeeRateFromThorswap:Z,createStargateClient:Y}=await import("@swapkit/toolboxes/cosmos"),W=J?Qz(J):`${zz.GAIA}/0`,{address:$}=await z.address.cosmosGetAddress({address_n:N(W)}),q=await R(l.Cosmos);if(Q.amount[0])Q.amount[0].amount=String(await Z(p.Cosmos,500));return{...q,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=M.getBaseValue("string"),B=await q.getAccount($),_=await z.cosmos.cosmosSignAmino({signerAddress:$,signDoc:{fee:Q,memo:L||"",sequence:B?.sequence.toString()??"",chain_id:p.Cosmos,account_number:B?.accountNumber.toString()??"",msgs:[{value:{amount:[{denom:"uatom",amount:G}],to_address:j,from_address:$},type:"cosmos-sdk/MsgSend"}]}}),I=atob(_.serialized),O=new Uint8Array(I.length).map((D,F)=>I.charCodeAt(F));return(await(await Y(Jz.get("rpcUrls")[l.Cosmos])).broadcastTx(O)).transactionHash},address:$}};import{ChainToChainId as Xz,NetworkDerivationPath as Yz,SwapKitError as w,derivationPathToString as Zz}from"@swapkit/helpers";import{AbstractSigner as $z}from"ethers";class v extends $z{sdk;chain;derivationPath;address;provider;constructor({sdk:z,chain:J,derivationPath:Q,provider:R}){super();this.sdk=z,this.chain=J,this.derivationPath=Q||Yz.ETH,this.address="",this.provider=R}signTypedData(){throw new w("wallet_keepkey_method_not_supported",{method:"signTypedData"})}getAddress=async()=>{if(this.address)return this.address;let{address:z}=await this.sdk.address.ethereumGetAddress({address_n:N(Zz(this.derivationPath))});return this.address=z,z};signMessage=(z)=>this.sdk.eth.ethSign({address:this.address,message:z});signTransaction=async({to:z,value:J,gasLimit:Q,nonce:R,data:Z,maxFeePerGas:Y,maxPriorityFeePerGas:W,gasPrice:$})=>{if(!z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing to address"});if(!Q)throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasLimit"});if(!Z)throw new w("wallet_keepkey_invalid_params",{reason:"Missing data"});let q=!!((Y||W)&&!$);if(q&&!Y)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxFeePerGas"});if(q&&!W)throw new w("wallet_keepkey_invalid_params",{reason:"Missing maxPriorityFeePerGas"});if(!(q||$))throw new w("wallet_keepkey_invalid_params",{reason:"Missing gasPrice"});let{toHexString:U}=await import("@swapkit/toolboxes/evm"),M=R?BigInt(R):BigInt(await this.provider.getTransactionCount(await this.getAddress(),"pending")),j={gas:U(BigInt(Q)),addressNList:[2147483692,2147483708,2147483648,0,0],from:this.address,chainId:U(BigInt(Xz[this.chain])),to:z.toString(),value:U(BigInt(J||0)),nonce:U(M),data:Z,...q&&{maxFeePerGas:U(BigInt(Y?.toString()||"0")),maxPriorityFeePerGas:U(BigInt(W?.toString()||"0"))},...!q&&{gasPrice:U(BigInt($?.toString()||"0"))}};return(await this.sdk.eth.ethSignTransaction(j)).serialized};sendTransaction=async(z)=>{if(!this.provider)throw new w("wallet_keepkey_no_provider");let J=await this.signTransaction(z);return await this.provider.broadcastTransaction(J)};connect=(z)=>new v({sdk:this.sdk,chain:this.chain,derivationPath:this.derivationPath,provider:z})}import{Chain as u,ChainId as qz,DerivationPath as jz,SKConfig as c,SwapKitError as Uz,derivationPathToString as Bz}from"@swapkit/helpers";var h=async({sdk:z,derivationPath:J})=>{let{createStargateClient:Q,getCosmosToolbox:R}=await import("@swapkit/toolboxes/cosmos"),Z=await R(u.Maya),Y=J?Bz(J):`${jz.MAYA}/0`,{address:W}=await z.address.mayachainGetAddress({address_n:N(Y)}),$=async({assetValue:M,recipient:j,sender:L,memo:G})=>{let{makeSignDoc:B}=(await import("@cosmjs/amino")).default,{getDenomWithChain:_}=await import("@swapkit/toolboxes/cosmos"),I=await Z.getAccount(L);if(!I)throw new Uz("wallet_keepkey_account_not_found");let{accountNumber:O,sequence:V=0}=I,H=M.getBaseValue("string"),D=j&&j!=="",F=D?{type:"mayachain/MsgSend",value:{amount:[{amount:H,denom:M.symbol.toLowerCase()}],from_address:L,to_address:j}}:{type:"mayachain/MsgDeposit",value:{coins:[{amount:H,asset:_(M)}],memo:G,signer:L}},E=B([F],{gas:"500000000",amount:[]},qz.Maya,G,O?.toString(),V),y=await(D?z.mayachain.mayachainSignAminoTransfer:z.mayachain.mayachainSignAminoDeposit)({signDoc:E,signerAddress:L}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...Z,transfer:async({assetValue:M,recipient:j,memo:L})=>{let G=await Q(c.get("rpcUrls")[u.Maya]),B=await $({assetValue:M,recipient:j,memo:L,sender:W}),{transactionHash:_}=await G.broadcastTx(B);return _},deposit:async({assetValue:M,memo:j})=>{let L=await Q(c.get("rpcUrls")[u.Maya]),G=await $({assetValue:M,memo:j,sender:W}),{transactionHash:B}=await L.broadcastTx(G);return B},address:W}};import{Chain as S,ChainId as Rz,DerivationPath as Wz,SKConfig as d,SwapKitError as Gz,derivationPathToString as Lz}from"@swapkit/helpers";var o=async({sdk:z,derivationPath:J})=>{let{makeSignDoc:Q}=(await import("@cosmjs/amino")).default,{buildAminoMsg:R,getDefaultChainFee:Z,createStargateClient:Y,getCosmosToolbox:W}=await import("@swapkit/toolboxes/cosmos"),$=await W(S.THORChain),q=J?Lz(J):`${Wz.THOR}/0`,{address:U}=await z.address.thorchainGetAddress({address_n:N(q)}),M=async({assetValue:G,recipient:B,sender:_,memo:I})=>{let O=await $.getAccount(_);if(!O)throw new Gz("wallet_keepkey_account_not_found");let{accountNumber:V,sequence:H=0}=O,D=B&&B!=="",F=R({sender:_,recipient:B,assetValue:G,memo:I}),E=Rz.THORChain,f=Q([F],Z(S.THORChain),E,I,V?.toString(),H),y=D?await z.thorchain.thorchainSignAminoTransfer({signDoc:f,signerAddress:_}):await z.thorchain.thorchainSignAminoDeposit({signDoc:f,signerAddress:_}),K=atob(y.serialized);return new Uint8Array(K.length).map((a,k)=>K.charCodeAt(k))};return{...$,transfer:async({assetValue:G,recipient:B,memo:_})=>{let I=await Y(d.get("rpcUrls")[S.THORChain]),O=await M({assetValue:G,recipient:B,memo:_,sender:U}),{transactionHash:V}=await I.broadcastTx(O);return V},deposit:async({assetValue:G,memo:B})=>{let _=await Y(d.get("rpcUrls")[S.THORChain]),I=await M({assetValue:G,memo:B,sender:U}),{transactionHash:O}=await _.broadcastTx(I);return O},address:U}};import{Chain as P,DerivationPath as _z,FeeOption as Mz,SwapKitError as r,derivationPathToString as Oz}from"@swapkit/helpers";var s=async({sdk:z,chain:J,derivationPath:Q})=>{let{getUtxoToolbox:R}=await import("@swapkit/toolboxes/utxo"),Z=await R(J),Y=[P.Bitcoin,P.Litecoin].includes(J)?"p2wpkh":"p2pkh",W=Q?Oz(Q):`${_z[J]}/0`,$={coin:x[J],script_type:Y,address_n:N(W)},q=(await z.address.utxoGetAddress($)).address,U=async(j,L,G="")=>{let B=j.txOutputs.map((O)=>{let{value:V,address:H,change:D}=O,F=J===P.BitcoinCash?Z.stripToCashAddress(H):H;if(D||H===q)return{addressNList:$.address_n,isChange:!0,addressType:"change",amount:V,scriptType:Y};if(F)return{address:F,amount:V,addressType:"spend"};return null}).filter(Boolean),_=(O)=>{return O.filter((V)=>V!==null&&typeof V==="object"&&Object.keys(V).length>0)};return(await z.utxo.utxoSignTransaction({coin:x[J],inputs:L,outputs:_(B),opReturnData:G})).serializedTx?.toString()};return{...Z,signTransaction:U,transfer:async({recipient:j,feeOptionKey:L,feeRate:G,memo:B,..._})=>{if(!q)throw new r("wallet_keepkey_invalid_params",{reason:"From address must be provided"});if(!j)throw new r("wallet_keepkey_invalid_params",{reason:"Recipient address must be provided"});let I=J===P.BitcoinCash?Z.buildTx:Z.createTransaction,{psbt:O,inputs:V}=await I({..._,memo:B,recipient:j,feeRate:G||(await Z.getFeeRates())[L||Mz.Fast],sender:q,fetchTxHex:!0}),H=V.map(({value:F,index:E,hash:f,txHex:y})=>({addressNList:$.address_n,amount:F.toString(),hex:y||"",scriptType:Y,txid:f,vout:E})),D=await U(O,H,B);return Z.broadcastTx(D)},address:q}};var Dz=Hz({name:"connectKeepkey",supportedChains:[X.Arbitrum,X.Avalanche,X.Base,X.BinanceSmartChain,X.Bitcoin,X.BitcoinCash,X.Cosmos,X.Dogecoin,X.Dash,X.Ethereum,X.Litecoin,X.Optimism,X.Polygon,X.THORChain,X.Maya],walletType:n.KEEPKEY,connect:({addChain:z,supportedChains:J,walletType:Q})=>async function R(Z,Y){let W=Fz({chains:Z,supportedChains:J,walletType:Q}),$=C.get("integrations").keepKey;if(!$)throw new Error("KeepKey config not found");let q=C.get("apiKeys").keepKey||"1234";await t();let U={apiKey:q,pairingInfo:$},M=await Nz.create(U);if(U.apiKey&&U.apiKey!==q)C.setApiKey("keepKey",U.apiKey);return await Promise.all(W.map(async(j)=>{let L=await bz({chain:j,derivationPath:Y?.[j]||Iz[j],sdk:M}),G=await L.getAddress()||"";z({...L,address:G,chain:j,walletType:n.KEEPKEY})})),!0}}),az=i(Dz);async function bz({sdk:z,chain:J,derivationPath:Q}){let{getProvider:R,getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm");switch(J){case X.BinanceSmartChain:case X.Arbitrum:case X.Optimism:case X.Polygon:case X.Avalanche:case X.Base:case X.Ethereum:{let Y=await R(J),W=new v({sdk:z,chain:J,derivationPath:Q,provider:Y});return await Z(J,{provider:Y,signer:W})}case X.Cosmos:return m({sdk:z,derivationPath:Q});case X.THORChain:return o({sdk:z,derivationPath:Q});case X.Maya:return h({sdk:z,derivationPath:Q});case X.Bitcoin:case X.BitcoinCash:case X.Dash:case X.Dogecoin:case X.Litecoin:return s({sdk:z,chain:J,derivationPath:Q});default:throw new Vz("wallet_keepkey_chain_not_supported",{chain:J})}}async function t(z=0){if(z>=3)alert("KeepKey desktop is required for keepkey-sdk, please go to https://keepkey.com/get-started");if(!await Az())window.location.assign("keepkey://launch"),await new Promise((Q)=>setTimeout(Q,30000)),t(z+1)}async function Az(z="http://localhost:1646/spec/swagger.json"){try{return(await fetch(z)).status===200}catch(J){return!1}}export{Dz as keepkeyWallet,az as KEEPKEY_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=D8EC357B71EA30F564756E2164756E21
3
+ //# debugId=C358D755D9B9BFA964756E2164756E21
@@ -11,6 +11,6 @@
11
11
  "import type { KeepKeySdk } from \"@keepkey/keepkey-sdk\";\nimport {\n Chain,\n DerivationPath,\n type DerivationPathArray,\n FeeOption,\n type GenericTransferParams,\n SwapKitError,\n type UTXOChain,\n derivationPathToString,\n} from \"@swapkit/helpers\";\nimport type { Psbt } from \"bitcoinjs-lib\";\n\nimport type { UTXOToolboxes } from \"@swapkit/toolboxes/utxo\";\nimport { ChainToKeepKeyName, bip32ToAddressNList } from \"../coins\";\n\ninterface KeepKeyInputObject {\n addressNList: number[];\n scriptType: string;\n amount: string;\n vout: number;\n txid: string;\n hex: string;\n}\n\nexport const utxoWalletMethods = async ({\n sdk,\n chain,\n derivationPath,\n}: { sdk: KeepKeySdk; chain: UTXOChain; derivationPath?: DerivationPathArray }) => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n // This might not work for BCH\n const toolbox = await getUtxoToolbox(chain);\n const scriptType = [Chain.Bitcoin, Chain.Litecoin].includes(chain)\n ? (\"p2wpkh\" as const)\n : (\"p2pkh\" as const);\n\n const derivationPathString = derivationPath\n ? derivationPathToString(derivationPath)\n : `${DerivationPath[chain]}/0`;\n\n const addressInfo = {\n coin: ChainToKeepKeyName[chain],\n script_type: scriptType,\n address_n: bip32ToAddressNList(derivationPathString),\n };\n\n const walletAddress: string = (await sdk.address.utxoGetAddress(addressInfo)).address;\n\n const signTransaction = async (psbt: Psbt, inputs: KeepKeyInputObject[], memo = \"\") => {\n const outputs = psbt.txOutputs\n .map((output) => {\n const { value, address, change } = output as {\n address: string;\n script: Buffer;\n value: number;\n change?: boolean;\n };\n\n const outputAddress =\n // @ts-expect-error - stripToCashAddress is not defined in the UTXO toolbox just only on BCH\n chain === Chain.BitcoinCash ? toolbox.stripToCashAddress(address) : address;\n\n if (change || address === walletAddress) {\n return {\n addressNList: addressInfo.address_n,\n isChange: true,\n addressType: \"change\",\n amount: value,\n scriptType,\n };\n }\n\n if (outputAddress) {\n return { address: outputAddress, amount: value, addressType: \"spend\" };\n }\n\n return null;\n })\n .filter(Boolean);\n\n const removeNullAndEmptyObjectsFromArray = (arr: any[]) => {\n return arr.filter(\n (item) => item !== null && typeof item === \"object\" && Object.keys(item).length > 0,\n );\n };\n\n const responseSign = await sdk.utxo.utxoSignTransaction({\n coin: ChainToKeepKeyName[chain],\n inputs,\n outputs: removeNullAndEmptyObjectsFromArray(outputs),\n opReturnData: memo,\n });\n\n return responseSign.serializedTx?.toString();\n };\n\n const transfer = async ({\n recipient,\n feeOptionKey,\n feeRate,\n memo,\n ...rest\n }: GenericTransferParams) => {\n if (!walletAddress)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"From address must be provided\",\n });\n if (!recipient)\n throw new SwapKitError(\"wallet_keepkey_invalid_params\", {\n reason: \"Recipient address must be provided\",\n });\n\n const createTxMethod =\n chain === Chain.BitcoinCash\n ? (toolbox as UTXOToolboxes[\"BCH\"]).buildTx\n : (toolbox as UTXOToolboxes[\"BTC\"]).createTransaction;\n\n const { psbt, inputs: rawInputs } = await createTxMethod({\n ...rest,\n memo,\n recipient,\n feeRate: feeRate || (await toolbox.getFeeRates())[feeOptionKey || FeeOption.Fast],\n sender: walletAddress,\n fetchTxHex: true,\n });\n\n const inputs = rawInputs.map(({ value, index, hash, txHex }) => ({\n //@TODO don't hardcode master, lookup on blockbook what input this is for and what path that address is!\n addressNList: addressInfo.address_n,\n amount: value.toString(),\n hex: txHex || \"\",\n scriptType,\n txid: hash,\n vout: index,\n }));\n\n const txHex = await signTransaction(psbt, inputs, memo);\n return toolbox.broadcastTx(txHex);\n };\n\n return { ...toolbox, signTransaction, transfer, address: walletAddress };\n};\n"
12
12
  ],
13
13
  "mappings": "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",
14
- "debugId": "D8EC357B71EA30F564756E2164756E21",
14
+ "debugId": "C358D755D9B9BFA964756E2164756E21",
15
15
  "names": []
16
16
  }
@@ -1,3 +1,3 @@
1
- import{a as B}from"../../chunk-ebfkk1jn.js";import{c as d,d as u}from"../../chunk-38ztynv0.js";import{AssetValue as L,Chain as t,ChainIdToChain as V,SwapKitError as _,WalletOption as b,createWallet as j,filterSupportedChains as H}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as p,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var O=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new p("wallet_keepkey_chain_not_supported",{chain:e})}};function w(e){if(!window.keepkey)throw new p("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function F({method:e,params:c,chain:r}){let s=w(r);return new Promise((o,i)=>{if(s&&"request"in s)s.request({method:e,params:c},(n,m)=>{n?i(n):o(m)});else i(new p("wallet_provider_not_found"))})}async function k(e){let c=w(e);if(!c)throw new p({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[s]=await c.request({method:r,params:[]});return s}async function f({assetValue:e,recipient:c,memo:r,gasLimit:s},o="transfer"){if(!e)throw new p("wallet_keepkey_asset_not_defined");let i=await k(e.chain),n=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:s}];return F({method:o,params:n,chain:e.chain})}function l(e,c){return{call:async({contractAddress:r,abi:s,funcName:o,funcParams:i=[],txOverrides:n})=>{if(!r)throw new p("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:P}=await import("@swapkit/toolboxes/evm");if(y({abi:s,funcName:o})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:s,funcName:o,funcParams:i,txOverrides:n});return e.send("eth_sendTransaction",[{value:P(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,s,e)[o]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:s,amount:o,from:i})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:P,to:T,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[s,BigInt(o||n)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(P||0)),from:i,to:T,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:s,to:o,data:i,value:n}=r;if(!o)throw new p("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(n||0)),from:s,to:o,data:i||"0x"}])}}}var K=j({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:b.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function s(o){let i=H({chains:o,supportedChains:c,walletType:r});return await Promise.all(i.map(async(n)=>{let m=await k(n),g=await R(n);e({...g,address:m,chain:n,walletType:r})})),!0}}),S=B(K);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:s}=await import("@swapkit/toolboxes/cosmos"),o=e===t.Maya?s:r;return{...c(e),deposit:(n)=>f({...n,recipient:""},"deposit"),transfer:(n)=>f({...n,gasLimit:o},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(V[e]);if(!r)throw new _("wallet_keepkey_signer_not_found");let s=c(e,{signer:r}),o=await r.getAccounts();if(!o?.[0]?.address)throw new _("wallet_keepkey_no_accounts");let[{address:i}]=o;return{...s,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{let o=O(e),i=await window?.keepkey?.[o]?.request({method:"request_balance"});return[L.from({chain:e,value:i[0].balance})]},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:s}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:o}=await import("ethers"),i=w(e);if(!i)throw new _("wallet_keepkey_not_found");let n=new o(i,"any"),m=await n.getSigner(),g=await s(e,{provider:n,signer:m}),y=l(n,e);try{if(e!==t.Ethereum){let P=g.getNetworkParams();await r(n,e,P)}}catch(P){throw new _({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:b.KEEPKEY,chain:e}})}return c({provider:n,chain:e,toolbox:{...g,...y}})}default:return null}}export{K as keepkeyBexWallet,S as KEEPKEY_BEX_SUPPORTED_CHAINS};
1
+ import{A as B}from"../../chunk-zfnkndsr.js";import{C as d,D as u}from"../../chunk-qwd1kp32.js";import{AssetValue as L,Chain as t,ChainIdToChain as V,SwapKitError as _,WalletOption as b,createWallet as j,filterSupportedChains as H}from"@swapkit/helpers";import{Chain as a,EVMChains as D,SwapKitError as p,WalletOption as A}from"@swapkit/helpers";import{erc20ABI as I}from"@swapkit/helpers/contracts";var O=(e)=>{switch(e){case a.Bitcoin:return"bitcoin";case a.BitcoinCash:return"bitcoincash";case a.Dash:return"dash";case a.Dogecoin:return"dogecoin";case a.Litecoin:return"litecoin";default:throw new p("wallet_keepkey_chain_not_supported",{chain:e})}};function w(e){if(!window.keepkey)throw new p("wallet_keepkey_not_found");switch(e){case a.Ethereum:case a.Base:case a.Avalanche:case a.BinanceSmartChain:case a.Arbitrum:case a.Optimism:case a.Polygon:return window.keepkey.ethereum;case a.Cosmos:return window.keepkey.cosmos;case a.Bitcoin:return window.keepkey.bitcoin;case a.BitcoinCash:return window.keepkey.bitcoincash;case a.Dogecoin:return window.keepkey.dogecoin;case a.Litecoin:return window.keepkey.litecoin;case a.Dash:return window.keepkey.dash;case a.THORChain:return window.keepkey.thorchain;case a.Maya:return window.keepkey.mayachain;default:return}}async function F({method:e,params:c,chain:r}){let s=w(r);return new Promise((o,i)=>{if(s&&"request"in s)s.request({method:e,params:c},(n,m)=>{n?i(n):o(m)});else i(new p("wallet_provider_not_found"))})}async function k(e){let c=w(e);if(!c)throw new p({errorKey:"wallet_provider_not_found",info:{wallet:A.KEEPKEY,chain:e}});let r="request_accounts";if(D.includes(e))r="eth_requestAccounts";let[s]=await c.request({method:r,params:[]});return s}async function f({assetValue:e,recipient:c,memo:r,gasLimit:s},o="transfer"){if(!e)throw new p("wallet_keepkey_asset_not_defined");let i=await k(e.chain),n=[{amount:{amount:e.getValue("string"),decimals:e.decimal},asset:{chain:e.chain,symbol:e.symbol.toUpperCase(),ticker:e.symbol.toUpperCase()},memo:r,from:i,recipient:c,gasLimit:s}];return F({method:o,params:n,chain:e.chain})}function l(e,c){return{call:async({contractAddress:r,abi:s,funcName:o,funcParams:i=[],txOverrides:n})=>{if(!r)throw new p("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:g,isStateChangingCall:y,toHexString:P}=await import("@swapkit/toolboxes/evm");if(y({abi:s,funcName:o})){let X=g({provider:e,chain:c}),{value:U,from:q,to:M,data:x}=await X({contractAddress:r,abi:s,funcName:o,funcParams:i,txOverrides:n});return e.send("eth_sendTransaction",[{value:P(BigInt(U||0)),from:q,to:M,data:x||"0x"}])}let v=await m(r,s,e)[o]?.(...i);return typeof v?.hash==="string"?v?.hash:v},approve:async({assetAddress:r,spenderAddress:s,amount:o,from:i})=>{let{MAX_APPROVAL:n,getCreateContractTxObject:m,toHexString:g}=await import("@swapkit/toolboxes/evm"),y=m({provider:e,chain:c}),{value:P,to:T,data:E}=await y({contractAddress:r,abi:I,funcName:"approve",funcParams:[s,BigInt(o||n)],txOverrides:{from:i}});return e.send("eth_sendTransaction",[{value:g(BigInt(P||0)),from:i,to:T,data:E||"0x"}])},sendTransaction:async(r)=>{let{from:s,to:o,data:i,value:n}=r;if(!o)throw new p("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@swapkit/toolboxes/evm");return e.send("eth_sendTransaction",[{value:m(BigInt(n||0)),from:s,to:o,data:i||"0x"}])}}}var K=j({name:"connectKeepkeyBex",supportedChains:[t.Arbitrum,t.Avalanche,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Base,t.Cosmos,t.Dash,t.Dogecoin,t.Ethereum,t.Kujira,t.Litecoin,t.Maya,t.Optimism,t.Polygon,t.Solana,t.THORChain],walletType:b.KEEPKEY_BEX,connect:({addChain:e,supportedChains:c,walletType:r})=>async function s(o){let i=H({chains:o,supportedChains:c,walletType:r});return await Promise.all(i.map(async(n)=>{let m=await k(n),g=await R(n);e({...g,address:m,chain:n,walletType:r})})),!0}}),S=B(K);async function R(e){switch(e){case t.Maya:case t.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:r,MAYA_GAS_VALUE:s}=await import("@swapkit/toolboxes/cosmos"),o=e===t.Maya?s:r;return{...c(e),deposit:(n)=>f({...n,recipient:""},"deposit"),transfer:(n)=>f({...n,gasLimit:o},"transfer")}}case t.Cosmos:case t.Kujira:{let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),r=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(V[e]);if(!r)throw new _("wallet_keepkey_signer_not_found");let s=c(e,{signer:r}),o=await r.getAccounts();if(!o?.[0]?.address)throw new _("wallet_keepkey_no_accounts");let[{address:i}]=o;return{...s,address:i}}case t.Dash:case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:c}=await import("@swapkit/toolboxes/utxo");return{...await c(e),getBalance:async()=>{let o=O(e),i=await window?.keepkey?.[o]?.request({method:"request_balance"});return[L.from({chain:e,value:i[0].balance})]},transfer:f}}case t.Ethereum:case t.BinanceSmartChain:case t.Base:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:r}=await import("@swapkit/helpers"),{getEvmToolbox:s}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:o}=await import("ethers"),i=w(e);if(!i)throw new _("wallet_keepkey_not_found");let n=new o(i,"any"),m=await n.getSigner(),g=await s(e,{provider:n,signer:m}),y=l(n,e);try{if(e!==t.Ethereum){let P=g.getNetworkParams();await r(n,e,P)}}catch(P){throw new _({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:b.KEEPKEY,chain:e}})}return c({provider:n,chain:e,toolbox:{...g,...y}})}default:return null}}export{K as keepkeyBexWallet,S as KEEPKEY_BEX_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=3200B33418FAB69964756E2164756E21
3
+ //# debugId=0F160E0AAF7196EF64756E2164756E21
@@ -6,6 +6,6 @@
6
6
  "import {\n type AssetValue,\n Chain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ninterface UTXOProvider {\n request: (\n args: {\n method: string;\n params?: {\n amount: { amount: string; decimals?: number };\n asset: { chain: Chain; symbol: string; ticker: string };\n memo: string | undefined;\n from?: string;\n recipient: string;\n gasLimit?: string | bigint;\n }[];\n },\n callback: (err: string, tx: string) => void,\n ) => void;\n}\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: string | 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 | undefined;\n};\n\nexport const getProviderNameFromChain = (chain: Chain): string => {\n switch (chain) {\n case Chain.Bitcoin:\n return \"bitcoin\";\n case Chain.BitcoinCash:\n return \"bitcoincash\";\n case Chain.Dash:\n return \"dash\";\n case Chain.Dogecoin:\n return \"dogecoin\";\n case Chain.Litecoin:\n return \"litecoin\";\n default:\n throw new SwapKitError(\"wallet_keepkey_chain_not_supported\", { chain });\n }\n};\n\ndeclare const window: {\n keepkey?: {\n binance: Eip1193Provider;\n bitcoin: Eip1193Provider;\n bitcoincash: Eip1193Provider;\n dogecoin: Eip1193Provider;\n ethereum: Eip1193Provider;\n cosmos: Eip1193Provider;\n dash: Eip1193Provider;\n litecoin: Eip1193Provider;\n thorchain: Eip1193Provider;\n mayachain: Eip1193Provider;\n };\n} & Window;\n\nexport function getKEEPKEYProvider<T extends Chain>(chain: T) {\n if (!window.keepkey) throw new SwapKitError(\"wallet_keepkey_not_found\");\n\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Base:\n case Chain.Avalanche:\n case Chain.BinanceSmartChain:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n return window.keepkey.ethereum as Eip1193Provider;\n case Chain.Cosmos:\n return window.keepkey.cosmos as Eip1193Provider;\n case Chain.Bitcoin:\n return window.keepkey.bitcoin as UTXOProvider;\n case Chain.BitcoinCash:\n return window.keepkey.bitcoincash as UTXOProvider;\n case Chain.Dogecoin:\n return window.keepkey.dogecoin as UTXOProvider;\n case Chain.Litecoin:\n return window.keepkey.litecoin as UTXOProvider;\n case Chain.Dash:\n return window.keepkey.dash as UTXOProvider;\n case Chain.THORChain:\n return window.keepkey.thorchain as UTXOProvider;\n case Chain.Maya:\n return window.keepkey.mayachain as UTXOProvider;\n\n default:\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 = getKEEPKEYProvider(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 } else {\n reject(new SwapKitError(\"wallet_provider_not_found\"));\n }\n });\n}\n\nexport async function getKEEPKEYAddress(chain: Chain) {\n const eipProvider = getKEEPKEYProvider(chain) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.KEEPKEY, chain },\n });\n }\n\n let method = \"request_accounts\";\n if (EVMChains.includes(chain as EVMChain)) {\n method = \"eth_requestAccounts\";\n }\n\n const [response] = await eipProvider.request({ method, params: [] });\n return response;\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams & { assetValue: AssetValue },\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_keepkey_asset_not_defined\");\n }\n\n const from = await getKEEPKEYAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getValue(\"string\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo,\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getKEEPKEYMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_keepkey_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall, toHexString } =\n await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n return provider.send(\"eth_sendTransaction\", [\n { value: toHexString(BigInt(value || 0)), from, to, data: data || \"0x\" },\n ]);\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject, toHexString } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx({\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams: [spenderAddress, BigInt(amount || MAX_APPROVAL)],\n txOverrides: { from },\n });\n\n return provider.send(\"eth_sendTransaction\", [\n { value: toHexString(BigInt(value || 0)), from, to, data: data || \"0x\" },\n ]);\n },\n sendTransaction: async (tx: EVMTxParams) => {\n const { from, to, data, value } = tx;\n if (!to) {\n throw new SwapKitError(\"wallet_keepkey_send_transaction_no_address\");\n }\n\n const { toHexString } = await import(\"@swapkit/toolboxes/evm\");\n\n return provider.send(\"eth_sendTransaction\", [\n { value: toHexString(BigInt(value || 0)), from, to, data: data || \"0x\" },\n ]);\n },\n };\n}\n"
7
7
  ],
8
8
  "mappings": "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",
9
- "debugId": "3200B33418FAB69964756E2164756E21",
9
+ "debugId": "0F160E0AAF7196EF64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,3 +1,3 @@
1
- import{c as b,d as f}from"../../chunk-38ztynv0.js";import{Chain as a,ChainId as r,ChainToChainId as y,SwapKitError as t,WalletOption as p,createWallet as F,filterSupportedChains as I}from"@swapkit/helpers";import{ChainId as l}from"@swapkit/helpers";var h=new Map([[l.Kujira,{chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",rpc:"https://kujira-rpc.nodes.defiantlabs.net",rest:"https://rest.cosmos.directory/kujira/",nodeProvider:{name:"PFC",email:"pfc-validator@protonmail.com",website:"https://pfc.zone/"},bip44:{coinType:118},bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub"},currencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"bKUJI",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji",coinDecimals:6,coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png"},{coinDenom:"AQLA",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla",coinDecimals:6,coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png"}],feeCurrencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"axlUSDC",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F",coinDecimals:6,coinGeckoId:"usd-coin"},{coinDenom:"ATOM",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2",coinDecimals:6,coinGeckoId:"cosmos"},{coinDenom:"OSMO",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23",coinDecimals:6,coinGeckoId:"osmosis"},{coinDenom:"CMDX",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07",coinDecimals:6,coinGeckoId:"comdex"},{coinDenom:"EVMOS",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10",coinDecimals:6,coinGeckoId:"evmos"},{coinDenom:"JUNO",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5",coinDecimals:6,coinGeckoId:"juno-network"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"SCRT",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5",coinDecimals:6,coinGeckoId:"secret"},{coinDenom:"STARS",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602",coinDecimals:6,coinGeckoId:"stargaze"},{coinDenom:"wAVAX",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2",coinDecimals:18,coinGeckoId:"avalanche-2"},{coinDenom:"wETH",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7",coinDecimals:18,coinGeckoId:"ethereum"}],stakeCurrency:{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},features:["cosmwasm"]}],[l.THORChain,{chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",rpc:"https://rpc-thorchain.keplr.app",rest:"https://lcd-thorchain.keplr.app",bip44:{coinType:931},bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub"},currencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png"}],feeCurrencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",gasPriceStep:{low:0.02,average:0.02,high:0.03}}],features:[]}]]);var x=[r.Cosmos,r.Kujira,r.THORChain],v=F({name:"connectKeplr",supportedChains:[a.Cosmos,a.Kujira,a.THORChain],connect:({addChain:u,supportedChains:D})=>async function j(k,o=p.KEPLR){let C=o===p.LEAP?"leap":"keplr",d=I({chains:k,supportedChains:D,walletType:o}),e=window[C];return await Promise.all(d.map(async(i)=>{let n=y[i];if(!x.includes(n)){let m=h.get(n);if(!m)throw new t("wallet_keplr_chain_not_supported",{chain:i});await e.experimentalSuggestChain(m)}e?.enable(n);let c=e?.getOfflineSignerOnlyAmino(n);if(!c)throw new t("wallet_keplr_signer_not_found");let{getCosmosToolbox:g}=await import("@swapkit/toolboxes/cosmos"),s=await c.getAccounts();if(!s?.[0]?.address)throw new t("wallet_keplr_no_accounts");let[{address:A}]=s,E=g(i,{signer:c});u({...E,chain:i,address:A,walletType:o})})),!0}});export{v as keplrWallet};
1
+ import{C as b,D as f}from"../../chunk-qwd1kp32.js";import{Chain as a,ChainId as r,ChainToChainId as y,SwapKitError as t,WalletOption as p,createWallet as F,filterSupportedChains as I}from"@swapkit/helpers";import{ChainId as l}from"@swapkit/helpers";var h=new Map([[l.Kujira,{chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",rpc:"https://kujira-rpc.nodes.defiantlabs.net",rest:"https://rest.cosmos.directory/kujira/",nodeProvider:{name:"PFC",email:"pfc-validator@protonmail.com",website:"https://pfc.zone/"},bip44:{coinType:118},bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub"},currencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"bKUJI",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji",coinDecimals:6,coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png"},{coinDenom:"AQLA",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla",coinDecimals:6,coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png"}],feeCurrencies:[{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},{coinDenom:"USK",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk",coinDecimals:6,coinGeckoId:"usk"},{coinDenom:"axlUSDC",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F",coinDecimals:6,coinGeckoId:"usd-coin"},{coinDenom:"ATOM",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2",coinDecimals:6,coinGeckoId:"cosmos"},{coinDenom:"OSMO",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23",coinDecimals:6,coinGeckoId:"osmosis"},{coinDenom:"CMDX",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07",coinDecimals:6,coinGeckoId:"comdex"},{coinDenom:"EVMOS",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10",coinDecimals:6,coinGeckoId:"evmos"},{coinDenom:"JUNO",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5",coinDecimals:6,coinGeckoId:"juno-network"},{coinDenom:"MNTA",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta",coinDecimals:6,coinGeckoId:"mantadao"},{coinDenom:"SCRT",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5",coinDecimals:6,coinGeckoId:"secret"},{coinDenom:"STARS",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602",coinDecimals:6,coinGeckoId:"stargaze"},{coinDenom:"wAVAX",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2",coinDecimals:18,coinGeckoId:"avalanche-2"},{coinDenom:"wETH",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7",coinDecimals:18,coinGeckoId:"ethereum"}],stakeCurrency:{coinDenom:"KUJI",coinMinimalDenom:"ukuji",coinDecimals:6,coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png"},features:["cosmwasm"]}],[l.THORChain,{chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",rpc:"https://rpc-thorchain.keplr.app",rest:"https://lcd-thorchain.keplr.app",bip44:{coinType:931},bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub"},currencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png"}],feeCurrencies:[{coinDenom:"RUNE",coinMinimalDenom:"rune",coinDecimals:8,coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",gasPriceStep:{low:0.02,average:0.02,high:0.03}}],features:[]}]]);var x=[r.Cosmos,r.Kujira,r.THORChain],v=F({name:"connectKeplr",supportedChains:[a.Cosmos,a.Kujira,a.THORChain],connect:({addChain:u,supportedChains:D})=>async function j(k,o=p.KEPLR){let C=o===p.LEAP?"leap":"keplr",d=I({chains:k,supportedChains:D,walletType:o}),e=window[C];return await Promise.all(d.map(async(i)=>{let n=y[i];if(!x.includes(n)){let m=h.get(n);if(!m)throw new t("wallet_keplr_chain_not_supported",{chain:i});await e.experimentalSuggestChain(m)}e?.enable(n);let c=e?.getOfflineSignerOnlyAmino(n);if(!c)throw new t("wallet_keplr_signer_not_found");let{getCosmosToolbox:g}=await import("@swapkit/toolboxes/cosmos"),s=await c.getAccounts();if(!s?.[0]?.address)throw new t("wallet_keplr_no_accounts");let[{address:A}]=s,E=g(i,{signer:c});u({...E,chain:i,address:A,walletType:o})})),!0}});export{v as keplrWallet};
2
2
 
3
- //# debugId=6FD2408D3FF1F0DD64756E2164756E21
3
+ //# debugId=6CE237E8BFE52E3164756E2164756E21
@@ -6,6 +6,6 @@
6
6
  "import type { ChainInfo } from \"@keplr-wallet/types\";\nimport { ChainId } from \"@swapkit/helpers\";\n\nexport const chainRegistry = new Map<ChainId, ChainInfo>([\n [\n ChainId.Kujira,\n {\n chainId: \"kaiyo-1\",\n chainName: \"Kujira\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png\",\n rpc: \"https://kujira-rpc.nodes.defiantlabs.net\",\n rest: \"https://rest.cosmos.directory/kujira/\",\n nodeProvider: {\n name: \"PFC\",\n email: \"pfc-validator@protonmail.com\",\n website: \"https://pfc.zone/\",\n },\n bip44: {\n coinType: 118,\n },\n bech32Config: {\n bech32PrefixAccAddr: \"kujira\",\n bech32PrefixAccPub: \"kujirapub\",\n bech32PrefixValAddr: \"kujiravaloper\",\n bech32PrefixValPub: \"kujiravaloperpub\",\n bech32PrefixConsAddr: \"kujiravalcons\",\n bech32PrefixConsPub: \"kujiravalconspub\",\n },\n currencies: [\n {\n coinDenom: \"KUJI\",\n coinMinimalDenom: \"ukuji\",\n coinDecimals: 6,\n coinGeckoId: \"kujira\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n },\n {\n coinDenom: \"USK\",\n coinMinimalDenom:\n \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n coinDecimals: 6,\n coinGeckoId: \"usk\",\n },\n {\n coinDenom: \"MNTA\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n coinDecimals: 6,\n coinGeckoId: \"mantadao\",\n },\n {\n coinDenom: \"bKUJI\",\n coinMinimalDenom:\n \"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji\",\n coinDecimals: 6,\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png\",\n },\n {\n coinDenom: \"AQLA\",\n coinMinimalDenom: \"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla\",\n coinDecimals: 6,\n coinGeckoId: \"aqualibre\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png\",\n },\n ],\n feeCurrencies: [\n {\n coinDenom: \"KUJI\",\n coinMinimalDenom: \"ukuji\",\n coinDecimals: 6,\n coinGeckoId: \"kujira\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n },\n {\n coinDenom: \"USK\",\n coinMinimalDenom:\n \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n coinDecimals: 6,\n coinGeckoId: \"usk\",\n },\n {\n coinDenom: \"axlUSDC\",\n coinMinimalDenom: \"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F\",\n coinDecimals: 6,\n coinGeckoId: \"usd-coin\",\n },\n {\n coinDenom: \"ATOM\",\n coinMinimalDenom: \"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2\",\n coinDecimals: 6,\n coinGeckoId: \"cosmos\",\n },\n {\n coinDenom: \"OSMO\",\n coinMinimalDenom: \"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23\",\n coinDecimals: 6,\n coinGeckoId: \"osmosis\",\n },\n {\n coinDenom: \"CMDX\",\n coinMinimalDenom: \"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07\",\n coinDecimals: 6,\n coinGeckoId: \"comdex\",\n },\n {\n coinDenom: \"EVMOS\",\n coinMinimalDenom: \"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10\",\n coinDecimals: 6,\n coinGeckoId: \"evmos\",\n },\n {\n coinDenom: \"JUNO\",\n coinMinimalDenom: \"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5\",\n coinDecimals: 6,\n coinGeckoId: \"juno-network\",\n },\n {\n coinDenom: \"MNTA\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n coinDecimals: 6,\n coinGeckoId: \"mantadao\",\n },\n {\n coinDenom: \"SCRT\",\n coinMinimalDenom: \"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5\",\n coinDecimals: 6,\n coinGeckoId: \"secret\",\n },\n {\n coinDenom: \"STARS\",\n coinMinimalDenom: \"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602\",\n coinDecimals: 6,\n coinGeckoId: \"stargaze\",\n },\n {\n coinDenom: \"wAVAX\",\n coinMinimalDenom: \"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2\",\n coinDecimals: 18,\n coinGeckoId: \"avalanche-2\",\n },\n {\n coinDenom: \"wETH\",\n coinMinimalDenom: \"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7\",\n coinDecimals: 18,\n coinGeckoId: \"ethereum\",\n },\n ],\n stakeCurrency: {\n coinDenom: \"KUJI\",\n coinMinimalDenom: \"ukuji\",\n coinDecimals: 6,\n coinGeckoId: \"kujira\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n },\n features: [\"cosmwasm\"],\n },\n ],\n [\n ChainId.THORChain,\n {\n chainId: \"thorchain-1\",\n chainName: \"THORChain\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png\",\n rpc: \"https://rpc-thorchain.keplr.app\",\n rest: \"https://lcd-thorchain.keplr.app\",\n bip44: {\n coinType: 931,\n },\n bech32Config: {\n bech32PrefixAccAddr: \"thor\",\n bech32PrefixAccPub: \"thorpub\",\n bech32PrefixValAddr: \"thorvaloper\",\n bech32PrefixValPub: \"thorvaloperpub\",\n bech32PrefixConsAddr: \"thorvalcons\",\n bech32PrefixConsPub: \"thorvalconspub\",\n },\n currencies: [\n {\n coinDenom: \"RUNE\",\n coinMinimalDenom: \"rune\",\n coinDecimals: 8,\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n },\n ],\n feeCurrencies: [\n {\n coinDenom: \"RUNE\",\n coinMinimalDenom: \"rune\",\n coinDecimals: 8,\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n gasPriceStep: {\n low: 0.02,\n average: 0.02,\n high: 0.03,\n },\n },\n ],\n features: [],\n },\n ],\n]);\n"
7
7
  ],
8
8
  "mappings": "mDAAA,gBACE,aACA,oBACA,kBACA,kBACA,kBACA,2BACA,yBCNF,kBAAS,yBAEF,IAAM,EAAgB,IAAI,IAAwB,CACvD,CACE,EAAQ,OACR,CACE,QAAS,UACT,UAAW,SACX,oBACE,gGACF,IAAK,2CACL,KAAM,wCACN,aAAc,CACZ,KAAM,MACN,MAAO,+BACP,QAAS,mBACX,EACA,MAAO,CACL,SAAU,GACZ,EACA,aAAc,CACZ,oBAAqB,SACrB,mBAAoB,YACpB,oBAAqB,gBACrB,mBAAoB,mBACpB,qBAAsB,gBACtB,oBAAqB,kBACvB,EACA,WAAY,CACV,CACE,UAAW,OACX,iBAAkB,QAClB,aAAc,EACd,YAAa,SACb,aACE,+FACJ,EACA,CACE,UAAW,MACX,iBACE,iFACF,aAAc,EACd,YAAa,KACf,EACA,CACE,UAAW,OACX,iBAAkB,8DAClB,aAAc,EACd,YAAa,UACf,EACA,CACE,UAAW,QACX,iBACE,qFACF,aAAc,EACd,aACE,yKACJ,EACA,CACE,UAAW,OACX,iBAAkB,8DAClB,aAAc,EACd,YAAa,YACb,aACE,oJACJ,CACF,EACA,cAAe,CACb,CACE,UAAW,OACX,iBAAkB,QAClB,aAAc,EACd,YAAa,SACb,aACE,+FACJ,EACA,CACE,UAAW,MACX,iBACE,iFACF,aAAc,EACd,YAAa,KACf,EACA,CACE,UAAW,UACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,UACf,EACA,CACE,UAAW,OACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,QACf,EACA,CACE,UAAW,OACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,SACf,EACA,CACE,UAAW,OACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,QACf,EACA,CACE,UAAW,QACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,OACf,EACA,CACE,UAAW,OACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,cACf,EACA,CACE,UAAW,OACX,iBAAkB,8DAClB,aAAc,EACd,YAAa,UACf,EACA,CACE,UAAW,OACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,QACf,EACA,CACE,UAAW,QACX,iBAAkB,uEAClB,aAAc,EACd,YAAa,UACf,EACA,CACE,UAAW,QACX,iBAAkB,uEAClB,aAAc,GACd,YAAa,aACf,EACA,CACE,UAAW,OACX,iBAAkB,uEAClB,aAAc,GACd,YAAa,UACf,CACF,EACA,cAAe,CACb,UAAW,OACX,iBAAkB,QAClB,aAAc,EACd,YAAa,SACb,aACE,+FACJ,EACA,SAAU,CAAC,UAAU,CACvB,CACF,EACA,CACE,EAAQ,UACR,CACE,QAAS,cACT,UAAW,YACX,oBACE,oGACF,IAAK,kCACL,KAAM,kCACN,MAAO,CACL,SAAU,GACZ,EACA,aAAc,CACZ,oBAAqB,OACrB,mBAAoB,UACpB,oBAAqB,cACrB,mBAAoB,iBACpB,qBAAsB,cACtB,oBAAqB,gBACvB,EACA,WAAY,CACV,CACE,UAAW,OACX,iBAAkB,OAClB,aAAc,EACd,YAAa,YACb,aACE,kGACJ,CACF,EACA,cAAe,CACb,CACE,UAAW,OACX,iBAAkB,OAClB,aAAc,EACd,YAAa,YACb,aACE,mGACF,aAAc,CACZ,IAAK,KACL,QAAS,KACT,KAAM,IACR,CACF,CACF,EACA,SAAU,CAAC,CACb,CACF,CACF,CAAC,EDvMD,IAAM,EAAyB,CAAC,EAAQ,OAAQ,EAAQ,OAAQ,EAAQ,SAAS,EAEpE,EAAc,EAAa,CACtC,KAAM,eACN,gBAAiB,CAAC,EAAM,OAAQ,EAAM,OAAQ,EAAM,SAAS,EAC7D,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAY,CACzB,EACA,EAAqD,EAAa,MAClE,CACA,IAAM,EAAe,IAAe,EAAa,KAAO,OAAS,QAC3D,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAC9E,EAAc,OAAO,GA6B3B,OA3BA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAU,EAAe,GAE/B,IAAK,EAAuB,SAAS,CAAO,EAAG,CAC7C,IAAM,EAAc,EAAc,IAAI,CAAO,EAC7C,IAAK,EAAa,MAAM,IAAI,EAAa,mCAAoC,CAAE,OAAM,CAAC,EAEtF,MAAM,EAAY,yBAAyB,CAAW,EAGxD,GAAa,OAAO,CAAO,EAC3B,IAAM,EAAS,GAAa,0BAA0B,CAAO,EAC7D,IAAK,EAAQ,MAAM,IAAI,EAAa,+BAA+B,EAEnE,IAAQ,oBAAqB,KAAa,qCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,IAAK,IAAW,IAAI,QAAS,MAAM,IAAI,EAAa,0BAA0B,EAE9E,KAAS,YAAa,EAChB,EAAU,EAAiB,EAAO,CAAE,QAAO,CAAC,EAElD,EAAS,IAAK,EAAS,QAAO,UAAS,YAAW,CAAC,EACpD,CACH,EAEO,GAEb,CAAC",
9
- "debugId": "6FD2408D3FF1F0DD64756E2164756E21",
9
+ "debugId": "6CE237E8BFE52E3164756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,3 +1,3 @@
1
- var _={};E(_,{validatePhrase:()=>K,keystoreWallet:()=>x,generatePhrase:()=>P,encryptToKeyStore:()=>B,decryptFromKeystore:()=>T,KEYSTORE_SUPPORTED_CHAINS:()=>A});module.exports=D(_);var t=require("@swapkit/helpers");var o=require("node:crypto"),h=require("@scure/bip39"),d=require("@scure/bip39/wordlists/english");async function g(r){let{blake2bFinal:c,blake2bInit:p,blake2bUpdate:i}=(await import("blakejs")).default,a=r;if(!(a instanceof Buffer))a=Buffer.from(a,"hex");let n=p(32);return i(n,a),Array.from(c(n)).map((e)=>e<16?`0${e.toString(16)}`:e.toString(16)).join("")}async function B(r,c){let i=o.randomBytes(16),a=o.randomBytes(32),n={c:262144,prf:"hmac-sha256",dklen:32,salt:a.toString("hex")},e=o.pbkdf2Sync(c,a,n.c,n.dklen,"sha256"),f=o.createCipheriv("aes-128-ctr",e.subarray(0,16),i),s=Buffer.concat([f.update(Buffer.from(r,"utf8")),f.final()]),l=Buffer.concat([e.subarray(16,32),Buffer.from(s)]),m=await g(l);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:i.toString("hex")},ciphertext:s.toString("hex"),kdf:"pbkdf2",kdfparams:n,mac:m}}}function P(r=12){return h.generateMnemonic(d.wordlist,r===12?128:256)}function K(r){return h.validateMnemonic(r,d.wordlist)}async function T(r,c){let{SwapKitError:p}=await import("@swapkit/helpers");switch(r.version){case 1:{let i=r.crypto.kdfparams,a=Buffer.from(i.salt,"hex"),n=o.pbkdf2Sync(c,a,i.c,i.dklen,"sha256"),e=Buffer.from(r.crypto.ciphertext,"hex"),f=Buffer.concat([n.subarray(16,32),e]);if(await g(f)!==r.crypto.mac)throw new p("wallet_keystore_invalid_password");let l=o.createDecipheriv(r.crypto.cipher,n.subarray(0,16),Buffer.from(r.crypto.cipherparams.iv,"hex"));return Buffer.concat([l.update(e),l.final()]).toString("utf8")}default:throw new p("wallet_keystore_unsupported_version")}}var x=t.createWallet({name:"connectKeystore",walletType:t.WalletOption.KEYSTORE,supportedChains:[...t.EVMChains,...t.UTXOChains,...t.CosmosChains,t.Chain.Polkadot,t.Chain.Chainflip,t.Chain.Ripple,t.Chain.Solana,t.Chain.Tron],connect:({addChain:r,supportedChains:c,walletType:p})=>async function i(a,n,e){let f=t.filterSupportedChains({chains:a,supportedChains:c,walletType:p});return await Promise.all(f.map(async(s)=>{let l=typeof e==="number"?e:0,m=e&&typeof e==="object"?e[s]:void 0,v=t.NetworkDerivationPath[s].slice(0,s===t.Chain.Solana?4:5),b=m||t.updateDerivationPath(v,{index:l}),{getToolbox:k}=await import("@swapkit/toolboxes"),y=await k(s,{phrase:n,derivationPath:b}),S=await y.getAddress()||"",C={...y,address:S};r({...C,chain:s,walletType:t.WalletOption.KEYSTORE})})),!0}}),A=w(x);
1
+ var _={};E(_,{validatePhrase:()=>K,keystoreWallet:()=>x,generatePhrase:()=>P,encryptToKeyStore:()=>B,decryptFromKeystore:()=>T,KEYSTORE_SUPPORTED_CHAINS:()=>A});module.exports=D(_);var t=require("@swapkit/helpers");var o=require("node:crypto"),h=require("@scure/bip39"),d=require("@scure/bip39/wordlists/english");async function g(r){let{blake2bFinal:c,blake2bInit:p,blake2bUpdate:i}=(await import("blakejs")).default,a=r;if(!(a instanceof Buffer))a=Buffer.from(a,"hex");let n=p(32);return i(n,a),Array.from(c(n)).map((e)=>e<16?`0${e.toString(16)}`:e.toString(16)).join("")}async function B(r,c){let i=o.randomBytes(16),a=o.randomBytes(32),n={c:262144,prf:"hmac-sha256",dklen:32,salt:a.toString("hex")},e=o.pbkdf2Sync(c,a,n.c,n.dklen,"sha256"),f=o.createCipheriv("aes-128-ctr",e.subarray(0,16),i),s=Buffer.concat([f.update(Buffer.from(r,"utf8")),f.final()]),l=Buffer.concat([e.subarray(16,32),Buffer.from(s)]),m=await g(l);return{meta:"xchain-keystore",version:1,crypto:{cipher:"aes-128-ctr",cipherparams:{iv:i.toString("hex")},ciphertext:s.toString("hex"),kdf:"pbkdf2",kdfparams:n,mac:m}}}function P(r=12){return h.generateMnemonic(d.wordlist,r===12?128:256)}function K(r){return h.validateMnemonic(r,d.wordlist)}async function T(r,c){let{SwapKitError:p}=await import("@swapkit/helpers");switch(r.version){case 1:{let i=r.crypto.kdfparams,a=Buffer.from(i.salt,"hex"),n=o.pbkdf2Sync(c,a,i.c,i.dklen,"sha256"),e=Buffer.from(r.crypto.ciphertext,"hex"),f=Buffer.concat([n.subarray(16,32),e]);if(await g(f)!==r.crypto.mac)throw new p("wallet_keystore_invalid_password");let l=o.createDecipheriv(r.crypto.cipher,n.subarray(0,16),Buffer.from(r.crypto.cipherparams.iv,"hex"));return Buffer.concat([l.update(e),l.final()]).toString("utf8")}default:throw new p("wallet_keystore_unsupported_version")}}var x=t.createWallet({name:"connectKeystore",walletType:t.WalletOption.KEYSTORE,supportedChains:[...t.EVMChains,...t.UTXOChains,...t.CosmosChains,t.Chain.Polkadot,t.Chain.Chainflip,t.Chain.Ripple,t.Chain.Solana,t.Chain.Tron,t.Chain.Near],connect:({addChain:r,supportedChains:c,walletType:p})=>async function i(a,n,e){let f=t.filterSupportedChains({chains:a,supportedChains:c,walletType:p});return await Promise.all(f.map(async(s)=>{let l=typeof e==="number"?e:0,m=e&&typeof e==="object"?e[s]:void 0,v=t.NetworkDerivationPath[s].slice(0,s===t.Chain.Solana?4:5),b=m||t.updateDerivationPath(v,{index:l}),{getToolbox:k}=await import("@swapkit/toolboxes"),y=await k(s,{phrase:n,derivationPath:b}),S=await y.getAddress()||"",C={...y,address:S};r({...C,chain:s,walletType:t.WalletOption.KEYSTORE})})),!0}}),A=w(x);
2
2
 
3
- //# debugId=628CC53E568892EA64756E2164756E21
3
+ //# debugId=8B787A2A3639BA0C64756E2164756E21