@swapkit/wallets 4.1.11 → 4.1.13

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.
@@ -1,4 +1,4 @@
1
- var P={};k(P,{ctrlWallet:()=>K,CTRL_SUPPORTED_CHAINS:()=>E});module.exports=f(P);var z=require("@swapkit/helpers"),R=require("@swapkit/wallet-core");var J=require("@swapkit/helpers");async function Y(Q){if(!window.xfi)throw new J.SwapKitError("wallet_ctrl_not_found");let{match:Z}=await import("ts-pattern");return Z(Q).with(J.Chain.Arbitrum,J.Chain.Aurora,J.Chain.Avalanche,J.Chain.Base,J.Chain.Berachain,J.Chain.BinanceSmartChain,J.Chain.Ethereum,J.Chain.Gnosis,J.Chain.Optimism,J.Chain.Polygon,()=>window.xfi?.ethereum).with(J.Chain.Cosmos,J.Chain.Kujira,J.Chain.Noble,()=>window.xfi?.keplr).with(J.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(J.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(J.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(J.Chain.Litecoin,()=>window.xfi?.litecoin).with(J.Chain.Solana,()=>window.xfi?.solana).with(J.Chain.THORChain,()=>window.xfi?.thorchain).with(J.Chain.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function W({method:Q,params:Z,chain:X}){let $=await Y(X);return new Promise((D,F)=>{if($&&"request"in $)$.request({method:Q,params:Z},(B,H)=>{B?F(B):D(H)})})}async function L(Q){try{let Z=await Y(Q);if(!Z)throw new J.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:Q,wallet:J.WalletOption.CTRL}});if([J.Chain.Cosmos,J.Chain.Kujira,J.Chain.Noble].includes(Q)){let $=await Y(J.Chain.Cosmos);if(!$||"request"in $)throw new J.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:Q,wallet:J.WalletOption.CTRL}});let D=J.ChainToChainId[Q];await $.enable(D);let F=$.getOfflineSigner(D),[B]=await F.getAccounts();return B?.address}if(J.EVMChains.includes(Q)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:$}=await import("ethers"),D=new $(Z,"any"),[F]=await J.providerRequest({method:"eth_requestAccounts",params:[],provider:D});return F}if(Q===J.Chain.Solana)return(await(await Y(J.Chain.Solana)).connect()).publicKey.toString();if(Q===J.Chain.Near){if(!window.xfi?.near)throw new J.SwapKitError("wallet_ctrl_not_found",{chain:J.Chain.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 J.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:Q,wallet:J.WalletOption.CTRL}})}}async function y({assetValue:Q,recipient:Z,memo:X,gasLimit:$},D="transfer"){if(!Q)throw new J.SwapKitError("wallet_ctrl_asset_not_defined");let F=await L(Q.chain),B=[{amount:{amount:Q.getBaseValue("number"),decimals:Q.decimal},asset:{chain:Q.chain,symbol:Q.symbol.toUpperCase(),ticker:Q.symbol.toUpperCase()},from:F,gasLimit:$,memo:X||"",recipient:Z}];return W({chain:Q.chain,method:D,params:B})}var K=R.createWallet({connect:({addChain:Q,walletType:Z,supportedChains:X})=>async function(D){let B=z.filterSupportedChains({chains:D,supportedChains:X,walletType:Z}).map(async(H)=>{let j=await L(H),q=await b(H);Q({...q,address:j,chain:H,walletType:Z})});return await Promise.all(B),!0},name:"connectCtrl",supportedChains:[z.Chain.Arbitrum,z.Chain.Aurora,z.Chain.Avalanche,z.Chain.Base,z.Chain.Berachain,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dogecoin,z.Chain.Ethereum,z.Chain.Gnosis,z.Chain.Kujira,z.Chain.Litecoin,z.Chain.Maya,z.Chain.Near,z.Chain.Noble,z.Chain.Optimism,z.Chain.Polygon,z.Chain.Solana,z.Chain.THORChain],walletType:z.WalletOption.CTRL}),E=R.getWalletSupportedChains(K);async function b(Q){switch(Q){case z.Chain.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),X=window.xfi?.solana;if(!X)throw new z.SwapKitError("wallet_ctrl_not_found");return{...Z({signer:X})}}case z.Chain.Maya:case z.Chain.THORChain:{let{getCosmosToolbox:Z,THORCHAIN_GAS_VALUE:X,MAYA_GAS_VALUE:$}=await import("@swapkit/toolboxes/cosmos"),D=Q===z.Chain.Maya?$:X;return{...await Z(Q),deposit:(B)=>y({...B,recipient:""},"deposit"),transfer:(B)=>y({...B,gasLimit:D},"transfer")}}case z.Chain.Cosmos:case z.Chain.Kujira:case z.Chain.Noble:{let{getCosmosToolbox:Z}=await import("@swapkit/toolboxes/cosmos"),X=z.ChainToChainId[Q],$=await Y(Q);await $?.enable(X);let D=$?.getOfflineSignerOnlyAmino(X);if(!D)throw new z.SwapKitError("wallet_ctrl_not_found");return Z(Q,{signer:D})}case z.Chain.Bitcoin:case z.Chain.BitcoinCash:case z.Chain.Dogecoin:case z.Chain.Litecoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo");return{...await Z(Q),transfer:y}}case z.Chain.Arbitrum:case z.Chain.Aurora:case z.Chain.Avalanche:case z.Chain.Base:case z.Chain.Berachain:case z.Chain.BinanceSmartChain:case z.Chain.Ethereum:case z.Chain.Gnosis:case z.Chain.Optimism:case z.Chain.Polygon:{let{prepareNetworkSwitch:Z,switchEVMWalletNetwork:X}=await import("@swapkit/helpers"),{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:D}=await import("ethers"),F=await Y(Q);if(!F)throw new z.SwapKitError("wallet_ctrl_not_found");let B=new D(F,"any"),H=await B.getSigner(),j=await $(Q,{provider:B,signer:H});try{if(Q!==z.Chain.Ethereum){let q=j.getNetworkParams();await X(B,Q,q)}}catch(q){throw new z.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:Q,wallet:z.WalletOption.CTRL}})}return Z({chain:Q,provider:B,toolbox:j})}case z.Chain.Near:{if(!window.xfi?.near)throw new z.SwapKitError("wallet_ctrl_not_found",{chain:z.Chain.Near});let{createNearSignerFromProvider:Z}=await import("../../chunk-t3m5498m.js"),{getNearToolbox:X}=await import("@swapkit/toolboxes/near"),$=window.xfi.near,D=await Z($,"CTRL"),F=await D.getAddress();return{...await X({signer:D}),createTransaction:async(q)=>{let{functionCall:U,transfer:_}=await import("near-api-js/lib/transaction");if(q.functionCall){let{methodName:O,args:A,attachedDeposit:I}=q.functionCall;return{actions:[U(O,A,BigInt("30000000000000"),BigInt(I||"0"))],receiverId:q.recipient,signerId:F}}let M=q.assetValue.getBaseValue("string");return{actions:[_(BigInt(M))],receiverId:q.recipient,signerId:F}},transfer:async(q)=>{let{transfer:U}=await import("near-api-js/lib/transaction"),_=q.assetValue.getBaseValue("string"),N={actions:[U(BigInt(_))],receiverId:q.recipient,signerId:F};return await $.request({method:"signAndSendTransaction",params:{transaction:N}})}}}default:return null}}
1
+ var p={};N(p,{ctrlWallet:()=>b,CTRL_SUPPORTED_CHAINS:()=>S});module.exports=y(p);var o=require("@swapkit/helpers"),x=require("@swapkit/wallet-core");var t=require("@swapkit/helpers");async function m(r){if(!window.xfi)throw new t.SwapKitError("wallet_ctrl_not_found");let{match:n}=await import("ts-pattern");return n(r).with(t.Chain.Arbitrum,t.Chain.Aurora,t.Chain.Avalanche,t.Chain.Base,t.Chain.Berachain,t.Chain.BinanceSmartChain,t.Chain.Ethereum,t.Chain.Gnosis,t.Chain.Optimism,t.Chain.Polygon,()=>window.xfi?.ethereum).with(t.Chain.Cosmos,t.Chain.Kujira,t.Chain.Noble,()=>window.xfi?.keplr).with(t.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(t.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(t.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(t.Chain.Litecoin,()=>window.xfi?.litecoin).with(t.Chain.Solana,()=>window.xfi?.solana).with(t.Chain.THORChain,()=>window.xfi?.thorchain).with(t.Chain.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function u({method:r,params:n,chain:a}){let e=await m(a);return new Promise((s,w)=>{if(e&&"request"in e)e.request({method:r,params:n},(c,f)=>{c?w(c):s(f)})})}async function T(r){try{let n=await m(r);if(!n)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:r,wallet:t.WalletOption.CTRL}});if([t.Chain.Cosmos,t.Chain.Kujira,t.Chain.Noble].includes(r)){let e=await m(t.Chain.Cosmos);if(!e||"request"in e)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:r,wallet:t.WalletOption.CTRL}});let s=t.ChainToChainId[r];await e.enable(s);let w=e.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(t.EVMChains.includes(r)){if("request"in n&&typeof n.request==="function")return(await n.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:e}=await import("ethers"),s=new e(n,"any"),[w]=await t.providerRequest({method:"eth_requestAccounts",params:[],provider:s});return w}if(r===t.Chain.Solana)return(await(await m(t.Chain.Solana)).connect()).publicKey.toString();if(r===t.Chain.Near){if(!window.xfi?.near)throw new t.SwapKitError("wallet_ctrl_not_found",{chain:t.Chain.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await n.request({method:"request_accounts",params:[]}))[0]}catch(n){throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:r,wallet:t.WalletOption.CTRL}})}}async function g({assetValue:r,recipient:n,memo:a,gasLimit:e},s="transfer"){if(!r)throw new t.SwapKitError("wallet_ctrl_asset_not_defined");let w=await T(r.chain),c=[{amount:{amount:r.getBaseValue("number"),decimals:r.decimal},asset:{chain:r.chain,symbol:r.symbol.toUpperCase(),ticker:r.symbol.toUpperCase()},from:w,gasLimit:e,memo:a||"",recipient:n}];return u({chain:r.chain,method:s,params:c})}var b=x.createWallet({connect:({addChain:r,walletType:n,supportedChains:a})=>async function(s){let c=o.filterSupportedChains({chains:s,supportedChains:a,walletType:n}).map(async(f)=>{let i=await T(f),_=await B(f);r({..._,address:i,chain:f,walletType:n})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[o.Chain.Arbitrum,o.Chain.Aurora,o.Chain.Avalanche,o.Chain.Base,o.Chain.Berachain,o.Chain.BinanceSmartChain,o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Cosmos,o.Chain.Dogecoin,o.Chain.Ethereum,o.Chain.Gnosis,o.Chain.Kujira,o.Chain.Litecoin,o.Chain.Maya,o.Chain.Near,o.Chain.Noble,o.Chain.Optimism,o.Chain.Polygon,o.Chain.Solana,o.Chain.THORChain],walletType:o.WalletOption.CTRL}),S=x.getWalletSupportedChains(b);async function B(r){switch(r){case o.Chain.Solana:{let{getSolanaToolbox:n}=await import("@swapkit/toolboxes/solana"),a=window.xfi?.solana;if(!a)throw new o.SwapKitError("wallet_ctrl_not_found");return await n({signer:a})}case o.Chain.Maya:case o.Chain.THORChain:{let{getCosmosToolbox:n,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:e}=await import("@swapkit/toolboxes/cosmos"),s=r===o.Chain.Maya?e:a;return{...await n(r),deposit:(c)=>g({...c,recipient:""},"deposit"),transfer:(c)=>g({...c,gasLimit:s},"transfer")}}case o.Chain.Cosmos:case o.Chain.Kujira:case o.Chain.Noble:{let{getCosmosToolbox:n}=await import("@swapkit/toolboxes/cosmos"),a=o.ChainToChainId[r],e=await m(r);await e?.enable(a);let s=e?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new o.SwapKitError("wallet_ctrl_not_found");return await n(r,{signer:s})}case o.Chain.Bitcoin:case o.Chain.BitcoinCash:case o.Chain.Dogecoin:case o.Chain.Litecoin:{let{getUtxoToolbox:n}=await import("@swapkit/toolboxes/utxo");return{...await n(r),transfer:g}}case o.Chain.Arbitrum:case o.Chain.Aurora:case o.Chain.Avalanche:case o.Chain.Base:case o.Chain.Berachain:case o.Chain.BinanceSmartChain:case o.Chain.Ethereum:case o.Chain.Gnosis:case o.Chain.Optimism:case o.Chain.Polygon:{let{prepareNetworkSwitch:n,switchEVMWalletNetwork:a}=await import("@swapkit/helpers"),{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=await m(r);if(!w)throw new o.SwapKitError("wallet_ctrl_not_found");let c=new s(w,"any"),f=await c.getSigner(),i=await e(r,{provider:c,signer:f});try{if(r!==o.Chain.Ethereum){let _=i.getNetworkParams();await a(c,r,_)}}catch(_){throw new o.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:r,wallet:o.WalletOption.CTRL}})}return n({chain:r,provider:c,toolbox:i})}case o.Chain.Near:{if(!window.xfi?.near)throw new o.SwapKitError("wallet_ctrl_not_found",{chain:o.Chain.Near});let{createNearSignerFromProvider:n}=await import("../../chunk-t3m5498m.js"),{getNearToolbox:a}=await import("@swapkit/toolboxes/near"),e=window.xfi.near,s=await n(e,"CTRL"),w=await s.getAddress();return{...await a({signer:s}),transfer:async(i)=>{let{transfer:_}=await import("near-api-js/lib/transaction"),A=i.assetValue.getBaseValue("string"),d={actions:[_(BigInt(A))],receiverId:i.recipient,signerId:w};return await e.request({method:"signAndSendTransaction",params:{transaction:d}})}}}default:return null}}
2
2
 
3
- //# debugId=1648EAC05E23FF9564756E2164756E21
3
+ //# debugId=66940FBFF1B3BF3764756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -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 filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\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 name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\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(\"@swapkit/toolboxes/cosmos\");\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 case Chain.Noble: {\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.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\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\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: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\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 = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\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(\"near-api-js/lib/transaction\");\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 { actions: [action], receiverId: params.recipient, signerId: accountId };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return { actions: [action], receiverId: params.recipient, signerId: accountId };\n };\n\n return { ...toolbox, createTransaction, transfer };\n }\n\n default:\n return null;\n }\n}\n",
5
+ "import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\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 name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\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 = await 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(\"@swapkit/toolboxes/cosmos\");\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 case Chain.Noble: {\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, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await 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.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\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\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: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\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 const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n const transaction = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\n\n return txHash;\n };\n\n return { ...toolbox, transfer };\n }\n\n default:\n return null;\n }\n}\n",
6
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 providerRequest,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { 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 | Chain.Noble\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.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => 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-expect-error\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({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\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({ method: \"eth_requestAccounts\", params: [], provider });\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[]>?.({ method: \"connect\" });\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({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\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: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "1648EAC05E23FF9564756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "66940FBFF1B3BF3764756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- import{F as G,G as H}from"../../chunk-fxqrst6z.js";import{Chain as z,ChainToChainId as T,filterSupportedChains as V,SwapKitError as U,WalletOption as W}from"@swapkit/helpers";import{createWallet as x,getWalletSupportedChains as g}from"@swapkit/wallet-core";import{Chain as Z,ChainToChainId as E,EVMChains as b,providerRequest as P,SwapKitError as y,WalletOption as N}from"@swapkit/helpers";async function j(J){if(!window.xfi)throw new y("wallet_ctrl_not_found");let{match:Q}=await import("ts-pattern");return Q(J).with(Z.Arbitrum,Z.Aurora,Z.Avalanche,Z.Base,Z.Berachain,Z.BinanceSmartChain,Z.Ethereum,Z.Gnosis,Z.Optimism,Z.Polygon,()=>window.xfi?.ethereum).with(Z.Cosmos,Z.Kujira,Z.Noble,()=>window.xfi?.keplr).with(Z.Bitcoin,()=>window.xfi?.bitcoin).with(Z.BitcoinCash,()=>window.xfi?.bitcoincash).with(Z.Dogecoin,()=>window.xfi?.dogecoin).with(Z.Litecoin,()=>window.xfi?.litecoin).with(Z.Solana,()=>window.xfi?.solana).with(Z.THORChain,()=>window.xfi?.thorchain).with(Z.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function S({method:J,params:Q,chain:X}){let $=await j(X);return new Promise((D,F)=>{if($&&"request"in $)$.request({method:J,params:Q},(B,Y)=>{B?F(B):D(Y)})})}async function O(J){try{let Q=await j(J);if(!Q)throw new y({errorKey:"wallet_provider_not_found",info:{chain:J,wallet:N.CTRL}});if([Z.Cosmos,Z.Kujira,Z.Noble].includes(J)){let $=await j(Z.Cosmos);if(!$||"request"in $)throw new y({errorKey:"wallet_provider_not_found",info:{chain:J,wallet:N.CTRL}});let D=E[J];await $.enable(D);let F=$.getOfflineSigner(D),[B]=await F.getAccounts();return B?.address}if(b.includes(J)){if("request"in Q&&typeof Q.request==="function")return(await Q.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:$}=await import("ethers"),D=new $(Q,"any"),[F]=await P({method:"eth_requestAccounts",params:[],provider:D});return F}if(J===Z.Solana)return(await(await j(Z.Solana)).connect()).publicKey.toString();if(J===Z.Near){if(!window.xfi?.near)throw new y("wallet_ctrl_not_found",{chain:Z.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await Q.request({method:"request_accounts",params:[]}))[0]}catch(Q){throw new y({errorKey:"wallet_provider_not_found",info:{chain:J,wallet:N.CTRL}})}}async function _({assetValue:J,recipient:Q,memo:X,gasLimit:$},D="transfer"){if(!J)throw new y("wallet_ctrl_asset_not_defined");let F=await O(J.chain),B=[{amount:{amount:J.getBaseValue("number"),decimals:J.decimal},asset:{chain:J.chain,symbol:J.symbol.toUpperCase(),ticker:J.symbol.toUpperCase()},from:F,gasLimit:$,memo:X||"",recipient:Q}];return S({chain:J.chain,method:D,params:B})}var u=x({connect:({addChain:J,walletType:Q,supportedChains:X})=>async function(D){let B=V({chains:D,supportedChains:X,walletType:Q}).map(async(Y)=>{let R=await O(Y),q=await v(Y);J({...q,address:R,chain:Y,walletType:Q})});return await Promise.all(B),!0},name:"connectCtrl",supportedChains:[z.Arbitrum,z.Aurora,z.Avalanche,z.Base,z.Berachain,z.BinanceSmartChain,z.Bitcoin,z.BitcoinCash,z.Cosmos,z.Dogecoin,z.Ethereum,z.Gnosis,z.Kujira,z.Litecoin,z.Maya,z.Near,z.Noble,z.Optimism,z.Polygon,z.Solana,z.THORChain],walletType:W.CTRL}),l=g(u);async function v(J){switch(J){case z.Solana:{let{getSolanaToolbox:Q}=await import("@swapkit/toolboxes/solana"),X=window.xfi?.solana;if(!X)throw new U("wallet_ctrl_not_found");return{...Q({signer:X})}}case z.Maya:case z.THORChain:{let{getCosmosToolbox:Q,THORCHAIN_GAS_VALUE:X,MAYA_GAS_VALUE:$}=await import("@swapkit/toolboxes/cosmos"),D=J===z.Maya?$:X;return{...await Q(J),deposit:(B)=>_({...B,recipient:""},"deposit"),transfer:(B)=>_({...B,gasLimit:D},"transfer")}}case z.Cosmos:case z.Kujira:case z.Noble:{let{getCosmosToolbox:Q}=await import("@swapkit/toolboxes/cosmos"),X=T[J],$=await j(J);await $?.enable(X);let D=$?.getOfflineSignerOnlyAmino(X);if(!D)throw new U("wallet_ctrl_not_found");return Q(J,{signer:D})}case z.Bitcoin:case z.BitcoinCash:case z.Dogecoin:case z.Litecoin:{let{getUtxoToolbox:Q}=await import("@swapkit/toolboxes/utxo");return{...await Q(J),transfer:_}}case z.Arbitrum:case z.Aurora:case z.Avalanche:case z.Base:case z.Berachain:case z.BinanceSmartChain:case z.Ethereum:case z.Gnosis:case z.Optimism:case z.Polygon:{let{prepareNetworkSwitch:Q,switchEVMWalletNetwork:X}=await import("@swapkit/helpers"),{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:D}=await import("ethers"),F=await j(J);if(!F)throw new U("wallet_ctrl_not_found");let B=new D(F,"any"),Y=await B.getSigner(),R=await $(J,{provider:B,signer:Y});try{if(J!==z.Ethereum){let q=R.getNetworkParams();await X(B,J,q)}}catch(q){throw new U({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:J,wallet:W.CTRL}})}return Q({chain:J,provider:B,toolbox:R})}case z.Near:{if(!window.xfi?.near)throw new U("wallet_ctrl_not_found",{chain:z.Near});let{createNearSignerFromProvider:Q}=await import("../../chunk-dtr1yvx8.js"),{getNearToolbox:X}=await import("@swapkit/toolboxes/near"),$=window.xfi.near,D=await Q($,"CTRL"),F=await D.getAddress();return{...await X({signer:D}),createTransaction:async(q)=>{let{functionCall:L,transfer:M}=await import("near-api-js/lib/transaction");if(q.functionCall){let{methodName:I,args:f,attachedDeposit:k}=q.functionCall;return{actions:[L(I,f,BigInt("30000000000000"),BigInt(k||"0"))],receiverId:q.recipient,signerId:F}}let K=q.assetValue.getBaseValue("string");return{actions:[M(BigInt(K))],receiverId:q.recipient,signerId:F}},transfer:async(q)=>{let{transfer:L}=await import("near-api-js/lib/transaction"),M=q.assetValue.getBaseValue("string"),A={actions:[L(BigInt(M))],receiverId:q.recipient,signerId:F};return await $.request({method:"signAndSendTransaction",params:{transaction:A}})}}}default:return null}}export{u as ctrlWallet,l as CTRL_SUPPORTED_CHAINS};
1
+ import{F as l,G as f}from"../../chunk-fxqrst6z.js";import{Chain as o,ChainToChainId as G,filterSupportedChains as H,SwapKitError as T,WalletOption as u}from"@swapkit/helpers";import{createWallet as L,getWalletSupportedChains as I}from"@swapkit/wallet-core";import{Chain as n,ChainToChainId as S,EVMChains as B,providerRequest as p,SwapKitError as x,WalletOption as A}from"@swapkit/helpers";async function _(t){if(!window.xfi)throw new x("wallet_ctrl_not_found");let{match:r}=await import("ts-pattern");return r(t).with(n.Arbitrum,n.Aurora,n.Avalanche,n.Base,n.Berachain,n.BinanceSmartChain,n.Ethereum,n.Gnosis,n.Optimism,n.Polygon,()=>window.xfi?.ethereum).with(n.Cosmos,n.Kujira,n.Noble,()=>window.xfi?.keplr).with(n.Bitcoin,()=>window.xfi?.bitcoin).with(n.BitcoinCash,()=>window.xfi?.bitcoincash).with(n.Dogecoin,()=>window.xfi?.dogecoin).with(n.Litecoin,()=>window.xfi?.litecoin).with(n.Solana,()=>window.xfi?.solana).with(n.THORChain,()=>window.xfi?.thorchain).with(n.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function R({method:t,params:r,chain:a}){let e=await _(a);return new Promise((s,w)=>{if(e&&"request"in e)e.request({method:t,params:r},(c,i)=>{c?w(c):s(i)})})}async function d(t){try{let r=await _(t);if(!r)throw new x({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}});if([n.Cosmos,n.Kujira,n.Noble].includes(t)){let e=await _(n.Cosmos);if(!e||"request"in e)throw new x({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}});let s=S[t];await e.enable(s);let w=e.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(B.includes(t)){if("request"in r&&typeof r.request==="function")return(await r.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:e}=await import("ethers"),s=new e(r,"any"),[w]=await p({method:"eth_requestAccounts",params:[],provider:s});return w}if(t===n.Solana)return(await(await _(n.Solana)).connect()).publicKey.toString();if(t===n.Near){if(!window.xfi?.near)throw new x("wallet_ctrl_not_found",{chain:n.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await r.request({method:"request_accounts",params:[]}))[0]}catch(r){throw new x({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}})}}async function b({assetValue:t,recipient:r,memo:a,gasLimit:e},s="transfer"){if(!t)throw new x("wallet_ctrl_asset_not_defined");let w=await d(t.chain),c=[{amount:{amount:t.getBaseValue("number"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},from:w,gasLimit:e,memo:a||"",recipient:r}];return R({chain:t.chain,method:s,params:c})}var P=L({connect:({addChain:t,walletType:r,supportedChains:a})=>async function(s){let c=H({chains:s,supportedChains:a,walletType:r}).map(async(i)=>{let m=await d(i),g=await O(i);t({...g,address:m,chain:i,walletType:r})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[o.Arbitrum,o.Aurora,o.Avalanche,o.Base,o.Berachain,o.BinanceSmartChain,o.Bitcoin,o.BitcoinCash,o.Cosmos,o.Dogecoin,o.Ethereum,o.Gnosis,o.Kujira,o.Litecoin,o.Maya,o.Near,o.Noble,o.Optimism,o.Polygon,o.Solana,o.THORChain],walletType:u.CTRL}),Y=I(P);async function O(t){switch(t){case o.Solana:{let{getSolanaToolbox:r}=await import("@swapkit/toolboxes/solana"),a=window.xfi?.solana;if(!a)throw new T("wallet_ctrl_not_found");return await r({signer:a})}case o.Maya:case o.THORChain:{let{getCosmosToolbox:r,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:e}=await import("@swapkit/toolboxes/cosmos"),s=t===o.Maya?e:a;return{...await r(t),deposit:(c)=>b({...c,recipient:""},"deposit"),transfer:(c)=>b({...c,gasLimit:s},"transfer")}}case o.Cosmos:case o.Kujira:case o.Noble:{let{getCosmosToolbox:r}=await import("@swapkit/toolboxes/cosmos"),a=G[t],e=await _(t);await e?.enable(a);let s=e?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new T("wallet_ctrl_not_found");return await r(t,{signer:s})}case o.Bitcoin:case o.BitcoinCash:case o.Dogecoin:case o.Litecoin:{let{getUtxoToolbox:r}=await import("@swapkit/toolboxes/utxo");return{...await r(t),transfer:b}}case o.Arbitrum:case o.Aurora:case o.Avalanche:case o.Base:case o.Berachain:case o.BinanceSmartChain:case o.Ethereum:case o.Gnosis:case o.Optimism:case o.Polygon:{let{prepareNetworkSwitch:r,switchEVMWalletNetwork:a}=await import("@swapkit/helpers"),{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=await _(t);if(!w)throw new T("wallet_ctrl_not_found");let c=new s(w,"any"),i=await c.getSigner(),m=await e(t,{provider:c,signer:i});try{if(t!==o.Ethereum){let g=m.getNetworkParams();await a(c,t,g)}}catch(g){throw new T({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:t,wallet:u.CTRL}})}return r({chain:t,provider:c,toolbox:m})}case o.Near:{if(!window.xfi?.near)throw new T("wallet_ctrl_not_found",{chain:o.Near});let{createNearSignerFromProvider:r}=await import("../../chunk-dtr1yvx8.js"),{getNearToolbox:a}=await import("@swapkit/toolboxes/near"),e=window.xfi.near,s=await r(e,"CTRL"),w=await s.getAddress();return{...await a({signer:s}),transfer:async(m)=>{let{transfer:g}=await import("near-api-js/lib/transaction"),y=m.assetValue.getBaseValue("string"),N={actions:[g(BigInt(y))],receiverId:m.recipient,signerId:w};return await e.request({method:"signAndSendTransaction",params:{transaction:N}})}}}default:return null}}export{P as ctrlWallet,Y as CTRL_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=3F0D0386C7833EDA64756E2164756E21
3
+ //# debugId=F17DBBE61A58725664756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -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 filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\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 name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\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(\"@swapkit/toolboxes/cosmos\");\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 case Chain.Noble: {\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.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\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\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: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\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 = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\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(\"near-api-js/lib/transaction\");\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 { actions: [action], receiverId: params.recipient, signerId: accountId };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return { actions: [action], receiverId: params.recipient, signerId: accountId };\n };\n\n return { ...toolbox, createTransaction, transfer };\n }\n\n default:\n return null;\n }\n}\n",
5
+ "import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\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 name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\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 = await 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(\"@swapkit/toolboxes/cosmos\");\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 case Chain.Noble: {\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, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await 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.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\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\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: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\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 const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n const transaction = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\n\n return txHash;\n };\n\n return { ...toolbox, transfer };\n }\n\n default:\n return null;\n }\n}\n",
6
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 providerRequest,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { 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 | Chain.Noble\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.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => 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-expect-error\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({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\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({ method: \"eth_requestAccounts\", params: [], provider });\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[]>?.({ method: \"connect\" });\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({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\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: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "3F0D0386C7833EDA64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "F17DBBE61A58725664756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var E={};j(E,{waitForTronLink:()=>q,verifyNetwork:()=>Y,tronlinkWallet:()=>$,setupEventListeners:()=>G,isTronLinkLocked:()=>X,getWalletForChain:()=>z,getExpectedTronNetwork:()=>Q,TronLinkResponseCode:()=>Z,TRONLINK_SUPPORTED_CHAINS:()=>y});module.exports=A(E);var I=require("@swapkit/helpers"),B=require("@swapkit/wallet-core");var b=require("@swapkit/helpers"),V=require("@swapkit/toolboxes/tron");var Z;((g)=>{g[g.SUCCESS=200]="SUCCESS";g[g.LOCKED=4000]="LOCKED";g[g.REJECTED=4001]="REJECTED";g[g.UNAUTHORIZED=4100]="UNAUTHORIZED";g[g.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";g[g.DISCONNECTED=4900]="DISCONNECTED";g[g.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(Z||={});function q(D=3000){return new Promise((m,U)=>{let P=!1,f=()=>{if(P)return;if(P=!0,window.removeEventListener("tronlink#initialized",f),_)clearTimeout(_);if(window.tronLink)m(window.tronLink);else U(new b.SwapKitError("wallet_provider_not_found",{wallet:b.WalletOption.TRONLINK}))};if(window.tronLink){m(window.tronLink);return}window.addEventListener("tronlink#initialized",f,{once:!0});let _=setTimeout(f,D)})}async function X(){try{let D=await q(1000),m=Boolean(D.tronWeb?.defaultAddress?.base58),U=D.ready===!1,P=Boolean(D.tronWeb&&typeof D.tronWeb.trx==="object"&&typeof D.tronWeb.trx.sign==="function");return!m&&(U||!P)}catch{return!1}}function S(D){let m=D;if(m.code===4000||m.code===4000)throw new b.SwapKitError("wallet_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:b.WalletOption.TRONLINK});if(m.code===4001||m.code===4001)throw new b.SwapKitError("wallet_connection_rejected_by_user");if(m.code===4100||m.code===4100)throw new b.SwapKitError("wallet_connection_rejected_by_user",{message:"Unauthorized: Please authorize the connection in TronLink"});throw new b.SwapKitError("wallet_provider_not_found",{message:m.message||"Failed to connect to TronLink",wallet:b.WalletOption.TRONLINK})}async function x(D){try{let m=await D.request({method:"tron_requestAccounts"});if(m.code===4000)throw new b.SwapKitError("wallet_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:b.WalletOption.TRONLINK});if(m.code!==200)throw Error(`TronLink error: ${m.message}`)}catch(m){S(m)}}async function z(D,m){if(D!==b.Chain.Tron)throw new b.SwapKitError("wallet_chain_not_supported",{chain:D,wallet:b.WalletOption.TRONLINK});let U=await q(),P=await X();!P&&await x(U);let f=U.tronWeb?.defaultAddress?.base58;if(!f){if(P)throw new b.SwapKitError("wallet_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:b.WalletOption.TRONLINK});throw new b.SwapKitError("wallet_provider_not_found",{message:"No account found in TronLink",wallet:b.WalletOption.TRONLINK})}if(m)Y(m);return{...await V.createTronToolbox({signer:{getAddress:async()=>f,signTransaction:async(g)=>{return await U.tronWeb.trx.sign(g)}}}),address:f}}function G(D,m){let U=(P)=>{if(P.data?.message?.action==="setAccount"){let f=P.data.message.data.address;if(D)D(f);else window.location.reload()}if(P.data?.message?.action==="setNode"){let f=P.data.message.data.node;if(m)m(f.fullNode);else window.location.reload()}};return window.addEventListener("message",U),()=>window.removeEventListener("message",U)}function Y(D){let m=window.tronLink;if(!m)throw new b.SwapKitError("wallet_provider_not_found",{wallet:b.WalletOption.TRONLINK});let U=m.tronWeb.fullNode?.host;if(U&&!U.includes(D))throw new b.SwapKitError("wallet_failed_to_add_or_switch_network",{currentNetwork:U,expectedNetwork:D,message:`Wrong network. Please switch to ${D} in TronLink.`,wallet:b.WalletOption.TRONLINK})}function Q(D=!1){return D?"shasta":"api.trongrid.io"}var $=B.createWallet({connect:({addChain:D,supportedChains:m,walletType:U})=>async function(f){if(I.filterSupportedChains({chains:f,supportedChains:m,walletType:U}).length===0)throw Error("TronLink wallet only supports Tron chain");let H=Q(!1),g=await z(I.Chain.Tron,H),M=g.address,F=G((J)=>{if(J!==M)window.location.reload()},(J)=>{if(!J.includes(H))window.location.reload()}),O=()=>{F()};return D({...g,balance:[],chain:I.Chain.Tron,disconnect:O,walletType:U}),!0},name:"connectTronLink",supportedChains:[I.Chain.Tron],walletType:I.WalletOption.TRONLINK}),y=B.getWalletSupportedChains($);
1
+ var A={};x(A,{waitForTronLink:()=>f,verifyNetwork:()=>k,tronlinkWallet:()=>L,setupEventListeners:()=>T,isTronLinkLocked:()=>h,getWalletForChain:()=>g,getExpectedTronNetwork:()=>m,TronLinkResponseCode:()=>u,TRONLINK_SUPPORTED_CHAINS:()=>y});module.exports=b(A);var c=require("@swapkit/helpers"),d=require("@swapkit/wallet-core");var r=require("@swapkit/helpers"),p=require("@swapkit/toolboxes/tron");var u;((e)=>{e[e.SUCCESS=200]="SUCCESS";e[e.LOCKED=4000]="LOCKED";e[e.REJECTED=4001]="REJECTED";e[e.UNAUTHORIZED=4100]="UNAUTHORIZED";e[e.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";e[e.DISCONNECTED=4900]="DISCONNECTED";e[e.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(u||={});function f(n=3000){return new Promise((t,o)=>{let i=!1,s=()=>{if(i)return;if(i=!0,window.removeEventListener("tronlink#initialized",s),a)clearTimeout(a);if(window.tronLink)t(window.tronLink);else o(new r.SwapKitError("wallet_provider_not_found",{wallet:r.WalletOption.TRONLINK}))};if(window.tronLink){t(window.tronLink);return}window.addEventListener("tronlink#initialized",s,{once:!0});let a=setTimeout(s,n)})}async function h(){try{let n=await f(1000),t=Boolean(n.tronWeb?.defaultAddress?.base58),o=n.ready!==!1,i=Boolean(n.tronWeb&&typeof n.tronWeb.trx==="object"&&typeof n.tronWeb.trx.sign==="function");return!t&&(!o||!i)}catch{return!1}}async function _(n){let t=await n.request({method:"tron_requestAccounts"});if(t==="")throw new r.SwapKitError("wallet_tronlink_locked",{message:"TronLink is locked. Please unlock it to continue."});if(t.code!==200)throw new r.SwapKitError("wallet_tronlink_request_accounts_failed",{code:t.code,message:`TronLink requestAccounts failed: ${t.message}`})}async function g(n,t){if(n!==r.Chain.Tron)throw new r.SwapKitError("wallet_chain_not_supported",{chain:n,wallet:r.WalletOption.TRONLINK});let o=await f();await h()&&await _(o);let s=o.tronWeb?.defaultAddress?.base58;if(t)k(t);return{...await p.createTronToolbox({signer:{getAddress:async()=>s,signTransaction:async(e)=>{return await o.tronWeb.trx.sign(e)}}}),address:s}}function T(n,t){let o=(i)=>{switch(i.data?.message?.action){case"setAccount":{let a=i.data.message.data.address;if(n){n(a);return}window.location.reload();return}case"setNode":{let a=i.data.message.data.node;if(t)t(a.fullNode);window.location.reload();return}default:return}};return window.addEventListener("message",o),()=>window.removeEventListener("message",o)}function k(n){let t=window.tronLink;if(!t)throw new r.SwapKitError("wallet_provider_not_found",{wallet:r.WalletOption.TRONLINK});let o=t.tronWeb.fullNode?.host;if(o&&!o.includes(n))throw new r.SwapKitError("wallet_failed_to_add_or_switch_network",{currentNetwork:o,expectedNetwork:n,message:`Wrong network. Please switch to ${n} in TronLink.`,wallet:r.WalletOption.TRONLINK})}function m(n=!1){return n?"shasta":"api.trongrid.io"}var L=d.createWallet({connect:({addChain:n,supportedChains:t,walletType:o})=>async function(s){if(c.filterSupportedChains({chains:s,supportedChains:t,walletType:o}).length===0)throw Error("TronLink wallet only supports Tron chain");let l=m(!1),e=await g(c.Chain.Tron,l),N=e.address,W=T((w)=>{if(w!==N)window.location.reload()},(w)=>{if(!w.includes(l))window.location.reload()}),E=()=>{W()};return n({...e,balance:[],chain:c.Chain.Tron,disconnect:E,walletType:o}),!0},name:"connectTronLink",supportedChains:[c.Chain.Tron],walletType:c.WalletOption.TRONLINK}),y=d.getWalletSupportedChains(L);
2
2
 
3
- //# debugId=5FEF9FF15A2946EF64756E2164756E21
3
+ //# debugId=1985151510998BD964756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,11 +2,11 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
4
4
  "sourcesContent": [
5
- "import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n // Store original address for comparison in event listeners\n const currentAddress = walletMethods.address;\n\n // Setup event listeners for account/network changes\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n // Handle account change - reload to refresh connection\n window.location.reload();\n }\n },\n (newNetwork) => {\n // Handle network change - reload to refresh connection\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n // Create disconnect function that cleans up event listeners\n const disconnect = () => {\n cleanup();\n };\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Tron, disconnect, walletType });\n\n return true;\n },\n name: \"connectTronLink\",\n supportedChains: [Chain.Tron],\n walletType: WalletOption.TRONLINK,\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./helpers.js\";\nexport * from \"./types.js\";\n",
6
- "import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createTronToolbox, type TronSigner, type TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { TronLinkError, TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK }));\n }\n };\n\n // Check if already available\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n // Listen for the initialization event\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n // Fallback timeout\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\n/**\n * Helper function to check if TronLink wallet is locked\n * Returns true if wallet is locked, false if unlocked\n */\nexport async function isTronLinkLocked(): Promise<boolean> {\n try {\n const tronLink = await waitForTronLink(1000); // Shorter timeout for lock check\n\n // Check multiple indicators for locked state:\n // 1. No default address is the most reliable indicator\n const hasDefaultAddress = Boolean(tronLink.tronWeb?.defaultAddress?.base58);\n\n // 2. ready property explicitly false (not undefined)\n // Note: In some versions, ready might be undefined when unlocked, so only check for explicit false\n const isReadyFalse = tronLink.ready === false;\n\n // 3. tronWeb object completeness check\n const hasTronWeb = Boolean(\n tronLink.tronWeb && typeof tronLink.tronWeb.trx === \"object\" && typeof tronLink.tronWeb.trx.sign === \"function\",\n );\n\n // Wallet is locked if:\n // - No default address AND (ready is false OR tronWeb is incomplete)\n // - This avoids false positives when the wallet is just initializing\n return !hasDefaultAddress && (isReadyFalse || !hasTronWeb);\n } catch {\n // If we can't even get TronLink, it's not available (not necessarily locked)\n return false;\n }\n}\n\n/**\n * Helper function to handle TronLink error responses\n */\nfunction handleTronLinkError(error: TronLinkError | Error): never {\n const tronError = error as TronLinkError;\n\n // Check if the error code indicates locked wallet\n if (tronError.code === TronLinkResponseCode.LOCKED || tronError.code === 4000) {\n throw new SwapKitError(\"wallet_locked\", {\n message: \"TronLink is locked. Please unlock it to continue.\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n // Handle rejection\n if (tronError.code === TronLinkResponseCode.REJECTED || tronError.code === 4001) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\");\n }\n\n // Handle unauthorized\n if (tronError.code === TronLinkResponseCode.UNAUTHORIZED || tronError.code === 4100) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", {\n message: \"Unauthorized: Please authorize the connection in TronLink\",\n });\n }\n\n // Generic connection error\n throw new SwapKitError(\"wallet_provider_not_found\", {\n message: tronError.message || \"Failed to connect to TronLink\",\n wallet: WalletOption.TRONLINK,\n });\n}\n\n/**\n * Helper function to request TronLink accounts\n */\nasync function requestTronLinkAccounts(tronLink: TronLinkWindow): Promise<void> {\n try {\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n // Check response code for locked state\n if (response.code === TronLinkResponseCode.LOCKED) {\n throw new SwapKitError(\"wallet_locked\", {\n message: \"TronLink is locked. Please unlock it to continue.\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new Error(`TronLink error: ${response.message}`);\n }\n } catch (error: unknown) {\n handleTronLinkError(error as TronLinkError);\n }\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new SwapKitError(\"wallet_chain_not_supported\", { chain, wallet: WalletOption.TRONLINK });\n }\n\n const tronLink = await waitForTronLink();\n\n // Check if wallet is potentially locked\n const isLocked = await isTronLinkLocked();\n\n // Always request accounts - this will trigger unlock prompt if needed\n !isLocked && (await requestTronLinkAccounts(tronLink));\n\n // After successful account request, verify connection\n const address = tronLink.tronWeb?.defaultAddress?.base58;\n\n if (!address) {\n // If still no address after successful request, wallet might be locked\n if (isLocked) {\n throw new SwapKitError(\"wallet_locked\", {\n message: \"TronLink is locked. Please unlock it to continue.\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n throw new SwapKitError(\"wallet_provider_not_found\", {\n message: \"No account found in TronLink\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n // Verify network if required\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n // Create signer object\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n // Create toolbox with signer\n const toolbox = await createTronToolbox({ signer });\n\n // Return wallet methods\n return { ...toolbox, address };\n}\n\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n): () => void {\n const messageHandler = (event: MessageEvent) => {\n if (event.data?.message?.action === \"setAccount\") {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n } else {\n // Default behavior: reload the page\n window.location.reload();\n }\n }\n\n if (event.data?.message?.action === \"setNode\") {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n } else {\n // Default behavior: reload the page on network change\n window.location.reload();\n }\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n // Return cleanup function\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new SwapKitError(\"wallet_failed_to_add_or_switch_network\", {\n currentNetwork: currentNode,\n expectedNetwork,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n wallet: WalletOption.TRONLINK,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
7
- "import type { TronSignedTransaction, TronTransaction } from \"@swapkit/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse>;\n tronWeb: {\n defaultAddress: { base58: string; hex: string };\n fullNode?: { host: string };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: { address: string };\n setNode: { node: { chain: string; fullNode: string } };\n}\n\nexport interface TronLinkError extends Error {\n code: number;\n data?: unknown;\n}\n"
5
+ "import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n const currentAddress = walletMethods.address;\n\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n window.location.reload();\n }\n },\n (newNetwork) => {\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n const disconnect = () => {\n cleanup();\n };\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Tron, disconnect, walletType });\n\n return true;\n },\n name: \"connectTronLink\",\n supportedChains: [Chain.Tron],\n walletType: WalletOption.TRONLINK,\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./helpers.js\";\nexport * from \"./types.js\";\n",
6
+ "import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createTronToolbox, type TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK }));\n }\n };\n\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\nexport async function isTronLinkLocked() {\n try {\n const tronLink = await waitForTronLink(1000);\n\n const hasDefaultAddress = Boolean(tronLink.tronWeb?.defaultAddress?.base58);\n\n const isReady = tronLink.ready !== false;\n\n const hasTronWeb = Boolean(\n tronLink.tronWeb && typeof tronLink.tronWeb.trx === \"object\" && typeof tronLink.tronWeb.trx.sign === \"function\",\n );\n\n return !hasDefaultAddress && (!isReady || !hasTronWeb);\n } catch {\n return false;\n }\n}\n\nasync function requestTronLinkAccounts(tronLink: TronLinkWindow) {\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n if (response === \"\") {\n throw new SwapKitError(\"wallet_tronlink_locked\", { message: \"TronLink is locked. Please unlock it to continue.\" });\n }\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new SwapKitError(\"wallet_tronlink_request_accounts_failed\", {\n code: response.code,\n message: `TronLink requestAccounts failed: ${response.message}`,\n });\n }\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new SwapKitError(\"wallet_chain_not_supported\", { chain, wallet: WalletOption.TRONLINK });\n }\n\n const tronLink = await waitForTronLink();\n const isLocked = await isTronLinkLocked();\n\n isLocked && (await requestTronLinkAccounts(tronLink));\n\n const address = tronLink.tronWeb?.defaultAddress?.base58;\n\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n const signer = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n}\n\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n) {\n const messageHandler = (event: MessageEvent) => {\n const eventDataAction = event.data?.message?.action;\n\n switch (eventDataAction) {\n case \"setAccount\": {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n return;\n }\n window.location.reload();\n return;\n }\n case \"setNode\": {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n }\n window.location.reload();\n return;\n }\n default:\n return;\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new SwapKitError(\"wallet_failed_to_add_or_switch_network\", {\n currentNetwork: currentNode,\n expectedNetwork,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n wallet: WalletOption.TRONLINK,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
7
+ "import type { TronSignedTransaction, TronTransaction } from \"@swapkit/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse | \"\">;\n tronWeb: {\n defaultAddress: { base58: string; hex: string };\n fullNode?: { host: string };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: { address: string };\n setNode: { node: { chain: string; fullNode: string } };\n}\n"
8
8
  ],
9
- "mappings": "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",
10
- "debugId": "5FEF9FF15A2946EF64756E2164756E21",
9
+ "mappings": "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",
10
+ "debugId": "1985151510998BD964756E2164756E21",
11
11
  "names": []
12
12
  }
@@ -1,4 +1,4 @@
1
- import"../../chunk-fxqrst6z.js";import{Chain as J,filterSupportedChains as A,WalletOption as j}from"@swapkit/helpers";import{createWallet as y,getWalletSupportedChains as E}from"@swapkit/wallet-core";import{Chain as $,SwapKitError as f,WalletOption as I}from"@swapkit/helpers";import{createTronToolbox as M}from"@swapkit/toolboxes/tron";var Z;((b)=>{b[b.SUCCESS=200]="SUCCESS";b[b.LOCKED=4000]="LOCKED";b[b.REJECTED=4001]="REJECTED";b[b.UNAUTHORIZED=4100]="UNAUTHORIZED";b[b.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";b[b.DISCONNECTED=4900]="DISCONNECTED";b[b.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(Z||={});function q(D=3000){return new Promise((m,g)=>{let U=!1,P=()=>{if(U)return;if(U=!0,window.removeEventListener("tronlink#initialized",P),_)clearTimeout(_);if(window.tronLink)m(window.tronLink);else g(new f("wallet_provider_not_found",{wallet:I.TRONLINK}))};if(window.tronLink){m(window.tronLink);return}window.addEventListener("tronlink#initialized",P,{once:!0});let _=setTimeout(P,D)})}async function F(){try{let D=await q(1000),m=Boolean(D.tronWeb?.defaultAddress?.base58),g=D.ready===!1,U=Boolean(D.tronWeb&&typeof D.tronWeb.trx==="object"&&typeof D.tronWeb.trx.sign==="function");return!m&&(g||!U)}catch{return!1}}function O(D){let m=D;if(m.code===4000||m.code===4000)throw new f("wallet_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:I.TRONLINK});if(m.code===4001||m.code===4001)throw new f("wallet_connection_rejected_by_user");if(m.code===4100||m.code===4100)throw new f("wallet_connection_rejected_by_user",{message:"Unauthorized: Please authorize the connection in TronLink"});throw new f("wallet_provider_not_found",{message:m.message||"Failed to connect to TronLink",wallet:I.TRONLINK})}async function S(D){try{let m=await D.request({method:"tron_requestAccounts"});if(m.code===4000)throw new f("wallet_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:I.TRONLINK});if(m.code!==200)throw Error(`TronLink error: ${m.message}`)}catch(m){O(m)}}async function z(D,m){if(D!==$.Tron)throw new f("wallet_chain_not_supported",{chain:D,wallet:I.TRONLINK});let g=await q(),U=await F();!U&&await S(g);let P=g.tronWeb?.defaultAddress?.base58;if(!P){if(U)throw new f("wallet_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:I.TRONLINK});throw new f("wallet_provider_not_found",{message:"No account found in TronLink",wallet:I.TRONLINK})}if(m)x(m);return{...await M({signer:{getAddress:async()=>P,signTransaction:async(b)=>{return await g.tronWeb.trx.sign(b)}}}),address:P}}function G(D,m){let g=(U)=>{if(U.data?.message?.action==="setAccount"){let P=U.data.message.data.address;if(D)D(P);else window.location.reload()}if(U.data?.message?.action==="setNode"){let P=U.data.message.data.node;if(m)m(P.fullNode);else window.location.reload()}};return window.addEventListener("message",g),()=>window.removeEventListener("message",g)}function x(D){let m=window.tronLink;if(!m)throw new f("wallet_provider_not_found",{wallet:I.TRONLINK});let g=m.tronWeb.fullNode?.host;if(g&&!g.includes(D))throw new f("wallet_failed_to_add_or_switch_network",{currentNetwork:g,expectedNetwork:D,message:`Wrong network. Please switch to ${D} in TronLink.`,wallet:I.TRONLINK})}function Q(D=!1){return D?"shasta":"api.trongrid.io"}var T=y({connect:({addChain:D,supportedChains:m,walletType:g})=>async function(P){if(A({chains:P,supportedChains:m,walletType:g}).length===0)throw Error("TronLink wallet only supports Tron chain");let B=Q(!1),b=await z(J.Tron,B),V=b.address,X=G((H)=>{if(H!==V)window.location.reload()},(H)=>{if(!H.includes(B))window.location.reload()}),Y=()=>{X()};return D({...b,balance:[],chain:J.Tron,disconnect:Y,walletType:g}),!0},name:"connectTronLink",supportedChains:[J.Tron],walletType:j.TRONLINK}),c=E(T);export{q as waitForTronLink,x as verifyNetwork,T as tronlinkWallet,G as setupEventListeners,F as isTronLinkLocked,z as getWalletForChain,Q as getExpectedTronNetwork,Z as TronLinkResponseCode,c as TRONLINK_SUPPORTED_CHAINS};
1
+ import"../../chunk-fxqrst6z.js";import{Chain as w,filterSupportedChains as b,WalletOption as x}from"@swapkit/helpers";import{createWallet as y,getWalletSupportedChains as A}from"@swapkit/wallet-core";import{Chain as L,SwapKitError as a,WalletOption as c}from"@swapkit/helpers";import{createTronToolbox as N}from"@swapkit/toolboxes/tron";var u;((e)=>{e[e.SUCCESS=200]="SUCCESS";e[e.LOCKED=4000]="LOCKED";e[e.REJECTED=4001]="REJECTED";e[e.UNAUTHORIZED=4100]="UNAUTHORIZED";e[e.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";e[e.DISCONNECTED=4900]="DISCONNECTED";e[e.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(u||={});function f(n=3000){return new Promise((t,o)=>{let r=!1,i=()=>{if(r)return;if(r=!0,window.removeEventListener("tronlink#initialized",i),s)clearTimeout(s);if(window.tronLink)t(window.tronLink);else o(new a("wallet_provider_not_found",{wallet:c.TRONLINK}))};if(window.tronLink){t(window.tronLink);return}window.addEventListener("tronlink#initialized",i,{once:!0});let s=setTimeout(i,n)})}async function W(){try{let n=await f(1000),t=Boolean(n.tronWeb?.defaultAddress?.base58),o=n.ready!==!1,r=Boolean(n.tronWeb&&typeof n.tronWeb.trx==="object"&&typeof n.tronWeb.trx.sign==="function");return!t&&(!o||!r)}catch{return!1}}async function E(n){let t=await n.request({method:"tron_requestAccounts"});if(t==="")throw new a("wallet_tronlink_locked",{message:"TronLink is locked. Please unlock it to continue."});if(t.code!==200)throw new a("wallet_tronlink_request_accounts_failed",{code:t.code,message:`TronLink requestAccounts failed: ${t.message}`})}async function g(n,t){if(n!==L.Tron)throw new a("wallet_chain_not_supported",{chain:n,wallet:c.TRONLINK});let o=await f();await W()&&await E(o);let i=o.tronWeb?.defaultAddress?.base58;if(t)_(t);return{...await N({signer:{getAddress:async()=>i,signTransaction:async(e)=>{return await o.tronWeb.trx.sign(e)}}}),address:i}}function T(n,t){let o=(r)=>{switch(r.data?.message?.action){case"setAccount":{let s=r.data.message.data.address;if(n){n(s);return}window.location.reload();return}case"setNode":{let s=r.data.message.data.node;if(t)t(s.fullNode);window.location.reload();return}default:return}};return window.addEventListener("message",o),()=>window.removeEventListener("message",o)}function _(n){let t=window.tronLink;if(!t)throw new a("wallet_provider_not_found",{wallet:c.TRONLINK});let o=t.tronWeb.fullNode?.host;if(o&&!o.includes(n))throw new a("wallet_failed_to_add_or_switch_network",{currentNetwork:o,expectedNetwork:n,message:`Wrong network. Please switch to ${n} in TronLink.`,wallet:c.TRONLINK})}function m(n=!1){return n?"shasta":"api.trongrid.io"}var S=y({connect:({addChain:n,supportedChains:t,walletType:o})=>async function(i){if(b({chains:i,supportedChains:t,walletType:o}).length===0)throw Error("TronLink wallet only supports Tron chain");let d=m(!1),e=await g(w.Tron,d),p=e.address,h=T((l)=>{if(l!==p)window.location.reload()},(l)=>{if(!l.includes(d))window.location.reload()}),k=()=>{h()};return n({...e,balance:[],chain:w.Tron,disconnect:k,walletType:o}),!0},name:"connectTronLink",supportedChains:[w.Tron],walletType:x.TRONLINK}),q=A(S);export{f as waitForTronLink,_ as verifyNetwork,S as tronlinkWallet,T as setupEventListeners,W as isTronLinkLocked,g as getWalletForChain,m as getExpectedTronNetwork,u as TronLinkResponseCode,q as TRONLINK_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=1AA3A956BE22732D64756E2164756E21
3
+ //# debugId=74D55119FBB869FD64756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,11 +2,11 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
4
4
  "sourcesContent": [
5
- "import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n // Store original address for comparison in event listeners\n const currentAddress = walletMethods.address;\n\n // Setup event listeners for account/network changes\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n // Handle account change - reload to refresh connection\n window.location.reload();\n }\n },\n (newNetwork) => {\n // Handle network change - reload to refresh connection\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n // Create disconnect function that cleans up event listeners\n const disconnect = () => {\n cleanup();\n };\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Tron, disconnect, walletType });\n\n return true;\n },\n name: \"connectTronLink\",\n supportedChains: [Chain.Tron],\n walletType: WalletOption.TRONLINK,\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./helpers.js\";\nexport * from \"./types.js\";\n",
6
- "import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createTronToolbox, type TronSigner, type TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { TronLinkError, TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK }));\n }\n };\n\n // Check if already available\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n // Listen for the initialization event\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n // Fallback timeout\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\n/**\n * Helper function to check if TronLink wallet is locked\n * Returns true if wallet is locked, false if unlocked\n */\nexport async function isTronLinkLocked(): Promise<boolean> {\n try {\n const tronLink = await waitForTronLink(1000); // Shorter timeout for lock check\n\n // Check multiple indicators for locked state:\n // 1. No default address is the most reliable indicator\n const hasDefaultAddress = Boolean(tronLink.tronWeb?.defaultAddress?.base58);\n\n // 2. ready property explicitly false (not undefined)\n // Note: In some versions, ready might be undefined when unlocked, so only check for explicit false\n const isReadyFalse = tronLink.ready === false;\n\n // 3. tronWeb object completeness check\n const hasTronWeb = Boolean(\n tronLink.tronWeb && typeof tronLink.tronWeb.trx === \"object\" && typeof tronLink.tronWeb.trx.sign === \"function\",\n );\n\n // Wallet is locked if:\n // - No default address AND (ready is false OR tronWeb is incomplete)\n // - This avoids false positives when the wallet is just initializing\n return !hasDefaultAddress && (isReadyFalse || !hasTronWeb);\n } catch {\n // If we can't even get TronLink, it's not available (not necessarily locked)\n return false;\n }\n}\n\n/**\n * Helper function to handle TronLink error responses\n */\nfunction handleTronLinkError(error: TronLinkError | Error): never {\n const tronError = error as TronLinkError;\n\n // Check if the error code indicates locked wallet\n if (tronError.code === TronLinkResponseCode.LOCKED || tronError.code === 4000) {\n throw new SwapKitError(\"wallet_locked\", {\n message: \"TronLink is locked. Please unlock it to continue.\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n // Handle rejection\n if (tronError.code === TronLinkResponseCode.REJECTED || tronError.code === 4001) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\");\n }\n\n // Handle unauthorized\n if (tronError.code === TronLinkResponseCode.UNAUTHORIZED || tronError.code === 4100) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", {\n message: \"Unauthorized: Please authorize the connection in TronLink\",\n });\n }\n\n // Generic connection error\n throw new SwapKitError(\"wallet_provider_not_found\", {\n message: tronError.message || \"Failed to connect to TronLink\",\n wallet: WalletOption.TRONLINK,\n });\n}\n\n/**\n * Helper function to request TronLink accounts\n */\nasync function requestTronLinkAccounts(tronLink: TronLinkWindow): Promise<void> {\n try {\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n // Check response code for locked state\n if (response.code === TronLinkResponseCode.LOCKED) {\n throw new SwapKitError(\"wallet_locked\", {\n message: \"TronLink is locked. Please unlock it to continue.\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new Error(`TronLink error: ${response.message}`);\n }\n } catch (error: unknown) {\n handleTronLinkError(error as TronLinkError);\n }\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new SwapKitError(\"wallet_chain_not_supported\", { chain, wallet: WalletOption.TRONLINK });\n }\n\n const tronLink = await waitForTronLink();\n\n // Check if wallet is potentially locked\n const isLocked = await isTronLinkLocked();\n\n // Always request accounts - this will trigger unlock prompt if needed\n !isLocked && (await requestTronLinkAccounts(tronLink));\n\n // After successful account request, verify connection\n const address = tronLink.tronWeb?.defaultAddress?.base58;\n\n if (!address) {\n // If still no address after successful request, wallet might be locked\n if (isLocked) {\n throw new SwapKitError(\"wallet_locked\", {\n message: \"TronLink is locked. Please unlock it to continue.\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n throw new SwapKitError(\"wallet_provider_not_found\", {\n message: \"No account found in TronLink\",\n wallet: WalletOption.TRONLINK,\n });\n }\n\n // Verify network if required\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n // Create signer object\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n // Create toolbox with signer\n const toolbox = await createTronToolbox({ signer });\n\n // Return wallet methods\n return { ...toolbox, address };\n}\n\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n): () => void {\n const messageHandler = (event: MessageEvent) => {\n if (event.data?.message?.action === \"setAccount\") {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n } else {\n // Default behavior: reload the page\n window.location.reload();\n }\n }\n\n if (event.data?.message?.action === \"setNode\") {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n } else {\n // Default behavior: reload the page on network change\n window.location.reload();\n }\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n // Return cleanup function\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new SwapKitError(\"wallet_failed_to_add_or_switch_network\", {\n currentNetwork: currentNode,\n expectedNetwork,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n wallet: WalletOption.TRONLINK,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
7
- "import type { TronSignedTransaction, TronTransaction } from \"@swapkit/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse>;\n tronWeb: {\n defaultAddress: { base58: string; hex: string };\n fullNode?: { host: string };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: { address: string };\n setNode: { node: { chain: string; fullNode: string } };\n}\n\nexport interface TronLinkError extends Error {\n code: number;\n data?: unknown;\n}\n"
5
+ "import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n const currentAddress = walletMethods.address;\n\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n window.location.reload();\n }\n },\n (newNetwork) => {\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n const disconnect = () => {\n cleanup();\n };\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Tron, disconnect, walletType });\n\n return true;\n },\n name: \"connectTronLink\",\n supportedChains: [Chain.Tron],\n walletType: WalletOption.TRONLINK,\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./helpers.js\";\nexport * from \"./types.js\";\n",
6
+ "import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createTronToolbox, type TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport type { TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK }));\n }\n };\n\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\nexport async function isTronLinkLocked() {\n try {\n const tronLink = await waitForTronLink(1000);\n\n const hasDefaultAddress = Boolean(tronLink.tronWeb?.defaultAddress?.base58);\n\n const isReady = tronLink.ready !== false;\n\n const hasTronWeb = Boolean(\n tronLink.tronWeb && typeof tronLink.tronWeb.trx === \"object\" && typeof tronLink.tronWeb.trx.sign === \"function\",\n );\n\n return !hasDefaultAddress && (!isReady || !hasTronWeb);\n } catch {\n return false;\n }\n}\n\nasync function requestTronLinkAccounts(tronLink: TronLinkWindow) {\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n if (response === \"\") {\n throw new SwapKitError(\"wallet_tronlink_locked\", { message: \"TronLink is locked. Please unlock it to continue.\" });\n }\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new SwapKitError(\"wallet_tronlink_request_accounts_failed\", {\n code: response.code,\n message: `TronLink requestAccounts failed: ${response.message}`,\n });\n }\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new SwapKitError(\"wallet_chain_not_supported\", { chain, wallet: WalletOption.TRONLINK });\n }\n\n const tronLink = await waitForTronLink();\n const isLocked = await isTronLinkLocked();\n\n isLocked && (await requestTronLinkAccounts(tronLink));\n\n const address = tronLink.tronWeb?.defaultAddress?.base58;\n\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n const signer = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n}\n\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n) {\n const messageHandler = (event: MessageEvent) => {\n const eventDataAction = event.data?.message?.action;\n\n switch (eventDataAction) {\n case \"setAccount\": {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n return;\n }\n window.location.reload();\n return;\n }\n case \"setNode\": {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n }\n window.location.reload();\n return;\n }\n default:\n return;\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new SwapKitError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new SwapKitError(\"wallet_failed_to_add_or_switch_network\", {\n currentNetwork: currentNode,\n expectedNetwork,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n wallet: WalletOption.TRONLINK,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
7
+ "import type { TronSignedTransaction, TronTransaction } from \"@swapkit/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse | \"\">;\n tronWeb: {\n defaultAddress: { base58: string; hex: string };\n fullNode?: { host: string };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: { address: string };\n setNode: { node: { chain: string; fullNode: string } };\n}\n"
8
8
  ],
9
- "mappings": "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",
10
- "debugId": "1AA3A956BE22732D64756E2164756E21",
9
+ "mappings": "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",
10
+ "debugId": "74D55119FBB869FD64756E2164756E21",
11
11
  "names": []
12
12
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ctrl/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EAMN,MAAM,kBAAkB,CAAC;AAM1B,eAAO,MAAM,UAAU;;;;;;;CAyCrB,CAAC;AAEH,eAAO,MAAM,qBAAqB,4VAAuC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ctrl/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EAMN,MAAM,kBAAkB,CAAC;AAK1B,eAAO,MAAM,UAAU;;;;;;;CAyCrB,CAAC;AAEH,eAAO,MAAM,qBAAqB,4VAAuC,CAAC"}
@@ -2,10 +2,6 @@ import { Chain } from "@swapkit/helpers";
2
2
  import { type TronTransaction } from "@swapkit/toolboxes/tron";
3
3
  import type { TronLinkWindow } from "./types.js";
4
4
  export declare function waitForTronLink(timeout?: number): Promise<TronLinkWindow>;
5
- /**
6
- * Helper function to check if TronLink wallet is locked
7
- * Returns true if wallet is locked, false if unlocked
8
- */
9
5
  export declare function isTronLinkLocked(): Promise<boolean>;
10
6
  export declare function getWalletForChain(chain: Chain, expectedNetwork?: string): Promise<{
11
7
  address: string;
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/tronlink/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAA8B,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAsC,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AACnG,OAAO,KAAK,EAAiB,cAAc,EAAE,MAAM,YAAY,CAAC;AAGhE,wBAAgB,eAAe,CAAC,OAAO,SAAO,GAAG,OAAO,CAAC,cAAc,CAAC,CA6BvE;AAED;;;GAGG;AACH,wBAAsB,gBAAgB,IAAI,OAAO,CAAC,OAAO,CAAC,CAyBzD;AA0DD,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM;;;;;;;;cA/FxD,CAAC;;;;;;;;GAgJtB;AAED,wBAAgB,mBAAmB,CACjC,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,EAC3C,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,GAC1C,MAAM,IAAI,CA2BZ;AAED,wBAAgB,aAAa,CAAC,eAAe,EAAE,MAAM,QAepD;AAED,wBAAgB,sBAAsB,CAAC,OAAO,UAAQ,GAAG,MAAM,CAE9D"}
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/tronlink/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAA8B,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAqB,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAClF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAGjD,wBAAgB,eAAe,CAAC,OAAO,SAAO,GAAG,OAAO,CAAC,cAAc,CAAC,CA0BvE;AAED,wBAAsB,gBAAgB,qBAgBrC;AAiBD,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM;;;;;;;;cArC1E,CAAD;;;;;;;;GA+DF;AAED,wBAAgB,mBAAmB,CACjC,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,EAC3C,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,cA+B5C;AAED,wBAAgB,aAAa,CAAC,eAAe,EAAE,MAAM,QAepD;AAED,wBAAgB,sBAAsB,CAAC,OAAO,UAAQ,GAAG,MAAM,CAE9D"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tronlink/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAuC,MAAM,kBAAkB,CAAC;AAI9E,eAAO,MAAM,cAAc;;;;;;;CA4CzB,CAAC;AAEH,eAAO,MAAM,yBAAyB,cAA2C,CAAC;AAElF,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tronlink/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAuC,MAAM,kBAAkB,CAAC;AAI9E,eAAO,MAAM,cAAc;;;;;;;CAuCzB,CAAC;AAEH,eAAO,MAAM,yBAAyB,cAA2C,CAAC;AAElF,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC"}
@@ -10,7 +10,7 @@ export interface TronLinkWindow {
10
10
  request: (args: {
11
11
  method: string;
12
12
  params?: unknown;
13
- }) => Promise<TronLinkResponse>;
13
+ }) => Promise<TronLinkResponse | "">;
14
14
  tronWeb: {
15
15
  defaultAddress: {
16
16
  base58: string;
@@ -52,8 +52,4 @@ export interface TronLinkEvents {
52
52
  };
53
53
  };
54
54
  }
55
- export interface TronLinkError extends Error {
56
- code: number;
57
- data?: unknown;
58
- }
59
55
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/tronlink/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAEtF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,QAAQ,CAAC,EAAE,cAAc,CAAC;QAC1B,OAAO,CAAC,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC;KACrC;CACF;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,EAAE,CAAC,IAAI,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,OAAO,CAAA;KAAE,KAAK,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACnF,OAAO,EAAE;QACP,cAAc,EAAE;YAAE,MAAM,EAAE,MAAM,CAAC;YAAC,GAAG,EAAE,MAAM,CAAA;SAAE,CAAC;QAChD,QAAQ,CAAC,EAAE;YAAE,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC;QAC5B,GAAG,EAAE;YACH,IAAI,EAAE,CAAC,WAAW,EAAE,eAAe,KAAK,OAAO,CAAC,qBAAqB,CAAC,CAAC;YACvE,kBAAkB,EAAE,CAAC,QAAQ,EAAE,qBAAqB,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;YACzE,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;YACjD,mBAAmB,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;SAC5D,CAAC;KACH,CAAC;IACF,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,oBAAY,oBAAoB;IAC9B,OAAO,MAAM;IACb,MAAM,OAAO;IACb,QAAQ,OAAO;IACf,YAAY,OAAO;IACnB,kBAAkB,OAAO;IACzB,YAAY,OAAO;IACnB,kBAAkB,OAAO;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,oBAAoB,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAChC,OAAO,EAAE;QAAE,IAAI,EAAE;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;CACxD;AAED,MAAM,WAAW,aAAc,SAAQ,KAAK;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/tronlink/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAEtF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,QAAQ,CAAC,EAAE,cAAc,CAAC;QAC1B,OAAO,CAAC,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC;KACrC;CACF;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,EAAE,CAAC,IAAI,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,OAAO,CAAA;KAAE,KAAK,OAAO,CAAC,gBAAgB,GAAG,EAAE,CAAC,CAAC;IACxF,OAAO,EAAE;QACP,cAAc,EAAE;YAAE,MAAM,EAAE,MAAM,CAAC;YAAC,GAAG,EAAE,MAAM,CAAA;SAAE,CAAC;QAChD,QAAQ,CAAC,EAAE;YAAE,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC;QAC5B,GAAG,EAAE;YACH,IAAI,EAAE,CAAC,WAAW,EAAE,eAAe,KAAK,OAAO,CAAC,qBAAqB,CAAC,CAAC;YACvE,kBAAkB,EAAE,CAAC,QAAQ,EAAE,qBAAqB,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;YACzE,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;YACjD,mBAAmB,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;SAC5D,CAAC;KACH,CAAC;IACF,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,oBAAY,oBAAoB;IAC9B,OAAO,MAAM;IACb,MAAM,OAAO;IACb,QAAQ,OAAO;IACf,YAAY,OAAO;IACnB,kBAAkB,OAAO;IACzB,YAAY,OAAO;IACnB,kBAAkB,OAAO;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,oBAAoB,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAChC,OAAO,EAAE;QAAE,IAAI,EAAE;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;CACxD"}
package/package.json CHANGED
@@ -12,11 +12,11 @@
12
12
  "@scure/base": "~1.2.0",
13
13
  "@scure/bip39": "~1.6.0",
14
14
  "@solana/web3.js": "~1.98.0",
15
- "@swapkit/helpers": "4.0.12",
16
- "@swapkit/toolboxes": "4.0.12",
17
- "@swapkit/wallet-core": "4.0.12",
18
- "@swapkit/wallet-hardware": "4.1.11",
19
- "@swapkit/wallet-keystore": "4.0.12",
15
+ "@swapkit/helpers": "4.0.14",
16
+ "@swapkit/toolboxes": "4.0.14",
17
+ "@swapkit/wallet-core": "4.0.14",
18
+ "@swapkit/wallet-hardware": "4.1.13",
19
+ "@swapkit/wallet-keystore": "4.0.14",
20
20
  "@trezor/connect-web": "~9.6.0",
21
21
  "@walletconnect/modal": "~2.7.0",
22
22
  "@walletconnect/sign-client": "~2.21.0",
@@ -42,8 +42,8 @@
42
42
  "@scure/base": "1.2.6",
43
43
  "@scure/bip39": "1.6.0",
44
44
  "@solana/web3.js": "1.98.4",
45
- "@swapkit/helpers": "4.0.12",
46
- "@swapkit/toolboxes": "4.0.12",
45
+ "@swapkit/helpers": "4.0.14",
46
+ "@swapkit/toolboxes": "4.0.14",
47
47
  "@trezor/connect-web": "9.6.2",
48
48
  "@walletconnect/logger": "2.1.2",
49
49
  "@walletconnect/modal": "2.7.0",
@@ -183,5 +183,5 @@
183
183
  "type-check:go": "tsgo"
184
184
  },
185
185
  "type": "module",
186
- "version": "4.1.11"
186
+ "version": "4.1.13"
187
187
  }