@swapkit/wallets 4.1.10 → 4.1.12
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-hjyak2y4.js → chunk-4a80xkcp.js} +2 -2
- package/dist/{chunk-23hnqbxw.js → chunk-dtr1yvx8.js} +2 -2
- package/dist/{chunk-23hnqbxw.js.map → chunk-dtr1yvx8.js.map} +1 -1
- package/dist/chunk-fxqrst6z.js +5 -0
- package/dist/{chunk-yqaz2d25.js.map → chunk-fxqrst6z.js.map} +1 -1
- package/dist/chunk-t3m5498m.js.map +1 -1
- package/dist/src/bitget/index.cjs +2 -2
- package/dist/src/bitget/index.cjs.map +2 -2
- package/dist/src/bitget/index.js +2 -2
- package/dist/src/bitget/index.js.map +2 -2
- package/dist/src/coinbase/index.cjs +2 -2
- package/dist/src/coinbase/index.cjs.map +2 -2
- package/dist/src/coinbase/index.js +2 -2
- package/dist/src/coinbase/index.js.map +2 -2
- package/dist/src/cosmostation/index.cjs +2 -2
- package/dist/src/cosmostation/index.cjs.map +2 -2
- package/dist/src/cosmostation/index.js +2 -2
- package/dist/src/cosmostation/index.js.map +2 -2
- package/dist/src/ctrl/index.cjs +2 -2
- package/dist/src/ctrl/index.cjs.map +3 -3
- package/dist/src/ctrl/index.js +2 -2
- package/dist/src/ctrl/index.js.map +3 -3
- package/dist/src/evm-extensions/index.cjs +2 -2
- package/dist/src/evm-extensions/index.cjs.map +2 -2
- package/dist/src/evm-extensions/index.js +2 -2
- package/dist/src/evm-extensions/index.js.map +2 -2
- package/dist/src/exodus/index.cjs +2 -2
- package/dist/src/exodus/index.cjs.map +2 -2
- package/dist/src/exodus/index.js +2 -2
- package/dist/src/exodus/index.js.map +2 -2
- package/dist/src/index.js +1 -1
- package/dist/src/keepkey-bex/index.cjs +2 -2
- package/dist/src/keepkey-bex/index.cjs.map +2 -2
- package/dist/src/keepkey-bex/index.js +2 -2
- package/dist/src/keepkey-bex/index.js.map +2 -2
- package/dist/src/keplr/index.cjs +2 -2
- package/dist/src/keplr/index.cjs.map +2 -2
- package/dist/src/keplr/index.js +2 -2
- package/dist/src/keplr/index.js.map +2 -2
- package/dist/src/okx/index.cjs +2 -2
- package/dist/src/okx/index.cjs.map +2 -2
- package/dist/src/okx/index.js +2 -2
- package/dist/src/okx/index.js.map +2 -2
- package/dist/src/onekey/index.cjs +2 -2
- package/dist/src/onekey/index.cjs.map +2 -2
- package/dist/src/onekey/index.js +2 -2
- package/dist/src/onekey/index.js.map +2 -2
- package/dist/src/phantom/index.cjs +2 -2
- package/dist/src/phantom/index.cjs.map +2 -2
- package/dist/src/phantom/index.js +2 -2
- package/dist/src/phantom/index.js.map +2 -2
- package/dist/src/polkadotjs/index.cjs +2 -2
- package/dist/src/polkadotjs/index.cjs.map +2 -2
- package/dist/src/polkadotjs/index.js +2 -2
- package/dist/src/polkadotjs/index.js.map +2 -2
- package/dist/src/radix/index.cjs +2 -2
- package/dist/src/radix/index.cjs.map +2 -2
- package/dist/src/radix/index.js +2 -2
- package/dist/src/radix/index.js.map +2 -2
- package/dist/src/talisman/index.cjs +2 -2
- package/dist/src/talisman/index.cjs.map +2 -2
- package/dist/src/talisman/index.js +2 -2
- package/dist/src/talisman/index.js.map +2 -2
- package/dist/src/tronlink/index.cjs +2 -2
- package/dist/src/tronlink/index.cjs.map +4 -4
- package/dist/src/tronlink/index.js +2 -2
- package/dist/src/tronlink/index.js.map +4 -4
- package/dist/src/vultisig/index.cjs +2 -2
- package/dist/src/vultisig/index.cjs.map +2 -2
- package/dist/src/vultisig/index.js +2 -2
- package/dist/src/vultisig/index.js.map +2 -2
- package/dist/src/walletconnect/index.cjs +2 -2
- package/dist/src/walletconnect/index.cjs.map +2 -2
- package/dist/src/walletconnect/index.js +2 -2
- package/dist/src/walletconnect/index.js.map +2 -2
- package/dist/src/xaman/index.cjs +2 -2
- package/dist/src/xaman/index.cjs.map +2 -2
- package/dist/src/xaman/index.js +2 -2
- package/dist/src/xaman/index.js.map +2 -2
- package/dist/types/ctrl/index.d.ts.map +1 -1
- package/dist/types/tronlink/helpers.d.ts +0 -4
- package/dist/types/tronlink/helpers.d.ts.map +1 -1
- package/dist/types/tronlink/types.d.ts +1 -5
- package/dist/types/tronlink/types.d.ts.map +1 -1
- package/package.json +8 -8
- package/dist/chunk-yqaz2d25.js +0 -5
- /package/dist/{chunk-hjyak2y4.js.map → chunk-4a80xkcp.js.map} +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var h={};f(h,{polkadotWallet:()=>i,POLKADOT_SUPPORTED_CHAINS:()=>_});module.exports=u(h);var t=require("@swapkit/helpers"),r=require("@swapkit/wallet-core"),i=r.createWallet({connect:({addChain:e,supportedChains:l,walletType:d})=>async function
|
|
1
|
+
var h={};f(h,{polkadotWallet:()=>i,POLKADOT_SUPPORTED_CHAINS:()=>_});module.exports=u(h);var t=require("@swapkit/helpers"),r=require("@swapkit/wallet-core"),i=r.createWallet({connect:({addChain:e,supportedChains:l,walletType:d})=>async function(s){let o=t.filterSupportedChains({chains:s,supportedChains:l,walletType:d});return await Promise.all(o.map(async(a)=>{let{address:c,...w}=await P(a);e({...w,address:c,chain:a,walletType:d})})),!0},name:"connectPolkadotJs",supportedChains:[t.Chain.Polkadot],walletType:t.WalletOption.POLKADOT_JS}),_=r.getWalletSupportedChains(i);async function P(e){switch(e){case t.Chain.Polkadot:{let{getSubstrateToolbox:l}=await import("@swapkit/toolboxes/substrate"),n=await window?.injectedWeb3?.["polkadot-js"]?.enable?.("polkadot-js");if(!n)throw new t.SwapKitError({errorKey:"wallet_polkadot_not_found",info:{chain:e}});let s=await l(e,{signer:n.signer}),[o]=await n.accounts.get();if(!o?.address)throw new t.SwapKitError({errorKey:"wallet_missing_params",info:{address:o?.address,wallet:t.WalletOption.POLKADOT_JS}});let a=s.convertAddress(o.address,0);return{...s,address:a,getAddress:()=>a}}default:throw new t.SwapKitError({errorKey:"wallet_chain_not_supported",info:{chain:e,wallet:t.WalletOption.POLKADOT_JS}})}}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=46EAF3480890C60364756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import { Chain, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nexport const polkadotWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectPolkadotJs(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const { address, ...walletMethods } = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectPolkadotJs\",\n supportedChains: [Chain.Polkadot],\n walletType: WalletOption.POLKADOT_JS,\n});\n\nexport const POLKADOT_SUPPORTED_CHAINS = getWalletSupportedChains(polkadotWallet);\n\nasync function getWalletMethods(chain: Chain) {\n switch (chain) {\n case Chain.Polkadot: {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const injectedExtension = window?.injectedWeb3?.[\"polkadot-js\"];\n\n const rawExtension = await injectedExtension?.enable?.(\"polkadot-js\");\n if (!rawExtension) {\n throw new SwapKitError({ errorKey: \"wallet_polkadot_not_found\", info: { chain } });\n }\n\n const toolbox = await getSubstrateToolbox(chain, { signer: rawExtension.signer });\n const [account] = await rawExtension.accounts.get();\n\n if (!account?.address) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address: account?.address, wallet: WalletOption.POLKADOT_JS },\n });\n }\n\n const address = toolbox.convertAddress(account.address, 0);\n return { ...toolbox, address, getAddress: () => address };\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.POLKADOT_JS },\n });\n }\n}\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "yFAAyE,IAAzE,8BACA,kCAEa,EAAiB,eAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "yFAAyE,IAAzE,8BACA,kCAEa,EAAiB,eAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAAgC,CAAC,EAAiB,CAChD,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAUpF,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAQ,aAAY,GAAkB,MAAM,EAAiB,CAAK,EAElE,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EAC1D,CACH,EAEO,IAEX,KAAM,oBACN,gBAAiB,CAAC,QAAM,QAAQ,EAChC,WAAY,eAAa,WAC3B,CAAC,EAEY,EAA4B,2BAAyB,CAAc,EAEhF,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,QAAM,SAAU,CACnB,IAAQ,uBAAwB,KAAa,wCAGvC,EAAe,MAFK,QAAQ,eAAe,gBAEH,SAAS,aAAa,EACpE,GAAI,CAAC,EACH,MAAM,IAAI,eAAa,CAAE,SAAU,4BAA6B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGnF,IAAM,EAAU,MAAM,EAAoB,EAAO,CAAE,OAAQ,EAAa,MAAO,CAAC,GACzE,GAAW,MAAM,EAAa,SAAS,IAAI,EAElD,GAAI,CAAC,GAAS,QACZ,MAAM,IAAI,eAAa,CACrB,SAAU,wBACV,KAAM,CAAE,QAAS,GAAS,QAAS,OAAQ,eAAa,WAAY,CACtE,CAAC,EAGH,IAAM,EAAU,EAAQ,eAAe,EAAQ,QAAS,CAAC,EACzD,MAAO,IAAK,EAAS,UAAS,WAAY,IAAM,CAAQ,CAC1D,SAGE,MAAM,IAAI,eAAa,CACrB,SAAU,6BACV,KAAM,CAAE,QAAO,OAAQ,eAAa,WAAY,CAClD,CAAC",
|
|
8
|
+
"debugId": "46EAF3480890C60364756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as p,G as u}from"../../chunk-
|
|
1
|
+
import{F as p,G as u}from"../../chunk-fxqrst6z.js";import{Chain as i,filterSupportedChains as f,SwapKitError as l,WalletOption as d}from"@swapkit/helpers";import{createWallet as _,getWalletSupportedChains as P}from"@swapkit/wallet-core";var h=_({connect:({addChain:t,supportedChains:s,walletType:r})=>async function(n){let e=f({chains:n,supportedChains:s,walletType:r});return await Promise.all(e.map(async(o)=>{let{address:c,...w}=await m(o);t({...w,address:c,chain:o,walletType:r})})),!0},name:"connectPolkadotJs",supportedChains:[i.Polkadot],walletType:d.POLKADOT_JS}),g=P(h);async function m(t){switch(t){case i.Polkadot:{let{getSubstrateToolbox:s}=await import("@swapkit/toolboxes/substrate"),a=await window?.injectedWeb3?.["polkadot-js"]?.enable?.("polkadot-js");if(!a)throw new l({errorKey:"wallet_polkadot_not_found",info:{chain:t}});let n=await s(t,{signer:a.signer}),[e]=await a.accounts.get();if(!e?.address)throw new l({errorKey:"wallet_missing_params",info:{address:e?.address,wallet:d.POLKADOT_JS}});let o=n.convertAddress(e.address,0);return{...n,address:o,getAddress:()=>o}}default:throw new l({errorKey:"wallet_chain_not_supported",info:{chain:t,wallet:d.POLKADOT_JS}})}}export{h as polkadotWallet,g as POLKADOT_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=1CBFA60D21FBDCB664756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import { Chain, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nexport const polkadotWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectPolkadotJs(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const { address, ...walletMethods } = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectPolkadotJs\",\n supportedChains: [Chain.Polkadot],\n walletType: WalletOption.POLKADOT_JS,\n});\n\nexport const POLKADOT_SUPPORTED_CHAINS = getWalletSupportedChains(polkadotWallet);\n\nasync function getWalletMethods(chain: Chain) {\n switch (chain) {\n case Chain.Polkadot: {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const injectedExtension = window?.injectedWeb3?.[\"polkadot-js\"];\n\n const rawExtension = await injectedExtension?.enable?.(\"polkadot-js\");\n if (!rawExtension) {\n throw new SwapKitError({ errorKey: \"wallet_polkadot_not_found\", info: { chain } });\n }\n\n const toolbox = await getSubstrateToolbox(chain, { signer: rawExtension.signer });\n const [account] = await rawExtension.accounts.get();\n\n if (!account?.address) {\n throw new SwapKitError({\n errorKey: \"wallet_missing_params\",\n info: { address: account?.address, wallet: WalletOption.POLKADOT_JS },\n });\n }\n\n const address = toolbox.convertAddress(account.address, 0);\n return { ...toolbox, address, getAddress: () => address };\n }\n\n default:\n throw new SwapKitError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.POLKADOT_JS },\n });\n }\n}\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "mDAAA,gBAAS,2BAAO,kBAAuB,kBAAc,yBACrD,uBAAS,8BAAc,6BAEhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "mDAAA,gBAAS,2BAAO,kBAAuB,kBAAc,yBACrD,uBAAS,8BAAc,6BAEhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAAgC,CAAC,EAAiB,CAChD,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAUpF,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAQ,aAAY,GAAkB,MAAM,EAAiB,CAAK,EAElE,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EAC1D,CACH,EAEO,IAEX,KAAM,oBACN,gBAAiB,CAAC,EAAM,QAAQ,EAChC,WAAY,EAAa,WAC3B,CAAC,EAEY,EAA4B,EAAyB,CAAc,EAEhF,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,EAAM,SAAU,CACnB,IAAQ,uBAAwB,KAAa,wCAGvC,EAAe,MAFK,QAAQ,eAAe,gBAEH,SAAS,aAAa,EACpE,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,CAAE,SAAU,4BAA6B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGnF,IAAM,EAAU,MAAM,EAAoB,EAAO,CAAE,OAAQ,EAAa,MAAO,CAAC,GACzE,GAAW,MAAM,EAAa,SAAS,IAAI,EAElD,GAAI,CAAC,GAAS,QACZ,MAAM,IAAI,EAAa,CACrB,SAAU,wBACV,KAAM,CAAE,QAAS,GAAS,QAAS,OAAQ,EAAa,WAAY,CACtE,CAAC,EAGH,IAAM,EAAU,EAAQ,eAAe,EAAQ,QAAS,CAAC,EACzD,MAAO,IAAK,EAAS,UAAS,WAAY,IAAM,CAAQ,CAC1D,SAGE,MAAM,IAAI,EAAa,CACrB,SAAU,6BACV,KAAM,CAAE,QAAO,OAAQ,EAAa,WAAY,CAClD,CAAC",
|
|
8
|
+
"debugId": "1CBFA60D21FBDCB664756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
package/dist/src/radix/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var k={};N(k,{radixWallet:()=>T,RADIX_SUPPORTED_CHAINS:()=>S});module.exports=I(k);var j=require("@swapkit/helpers"),_=require("@swapkit/wallet-core"),T=_.createWallet({connect:({addChain:M,supportedChains:L,walletType:J})=>async function
|
|
1
|
+
var k={};N(k,{radixWallet:()=>T,RADIX_SUPPORTED_CHAINS:()=>S});module.exports=I(k);var j=require("@swapkit/helpers"),_=require("@swapkit/wallet-core"),T=_.createWallet({connect:({addChain:M,supportedChains:L,walletType:J})=>async function(O){let Q=j.filterSupportedChains({chains:O,supportedChains:L,walletType:J});if(!j.SKConfig.get("integrations").radix)throw new j.SwapKitError("wallet_radix_not_found");return await Promise.all(Q.map(async(H)=>{let z=await h();M({...z,chain:H,walletType:J})})),!0},name:"connectRadixWallet",supportedChains:[j.Chain.Radix],walletType:j.WalletOption.RADIX_WALLET}),S=_.getWalletSupportedChains(T);async function x(M){let{GatewayApiClient:L}=await import("@radixdlt/babylon-gateway-api-sdk"),{applicationName:J}=j.SKConfig.get("integrations").radix,W=L.initialize({applicationName:J,networkId:1}),O=!0,Q,V=[],H=await B(W);while(O){let z={address:M,at_ledger_state:{state_version:H},cursor:Q,limit_per_page:100},U=await W.state.innerClient.entityFungiblesPage({stateEntityFungiblesPageRequest:z});if(V=V.concat(U.items),U.next_cursor)Q=U.next_cursor;else O=!1}return V}function B(M){return M.status.getCurrent().then((L)=>L.ledger_state.state_version)}async function C(M){let{GatewayApiClient:L}=await import("@radixdlt/babylon-gateway-api-sdk"),J=await x(M),{applicationName:W}=j.SKConfig.get("integrations").radix,O=L.initialize({applicationName:W,networkId:1}),Q=[],V=50,H=[];for(let z=0;z<J.length;z+=50)H.push(J.slice(z,z+50));for(let z of H){let U=z.map((K)=>K.resource_address),Y=await O.state.getEntityDetailsVaultAggregated(U),G=new Map;for(let K of Y)if(K.details!==void 0){let X=K.metadata?.items.find((q)=>q.key==="symbol"),$=X?.value.typed.type==="String"?X.value.typed.value:"?";if(K.details.type==="FungibleResource")G.set(K.address,{decimals:K.details.divisibility,symbol:$})}for(let K of z)if(K.aggregation_level==="Global"){let X=G.get(K.resource_address)||{decimals:0,symbol:"?"},$=j.AssetValue.from({asset:X.symbol!==j.Chain.Radix?`${j.Chain.Radix}.${X.symbol}-${K.resource_address}`:"XRD.XRD",value:K.amount});Q.push($)}}return Q}async function h(){let{RadixDappToolkit:M}=await import("@radixdlt/radix-dapp-toolkit"),L=j.SKConfig.get("integrations").radix,J=M({...L,networkId:L.network.networkId});function W(H){return new Promise((z)=>setTimeout(z,H))}await W(400);function O(){return J.walletApi.getWalletData()?.accounts?.[0]?.address}let Q=async()=>{let{DataRequestBuilder:H}=await import("@radixdlt/radix-dapp-toolkit");J.walletApi.setRequestData(H.accounts().exactly(1));let z=await J.walletApi.sendRequest();if(!z)throw new j.SwapKitError("wallet_radix_no_account");let U=z.unwrapOr(null)?.accounts[0]?.address;if(!U)throw new j.SwapKitError("wallet_radix_no_account");return U},V=O()||await Q();return{address:V,getAddress:O,getBalance:()=>C(V),radixDappToolkit:J,signAndBroadcast:async({manifest:H,message:z})=>{let Y=(await J.walletApi.sendTransaction({message:z,transactionManifest:H})).unwrapOr(null)?.transactionIntentHash;if(!Y)throw new j.SwapKitError("wallet_radix_transaction_failed");return Y},transfer:(H)=>{throw new j.SwapKitError("wallet_radix_method_not_supported",{method:"transfer"})}}}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=4D721A73D5B0F23A64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import type {\n FungibleResourcesCollectionItem,\n GatewayApiClient,\n StateEntityDetailsVaultResponseItem,\n StateEntityFungiblesPageRequest,\n StateEntityFungiblesPageResponse,\n} from \"@radixdlt/babylon-gateway-api-sdk\";\nimport { AssetValue, Chain, filterSupportedChains, SKConfig, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nexport const radixWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectRadixWallet(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const radixConfig = SKConfig.get(\"integrations\").radix;\n\n if (!radixConfig) {\n throw new SwapKitError(\"wallet_radix_not_found\");\n }\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods();\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectRadixWallet\",\n supportedChains: [Chain.Radix],\n walletType: WalletOption.RADIX_WALLET,\n});\n\nexport const RADIX_SUPPORTED_CHAINS = getWalletSupportedChains(radixWallet);\n\nasync function fetchFungibleResources(address: string): Promise<FungibleResourcesCollectionItem[]> {\n const { GatewayApiClient } = await import(\"@radixdlt/babylon-gateway-api-sdk\");\n const { applicationName } = SKConfig.get(\"integrations\").radix;\n const networkApi = GatewayApiClient.initialize({ applicationName, networkId: 1 });\n\n let hasNextPage = true;\n let nextCursor: string | undefined;\n let fungibleResources: FungibleResourcesCollectionItem[] = [];\n\n const stateVersion = await currentStateVersion(networkApi);\n\n while (hasNextPage) {\n const stateEntityFungiblesPageRequest: StateEntityFungiblesPageRequest = {\n address: address,\n at_ledger_state: { state_version: stateVersion },\n cursor: nextCursor,\n limit_per_page: 100,\n };\n\n const stateEntityFungiblesPageResponse: StateEntityFungiblesPageResponse =\n await networkApi.state.innerClient.entityFungiblesPage({\n stateEntityFungiblesPageRequest: stateEntityFungiblesPageRequest,\n });\n\n fungibleResources = fungibleResources.concat(stateEntityFungiblesPageResponse.items);\n\n if (stateEntityFungiblesPageResponse.next_cursor) {\n nextCursor = stateEntityFungiblesPageResponse.next_cursor;\n } else {\n hasNextPage = false;\n }\n }\n return fungibleResources;\n}\n\nfunction currentStateVersion(networkApi: GatewayApiClient) {\n return networkApi.status.getCurrent().then((status) => status.ledger_state.state_version);\n}\n\n// TODO - @Towan: is that still needed with SwapKitApi.getChainBalance()?\nasync function getBalance(address: string): Promise<AssetValue[]> {\n const { GatewayApiClient } = await import(\"@radixdlt/babylon-gateway-api-sdk\");\n const resources = await fetchFungibleResources(address);\n const { applicationName } = SKConfig.get(\"integrations\").radix;\n const networkApi = GatewayApiClient.initialize({ applicationName, networkId: 1 });\n\n const balances: AssetValue[] = [];\n const BATCH_SIZE = 50;\n\n // Split resources into batches of up to 50 items\n const resourceBatches: FungibleResourcesCollectionItem[][] = [];\n for (let i = 0; i < resources.length; i += BATCH_SIZE) {\n resourceBatches.push(resources.slice(i, i + BATCH_SIZE));\n }\n\n for (const batch of resourceBatches) {\n const addresses = batch.map((item) => item.resource_address);\n const response: StateEntityDetailsVaultResponseItem[] =\n await networkApi.state.getEntityDetailsVaultAggregated(addresses);\n\n const divisibilities = new Map<string, { decimals: number; symbol: string }>();\n\n for (const result of response) {\n if (result.details !== undefined) {\n const metaDataSymbol = result.metadata?.items.find((item) => item.key === \"symbol\");\n const symbol = metaDataSymbol?.value.typed.type === \"String\" ? metaDataSymbol.value.typed.value : \"?\";\n\n if (result.details.type === \"FungibleResource\") {\n divisibilities.set(result.address, { decimals: result.details.divisibility, symbol });\n }\n }\n }\n\n for (const item of batch) {\n if (item.aggregation_level === \"Global\") {\n const assetInfo = divisibilities.get(item.resource_address) || { decimals: 0, symbol: \"?\" };\n\n const balance = AssetValue.from({\n asset:\n assetInfo.symbol !== Chain.Radix\n ? `${Chain.Radix}.${assetInfo.symbol}-${item.resource_address}`\n : \"XRD.XRD\",\n value: item.amount,\n });\n balances.push(balance);\n }\n }\n }\n\n return balances;\n}\n\nasync function getWalletMethods() {\n const { RadixDappToolkit } = await import(\"@radixdlt/radix-dapp-toolkit\");\n const dappConfig = SKConfig.get(\"integrations\").radix;\n const rdt = RadixDappToolkit({ ...dappConfig, networkId: dappConfig.network.networkId });\n\n function delay(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n // TODO: @Towan - Wat is dat?\n await delay(400);\n\n function getAddress() {\n const existingWalletData = rdt.walletApi.getWalletData();\n const account = existingWalletData?.accounts?.[0];\n\n return account?.address;\n }\n\n const getNewAddress = async () => {\n const { DataRequestBuilder } = await import(\"@radixdlt/radix-dapp-toolkit\");\n rdt.walletApi.setRequestData(DataRequestBuilder.accounts().exactly(1));\n const res = await rdt.walletApi.sendRequest();\n\n if (!res) {\n throw new SwapKitError(\"wallet_radix_no_account\");\n }\n\n const newAddress = res.unwrapOr(null)?.accounts[0]?.address;\n\n if (!newAddress) {\n throw new SwapKitError(\"wallet_radix_no_account\");\n }\n\n return newAddress;\n };\n\n const address = getAddress() || (await getNewAddress());\n\n return {\n address,\n getAddress,\n getBalance: () => getBalance(address),\n radixDappToolkit: rdt,\n signAndBroadcast: async ({ manifest, message }: { manifest: string; message: string }) => {\n const tx = await rdt.walletApi.sendTransaction({ message, transactionManifest: manifest });\n\n const txResult = tx.unwrapOr(null)?.transactionIntentHash;\n\n if (!txResult) {\n throw new SwapKitError(\"wallet_radix_transaction_failed\");\n }\n\n return txResult;\n },\n transfer: (_params: { assetValue: AssetValue; recipient: string; from: string }) => {\n throw new SwapKitError(\"wallet_radix_method_not_supported\", { method: \"transfer\" });\n },\n };\n}\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "mFAO+F,IAA/F,8BACA,kCAEa,EAAc,eAAa,CACtC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "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",
|
|
8
|
+
"debugId": "4D721A73D5B0F23A64756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
package/dist/src/radix/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as _,G as $}from"../../chunk-
|
|
1
|
+
import{F as _,G as $}from"../../chunk-fxqrst6z.js";import{AssetValue as N,Chain as T,filterSupportedChains as S,SKConfig as Y,SwapKitError as X,WalletOption as x}from"@swapkit/helpers";import{createWallet as B,getWalletSupportedChains as C}from"@swapkit/wallet-core";var h=B({connect:({addChain:L,supportedChains:K,walletType:H})=>async function(M){let O=S({chains:M,supportedChains:K,walletType:H});if(!Y.get("integrations").radix)throw new X("wallet_radix_not_found");return await Promise.all(O.map(async(z)=>{let j=await E();L({...j,chain:z,walletType:H})})),!0},name:"connectRadixWallet",supportedChains:[T.Radix],walletType:x.RADIX_WALLET}),f=C(h);async function k(L){let{GatewayApiClient:K}=await import("@radixdlt/babylon-gateway-api-sdk"),{applicationName:H}=Y.get("integrations").radix,V=K.initialize({applicationName:H,networkId:1}),M=!0,O,U=[],z=await v(V);while(M){let j={address:L,at_ledger_state:{state_version:z},cursor:O,limit_per_page:100},Q=await V.state.innerClient.entityFungiblesPage({stateEntityFungiblesPageRequest:j});if(U=U.concat(Q.items),Q.next_cursor)O=Q.next_cursor;else M=!1}return U}function v(L){return L.status.getCurrent().then((K)=>K.ledger_state.state_version)}async function D(L){let{GatewayApiClient:K}=await import("@radixdlt/babylon-gateway-api-sdk"),H=await k(L),{applicationName:V}=Y.get("integrations").radix,M=K.initialize({applicationName:V,networkId:1}),O=[],U=50,z=[];for(let j=0;j<H.length;j+=50)z.push(H.slice(j,j+50));for(let j of z){let Q=j.map((J)=>J.resource_address),Z=await M.state.getEntityDetailsVaultAggregated(Q),q=new Map;for(let J of Z)if(J.details!==void 0){let W=J.metadata?.items.find((I)=>I.key==="symbol"),G=W?.value.typed.type==="String"?W.value.typed.value:"?";if(J.details.type==="FungibleResource")q.set(J.address,{decimals:J.details.divisibility,symbol:G})}for(let J of j)if(J.aggregation_level==="Global"){let W=q.get(J.resource_address)||{decimals:0,symbol:"?"},G=N.from({asset:W.symbol!==T.Radix?`${T.Radix}.${W.symbol}-${J.resource_address}`:"XRD.XRD",value:J.amount});O.push(G)}}return O}async function E(){let{RadixDappToolkit:L}=await import("@radixdlt/radix-dapp-toolkit"),K=Y.get("integrations").radix,H=L({...K,networkId:K.network.networkId});function V(z){return new Promise((j)=>setTimeout(j,z))}await V(400);function M(){return H.walletApi.getWalletData()?.accounts?.[0]?.address}let O=async()=>{let{DataRequestBuilder:z}=await import("@radixdlt/radix-dapp-toolkit");H.walletApi.setRequestData(z.accounts().exactly(1));let j=await H.walletApi.sendRequest();if(!j)throw new X("wallet_radix_no_account");let Q=j.unwrapOr(null)?.accounts[0]?.address;if(!Q)throw new X("wallet_radix_no_account");return Q},U=M()||await O();return{address:U,getAddress:M,getBalance:()=>D(U),radixDappToolkit:H,signAndBroadcast:async({manifest:z,message:j})=>{let Z=(await H.walletApi.sendTransaction({message:j,transactionManifest:z})).unwrapOr(null)?.transactionIntentHash;if(!Z)throw new X("wallet_radix_transaction_failed");return Z},transfer:(z)=>{throw new X("wallet_radix_method_not_supported",{method:"transfer"})}}}export{h as radixWallet,f as RADIX_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=58A0CFCA38DE936164756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import type {\n FungibleResourcesCollectionItem,\n GatewayApiClient,\n StateEntityDetailsVaultResponseItem,\n StateEntityFungiblesPageRequest,\n StateEntityFungiblesPageResponse,\n} from \"@radixdlt/babylon-gateway-api-sdk\";\nimport { AssetValue, Chain, filterSupportedChains, SKConfig, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nexport const radixWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectRadixWallet(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const radixConfig = SKConfig.get(\"integrations\").radix;\n\n if (!radixConfig) {\n throw new SwapKitError(\"wallet_radix_not_found\");\n }\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods();\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectRadixWallet\",\n supportedChains: [Chain.Radix],\n walletType: WalletOption.RADIX_WALLET,\n});\n\nexport const RADIX_SUPPORTED_CHAINS = getWalletSupportedChains(radixWallet);\n\nasync function fetchFungibleResources(address: string): Promise<FungibleResourcesCollectionItem[]> {\n const { GatewayApiClient } = await import(\"@radixdlt/babylon-gateway-api-sdk\");\n const { applicationName } = SKConfig.get(\"integrations\").radix;\n const networkApi = GatewayApiClient.initialize({ applicationName, networkId: 1 });\n\n let hasNextPage = true;\n let nextCursor: string | undefined;\n let fungibleResources: FungibleResourcesCollectionItem[] = [];\n\n const stateVersion = await currentStateVersion(networkApi);\n\n while (hasNextPage) {\n const stateEntityFungiblesPageRequest: StateEntityFungiblesPageRequest = {\n address: address,\n at_ledger_state: { state_version: stateVersion },\n cursor: nextCursor,\n limit_per_page: 100,\n };\n\n const stateEntityFungiblesPageResponse: StateEntityFungiblesPageResponse =\n await networkApi.state.innerClient.entityFungiblesPage({\n stateEntityFungiblesPageRequest: stateEntityFungiblesPageRequest,\n });\n\n fungibleResources = fungibleResources.concat(stateEntityFungiblesPageResponse.items);\n\n if (stateEntityFungiblesPageResponse.next_cursor) {\n nextCursor = stateEntityFungiblesPageResponse.next_cursor;\n } else {\n hasNextPage = false;\n }\n }\n return fungibleResources;\n}\n\nfunction currentStateVersion(networkApi: GatewayApiClient) {\n return networkApi.status.getCurrent().then((status) => status.ledger_state.state_version);\n}\n\n// TODO - @Towan: is that still needed with SwapKitApi.getChainBalance()?\nasync function getBalance(address: string): Promise<AssetValue[]> {\n const { GatewayApiClient } = await import(\"@radixdlt/babylon-gateway-api-sdk\");\n const resources = await fetchFungibleResources(address);\n const { applicationName } = SKConfig.get(\"integrations\").radix;\n const networkApi = GatewayApiClient.initialize({ applicationName, networkId: 1 });\n\n const balances: AssetValue[] = [];\n const BATCH_SIZE = 50;\n\n // Split resources into batches of up to 50 items\n const resourceBatches: FungibleResourcesCollectionItem[][] = [];\n for (let i = 0; i < resources.length; i += BATCH_SIZE) {\n resourceBatches.push(resources.slice(i, i + BATCH_SIZE));\n }\n\n for (const batch of resourceBatches) {\n const addresses = batch.map((item) => item.resource_address);\n const response: StateEntityDetailsVaultResponseItem[] =\n await networkApi.state.getEntityDetailsVaultAggregated(addresses);\n\n const divisibilities = new Map<string, { decimals: number; symbol: string }>();\n\n for (const result of response) {\n if (result.details !== undefined) {\n const metaDataSymbol = result.metadata?.items.find((item) => item.key === \"symbol\");\n const symbol = metaDataSymbol?.value.typed.type === \"String\" ? metaDataSymbol.value.typed.value : \"?\";\n\n if (result.details.type === \"FungibleResource\") {\n divisibilities.set(result.address, { decimals: result.details.divisibility, symbol });\n }\n }\n }\n\n for (const item of batch) {\n if (item.aggregation_level === \"Global\") {\n const assetInfo = divisibilities.get(item.resource_address) || { decimals: 0, symbol: \"?\" };\n\n const balance = AssetValue.from({\n asset:\n assetInfo.symbol !== Chain.Radix\n ? `${Chain.Radix}.${assetInfo.symbol}-${item.resource_address}`\n : \"XRD.XRD\",\n value: item.amount,\n });\n balances.push(balance);\n }\n }\n }\n\n return balances;\n}\n\nasync function getWalletMethods() {\n const { RadixDappToolkit } = await import(\"@radixdlt/radix-dapp-toolkit\");\n const dappConfig = SKConfig.get(\"integrations\").radix;\n const rdt = RadixDappToolkit({ ...dappConfig, networkId: dappConfig.network.networkId });\n\n function delay(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n // TODO: @Towan - Wat is dat?\n await delay(400);\n\n function getAddress() {\n const existingWalletData = rdt.walletApi.getWalletData();\n const account = existingWalletData?.accounts?.[0];\n\n return account?.address;\n }\n\n const getNewAddress = async () => {\n const { DataRequestBuilder } = await import(\"@radixdlt/radix-dapp-toolkit\");\n rdt.walletApi.setRequestData(DataRequestBuilder.accounts().exactly(1));\n const res = await rdt.walletApi.sendRequest();\n\n if (!res) {\n throw new SwapKitError(\"wallet_radix_no_account\");\n }\n\n const newAddress = res.unwrapOr(null)?.accounts[0]?.address;\n\n if (!newAddress) {\n throw new SwapKitError(\"wallet_radix_no_account\");\n }\n\n return newAddress;\n };\n\n const address = getAddress() || (await getNewAddress());\n\n return {\n address,\n getAddress,\n getBalance: () => getBalance(address),\n radixDappToolkit: rdt,\n signAndBroadcast: async ({ manifest, message }: { manifest: string; message: string }) => {\n const tx = await rdt.walletApi.sendTransaction({ message, transactionManifest: manifest });\n\n const txResult = tx.unwrapOr(null)?.transactionIntentHash;\n\n if (!txResult) {\n throw new SwapKitError(\"wallet_radix_transaction_failed\");\n }\n\n return txResult;\n },\n transfer: (_params: { assetValue: AssetValue; recipient: string; from: string }) => {\n throw new SwapKitError(\"wallet_radix_method_not_supported\", { method: \"transfer\" });\n },\n };\n}\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "mDAOA,qBAAS,WAAY,2BAAO,cAAuB,kBAAU,kBAAc,yBAC3E,uBAAS,8BAAc,6BAEhB,IAAM,EAAc,EAAa,CACtC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "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",
|
|
8
|
+
"debugId": "58A0CFCA38DE936164756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _={};p(_,{talismanWallet:()=>d,TALISMAN_SUPPORTED_CHAINS:()=>h});module.exports=m(_);var t=require("@swapkit/helpers"),l=require("@swapkit/wallet-core"),d=l.createWallet({connect:({addChain:e,supportedChains:a,walletType:r})=>async function
|
|
1
|
+
var _={};p(_,{talismanWallet:()=>d,TALISMAN_SUPPORTED_CHAINS:()=>h});module.exports=m(_);var t=require("@swapkit/helpers"),l=require("@swapkit/wallet-core"),d=l.createWallet({connect:({addChain:e,supportedChains:a,walletType:r})=>async function(o){let i=t.filterSupportedChains({chains:o,supportedChains:a,walletType:r});return await Promise.all(i.map(async(n)=>{let s=await u(n);e({...s,chain:n,walletType:r})})),!0},name:"connectTalisman",supportedChains:[t.Chain.Ethereum,t.Chain.Arbitrum,t.Chain.Avalanche,t.Chain.Base,t.Chain.Polygon,t.Chain.BinanceSmartChain,t.Chain.Optimism,t.Chain.Polkadot,t.Chain.Chainflip],walletType:t.WalletOption.TALISMAN}),h=l.getWalletSupportedChains(d);async function f({walletProvider:e,chain:a}){let{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:w}=await import("ethers");if(!e)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:a,wallet:t.WalletOption.TALISMAN}});let o=new w(e,"any"),i=await o.getSigner(),n=await r(a,{provider:o,signer:i});try{if(a!==t.Chain.Ethereum)await t.switchEVMWalletNetwork(o,a,n.getNetworkParams())}catch(s){throw new t.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:a,wallet:t.WalletOption.TALISMAN}})}return t.prepareNetworkSwitch({chain:a,provider:o,toolbox:n})}async function u(e){switch(e){case t.Chain.Ethereum:case t.Chain.Arbitrum:case t.Chain.Optimism:case t.Chain.Polygon:case t.Chain.Avalanche:case t.Chain.BinanceSmartChain:case t.Chain.Base:{if(!(window.talismanEth&&("send"in window.talismanEth)))throw new t.SwapKitError({errorKey:"wallet_talisman_not_found",info:{chain:e}});let a=await f({chain:e,walletProvider:window.talismanEth}),r=(await window.talismanEth.send("eth_requestAccounts",[]))[0];return{...a,address:r}}case t.Chain.Polkadot:case t.Chain.Chainflip:{let{getSubstrateToolbox:a,SubstrateNetwork:r}=await import("@swapkit/toolboxes/substrate"),o=await window?.injectedWeb3?.talisman?.enable?.("talisman");if(!o)throw new t.SwapKitError({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 t.SwapKitError({errorKey:"wallet_missing_params",info:{accounts:n,address:n[0]?.address,wallet:t.WalletOption.TALISMAN}});let s=i.convertAddress(n[0].address,r[e].prefix);return{...i,address:s}}default:throw new t.SwapKitError({errorKey:"wallet_chain_not_supported",info:{chain:e,wallet:t.WalletOption.TALISMAN}})}}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=381BF35F5A11DF6764756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"sourcesContent": [
|
|
5
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": "yFAQO,IARP,8BASA,kCAGa,EAAiB,eAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "yFAQO,IARP,8BASA,kCAGa,EAAiB,eAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAA8B,CAAC,EAAiB,CAC9C,IAAM,EAAiB,wBAAsB,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,QAAM,SACN,QAAM,SACN,QAAM,UACN,QAAM,KACN,QAAM,QACN,QAAM,kBACN,QAAM,SACN,QAAM,SACN,QAAM,SACR,EACA,WAAY,eAAa,QAC3B,CAAC,EAEY,EAA4B,2BAAyB,CAAc,EAEhF,eAAe,CAAoB,EACjC,iBACA,SAIC,CACD,IAAQ,iBAAkB,KAAa,mCAC/B,mBAAoB,KAAa,kBAEzC,GAAI,CAAC,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,QAAM,SAClB,MAAM,yBAAuB,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,uBAAqB,CAAE,QAAO,WAAU,SAAQ,CAAC,EAG1D,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,QAAM,cACN,QAAM,cACN,QAAM,cACN,QAAM,aACN,QAAM,eACN,QAAM,uBACN,QAAM,KAAM,CACf,GAAI,EAAE,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,QAAM,cACN,QAAM,UAAW,CACpB,IAAQ,sBAAqB,oBAAqB,KAAa,wCAGzD,EAAe,MADK,QAAQ,cAAc,UACF,SAAS,UAAU,EAEjE,GAAI,CAAC,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,GAAI,CAAC,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": "381BF35F5A11DF6764756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as d,G as m}from"../../chunk-
|
|
1
|
+
import{F as d,G as m}from"../../chunk-fxqrst6z.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(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=45D6521B7BDF245664756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"sourcesContent": [
|
|
5
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,2BAEA,0BACA,kBACA,4BACA,kBACA,yBAEF,uBAAS,8BAAc,6BAGhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "mDAAA,gBACE,2BAEA,0BACA,kBACA,4BACA,kBACA,yBAEF,uBAAS,8BAAc,6BAGhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAA8B,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,GAAI,CAAC,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,GAAI,EAAE,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,GAAI,CAAC,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,GAAI,CAAC,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": "45D6521B7BDF245664756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var A={};v(A,{waitForTronLink:()=>l,verifyNetwork:()=>b,tronlinkWallet:()=>k,setupEventListeners:()=>m,isTronLinkLocked:()=>_,getWalletForChain:()=>g,getExpectedTronNetwork:()=>T,TronLinkResponseCode:()=>f,TRONLINK_SUPPORTED_CHAINS:()=>y});module.exports=S(A);var c=require("@swapkit/helpers"),d=require("@swapkit/wallet-core");var i=require("@swapkit/helpers"),L=require("@swapkit/toolboxes/tron");var f;((o)=>{o[o.SUCCESS=200]="SUCCESS";o[o.LOCKED=4000]="LOCKED";o[o.REJECTED=4001]="REJECTED";o[o.UNAUTHORIZED=4100]="UNAUTHORIZED";o[o.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";o[o.DISCONNECTED=4900]="DISCONNECTED";o[o.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(f||={});function l(n=3000){return new Promise((t,r)=>{let e=!1,s=()=>{if(e)return;if(e=!0,window.removeEventListener("tronlink#initialized",s),a)clearTimeout(a);if(window.tronLink)t(window.tronLink);else r(new i.SwapKitError("wallet_provider_not_found",{wallet:i.WalletOption.TRONLINK}))};if(window.tronLink){t(window.tronLink);return}window.addEventListener("tronlink#initialized",s,{once:!0});let a=setTimeout(s,n)})}async function _(){try{let n=await l(1000),t=Boolean(n.tronWeb?.defaultAddress?.base58),r=n.ready===!1,e=Boolean(n.tronWeb&&typeof n.tronWeb.trx==="object"&&typeof n.tronWeb.trx.sign==="function");return!t&&(r||!e)}catch{return!1}}async function x(n){let t=await n.request({method:"tron_requestAccounts"});if(t==="")throw new i.SwapKitError("wallet_tronlink_locked",{message:"TronLink is locked. Please unlock it to continue.",wallet:i.WalletOption.TRONLINK});if(t.code!==200)throw new i.SwapKitError("wallet_tronlink_request_accounts_failed",{code:t.code,message:`TronLink requestAccounts failed: ${t.message}`})}async function g(n,t){if(n!==i.Chain.Tron)throw new i.SwapKitError("wallet_chain_not_supported",{chain:n,wallet:i.WalletOption.TRONLINK});let r=await l();await _()&&await x(r);let s=r.tronWeb?.defaultAddress?.base58;if(t)b(t);return{...await L.createTronToolbox({signer:{getAddress:async()=>s,signTransaction:async(o)=>{return await r.tronWeb.trx.sign(o)}}}),address:s}}function m(n,t){let r=(e)=>{switch(e.data?.message?.action){case"setAccount":{let a=e.data.message.data.address;if(n){n(a);return}window.location.reload();return}case"setNode":{let a=e.data.message.data.node;if(t)t(a.fullNode);window.location.reload();return}default:return}};return window.addEventListener("message",r),()=>window.removeEventListener("message",r)}function b(n){let t=window.tronLink;if(!t)throw new i.SwapKitError("wallet_provider_not_found",{wallet:i.WalletOption.TRONLINK});let r=t.tronWeb.fullNode?.host;if(r&&!r.includes(n))throw new i.SwapKitError("wallet_failed_to_add_or_switch_network",{currentNetwork:r,expectedNetwork:n,message:`Wrong network. Please switch to ${n} in TronLink.`,wallet:i.WalletOption.TRONLINK})}function T(n=!1){return n?"shasta":"api.trongrid.io"}var k=d.createWallet({connect:({addChain:n,supportedChains:t,walletType:r})=>async function(s){if(c.filterSupportedChains({chains:s,supportedChains:t,walletType:r}).length===0)throw Error("TronLink wallet only supports Tron chain");let u=T(!1),o=await g(c.Chain.Tron,u),E=o.address,N=m((w)=>{if(w!==E)window.location.reload()},(w)=>{if(!w.includes(u))window.location.reload()}),W=()=>{N()};return n({...o,balance:[],chain:c.Chain.Tron,disconnect:W,walletType:r}),!0},name:"connectTronLink",supportedChains:[c.Chain.Tron],walletType:c.WalletOption.TRONLINK}),y=d.getWalletSupportedChains(k);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=6A107E3EA1E626BE64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -3,10 +3,10 @@
|
|
|
3
3
|
"sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
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 {
|
|
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
|
|
6
|
+
"import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createTronToolbox, type TronSigner, 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 isReadyFalse = 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 && (isReadyFalse || !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\", {\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 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: TronSigner = {\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": "oQAA2D,IAA3D,8BACA,kCCDkD,IAAlD,8BACA,qCCwBO,IAAK,GAAL,CAAK,IAAL,CACL,YAAU,KAAV,UACA,WAAS,MAAT,SACA,aAAW,MAAX,WACA,iBAAe,MAAf,eACA,uBAAqB,MAArB,qBACA,iBAAe,MAAf,eACA,uBAAqB,MAArB,uBAPU,QDpBL,SAAS,CAAe,CAAC,EAAU,KAA+B,CACvE,OAAO,IAAI,QAAQ,CAAC,EAAS,IAAW,CACtC,IAAI,EAAU,GAER,EAAiB,IAAM,CAC3B,GAAI,EAAS,OAGb,GAFA,EAAU,GACV,OAAO,oBAAoB,uBAAwB,CAAc,EAC7D,EAAW,aAAa,CAAS,EAErC,GAAI,OAAO,SACT,EAAQ,OAAO,QAAQ,EAEvB,OAAO,IAAI,eAAa,4BAA6B,CAAE,OAAQ,eAAa,QAAS,CAAC,CAAC,
|
|
10
|
-
"debugId": "
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "6A107E3EA1E626BE64756E2164756E21",
|
|
11
11
|
"names": []
|
|
12
12
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import"../../chunk-
|
|
1
|
+
import"../../chunk-fxqrst6z.js";import{Chain as w,filterSupportedChains as S,WalletOption as v}from"@swapkit/helpers";import{createWallet as y,getWalletSupportedChains as A}from"@swapkit/wallet-core";import{Chain as k,SwapKitError as a,WalletOption as c}from"@swapkit/helpers";import{createTronToolbox as E}from"@swapkit/toolboxes/tron";var f;((o)=>{o[o.SUCCESS=200]="SUCCESS";o[o.LOCKED=4000]="LOCKED";o[o.REJECTED=4001]="REJECTED";o[o.UNAUTHORIZED=4100]="UNAUTHORIZED";o[o.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";o[o.DISCONNECTED=4900]="DISCONNECTED";o[o.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(f||={});function l(n=3000){return new Promise((t,r)=>{let i=!1,e=()=>{if(i)return;if(i=!0,window.removeEventListener("tronlink#initialized",e),s)clearTimeout(s);if(window.tronLink)t(window.tronLink);else r(new a("wallet_provider_not_found",{wallet:c.TRONLINK}))};if(window.tronLink){t(window.tronLink);return}window.addEventListener("tronlink#initialized",e,{once:!0});let s=setTimeout(e,n)})}async function N(){try{let n=await l(1000),t=Boolean(n.tronWeb?.defaultAddress?.base58),r=n.ready===!1,i=Boolean(n.tronWeb&&typeof n.tronWeb.trx==="object"&&typeof n.tronWeb.trx.sign==="function");return!t&&(r||!i)}catch{return!1}}async function W(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.",wallet:c.TRONLINK});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!==k.Tron)throw new a("wallet_chain_not_supported",{chain:n,wallet:c.TRONLINK});let r=await l();await N()&&await W(r);let e=r.tronWeb?.defaultAddress?.base58;if(t)x(t);return{...await E({signer:{getAddress:async()=>e,signTransaction:async(o)=>{return await r.tronWeb.trx.sign(o)}}}),address:e}}function m(n,t){let r=(i)=>{switch(i.data?.message?.action){case"setAccount":{let s=i.data.message.data.address;if(n){n(s);return}window.location.reload();return}case"setNode":{let s=i.data.message.data.node;if(t)t(s.fullNode);window.location.reload();return}default:return}};return window.addEventListener("message",r),()=>window.removeEventListener("message",r)}function x(n){let t=window.tronLink;if(!t)throw new a("wallet_provider_not_found",{wallet:c.TRONLINK});let r=t.tronWeb.fullNode?.host;if(r&&!r.includes(n))throw new a("wallet_failed_to_add_or_switch_network",{currentNetwork:r,expectedNetwork:n,message:`Wrong network. Please switch to ${n} in TronLink.`,wallet:c.TRONLINK})}function T(n=!1){return n?"shasta":"api.trongrid.io"}var D=y({connect:({addChain:n,supportedChains:t,walletType:r})=>async function(e){if(S({chains:e,supportedChains:t,walletType:r}).length===0)throw Error("TronLink wallet only supports Tron chain");let d=T(!1),o=await g(w.Tron,d),L=o.address,_=m((u)=>{if(u!==L)window.location.reload()},(u)=>{if(!u.includes(d))window.location.reload()}),b=()=>{_()};return n({...o,balance:[],chain:w.Tron,disconnect:b,walletType:r}),!0},name:"connectTronLink",supportedChains:[w.Tron],walletType:v.TRONLINK}),B=A(D);export{l as waitForTronLink,x as verifyNetwork,D as tronlinkWallet,m as setupEventListeners,N as isTronLinkLocked,g as getWalletForChain,T as getExpectedTronNetwork,f as TronLinkResponseCode,B as TRONLINK_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=429432B3F2578DF864756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -3,10 +3,10 @@
|
|
|
3
3
|
"sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
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 {
|
|
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
|
|
6
|
+
"import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createTronToolbox, type TronSigner, 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 isReadyFalse = 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 && (isReadyFalse || !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\", {\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 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: TronSigner = {\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": "gCAAA,gBAAS,2BAAO,kBAAuB,yBACvC,uBAAS,8BAAc,6BCDvB,gBAAS,kBAAO,kBAAc,yBAC9B,4BAAS,gCCwBF,IAAK,GAAL,CAAK,IAAL,CACL,YAAU,KAAV,UACA,WAAS,MAAT,SACA,aAAW,MAAX,WACA,iBAAe,MAAf,eACA,uBAAqB,MAArB,qBACA,iBAAe,MAAf,eACA,uBAAqB,MAArB,uBAPU,QDpBL,SAAS,CAAe,CAAC,EAAU,KAA+B,CACvE,OAAO,IAAI,QAAQ,CAAC,EAAS,IAAW,CACtC,IAAI,EAAU,GAER,EAAiB,IAAM,CAC3B,GAAI,EAAS,OAGb,GAFA,EAAU,GACV,OAAO,oBAAoB,uBAAwB,CAAc,EAC7D,EAAW,aAAa,CAAS,EAErC,GAAI,OAAO,SACT,EAAQ,OAAO,QAAQ,EAEvB,OAAO,IAAI,EAAa,4BAA6B,CAAE,OAAQ,EAAa,QAAS,CAAC,CAAC,
|
|
10
|
-
"debugId": "
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "429432B3F2578DF864756E2164756E21",
|
|
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)=>({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
|
|
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(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=EFEB7BE0A5777AA864756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|