@tcswap/wallet-extensions 4.1.16
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-7y3ffnf3.js +4 -0
- package/dist/chunk-7y3ffnf3.js.map +10 -0
- package/dist/chunk-fazw0jvt.js +4 -0
- package/dist/chunk-fazw0jvt.js.map +9 -0
- package/dist/chunk-kx2thqhk.js +5 -0
- package/dist/chunk-kx2thqhk.js.map +9 -0
- package/dist/chunk-swh9jwp7.js +4 -0
- package/dist/chunk-swh9jwp7.js.map +10 -0
- package/dist/src/bitget/index.cjs +4 -0
- package/dist/src/bitget/index.cjs.map +11 -0
- package/dist/src/bitget/index.js +4 -0
- package/dist/src/bitget/index.js.map +11 -0
- package/dist/src/cosmostation/index.cjs +4 -0
- package/dist/src/cosmostation/index.cjs.map +10 -0
- package/dist/src/cosmostation/index.js +4 -0
- package/dist/src/cosmostation/index.js.map +10 -0
- package/dist/src/ctrl/index.cjs +4 -0
- package/dist/src/ctrl/index.cjs.map +11 -0
- package/dist/src/ctrl/index.js +4 -0
- package/dist/src/ctrl/index.js.map +11 -0
- package/dist/src/evm-extensions/index.cjs +4 -0
- package/dist/src/evm-extensions/index.cjs.map +10 -0
- package/dist/src/evm-extensions/index.js +4 -0
- package/dist/src/evm-extensions/index.js.map +10 -0
- package/dist/src/index.cjs +4 -0
- package/dist/src/index.cjs.map +9 -0
- package/dist/src/index.js +3 -0
- package/dist/src/index.js.map +9 -0
- package/dist/src/keepkey-bex/index.cjs +4 -0
- package/dist/src/keepkey-bex/index.cjs.map +11 -0
- package/dist/src/keepkey-bex/index.js +4 -0
- package/dist/src/keepkey-bex/index.js.map +11 -0
- package/dist/src/keplr/index.cjs +4 -0
- package/dist/src/keplr/index.cjs.map +11 -0
- package/dist/src/keplr/index.js +4 -0
- package/dist/src/keplr/index.js.map +11 -0
- package/dist/src/okx/index.cjs +4 -0
- package/dist/src/okx/index.cjs.map +11 -0
- package/dist/src/okx/index.js +4 -0
- package/dist/src/okx/index.js.map +11 -0
- package/dist/src/onekey/index.cjs +4 -0
- package/dist/src/onekey/index.cjs.map +10 -0
- package/dist/src/onekey/index.js +4 -0
- package/dist/src/onekey/index.js.map +10 -0
- package/dist/src/phantom/index.cjs +4 -0
- package/dist/src/phantom/index.cjs.map +10 -0
- package/dist/src/phantom/index.js +4 -0
- package/dist/src/phantom/index.js.map +10 -0
- package/dist/src/polkadotjs/index.cjs +4 -0
- package/dist/src/polkadotjs/index.cjs.map +10 -0
- package/dist/src/polkadotjs/index.js +4 -0
- package/dist/src/polkadotjs/index.js.map +10 -0
- package/dist/src/talisman/index.cjs +4 -0
- package/dist/src/talisman/index.cjs.map +10 -0
- package/dist/src/talisman/index.js +4 -0
- package/dist/src/talisman/index.js.map +10 -0
- package/dist/src/tronlink/index.cjs +4 -0
- package/dist/src/tronlink/index.cjs.map +12 -0
- package/dist/src/tronlink/index.js +4 -0
- package/dist/src/tronlink/index.js.map +12 -0
- package/dist/src/vultisig/index.cjs +4 -0
- package/dist/src/vultisig/index.cjs.map +11 -0
- package/dist/src/vultisig/index.js +4 -0
- package/dist/src/vultisig/index.js.map +11 -0
- package/dist/types/bitget/helpers.d.ts +1607 -0
- package/dist/types/bitget/helpers.d.ts.map +1 -0
- package/dist/types/bitget/index.d.ts +11 -0
- package/dist/types/bitget/index.d.ts.map +1 -0
- package/dist/types/cosmostation/index.d.ts +24 -0
- package/dist/types/cosmostation/index.d.ts.map +1 -0
- package/dist/types/ctrl/index.d.ts +14 -0
- package/dist/types/ctrl/index.d.ts.map +1 -0
- package/dist/types/ctrl/walletHelpers.d.ts +23 -0
- package/dist/types/ctrl/walletHelpers.d.ts.map +1 -0
- package/dist/types/evm-extensions/index.d.ts +747 -0
- package/dist/types/evm-extensions/index.d.ts.map +1 -0
- package/dist/types/evm-extensions/types.d.ts +18 -0
- package/dist/types/evm-extensions/types.d.ts.map +1 -0
- package/dist/types/helpers/near.d.ts +60 -0
- package/dist/types/helpers/near.d.ts.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/keepkey-bex/index.d.ts +14 -0
- package/dist/types/keepkey-bex/index.d.ts.map +1 -0
- package/dist/types/keepkey-bex/walletHelpers.d.ts +48 -0
- package/dist/types/keepkey-bex/walletHelpers.d.ts.map +1 -0
- package/dist/types/keplr/chainRegistry.d.ts +4 -0
- package/dist/types/keplr/chainRegistry.d.ts.map +1 -0
- package/dist/types/keplr/index.d.ts +14 -0
- package/dist/types/keplr/index.d.ts.map +1 -0
- package/dist/types/okx/helpers.d.ts +855 -0
- package/dist/types/okx/helpers.d.ts.map +1 -0
- package/dist/types/okx/index.d.ts +11 -0
- package/dist/types/okx/index.d.ts.map +1 -0
- package/dist/types/okx/types.d.ts +104 -0
- package/dist/types/okx/types.d.ts.map +1 -0
- package/dist/types/onekey/evmSigner.d.ts +32 -0
- package/dist/types/onekey/evmSigner.d.ts.map +1 -0
- package/dist/types/onekey/index.d.ts +14 -0
- package/dist/types/onekey/index.d.ts.map +1 -0
- package/dist/types/phantom/index.d.ts +15 -0
- package/dist/types/phantom/index.d.ts.map +1 -0
- package/dist/types/polkadotjs/index.d.ts +14 -0
- package/dist/types/polkadotjs/index.d.ts.map +1 -0
- package/dist/types/talisman/index.d.ts +14 -0
- package/dist/types/talisman/index.d.ts.map +1 -0
- package/dist/types/tronlink/helpers.d.ts +29 -0
- package/dist/types/tronlink/helpers.d.ts.map +1 -0
- package/dist/types/tronlink/index.d.ts +13 -0
- package/dist/types/tronlink/index.d.ts.map +1 -0
- package/dist/types/tronlink/types.d.ts +55 -0
- package/dist/types/tronlink/types.d.ts.map +1 -0
- package/dist/types/types.d.ts +166 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/vultisig/index.d.ts +14 -0
- package/dist/types/vultisig/index.d.ts.map +1 -0
- package/dist/types/vultisig/walletHelpers.d.ts +37 -0
- package/dist/types/vultisig/walletHelpers.d.ts.map +1 -0
- package/package.json +133 -0
- package/src/bitget/helpers.ts +181 -0
- package/src/bitget/index.ts +26 -0
- package/src/cosmostation/index.ts +122 -0
- package/src/ctrl/index.ts +194 -0
- package/src/ctrl/walletHelpers.ts +186 -0
- package/src/evm-extensions/index.ts +122 -0
- package/src/evm-extensions/types.ts +15 -0
- package/src/helpers/near-browser-provider.d.ts +270 -0
- package/src/helpers/near.ts +174 -0
- package/src/index.ts +1 -0
- package/src/keepkey-bex/index.ts +151 -0
- package/src/keepkey-bex/walletHelpers.ts +241 -0
- package/src/keplr/chainRegistry.ts +240 -0
- package/src/keplr/index.ts +54 -0
- package/src/okx/helpers.ts +192 -0
- package/src/okx/index.ts +43 -0
- package/src/okx/types.ts +117 -0
- package/src/onekey/evmSigner.ts +116 -0
- package/src/onekey/index.ts +182 -0
- package/src/phantom/index.ts +136 -0
- package/src/polkadotjs/index.ts +61 -0
- package/src/talisman/index.ts +132 -0
- package/src/tronlink/helpers.ts +153 -0
- package/src/tronlink/index.ts +49 -0
- package/src/tronlink/types.ts +44 -0
- package/src/types.ts +157 -0
- package/src/vultisig/index.ts +179 -0
- package/src/vultisig/walletHelpers.ts +295 -0
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as I,b as L}from"./chunk-kx2thqhk.js";import{SignedTransaction as M}from"@near-js/transactions";import{USwapError as B}from"@tcswap/helpers";async function Y(q,z){if(!(q.isSignedIn?q.isSignedIn():!1))await q.connect({contractId:"swapkit",methodNames:["transfer"]});return{...q,async getAddress(){if(q.getAccountId)return q.getAccountId();if(q.isSignedIn&&!q.isSignedIn()){let x=await q.connect();if(Array.isArray(x)&&x.length>0&&x[0])return typeof x[0]==="string"?x[0]:x[0].accountId;throw new B("wallet_connection_rejected_by_user",{wallet:z})}throw new B("wallet_connection_rejected_by_user",{wallet:z})},async getPublicKey(){let{PublicKey:x}=await import("@near-js/crypto");if(q.getPublicKey){let D=await q.getPublicKey();return x.from(D)}throw new B("wallet_ledger_method_not_supported",{method:"getPublicKey",wallet:z})},signDelegateAction(x){return Promise.reject(new B("wallet_ledger_method_not_supported",{method:"signDelegateAction",wallet:z}))},async signNep413Message(x,D,G,F,H){if(!q.signMessage)throw new B("wallet_ledger_method_not_supported",{method:"signNep413Message",wallet:z});return await q.signMessage({callbackUrl:H,message:x,nonce:Buffer.from(F),recipient:G})},async signTransaction(x){if(!q.request)throw new B("wallet_near_method_not_supported",{method:"request",wallet:z});let D={actions:x.actions.map((H)=>Q(H)),receiverId:x.receiverId,signerId:x.signerId},G=await q.requestSignTransactions({transactions:[D]}),F=M.decode(Uint8Array.fromBase64(G.txs[0].signedTx));return[F.signature.ed25519Signature?.data,F]}}}function Z(q,z){let A=z.split("."),C=q;for(let x of A)if(C=C?.[x],!C)return null;return C}function _(q){return q?"near:testnet":"near:mainnet"}function Q(q){let z=q.enum,A=q;switch(z){case"functionCall":case"FunctionCall":return{params:{args:typeof Buffer.from(A.functionCall?.args??"{}").toString("base64"),deposit:(A.functionCall?.deposit??0).toString(),gas:(A.functionCall?.gas??0).toString(),methodName:A.functionCall?.methodName??""},type:"FunctionCall"};default:throw Error(`Unsupported action kind for wallet JSON: ${z}`)}}export{_ as getNearChainId,Z as detectNearProvider,Y as createNearSignerFromProvider};
|
|
2
|
+
|
|
3
|
+
//# debugId=91CC456592941BB664756E2164756E21
|
|
4
|
+
//# sourceMappingURL=chunk-7y3ffnf3.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/helpers/near.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\n//TBD @towan to be moved somewhere else\n\nimport type { Account } from \"@near-js/accounts\";\nimport { type Action, SignedTransaction, type Transaction } from \"@near-js/transactions\";\nimport { USwapError } from \"@tcswap/helpers\";\nimport type { NearSigner } from \"@tcswap/toolboxes/near\";\n\n/**\n * NEAR Browser Wallet Provider Interface\n * Common interface implemented by browser extension wallets\n */\nexport interface NearBrowserWalletProvider {\n connect(params?: { contractId?: string; methodNames?: string[] }): Promise<Account[] | { accountId: string }>;\n disconnect?(): Promise<void>;\n signOut?(): Promise<void>; // Alternative to disconnect\n\n getAccountId(): string | Promise<string>;\n getAccounts?(): Promise<Account[]>;\n isSignedIn(): boolean;\n getPublicKey?(): Promise<string>;\n\n signMessage?(params: any): Promise<any>;\n signAndSendTransaction(params: { receiverId: string; actions: Action[]; signerId?: string }): Promise<any>;\n signAndSendTransactions?(params: { transactions: Transaction[] }): Promise<any[]>;\n\n request<T>(params: { method: string; params?: any }): Promise<T>;\n verifyOwner?(params: { message: string; callbackUrl?: string }): Promise<any>;\n getNetwork?(): Promise<{ networkId: string; nodeUrl: string }>;\n\n on?(event: string, handler: (...args: any[]) => void): void;\n off?(event: string, handler: (...args: any[]) => void): void;\n}\n\n/**\n * Helper to create a NEAR signer from browser extension providers\n */\nexport async function createNearSignerFromProvider(provider: NearBrowserWalletProvider, walletName: string) {\n const isConnected = provider.isSignedIn ? provider.isSignedIn() : false;\n if (!isConnected) {\n await provider.connect({ contractId: \"swapkit\", methodNames: [\"transfer\"] });\n }\n\n const signer = {\n ...provider,\n\n async getAddress() {\n if (provider.getAccountId) {\n return provider.getAccountId();\n }\n\n if (provider.isSignedIn && !provider.isSignedIn()) {\n // Try connect method for wallets that don't have requestSignIn\n const result = await provider.connect();\n if (Array.isArray(result) && result.length > 0 && result[0]) {\n return typeof result[0] === \"string\" ? result[0] : result[0].accountId;\n }\n throw new USwapError(\"wallet_connection_rejected_by_user\", { wallet: walletName });\n }\n\n throw new USwapError(\"wallet_connection_rejected_by_user\", { wallet: walletName });\n },\n async getPublicKey() {\n const { PublicKey } = await import(\"@near-js/crypto\");\n\n if (provider.getPublicKey) {\n const pubKey = await provider.getPublicKey();\n return PublicKey.from(pubKey);\n }\n\n throw new USwapError(\"wallet_ledger_method_not_supported\", { method: \"getPublicKey\", wallet: walletName });\n },\n\n signDelegateAction(_delegateAction: any) {\n // Most browser wallets don't support delegate actions yet\n return Promise.reject(\n new USwapError(\"wallet_ledger_method_not_supported\", { method: \"signDelegateAction\", wallet: walletName }),\n );\n },\n\n async signNep413Message(\n message: string,\n _accountId: string,\n recipient: string,\n nonce: Uint8Array,\n callbackUrl?: string,\n ) {\n if (!provider.signMessage) {\n throw new USwapError(\"wallet_ledger_method_not_supported\", { method: \"signNep413Message\", wallet: walletName });\n }\n\n const result = await (provider as Required<Pick<NearBrowserWalletProvider, \"signMessage\">>).signMessage({\n callbackUrl,\n message,\n nonce: Buffer.from(nonce),\n recipient,\n });\n\n return result;\n },\n\n async signTransaction(transaction: Transaction) {\n if (!provider.request) {\n throw new USwapError(\"wallet_near_method_not_supported\", { method: \"request\", wallet: walletName });\n }\n\n const mappedTransaction = {\n actions: transaction.actions.map((action) => actionToWalletJson(action)),\n receiverId: transaction.receiverId,\n signerId: transaction.signerId,\n };\n\n // @ts-expect-error\n const result: any = await provider.requestSignTransactions({ transactions: [mappedTransaction] });\n\n const signedTransaction = SignedTransaction.decode(Uint8Array.fromBase64(result.txs[0].signedTx));\n\n return [signedTransaction.signature.ed25519Signature?.data, signedTransaction] as [\n Uint8Array<ArrayBufferLike>,\n SignedTransaction,\n ];\n },\n };\n\n return signer as NearSigner;\n}\n\n/**\n * Detect if a wallet provider supports NEAR\n */\nexport function detectNearProvider(window: any, providerPath: string): NearBrowserWalletProvider | null {\n const parts = providerPath.split(\".\");\n let provider = window;\n\n for (const part of parts) {\n provider = provider?.[part];\n if (!provider) return null;\n }\n\n return provider;\n}\n\n/**\n * Get NEAR chain ID for WalletConnect\n */\nexport function getNearChainId(isTestnet: boolean): string {\n return isTestnet ? \"near:testnet\" : \"near:mainnet\";\n}\n\nfunction actionToWalletJson(action: Transaction[\"actions\"][number]) {\n const kind = action.enum;\n const data = action;\n\n switch (kind) {\n case \"functionCall\":\n case \"FunctionCall\":\n return {\n params: {\n // args must be base64 string for wallet JSON\n args: typeof Buffer.from(data.functionCall?.args ?? \"{}\").toString(\"base64\"),\n deposit: (data.functionCall?.deposit ?? 0).toString(),\n gas: (data.functionCall?.gas ?? 0).toString(),\n methodName: data.functionCall?.methodName ?? \"\",\n },\n type: \"FunctionCall\",\n };\n\n default:\n throw new Error(`Unsupported action kind for wallet JSON: ${kind}`);\n }\n}\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "+CAOA,4BAAsB,8BACtB,qBAAS,wBAgCT,eAAsB,CAA4B,CAAC,EAAqC,EAAoB,CAE1G,GAAI,EADgB,EAAS,WAAa,EAAS,WAAW,EAAI,IAEhE,MAAM,EAAS,QAAQ,CAAE,WAAY,UAAW,YAAa,CAAC,UAAU,CAAE,CAAC,EAoF7E,MAjFe,IACV,OAEG,WAAU,EAAG,CACjB,GAAI,EAAS,aACX,OAAO,EAAS,aAAa,EAG/B,GAAI,EAAS,YAAc,CAAC,EAAS,WAAW,EAAG,CAEjD,IAAM,EAAS,MAAM,EAAS,QAAQ,EACtC,GAAI,MAAM,QAAQ,CAAM,GAAK,EAAO,OAAS,GAAK,EAAO,GACvD,OAAO,OAAO,EAAO,KAAO,SAAW,EAAO,GAAK,EAAO,GAAG,UAE/D,MAAM,IAAI,EAAW,qCAAsC,CAAE,OAAQ,CAAW,CAAC,EAGnF,MAAM,IAAI,EAAW,qCAAsC,CAAE,OAAQ,CAAW,CAAC,QAE7E,aAAY,EAAG,CACnB,IAAQ,aAAc,KAAa,2BAEnC,GAAI,EAAS,aAAc,CACzB,IAAM,EAAS,MAAM,EAAS,aAAa,EAC3C,OAAO,EAAU,KAAK,CAAM,EAG9B,MAAM,IAAI,EAAW,qCAAsC,CAAE,OAAQ,eAAgB,OAAQ,CAAW,CAAC,GAG3G,kBAAkB,CAAC,EAAsB,CAEvC,OAAO,QAAQ,OACb,IAAI,EAAW,qCAAsC,CAAE,OAAQ,qBAAsB,OAAQ,CAAW,CAAC,CAC3G,QAGI,kBAAiB,CACrB,EACA,EACA,EACA,EACA,EACA,CACA,GAAI,CAAC,EAAS,YACZ,MAAM,IAAI,EAAW,qCAAsC,CAAE,OAAQ,oBAAqB,OAAQ,CAAW,CAAC,EAUhH,OAPe,MAAO,EAAsE,YAAY,CACtG,cACA,UACA,MAAO,OAAO,KAAK,CAAK,EACxB,WACF,CAAC,QAKG,gBAAe,CAAC,EAA0B,CAC9C,GAAI,CAAC,EAAS,QACZ,MAAM,IAAI,EAAW,mCAAoC,CAAE,OAAQ,UAAW,OAAQ,CAAW,CAAC,EAGpG,IAAM,EAAoB,CACxB,QAAS,EAAY,QAAQ,IAAI,CAAC,IAAW,EAAmB,CAAM,CAAC,EACvE,WAAY,EAAY,WACxB,SAAU,EAAY,QACxB,EAGM,EAAc,MAAM,EAAS,wBAAwB,CAAE,aAAc,CAAC,CAAiB,CAAE,CAAC,EAE1F,EAAoB,EAAkB,OAAO,WAAW,WAAW,EAAO,IAAI,GAAG,QAAQ,CAAC,EAEhG,MAAO,CAAC,EAAkB,UAAU,kBAAkB,KAAM,CAAiB,EAKjF,EAQK,SAAS,CAAkB,CAAC,EAAa,EAAwD,CACtG,IAAM,EAAQ,EAAa,MAAM,GAAG,EAChC,EAAW,EAEf,QAAW,KAAQ,EAEjB,GADA,EAAW,IAAW,GAClB,CAAC,EAAU,OAAO,KAGxB,OAAO,EAMF,SAAS,CAAc,CAAC,EAA4B,CACzD,OAAO,EAAY,eAAiB,eAGtC,SAAS,CAAkB,CAAC,EAAwC,CAClE,IAAM,EAAO,EAAO,KACd,EAAO,EAEb,OAAQ,OACD,mBACA,eACH,MAAO,CACL,OAAQ,CAEN,KAAM,OAAO,OAAO,KAAK,EAAK,cAAc,MAAQ,IAAI,EAAE,SAAS,QAAQ,EAC3E,SAAU,EAAK,cAAc,SAAW,GAAG,SAAS,EACpD,KAAM,EAAK,cAAc,KAAO,GAAG,SAAS,EAC5C,WAAY,EAAK,cAAc,YAAc,EAC/C,EACA,KAAM,cACR,UAGA,MAAU,MAAM,4CAA4C,GAAM",
|
|
8
|
+
"debugId": "91CC456592941BB664756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var j=Object.create;var{getPrototypeOf:k,defineProperty:e,getOwnPropertyNames:h,getOwnPropertyDescriptor:l}=Object,i=Object.prototype.hasOwnProperty;var m=(a,b,c)=>{c=a!=null?j(k(a)):{};let d=b||!a||!a.__esModule?e(c,"default",{value:a,enumerable:!0}):c;for(let f of h(a))if(!i.call(d,f))e(d,f,{get:()=>a[f],enumerable:!0});return d},g=new WeakMap,n=(a)=>{var b=g.get(a),c;if(b)return b;if(b=e({},"__esModule",{value:!0}),a&&typeof a==="object"||typeof a==="function")h(a).map((d)=>!i.call(b,d)&&e(b,d,{get:()=>a[d],enumerable:!(c=l(a,d))||c.enumerable}));return g.set(a,b),b};var o=(a,b)=>{for(var c in b)e(a,c,{get:b[c],enumerable:!0,configurable:!0,set:(d)=>b[c]=()=>d})};
|
|
2
|
+
|
|
3
|
+
//# debugId=9E860276D712218864756E2164756E21
|
|
4
|
+
//# sourceMappingURL=chunk-fazw0jvt.js.map
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
var g=Object.create;var{getPrototypeOf:h,defineProperty:f,getOwnPropertyNames:i}=Object;var j=Object.prototype.hasOwnProperty;var k=(a,c,b)=>{b=a!=null?g(h(a)):{};let d=c||!a||!a.__esModule?f(b,"default",{value:a,enumerable:!0}):b;for(let e of i(a))if(!j.call(d,e))f(d,e,{get:()=>a[e],enumerable:!0});return d};var l=((a)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(a,{get:(c,b)=>(typeof require<"u"?require:c)[b]}):a)(function(a){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+a+'" is not supported')});
|
|
2
|
+
export{k as a,l as b};
|
|
3
|
+
|
|
4
|
+
//# debugId=39A6BAAD80B300E064756E2164756E21
|
|
5
|
+
//# sourceMappingURL=chunk-kx2thqhk.js.map
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var I=require("@near-js/transactions"),B=require("@tcswap/helpers");async function R(q,z){if(!(q.isSignedIn?q.isSignedIn():!1))await q.connect({contractId:"swapkit",methodNames:["transfer"]});return{...q,async getAddress(){if(q.getAccountId)return q.getAccountId();if(q.isSignedIn&&!q.isSignedIn()){let x=await q.connect();if(Array.isArray(x)&&x.length>0&&x[0])return typeof x[0]==="string"?x[0]:x[0].accountId;throw new B.USwapError("wallet_connection_rejected_by_user",{wallet:z})}throw new B.USwapError("wallet_connection_rejected_by_user",{wallet:z})},async getPublicKey(){let{PublicKey:x}=await import("@near-js/crypto");if(q.getPublicKey){let D=await q.getPublicKey();return x.from(D)}throw new B.USwapError("wallet_ledger_method_not_supported",{method:"getPublicKey",wallet:z})},signDelegateAction(x){return Promise.reject(new B.USwapError("wallet_ledger_method_not_supported",{method:"signDelegateAction",wallet:z}))},async signNep413Message(x,D,G,F,H){if(!q.signMessage)throw new B.USwapError("wallet_ledger_method_not_supported",{method:"signNep413Message",wallet:z});return await q.signMessage({callbackUrl:H,message:x,nonce:Buffer.from(F),recipient:G})},async signTransaction(x){if(!q.request)throw new B.USwapError("wallet_near_method_not_supported",{method:"request",wallet:z});let D={actions:x.actions.map((H)=>M(H)),receiverId:x.receiverId,signerId:x.signerId},G=await q.requestSignTransactions({transactions:[D]}),F=I.SignedTransaction.decode(Uint8Array.fromBase64(G.txs[0].signedTx));return[F.signature.ed25519Signature?.data,F]}}}function V(q,z){let A=z.split("."),C=q;for(let x of A)if(C=C?.[x],!C)return null;return C}function X(q){return q?"near:testnet":"near:mainnet"}function M(q){let z=q.enum,A=q;switch(z){case"functionCall":case"FunctionCall":return{params:{args:typeof Buffer.from(A.functionCall?.args??"{}").toString("base64"),deposit:(A.functionCall?.deposit??0).toString(),gas:(A.functionCall?.gas??0).toString(),methodName:A.functionCall?.methodName??""},type:"FunctionCall"};default:throw Error(`Unsupported action kind for wallet JSON: ${z}`)}}
|
|
2
|
+
|
|
3
|
+
//# debugId=47A3ED7651B1620F64756E2164756E21
|
|
4
|
+
//# sourceMappingURL=chunk-swh9jwp7.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/helpers/near.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\n//TBD @towan to be moved somewhere else\n\nimport type { Account } from \"@near-js/accounts\";\nimport { type Action, SignedTransaction, type Transaction } from \"@near-js/transactions\";\nimport { USwapError } from \"@tcswap/helpers\";\nimport type { NearSigner } from \"@tcswap/toolboxes/near\";\n\n/**\n * NEAR Browser Wallet Provider Interface\n * Common interface implemented by browser extension wallets\n */\nexport interface NearBrowserWalletProvider {\n connect(params?: { contractId?: string; methodNames?: string[] }): Promise<Account[] | { accountId: string }>;\n disconnect?(): Promise<void>;\n signOut?(): Promise<void>; // Alternative to disconnect\n\n getAccountId(): string | Promise<string>;\n getAccounts?(): Promise<Account[]>;\n isSignedIn(): boolean;\n getPublicKey?(): Promise<string>;\n\n signMessage?(params: any): Promise<any>;\n signAndSendTransaction(params: { receiverId: string; actions: Action[]; signerId?: string }): Promise<any>;\n signAndSendTransactions?(params: { transactions: Transaction[] }): Promise<any[]>;\n\n request<T>(params: { method: string; params?: any }): Promise<T>;\n verifyOwner?(params: { message: string; callbackUrl?: string }): Promise<any>;\n getNetwork?(): Promise<{ networkId: string; nodeUrl: string }>;\n\n on?(event: string, handler: (...args: any[]) => void): void;\n off?(event: string, handler: (...args: any[]) => void): void;\n}\n\n/**\n * Helper to create a NEAR signer from browser extension providers\n */\nexport async function createNearSignerFromProvider(provider: NearBrowserWalletProvider, walletName: string) {\n const isConnected = provider.isSignedIn ? provider.isSignedIn() : false;\n if (!isConnected) {\n await provider.connect({ contractId: \"swapkit\", methodNames: [\"transfer\"] });\n }\n\n const signer = {\n ...provider,\n\n async getAddress() {\n if (provider.getAccountId) {\n return provider.getAccountId();\n }\n\n if (provider.isSignedIn && !provider.isSignedIn()) {\n // Try connect method for wallets that don't have requestSignIn\n const result = await provider.connect();\n if (Array.isArray(result) && result.length > 0 && result[0]) {\n return typeof result[0] === \"string\" ? result[0] : result[0].accountId;\n }\n throw new USwapError(\"wallet_connection_rejected_by_user\", { wallet: walletName });\n }\n\n throw new USwapError(\"wallet_connection_rejected_by_user\", { wallet: walletName });\n },\n async getPublicKey() {\n const { PublicKey } = await import(\"@near-js/crypto\");\n\n if (provider.getPublicKey) {\n const pubKey = await provider.getPublicKey();\n return PublicKey.from(pubKey);\n }\n\n throw new USwapError(\"wallet_ledger_method_not_supported\", { method: \"getPublicKey\", wallet: walletName });\n },\n\n signDelegateAction(_delegateAction: any) {\n // Most browser wallets don't support delegate actions yet\n return Promise.reject(\n new USwapError(\"wallet_ledger_method_not_supported\", { method: \"signDelegateAction\", wallet: walletName }),\n );\n },\n\n async signNep413Message(\n message: string,\n _accountId: string,\n recipient: string,\n nonce: Uint8Array,\n callbackUrl?: string,\n ) {\n if (!provider.signMessage) {\n throw new USwapError(\"wallet_ledger_method_not_supported\", { method: \"signNep413Message\", wallet: walletName });\n }\n\n const result = await (provider as Required<Pick<NearBrowserWalletProvider, \"signMessage\">>).signMessage({\n callbackUrl,\n message,\n nonce: Buffer.from(nonce),\n recipient,\n });\n\n return result;\n },\n\n async signTransaction(transaction: Transaction) {\n if (!provider.request) {\n throw new USwapError(\"wallet_near_method_not_supported\", { method: \"request\", wallet: walletName });\n }\n\n const mappedTransaction = {\n actions: transaction.actions.map((action) => actionToWalletJson(action)),\n receiverId: transaction.receiverId,\n signerId: transaction.signerId,\n };\n\n // @ts-expect-error\n const result: any = await provider.requestSignTransactions({ transactions: [mappedTransaction] });\n\n const signedTransaction = SignedTransaction.decode(Uint8Array.fromBase64(result.txs[0].signedTx));\n\n return [signedTransaction.signature.ed25519Signature?.data, signedTransaction] as [\n Uint8Array<ArrayBufferLike>,\n SignedTransaction,\n ];\n },\n };\n\n return signer as NearSigner;\n}\n\n/**\n * Detect if a wallet provider supports NEAR\n */\nexport function detectNearProvider(window: any, providerPath: string): NearBrowserWalletProvider | null {\n const parts = providerPath.split(\".\");\n let provider = window;\n\n for (const part of parts) {\n provider = provider?.[part];\n if (!provider) return null;\n }\n\n return provider;\n}\n\n/**\n * Get NEAR chain ID for WalletConnect\n */\nexport function getNearChainId(isTestnet: boolean): string {\n return isTestnet ? \"near:testnet\" : \"near:mainnet\";\n}\n\nfunction actionToWalletJson(action: Transaction[\"actions\"][number]) {\n const kind = action.enum;\n const data = action;\n\n switch (kind) {\n case \"functionCall\":\n case \"FunctionCall\":\n return {\n params: {\n // args must be base64 string for wallet JSON\n args: typeof Buffer.from(data.functionCall?.args ?? \"{}\").toString(\"base64\"),\n deposit: (data.functionCall?.deposit ?? 0).toString(),\n gas: (data.functionCall?.gas ?? 0).toString(),\n methodName: data.functionCall?.methodName ?? \"\",\n },\n type: \"FunctionCall\",\n };\n\n default:\n throw new Error(`Unsupported action kind for wallet JSON: ${kind}`);\n }\n}\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "AAOiE,IAAjE,mCACA,6BAgCA,eAAsB,CAA4B,CAAC,EAAqC,EAAoB,CAE1G,GAAI,EADgB,EAAS,WAAa,EAAS,WAAW,EAAI,IAEhE,MAAM,EAAS,QAAQ,CAAE,WAAY,UAAW,YAAa,CAAC,UAAU,CAAE,CAAC,EAoF7E,MAjFe,IACV,OAEG,WAAU,EAAG,CACjB,GAAI,EAAS,aACX,OAAO,EAAS,aAAa,EAG/B,GAAI,EAAS,YAAc,CAAC,EAAS,WAAW,EAAG,CAEjD,IAAM,EAAS,MAAM,EAAS,QAAQ,EACtC,GAAI,MAAM,QAAQ,CAAM,GAAK,EAAO,OAAS,GAAK,EAAO,GACvD,OAAO,OAAO,EAAO,KAAO,SAAW,EAAO,GAAK,EAAO,GAAG,UAE/D,MAAM,IAAI,aAAW,qCAAsC,CAAE,OAAQ,CAAW,CAAC,EAGnF,MAAM,IAAI,aAAW,qCAAsC,CAAE,OAAQ,CAAW,CAAC,QAE7E,aAAY,EAAG,CACnB,IAAQ,aAAc,KAAa,2BAEnC,GAAI,EAAS,aAAc,CACzB,IAAM,EAAS,MAAM,EAAS,aAAa,EAC3C,OAAO,EAAU,KAAK,CAAM,EAG9B,MAAM,IAAI,aAAW,qCAAsC,CAAE,OAAQ,eAAgB,OAAQ,CAAW,CAAC,GAG3G,kBAAkB,CAAC,EAAsB,CAEvC,OAAO,QAAQ,OACb,IAAI,aAAW,qCAAsC,CAAE,OAAQ,qBAAsB,OAAQ,CAAW,CAAC,CAC3G,QAGI,kBAAiB,CACrB,EACA,EACA,EACA,EACA,EACA,CACA,GAAI,CAAC,EAAS,YACZ,MAAM,IAAI,aAAW,qCAAsC,CAAE,OAAQ,oBAAqB,OAAQ,CAAW,CAAC,EAUhH,OAPe,MAAO,EAAsE,YAAY,CACtG,cACA,UACA,MAAO,OAAO,KAAK,CAAK,EACxB,WACF,CAAC,QAKG,gBAAe,CAAC,EAA0B,CAC9C,GAAI,CAAC,EAAS,QACZ,MAAM,IAAI,aAAW,mCAAoC,CAAE,OAAQ,UAAW,OAAQ,CAAW,CAAC,EAGpG,IAAM,EAAoB,CACxB,QAAS,EAAY,QAAQ,IAAI,CAAC,IAAW,EAAmB,CAAM,CAAC,EACvE,WAAY,EAAY,WACxB,SAAU,EAAY,QACxB,EAGM,EAAc,MAAM,EAAS,wBAAwB,CAAE,aAAc,CAAC,CAAiB,CAAE,CAAC,EAE1F,EAAoB,oBAAkB,OAAO,WAAW,WAAW,EAAO,IAAI,GAAG,QAAQ,CAAC,EAEhG,MAAO,CAAC,EAAkB,UAAU,kBAAkB,KAAM,CAAiB,EAKjF,EAQK,SAAS,CAAkB,CAAC,EAAa,EAAwD,CACtG,IAAM,EAAQ,EAAa,MAAM,GAAG,EAChC,EAAW,EAEf,QAAW,KAAQ,EAEjB,GADA,EAAW,IAAW,GAClB,CAAC,EAAU,OAAO,KAGxB,OAAO,EAMF,SAAS,CAAc,CAAC,EAA4B,CACzD,OAAO,EAAY,eAAiB,eAGtC,SAAS,CAAkB,CAAC,EAAwC,CAClE,IAAM,EAAO,EAAO,KACd,EAAO,EAEb,OAAQ,OACD,mBACA,eACH,MAAO,CACL,OAAQ,CAEN,KAAM,OAAO,OAAO,KAAK,EAAK,cAAc,MAAQ,IAAI,EAAE,SAAS,QAAQ,EAC3E,SAAU,EAAK,cAAc,SAAW,GAAG,SAAS,EACpD,KAAM,EAAK,cAAc,KAAO,GAAG,SAAS,EAC5C,WAAY,EAAK,cAAc,YAAc,EAC/C,EACA,KAAM,cACR,UAGA,MAAU,MAAM,4CAA4C,GAAM",
|
|
8
|
+
"debugId": "47A3ED7651B1620F64756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var $={};Y($,{bitgetWallet:()=>V,BITGET_SUPPORTED_CHAINS:()=>Z});module.exports=X($);var D=require("@tcswap/helpers"),F=require("@tcswap/wallet-core");var m=require("@tcswap/helpers"),K=require("bitcoinjs-lib");async function Q(H){let{match:M,P:q}=await import("ts-pattern"),B=window.bitkeep;return M(H).with(q.union(m.Chain.Arbitrum,m.Chain.Aurora,m.Chain.Avalanche,m.Chain.Base,m.Chain.Berachain,m.Chain.BinanceSmartChain,m.Chain.Ethereum,m.Chain.Gnosis,m.Chain.Monad,m.Chain.Optimism,m.Chain.Polygon,m.Chain.XLayer),async()=>{if(!(B&&("ethereum"in B)))throw new m.USwapError("wallet_bitkeep_not_found");let u=B.ethereum,[O]=await u.send("eth_requestAccounts",[]);return{...await W({chain:H,walletProvider:u}),address:O}}).with(m.Chain.Bitcoin,async()=>{if(!(B&&("unisat"in B)))throw new m.USwapError("wallet_bitkeep_not_found");let{unisat:u}=B,{getUtxoToolbox:O}=await import("@tcswap/toolboxes/utxo"),[y]=await u.requestAccounts();async function _(G){let J=await u.signPsbt(G.toHex(),{autoFinalized:!1});return K.Psbt.fromHex(J)}let I={getAddress:()=>Promise.resolve(y),signTransaction:_};return{...await O(m.Chain.Bitcoin,{signer:I}),address:y}}).with(m.Chain.Cosmos,async()=>{if(!(B&&("keplr"in B)))throw new m.USwapError("wallet_bitkeep_not_found");let{keplr:u}=B;await u.enable(m.GAIAConfig.chainId);let O=u.getOfflineSignerOnlyAmino(m.GAIAConfig.chainId),y=await O.getAccounts();if(!y?.[0])throw new m.USwapError("wallet_bitkeep_no_accounts",{chain:m.Chain.Cosmos});let{getCosmosToolbox:_}=await import("@tcswap/toolboxes/cosmos"),[{address:I}]=y,z={...O,getAddress:()=>Promise.resolve(I),signTransaction:async()=>Promise.resolve({})};return{...await _(m.Chain.Cosmos,{signer:z}),address:I}}).with(m.Chain.Solana,async()=>{if(!(B&&("solana"in B)))throw new m.USwapError("wallet_bitkeep_not_found");let{getSolanaToolbox:u}=await import("@tcswap/toolboxes/solana"),O=B?.solana,y=await O.connect(),_=y.publicKey.toString(),I={...O,getAddress:async()=>_,publicKey:y.publicKey};return{...await u({signer:I}),address:_}}).with(m.Chain.Tron,async()=>{if(!(B&&("tronLink"in B)&&("tronWeb"in B)))throw new m.USwapError("wallet_bitkeep_not_found");let{createTronToolbox:u}=await import("@tcswap/toolboxes/tron"),{tronLink:O,tronWeb:y}=B,_=await O.request({method:"tron_requestAccounts"});if(_.code!==200)throw new m.USwapError("wallet_connection_rejected_by_user",{message:_.message||"User rejected connection"});let I=y.defaultAddress?.base58;if(!I)throw new m.USwapError("wallet_bitkeep_no_accounts",{chain:m.Chain.Tron});return{...await u({signer:{getAddress:()=>Promise.resolve(I),signTransaction:async(J)=>{return await y.trx.sign(J)}}}),address:I}}).otherwise(()=>{throw new m.USwapError("wallet_chain_not_supported")})}var W=async({chain:H,walletProvider:M})=>{let{getEvmToolbox:q}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:B}=await import("ethers");if(!M)throw new m.USwapError("wallet_provider_not_found");let u=new B(M,"any"),O=await u.getSigner(),y=await q(H,{provider:u,signer:O});try{if(H!==m.Chain.Ethereum&&"getNetworkParams"in y)await m.switchEVMWalletNetwork(u,H,y.getNetworkParams())}catch{throw new m.USwapError("wallet_bitkeep_failed_to_switch_network",{chain:H})}return m.prepareNetworkSwitch({chain:H,provider:u,toolbox:y})};var V=F.createWallet({connect:({addChain:H,walletType:M,supportedChains:q})=>async function(u){let O=D.filterSupportedChains({chains:u,supportedChains:q,walletType:M});return await Promise.all(O.map(async(y)=>{let _=await Q(y);H({..._,chain:y,walletType:M})})),!0},name:"connectBitget",supportedChains:[...D.EVMChains,D.Chain.Cosmos,D.Chain.Bitcoin,D.Chain.Solana,D.Chain.Tron],walletType:D.WalletOption.BITGET}),Z=F.getWalletSupportedChains(V);
|
|
2
|
+
|
|
3
|
+
//# debugId=14A8E62D5C63D1FA64756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/bitget/index.ts", "../src/bitget/helpers.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"import { Chain, EVMChains, filterSupportedChains, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectBitget\",\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana, Chain.Tron],\n walletType: WalletOption.BITGET,\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n type EVMChain,\n GAIAConfig,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n USwapError,\n} from \"@tcswap/helpers\";\nimport type { TronTransaction } from \"@tcswap/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n const bitget = window.bitkeep;\n\n return match(chain)\n .with(\n P.union(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Monad,\n Chain.Optimism,\n Chain.Polygon,\n Chain.XLayer,\n ),\n async () => {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({ chain: chain as EVMChain, walletProvider: wallet });\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@tcswap/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = { getAddress: () => Promise.resolve(address), signTransaction };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(GAIAConfig.chainId);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(GAIAConfig.chainId);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0]) throw new USwapError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@tcswap/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = await getCosmosToolbox(Chain.Cosmos, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Solana, async () => {\n if (!(bitget && \"solana\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@tcswap/toolboxes/solana\");\n const provider = bitget?.solana;\n\n // Connect to get the public key\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n // Create a proper signer object that wraps the provider\n const signer = { ...provider, getAddress: async () => address, publicKey: providerConnection.publicKey };\n\n const toolbox = await getSolanaToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Tron, async () => {\n if (!(bitget && \"tronLink\" in bitget && \"tronWeb\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n\n const { createTronToolbox } = await import(\"@tcswap/toolboxes/tron\");\n const { tronLink, tronWeb } = bitget;\n\n // Request account access\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n // Check if the request was successful\n if (response.code !== 200) {\n throw new USwapError(\"wallet_connection_rejected_by_user\", {\n message: response.message || \"User rejected connection\",\n });\n }\n\n // After successful approval, the address should be available in tronWeb.defaultAddress\n const address = tronWeb.defaultAddress?.base58;\n\n if (!address) {\n throw new USwapError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Tron });\n }\n\n // Create signer compatible with TronSigner interface\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWeb.trx.sign(transaction);\n return signedTx;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new USwapError(\"wallet_chain_not_supported\");\n });\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: {\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n}) => {\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new USwapError(\"wallet_provider_not_found\");\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 && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch {\n throw new USwapError(\"wallet_bitkeep_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n};\n"
|
|
7
|
+
],
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "14A8E62D5C63D1FA64756E2164756E21",
|
|
10
|
+
"names": []
|
|
11
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as R,b as q}from"../../chunk-kx2thqhk.js";import{Chain as G,EVMChains as $,filterSupportedChains as f,WalletOption as j}from"@tcswap/helpers";import{createWallet as L,getWalletSupportedChains as N}from"@tcswap/wallet-core";import{Chain as m,GAIAConfig as Q,prepareNetworkSwitch as W,switchEVMWalletNetwork as X,USwapError as D}from"@tcswap/helpers";import{Psbt as Y}from"bitcoinjs-lib";async function V(H){let{match:M,P:z}=await import("ts-pattern"),B=window.bitkeep;return M(H).with(z.union(m.Arbitrum,m.Aurora,m.Avalanche,m.Base,m.Berachain,m.BinanceSmartChain,m.Ethereum,m.Gnosis,m.Monad,m.Optimism,m.Polygon,m.XLayer),async()=>{if(!(B&&("ethereum"in B)))throw new D("wallet_bitkeep_not_found");let u=B.ethereum,[O]=await u.send("eth_requestAccounts",[]);return{...await Z({chain:H,walletProvider:u}),address:O}}).with(m.Bitcoin,async()=>{if(!(B&&("unisat"in B)))throw new D("wallet_bitkeep_not_found");let{unisat:u}=B,{getUtxoToolbox:O}=await import("@tcswap/toolboxes/utxo"),[y]=await u.requestAccounts();async function _(J){let K=await u.signPsbt(J.toHex(),{autoFinalized:!1});return Y.fromHex(K)}let I={getAddress:()=>Promise.resolve(y),signTransaction:_};return{...await O(m.Bitcoin,{signer:I}),address:y}}).with(m.Cosmos,async()=>{if(!(B&&("keplr"in B)))throw new D("wallet_bitkeep_not_found");let{keplr:u}=B;await u.enable(Q.chainId);let O=u.getOfflineSignerOnlyAmino(Q.chainId),y=await O.getAccounts();if(!y?.[0])throw new D("wallet_bitkeep_no_accounts",{chain:m.Cosmos});let{getCosmosToolbox:_}=await import("@tcswap/toolboxes/cosmos"),[{address:I}]=y,F={...O,getAddress:()=>Promise.resolve(I),signTransaction:async()=>Promise.resolve({})};return{...await _(m.Cosmos,{signer:F}),address:I}}).with(m.Solana,async()=>{if(!(B&&("solana"in B)))throw new D("wallet_bitkeep_not_found");let{getSolanaToolbox:u}=await import("@tcswap/toolboxes/solana"),O=B?.solana,y=await O.connect(),_=y.publicKey.toString(),I={...O,getAddress:async()=>_,publicKey:y.publicKey};return{...await u({signer:I}),address:_}}).with(m.Tron,async()=>{if(!(B&&("tronLink"in B)&&("tronWeb"in B)))throw new D("wallet_bitkeep_not_found");let{createTronToolbox:u}=await import("@tcswap/toolboxes/tron"),{tronLink:O,tronWeb:y}=B,_=await O.request({method:"tron_requestAccounts"});if(_.code!==200)throw new D("wallet_connection_rejected_by_user",{message:_.message||"User rejected connection"});let I=y.defaultAddress?.base58;if(!I)throw new D("wallet_bitkeep_no_accounts",{chain:m.Tron});return{...await u({signer:{getAddress:()=>Promise.resolve(I),signTransaction:async(K)=>{return await y.trx.sign(K)}}}),address:I}}).otherwise(()=>{throw new D("wallet_chain_not_supported")})}var Z=async({chain:H,walletProvider:M})=>{let{getEvmToolbox:z}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:B}=await import("ethers");if(!M)throw new D("wallet_provider_not_found");let u=new B(M,"any"),O=await u.getSigner(),y=await z(H,{provider:u,signer:O});try{if(H!==m.Ethereum&&"getNetworkParams"in y)await X(u,H,y.getNetworkParams())}catch{throw new D("wallet_bitkeep_failed_to_switch_network",{chain:H})}return W({chain:H,provider:u,toolbox:y})};var T=L({connect:({addChain:H,walletType:M,supportedChains:z})=>async function(u){let O=f({chains:u,supportedChains:z,walletType:M});return await Promise.all(O.map(async(y)=>{let _=await V(y);H({..._,chain:y,walletType:M})})),!0},name:"connectBitget",supportedChains:[...$,G.Cosmos,G.Bitcoin,G.Solana,G.Tron],walletType:j.BITGET}),v=N(T);export{T as bitgetWallet,v as BITGET_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=AD86DE9DA9D66A0264756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/bitget/index.ts", "../src/bitget/helpers.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"import { Chain, EVMChains, filterSupportedChains, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectBitget\",\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana, Chain.Tron],\n walletType: WalletOption.BITGET,\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n type EVMChain,\n GAIAConfig,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n USwapError,\n} from \"@tcswap/helpers\";\nimport type { TronTransaction } from \"@tcswap/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n const bitget = window.bitkeep;\n\n return match(chain)\n .with(\n P.union(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Monad,\n Chain.Optimism,\n Chain.Polygon,\n Chain.XLayer,\n ),\n async () => {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({ chain: chain as EVMChain, walletProvider: wallet });\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@tcswap/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = { getAddress: () => Promise.resolve(address), signTransaction };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(GAIAConfig.chainId);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(GAIAConfig.chainId);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0]) throw new USwapError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@tcswap/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = await getCosmosToolbox(Chain.Cosmos, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Solana, async () => {\n if (!(bitget && \"solana\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@tcswap/toolboxes/solana\");\n const provider = bitget?.solana;\n\n // Connect to get the public key\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n // Create a proper signer object that wraps the provider\n const signer = { ...provider, getAddress: async () => address, publicKey: providerConnection.publicKey };\n\n const toolbox = await getSolanaToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Tron, async () => {\n if (!(bitget && \"tronLink\" in bitget && \"tronWeb\" in bitget)) {\n throw new USwapError(\"wallet_bitkeep_not_found\");\n }\n\n const { createTronToolbox } = await import(\"@tcswap/toolboxes/tron\");\n const { tronLink, tronWeb } = bitget;\n\n // Request account access\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n // Check if the request was successful\n if (response.code !== 200) {\n throw new USwapError(\"wallet_connection_rejected_by_user\", {\n message: response.message || \"User rejected connection\",\n });\n }\n\n // After successful approval, the address should be available in tronWeb.defaultAddress\n const address = tronWeb.defaultAddress?.base58;\n\n if (!address) {\n throw new USwapError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Tron });\n }\n\n // Create signer compatible with TronSigner interface\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWeb.trx.sign(transaction);\n return signedTx;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new USwapError(\"wallet_chain_not_supported\");\n });\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: {\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n}) => {\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new USwapError(\"wallet_provider_not_found\");\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 && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch {\n throw new USwapError(\"wallet_bitkeep_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n};\n"
|
|
7
|
+
],
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "AD86DE9DA9D66A0264756E2164756E21",
|
|
10
|
+
"names": []
|
|
11
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var S={};u(S,{cosmostationWallet:()=>p,COSMOSTATION_SUPPORTED_CHAINS:()=>O});module.exports=d(S);var o=require("@tcswap/helpers"),l=require("@tcswap/wallet-core"),C=[o.ChainId.Cosmos,o.ChainId.Kujira,o.ChainId.Noble,o.ChainId.THORChain],_=[o.Chain.Ethereum,o.Chain.BinanceSmartChain,o.Chain.Avalanche,o.Chain.Polygon,o.Chain.Arbitrum,o.Chain.Optimism,o.Chain.Base,o.Chain.XLayer];async function f(i,c,s){await Promise.all(i.map(async(n)=>{let e=o.ChainToChainId[n];await s.enable(e);let a=s.getOfflineSignerOnlyAmino(e);if(!a)throw new o.USwapError("wallet_cosmostation_signer_not_found");let{getCosmosToolbox:r}=await import("@tcswap/toolboxes/cosmos"),t=await a.getAccounts();if(!t?.[0]?.address)throw new o.USwapError("wallet_cosmostation_no_accounts");let[{address:w}]=t,h=await r(n,{signer:a});c({...h,address:w,chain:n,walletType:o.WalletOption.COSMOSTATION})}))}async function y(i,c){let s=window.ethereum;if(!s)throw new o.USwapError("wallet_cosmostation_evm_provider_not_found");let n=await s.request({method:"eth_requestAccounts"});if(!n||n.length===0)throw new o.USwapError("wallet_cosmostation_no_evm_accounts");let{getEvmToolbox:e}=await import("@tcswap/toolboxes/evm");for(let a of i){let r=e(a,{provider:s}),[t]=n;if(!t)throw new o.USwapError("wallet_cosmostation_no_evm_address");c({...r,address:t,chain:a,walletType:o.WalletOption.COSMOSTATION})}}var p=l.createWallet({connect:({addChain:i,supportedChains:c})=>async function(n){let e=o.filterSupportedChains({chains:n,supportedChains:c,walletType:o.WalletOption.COSMOSTATION});if(!window.cosmostation)throw new o.USwapError("wallet_cosmostation_not_found");let a=e.filter((t)=>C.includes(o.ChainToChainId[t])),r=e.filter((t)=>_.includes(t));if(a.length>0){let t=window.cosmostation.providers?.keplr;if(!t)throw new o.USwapError("wallet_cosmostation_keplr_provider_not_found");await f(a,i,t)}if(r.length>0)await y(r,i);return!0},name:"connectCosmostation",supportedChains:[o.Chain.Cosmos,o.Chain.Kujira,o.Chain.Noble,o.Chain.THORChain,o.Chain.Ethereum,o.Chain.BinanceSmartChain,o.Chain.Avalanche,o.Chain.Polygon,o.Chain.Arbitrum,o.Chain.Optimism,o.Chain.Base,o.Chain.XLayer]}),O=l.getWalletSupportedChains(p);
|
|
2
|
+
|
|
3
|
+
//# debugId=AE962C27E7194C4F64756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/cosmostation/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport type { Keplr } from \"@keplr-wallet/types\";\nimport { Chain, ChainId, ChainToChainId, filterSupportedChains, USwapError, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nconst cosmostationSupportedChainIds = [ChainId.Cosmos, ChainId.Kujira, ChainId.Noble, ChainId.THORChain] as const;\nconst cosmostationSupportedEVMChains = [\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n Chain.XLayer,\n] as const;\n\ndeclare global {\n interface Window {\n cosmostation?: { providers?: { keplr?: Keplr } };\n }\n}\n\nasync function connectCosmosChains(chains: Chain[], addChain: any, keplrProvider: Keplr) {\n await Promise.all(\n chains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof cosmostationSupportedChainIds)[number];\n\n await keplrProvider.enable(chainId);\n const signer = keplrProvider.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new USwapError(\"wallet_cosmostation_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@tcswap/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new USwapError(\"wallet_cosmostation_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(chain as any, { signer });\n\n addChain({ ...toolbox, address, chain, walletType: WalletOption.COSMOSTATION });\n }),\n );\n}\n\nasync function connectEvmChains(chains: Chain[], addChain: any) {\n const provider = window.ethereum;\n\n if (!provider) {\n throw new USwapError(\"wallet_cosmostation_evm_provider_not_found\");\n }\n\n const accounts = (await provider.request({ method: \"eth_requestAccounts\" })) as string[];\n\n if (!accounts || accounts.length === 0) {\n throw new USwapError(\"wallet_cosmostation_no_evm_accounts\");\n }\n\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n\n for (const chain of chains) {\n const toolbox = getEvmToolbox(chain as any, { provider });\n const [address] = accounts;\n\n if (!address) {\n throw new USwapError(\"wallet_cosmostation_no_evm_address\");\n }\n\n addChain({ ...toolbox, address, chain, walletType: WalletOption.COSMOSTATION });\n }\n}\n\nexport const cosmostationWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectCosmostation(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType: WalletOption.COSMOSTATION });\n\n if (!window.cosmostation) {\n throw new USwapError(\"wallet_cosmostation_not_found\");\n }\n\n const cosmosChains = filteredChains.filter((chain) =>\n cosmostationSupportedChainIds.includes(ChainToChainId[chain] as any),\n );\n const evmChains = filteredChains.filter((chain) => cosmostationSupportedEVMChains.includes(chain as any));\n\n if (cosmosChains.length > 0) {\n const keplrProvider = window.cosmostation.providers?.keplr;\n if (!keplrProvider) {\n throw new USwapError(\"wallet_cosmostation_keplr_provider_not_found\");\n }\n\n await connectCosmosChains(cosmosChains, addChain, keplrProvider);\n }\n\n if (evmChains.length > 0) {\n await connectEvmChains(evmChains, addChain);\n }\n\n return true;\n },\n name: \"connectCosmostation\",\n supportedChains: [\n Chain.Cosmos,\n Chain.Kujira,\n Chain.Noble,\n Chain.THORChain,\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n Chain.XLayer,\n ],\n});\n\nexport const COSMOSTATION_SUPPORTED_CHAINS = getWalletSupportedChains(cosmostationWallet);\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "iGAKgG,IAAhG,6BACA,iCAEM,EAAgC,CAAC,UAAQ,OAAQ,UAAQ,OAAQ,UAAQ,MAAO,UAAQ,SAAS,EACjG,EAAiC,CACrC,QAAM,SACN,QAAM,kBACN,QAAM,UACN,QAAM,QACN,QAAM,SACN,QAAM,SACN,QAAM,KACN,QAAM,MACR,EAQA,eAAe,CAAmB,CAAC,EAAiB,EAAe,EAAsB,CACvF,MAAM,QAAQ,IACZ,EAAO,IAAI,MAAO,IAAU,CAC1B,IAAM,EAAU,iBAAe,GAE/B,MAAM,EAAc,OAAO,CAAO,EAClC,IAAM,EAAS,EAAc,0BAA0B,CAAO,EAC9D,GAAI,CAAC,EAAQ,MAAM,IAAI,aAAW,sCAAsC,EAExE,IAAQ,oBAAqB,KAAa,oCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,GAAI,CAAC,IAAW,IAAI,QAAS,MAAM,IAAI,aAAW,iCAAiC,EAEnF,KAAS,YAAa,EAChB,EAAU,MAAM,EAAiB,EAAc,CAAE,QAAO,CAAC,EAE/D,EAAS,IAAK,EAAS,UAAS,QAAO,WAAY,eAAa,YAAa,CAAC,EAC/E,CACH,EAGF,eAAe,CAAgB,CAAC,EAAiB,EAAe,CAC9D,IAAM,EAAW,OAAO,SAExB,GAAI,CAAC,EACH,MAAM,IAAI,aAAW,4CAA4C,EAGnE,IAAM,EAAY,MAAM,EAAS,QAAQ,CAAE,OAAQ,qBAAsB,CAAC,EAE1E,GAAI,CAAC,GAAY,EAAS,SAAW,EACnC,MAAM,IAAI,aAAW,qCAAqC,EAG5D,IAAQ,iBAAkB,KAAa,iCAEvC,QAAW,KAAS,EAAQ,CAC1B,IAAM,EAAU,EAAc,EAAc,CAAE,UAAS,CAAC,GACjD,GAAW,EAElB,GAAI,CAAC,EACH,MAAM,IAAI,aAAW,oCAAoC,EAG3D,EAAS,IAAK,EAAS,UAAS,QAAO,WAAY,eAAa,YAAa,CAAC,GAI3E,IAAM,EAAqB,eAAa,CAC7C,QAAS,EAAG,WAAU,qBACpB,cAAkC,CAAC,EAAiB,CAClD,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,WAAY,eAAa,YAAa,CAAC,EAE/G,GAAI,CAAC,OAAO,aACV,MAAM,IAAI,aAAW,+BAA+B,EAGtD,IAAM,EAAe,EAAe,OAAO,CAAC,IAC1C,EAA8B,SAAS,iBAAe,EAAa,CACrE,EACM,EAAY,EAAe,OAAO,CAAC,IAAU,EAA+B,SAAS,CAAY,CAAC,EAExG,GAAI,EAAa,OAAS,EAAG,CAC3B,IAAM,EAAgB,OAAO,aAAa,WAAW,MACrD,GAAI,CAAC,EACH,MAAM,IAAI,aAAW,8CAA8C,EAGrE,MAAM,EAAoB,EAAc,EAAU,CAAa,EAGjE,GAAI,EAAU,OAAS,EACrB,MAAM,EAAiB,EAAW,CAAQ,EAG5C,MAAO,IAEX,KAAM,sBACN,gBAAiB,CACf,QAAM,OACN,QAAM,OACN,QAAM,MACN,QAAM,UACN,QAAM,SACN,QAAM,kBACN,QAAM,UACN,QAAM,QACN,QAAM,SACN,QAAM,SACN,QAAM,KACN,QAAM,MACR,CACF,CAAC,EAEY,EAAgC,2BAAyB,CAAkB",
|
|
8
|
+
"debugId": "AE962C27E7194C4F64756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as w,b as h}from"../../chunk-kx2thqhk.js";import{Chain as o,ChainId as m,ChainToChainId as d,filterSupportedChains as _,USwapError as i,WalletOption as p}from"@tcswap/helpers";import{createWallet as f,getWalletSupportedChains as y}from"@tcswap/wallet-core";var O=[m.Cosmos,m.Kujira,m.Noble,m.THORChain],S=[o.Ethereum,o.BinanceSmartChain,o.Avalanche,o.Polygon,o.Arbitrum,o.Optimism,o.Base,o.XLayer];async function T(r,l,s){await Promise.all(r.map(async(n)=>{let e=d[n];await s.enable(e);let a=s.getOfflineSignerOnlyAmino(e);if(!a)throw new i("wallet_cosmostation_signer_not_found");let{getCosmosToolbox:c}=await import("@tcswap/toolboxes/cosmos"),t=await a.getAccounts();if(!t?.[0]?.address)throw new i("wallet_cosmostation_no_accounts");let[{address:u}]=t,C=await c(n,{signer:a});l({...C,address:u,chain:n,walletType:p.COSMOSTATION})}))}async function g(r,l){let s=window.ethereum;if(!s)throw new i("wallet_cosmostation_evm_provider_not_found");let n=await s.request({method:"eth_requestAccounts"});if(!n||n.length===0)throw new i("wallet_cosmostation_no_evm_accounts");let{getEvmToolbox:e}=await import("@tcswap/toolboxes/evm");for(let a of r){let c=e(a,{provider:s}),[t]=n;if(!t)throw new i("wallet_cosmostation_no_evm_address");l({...c,address:t,chain:a,walletType:p.COSMOSTATION})}}var v=f({connect:({addChain:r,supportedChains:l})=>async function(n){let e=_({chains:n,supportedChains:l,walletType:p.COSMOSTATION});if(!window.cosmostation)throw new i("wallet_cosmostation_not_found");let a=e.filter((t)=>O.includes(d[t])),c=e.filter((t)=>S.includes(t));if(a.length>0){let t=window.cosmostation.providers?.keplr;if(!t)throw new i("wallet_cosmostation_keplr_provider_not_found");await T(a,r,t)}if(c.length>0)await g(c,r);return!0},name:"connectCosmostation",supportedChains:[o.Cosmos,o.Kujira,o.Noble,o.THORChain,o.Ethereum,o.BinanceSmartChain,o.Avalanche,o.Polygon,o.Arbitrum,o.Optimism,o.Base,o.XLayer]}),I=y(v);export{v as cosmostationWallet,I as COSMOSTATION_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=C699F27F7B8CDD7164756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/cosmostation/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport type { Keplr } from \"@keplr-wallet/types\";\nimport { Chain, ChainId, ChainToChainId, filterSupportedChains, USwapError, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nconst cosmostationSupportedChainIds = [ChainId.Cosmos, ChainId.Kujira, ChainId.Noble, ChainId.THORChain] as const;\nconst cosmostationSupportedEVMChains = [\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n Chain.XLayer,\n] as const;\n\ndeclare global {\n interface Window {\n cosmostation?: { providers?: { keplr?: Keplr } };\n }\n}\n\nasync function connectCosmosChains(chains: Chain[], addChain: any, keplrProvider: Keplr) {\n await Promise.all(\n chains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof cosmostationSupportedChainIds)[number];\n\n await keplrProvider.enable(chainId);\n const signer = keplrProvider.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new USwapError(\"wallet_cosmostation_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@tcswap/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new USwapError(\"wallet_cosmostation_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(chain as any, { signer });\n\n addChain({ ...toolbox, address, chain, walletType: WalletOption.COSMOSTATION });\n }),\n );\n}\n\nasync function connectEvmChains(chains: Chain[], addChain: any) {\n const provider = window.ethereum;\n\n if (!provider) {\n throw new USwapError(\"wallet_cosmostation_evm_provider_not_found\");\n }\n\n const accounts = (await provider.request({ method: \"eth_requestAccounts\" })) as string[];\n\n if (!accounts || accounts.length === 0) {\n throw new USwapError(\"wallet_cosmostation_no_evm_accounts\");\n }\n\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n\n for (const chain of chains) {\n const toolbox = getEvmToolbox(chain as any, { provider });\n const [address] = accounts;\n\n if (!address) {\n throw new USwapError(\"wallet_cosmostation_no_evm_address\");\n }\n\n addChain({ ...toolbox, address, chain, walletType: WalletOption.COSMOSTATION });\n }\n}\n\nexport const cosmostationWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectCosmostation(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType: WalletOption.COSMOSTATION });\n\n if (!window.cosmostation) {\n throw new USwapError(\"wallet_cosmostation_not_found\");\n }\n\n const cosmosChains = filteredChains.filter((chain) =>\n cosmostationSupportedChainIds.includes(ChainToChainId[chain] as any),\n );\n const evmChains = filteredChains.filter((chain) => cosmostationSupportedEVMChains.includes(chain as any));\n\n if (cosmosChains.length > 0) {\n const keplrProvider = window.cosmostation.providers?.keplr;\n if (!keplrProvider) {\n throw new USwapError(\"wallet_cosmostation_keplr_provider_not_found\");\n }\n\n await connectCosmosChains(cosmosChains, addChain, keplrProvider);\n }\n\n if (evmChains.length > 0) {\n await connectEvmChains(evmChains, addChain);\n }\n\n return true;\n },\n name: \"connectCosmostation\",\n supportedChains: [\n Chain.Cosmos,\n Chain.Kujira,\n Chain.Noble,\n Chain.THORChain,\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n Chain.XLayer,\n ],\n});\n\nexport const COSMOSTATION_SUPPORTED_CHAINS = getWalletSupportedChains(cosmostationWallet);\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "mDAKA,gBAAS,aAAO,oBAAS,2BAAgB,gBAAuB,kBAAY,wBAC5E,uBAAS,8BAAc,4BAEvB,IAAM,EAAgC,CAAC,EAAQ,OAAQ,EAAQ,OAAQ,EAAQ,MAAO,EAAQ,SAAS,EACjG,EAAiC,CACrC,EAAM,SACN,EAAM,kBACN,EAAM,UACN,EAAM,QACN,EAAM,SACN,EAAM,SACN,EAAM,KACN,EAAM,MACR,EAQA,eAAe,CAAmB,CAAC,EAAiB,EAAe,EAAsB,CACvF,MAAM,QAAQ,IACZ,EAAO,IAAI,MAAO,IAAU,CAC1B,IAAM,EAAU,EAAe,GAE/B,MAAM,EAAc,OAAO,CAAO,EAClC,IAAM,EAAS,EAAc,0BAA0B,CAAO,EAC9D,GAAI,CAAC,EAAQ,MAAM,IAAI,EAAW,sCAAsC,EAExE,IAAQ,oBAAqB,KAAa,oCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,GAAI,CAAC,IAAW,IAAI,QAAS,MAAM,IAAI,EAAW,iCAAiC,EAEnF,KAAS,YAAa,EAChB,EAAU,MAAM,EAAiB,EAAc,CAAE,QAAO,CAAC,EAE/D,EAAS,IAAK,EAAS,UAAS,QAAO,WAAY,EAAa,YAAa,CAAC,EAC/E,CACH,EAGF,eAAe,CAAgB,CAAC,EAAiB,EAAe,CAC9D,IAAM,EAAW,OAAO,SAExB,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,4CAA4C,EAGnE,IAAM,EAAY,MAAM,EAAS,QAAQ,CAAE,OAAQ,qBAAsB,CAAC,EAE1E,GAAI,CAAC,GAAY,EAAS,SAAW,EACnC,MAAM,IAAI,EAAW,qCAAqC,EAG5D,IAAQ,iBAAkB,KAAa,iCAEvC,QAAW,KAAS,EAAQ,CAC1B,IAAM,EAAU,EAAc,EAAc,CAAE,UAAS,CAAC,GACjD,GAAW,EAElB,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,oCAAoC,EAG3D,EAAS,IAAK,EAAS,UAAS,QAAO,WAAY,EAAa,YAAa,CAAC,GAI3E,IAAM,EAAqB,EAAa,CAC7C,QAAS,EAAG,WAAU,qBACpB,cAAkC,CAAC,EAAiB,CAClD,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,WAAY,EAAa,YAAa,CAAC,EAE/G,GAAI,CAAC,OAAO,aACV,MAAM,IAAI,EAAW,+BAA+B,EAGtD,IAAM,EAAe,EAAe,OAAO,CAAC,IAC1C,EAA8B,SAAS,EAAe,EAAa,CACrE,EACM,EAAY,EAAe,OAAO,CAAC,IAAU,EAA+B,SAAS,CAAY,CAAC,EAExG,GAAI,EAAa,OAAS,EAAG,CAC3B,IAAM,EAAgB,OAAO,aAAa,WAAW,MACrD,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,8CAA8C,EAGrE,MAAM,EAAoB,EAAc,EAAU,CAAa,EAGjE,GAAI,EAAU,OAAS,EACrB,MAAM,EAAiB,EAAW,CAAQ,EAG5C,MAAO,IAEX,KAAM,sBACN,gBAAiB,CACf,EAAM,OACN,EAAM,OACN,EAAM,MACN,EAAM,UACN,EAAM,SACN,EAAM,kBACN,EAAM,UACN,EAAM,QACN,EAAM,SACN,EAAM,SACN,EAAM,KACN,EAAM,MACR,CACF,CAAC,EAEY,EAAgC,EAAyB,CAAkB",
|
|
8
|
+
"debugId": "C699F27F7B8CDD7164756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var L={};S(L,{ctrlWallet:()=>y,CTRL_SUPPORTED_CHAINS:()=>B});module.exports=N(L);var t=require("@tcswap/helpers"),T=require("@tcswap/wallet-core");var n=require("@tcswap/helpers"),x=require("ts-pattern");function i(o){if(!window.ctrl)throw new n.USwapError("wallet_ctrl_not_found");return x.match(o).with(...n.EVMChains,()=>window.ctrl?.ethereum).with(n.Chain.Cosmos,n.Chain.Kujira,n.Chain.Noble,()=>window.ctrl?.keplr).with(n.Chain.Bitcoin,()=>window.ctrl?.bitcoin).with(n.Chain.BitcoinCash,()=>window.ctrl?.bitcoincash).with(n.Chain.Dogecoin,()=>window.ctrl?.dogecoin).with(n.Chain.Litecoin,()=>window.ctrl?.litecoin).with(n.Chain.Solana,()=>window.ctrl?.solana).with(n.Chain.THORChain,()=>window.ctrl?.thorchain).with(n.Chain.Maya,()=>window.ctrl?.mayachain).with(n.Chain.Near,()=>window.ctrl?.near).otherwise(()=>{return})}async function u({method:o,params:e,chain:a}){let r=await i(a);return new Promise((s,w)=>{if(r&&"request"in r)r.request({method:o,params:e},(c,f)=>{c?w(c):s(f)})})}async function b(o){try{let e=await i(o);if(!e)throw new n.USwapError({errorKey:"wallet_provider_not_found",info:{chain:o,wallet:n.WalletOption.CTRL}});if([n.Chain.Cosmos,n.Chain.Kujira,n.Chain.Noble].includes(o)){let r=await i(n.Chain.Cosmos);if(!r||"request"in r)throw new n.USwapError({errorKey:"wallet_provider_not_found",info:{chain:o,wallet:n.WalletOption.CTRL}});let s=n.ChainToChainId[o];await r.enable(s);let w=r.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(n.EVMChains.includes(o)){if("request"in e&&typeof e.request==="function")return(await e.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:r}=await import("ethers"),s=new r(e,"any"),[w]=await n.providerRequest({method:"eth_requestAccounts",params:[],provider:s});return w}if(o===n.Chain.Solana)return(await(await i(n.Chain.Solana)).connect()).publicKey.toString();if(o===n.Chain.Near){if(!window.ctrl?.near)throw new n.USwapError("wallet_ctrl_not_found",{chain:n.Chain.Near});if(!window.ctrl.near.isSignedIn?.())return(await window.ctrl.near.request?.({method:"connect"}))?.[0]||"";return window.ctrl.near.getAccountId?.()||""}return(await e.request({method:"request_accounts",params:[]}))[0]}catch{throw new n.USwapError({errorKey:"wallet_provider_not_found",info:{chain:o,wallet:n.WalletOption.CTRL}})}}async function g({assetValue:o,recipient:e,memo:a,gasLimit:r},s="transfer"){if(!o)throw new n.USwapError("wallet_ctrl_asset_not_defined");let w=await b(o.chain),c=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},from:w,gasLimit:r,memo:a||"",recipient:e}];return u({chain:o.chain,method:s,params:c})}var y=T.createWallet({connect:({addChain:o,walletType:e,supportedChains:a})=>async function(s){let c=t.filterSupportedChains({chains:s,supportedChains:a,walletType:e}).map(async(f)=>{let m=await b(f),_=await p(f);o({..._,address:m,chain:f,walletType:e})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[t.Chain.Arbitrum,t.Chain.Aurora,t.Chain.Avalanche,t.Chain.Base,t.Chain.Berachain,t.Chain.BinanceSmartChain,t.Chain.Bitcoin,t.Chain.BitcoinCash,t.Chain.Cosmos,t.Chain.Dogecoin,t.Chain.Ethereum,t.Chain.Gnosis,t.Chain.Kujira,t.Chain.Litecoin,t.Chain.Maya,t.Chain.Monad,t.Chain.Near,t.Chain.Noble,t.Chain.Optimism,t.Chain.Polygon,t.Chain.Solana,t.Chain.THORChain,t.Chain.XLayer],walletType:t.WalletOption.CTRL}),B=T.getWalletSupportedChains(y);async function p(o){switch(o){case t.Chain.Solana:{let{getSolanaToolbox:e}=await import("@tcswap/toolboxes/solana"),a=i(o);if(!a)throw new t.USwapError("wallet_ctrl_not_found");return await e({signer:a})}case t.Chain.Maya:case t.Chain.THORChain:{let{getCosmosToolbox:e,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:r}=await import("@tcswap/toolboxes/cosmos"),s=o===t.Chain.Maya?r:a;return{...await e(o),deposit:(c)=>g({...c,recipient:""},"deposit"),transfer:(c)=>g({...c,gasLimit:s},"transfer")}}case t.Chain.Cosmos:case t.Chain.Kujira:case t.Chain.Noble:{let{getCosmosToolbox:e}=await import("@tcswap/toolboxes/cosmos"),a=t.ChainToChainId[o],r=i(o);await r?.enable(a);let s=r?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new t.USwapError("wallet_ctrl_not_found");return await e(o,{signer:s})}case t.Chain.Bitcoin:case t.Chain.BitcoinCash:case t.Chain.Dogecoin:case t.Chain.Litecoin:{let{getUtxoToolbox:e}=await import("@tcswap/toolboxes/utxo");return{...await e(o),transfer:g}}case t.Chain.Arbitrum:case t.Chain.Aurora:case t.Chain.Avalanche:case t.Chain.Base:case t.Chain.Berachain:case t.Chain.BinanceSmartChain:case t.Chain.Ethereum:case t.Chain.Gnosis:case t.Chain.Monad:case t.Chain.Optimism:case t.Chain.Polygon:case t.Chain.XLayer:{let{prepareNetworkSwitch:e,switchEVMWalletNetwork:a}=await import("@tcswap/helpers"),{getEvmToolbox:r}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=i(o);if(!w)throw new t.USwapError("wallet_ctrl_not_found");let c=new s(w,"any"),f=await c.getSigner(),m=await r(o,{provider:c,signer:f});try{if(o!==t.Chain.Ethereum){let _=m.getNetworkParams();await a(c,o,_)}}catch{throw new t.USwapError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:o,wallet:t.WalletOption.CTRL}})}return e({chain:o,provider:c,toolbox:m})}case t.Chain.Near:{let e=i(o);if(!e)throw new t.USwapError("wallet_ctrl_not_found",{chain:t.Chain.Near});let{createNearSignerFromProvider:a}=await import("../../chunk-swh9jwp7.js"),{getNearToolbox:r}=await import("@tcswap/toolboxes/near"),s=await a(e,"CTRL"),w=await s.getAddress();return{...await r({signer:s}),transfer:async(m)=>{let{actionCreators:_}=await import("@near-js/transactions"),A=m.assetValue.getBaseValue("string"),d={actions:[_.transfer(BigInt(A))],receiverId:m.recipient,signerId:w};return await e.request({method:"signAndSendTransaction",params:{transaction:d}})}}}default:return null}}
|
|
2
|
+
|
|
3
|
+
//# debugId=6ED94D00255E4AB364756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Monad,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n Chain.XLayer,\n ],\n walletType: WalletOption.CTRL,\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@tcswap/toolboxes/solana\");\n const provider = getCtrlProvider(chain);\n\n if (!provider) {\n throw new USwapError(\"wallet_ctrl_not_found\");\n }\n const toolbox = await getSolanaToolbox({ signer: provider });\n\n return toolbox;\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@tcswap/toolboxes/cosmos\");\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@tcswap/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId, { preferNoSetFee: true });\n\n if (!signer) {\n throw new USwapError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@tcswap/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Monad:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.XLayer: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@tcswap/helpers\");\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new USwapError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new USwapError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n const provider = getCtrlProvider(chain);\n\n if (!provider) {\n throw new USwapError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@tcswap/toolboxes/near\");\n\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const { actionCreators } = await import(\"@near-js/transactions\");\n\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = actionCreators.transfer(BigInt(amountInYocto));\n\n const transaction = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\n\n return txHash;\n };\n\n return { ...toolbox, transfer };\n }\n\n default:\n return null;\n }\n}\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type CosmosChain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n providerRequest,\n type TCLikeChain,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport type { SolanaProvider } from \"@tcswap/toolboxes/solana\";\nimport type { Eip1193Provider } from \"ethers\";\nimport { match } from \"ts-pattern\";\nimport type { NearBrowserWalletProvider } from \"../helpers/near\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype CtrlProviderType<T> = T extends typeof Chain.Solana\n ? SolanaProvider\n : T extends Exclude<CosmosChain, TCLikeChain>\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : T extends typeof Chain.Near\n ? NearBrowserWalletProvider\n : undefined;\n\nexport function getCtrlProvider<T extends Chain>(chain: T): CtrlProviderType<T> {\n if (!window.ctrl) throw new USwapError(\"wallet_ctrl_not_found\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(...EVMChains, () => window.ctrl?.ethereum)\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => window.ctrl?.keplr)\n .with(Chain.Bitcoin, () => window.ctrl?.bitcoin)\n .with(Chain.BitcoinCash, () => window.ctrl?.bitcoincash)\n .with(Chain.Dogecoin, () => window.ctrl?.dogecoin)\n .with(Chain.Litecoin, () => window.ctrl?.litecoin)\n .with(Chain.Solana, () => window.ctrl?.solana)\n .with(Chain.THORChain, () => window.ctrl?.thorchain)\n .with(Chain.Maya, () => window.ctrl?.mayachain)\n .with(Chain.Near, () => window.ctrl?.near)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain as Exclude<CosmosChain, TCLikeChain>)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.ctrl?.near) {\n throw new USwapError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.ctrl.near.isSignedIn?.()) {\n const result = await window.ctrl.near.request<string[]>?.({ method: \"connect\" });\n return result?.[0] || \"\";\n }\n\n return window.ctrl.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new USwapError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
|
|
7
|
+
],
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "6ED94D00255E4AB364756E2164756E21",
|
|
10
|
+
"names": []
|
|
11
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as l,b as i}from"../../chunk-kx2thqhk.js";import{Chain as t,ChainToChainId as R,filterSupportedChains as G,USwapError as b,WalletOption as u}from"@tcswap/helpers";import{createWallet as I,getWalletSupportedChains as M}from"@tcswap/wallet-core";import{Chain as c,ChainToChainId as B,EVMChains as d,providerRequest as p,USwapError as g,WalletOption as y}from"@tcswap/helpers";import{match as L}from"ts-pattern";function f(o){if(!window.ctrl)throw new g("wallet_ctrl_not_found");return L(o).with(...d,()=>window.ctrl?.ethereum).with(c.Cosmos,c.Kujira,c.Noble,()=>window.ctrl?.keplr).with(c.Bitcoin,()=>window.ctrl?.bitcoin).with(c.BitcoinCash,()=>window.ctrl?.bitcoincash).with(c.Dogecoin,()=>window.ctrl?.dogecoin).with(c.Litecoin,()=>window.ctrl?.litecoin).with(c.Solana,()=>window.ctrl?.solana).with(c.THORChain,()=>window.ctrl?.thorchain).with(c.Maya,()=>window.ctrl?.mayachain).with(c.Near,()=>window.ctrl?.near).otherwise(()=>{return})}async function H({method:o,params:n,chain:s}){let e=await f(s);return new Promise((r,w)=>{if(e&&"request"in e)e.request({method:o,params:n},(a,m)=>{a?w(a):r(m)})})}async function A(o){try{let n=await f(o);if(!n)throw new g({errorKey:"wallet_provider_not_found",info:{chain:o,wallet:y.CTRL}});if([c.Cosmos,c.Kujira,c.Noble].includes(o)){let e=await f(c.Cosmos);if(!e||"request"in e)throw new g({errorKey:"wallet_provider_not_found",info:{chain:o,wallet:y.CTRL}});let r=B[o];await e.enable(r);let w=e.getOfflineSigner(r),[a]=await w.getAccounts();return a?.address}if(d.includes(o)){if("request"in n&&typeof n.request==="function")return(await n.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:e}=await import("ethers"),r=new e(n,"any"),[w]=await p({method:"eth_requestAccounts",params:[],provider:r});return w}if(o===c.Solana)return(await(await f(c.Solana)).connect()).publicKey.toString();if(o===c.Near){if(!window.ctrl?.near)throw new g("wallet_ctrl_not_found",{chain:c.Near});if(!window.ctrl.near.isSignedIn?.())return(await window.ctrl.near.request?.({method:"connect"}))?.[0]||"";return window.ctrl.near.getAccountId?.()||""}return(await n.request({method:"request_accounts",params:[]}))[0]}catch{throw new g({errorKey:"wallet_provider_not_found",info:{chain:o,wallet:y.CTRL}})}}async function x({assetValue:o,recipient:n,memo:s,gasLimit:e},r="transfer"){if(!o)throw new g("wallet_ctrl_asset_not_defined");let w=await A(o.chain),a=[{amount:{amount:o.getBaseValue("number"),decimals:o.decimal},asset:{chain:o.chain,symbol:o.symbol.toUpperCase(),ticker:o.symbol.toUpperCase()},from:w,gasLimit:e,memo:s||"",recipient:n}];return H({chain:o.chain,method:r,params:a})}var O=I({connect:({addChain:o,walletType:n,supportedChains:s})=>async function(r){let a=G({chains:r,supportedChains:s,walletType:n}).map(async(m)=>{let _=await A(m),T=await P(m);o({...T,address:_,chain:m,walletType:n})});return await Promise.all(a),!0},name:"connectCtrl",supportedChains:[t.Arbitrum,t.Aurora,t.Avalanche,t.Base,t.Berachain,t.BinanceSmartChain,t.Bitcoin,t.BitcoinCash,t.Cosmos,t.Dogecoin,t.Ethereum,t.Gnosis,t.Kujira,t.Litecoin,t.Maya,t.Monad,t.Near,t.Noble,t.Optimism,t.Polygon,t.Solana,t.THORChain,t.XLayer],walletType:u.CTRL}),E=M(O);async function P(o){switch(o){case t.Solana:{let{getSolanaToolbox:n}=await import("@tcswap/toolboxes/solana"),s=f(o);if(!s)throw new b("wallet_ctrl_not_found");return await n({signer:s})}case t.Maya:case t.THORChain:{let{getCosmosToolbox:n,THORCHAIN_GAS_VALUE:s,MAYA_GAS_VALUE:e}=await import("@tcswap/toolboxes/cosmos"),r=o===t.Maya?e:s;return{...await n(o),deposit:(a)=>x({...a,recipient:""},"deposit"),transfer:(a)=>x({...a,gasLimit:r},"transfer")}}case t.Cosmos:case t.Kujira:case t.Noble:{let{getCosmosToolbox:n}=await import("@tcswap/toolboxes/cosmos"),s=R[o],e=f(o);await e?.enable(s);let r=e?.getOfflineSignerOnlyAmino(s,{preferNoSetFee:!0});if(!r)throw new b("wallet_ctrl_not_found");return await n(o,{signer:r})}case t.Bitcoin:case t.BitcoinCash:case t.Dogecoin:case t.Litecoin:{let{getUtxoToolbox:n}=await import("@tcswap/toolboxes/utxo");return{...await n(o),transfer:x}}case t.Arbitrum:case t.Aurora:case t.Avalanche:case t.Base:case t.Berachain:case t.BinanceSmartChain:case t.Ethereum:case t.Gnosis:case t.Monad:case t.Optimism:case t.Polygon:case t.XLayer:{let{prepareNetworkSwitch:n,switchEVMWalletNetwork:s}=await import("@tcswap/helpers"),{getEvmToolbox:e}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:r}=await import("ethers"),w=f(o);if(!w)throw new b("wallet_ctrl_not_found");let a=new r(w,"any"),m=await a.getSigner(),_=await e(o,{provider:a,signer:m});try{if(o!==t.Ethereum){let T=_.getNetworkParams();await s(a,o,T)}}catch{throw new b({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:o,wallet:u.CTRL}})}return n({chain:o,provider:a,toolbox:_})}case t.Near:{let n=f(o);if(!n)throw new b("wallet_ctrl_not_found",{chain:t.Near});let{createNearSignerFromProvider:s}=await import("../../chunk-7y3ffnf3.js"),{getNearToolbox:e}=await import("@tcswap/toolboxes/near"),r=await s(n,"CTRL"),w=await r.getAddress();return{...await e({signer:r}),transfer:async(_)=>{let{actionCreators:T}=await import("@near-js/transactions"),N=_.assetValue.getBaseValue("string"),S={actions:[T.transfer(BigInt(N))],receiverId:_.recipient,signerId:w};return await n.request({method:"signAndSendTransaction",params:{transaction:S}})}}}default:return null}}export{O as ctrlWallet,E as CTRL_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=66443FD54A5EA84A64756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Monad,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n Chain.XLayer,\n ],\n walletType: WalletOption.CTRL,\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@tcswap/toolboxes/solana\");\n const provider = getCtrlProvider(chain);\n\n if (!provider) {\n throw new USwapError(\"wallet_ctrl_not_found\");\n }\n const toolbox = await getSolanaToolbox({ signer: provider });\n\n return toolbox;\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@tcswap/toolboxes/cosmos\");\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@tcswap/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId, { preferNoSetFee: true });\n\n if (!signer) {\n throw new USwapError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@tcswap/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Monad:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.XLayer: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@tcswap/helpers\");\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new USwapError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new USwapError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n const provider = getCtrlProvider(chain);\n\n if (!provider) {\n throw new USwapError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@tcswap/toolboxes/near\");\n\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const { actionCreators } = await import(\"@near-js/transactions\");\n\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = actionCreators.transfer(BigInt(amountInYocto));\n\n const transaction = { actions: [action], receiverId: params.recipient, signerId: accountId };\n\n const txHash: string = await provider.request({ method: \"signAndSendTransaction\", params: { transaction } });\n\n return txHash;\n };\n\n return { ...toolbox, transfer };\n }\n\n default:\n return null;\n }\n}\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type CosmosChain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n providerRequest,\n type TCLikeChain,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport type { SolanaProvider } from \"@tcswap/toolboxes/solana\";\nimport type { Eip1193Provider } from \"ethers\";\nimport { match } from \"ts-pattern\";\nimport type { NearBrowserWalletProvider } from \"../helpers/near\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype CtrlProviderType<T> = T extends typeof Chain.Solana\n ? SolanaProvider\n : T extends Exclude<CosmosChain, TCLikeChain>\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : T extends typeof Chain.Near\n ? NearBrowserWalletProvider\n : undefined;\n\nexport function getCtrlProvider<T extends Chain>(chain: T): CtrlProviderType<T> {\n if (!window.ctrl) throw new USwapError(\"wallet_ctrl_not_found\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(...EVMChains, () => window.ctrl?.ethereum)\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => window.ctrl?.keplr)\n .with(Chain.Bitcoin, () => window.ctrl?.bitcoin)\n .with(Chain.BitcoinCash, () => window.ctrl?.bitcoincash)\n .with(Chain.Dogecoin, () => window.ctrl?.dogecoin)\n .with(Chain.Litecoin, () => window.ctrl?.litecoin)\n .with(Chain.Solana, () => window.ctrl?.solana)\n .with(Chain.THORChain, () => window.ctrl?.thorchain)\n .with(Chain.Maya, () => window.ctrl?.mayachain)\n .with(Chain.Near, () => window.ctrl?.near)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain as Exclude<CosmosChain, TCLikeChain>)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.ctrl?.near) {\n throw new USwapError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.ctrl.near.isSignedIn?.()) {\n const result = await window.ctrl.near.request<string[]>?.({ method: \"connect\" });\n return result?.[0] || \"\";\n }\n\n return window.ctrl.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new USwapError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
|
|
7
|
+
],
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "66443FD54A5EA84A64756E2164756E21",
|
|
10
|
+
"names": []
|
|
11
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var u={};M(u,{getWeb3WalletMethods:()=>O,evmWallet:()=>_,EVM_EXTENSIONS_SUPPORTED_CHAINS:()=>g});module.exports=m(u);var t=require("@tcswap/helpers"),c=require("@tcswap/wallet-core"),S=(r)=>{switch(r){case t.WalletOption.COINBASE_WEB:return window.coinbaseWalletExtension;case t.WalletOption.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},O=async({address:r,walletProvider:w,chain:o,provider:e})=>{if(!w)throw new t.USwapError("wallet_evm_extensions_not_found");let{getEvmToolbox:n}=await import("@tcswap/toolboxes/evm"),i=await e.getSigner(),a=await n(o,{provider:e,signer:i}),{chainIdHex:E}=t.getChainConfig(o);if((await e.getNetwork()).chainId.toString()!==E)try{let s=a.getNetworkParams();await t.switchEVMWalletNetwork(e,o,s)}catch{throw new t.USwapError("wallet_evm_extensions_failed_to_switch_network",{chain:o})}return t.prepareNetworkSwitch({chain:o,provider:e,toolbox:{...a,getBalance:()=>a.getBalance(r)}})},_=c.createWallet({connect:({addChain:r,supportedChains:w})=>async function(e,n=t.WalletOption.METAMASK,i){let a=t.filterSupportedChains({chains:e,supportedChains:w,walletType:n}),{BrowserProvider:E}=await import("ethers");return await Promise.all(a.map(async(p)=>{if(n===t.WalletOption.EIP6963&&!i)throw new t.USwapError("wallet_evm_extensions_no_provider");let s=i||S(n),l=new E(s,"any");await l.send("eth_requestAccounts",[]);let d=await(await l.getSigner()).getAddress(),h=await O({address:d,chain:p,provider:l,walletProvider:s});r({...h,address:d,chain:p,disconnect:()=>l.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:n});return})),!0},name:"connectEVMWallet",supportedChains:[...t.EVMChains]}),g=c.getWalletSupportedChains(_);
|
|
2
|
+
|
|
3
|
+
//# debugId=66DE5E3DBEFC294164756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/evm-extensions/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n type Chain,\n type EVMChain,\n EVMChains,\n filterSupportedChains,\n getChainConfig,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\nexport type EVMWalletOptions =\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963;\n\nconst getWalletForType = (\n walletType:\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963,\n) => {\n switch (walletType) {\n case WalletOption.COINBASE_WEB:\n return window.coinbaseWalletExtension;\n case WalletOption.TRUSTWALLET_WEB:\n return window.trustwallet;\n default:\n return window.ethereum;\n }\n};\n\nexport const getWeb3WalletMethods = async ({\n address,\n walletProvider,\n chain,\n provider,\n}: {\n address: string;\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n provider: BrowserProvider;\n}) => {\n if (!walletProvider) throw new USwapError(\"wallet_evm_extensions_not_found\");\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const { chainIdHex } = getChainConfig(chain);\n\n const currentNetwork = await provider.getNetwork();\n if (currentNetwork.chainId.toString() !== chainIdHex) {\n try {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch {\n throw new USwapError(\"wallet_evm_extensions_failed_to_switch_network\", { chain });\n }\n }\n\n return prepareNetworkSwitch({\n chain,\n provider,\n toolbox: { ...toolbox, getBalance: () => toolbox.getBalance(address) },\n });\n};\n\nexport const evmWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectEVMWallet(\n chains: Chain[],\n walletType: EVMWalletOptions = WalletOption.METAMASK,\n eip1193Provider?: Eip1193Provider,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963 && !eip1193Provider)\n throw new USwapError(\"wallet_evm_extensions_no_provider\");\n\n const windowProvider = eip1193Provider || getWalletForType(walletType);\n const browserProvider = new BrowserProvider(windowProvider, \"any\");\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n address,\n chain,\n provider: browserProvider,\n walletProvider: windowProvider,\n });\n\n const disconnect = () => browserProvider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n addChain({ ...walletMethods, address, chain, disconnect, walletType });\n return;\n }),\n );\n\n return true;\n },\n name: \"connectEVMWallet\",\n supportedChains: [...EVMChains] as EVMChain[],\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "qHAcO,IAVP,6BAWA,iCAWM,EAAmB,CACvB,IAOG,CACH,OAAQ,QACD,eAAa,aAChB,OAAO,OAAO,6BACX,eAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,UACA,iBACA,QACA,cAMI,CACJ,GAAI,CAAC,EAAgB,MAAM,IAAI,aAAW,iCAAiC,EAC3E,IAAQ,iBAAkB,KAAa,iCAEjC,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,GACvD,cAAe,iBAAe,CAAK,EAG3C,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,EACxC,GAAI,CACF,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,yBAAuB,EAAU,EAAO,CAAa,EAC3D,KAAM,CACN,MAAM,IAAI,aAAW,iDAAkD,CAAE,OAAM,CAAC,EAIpF,OAAO,uBAAqB,CAC1B,QACA,WACA,QAAS,IAAK,EAAS,WAAY,IAAM,EAAQ,WAAW,CAAO,CAAE,CACvE,CAAC,GAGU,EAAY,eAAa,CACpC,QAAS,EAAG,WAAU,qBACpB,cAA+B,CAC7B,EACA,EAA+B,eAAa,SAC5C,EACA,CACA,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,mBAAoB,KAAa,kBA2BzC,OAzBA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,eAAa,SAAW,CAAC,EAC1C,MAAM,IAAI,aAAW,mCAAmC,EAE1D,IAAM,EAAiB,GAAmB,EAAiB,CAAU,EAC/D,EAAkB,IAAI,EAAgB,EAAgB,KAAK,EAEjE,MAAM,EAAgB,KAAK,sBAAuB,CAAC,CAAC,EAEpD,IAAM,EAAU,MADD,MAAM,EAAgB,UAAU,GAClB,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,UACA,QACA,SAAU,EACV,eAAgB,CAClB,CAAC,EAGD,EAAS,IAAK,EAAe,UAAS,QAAO,WAD1B,IAAM,EAAgB,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EACvC,YAAW,CAAC,EACrE,OACD,CACH,EAEO,IAEX,KAAM,mBACN,gBAAiB,CAAC,GAAG,WAAS,CAChC,CAAC,EAEY,EAAkC,2BAAyB,CAAS",
|
|
8
|
+
"debugId": "66DE5E3DBEFC294164756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as W,b as O}from"../../chunk-kx2thqhk.js";import{EVMChains as h,filterSupportedChains as m,getChainConfig as M,prepareNetworkSwitch as S,switchEVMWalletNetwork as g,USwapError as p,WalletOption as l}from"@tcswap/helpers";import{createWallet as u,getWalletSupportedChains as B}from"@tcswap/wallet-core";var P=(n)=>{switch(n){case l.COINBASE_WEB:return window.coinbaseWalletExtension;case l.TRUSTWALLET_WEB:return window.trustwallet;default:return window.ethereum}},A=async({address:n,walletProvider:c,chain:e,provider:t})=>{if(!c)throw new p("wallet_evm_extensions_not_found");let{getEvmToolbox:o}=await import("@tcswap/toolboxes/evm"),a=await t.getSigner(),r=await o(e,{provider:t,signer:a}),{chainIdHex:w}=M(e);if((await t.getNetwork()).chainId.toString()!==w)try{let i=r.getNetworkParams();await g(t,e,i)}catch{throw new p("wallet_evm_extensions_failed_to_switch_network",{chain:e})}return S({chain:e,provider:t,toolbox:{...r,getBalance:()=>r.getBalance(n)}})},C=u({connect:({addChain:n,supportedChains:c})=>async function(t,o=l.METAMASK,a){let r=m({chains:t,supportedChains:c,walletType:o}),{BrowserProvider:w}=await import("ethers");return await Promise.all(r.map(async(E)=>{if(o===l.EIP6963&&!a)throw new p("wallet_evm_extensions_no_provider");let i=a||P(o),s=new w(i,"any");await s.send("eth_requestAccounts",[]);let d=await(await s.getSigner()).getAddress(),_=await A({address:d,chain:E,provider:s,walletProvider:i});n({..._,address:d,chain:E,disconnect:()=>s.send("wallet_revokePermissions",[{eth_accounts:{}}]),walletType:o});return})),!0},name:"connectEVMWallet",supportedChains:[...h]}),I=B(C);export{A as getWeb3WalletMethods,C as evmWallet,I as EVM_EXTENSIONS_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=F6C408FDFFE7194364756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/evm-extensions/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n type Chain,\n type EVMChain,\n EVMChains,\n filterSupportedChains,\n getChainConfig,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\nexport type EVMWalletOptions =\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963;\n\nconst getWalletForType = (\n walletType:\n | WalletOption.BRAVE\n | WalletOption.OKX_MOBILE\n | WalletOption.METAMASK\n | WalletOption.TRUSTWALLET_WEB\n | WalletOption.COINBASE_WEB\n | WalletOption.EIP6963,\n) => {\n switch (walletType) {\n case WalletOption.COINBASE_WEB:\n return window.coinbaseWalletExtension;\n case WalletOption.TRUSTWALLET_WEB:\n return window.trustwallet;\n default:\n return window.ethereum;\n }\n};\n\nexport const getWeb3WalletMethods = async ({\n address,\n walletProvider,\n chain,\n provider,\n}: {\n address: string;\n walletProvider?: Eip1193Provider;\n chain: EVMChain;\n provider: BrowserProvider;\n}) => {\n if (!walletProvider) throw new USwapError(\"wallet_evm_extensions_not_found\");\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const { chainIdHex } = getChainConfig(chain);\n\n const currentNetwork = await provider.getNetwork();\n if (currentNetwork.chainId.toString() !== chainIdHex) {\n try {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n } catch {\n throw new USwapError(\"wallet_evm_extensions_failed_to_switch_network\", { chain });\n }\n }\n\n return prepareNetworkSwitch({\n chain,\n provider,\n toolbox: { ...toolbox, getBalance: () => toolbox.getBalance(address) },\n });\n};\n\nexport const evmWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectEVMWallet(\n chains: Chain[],\n walletType: EVMWalletOptions = WalletOption.METAMASK,\n eip1193Provider?: Eip1193Provider,\n ) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const { BrowserProvider } = await import(\"ethers\");\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n if (walletType === WalletOption.EIP6963 && !eip1193Provider)\n throw new USwapError(\"wallet_evm_extensions_no_provider\");\n\n const windowProvider = eip1193Provider || getWalletForType(walletType);\n const browserProvider = new BrowserProvider(windowProvider, \"any\");\n\n await browserProvider.send(\"eth_requestAccounts\", []);\n const signer = await browserProvider.getSigner();\n const address = await signer.getAddress();\n\n const walletMethods = await getWeb3WalletMethods({\n address,\n chain,\n provider: browserProvider,\n walletProvider: windowProvider,\n });\n\n const disconnect = () => browserProvider.send(\"wallet_revokePermissions\", [{ eth_accounts: {} }]);\n addChain({ ...walletMethods, address, chain, disconnect, walletType });\n return;\n }),\n );\n\n return true;\n },\n name: \"connectEVMWallet\",\n supportedChains: [...EVMChains] as EVMChain[],\n});\n\nexport const EVM_EXTENSIONS_SUPPORTED_CHAINS = getWalletSupportedChains(evmWallet);\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "mDAIA,oBAGE,2BACA,oBACA,0BACA,4BACA,gBACA,kBACA,wBAEF,uBAAS,8BAAc,4BAWvB,IAAM,EAAmB,CACvB,IAOG,CACH,OAAQ,QACD,EAAa,aAChB,OAAO,OAAO,6BACX,EAAa,gBAChB,OAAO,OAAO,oBAEd,OAAO,OAAO,WAIP,EAAuB,OAClC,UACA,iBACA,QACA,cAMI,CACJ,GAAI,CAAC,EAAgB,MAAM,IAAI,EAAW,iCAAiC,EAC3E,IAAQ,iBAAkB,KAAa,iCAEjC,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,GACvD,cAAe,EAAe,CAAK,EAG3C,IADuB,MAAM,EAAS,WAAW,GAC9B,QAAQ,SAAS,IAAM,EACxC,GAAI,CACF,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAU,EAAO,CAAa,EAC3D,KAAM,CACN,MAAM,IAAI,EAAW,iDAAkD,CAAE,OAAM,CAAC,EAIpF,OAAO,EAAqB,CAC1B,QACA,WACA,QAAS,IAAK,EAAS,WAAY,IAAM,EAAQ,WAAW,CAAO,CAAE,CACvE,CAAC,GAGU,EAAY,EAAa,CACpC,QAAS,EAAG,WAAU,qBACpB,cAA+B,CAC7B,EACA,EAA+B,EAAa,SAC5C,EACA,CACA,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,GAC5E,mBAAoB,KAAa,kBA2BzC,OAzBA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,GAAI,IAAe,EAAa,SAAW,CAAC,EAC1C,MAAM,IAAI,EAAW,mCAAmC,EAE1D,IAAM,EAAiB,GAAmB,EAAiB,CAAU,EAC/D,EAAkB,IAAI,EAAgB,EAAgB,KAAK,EAEjE,MAAM,EAAgB,KAAK,sBAAuB,CAAC,CAAC,EAEpD,IAAM,EAAU,MADD,MAAM,EAAgB,UAAU,GAClB,WAAW,EAElC,EAAgB,MAAM,EAAqB,CAC/C,UACA,QACA,SAAU,EACV,eAAgB,CAClB,CAAC,EAGD,EAAS,IAAK,EAAe,UAAS,QAAO,WAD1B,IAAM,EAAgB,KAAK,2BAA4B,CAAC,CAAE,aAAc,CAAC,CAAE,CAAC,CAAC,EACvC,YAAW,CAAC,EACrE,OACD,CACH,EAEO,IAEX,KAAM,mBACN,gBAAiB,CAAC,GAAG,CAAS,CAChC,CAAC,EAEY,EAAkC,EAAyB,CAAS",
|
|
8
|
+
"debugId": "F6C408FDFFE7194364756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var I={};K(I,{keepkeyBexWallet:()=>l,KEEPKEY_BEX_SUPPORTED_CHAINS:()=>U});module.exports=D(I);var e=require("@tcswap/helpers"),f=require("@tcswap/wallet-core");var r=require("@tcswap/helpers"),T=require("@tcswap/helpers/contracts"),E=(t)=>{switch(t){case r.Chain.Bitcoin:return"bitcoin";case r.Chain.BitcoinCash:return"bitcoincash";case r.Chain.Dash:return"dash";case r.Chain.Dogecoin:return"dogecoin";case r.Chain.Litecoin:return"litecoin";default:throw new r.USwapError("wallet_keepkey_chain_not_supported",{chain:t})}};function P(t){if(!window.keepkey)throw new r.USwapError("wallet_keepkey_not_found");switch(t){case r.Chain.Ethereum:case r.Chain.Base:case r.Chain.Avalanche:case r.Chain.BinanceSmartChain:case r.Chain.Arbitrum:case r.Chain.Optimism:case r.Chain.Polygon:case r.Chain.XLayer:return window.keepkey.ethereum;case r.Chain.Cosmos:return window.keepkey.cosmos;case r.Chain.Bitcoin:return window.keepkey.bitcoin;case r.Chain.BitcoinCash:return window.keepkey.bitcoincash;case r.Chain.Dogecoin:return window.keepkey.dogecoin;case r.Chain.Litecoin:return window.keepkey.litecoin;case r.Chain.Dash:return window.keepkey.dash;case r.Chain.THORChain:return window.keepkey.thorchain;case r.Chain.Maya:return window.keepkey.mayachain;default:return}}function x({method:t,params:c,chain:n}){let o=P(n);return new Promise((i,a)=>{if(o&&"request"in o)o.request({method:t,params:c},(s,m)=>{s?a(s):i(m)});else a(new r.USwapError("wallet_provider_not_found"))})}async function k(t){let c=P(t);if(!c)throw new r.USwapError({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:r.WalletOption.KEEPKEY}});let n="request_accounts";if(r.EVMChains.includes(t))n="eth_requestAccounts";let[o]=await c.request({method:n,params:[]});return o}async function y({assetValue:t,recipient:c,memo:n,gasLimit:o},i="transfer"){if(!t)throw new r.USwapError("wallet_keepkey_asset_not_defined");let a=await k(t.chain),s=[{amount:{amount:t.getValue("string"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},from:a,gasLimit:o,memo:n,recipient:c}];return x({chain:t.chain,method:i,params:s})}function O(t,c){return{approve:async({assetAddress:n,spenderAddress:o,amount:i,from:a})=>{let{MAX_APPROVAL:s,getCreateContractTxObject:m,toHexString:u}=await import("@tcswap/toolboxes/evm"),g=m({chain:c,provider:t}),{value:p,to:_,data:v}=await g({abi:T.erc20ABI,contractAddress:n,funcName:"approve",funcParams:[o,BigInt(i||s)],txOverrides:{from:a}});return t.send("eth_sendTransaction",[{data:v||"0x",from:a,to:_,value:u(BigInt(p||0))}])},call:async({contractAddress:n,abi:o,funcName:i,funcParams:a=[],txOverrides:s})=>{if(!n)throw new r.USwapError("wallet_keepkey_contract_address_not_provided");let{createContract:m,getCreateContractTxObject:u,isStateChangingCall:g,toHexString:p}=await import("@tcswap/toolboxes/evm");if(g({abi:o,funcName:i})){let b=u({chain:c,provider:t}),{value:B,from:X,to:M,data:q}=await b({abi:o,contractAddress:n,funcName:i,funcParams:a,txOverrides:s});return t.send("eth_sendTransaction",[{data:q||"0x",from:X,to:M,value:p(BigInt(B||0))}])}let w=await m(n,o,t)[i]?.(...a);return typeof w?.hash==="string"?w?.hash:w},sendTransaction:async(n)=>{let{from:o,to:i,data:a,value:s}=n;if(!i)throw new r.USwapError("wallet_keepkey_send_transaction_no_address");let{toHexString:m}=await import("@tcswap/toolboxes/evm");return t.send("eth_sendTransaction",[{data:a||"0x",from:o,to:i,value:m(BigInt(s||0))}])}}}var l=f.createWallet({connect:({addChain:t,supportedChains:c,walletType:n})=>async function(i){let a=e.filterSupportedChains({chains:i,supportedChains:c,walletType:n});return await Promise.all(a.map(async(s)=>{let m=await k(s),u=await A(s);t({...u,address:m,chain:s,walletType:n})})),!0},name:"connectKeepkeyBex",supportedChains:[e.Chain.Arbitrum,e.Chain.Avalanche,e.Chain.BinanceSmartChain,e.Chain.Bitcoin,e.Chain.BitcoinCash,e.Chain.Base,e.Chain.Cosmos,e.Chain.Dash,e.Chain.Dogecoin,e.Chain.Ethereum,e.Chain.Kujira,e.Chain.Litecoin,e.Chain.Maya,e.Chain.Optimism,e.Chain.Polygon,e.Chain.Ripple,e.Chain.Solana,e.Chain.THORChain,e.Chain.XLayer],walletType:e.WalletOption.KEEPKEY_BEX}),U=f.getWalletSupportedChains(l);async function A(t){switch(t){case e.Chain.Maya:case e.Chain.THORChain:{let{getCosmosToolbox:c,THORCHAIN_GAS_VALUE:n,MAYA_GAS_VALUE:o}=await import("@tcswap/toolboxes/cosmos"),i=t===e.Chain.Maya?o:n;return{...await c(t),deposit:(s)=>y({...s,recipient:""},"deposit"),transfer:(s)=>y({...s,gasLimit:i},"transfer")}}case e.Chain.Cosmos:case e.Chain.Kujira:{let{getCosmosToolbox:c}=await import("@tcswap/toolboxes/cosmos"),n=window.keepkey?.cosmos?.getOfflineSignerOnlyAmino(e.ChainId[t]);if(!n)throw new e.USwapError("wallet_keepkey_signer_not_found");let o=await c(t,{signer:n}),i=await n.getAccounts();if(!i?.[0]?.address)throw new e.USwapError("wallet_keepkey_no_accounts");let[{address:a}]=i;return{...o,address:a}}case e.Chain.Dash:case e.Chain.Bitcoin:case e.Chain.BitcoinCash:case e.Chain.Dogecoin:case e.Chain.Litecoin:{let{getUtxoToolbox:c}=await import("@tcswap/toolboxes/utxo");return{...await c(t),getBalance:async()=>{let i=E(t),a=await window?.keepkey?.[i]?.request({method:"request_balance"});return[e.AssetValue.from({chain:t,value:a[0].balance})]},transfer:y}}case e.Chain.Ethereum:case e.Chain.BinanceSmartChain:case e.Chain.Base:case e.Chain.Arbitrum:case e.Chain.Optimism:case e.Chain.Polygon:case e.Chain.Avalanche:{let{prepareNetworkSwitch:c,switchEVMWalletNetwork:n}=await import("@tcswap/helpers"),{getEvmToolbox:o}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:i}=await import("ethers"),a=P(t);if(!a)throw new e.USwapError("wallet_keepkey_not_found");let s=new i(a,"any"),m=await s.getSigner(),u=await o(t,{provider:s,signer:m}),g=O(s,t);try{if(t!==e.Chain.Ethereum){let p=u.getNetworkParams();await n(s,t,p)}}catch{throw new e.USwapError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:t,wallet:e.WalletOption.KEEPKEY}})}return c({chain:t,provider:s,toolbox:{...u,...g}})}default:return null}}
|
|
2
|
+
|
|
3
|
+
//# debugId=2024307D44097BF064756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|