@swapkit/wallets 4.0.0-beta.71 → 4.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-23hnqbxw.js +4 -0
- package/dist/chunk-23hnqbxw.js.map +10 -0
- package/dist/{chunk-sbf0f2p4.js → chunk-hjyak2y4.js} +3 -3
- package/dist/chunk-hjyak2y4.js.map +10 -0
- package/dist/{chunk-x5n5v0h8.js → chunk-rv3zf3sa.js} +3 -3
- package/dist/chunk-rv3zf3sa.js.map +10 -0
- package/dist/chunk-t3m5498m.js +4 -0
- package/dist/chunk-t3m5498m.js.map +10 -0
- package/dist/src/bitget/index.cjs +2 -2
- package/dist/src/bitget/index.cjs.map +4 -4
- package/dist/src/bitget/index.js +2 -2
- package/dist/src/bitget/index.js.map +4 -4
- package/dist/src/coinbase/index.cjs +2 -2
- package/dist/src/coinbase/index.cjs.map +4 -4
- package/dist/src/coinbase/index.js +2 -2
- package/dist/src/coinbase/index.js.map +4 -4
- package/dist/src/cosmostation/index.cjs +2 -2
- package/dist/src/cosmostation/index.cjs.map +3 -3
- package/dist/src/cosmostation/index.js +2 -2
- package/dist/src/cosmostation/index.js.map +3 -3
- package/dist/src/ctrl/index.cjs +2 -2
- package/dist/src/ctrl/index.cjs.map +4 -4
- package/dist/src/ctrl/index.js +2 -2
- package/dist/src/ctrl/index.js.map +4 -4
- package/dist/src/evm-extensions/index.cjs +2 -2
- package/dist/src/evm-extensions/index.cjs.map +3 -3
- package/dist/src/evm-extensions/index.js +2 -2
- package/dist/src/evm-extensions/index.js.map +3 -3
- package/dist/src/exodus/index.cjs +2 -2
- package/dist/src/exodus/index.cjs.map +3 -3
- package/dist/src/exodus/index.js +2 -2
- package/dist/src/exodus/index.js.map +3 -3
- package/dist/src/index.cjs +2 -2
- package/dist/src/index.cjs.map +4 -4
- package/dist/src/index.js +1 -1
- package/dist/src/index.js.map +4 -4
- package/dist/src/keepkey-bex/index.cjs +2 -2
- package/dist/src/keepkey-bex/index.cjs.map +4 -4
- package/dist/src/keepkey-bex/index.js +2 -2
- package/dist/src/keepkey-bex/index.js.map +4 -4
- package/dist/src/keplr/index.cjs +2 -2
- package/dist/src/keplr/index.cjs.map +4 -4
- package/dist/src/keplr/index.js +2 -2
- package/dist/src/keplr/index.js.map +4 -4
- package/dist/src/okx/index.cjs +2 -2
- package/dist/src/okx/index.cjs.map +4 -4
- package/dist/src/okx/index.js +2 -2
- package/dist/src/okx/index.js.map +4 -4
- package/dist/src/onekey/index.cjs +2 -2
- package/dist/src/onekey/index.cjs.map +3 -3
- package/dist/src/onekey/index.js +2 -2
- package/dist/src/onekey/index.js.map +3 -3
- package/dist/src/phantom/index.cjs +2 -2
- package/dist/src/phantom/index.cjs.map +3 -3
- package/dist/src/phantom/index.js +2 -2
- package/dist/src/phantom/index.js.map +3 -3
- package/dist/src/polkadotjs/index.cjs +2 -2
- package/dist/src/polkadotjs/index.cjs.map +3 -3
- package/dist/src/polkadotjs/index.js +2 -2
- package/dist/src/polkadotjs/index.js.map +3 -3
- package/dist/src/radix/index.cjs +2 -2
- package/dist/src/radix/index.cjs.map +3 -3
- package/dist/src/radix/index.js +2 -2
- package/dist/src/radix/index.js.map +3 -3
- package/dist/src/talisman/index.cjs +2 -2
- package/dist/src/talisman/index.cjs.map +3 -3
- package/dist/src/talisman/index.js +2 -2
- package/dist/src/talisman/index.js.map +3 -3
- package/dist/src/tronlink/index.cjs +2 -2
- package/dist/src/tronlink/index.cjs.map +5 -5
- package/dist/src/tronlink/index.js +2 -2
- package/dist/src/tronlink/index.js.map +5 -5
- package/dist/src/vultisig/index.cjs +2 -2
- package/dist/src/vultisig/index.cjs.map +4 -4
- package/dist/src/vultisig/index.js +2 -2
- package/dist/src/vultisig/index.js.map +4 -4
- package/dist/src/walletconnect/index.cjs +2 -2
- package/dist/src/walletconnect/index.cjs.map +6 -6
- package/dist/src/walletconnect/index.js +2 -2
- package/dist/src/walletconnect/index.js.map +6 -6
- package/dist/src/xaman/index.cjs +2 -2
- package/dist/src/xaman/index.cjs.map +5 -5
- package/dist/src/xaman/index.js +2 -2
- package/dist/src/xaman/index.js.map +5 -5
- package/dist/types/bitget/helpers.d.ts +246 -144
- package/dist/types/bitget/helpers.d.ts.map +1 -1
- package/dist/types/coinbase/index.d.ts.map +1 -1
- package/dist/types/coinbase/signer.d.ts +97 -28
- package/dist/types/coinbase/signer.d.ts.map +1 -1
- package/dist/types/cosmostation/index.d.ts.map +1 -1
- package/dist/types/ctrl/walletHelpers.d.ts +1 -1
- package/dist/types/ctrl/walletHelpers.d.ts.map +1 -1
- package/dist/types/evm-extensions/index.d.ts +97 -29
- package/dist/types/evm-extensions/index.d.ts.map +1 -1
- package/dist/types/evm-extensions/types.d.ts.map +1 -1
- package/dist/types/exodus/index.d.ts +1 -1
- package/dist/types/exodus/index.d.ts.map +1 -1
- package/dist/types/helpers/near.d.ts +2 -2
- package/dist/types/helpers/near.d.ts.map +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/keepkey-bex/index.d.ts.map +1 -1
- package/dist/types/keepkey-bex/walletHelpers.d.ts +1 -1
- package/dist/types/keepkey-bex/walletHelpers.d.ts.map +1 -1
- package/dist/types/keplr/chainRegistry.d.ts.map +1 -1
- package/dist/types/keplr/index.d.ts.map +1 -1
- package/dist/types/okx/helpers.d.ts +139 -105
- package/dist/types/okx/helpers.d.ts.map +1 -1
- package/dist/types/onekey/evmSigner.d.ts.map +1 -1
- package/dist/types/onekey/index.d.ts.map +1 -1
- package/dist/types/radix/index.d.ts.map +1 -1
- package/dist/types/tronlink/helpers.d.ts.map +1 -1
- package/dist/types/tronlink/index.d.ts +1 -1
- package/dist/types/tronlink/index.d.ts.map +1 -1
- package/dist/types/tronlink/types.d.ts.map +1 -1
- package/dist/types/types.d.ts +4 -4
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/utils.d.ts.map +1 -1
- package/dist/types/vultisig/index.d.ts.map +1 -1
- package/dist/types/vultisig/walletHelpers.d.ts +1 -1
- package/dist/types/vultisig/walletHelpers.d.ts.map +1 -1
- package/dist/types/walletconnect/constants.d.ts.map +1 -1
- package/dist/types/walletconnect/evmSigner.d.ts +1 -1
- package/dist/types/walletconnect/evmSigner.d.ts.map +1 -1
- package/dist/types/walletconnect/helpers.d.ts.map +1 -1
- package/dist/types/walletconnect/index.d.ts +2 -2
- package/dist/types/walletconnect/index.d.ts.map +1 -1
- package/dist/types/walletconnect/namespaces.d.ts.map +1 -1
- package/dist/types/xaman/helpers.d.ts +22 -19
- package/dist/types/xaman/helpers.d.ts.map +1 -1
- package/dist/types/xaman/index.d.ts.map +1 -1
- package/dist/types/xaman/walletMethods.d.ts +4 -4
- package/dist/types/xaman/walletMethods.d.ts.map +1 -1
- package/package.json +21 -28
- package/dist/chunk-mcrgqfr9.js +0 -4
- package/dist/chunk-mcrgqfr9.js.map +0 -10
- package/dist/chunk-sbf0f2p4.js.map +0 -10
- package/dist/chunk-wfattb4a.js +0 -4
- package/dist/chunk-wfattb4a.js.map +0 -10
- package/dist/chunk-x5n5v0h8.js.map +0 -10
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as d,G as m}from"../../chunk-yqaz2d25.js";import{Chain as t,
|
|
1
|
+
import{F as d,G as m}from"../../chunk-yqaz2d25.js";import{Chain as t,filterSupportedChains as p,prepareNetworkSwitch as h,SwapKitError as s,switchEVMWalletNetwork as f,WalletOption as l}from"@swapkit/helpers";import{createWallet as u,getWalletSupportedChains as _}from"@swapkit/wallet-core";var A=u({connect:({addChain:e,supportedChains:a,walletType:r})=>async function c(o){let i=p({chains:o,supportedChains:a,walletType:r});return await Promise.all(i.map(async(n)=>{let w=await S(n);e({...w,chain:n,walletType:r})})),!0},name:"connectTalisman",supportedChains:[t.Ethereum,t.Arbitrum,t.Avalanche,t.Base,t.Polygon,t.BinanceSmartChain,t.Optimism,t.Polkadot,t.Chainflip],walletType:l.TALISMAN}),C=_(A);async function E({walletProvider:e,chain:a}){let{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:c}=await import("ethers");if(!e)throw new s({errorKey:"wallet_provider_not_found",info:{chain:a,wallet:l.TALISMAN}});let o=new c(e,"any"),i=await o.getSigner(),n=await r(a,{provider:o,signer:i});try{if(a!==t.Ethereum)await f(o,a,n.getNetworkParams())}catch(w){throw new s({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:a,wallet:l.TALISMAN}})}return h({chain:a,provider:o,toolbox:n})}async function S(e){switch(e){case t.Ethereum:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:case t.BinanceSmartChain:case t.Base:{if(!(window.talismanEth&&("send"in window.talismanEth)))throw new s({errorKey:"wallet_talisman_not_found",info:{chain:e}});let a=await E({chain:e,walletProvider:window.talismanEth}),r=(await window.talismanEth.send("eth_requestAccounts",[]))[0];return{...a,address:r}}case t.Polkadot:case t.Chainflip:{let{getSubstrateToolbox:a,SubstrateNetwork:r}=await import("@swapkit/toolboxes/substrate"),o=await window?.injectedWeb3?.talisman?.enable?.("talisman");if(!o)throw new s({errorKey:"wallet_talisman_not_enabled",info:{chain:e}});let i=await a(e,{signer:o.signer}),n=await o.accounts.get();if(!n[0]?.address)throw new s({errorKey:"wallet_missing_params",info:{accounts:n,address:n[0]?.address,wallet:l.TALISMAN}});let w=i.convertAddress(n[0].address,r[e].prefix);return{...i,address:w}}default:throw new s({errorKey:"wallet_chain_not_supported",info:{chain:e,wallet:l.TALISMAN}})}}export{A as talismanWallet,C as TALISMAN_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=FA4686F6D1FC86AE64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/talisman/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import {\n Chain,\n type EVMChain,\n
|
|
5
|
+
"import {\n Chain,\n type EVMChain,\n filterSupportedChains,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport const talismanWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTalisman(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectTalisman\",\n supportedChains: [\n Chain.Ethereum,\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.Polygon,\n Chain.BinanceSmartChain,\n Chain.Optimism,\n Chain.Polkadot,\n Chain.Chainflip,\n ],\n walletType: WalletOption.TALISMAN,\n});\n\nexport const TALISMAN_SUPPORTED_CHAINS = getWalletSupportedChains(talismanWallet);\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n if (!walletProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.TALISMAN } });\n }\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.TALISMAN },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n}\n\nasync function getWalletMethods(chain: Chain) {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.BinanceSmartChain:\n case Chain.Base: {\n if (!(window.talismanEth && \"send\" in window.talismanEth)) {\n throw new SwapKitError({ errorKey: \"wallet_talisman_not_found\", info: { chain } });\n }\n\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: window.talismanEth });\n const address: string = (await window.talismanEth.send(\"eth_requestAccounts\", []))[0];\n\n return { ...evmWallet, address };\n }\n\n case Chain.Polkadot:\n case Chain.Chainflip: {\n const { getSubstrateToolbox, SubstrateNetwork } = await import(\"@swapkit/toolboxes/substrate\");\n\n const injectedExtension = window?.injectedWeb3?.talisman;\n const rawExtension = await injectedExtension?.enable?.(\"talisman\");\n\n if (!rawExtension) {\n throw new SwapKitError({ errorKey: \"wallet_talisman_not_enabled\", info: { chain } });\n }\n\n const toolbox = await getSubstrateToolbox(chain, { signer: rawExtension.signer });\n const accounts = await rawExtension.accounts.get();\n\n if (!accounts[0]?.address) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { accounts, address: accounts[0]?.address, wallet: WalletOption.TALISMAN },\n });\n }\n const address = toolbox.convertAddress(accounts[0].address, SubstrateNetwork[chain].prefix);\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.TALISMAN },\n });\n }\n}\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "mDAAA,gBACE,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "mDAAA,gBACE,2BAEA,0BACA,kBACA,4BACA,kBACA,yBAEF,uBAAS,8BAAc,6BAGhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,eAAe,CAAe,CAAC,EAAiB,CAC9C,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAUpF,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAK,EAElD,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,IAEX,KAAM,kBACN,gBAAiB,CACf,EAAM,SACN,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,QACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,SACR,EACA,WAAY,EAAa,QAC3B,CAAC,EAEY,EAA4B,EAAyB,CAAc,EAEhF,eAAe,CAAoB,EACjC,iBACA,SAIC,CACD,IAAQ,iBAAkB,KAAa,mCAC/B,mBAAoB,KAAa,kBAEzC,IAAK,EACH,MAAM,IAAI,EAAa,CAAE,SAAU,4BAA6B,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAAE,CAAC,EAGlH,IAAM,EAAW,IAAI,EAAgB,EAAgB,KAAK,EACpD,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EAE/D,GAAI,CACF,GAAI,IAAU,EAAM,SAClB,MAAM,EAAuB,EAAU,EAAO,EAAQ,iBAAiB,CAAC,EAE1E,MAAO,EAAQ,CACf,MAAM,IAAI,EAAa,CACrB,SAAU,yCACV,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAC/C,CAAC,EAGH,OAAO,EAAqB,CAAE,QAAO,WAAU,SAAQ,CAAC,EAG1D,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,EAAM,cACN,EAAM,cACN,EAAM,cACN,EAAM,aACN,EAAM,eACN,EAAM,uBACN,EAAM,KAAM,CACf,KAAM,OAAO,cAAe,SAAU,OAAO,cAC3C,MAAM,IAAI,EAAa,CAAE,SAAU,4BAA6B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGnF,IAAM,EAAY,MAAM,EAAqB,CAAE,QAAO,eAAgB,OAAO,WAAY,CAAC,EACpF,GAAmB,MAAM,OAAO,YAAY,KAAK,sBAAuB,CAAC,CAAC,GAAG,GAEnF,MAAO,IAAK,EAAW,SAAQ,CACjC,MAEK,EAAM,cACN,EAAM,UAAW,CACpB,IAAQ,sBAAqB,oBAAqB,KAAa,wCAGzD,EAAe,MADK,QAAQ,cAAc,UACF,SAAS,UAAU,EAEjE,IAAK,EACH,MAAM,IAAI,EAAa,CAAE,SAAU,8BAA+B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGrF,IAAM,EAAU,MAAM,EAAoB,EAAO,CAAE,OAAQ,EAAa,MAAO,CAAC,EAC1E,EAAW,MAAM,EAAa,SAAS,IAAI,EAEjD,IAAK,EAAS,IAAI,QAChB,MAAM,IAAI,EAAa,CACrB,SAAU,wBACV,KAAM,CAAE,WAAU,QAAS,EAAS,IAAI,QAAS,OAAQ,EAAa,QAAS,CACjF,CAAC,EAEH,IAAM,EAAU,EAAQ,eAAe,EAAS,GAAG,QAAS,EAAiB,GAAO,MAAM,EAE1F,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,EAAa,CACrB,SAAU,6BACV,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAC/C,CAAC",
|
|
8
|
+
"debugId": "FA4686F6D1FC86AE64756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -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||={});
|
|
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 new 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 P(f){if(I.filterSupportedChains({chains:f,supportedChains:m,walletType:U}).length===0)throw new 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($);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=11A734A643BD73D264756E2164756E21
|
|
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,
|
|
6
|
-
"import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { type TronSigner, type TronTransaction
|
|
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: {
|
|
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"
|
|
8
8
|
],
|
|
9
|
-
"mappings": "oQAA2D,IAA3D,8BACA,kCCDkD,IAAlD,8BACA,
|
|
10
|
-
"debugId": "
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "11A734A643BD73D264756E2164756E21",
|
|
11
11
|
"names": []
|
|
12
12
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import"../../chunk-yqaz2d25.js";import{Chain as J,
|
|
1
|
+
import"../../chunk-yqaz2d25.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 new 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 U(P){if(A({chains:P,supportedChains:m,walletType:g}).length===0)throw new 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};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=3D96AC47C5ACA4AF64756E2164756E21
|
|
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,
|
|
6
|
-
"import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { type TronSigner, type TronTransaction
|
|
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: {
|
|
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"
|
|
8
8
|
],
|
|
9
|
-
"mappings": "gCAAA,gBAAS,
|
|
10
|
-
"debugId": "
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "3D96AC47C5ACA4AF64756E2164756E21",
|
|
11
11
|
"names": []
|
|
12
12
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var v={};x(v,{vultisigWallet:()=>A,VULTISIG_SUPPORTED_CHAINS:()=>g});module.exports=b(v);var z=require("@swapkit/helpers"),O=require("@swapkit/wallet-core");var F=require("@swapkit/helpers"),N=require("@swapkit/helpers/contracts");async function _(D){if(!window.vultisig)throw new F.SwapKitError("wallet_vultisig_not_found");let{match:$}=await import("ts-pattern");return $(D).with(...F.EVMChains,()=>window.vultisig?.ethereum).with(F.Chain.Cosmos,F.Chain.Kujira,()=>window.vultisig?.cosmos).with(F.Chain.Bitcoin,()=>window.vultisig?.bitcoin).with(F.Chain.BitcoinCash,()=>window.vultisig?.bitcoincash).with(F.Chain.Dash,()=>window.vultisig?.dash).with(F.Chain.Dogecoin,()=>window.vultisig?.dogecoin).with(F.Chain.Litecoin,()=>window.vultisig?.litecoin).with(F.Chain.Solana,()=>window.vultisig?.solana).with(F.Chain.THORChain,()=>window.vultisig?.thorchain).with(F.Chain.Maya,()=>window.vultisig?.mayachain).with(F.Chain.Polkadot,()=>window.vultisig?.polkadot).with(F.Chain.Ripple,()=>window.vultisig?.ripple).with(F.Chain.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function P({method:D,params:$,chain:Q}){let J=await _(Q),q=$;if(Q===F.Chain.Cosmos||Q===F.Chain.Kujira||Q===F.Chain.Ripple)q=$.map((Z)=>({from:Z.from,to:Z.to,value:Z.amount.amount.toString()
|
|
1
|
+
var v={};x(v,{vultisigWallet:()=>A,VULTISIG_SUPPORTED_CHAINS:()=>g});module.exports=b(v);var z=require("@swapkit/helpers"),O=require("@swapkit/wallet-core");var F=require("@swapkit/helpers"),N=require("@swapkit/helpers/contracts");async function _(D){if(!window.vultisig)throw new F.SwapKitError("wallet_vultisig_not_found");let{match:$}=await import("ts-pattern");return $(D).with(...F.EVMChains,()=>window.vultisig?.ethereum).with(F.Chain.Cosmos,F.Chain.Kujira,()=>window.vultisig?.cosmos).with(F.Chain.Bitcoin,()=>window.vultisig?.bitcoin).with(F.Chain.BitcoinCash,()=>window.vultisig?.bitcoincash).with(F.Chain.Dash,()=>window.vultisig?.dash).with(F.Chain.Dogecoin,()=>window.vultisig?.dogecoin).with(F.Chain.Litecoin,()=>window.vultisig?.litecoin).with(F.Chain.Solana,()=>window.vultisig?.solana).with(F.Chain.THORChain,()=>window.vultisig?.thorchain).with(F.Chain.Maya,()=>window.vultisig?.mayachain).with(F.Chain.Polkadot,()=>window.vultisig?.polkadot).with(F.Chain.Ripple,()=>window.vultisig?.ripple).with(F.Chain.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function P({method:D,params:$,chain:Q}){let J=await _(Q),q=$;if(Q===F.Chain.Cosmos||Q===F.Chain.Kujira||Q===F.Chain.Ripple)q=$.map((Z)=>({data:Z.data,from:Z.from,to:Z.to,value:Z.amount.amount.toString()}));return new Promise((Z,G)=>{if(J&&"request"in J)J.request({method:D,params:q},(Y,H)=>{Y?G(Y):Z(H)})})}async function y(D){try{let $=await _(D);if(!$)throw new F.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:D,wallet:F.WalletOption.VULTISIG}});if([F.Chain.Cosmos,F.Chain.Kujira].includes(D)){let J=await _(F.Chain.Cosmos),q=F.ChainToChainId[D];await J.request({method:"wallet_switch_chain",params:[{chainId:q}]});let Z=await J.request({method:"get_accounts"});if(!Z)Z=(await J.request({method:"request_accounts"}))[0].address;return Z}if(F.EVMChains.includes(D)){if("request"in $&&typeof $.request==="function")return(await $.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:J}=await import("ethers"),q=new J($,"any"),[Z]=await F.providerRequest({method:"eth_requestAccounts",params:[],provider:q});return Z}if(D===F.Chain.Solana)return(await(await _(F.Chain.Solana)).connect()).publicKey.toString();return(await $.request({method:"request_accounts",params:[]}))[0]}catch($){throw new F.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:D,wallet:F.WalletOption.VULTISIG}})}}async function L({assetValue:D,recipient:$,memo:Q,gasLimit:J},q="send_transaction"){if(!D)throw new F.SwapKitError("wallet_vultisig_asset_not_defined");let Z=await y(D.chain),G=[{amount:{amount:D.getBaseValue("number"),decimals:D.decimal},asset:{chain:D.chain,symbol:D.symbol.toUpperCase(),ticker:D.symbol.toUpperCase()},data:Q||"",from:Z,gasLimit:J,to:$}];return P({chain:D.chain,method:q,params:G})}function S(D,$){return{approve:async({assetAddress:Q,spenderAddress:J,amount:q,from:Z})=>{let{MAX_APPROVAL:G,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),H=[J,BigInt(q||G)],U={abi:N.erc20ABI,contractAddress:Q,funcName:"approve",funcParams:H,txOverrides:{from:Z}},R=Y({chain:$,provider:D}),{value:I,to:j,data:K}=await R(U);return(await(await D.getSigner()).sendTransaction({data:K||"0x",from:Z,to:j,value:BigInt(I||0)})).hash},call:async({contractAddress:Q,abi:J,funcName:q,funcParams:Z=[],txOverrides:G})=>{if(!Q)throw new F.SwapKitError("wallet_vultisig_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:H,isStateChangingCall:X}=await import("@swapkit/toolboxes/evm");if(X({abi:J,funcName:q})){let j=H({chain:$,provider:D}),{value:K,from:M,to:E,data:T}=await j({abi:J,contractAddress:Q,funcName:q,funcParams:Z,txOverrides:G});return(await(await D.getSigner()).sendTransaction({data:T||"0x",from:M,to:E,value:BigInt(K||0)})).hash}let I=await Y(Q,J,D)[q]?.(...Z);return typeof I?.hash==="string"?I?.hash:I},sendTransaction:async(Q)=>{let{from:J,to:q,data:Z,value:G}=Q;if(!q)throw new F.SwapKitError("wallet_vultisig_send_transaction_no_address");return(await(await D.getSigner()).sendTransaction({data:Z||"0x",from:J,to:q,value:BigInt(G||0)})).hash}}}async function V(D,$,Q){try{await D.request({method:"wallet_switch_chain",params:[{chainId:F.ChainToChainId[$]}]})}catch(J){if(!Q)throw new F.SwapKitError("helpers_failed_to_switch_network",{error:J,reason:"networkParams not provided"})}}function f(D,$,Q){return async(...J)=>{try{await V($,Q)}catch(q){throw new F.SwapKitError({errorKey:"helpers_failed_to_switch_network",info:{error:q}})}return D(...J)}}function k({toolbox:D,chain:$,provider:Q=window.ethereum,methodNames:J=[]}){let Z=[...J,"transfer","getAddress","getBalance"].reduce((G,Y)=>{if(!D[Y])return G;let H=D[Y];if(typeof H!=="function")return G;let X=f(H,Q,$);return{...G,[Y]:X}},{});return{...D,...Z}}var A=O.createWallet({connect:({addChain:D,walletType:$,supportedChains:Q})=>async function J(q){let Z=z.filterSupportedChains({chains:q,supportedChains:Q,walletType:$}),G=Z.filter((X)=>X!==z.Chain.Cosmos&&X!==z.Chain.Kujira).map(async(X)=>{let U=await y(X),R=await W(X);D({...R,address:U,chain:X,walletType:$})}),Y=Z.includes(z.Chain.Cosmos),H=Z.includes(z.Chain.Kujira);if(Y){let X=await y(z.Chain.Cosmos),U=await W(z.Chain.Cosmos);D({...U,address:X,chain:z.Chain.Cosmos,walletType:$})}if(H){let X=await y(z.Chain.Kujira),U=await W(z.Chain.Kujira);D({...U,address:X,chain:z.Chain.Kujira,walletType:$})}return await Promise.all(G),!0},name:"connectVultisig",supportedChains:[z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dash,z.Chain.Dogecoin,z.Chain.Ethereum,z.Chain.Kujira,z.Chain.Litecoin,z.Chain.Maya,z.Chain.Optimism,z.Chain.Polkadot,z.Chain.Polygon,z.Chain.Ripple,z.Chain.Solana,z.Chain.THORChain,z.Chain.Zcash],walletType:z.WalletOption.VULTISIG}),g=O.getWalletSupportedChains(A);async function W(D){let{match:$}=await import("ts-pattern");return $(D).with(z.Chain.Solana,async()=>{let{getSolanaToolbox:Q}=await import("@swapkit/toolboxes/solana"),J=window.vultisig?.solana;if(!J)throw new z.SwapKitError("wallet_vultisig_not_found");return{...await Q({signer:J})}}).with(z.Chain.Maya,z.Chain.THORChain,async()=>{let{getCosmosToolbox:Q,THORCHAIN_GAS_VALUE:J,MAYA_GAS_VALUE:q}=await import("@swapkit/toolboxes/cosmos"),Z=D===z.Chain.Maya?q:J;return{...await Q(D),deposit:(Y)=>L({...Y,recipient:""},"deposit_transaction"),transfer:(Y)=>L({...Y,gasLimit:Z},"send_transaction")}}).with(z.Chain.Cosmos,z.Chain.Kujira,async()=>{let{getCosmosToolbox:Q}=await import("@swapkit/toolboxes/cosmos"),J=await _(D),q=await Q(D);return k({chain:D,provider:J,toolbox:{...q,transfer:L}})}).with(...z.UTXOChains,async()=>{let{getUtxoToolbox:Q}=await import("@swapkit/toolboxes/utxo");return{...await Q(D),transfer:L}}).with(z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Ethereum,z.Chain.Optimism,z.Chain.Polygon,async()=>{let{prepareNetworkSwitch:Q,switchEVMWalletNetwork:J}=await import("@swapkit/helpers"),{getEvmToolbox:q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Z}=await import("ethers"),G=await _(D);if(!G)throw new z.SwapKitError("wallet_vultisig_not_found");let Y=new Z(G,"any"),H=await Y.getSigner(),X=await q(D,{provider:Y,signer:H}),U=S(Y,D);try{if(D!==z.Chain.Ethereum){let R=X.getNetworkParams();await J(Y,D,R)}}catch(R){throw new z.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:D,wallet:z.WalletOption.VULTISIG}})}return Q({chain:D,provider:Y,toolbox:{...X,...U}})}).with(z.Chain.Ripple,async()=>{let{getRippleToolbox:Q}=await import("@swapkit/toolboxes/ripple");return{...await Q(),transfer:L}}).with(z.Chain.Polkadot,async()=>{let{getSubstrateToolbox:Q}=await import("@swapkit/toolboxes/substrate");return{...await Q(D),transfer:L}}).otherwise(async()=>null)}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=CB7931C838DDDE6964756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/vultisig/index.ts", "../src/vultisig/walletHelpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import {\n Chain,\n type EVMChain,\n type GenericTransferParams,\n SwapKitError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n
|
|
6
|
-
"import {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n type NetworkParams,\n SwapKitError,\n type UTXOChain,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport type { VultisigCosmosProvider } from \"../types\";\n\ntype TransactionMethod = \"send_transaction\" | \"deposit_transaction\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n to: string;\n data?: string;\n from?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype VultisigProviderType<T> = T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? VultisigCosmosProvider\n : T extends EVMChain\n ? Eip1193Provider\n : T extends Chain.Maya | Chain.THORChain | Chain.Ripple | Chain.Polkadot | UTXOChain\n ? Eip1193Provider\n : undefined;\n\nexport async function getVultisigProvider<T extends Chain>(\n chain: T,\n): Promise<VultisigProviderType<T>> {\n if (!window.vultisig) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .with(...EVMChains, () => window.vultisig?.ethereum as Eip1193Provider)\n .with(Chain.Cosmos, Chain.Kujira, () => window.vultisig?.cosmos as VultisigCosmosProvider)\n .with(Chain.Bitcoin, () => window.vultisig?.bitcoin as Eip1193Provider)\n .with(Chain.BitcoinCash, () => window.vultisig?.bitcoincash as Eip1193Provider)\n .with(Chain.Dash, () => window.vultisig?.dash as Eip1193Provider)\n .with(Chain.Dogecoin, () => window.vultisig?.dogecoin as Eip1193Provider)\n .with(Chain.Litecoin, () => window.vultisig?.litecoin as Eip1193Provider)\n .with(Chain.Solana, () => window.vultisig?.solana as SolanaProvider)\n .with(Chain.THORChain, () => window.vultisig?.thorchain as Eip1193Provider)\n .with(Chain.Maya, () => window.vultisig?.mayachain as Eip1193Provider)\n .with(Chain.Polkadot, () => window.vultisig?.polkadot as Eip1193Provider)\n .with(Chain.Ripple, () => window.vultisig?.ripple as Eip1193Provider)\n .with(Chain.Zcash, () => window.vultisig?.zcash as Eip1193Provider)\n .otherwise(() => undefined) as VultisigProviderType<T>;\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getVultisigProvider(chain);\n let finalParams:\n | TransactionParams[]\n | {\n from: string;\n to?: string;\n value: string;\n data?: string;\n }[] = params;\n\n if (chain === Chain.Cosmos || chain === Chain.Kujira || chain === Chain.Ripple) {\n finalParams = params.map((p) => ({\n from: p.from as string,\n to: p.to as string,\n value: (p.amount as { amount: number; decimals?: number }).amount.toString(),\n data: p.data as string,\n }));\n }\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params: finalParams }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getVultisigAddress(chain: Chain) {\n try {\n const eipProvider = (await getVultisigProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.VULTISIG, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getVultisigProvider(Chain.Cosmos);\n const chainId = ChainToChainId[chain];\n\n await provider.request({\n method: \"wallet_switch_chain\",\n params: [{ chainId }],\n });\n\n let account = await provider.request({\n method: \"get_accounts\",\n });\n if (!account) {\n const connectedAcount = await provider.request({\n method: \"request_accounts\",\n });\n account = connectedAcount[0].address;\n }\n return account;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getVultisigProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.VULTISIG, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"send_transaction\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_vultisig_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getVultisigAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n data: memo || \"\",\n from,\n to: recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getVultisigMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_vultisig_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n\nexport async function switchCosmosWalletNetwork(\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n networkParams?: NetworkParams,\n) {\n try {\n await provider.request({\n method: \"wallet_switch_chain\",\n params: [{ chainId: ChainToChainId[chain] }],\n });\n } catch (error) {\n if (!networkParams) {\n throw new SwapKitError(\"helpers_failed_to_switch_network\", {\n error: error,\n reason: \"networkParams not provided\",\n });\n }\n }\n}\n\nexport function wrapMethodWithNetworkSwitch<T extends (...args: any[]) => any>(\n func: T,\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n) {\n return (async (...args: any[]) => {\n try {\n await switchCosmosWalletNetwork(provider, chain);\n } catch (error) {\n throw new SwapKitError({\n errorKey: \"helpers_failed_to_switch_network\",\n info: { error },\n });\n }\n return func(...args);\n }) as unknown as T;\n}\n\nexport function prepareNetworkSwitchCosmos<\n T extends Awaited<ReturnType<typeof getCosmosToolbox>>,\n M extends keyof T,\n>({\n toolbox,\n chain,\n provider = window.ethereum,\n methodNames = [],\n}: { toolbox: T; chain: Chain; provider?: VultisigCosmosProvider; methodNames?: M[] }) {\n const methodsToWrap = [...methodNames, \"transfer\", \"getAddress\", \"getBalance\"] as M[];\n const wrappedMethods = methodsToWrap.reduce((object, methodName) => {\n if (!toolbox[methodName]) return object;\n\n const method = toolbox[methodName];\n\n if (typeof method !== \"function\") return object;\n\n // @ts-expect-error\n const wrappedMethod = wrapMethodWithNetworkSwitch(method, provider, chain);\n\n // biome-ignore lint/performance/noAccumulatingSpread: valid use case\n return { ...object, [methodName]: wrappedMethod };\n }, {});\n\n return { ...toolbox, ...wrappedMethods };\n}\n"
|
|
5
|
+
"import {\n Chain,\n type EVMChain,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n} from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport {\n getVultisigAddress,\n getVultisigMethods,\n getVultisigProvider,\n prepareNetworkSwitchCosmos,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const vultisigWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectVultisig(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains\n .filter((chain) => chain !== Chain.Cosmos && chain !== Chain.Kujira)\n .map(async (chain) => {\n const address = await getVultisigAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n const cosmosIncluded = filteredChains.includes(Chain.Cosmos);\n const kujiraIncluded = filteredChains.includes(Chain.Kujira);\n\n // Race condition single cosmos provider exposed.\n if (cosmosIncluded) {\n const addressCosmos = await getVultisigAddress(Chain.Cosmos);\n const walletMethodsCosmos = await getWalletMethods(Chain.Cosmos);\n addChain({ ...walletMethodsCosmos, address: addressCosmos, chain: Chain.Cosmos, walletType });\n }\n if (kujiraIncluded) {\n const addressKujira = await getVultisigAddress(Chain.Kujira);\n const walletMethodsKujira = await getWalletMethods(Chain.Kujira);\n addChain({ ...walletMethodsKujira, address: addressKujira, chain: Chain.Kujira, walletType });\n }\n //--//\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectVultisig\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polkadot,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.Zcash,\n ],\n walletType: WalletOption.VULTISIG,\n});\n\nexport const VULTISIG_SUPPORTED_CHAINS = getWalletSupportedChains(vultisigWallet);\n\nasync function getWalletMethods(chain: (typeof VULTISIG_SUPPORTED_CHAINS)[number]) {\n const { match } = await import(\"ts-pattern\");\n return match(chain)\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n return { ...toolbox };\n })\n\n .with(Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as Chain.Cosmos | Chain.Kujira);\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit_transaction\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"send_transaction\"),\n };\n })\n\n .with(Chain.Cosmos, Chain.Kujira, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const provider = await getVultisigProvider(chain as Chain.Cosmos | Chain.Kujira);\n const toolbox = await getCosmosToolbox(chain as Chain.Cosmos | Chain.Kujira);\n return prepareNetworkSwitchCosmos({ chain, provider, toolbox: { ...toolbox, transfer: walletTransfer } });\n })\n\n .with(...UTXOChains, async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain as UTXOChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n async () => {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getVultisigProvider(chain as EVMChain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_vultisig_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain as EVMChain, { provider, signer });\n const vultisigMethods = getVultisigMethods(provider, chain as EVMChain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.VULTISIG },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox: { ...toolbox, ...vultisigMethods } });\n },\n )\n\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const toolbox = await getRippleToolbox();\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const toolbox = await getSubstrateToolbox(chain as Chain.Polkadot);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .otherwise(async () => null);\n}\n",
|
|
6
|
+
"import {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n type NetworkParams,\n providerRequest,\n SwapKitError,\n type UTXOChain,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport type { VultisigCosmosProvider } from \"../types\";\n\ntype TransactionMethod = \"send_transaction\" | \"deposit_transaction\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n to: string;\n data?: string;\n from?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype VultisigProviderType<T> = T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? VultisigCosmosProvider\n : T extends EVMChain\n ? Eip1193Provider\n : T extends Chain.Maya | Chain.THORChain | Chain.Ripple | Chain.Polkadot | UTXOChain\n ? Eip1193Provider\n : undefined;\n\nexport async function getVultisigProvider<T extends Chain>(chain: T): Promise<VultisigProviderType<T>> {\n if (!window.vultisig) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .with(...EVMChains, () => window.vultisig?.ethereum as Eip1193Provider)\n .with(Chain.Cosmos, Chain.Kujira, () => window.vultisig?.cosmos as VultisigCosmosProvider)\n .with(Chain.Bitcoin, () => window.vultisig?.bitcoin as Eip1193Provider)\n .with(Chain.BitcoinCash, () => window.vultisig?.bitcoincash as Eip1193Provider)\n .with(Chain.Dash, () => window.vultisig?.dash as Eip1193Provider)\n .with(Chain.Dogecoin, () => window.vultisig?.dogecoin as Eip1193Provider)\n .with(Chain.Litecoin, () => window.vultisig?.litecoin as Eip1193Provider)\n .with(Chain.Solana, () => window.vultisig?.solana as SolanaProvider)\n .with(Chain.THORChain, () => window.vultisig?.thorchain as Eip1193Provider)\n .with(Chain.Maya, () => window.vultisig?.mayachain as Eip1193Provider)\n .with(Chain.Polkadot, () => window.vultisig?.polkadot as Eip1193Provider)\n .with(Chain.Ripple, () => window.vultisig?.ripple as Eip1193Provider)\n .with(Chain.Zcash, () => window.vultisig?.zcash as Eip1193Provider)\n .otherwise(() => undefined) as VultisigProviderType<T>;\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getVultisigProvider(chain);\n let finalParams: TransactionParams[] | { from: string; to?: string; value: string; data?: string }[] = params;\n\n if (chain === Chain.Cosmos || chain === Chain.Kujira || chain === Chain.Ripple) {\n finalParams = params.map((p) => ({\n data: p.data as string,\n from: p.from as string,\n to: p.to as string,\n value: (p.amount as { amount: number; decimals?: number }).amount.toString(),\n }));\n }\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params: finalParams }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getVultisigAddress(chain: Chain) {\n try {\n const eipProvider = (await getVultisigProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.VULTISIG } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getVultisigProvider(Chain.Cosmos);\n const chainId = ChainToChainId[chain];\n\n await provider.request({ method: \"wallet_switch_chain\", params: [{ chainId }] });\n\n let account = await provider.request({ method: \"get_accounts\" });\n if (!account) {\n const connectedAcount = await provider.request({ method: \"request_accounts\" });\n account = connectedAcount[0].address;\n }\n return account;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getVultisigProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.VULTISIG } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"send_transaction\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_vultisig_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getVultisigAddress(assetValue.chain);\n const params = [\n {\n amount: { 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 data: memo || \"\",\n from,\n gasLimit,\n to: recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n\nexport function getVultisigMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n abi: erc20ABI,\n contractAddress: assetAddress,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash;\n },\n call: async <T>({ contractAddress, abi, funcName, funcParams = [], txOverrides }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, from, to, data } = await createTx({ abi, contractAddress, funcName, funcParams, txOverrides });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_vultisig_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash;\n },\n };\n}\n\nexport async function switchCosmosWalletNetwork(\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n networkParams?: NetworkParams,\n) {\n try {\n await provider.request({ method: \"wallet_switch_chain\", params: [{ chainId: ChainToChainId[chain] }] });\n } catch (error) {\n if (!networkParams) {\n throw new SwapKitError(\"helpers_failed_to_switch_network\", {\n error: error,\n reason: \"networkParams not provided\",\n });\n }\n }\n}\n\nexport function wrapMethodWithNetworkSwitch<T extends (...args: any[]) => any>(\n func: T,\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n) {\n return (async (...args: any[]) => {\n try {\n await switchCosmosWalletNetwork(provider, chain);\n } catch (error) {\n throw new SwapKitError({ errorKey: \"helpers_failed_to_switch_network\", info: { error } });\n }\n return func(...args);\n }) as unknown as T;\n}\n\nexport function prepareNetworkSwitchCosmos<T extends Awaited<ReturnType<typeof getCosmosToolbox>>, M extends keyof T>({\n toolbox,\n chain,\n provider = window.ethereum,\n methodNames = [],\n}: {\n toolbox: T;\n chain: Chain;\n provider?: VultisigCosmosProvider;\n methodNames?: M[];\n}) {\n const methodsToWrap = [...methodNames, \"transfer\", \"getAddress\", \"getBalance\"] as M[];\n const wrappedMethods = methodsToWrap.reduce((object, methodName) => {\n if (!toolbox[methodName]) return object;\n\n const method = toolbox[methodName];\n\n if (typeof method !== \"function\") return object;\n\n // @ts-expect-error\n const wrappedMethod = wrapMethodWithNetworkSwitch(method, provider, chain);\n\n // biome-ignore lint/performance/noAccumulatingSpread: valid use case\n return { ...object, [methodName]: wrappedMethod };\n }, {});\n\n return { ...toolbox, ...wrappedMethods };\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "yFASO,IATP,8BAWA,kCCCO,IAZP,8BAaA,wCAqCA,eAAsB,CAAoC,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "CB7931C838DDDE6964756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as B,G as H}from"../../chunk-yqaz2d25.js";import{Chain as D,SwapKitError as M,UTXOChains as
|
|
1
|
+
import{F as B,G as H}from"../../chunk-yqaz2d25.js";import{Chain as D,filterSupportedChains as m,SwapKitError as M,UTXOChains as C,WalletOption as f}from"@swapkit/helpers";import{createWallet as p,getWalletSupportedChains as d}from"@swapkit/wallet-core";import{Chain as G,ChainToChainId as A,EVMChains as T,providerRequest as x,SwapKitError as _,WalletOption as k}from"@swapkit/helpers";import{erc20ABI as g}from"@swapkit/helpers/contracts";async function I(z){if(!window.vultisig)throw new _("wallet_vultisig_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(...T,()=>window.vultisig?.ethereum).with(G.Cosmos,G.Kujira,()=>window.vultisig?.cosmos).with(G.Bitcoin,()=>window.vultisig?.bitcoin).with(G.BitcoinCash,()=>window.vultisig?.bitcoincash).with(G.Dash,()=>window.vultisig?.dash).with(G.Dogecoin,()=>window.vultisig?.dogecoin).with(G.Litecoin,()=>window.vultisig?.litecoin).with(G.Solana,()=>window.vultisig?.solana).with(G.THORChain,()=>window.vultisig?.thorchain).with(G.Maya,()=>window.vultisig?.mayachain).with(G.Polkadot,()=>window.vultisig?.polkadot).with(G.Ripple,()=>window.vultisig?.ripple).with(G.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function v({method:z,params:Z,chain:J}){let F=await I(J),$=Z;if(J===G.Cosmos||J===G.Kujira||J===G.Ripple)$=Z.map((Q)=>({data:Q.data,from:Q.from,to:Q.to,value:Q.amount.amount.toString()}));return new Promise((Q,Y)=>{if(F&&"request"in F)F.request({method:z,params:$},(q,U)=>{q?Y(q):Q(U)})})}async function j(z){try{let Z=await I(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{chain:z,wallet:k.VULTISIG}});if([G.Cosmos,G.Kujira].includes(z)){let F=await I(G.Cosmos),$=A[z];await F.request({method:"wallet_switch_chain",params:[{chainId:$}]});let Q=await F.request({method:"get_accounts"});if(!Q)Q=(await F.request({method:"request_accounts"}))[0].address;return Q}if(T.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:F}=await import("ethers"),$=new F(Z,"any"),[Q]=await x({method:"eth_requestAccounts",params:[],provider:$});return Q}if(z===G.Solana)return(await(await I(G.Solana)).connect()).publicKey.toString();return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{chain:z,wallet:k.VULTISIG}})}}async function y({assetValue:z,recipient:Z,memo:J,gasLimit:F},$="send_transaction"){if(!z)throw new _("wallet_vultisig_asset_not_defined");let Q=await j(z.chain),Y=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},data:J||"",from:Q,gasLimit:F,to:Z}];return v({chain:z.chain,method:$,params:Y})}function P(z,Z){return{approve:async({assetAddress:J,spenderAddress:F,amount:$,from:Q})=>{let{MAX_APPROVAL:Y,getCreateContractTxObject:q}=await import("@swapkit/toolboxes/evm"),U=[F,BigInt($||Y)],R={abi:g,contractAddress:J,funcName:"approve",funcParams:U,txOverrides:{from:Q}},L=q({chain:Z,provider:z}),{value:O,to:K,data:W}=await L(R);return(await(await z.getSigner()).sendTransaction({data:W||"0x",from:Q,to:K,value:BigInt(O||0)})).hash},call:async({contractAddress:J,abi:F,funcName:$,funcParams:Q=[],txOverrides:Y})=>{if(!J)throw new _("wallet_vultisig_contract_address_not_provided");let{createContract:q,getCreateContractTxObject:U,isStateChangingCall:X}=await import("@swapkit/toolboxes/evm");if(X({abi:F,funcName:$})){let K=U({chain:Z,provider:z}),{value:W,from:N,to:S,data:b}=await K({abi:F,contractAddress:J,funcName:$,funcParams:Q,txOverrides:Y});return(await(await z.getSigner()).sendTransaction({data:b||"0x",from:N,to:S,value:BigInt(W||0)})).hash}let O=await q(J,F,z)[$]?.(...Q);return typeof O?.hash==="string"?O?.hash:O},sendTransaction:async(J)=>{let{from:F,to:$,data:Q,value:Y}=J;if(!$)throw new _("wallet_vultisig_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({data:Q||"0x",from:F,to:$,value:BigInt(Y||0)})).hash}}}async function w(z,Z,J){try{await z.request({method:"wallet_switch_chain",params:[{chainId:A[Z]}]})}catch(F){if(!J)throw new _("helpers_failed_to_switch_network",{error:F,reason:"networkParams not provided"})}}function u(z,Z,J){return async(...F)=>{try{await w(Z,J)}catch($){throw new _({errorKey:"helpers_failed_to_switch_network",info:{error:$}})}return z(...F)}}function V({toolbox:z,chain:Z,provider:J=window.ethereum,methodNames:F=[]}){let Q=[...F,"transfer","getAddress","getBalance"].reduce((Y,q)=>{if(!z[q])return Y;let U=z[q];if(typeof U!=="function")return Y;let X=u(U,J,Z);return{...Y,[q]:X}},{});return{...z,...Q}}var l=p({connect:({addChain:z,walletType:Z,supportedChains:J})=>async function F($){let Q=m({chains:$,supportedChains:J,walletType:Z}),Y=Q.filter((X)=>X!==D.Cosmos&&X!==D.Kujira).map(async(X)=>{let R=await j(X),L=await E(X);z({...L,address:R,chain:X,walletType:Z})}),q=Q.includes(D.Cosmos),U=Q.includes(D.Kujira);if(q){let X=await j(D.Cosmos),R=await E(D.Cosmos);z({...R,address:X,chain:D.Cosmos,walletType:Z})}if(U){let X=await j(D.Kujira),R=await E(D.Kujira);z({...R,address:X,chain:D.Kujira,walletType:Z})}return await Promise.all(Y),!0},name:"connectVultisig",supportedChains:[D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Bitcoin,D.BitcoinCash,D.Cosmos,D.Dash,D.Dogecoin,D.Ethereum,D.Kujira,D.Litecoin,D.Maya,D.Optimism,D.Polkadot,D.Polygon,D.Ripple,D.Solana,D.THORChain,D.Zcash],walletType:f.VULTISIG}),e=d(l);async function E(z){let{match:Z}=await import("ts-pattern");return Z(z).with(D.Solana,async()=>{let{getSolanaToolbox:J}=await import("@swapkit/toolboxes/solana"),F=window.vultisig?.solana;if(!F)throw new M("wallet_vultisig_not_found");return{...await J({signer:F})}}).with(D.Maya,D.THORChain,async()=>{let{getCosmosToolbox:J,THORCHAIN_GAS_VALUE:F,MAYA_GAS_VALUE:$}=await import("@swapkit/toolboxes/cosmos"),Q=z===D.Maya?$:F;return{...await J(z),deposit:(q)=>y({...q,recipient:""},"deposit_transaction"),transfer:(q)=>y({...q,gasLimit:Q},"send_transaction")}}).with(D.Cosmos,D.Kujira,async()=>{let{getCosmosToolbox:J}=await import("@swapkit/toolboxes/cosmos"),F=await I(z),$=await J(z);return V({chain:z,provider:F,toolbox:{...$,transfer:y}})}).with(...C,async()=>{let{getUtxoToolbox:J}=await import("@swapkit/toolboxes/utxo");return{...await J(z),transfer:y}}).with(D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Ethereum,D.Optimism,D.Polygon,async()=>{let{prepareNetworkSwitch:J,switchEVMWalletNetwork:F}=await import("@swapkit/helpers"),{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Q}=await import("ethers"),Y=await I(z);if(!Y)throw new M("wallet_vultisig_not_found");let q=new Q(Y,"any"),U=await q.getSigner(),X=await $(z,{provider:q,signer:U}),R=P(q,z);try{if(z!==D.Ethereum){let L=X.getNetworkParams();await F(q,z,L)}}catch(L){throw new M({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:z,wallet:f.VULTISIG}})}return J({chain:z,provider:q,toolbox:{...X,...R}})}).with(D.Ripple,async()=>{let{getRippleToolbox:J}=await import("@swapkit/toolboxes/ripple");return{...await J(),transfer:y}}).with(D.Polkadot,async()=>{let{getSubstrateToolbox:J}=await import("@swapkit/toolboxes/substrate");return{...await J(z),transfer:y}}).otherwise(async()=>null)}export{l as vultisigWallet,e as VULTISIG_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=B3A7BA6E3D1E20DF64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|