@swapkit/wallets 4.2.0 → 4.2.2
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-rx1jg8mz.js +4 -0
- package/dist/chunk-rx1jg8mz.js.map +10 -0
- package/dist/chunk-sg1ppebr.js +4 -0
- package/dist/chunk-sg1ppebr.js.map +10 -0
- package/dist/src/ctrl/index.cjs +2 -2
- package/dist/src/ctrl/index.cjs.map +3 -3
- package/dist/src/ctrl/index.js +2 -2
- package/dist/src/ctrl/index.js.map +3 -3
- package/dist/src/near-wallet-selector/index.cjs +2 -2
- package/dist/src/near-wallet-selector/index.cjs.map +3 -3
- package/dist/src/near-wallet-selector/index.js +2 -2
- package/dist/src/near-wallet-selector/index.js.map +3 -3
- package/dist/src/okx/index.cjs +2 -2
- package/dist/src/okx/index.cjs.map +4 -4
- package/dist/src/okx/index.js +2 -2
- package/dist/src/okx/index.js.map +4 -4
- package/dist/src/walletconnect/index.cjs.map +2 -2
- package/dist/src/walletconnect/index.js.map +2 -2
- package/dist/types/helpers/near.d.ts +2 -2
- package/dist/types/helpers/near.d.ts.map +1 -1
- package/dist/types/near-wallet-selector/index.d.ts +2 -1
- package/dist/types/near-wallet-selector/index.d.ts.map +1 -1
- package/dist/types/okx/helpers.d.ts +1 -4
- package/dist/types/okx/helpers.d.ts.map +1 -1
- package/dist/types/okx/index.d.ts +2 -2
- package/dist/types/okx/index.d.ts.map +1 -1
- package/dist/types/walletconnect/index.d.ts.map +1 -1
- package/package.json +10 -10
- package/dist/chunk-c2smwq87.js +0 -4
- package/dist/chunk-c2smwq87.js.map +0 -10
- package/dist/chunk-eztfj06q.js +0 -4
- package/dist/chunk-eztfj06q.js.map +0 -10
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var I=require("@near-js/transactions"),B=require("@swapkit/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.SwapKitError("wallet_connection_rejected_by_user",{wallet:z})}throw new B.SwapKitError("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.SwapKitError("wallet_ledger_method_not_supported",{method:"getPublicKey",wallet:z})},signDelegateAction(x){return Promise.reject(new B.SwapKitError("wallet_ledger_method_not_supported",{method:"signDelegateAction",wallet:z}))},async signNep413Message(x,D,G,F,H){if(!q.signMessage)throw new B.SwapKitError("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.SwapKitError("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=4250DC607E8C7FB164756E2164756E21
|
|
4
|
+
//# sourceMappingURL=chunk-rx1jg8mz.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/helpers/near.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"//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 { SwapKitError } from \"@swapkit/helpers\";\nimport type { NearSigner } from \"@swapkit/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 SwapKitError(\"wallet_connection_rejected_by_user\", { wallet: walletName });\n }\n\n throw new SwapKitError(\"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 SwapKitError(\"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 SwapKitError(\"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 SwapKitError(\"wallet_ledger_method_not_supported\", {\n method: \"signNep413Message\",\n wallet: walletName,\n });\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 SwapKitError(\"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": "AAGiE,IAAjE,mCACA,8BAgCA,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,EAuF7E,MApFe,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,eAAa,qCAAsC,CAAE,OAAQ,CAAW,CAAC,EAGrF,MAAM,IAAI,eAAa,qCAAsC,CAAE,OAAQ,CAAW,CAAC,QAE/E,aAAY,EAAG,CACnB,IAAQ,aAAc,KAAa,2BAEnC,GAAI,EAAS,aAAc,CACzB,IAAM,EAAS,MAAM,EAAS,aAAa,EAC3C,OAAO,EAAU,KAAK,CAAM,EAG9B,MAAM,IAAI,eAAa,qCAAsC,CAAE,OAAQ,eAAgB,OAAQ,CAAW,CAAC,GAG7G,kBAAkB,CAAC,EAAsB,CAEvC,OAAO,QAAQ,OACb,IAAI,eAAa,qCAAsC,CAAE,OAAQ,qBAAsB,OAAQ,CAAW,CAAC,CAC7G,QAGI,kBAAiB,CACrB,EACA,EACA,EACA,EACA,EACA,CACA,GAAI,CAAC,EAAS,YACZ,MAAM,IAAI,eAAa,qCAAsC,CAC3D,OAAQ,oBACR,OAAQ,CACV,CAAC,EAUH,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,eAAa,mCAAoC,CAAE,OAAQ,UAAW,OAAQ,CAAW,CAAC,EAGtG,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": "4250DC607E8C7FB164756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{F as I,G as L}from"./chunk-jgq4njag.js";import{SignedTransaction as M}from"@near-js/transactions";import{SwapKitError as B}from"@swapkit/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=668E8708DE45763E64756E2164756E21
|
|
4
|
+
//# sourceMappingURL=chunk-sg1ppebr.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/helpers/near.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"//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 { SwapKitError } from \"@swapkit/helpers\";\nimport type { NearSigner } from \"@swapkit/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 SwapKitError(\"wallet_connection_rejected_by_user\", { wallet: walletName });\n }\n\n throw new SwapKitError(\"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 SwapKitError(\"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 SwapKitError(\"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 SwapKitError(\"wallet_ledger_method_not_supported\", {\n method: \"signNep413Message\",\n wallet: walletName,\n });\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 SwapKitError(\"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": "+CAGA,4BAAsB,8BACtB,uBAAS,yBAgCT,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,EAuF7E,MApFe,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,EAAa,qCAAsC,CAAE,OAAQ,CAAW,CAAC,EAGrF,MAAM,IAAI,EAAa,qCAAsC,CAAE,OAAQ,CAAW,CAAC,QAE/E,aAAY,EAAG,CACnB,IAAQ,aAAc,KAAa,2BAEnC,GAAI,EAAS,aAAc,CACzB,IAAM,EAAS,MAAM,EAAS,aAAa,EAC3C,OAAO,EAAU,KAAK,CAAM,EAG9B,MAAM,IAAI,EAAa,qCAAsC,CAAE,OAAQ,eAAgB,OAAQ,CAAW,CAAC,GAG7G,kBAAkB,CAAC,EAAsB,CAEvC,OAAO,QAAQ,OACb,IAAI,EAAa,qCAAsC,CAAE,OAAQ,qBAAsB,OAAQ,CAAW,CAAC,CAC7G,QAGI,kBAAiB,CACrB,EACA,EACA,EACA,EACA,EACA,CACA,GAAI,CAAC,EAAS,YACZ,MAAM,IAAI,EAAa,qCAAsC,CAC3D,OAAQ,oBACR,OAAQ,CACV,CAAC,EAUH,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,EAAa,mCAAoC,CAAE,OAAQ,UAAW,OAAQ,CAAW,CAAC,EAGtG,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": "668E8708DE45763E64756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
package/dist/src/ctrl/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var p={};N(p,{ctrlWallet:()=>b,CTRL_SUPPORTED_CHAINS:()=>S});module.exports=y(p);var o=require("@swapkit/helpers"),x=require("@swapkit/wallet-core");var t=require("@swapkit/helpers");async function m(n){if(!window.xfi)throw new t.SwapKitError("wallet_ctrl_not_found");let{match:e}=await import("ts-pattern");return e(n).with(t.Chain.Arbitrum,t.Chain.Aurora,t.Chain.Avalanche,t.Chain.Base,t.Chain.Berachain,t.Chain.BinanceSmartChain,t.Chain.Ethereum,t.Chain.Gnosis,t.Chain.Optimism,t.Chain.Polygon,()=>window.xfi?.ethereum).with(t.Chain.Cosmos,t.Chain.Kujira,t.Chain.Noble,()=>window.xfi?.keplr).with(t.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(t.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(t.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(t.Chain.Litecoin,()=>window.xfi?.litecoin).with(t.Chain.Solana,()=>window.xfi?.solana).with(t.Chain.THORChain,()=>window.xfi?.thorchain).with(t.Chain.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function u({method:n,params:e,chain:a}){let r=await m(a);return new Promise((s,w)=>{if(r&&"request"in r)r.request({method:n,params:e},(c,f)=>{c?w(c):s(f)})})}async function T(n){try{let e=await m(n);if(!e)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:n,wallet:t.WalletOption.CTRL}});if([t.Chain.Cosmos,t.Chain.Kujira,t.Chain.Noble].includes(n)){let r=await m(t.Chain.Cosmos);if(!r||"request"in r)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:n,wallet:t.WalletOption.CTRL}});let s=t.ChainToChainId[n];await r.enable(s);let w=r.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(t.EVMChains.includes(n)){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 t.providerRequest({method:"eth_requestAccounts",params:[],provider:s});return w}if(n===t.Chain.Solana)return(await(await m(t.Chain.Solana)).connect()).publicKey.toString();if(n===t.Chain.Near){if(!window.xfi?.near)throw new t.SwapKitError("wallet_ctrl_not_found",{chain:t.Chain.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await e.request({method:"request_accounts",params:[]}))[0]}catch{throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:n,wallet:t.WalletOption.CTRL}})}}async function g({assetValue:n,recipient:e,memo:a,gasLimit:r},s="transfer"){if(!n)throw new t.SwapKitError("wallet_ctrl_asset_not_defined");let w=await T(n.chain),c=[{amount:{amount:n.getBaseValue("number"),decimals:n.decimal},asset:{chain:n.chain,symbol:n.symbol.toUpperCase(),ticker:n.symbol.toUpperCase()},from:w,gasLimit:r,memo:a||"",recipient:e}];return u({chain:n.chain,method:s,params:c})}var b=x.createWallet({connect:({addChain:n,walletType:e,supportedChains:a})=>async function(s){let c=o.filterSupportedChains({chains:s,supportedChains:a,walletType:e}).map(async(f)=>{let i=await T(f),_=await B(f);n({..._,address:i,chain:f,walletType:e})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[o.Chain.Arbitrum,o.Chain.Aurora,o.Chain.Avalanche,o.Chain.Base,o.Chain.Berachain,o.Chain.BinanceSmartChain,o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Cosmos,o.Chain.Dogecoin,o.Chain.Ethereum,o.Chain.Gnosis,o.Chain.Kujira,o.Chain.Litecoin,o.Chain.Maya,o.Chain.Near,o.Chain.Noble,o.Chain.Optimism,o.Chain.Polygon,o.Chain.Solana,o.Chain.THORChain],walletType:o.WalletOption.CTRL}),S=x.getWalletSupportedChains(b);async function B(n){switch(n){case o.Chain.Solana:{let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana"),a=window.xfi?.solana;if(!a)throw new o.SwapKitError("wallet_ctrl_not_found");return await e({signer:a})}case o.Chain.Maya:case o.Chain.THORChain:{let{getCosmosToolbox:e,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:r}=await import("@swapkit/toolboxes/cosmos"),s=n===o.Chain.Maya?r:a;return{...await e(n),deposit:(c)=>g({...c,recipient:""},"deposit"),transfer:(c)=>g({...c,gasLimit:s},"transfer")}}case o.Chain.Cosmos:case o.Chain.Kujira:case o.Chain.Noble:{let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos"),a=o.ChainToChainId[n],r=await m(n);await r?.enable(a);let s=r?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new o.SwapKitError("wallet_ctrl_not_found");return await e(n,{signer:s})}case o.Chain.Bitcoin:case o.Chain.BitcoinCash:case o.Chain.Dogecoin:case o.Chain.Litecoin:{let{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo");return{...await e(n),transfer:g}}case o.Chain.Arbitrum:case o.Chain.Aurora:case o.Chain.Avalanche:case o.Chain.Base:case o.Chain.Berachain:case o.Chain.BinanceSmartChain:case o.Chain.Ethereum:case o.Chain.Gnosis:case o.Chain.Optimism:case o.Chain.Polygon:{let{prepareNetworkSwitch:e,switchEVMWalletNetwork:a}=await import("@swapkit/helpers"),{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=await m(n);if(!w)throw new o.SwapKitError("wallet_ctrl_not_found");let c=new s(w,"any"),f=await c.getSigner(),i=await r(n,{provider:c,signer:f});try{if(n!==o.Chain.Ethereum){let _=i.getNetworkParams();await a(c,n,_)}}catch{throw new o.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:n,wallet:o.WalletOption.CTRL}})}return e({chain:n,provider:c,toolbox:i})}case o.Chain.Near:{if(!window.xfi?.near)throw new o.SwapKitError("wallet_ctrl_not_found",{chain:o.Chain.Near});let{createNearSignerFromProvider:e}=await import("../../chunk-
|
|
1
|
+
var p={};N(p,{ctrlWallet:()=>b,CTRL_SUPPORTED_CHAINS:()=>S});module.exports=y(p);var o=require("@swapkit/helpers"),x=require("@swapkit/wallet-core");var t=require("@swapkit/helpers");async function m(n){if(!window.xfi)throw new t.SwapKitError("wallet_ctrl_not_found");let{match:e}=await import("ts-pattern");return e(n).with(t.Chain.Arbitrum,t.Chain.Aurora,t.Chain.Avalanche,t.Chain.Base,t.Chain.Berachain,t.Chain.BinanceSmartChain,t.Chain.Ethereum,t.Chain.Gnosis,t.Chain.Optimism,t.Chain.Polygon,()=>window.xfi?.ethereum).with(t.Chain.Cosmos,t.Chain.Kujira,t.Chain.Noble,()=>window.xfi?.keplr).with(t.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(t.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(t.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(t.Chain.Litecoin,()=>window.xfi?.litecoin).with(t.Chain.Solana,()=>window.xfi?.solana).with(t.Chain.THORChain,()=>window.xfi?.thorchain).with(t.Chain.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function u({method:n,params:e,chain:a}){let r=await m(a);return new Promise((s,w)=>{if(r&&"request"in r)r.request({method:n,params:e},(c,f)=>{c?w(c):s(f)})})}async function T(n){try{let e=await m(n);if(!e)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:n,wallet:t.WalletOption.CTRL}});if([t.Chain.Cosmos,t.Chain.Kujira,t.Chain.Noble].includes(n)){let r=await m(t.Chain.Cosmos);if(!r||"request"in r)throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:n,wallet:t.WalletOption.CTRL}});let s=t.ChainToChainId[n];await r.enable(s);let w=r.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(t.EVMChains.includes(n)){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 t.providerRequest({method:"eth_requestAccounts",params:[],provider:s});return w}if(n===t.Chain.Solana)return(await(await m(t.Chain.Solana)).connect()).publicKey.toString();if(n===t.Chain.Near){if(!window.xfi?.near)throw new t.SwapKitError("wallet_ctrl_not_found",{chain:t.Chain.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await e.request({method:"request_accounts",params:[]}))[0]}catch{throw new t.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:n,wallet:t.WalletOption.CTRL}})}}async function g({assetValue:n,recipient:e,memo:a,gasLimit:r},s="transfer"){if(!n)throw new t.SwapKitError("wallet_ctrl_asset_not_defined");let w=await T(n.chain),c=[{amount:{amount:n.getBaseValue("number"),decimals:n.decimal},asset:{chain:n.chain,symbol:n.symbol.toUpperCase(),ticker:n.symbol.toUpperCase()},from:w,gasLimit:r,memo:a||"",recipient:e}];return u({chain:n.chain,method:s,params:c})}var b=x.createWallet({connect:({addChain:n,walletType:e,supportedChains:a})=>async function(s){let c=o.filterSupportedChains({chains:s,supportedChains:a,walletType:e}).map(async(f)=>{let i=await T(f),_=await B(f);n({..._,address:i,chain:f,walletType:e})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[o.Chain.Arbitrum,o.Chain.Aurora,o.Chain.Avalanche,o.Chain.Base,o.Chain.Berachain,o.Chain.BinanceSmartChain,o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Cosmos,o.Chain.Dogecoin,o.Chain.Ethereum,o.Chain.Gnosis,o.Chain.Kujira,o.Chain.Litecoin,o.Chain.Maya,o.Chain.Near,o.Chain.Noble,o.Chain.Optimism,o.Chain.Polygon,o.Chain.Solana,o.Chain.THORChain],walletType:o.WalletOption.CTRL}),S=x.getWalletSupportedChains(b);async function B(n){switch(n){case o.Chain.Solana:{let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana"),a=window.xfi?.solana;if(!a)throw new o.SwapKitError("wallet_ctrl_not_found");return await e({signer:a})}case o.Chain.Maya:case o.Chain.THORChain:{let{getCosmosToolbox:e,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:r}=await import("@swapkit/toolboxes/cosmos"),s=n===o.Chain.Maya?r:a;return{...await e(n),deposit:(c)=>g({...c,recipient:""},"deposit"),transfer:(c)=>g({...c,gasLimit:s},"transfer")}}case o.Chain.Cosmos:case o.Chain.Kujira:case o.Chain.Noble:{let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos"),a=o.ChainToChainId[n],r=await m(n);await r?.enable(a);let s=r?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new o.SwapKitError("wallet_ctrl_not_found");return await e(n,{signer:s})}case o.Chain.Bitcoin:case o.Chain.BitcoinCash:case o.Chain.Dogecoin:case o.Chain.Litecoin:{let{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo");return{...await e(n),transfer:g}}case o.Chain.Arbitrum:case o.Chain.Aurora:case o.Chain.Avalanche:case o.Chain.Base:case o.Chain.Berachain:case o.Chain.BinanceSmartChain:case o.Chain.Ethereum:case o.Chain.Gnosis:case o.Chain.Optimism:case o.Chain.Polygon:{let{prepareNetworkSwitch:e,switchEVMWalletNetwork:a}=await import("@swapkit/helpers"),{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=await m(n);if(!w)throw new o.SwapKitError("wallet_ctrl_not_found");let c=new s(w,"any"),f=await c.getSigner(),i=await r(n,{provider:c,signer:f});try{if(n!==o.Chain.Ethereum){let _=i.getNetworkParams();await a(c,n,_)}}catch{throw new o.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:n,wallet:o.WalletOption.CTRL}})}return e({chain:n,provider:c,toolbox:i})}case o.Chain.Near:{if(!window.xfi?.near)throw new o.SwapKitError("wallet_ctrl_not_found",{chain:o.Chain.Near});let{createNearSignerFromProvider:e}=await import("../../chunk-rx1jg8mz.js"),{getNearToolbox:a}=await import("@swapkit/toolboxes/near"),r=window.xfi.near,s=await e(r,"CTRL"),w=await s.getAddress();return{...await a({signer:s}),transfer:async(i)=>{let{actionCreators:_}=await import("@near-js/transactions"),A=i.assetValue.getBaseValue("string"),d={actions:[_.transfer(BigInt(A))],receiverId:i.recipient,signerId:w};return await r.request({method:"signAndSendTransaction",params:{transaction:d}})}}}default:return null}}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=06D66E06BE36C54364756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n\n return toolbox;\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const {
|
|
5
|
+
"import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n\n return toolbox;\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const { 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
6
|
"import 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 SwapKitError,\n type TCLikeChain,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends typeof Chain.Solana\n ? SolanaProvider\n : T extends Exclude<CosmosChain, TCLikeChain>\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain as Exclude<CosmosChain, TCLikeChain>)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({ method: \"connect\" });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "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
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "06D66E06BE36C54364756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
package/dist/src/ctrl/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as l,G as f}from"../../chunk-jgq4njag.js";import{Chain as o,ChainToChainId as G,filterSupportedChains as H,SwapKitError as T,WalletOption as u}from"@swapkit/helpers";import{createWallet as L,getWalletSupportedChains as I}from"@swapkit/wallet-core";import{Chain as n,ChainToChainId as S,EVMChains as B,providerRequest as p,SwapKitError as g,WalletOption as A}from"@swapkit/helpers";async function _(t){if(!window.xfi)throw new g("wallet_ctrl_not_found");let{match:e}=await import("ts-pattern");return e(t).with(n.Arbitrum,n.Aurora,n.Avalanche,n.Base,n.Berachain,n.BinanceSmartChain,n.Ethereum,n.Gnosis,n.Optimism,n.Polygon,()=>window.xfi?.ethereum).with(n.Cosmos,n.Kujira,n.Noble,()=>window.xfi?.keplr).with(n.Bitcoin,()=>window.xfi?.bitcoin).with(n.BitcoinCash,()=>window.xfi?.bitcoincash).with(n.Dogecoin,()=>window.xfi?.dogecoin).with(n.Litecoin,()=>window.xfi?.litecoin).with(n.Solana,()=>window.xfi?.solana).with(n.THORChain,()=>window.xfi?.thorchain).with(n.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function R({method:t,params:e,chain:a}){let r=await _(a);return new Promise((s,w)=>{if(r&&"request"in r)r.request({method:t,params:e},(c,i)=>{c?w(c):s(i)})})}async function d(t){try{let e=await _(t);if(!e)throw new g({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}});if([n.Cosmos,n.Kujira,n.Noble].includes(t)){let r=await _(n.Cosmos);if(!r||"request"in r)throw new g({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}});let s=S[t];await r.enable(s);let w=r.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(B.includes(t)){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 p({method:"eth_requestAccounts",params:[],provider:s});return w}if(t===n.Solana)return(await(await _(n.Solana)).connect()).publicKey.toString();if(t===n.Near){if(!window.xfi?.near)throw new g("wallet_ctrl_not_found",{chain:n.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await e.request({method:"request_accounts",params:[]}))[0]}catch{throw new g({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}})}}async function b({assetValue:t,recipient:e,memo:a,gasLimit:r},s="transfer"){if(!t)throw new g("wallet_ctrl_asset_not_defined");let w=await d(t.chain),c=[{amount:{amount:t.getBaseValue("number"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},from:w,gasLimit:r,memo:a||"",recipient:e}];return R({chain:t.chain,method:s,params:c})}var P=L({connect:({addChain:t,walletType:e,supportedChains:a})=>async function(s){let c=H({chains:s,supportedChains:a,walletType:e}).map(async(i)=>{let m=await d(i),x=await O(i);t({...x,address:m,chain:i,walletType:e})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[o.Arbitrum,o.Aurora,o.Avalanche,o.Base,o.Berachain,o.BinanceSmartChain,o.Bitcoin,o.BitcoinCash,o.Cosmos,o.Dogecoin,o.Ethereum,o.Gnosis,o.Kujira,o.Litecoin,o.Maya,o.Near,o.Noble,o.Optimism,o.Polygon,o.Solana,o.THORChain],walletType:u.CTRL}),Y=I(P);async function O(t){switch(t){case o.Solana:{let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana"),a=window.xfi?.solana;if(!a)throw new T("wallet_ctrl_not_found");return await e({signer:a})}case o.Maya:case o.THORChain:{let{getCosmosToolbox:e,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:r}=await import("@swapkit/toolboxes/cosmos"),s=t===o.Maya?r:a;return{...await e(t),deposit:(c)=>b({...c,recipient:""},"deposit"),transfer:(c)=>b({...c,gasLimit:s},"transfer")}}case o.Cosmos:case o.Kujira:case o.Noble:{let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos"),a=G[t],r=await _(t);await r?.enable(a);let s=r?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new T("wallet_ctrl_not_found");return await e(t,{signer:s})}case o.Bitcoin:case o.BitcoinCash:case o.Dogecoin:case o.Litecoin:{let{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo");return{...await e(t),transfer:b}}case o.Arbitrum:case o.Aurora:case o.Avalanche:case o.Base:case o.Berachain:case o.BinanceSmartChain:case o.Ethereum:case o.Gnosis:case o.Optimism:case o.Polygon:{let{prepareNetworkSwitch:e,switchEVMWalletNetwork:a}=await import("@swapkit/helpers"),{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=await _(t);if(!w)throw new T("wallet_ctrl_not_found");let c=new s(w,"any"),i=await c.getSigner(),m=await r(t,{provider:c,signer:i});try{if(t!==o.Ethereum){let x=m.getNetworkParams();await a(c,t,x)}}catch{throw new T({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:t,wallet:u.CTRL}})}return e({chain:t,provider:c,toolbox:m})}case o.Near:{if(!window.xfi?.near)throw new T("wallet_ctrl_not_found",{chain:o.Near});let{createNearSignerFromProvider:e}=await import("../../chunk-
|
|
1
|
+
import{F as l,G as f}from"../../chunk-jgq4njag.js";import{Chain as o,ChainToChainId as G,filterSupportedChains as H,SwapKitError as T,WalletOption as u}from"@swapkit/helpers";import{createWallet as L,getWalletSupportedChains as I}from"@swapkit/wallet-core";import{Chain as n,ChainToChainId as S,EVMChains as B,providerRequest as p,SwapKitError as g,WalletOption as A}from"@swapkit/helpers";async function _(t){if(!window.xfi)throw new g("wallet_ctrl_not_found");let{match:e}=await import("ts-pattern");return e(t).with(n.Arbitrum,n.Aurora,n.Avalanche,n.Base,n.Berachain,n.BinanceSmartChain,n.Ethereum,n.Gnosis,n.Optimism,n.Polygon,()=>window.xfi?.ethereum).with(n.Cosmos,n.Kujira,n.Noble,()=>window.xfi?.keplr).with(n.Bitcoin,()=>window.xfi?.bitcoin).with(n.BitcoinCash,()=>window.xfi?.bitcoincash).with(n.Dogecoin,()=>window.xfi?.dogecoin).with(n.Litecoin,()=>window.xfi?.litecoin).with(n.Solana,()=>window.xfi?.solana).with(n.THORChain,()=>window.xfi?.thorchain).with(n.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function R({method:t,params:e,chain:a}){let r=await _(a);return new Promise((s,w)=>{if(r&&"request"in r)r.request({method:t,params:e},(c,i)=>{c?w(c):s(i)})})}async function d(t){try{let e=await _(t);if(!e)throw new g({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}});if([n.Cosmos,n.Kujira,n.Noble].includes(t)){let r=await _(n.Cosmos);if(!r||"request"in r)throw new g({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}});let s=S[t];await r.enable(s);let w=r.getOfflineSigner(s),[c]=await w.getAccounts();return c?.address}if(B.includes(t)){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 p({method:"eth_requestAccounts",params:[],provider:s});return w}if(t===n.Solana)return(await(await _(n.Solana)).connect()).publicKey.toString();if(t===n.Near){if(!window.xfi?.near)throw new g("wallet_ctrl_not_found",{chain:n.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await e.request({method:"request_accounts",params:[]}))[0]}catch{throw new g({errorKey:"wallet_provider_not_found",info:{chain:t,wallet:A.CTRL}})}}async function b({assetValue:t,recipient:e,memo:a,gasLimit:r},s="transfer"){if(!t)throw new g("wallet_ctrl_asset_not_defined");let w=await d(t.chain),c=[{amount:{amount:t.getBaseValue("number"),decimals:t.decimal},asset:{chain:t.chain,symbol:t.symbol.toUpperCase(),ticker:t.symbol.toUpperCase()},from:w,gasLimit:r,memo:a||"",recipient:e}];return R({chain:t.chain,method:s,params:c})}var P=L({connect:({addChain:t,walletType:e,supportedChains:a})=>async function(s){let c=H({chains:s,supportedChains:a,walletType:e}).map(async(i)=>{let m=await d(i),x=await O(i);t({...x,address:m,chain:i,walletType:e})});return await Promise.all(c),!0},name:"connectCtrl",supportedChains:[o.Arbitrum,o.Aurora,o.Avalanche,o.Base,o.Berachain,o.BinanceSmartChain,o.Bitcoin,o.BitcoinCash,o.Cosmos,o.Dogecoin,o.Ethereum,o.Gnosis,o.Kujira,o.Litecoin,o.Maya,o.Near,o.Noble,o.Optimism,o.Polygon,o.Solana,o.THORChain],walletType:u.CTRL}),Y=I(P);async function O(t){switch(t){case o.Solana:{let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana"),a=window.xfi?.solana;if(!a)throw new T("wallet_ctrl_not_found");return await e({signer:a})}case o.Maya:case o.THORChain:{let{getCosmosToolbox:e,THORCHAIN_GAS_VALUE:a,MAYA_GAS_VALUE:r}=await import("@swapkit/toolboxes/cosmos"),s=t===o.Maya?r:a;return{...await e(t),deposit:(c)=>b({...c,recipient:""},"deposit"),transfer:(c)=>b({...c,gasLimit:s},"transfer")}}case o.Cosmos:case o.Kujira:case o.Noble:{let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos"),a=G[t],r=await _(t);await r?.enable(a);let s=r?.getOfflineSignerOnlyAmino(a,{preferNoSetFee:!0});if(!s)throw new T("wallet_ctrl_not_found");return await e(t,{signer:s})}case o.Bitcoin:case o.BitcoinCash:case o.Dogecoin:case o.Litecoin:{let{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo");return{...await e(t),transfer:b}}case o.Arbitrum:case o.Aurora:case o.Avalanche:case o.Base:case o.Berachain:case o.BinanceSmartChain:case o.Ethereum:case o.Gnosis:case o.Optimism:case o.Polygon:{let{prepareNetworkSwitch:e,switchEVMWalletNetwork:a}=await import("@swapkit/helpers"),{getEvmToolbox:r}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:s}=await import("ethers"),w=await _(t);if(!w)throw new T("wallet_ctrl_not_found");let c=new s(w,"any"),i=await c.getSigner(),m=await r(t,{provider:c,signer:i});try{if(t!==o.Ethereum){let x=m.getNetworkParams();await a(c,t,x)}}catch{throw new T({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:t,wallet:u.CTRL}})}return e({chain:t,provider:c,toolbox:m})}case o.Near:{if(!window.xfi?.near)throw new T("wallet_ctrl_not_found",{chain:o.Near});let{createNearSignerFromProvider:e}=await import("../../chunk-sg1ppebr.js"),{getNearToolbox:a}=await import("@swapkit/toolboxes/near"),r=window.xfi.near,s=await e(r,"CTRL"),w=await s.getAddress();return{...await a({signer:s}),transfer:async(m)=>{let{actionCreators:x}=await import("@near-js/transactions"),y=m.assetValue.getBaseValue("string"),N={actions:[x.transfer(BigInt(y))],receiverId:m.recipient,signerId:w};return await r.request({method:"signAndSendTransaction",params:{transaction:N}})}}}default:return null}}export{P as ctrlWallet,Y as CTRL_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=F8058B5CF0DAEEF564756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n\n return toolbox;\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const {
|
|
5
|
+
"import {\n Chain,\n ChainToChainId,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectCtrl\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n walletType: WalletOption.CTRL,\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n\n return toolbox;\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId, { preferNoSetFee: true });\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.CTRL },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n const transfer = async (params: GenericTransferParams) => {\n const { 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
6
|
"import 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 SwapKitError,\n type TCLikeChain,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends typeof Chain.Solana\n ? SolanaProvider\n : T extends Exclude<CosmosChain, TCLikeChain>\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain as Exclude<CosmosChain, TCLikeChain>)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({ method: \"connect\" });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.CTRL } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n from,\n gasLimit,\n memo: memo || \"\",\n recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "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
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "F8058B5CF0DAEEF564756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var T={};O(T,{walletSelectorWallet:()=>A,WALLET_SELECTOR_SUPPORTED_CHAINS:()=>N});module.exports=x(T);var M=require("@near-wallet-selector/modal-ui-js/styles.css"),k=require("@swapkit/helpers"),j=require("@swapkit/toolboxes/near"),Q=require("@swapkit/wallet-core");function b(z){return{getAddress:async()=>{let D=(await z.getAccounts())[0]?.accountId;if(!D)throw new k.SwapKitError("wallet_connection_rejected_by_user");return D},getPublicKey:()=>{throw new k.SwapKitError("wallet_near_method_not_supported")},signAndSendTransactions:async(q)=>{return(await z.signAndSendTransactions(q))?.[0]?.transaction_outcome.id||""},signDelegateAction:()=>{throw new k.SwapKitError("wallet_near_method_not_supported")},signNep413Message:()=>{throw new k.SwapKitError("wallet_near_method_not_supported")},signTransaction:(q)=>{if(!z.signTransaction)throw new k.SwapKitError("wallet_near_method_not_supported");return z.signTransaction(q)}}}function I(z,q){return new Promise((D)=>{let L=z.store.observable.subscribe((J)=>{if(J.selectedWalletId)L.unsubscribe(),q.hide(),D()});q.show()})}async function F(z){let{setupWalletSelector:q}=await import("@near-wallet-selector/core"),{setupBitgetWallet:D}=await import("@near-wallet-selector/bitget-wallet"),{setupHotWallet:L}=await import("@near-wallet-selector/hot-wallet"),{setupMeteorWallet:J}=await import("@near-wallet-selector/meteor-wallet"),{setupMeteorWalletApp:R}=await import("@near-wallet-selector/meteor-wallet-app"),{setupMyNearWallet:Y}=await import("@near-wallet-selector/my-near-wallet"),{setupNearMobileWallet:U}=await import("@near-wallet-selector/near-mobile-wallet"),{setupNightly:B}=await import("@near-wallet-selector/nightly"),{setupOKXWallet:H}=await import("@near-wallet-selector/okx-wallet"),{setupModal:X}=await import("@near-wallet-selector/modal-ui-js"),Z=k.SKConfig.get("integrations")?.nearWalletSelector?.contractId||"",P=await q({modules:[D(),L(),J(),R({contractId:Z}),Y(),U(),B(),H(),...z||[]],network:"mainnet"});if(!P.isSignedIn()){let V=X(P,{contractId:Z,description:"Connect your NEAR wallet to SwapKit"});await I(P,V)}let _=await P.wallet(),$=b(_),f=await j.getNearToolbox({signer:$}),v=await $.getAddress();return{...f,address:v,disconnect:async()=>{try{await _.signOut()}catch(V){throw new k.SwapKitError("wallet_connection_rejected_by_user",V)}}}}var A=Q.createWallet({connect:({addChain:z,supportedChains:q,walletType:D})=>async function(J,R){if(k.filterSupportedChains({chains:J,supportedChains:q,walletType:D}).length===0)throw new k.SwapKitError("wallet_chain_not_supported",{chain:J[0],wallet:k.WalletOption.WALLET_SELECTOR});let U=await F(R);return z({...U,balance:[],chain:k.Chain.Near,walletType:D}),!0},name:"connectWalletSelector",supportedChains:[k.Chain.Near],walletType:k.WalletOption.WALLET_SELECTOR}),N=Q.getWalletSupportedChains(A);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=7CAA6745BD57E1F164756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/near-wallet-selector/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import
|
|
5
|
+
"import type { Wallet, WalletModuleFactory } from \"@near-wallet-selector/core\";\nimport \"@near-wallet-selector/modal-ui-js/styles.css\";\nimport type { Transaction } from \"@near-js/transactions\";\nimport { Chain, filterSupportedChains, SKConfig, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { getNearToolbox } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nfunction createNearSigner(wallet: Wallet) {\n return {\n getAddress: async () => {\n const accounts = await wallet.getAccounts();\n const accountId = accounts[0]?.accountId;\n\n if (!accountId) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\");\n }\n\n return accountId;\n },\n\n getPublicKey: () => {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n },\n signAndSendTransactions: async (transactions: { transactions: Transaction[] }) => {\n const result = await wallet.signAndSendTransactions(transactions);\n return result?.[0]?.transaction_outcome.id || \"\";\n },\n\n signDelegateAction: () => {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n },\n\n signNep413Message: () => {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n },\n\n signTransaction: (params: Transaction) => {\n if (!wallet.signTransaction) {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n }\n return wallet.signTransaction(params);\n },\n };\n}\n\nfunction waitForWalletSelection(selector: any, modal: any) {\n return new Promise<void>((resolve) => {\n const subscription = selector.store.observable.subscribe((state: any) => {\n if (state.selectedWalletId) {\n subscription.unsubscribe();\n modal.hide();\n resolve();\n }\n });\n\n modal.show();\n });\n}\n\nasync function getWalletMethods(walletFactories?: WalletModuleFactory[]) {\n const { setupWalletSelector } = await import(\"@near-wallet-selector/core\");\n const { setupBitgetWallet } = await import(\"@near-wallet-selector/bitget-wallet\");\n const { setupHotWallet } = await import(\"@near-wallet-selector/hot-wallet\");\n const { setupMeteorWallet } = await import(\"@near-wallet-selector/meteor-wallet\");\n const { setupMeteorWalletApp } = await import(\"@near-wallet-selector/meteor-wallet-app\");\n const { setupMyNearWallet } = await import(\"@near-wallet-selector/my-near-wallet\");\n const { setupNearMobileWallet } = await import(\"@near-wallet-selector/near-mobile-wallet\");\n const { setupNightly } = await import(\"@near-wallet-selector/nightly\");\n const { setupOKXWallet } = await import(\"@near-wallet-selector/okx-wallet\");\n const { setupModal } = await import(\"@near-wallet-selector/modal-ui-js\");\n\n const contractId = SKConfig.get(\"integrations\")?.nearWalletSelector?.contractId || \"\";\n const selector = await setupWalletSelector({\n modules: [\n setupBitgetWallet(),\n setupHotWallet(),\n setupMeteorWallet(),\n setupMeteorWalletApp({ contractId }),\n setupMyNearWallet(),\n setupNearMobileWallet(),\n setupNightly(),\n setupOKXWallet(),\n ...(walletFactories || []),\n ],\n network: \"mainnet\",\n });\n\n const isSignedIn = selector.isSignedIn();\n\n if (!isSignedIn) {\n // Only show modal if not already connected\n const modal = setupModal(selector, { contractId, description: \"Connect your NEAR wallet to SwapKit\" });\n\n await waitForWalletSelection(selector, modal);\n }\n\n const wallet = await selector.wallet();\n const signer = createNearSigner(wallet);\n const toolbox = await getNearToolbox({ signer });\n const address = await signer.getAddress();\n\n const disconnect = async () => {\n try {\n await wallet.signOut();\n } catch (error) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", error);\n }\n };\n\n return { ...toolbox, address, disconnect };\n}\n\nexport const walletSelectorWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectWalletSelector(chains: Chain[], walletFactories?: WalletModuleFactory[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new SwapKitError(\"wallet_chain_not_supported\", {\n chain: chains[0],\n wallet: WalletOption.WALLET_SELECTOR,\n });\n }\n\n const walletMethods = await getWalletMethods(walletFactories);\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Near, walletType });\n\n return true;\n },\n name: \"connectWalletSelector\",\n supportedChains: [Chain.Near],\n walletType: WalletOption.WALLET_SELECTOR,\n});\n\nexport const WALLET_SELECTOR_SUPPORTED_CHAINS = getWalletSupportedChains(walletSelectorWallet);\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "sGACO,IAAP,0DAEA,8BACA,qCACA,kCAEA,SAAS,CAAgB,CAAC,EAAgB,CACxC,MAAO,CACL,WAAY,SAAY,CAEtB,IAAM,GADW,MAAM,EAAO,YAAY,GACf,IAAI,UAE/B,GAAI,CAAC,EACH,MAAM,IAAI,eAAa,oCAAoC,EAG7D,OAAO,GAGT,aAAc,IAAM,CAClB,MAAM,IAAI,eAAa,kCAAkC,GAE3D,wBAAyB,MAAO,IAAkD,CAEhF,OADe,MAAM,EAAO,wBAAwB,CAAY,KAChD,IAAI,oBAAoB,IAAM,IAGhD,mBAAoB,IAAM,CACxB,MAAM,IAAI,eAAa,kCAAkC,GAG3D,kBAAmB,IAAM,CACvB,MAAM,IAAI,eAAa,kCAAkC,GAG3D,gBAAiB,CAAC,IAAwB,CACxC,GAAI,CAAC,EAAO,gBACV,MAAM,IAAI,eAAa,kCAAkC,EAE3D,OAAO,EAAO,gBAAgB,CAAM,EAExC,EAGF,SAAS,CAAsB,CAAC,EAAe,EAAY,CACzD,OAAO,IAAI,QAAc,CAAC,IAAY,CACpC,IAAM,EAAe,EAAS,MAAM,WAAW,UAAU,CAAC,IAAe,CACvE,GAAI,EAAM,iBACR,EAAa,YAAY,EACzB,EAAM,KAAK,EACX,EAAQ,EAEX,EAED,EAAM,KAAK,EACZ,EAGH,eAAe,CAAgB,CAAC,EAAyC,CACvE,IAAQ,uBAAwB,KAAa,uCACrC,qBAAsB,KAAa,gDACnC,kBAAmB,KAAa,6CAChC,qBAAsB,KAAa,gDACnC,wBAAyB,KAAa,oDACtC,qBAAsB,KAAa,iDACnC,yBAA0B,KAAa,qDACvC,gBAAiB,KAAa,0CAC9B,kBAAmB,KAAa,6CAChC,cAAe,KAAa,6CAE9B,EAAa,WAAS,IAAI,cAAc,GAAG,oBAAoB,YAAc,GAC7E,EAAW,MAAM,EAAoB,CACzC,QAAS,CACP,EAAkB,EAClB,EAAe,EACf,EAAkB,EAClB,EAAqB,CAAE,YAAW,CAAC,EACnC,EAAkB,EAClB,EAAsB,EACtB,EAAa,EACb,EAAe,EACf,GAAI,GAAmB,CAAC,CAC1B,EACA,QAAS,SACX,CAAC,EAID,GAAI,CAFe,EAAS,WAAW,EAEtB,CAEf,IAAM,EAAQ,EAAW,EAAU,CAAE,aAAY,YAAa,qCAAsC,CAAC,EAErG,MAAM,EAAuB,EAAU,CAAK,EAG9C,IAAM,EAAS,MAAM,EAAS,OAAO,EAC/B,EAAS,EAAiB,CAAM,EAChC,EAAU,MAAM,iBAAe,CAAE,QAAO,CAAC,EACzC,EAAU,MAAM,EAAO,WAAW,EAUxC,MAAO,IAAK,EAAS,UAAS,WARX,SAAY,CAC7B,GAAI,CACF,MAAM,EAAO,QAAQ,EACrB,MAAO,EAAO,CACd,MAAM,IAAI,eAAa,qCAAsC,CAAK,GAI7B,EAGpC,IAAM,EAAuB,eAAa,CAC/C,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAAoC,CAAC,EAAiB,EAAyC,CAG7F,GAFuB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAEjE,SAAW,EAC5B,MAAM,IAAI,eAAa,6BAA8B,CACnD,MAAO,EAAO,GACd,OAAQ,eAAa,eACvB,CAAC,EAGH,IAAM,EAAgB,MAAM,EAAiB,CAAe,EAI5D,OAFA,EAAS,IAAK,EAAe,QAAS,CAAC,EAAG,MAAO,QAAM,KAAM,YAAW,CAAC,EAElE,IAEX,KAAM,wBACN,gBAAiB,CAAC,QAAM,IAAI,EAC5B,WAAY,eAAa,eAC3B,CAAC,EAEY,EAAmC,2BAAyB,CAAoB",
|
|
8
|
+
"debugId": "7CAA6745BD57E1F164756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import{F as D,G}from"../../chunk-jgq4njag.js";import"@near-wallet-selector/modal-ui-js/styles.css";import{Chain as j,filterSupportedChains as x,SKConfig as O,SwapKitError as J,WalletOption as A}from"@swapkit/helpers";import{getNearToolbox as b}from"@swapkit/toolboxes/near";import{createWallet as I,getWalletSupportedChains as F}from"@swapkit/wallet-core";function N(q){return{getAddress:async()=>{let z=(await q.getAccounts())[0]?.accountId;if(!z)throw new J("wallet_connection_rejected_by_user");return z},getPublicKey:()=>{throw new J("wallet_near_method_not_supported")},signAndSendTransactions:async(k)=>{return(await q.signAndSendTransactions(k))?.[0]?.transaction_outcome.id||""},signDelegateAction:()=>{throw new J("wallet_near_method_not_supported")},signNep413Message:()=>{throw new J("wallet_near_method_not_supported")},signTransaction:(k)=>{if(!q.signTransaction)throw new J("wallet_near_method_not_supported");return q.signTransaction(k)}}}function T(q,k){return new Promise((z)=>{let P=q.store.observable.subscribe((L)=>{if(L.selectedWalletId)P.unsubscribe(),k.hide(),z()});k.show()})}async function y(q){let{setupWalletSelector:k}=await import("@near-wallet-selector/core"),{setupBitgetWallet:z}=await import("@near-wallet-selector/bitget-wallet"),{setupHotWallet:P}=await import("@near-wallet-selector/hot-wallet"),{setupMeteorWallet:L}=await import("@near-wallet-selector/meteor-wallet"),{setupMeteorWalletApp:R}=await import("@near-wallet-selector/meteor-wallet-app"),{setupMyNearWallet:Y}=await import("@near-wallet-selector/my-near-wallet"),{setupNearMobileWallet:U}=await import("@near-wallet-selector/near-mobile-wallet"),{setupNightly:B}=await import("@near-wallet-selector/nightly"),{setupOKXWallet:H}=await import("@near-wallet-selector/okx-wallet"),{setupModal:X}=await import("@near-wallet-selector/modal-ui-js"),Z=O.get("integrations")?.nearWalletSelector?.contractId||"",Q=await k({modules:[z(),P(),L(),R({contractId:Z}),Y(),U(),B(),H(),...q||[]],network:"mainnet"});if(!Q.isSignedIn()){let V=X(Q,{contractId:Z,description:"Connect your NEAR wallet to SwapKit"});await T(Q,V)}let _=await Q.wallet(),$=N(_),f=await b({signer:$}),v=await $.getAddress();return{...f,address:v,disconnect:async()=>{try{await _.signOut()}catch(V){throw new J("wallet_connection_rejected_by_user",V)}}}}var E=I({connect:({addChain:q,supportedChains:k,walletType:z})=>async function(L,R){if(x({chains:L,supportedChains:k,walletType:z}).length===0)throw new J("wallet_chain_not_supported",{chain:L[0],wallet:A.WALLET_SELECTOR});let U=await y(R);return q({...U,balance:[],chain:j.Near,walletType:z}),!0},name:"connectWalletSelector",supportedChains:[j.Near],walletType:A.WALLET_SELECTOR}),h=F(E);export{E as walletSelectorWallet,h as WALLET_SELECTOR_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=0FD34876DD484ADD64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/near-wallet-selector/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import
|
|
5
|
+
"import type { Wallet, WalletModuleFactory } from \"@near-wallet-selector/core\";\nimport \"@near-wallet-selector/modal-ui-js/styles.css\";\nimport type { Transaction } from \"@near-js/transactions\";\nimport { Chain, filterSupportedChains, SKConfig, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { getNearToolbox } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nfunction createNearSigner(wallet: Wallet) {\n return {\n getAddress: async () => {\n const accounts = await wallet.getAccounts();\n const accountId = accounts[0]?.accountId;\n\n if (!accountId) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\");\n }\n\n return accountId;\n },\n\n getPublicKey: () => {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n },\n signAndSendTransactions: async (transactions: { transactions: Transaction[] }) => {\n const result = await wallet.signAndSendTransactions(transactions);\n return result?.[0]?.transaction_outcome.id || \"\";\n },\n\n signDelegateAction: () => {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n },\n\n signNep413Message: () => {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n },\n\n signTransaction: (params: Transaction) => {\n if (!wallet.signTransaction) {\n throw new SwapKitError(\"wallet_near_method_not_supported\");\n }\n return wallet.signTransaction(params);\n },\n };\n}\n\nfunction waitForWalletSelection(selector: any, modal: any) {\n return new Promise<void>((resolve) => {\n const subscription = selector.store.observable.subscribe((state: any) => {\n if (state.selectedWalletId) {\n subscription.unsubscribe();\n modal.hide();\n resolve();\n }\n });\n\n modal.show();\n });\n}\n\nasync function getWalletMethods(walletFactories?: WalletModuleFactory[]) {\n const { setupWalletSelector } = await import(\"@near-wallet-selector/core\");\n const { setupBitgetWallet } = await import(\"@near-wallet-selector/bitget-wallet\");\n const { setupHotWallet } = await import(\"@near-wallet-selector/hot-wallet\");\n const { setupMeteorWallet } = await import(\"@near-wallet-selector/meteor-wallet\");\n const { setupMeteorWalletApp } = await import(\"@near-wallet-selector/meteor-wallet-app\");\n const { setupMyNearWallet } = await import(\"@near-wallet-selector/my-near-wallet\");\n const { setupNearMobileWallet } = await import(\"@near-wallet-selector/near-mobile-wallet\");\n const { setupNightly } = await import(\"@near-wallet-selector/nightly\");\n const { setupOKXWallet } = await import(\"@near-wallet-selector/okx-wallet\");\n const { setupModal } = await import(\"@near-wallet-selector/modal-ui-js\");\n\n const contractId = SKConfig.get(\"integrations\")?.nearWalletSelector?.contractId || \"\";\n const selector = await setupWalletSelector({\n modules: [\n setupBitgetWallet(),\n setupHotWallet(),\n setupMeteorWallet(),\n setupMeteorWalletApp({ contractId }),\n setupMyNearWallet(),\n setupNearMobileWallet(),\n setupNightly(),\n setupOKXWallet(),\n ...(walletFactories || []),\n ],\n network: \"mainnet\",\n });\n\n const isSignedIn = selector.isSignedIn();\n\n if (!isSignedIn) {\n // Only show modal if not already connected\n const modal = setupModal(selector, { contractId, description: \"Connect your NEAR wallet to SwapKit\" });\n\n await waitForWalletSelection(selector, modal);\n }\n\n const wallet = await selector.wallet();\n const signer = createNearSigner(wallet);\n const toolbox = await getNearToolbox({ signer });\n const address = await signer.getAddress();\n\n const disconnect = async () => {\n try {\n await wallet.signOut();\n } catch (error) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", error);\n }\n };\n\n return { ...toolbox, address, disconnect };\n}\n\nexport const walletSelectorWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectWalletSelector(chains: Chain[], walletFactories?: WalletModuleFactory[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new SwapKitError(\"wallet_chain_not_supported\", {\n chain: chains[0],\n wallet: WalletOption.WALLET_SELECTOR,\n });\n }\n\n const walletMethods = await getWalletMethods(walletFactories);\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Near, walletType });\n\n return true;\n },\n name: \"connectWalletSelector\",\n supportedChains: [Chain.Near],\n walletType: WalletOption.WALLET_SELECTOR,\n});\n\nexport const WALLET_SELECTOR_SUPPORTED_CHAINS = getWalletSupportedChains(walletSelectorWallet);\n"
|
|
6
6
|
],
|
|
7
|
-
"mappings": "
|
|
8
|
-
"debugId": "
|
|
7
|
+
"mappings": "8CACA,qDAEA,gBAAS,2BAAO,cAAuB,kBAAU,kBAAc,yBAC/D,yBAAS,gCACT,uBAAS,8BAAc,6BAEvB,SAAS,CAAgB,CAAC,EAAgB,CACxC,MAAO,CACL,WAAY,SAAY,CAEtB,IAAM,GADW,MAAM,EAAO,YAAY,GACf,IAAI,UAE/B,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,oCAAoC,EAG7D,OAAO,GAGT,aAAc,IAAM,CAClB,MAAM,IAAI,EAAa,kCAAkC,GAE3D,wBAAyB,MAAO,IAAkD,CAEhF,OADe,MAAM,EAAO,wBAAwB,CAAY,KAChD,IAAI,oBAAoB,IAAM,IAGhD,mBAAoB,IAAM,CACxB,MAAM,IAAI,EAAa,kCAAkC,GAG3D,kBAAmB,IAAM,CACvB,MAAM,IAAI,EAAa,kCAAkC,GAG3D,gBAAiB,CAAC,IAAwB,CACxC,GAAI,CAAC,EAAO,gBACV,MAAM,IAAI,EAAa,kCAAkC,EAE3D,OAAO,EAAO,gBAAgB,CAAM,EAExC,EAGF,SAAS,CAAsB,CAAC,EAAe,EAAY,CACzD,OAAO,IAAI,QAAc,CAAC,IAAY,CACpC,IAAM,EAAe,EAAS,MAAM,WAAW,UAAU,CAAC,IAAe,CACvE,GAAI,EAAM,iBACR,EAAa,YAAY,EACzB,EAAM,KAAK,EACX,EAAQ,EAEX,EAED,EAAM,KAAK,EACZ,EAGH,eAAe,CAAgB,CAAC,EAAyC,CACvE,IAAQ,uBAAwB,KAAa,uCACrC,qBAAsB,KAAa,gDACnC,kBAAmB,KAAa,6CAChC,qBAAsB,KAAa,gDACnC,wBAAyB,KAAa,oDACtC,qBAAsB,KAAa,iDACnC,yBAA0B,KAAa,qDACvC,gBAAiB,KAAa,0CAC9B,kBAAmB,KAAa,6CAChC,cAAe,KAAa,6CAE9B,EAAa,EAAS,IAAI,cAAc,GAAG,oBAAoB,YAAc,GAC7E,EAAW,MAAM,EAAoB,CACzC,QAAS,CACP,EAAkB,EAClB,EAAe,EACf,EAAkB,EAClB,EAAqB,CAAE,YAAW,CAAC,EACnC,EAAkB,EAClB,EAAsB,EACtB,EAAa,EACb,EAAe,EACf,GAAI,GAAmB,CAAC,CAC1B,EACA,QAAS,SACX,CAAC,EAID,GAAI,CAFe,EAAS,WAAW,EAEtB,CAEf,IAAM,EAAQ,EAAW,EAAU,CAAE,aAAY,YAAa,qCAAsC,CAAC,EAErG,MAAM,EAAuB,EAAU,CAAK,EAG9C,IAAM,EAAS,MAAM,EAAS,OAAO,EAC/B,EAAS,EAAiB,CAAM,EAChC,EAAU,MAAM,EAAe,CAAE,QAAO,CAAC,EACzC,EAAU,MAAM,EAAO,WAAW,EAUxC,MAAO,IAAK,EAAS,UAAS,WARX,SAAY,CAC7B,GAAI,CACF,MAAM,EAAO,QAAQ,EACrB,MAAO,EAAO,CACd,MAAM,IAAI,EAAa,qCAAsC,CAAK,GAI7B,EAGpC,IAAM,EAAuB,EAAa,CAC/C,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAAoC,CAAC,EAAiB,EAAyC,CAG7F,GAFuB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAEjE,SAAW,EAC5B,MAAM,IAAI,EAAa,6BAA8B,CACnD,MAAO,EAAO,GACd,OAAQ,EAAa,eACvB,CAAC,EAGH,IAAM,EAAgB,MAAM,EAAiB,CAAe,EAI5D,OAFA,EAAS,IAAK,EAAe,QAAS,CAAC,EAAG,MAAO,EAAM,KAAM,YAAW,CAAC,EAElE,IAEX,KAAM,wBACN,gBAAiB,CAAC,EAAM,IAAI,EAC5B,WAAY,EAAa,eAC3B,CAAC,EAEY,EAAmC,EAAyB,CAAoB",
|
|
8
|
+
"debugId": "0FD34876DD484ADD64756E2164756E21",
|
|
9
9
|
"names": []
|
|
10
10
|
}
|
package/dist/src/okx/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var N={};M(N,{okxWallet:()=>X,OKX_SUPPORTED_CHAINS:()=>y});module.exports=U(N);var F=require("@swapkit/helpers"),H=require("@swapkit/wallet-core");var z=require("@swapkit/helpers"),I=require("bitcoinjs-lib"),L=(Y)=>async({recipient:_,assetValue:$,memo:Z})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Cosmos});let{createSigningStargateClient:D}=await import("@swapkit/toolboxes/cosmos"),{keplr:G}=window.okxwallet,Q=G?.getOfflineSignerOnlyAmino(z.getChainConfig(z.Chain.Cosmos).chainId),j=await z.getRPCUrl(z.Chain.Cosmos),A=await D(j,Q),B=[{amount:$.getBaseValue("string"),denom:$?.symbol==="MUON"?"umuon":"uatom"}],{transactionHash:O}=await A.sendTokens(Y,_,B,1.6,Z);return O};async function R({walletProvider:Y,chain:_}){let{getEvmToolbox:$}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:Z}=await import("ethers");if(!Y)throw new z.SwapKitError("wallet_okx_not_found");let D=new Z(Y,"any"),G=await D.getSigner(),Q=await $(_,{provider:D,signer:G});try{if(_!==z.Chain.Ethereum&&"getNetworkParams"in Q)await z.switchEVMWalletNetwork(D,_,Q.getNetworkParams())}catch{throw new z.SwapKitError("wallet_okx_failed_to_switch_network",{chain:_})}return z.prepareNetworkSwitch({chain:_,provider:D,toolbox:Q})}async function J(Y){let{match:_,P:$}=await import("ts-pattern");return _(Y).with($.union(z.Chain.Arbitrum,z.Chain.Aurora,z.Chain.Avalanche,z.Chain.Base,z.Chain.Berachain,z.Chain.BinanceSmartChain,z.Chain.Ethereum,z.Chain.Gnosis,z.Chain.Optimism,z.Chain.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:Y});let Z=await R({chain:Y,walletProvider:window.okxwallet}),D=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...Z,address:D}}).with(z.Chain.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Bitcoin});let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo"),{bitcoin:D}=window.okxwallet,G=(await D.connect()).address,Q={getAddress:async()=>Promise.resolve(G),signTransaction:async(A)=>{let B=await D.signPsbt(A.toHex(),{from:G,type:"list"});return I.Psbt.fromHex(B)}};return{...await Z(z.Chain.Bitcoin,{signer:Q}),address:G}}).with(z.Chain.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Cosmos});let{keplr:Z}=window.okxwallet;await Z.enable(z.getChainConfig(Y).chainId);let G=await Z.getOfflineSignerOnlyAmino(z.getChainConfig(Y).chainId).getAccounts();if(!(G&&Array.isArray(G))||G.length===0)throw new z.SwapKitError("wallet_okx_no_accounts",{chain:z.Chain.Cosmos,message:"No Cosmos accounts returned from OKX Wallet"});let{getCosmosToolbox:Q}=await import("@swapkit/toolboxes/cosmos"),[{address:j}]=G;return{...await Q(z.Chain.Cosmos),address:j,transfer:L(j)}}).with(z.Chain.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new z.SwapKitError("wallet_okx_not_found",{chain:z.Chain.Tron});let{createTronToolbox:Z}=await import("@swapkit/toolboxes/tron"),D=window.okxwallet.tronLink,G=await D.request({method:"tron_requestAccounts"});if(!G||G.length===0)throw new z.SwapKitError("wallet_okx_no_accounts",{chain:z.Chain.Tron});let Q=D.tronWeb.defaultAddress.base58;return{...await Z({signer:{getAddress:async()=>Q,signTransaction:async(B)=>{return await D.tronWeb.trx.sign(B)}}}),address:Q}}).otherwise(()=>{throw new z.SwapKitError("wallet_okx_chain_not_supported",{chain:Y})})}var X=H.createWallet({connect:({addChain:Y,supportedChains:_,walletType:$})=>async function(D){let G=F.filterSupportedChains({chains:D,supportedChains:_,walletType:$});return await Promise.all(G.map(async(Q)=>{let j=await J(Q);Y({...j,chain:Q,walletType:$})})),!0},name:"connectOkx",supportedChains:[F.Chain.Arbitrum,F.Chain.Aurora,F.Chain.Avalanche,F.Chain.Base,F.Chain.Berachain,F.Chain.BinanceSmartChain,F.Chain.Bitcoin,F.Chain.Cosmos,F.Chain.Ethereum,F.Chain.Gnosis,F.Chain.Optimism,F.Chain.Polygon,F.Chain.Tron],walletType:F.WalletOption.OKX}),y=H.getWalletSupportedChains(X);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=86C9733D7D5C4E4264756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/okx/index.ts", "../src/okx/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(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 addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectOkx\",\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.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Tron,\n ],\n walletType: WalletOption.OKX,\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
|
|
6
|
-
"import {\n Chain,\n type EVMChain,\n type GenericTransferParams,\n getChainConfig,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type {
|
|
5
|
+
"import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(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 addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectOkx\",\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.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n // NEAR transfer is not yet supported in OKX Wallet\n // Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Tron,\n ],\n walletType: WalletOption.OKX,\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
|
|
6
|
+
"import {\n Chain,\n type EVMChain,\n type GenericTransferParams,\n getChainConfig,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nconst cosmosTransfer =\n (sender: string) =>\n async ({ recipient, assetValue, memo }: GenericTransferParams) => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { createSigningStargateClient } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const { keplr: wallet } = window.okxwallet;\n const offlineSigner = wallet?.getOfflineSignerOnlyAmino(getChainConfig(Chain.Cosmos).chainId);\n\n const rpcUrl = await getRPCUrl(Chain.Cosmos);\n const cosmJS = await createSigningStargateClient(rpcUrl, offlineSigner);\n\n const coins = [\n { amount: assetValue.getBaseValue(\"string\"), denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\" },\n ];\n\n const { transactionHash } = await cosmJS.sendTokens(sender, recipient, coins, 1.6, memo);\n return transactionHash;\n };\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_okx_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 SwapKitError(\"wallet_okx_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n\n return (\n 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.Optimism,\n Chain.Polygon,\n ),\n async () => {\n if (!(window.okxwallet && \"send\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain });\n }\n\n const evmWallet = await getWeb3WalletMethods({ chain: chain as EVMChain, walletProvider: window.okxwallet });\n const address: string = (await window.okxwallet.send(\"eth_requestAccounts\", [])).result[0];\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(window.okxwallet && \"bitcoin\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Bitcoin });\n }\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const { bitcoin: wallet } = window.okxwallet;\n const address = (await wallet.connect()).address;\n\n const signer = {\n getAddress: async () => Promise.resolve(address),\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { from: address, type: \"list\" });\n\n return Psbt.fromHex(signedPsbt);\n },\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { keplr: wallet } = window.okxwallet;\n\n await wallet.enable(getChainConfig(chain).chainId);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(getChainConfig(chain).chainId);\n const accounts = await offlineSigner.getAccounts();\n\n // Add defensive check for accounts array\n if (!(accounts && Array.isArray(accounts)) || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", {\n chain: Chain.Cosmos,\n message: \"No Cosmos accounts returned from OKX Wallet\",\n });\n }\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(Chain.Cosmos);\n\n return { ...toolbox, address, transfer: cosmosTransfer(address) };\n })\n // INFO: OK wallet near is broken\n // .with(Chain.Near, async () => {\n // if (!(window.okxwallet && \"near\" in window.okxwallet)) {\n // throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Near });\n // }\n\n // const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n // const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n // const provider = window.okxwallet.near;\n // const signer = await createNearSignerFromProvider(provider, \"OKX\");\n // const accountId = await signer.getAddress();\n // const toolbox = await getNearToolbox({ signer });\n\n // return { ...toolbox, address: accountId } as NearToolbox & { address: string };\n // })\n .with(Chain.Tron, async () => {\n if (!(window.okxwallet && \"tronLink\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Tron });\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n\n const tronLink = window.okxwallet.tronLink;\n\n // Request account access\n const accounts = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = tronLink.tronWeb.defaultAddress.base58;\n\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_okx_chain_not_supported\", { chain });\n })\n );\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "+EAA2D,IAA3D,8BAEA,kCCOO,IATP,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "86C9733D7D5C4E4264756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|