@tuwaio/nova-connect 1.0.0-fix-indep-alpha.6.bc09cf6 → 1.0.0-fix-indep-alpha.8.549f0ed
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-F4INBENJ.cjs → chunk-4GK7WPFO.cjs} +3 -3
- package/dist/{chunk-F4INBENJ.cjs.map → chunk-4GK7WPFO.cjs.map} +1 -1
- package/dist/{chunk-4GXQK7LW.js → chunk-4WDAZUTQ.js} +2 -2
- package/dist/{chunk-4GXQK7LW.js.map → chunk-4WDAZUTQ.js.map} +1 -1
- package/dist/chunk-5IDUDP5Y.js +3 -0
- package/dist/{chunk-7EUQO34W.js.map → chunk-5IDUDP5Y.js.map} +1 -1
- package/dist/chunk-JFUJC4EJ.cjs +2 -0
- package/dist/chunk-JFUJC4EJ.cjs.map +1 -0
- package/dist/{chunk-EWPT6HNX.cjs → chunk-L7YY2MZS.cjs} +2 -2
- package/dist/{chunk-EWPT6HNX.cjs.map → chunk-L7YY2MZS.cjs.map} +1 -1
- package/dist/{chunk-CKCFLRRG.js → chunk-QSUO4QWD.js} +4 -4
- package/dist/{chunk-CKCFLRRG.js.map → chunk-QSUO4QWD.js.map} +1 -1
- package/dist/{chunk-4WY4LVQ2.cjs → chunk-RZ4TMXW5.cjs} +4 -4
- package/dist/{chunk-4WY4LVQ2.cjs.map → chunk-RZ4TMXW5.cjs.map} +1 -1
- package/dist/chunk-WVALNTUP.js +2 -0
- package/dist/chunk-WVALNTUP.js.map +1 -0
- package/dist/components/index.cjs +1 -1
- package/dist/components/index.js +1 -1
- package/dist/evm/index.cjs +1 -1
- package/dist/evm/index.cjs.map +1 -1
- package/dist/evm/index.d.cts +11 -0
- package/dist/evm/index.d.ts +11 -0
- package/dist/evm/index.js +1 -1
- package/dist/evm/index.js.map +1 -1
- package/dist/{evm-Y352LZL3.cjs → evm-3XUGTMPL.cjs} +2 -2
- package/dist/{evm-Y352LZL3.cjs.map → evm-3XUGTMPL.cjs.map} +1 -1
- package/dist/{evm-KPV5OJOP.js → evm-5RQC7QOS.js} +2 -2
- package/dist/{evm-KPV5OJOP.js.map → evm-5RQC7QOS.js.map} +1 -1
- package/dist/getChainsListByConnectorType-LXHMQP2F.cjs +2 -0
- package/dist/{getChainsListByConnectorType-RKKDUHIO.cjs.map → getChainsListByConnectorType-LXHMQP2F.cjs.map} +1 -1
- package/dist/{getChainsListByConnectorType-6UA3PPII.js → getChainsListByConnectorType-TP2GS4LA.js} +2 -2
- package/dist/{getChainsListByConnectorType-6UA3PPII.js.map → getChainsListByConnectorType-TP2GS4LA.js.map} +1 -1
- package/dist/hooks/index.cjs +1 -1
- package/dist/hooks/index.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +0 -2
- package/dist/index.d.ts +0 -2
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/satellite/index.cjs +1 -1
- package/dist/satellite/index.d.cts +0 -4
- package/dist/satellite/index.d.ts +0 -4
- package/dist/satellite/index.js +1 -1
- package/dist/solana/index.cjs +1 -1
- package/dist/solana/index.cjs.map +1 -1
- package/dist/solana/index.d.cts +12 -3
- package/dist/solana/index.d.ts +12 -3
- package/dist/solana/index.js +1 -1
- package/dist/solana/index.js.map +1 -1
- package/dist/{solana-KISWBTPH.cjs → solana-H5F4APJH.cjs} +2 -2
- package/dist/{solana-KISWBTPH.cjs.map → solana-H5F4APJH.cjs.map} +1 -1
- package/dist/{solana-2KX5XQPR.js → solana-TKICEEDG.js} +2 -2
- package/dist/{solana-2KX5XQPR.js.map → solana-TKICEEDG.js.map} +1 -1
- package/package.json +4 -4
- package/dist/chunk-6ZNK56AI.js +0 -2
- package/dist/chunk-6ZNK56AI.js.map +0 -1
- package/dist/chunk-7EUQO34W.js +0 -3
- package/dist/chunk-PUEGOPQT.cjs +0 -2
- package/dist/chunk-PUEGOPQT.cjs.map +0 -1
- package/dist/getChainsListByConnectorType-RKKDUHIO.cjs +0 -2
package/dist/satellite/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkJFUJC4EJ_cjs=require('../chunk-JFUJC4EJ.cjs');Object.defineProperty(exports,"AllConnectors",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.a}});Object.defineProperty(exports,"Connection",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.b}});Object.defineProperty(exports,"Connector",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.c}});Object.defineProperty(exports,"SatelliteConnectProvider",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.d}});Object.defineProperty(exports,"SatelliteConnectProviderProps",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.e}});Object.defineProperty(exports,"SatelliteStoreContext",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.f}});Object.defineProperty(exports,"useInitializeAutoConnect",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.g}});Object.defineProperty(exports,"useSatelliteConnectStore",{enumerable:true,get:function(){return chunkJFUJC4EJ_cjs.h}});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,5 +1 @@
|
|
|
1
1
|
export { AllConnectors, Connection, Connector, SatelliteConnectProvider, SatelliteConnectProviderProps, SatelliteStoreContext, useInitializeAutoConnect, useSatelliteConnectStore } from '@tuwaio/satellite-react';
|
|
2
|
-
|
|
3
|
-
declare function getSatelliteExports(): Promise<any>;
|
|
4
|
-
|
|
5
|
-
export { getSatelliteExports };
|
|
@@ -1,5 +1 @@
|
|
|
1
1
|
export { AllConnectors, Connection, Connector, SatelliteConnectProvider, SatelliteConnectProviderProps, SatelliteStoreContext, useInitializeAutoConnect, useSatelliteConnectStore } from '@tuwaio/satellite-react';
|
|
2
|
-
|
|
3
|
-
declare function getSatelliteExports(): Promise<any>;
|
|
4
|
-
|
|
5
|
-
export { getSatelliteExports };
|
package/dist/satellite/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{
|
|
1
|
+
export{a as AllConnectors,b as Connection,c as Connector,d as SatelliteConnectProvider,e as SatelliteConnectProviderProps,f as SatelliteStoreContext,g as useInitializeAutoConnect,h as useSatelliteConnectStore}from'../chunk-WVALNTUP.js';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/solana/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var solana=require('@tuwaio/satellite-react/solana');var t={};async function l(){try{if(Object.keys(t).length===0){let
|
|
1
|
+
'use strict';var solana=require('@tuwaio/satellite-react/solana');var t={};async function l(){try{if(Object.keys(t).length===0){let n=await new Function('return import("@tuwaio/orbit-solana").catch(error => { console.warn("Failed to load Solana dependencies:", error); return null; })')();if(!n)return !1;t=n.defaultRpcUrlsByMoniker;}return !0}catch(r){return console.warn("Failed to initialize Solana utilities:",r),false}}function c(r){let n=r.split(":");if(n.length<2)return null;let e=n[1];e==="mainnet-beta"&&(e="mainnet");let a=e;return a in t?a:null}function u(r,n){let e={},a=Object.keys(n||t);for(let i of r){if(typeof i!="string")continue;let o=c(i);if(!o||!a.includes(o))continue;let s=n?.[o]??t[o];s&&(e[o]=s);}return e}async function p(r,n){if(await l(),n&&n.length>0){let e=u(n,r);return Object.keys(e)}return Object.keys(r||t)}function S(r){return r.length>0&&r.every(n=>typeof n=="string")}async function f(){return await l(),Object.keys(t)}async function d(r){return await l(),r in t}async function g(){try{let n=await new Function('return import("@tuwaio/satellite-react/solana").catch(error => { console.warn("Failed to load Solana exports:", error); return null; })')();if(!n)return {available:!1,error:"Failed to load Solana exports"};let e=n.SolanaConnectorsWatcher;return {...n,available:!0,SolanaConnectorsWatcher:e}}catch(r){return console.warn("Failed to load Solana exports:",r),{available:false,error:r instanceof Error?r.message:"Unknown error loading Solana exports"}}}Object.defineProperty(exports,"SolanaConnectorsWatcher",{enumerable:true,get:function(){return solana.SolanaConnectorsWatcher}});exports.getAvailableSolanaClusters=f;exports.getSolanaClusters=p;exports.getSolanaExports=g;exports.initializeSolanaUtils=l;exports.isSolanaChainList=S;exports.isValidSolanaCluster=d;//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/solana/utils.ts","../../src/solana/index.ts"],"names":["defaultRpcUrlsByMoniker","initializeSolanaUtils","orbitSolana","error","extractSolanaCluster","chainId","parts","cluster","moniker","buildSolanaRpcUrls","chains","solanaRPCUrls","availableRpcUrls","allowedClusters","rpcUrl","getSolanaClusters","isSolanaChainList","chain","getAvailableSolanaClusters","isValidSolanaCluster","getSolanaExports","satelliteReactSolana"],"mappings":"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","file":"index.cjs","sourcesContent":["import type { SolanaClusterMoniker } from 'gill';\nimport { ChainIdentifierArray } from '../index';\n\n// Use a local type definition to avoid direct imports\ntype SolanaRPCUrlsType = {\n rpcUrls: Partial<Record<string, string>>;\n};\n\n// Default values that will be populated at runtime if the package is available\nlet defaultRpcUrlsByMoniker: Record<string, string> = {};\n\n/**\n * Initializes Solana utilities by dynamically loading dependencies.\n * This function should be called before using any Solana-specific functionality.\n * \n * @returns Promise resolving to true if initialization was successful\n */\nexport async function initializeSolanaUtils(): Promise<boolean> {\n try {\n // Only try to load if not already initialized\n if (Object.keys(defaultRpcUrlsByMoniker).length === 0) {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/orbit-solana\").catch(error => { console.warn(\"Failed to load Solana dependencies:\", error); return null; })'\n );\n\n const orbitSolana = await importSolanaModule();\n\n if (!orbitSolana) {\n return false;\n }\n\n // Populate default values\n defaultRpcUrlsByMoniker = orbitSolana.defaultRpcUrlsByMoniker;\n }\n return true;\n } catch (error) {\n console.warn('Failed to initialize Solana utilities:', error);\n return false;\n }\n}\n\n/**\n * Extracts Solana cluster from chain identifier\n */\nfunction extractSolanaCluster(chainId: string): SolanaClusterMoniker | null {\n const parts = chainId.split(':');\n if (parts.length < 2) return null;\n\n let cluster = parts[1];\n // Map mainnet-beta to mainnet to match orbit-solana keys\n if (cluster === 'mainnet-beta') {\n cluster = 'mainnet';\n }\n\n const moniker = cluster as SolanaClusterMoniker;\n // Validate that it's a known cluster\n return moniker in defaultRpcUrlsByMoniker ? moniker : null;\n}\n\n/**\n * Builds available Solana RPC URLs from chain identifiers\n */\nfunction buildSolanaRpcUrls(\n chains: ChainIdentifierArray,\n solanaRPCUrls?: SolanaRPCUrlsType['rpcUrls'],\n): SolanaRPCUrlsType['rpcUrls'] {\n const availableRpcUrls: SolanaRPCUrlsType['rpcUrls'] = {};\n\n // If config is provided, we only consider clusters defined in it.\n // If not provided, we consider all default clusters.\n const allowedClusters = solanaRPCUrls ? Object.keys(solanaRPCUrls) : Object.keys(defaultRpcUrlsByMoniker);\n\n for (const chainId of chains) {\n if (typeof chainId !== 'string') continue;\n\n const cluster = extractSolanaCluster(chainId);\n if (!cluster) continue;\n\n // Check if this cluster is allowed by app config\n if (!allowedClusters.includes(cluster)) continue;\n\n // Get RPC URL with fallback to default\n const rpcUrl = solanaRPCUrls?.[cluster] ?? defaultRpcUrlsByMoniker[cluster];\n\n if (rpcUrl) {\n availableRpcUrls[cluster] = rpcUrl;\n }\n }\n\n return availableRpcUrls;\n}\n\n/**\n * Get Solana clusters from configuration\n */\nexport async function getSolanaClusters(\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>,\n chains?: ChainIdentifierArray,\n): Promise<string[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n\n if (chains && chains.length > 0) {\n // For Solana, build RPC URLs and return cluster names\n const availableRpcUrls = buildSolanaRpcUrls(chains, solanaRPCUrls);\n return Object.keys(availableRpcUrls);\n }\n\n // Return configured clusters or defaults\n return Object.keys(solanaRPCUrls || defaultRpcUrlsByMoniker);\n}\n\n/**\n * Type guard to check if a chain list contains Solana cluster names\n */\nexport function isSolanaChainList(chains: (string | number)[]): chains is string[] {\n return chains.length > 0 && chains.every((chain) => typeof chain === 'string');\n}\n\n/**\n * Gets available Solana clusters from the default configuration\n */\nexport async function getAvailableSolanaClusters(): Promise<SolanaClusterMoniker[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return Object.keys(defaultRpcUrlsByMoniker) as SolanaClusterMoniker[];\n}\n\n/**\n * Validates if a string is a valid Solana cluster moniker\n */\nexport async function isValidSolanaCluster(cluster: string): Promise<boolean> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return cluster in defaultRpcUrlsByMoniker;\n}\n","// Export utils with dynamic initialization\nexport * from './utils';\n\n// Export types only, not implementations\nexport type { SolanaClusterMoniker } from 'gill';\n\n// Export components directly to satisfy static imports\nexport { SolanaConnectorsWatcher } from '@tuwaio/satellite-react/solana';\n\n// Re-export the Connection type from satellite-react and create a type alias for Solana\nimport { Connection } from '@tuwaio/satellite-react';\nexport type SolanaConnection = Connection;\n\n// Dynamic exports that will be loaded at runtime\nexport async function getSolanaExports() {\n try {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/satellite-react/solana\").catch(error => { console.warn(\"Failed to load Solana exports:\", error); return null; })'\n );\n\n const satelliteReactSolana = await importSolanaModule();\n\n if (!satelliteReactSolana) {\n return {\n available: false,\n error: 'Failed to load Solana exports',\n };\n }\n\n return {\n ...satelliteReactSolana,\n available: true,\n };\n } catch (error) {\n console.warn('Failed to load Solana exports:', error);\n return {\n available: false,\n error: error instanceof Error ? error.message : 'Unknown error loading Solana exports',\n };\n }\n}\n\n// Extend the main interface with Solana-specific config\n// This will override the default `any` type with specific SolanaClusterMoniker typing\n// eslint-disable-next-line\n// @ts-ignore - Need for declaration merging\ndeclare module '@tuwaio/nova-connect' {\n interface AllChainConfigs {\n /**\n * Solana RPC URLs configuration - enhanced from default any type\n * @override Replaces default `any` with specific SolanaClusterMoniker typing when gill is available\n */\n // eslint-disable-next-line\n // @ts-ignore - Need for declaration merging\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/solana/utils.ts","../../src/solana/index.ts"],"names":["defaultRpcUrlsByMoniker","initializeSolanaUtils","orbitSolana","error","extractSolanaCluster","chainId","parts","cluster","moniker","buildSolanaRpcUrls","chains","solanaRPCUrls","availableRpcUrls","allowedClusters","rpcUrl","getSolanaClusters","isSolanaChainList","chain","getAvailableSolanaClusters","isValidSolanaCluster","getSolanaExports","satelliteReactSolana","actualSolanaConnectorsWatcher"],"mappings":"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","file":"index.cjs","sourcesContent":["import type { SolanaClusterMoniker } from 'gill';\n\nimport { ChainIdentifierArray } from '../index';\n\n// Use a local type definition to avoid direct imports\ntype SolanaRPCUrlsType = {\n rpcUrls: Partial<Record<string, string>>;\n};\n\n// Default values that will be populated at runtime if the package is available\nlet defaultRpcUrlsByMoniker: Record<string, string> = {};\n\n/**\n * Initializes Solana utilities by dynamically loading dependencies.\n * This function should be called before using any Solana-specific functionality.\n *\n * @returns Promise resolving to true if initialization was successful\n */\nexport async function initializeSolanaUtils(): Promise<boolean> {\n try {\n // Only try to load if not already initialized\n if (Object.keys(defaultRpcUrlsByMoniker).length === 0) {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/orbit-solana\").catch(error => { console.warn(\"Failed to load Solana dependencies:\", error); return null; })',\n );\n\n const orbitSolana = await importSolanaModule();\n\n if (!orbitSolana) {\n return false;\n }\n\n // Populate default values\n defaultRpcUrlsByMoniker = orbitSolana.defaultRpcUrlsByMoniker;\n }\n return true;\n } catch (error) {\n console.warn('Failed to initialize Solana utilities:', error);\n return false;\n }\n}\n\n/**\n * Extracts Solana cluster from chain identifier\n */\nfunction extractSolanaCluster(chainId: string): SolanaClusterMoniker | null {\n const parts = chainId.split(':');\n if (parts.length < 2) return null;\n\n let cluster = parts[1];\n // Map mainnet-beta to mainnet to match orbit-solana keys\n if (cluster === 'mainnet-beta') {\n cluster = 'mainnet';\n }\n\n const moniker = cluster as SolanaClusterMoniker;\n // Validate that it's a known cluster\n return moniker in defaultRpcUrlsByMoniker ? moniker : null;\n}\n\n/**\n * Builds available Solana RPC URLs from chain identifiers\n */\nfunction buildSolanaRpcUrls(\n chains: ChainIdentifierArray,\n solanaRPCUrls?: SolanaRPCUrlsType['rpcUrls'],\n): SolanaRPCUrlsType['rpcUrls'] {\n const availableRpcUrls: SolanaRPCUrlsType['rpcUrls'] = {};\n\n // If config is provided, we only consider clusters defined in it.\n // If not provided, we consider all default clusters.\n const allowedClusters = solanaRPCUrls ? Object.keys(solanaRPCUrls) : Object.keys(defaultRpcUrlsByMoniker);\n\n for (const chainId of chains) {\n if (typeof chainId !== 'string') continue;\n\n const cluster = extractSolanaCluster(chainId);\n if (!cluster) continue;\n\n // Check if this cluster is allowed by app config\n if (!allowedClusters.includes(cluster)) continue;\n\n // Get RPC URL with fallback to default\n const rpcUrl = solanaRPCUrls?.[cluster] ?? defaultRpcUrlsByMoniker[cluster];\n\n if (rpcUrl) {\n availableRpcUrls[cluster] = rpcUrl;\n }\n }\n\n return availableRpcUrls;\n}\n\n/**\n * Get Solana clusters from configuration\n */\nexport async function getSolanaClusters(\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>,\n chains?: ChainIdentifierArray,\n): Promise<string[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n\n if (chains && chains.length > 0) {\n // For Solana, build RPC URLs and return cluster names\n const availableRpcUrls = buildSolanaRpcUrls(chains, solanaRPCUrls);\n return Object.keys(availableRpcUrls);\n }\n\n // Return configured clusters or defaults\n return Object.keys(solanaRPCUrls || defaultRpcUrlsByMoniker);\n}\n\n/**\n * Type guard to check if a chain list contains Solana cluster names\n */\nexport function isSolanaChainList(chains: (string | number)[]): chains is string[] {\n return chains.length > 0 && chains.every((chain) => typeof chain === 'string');\n}\n\n/**\n * Gets available Solana clusters from the default configuration\n */\nexport async function getAvailableSolanaClusters(): Promise<SolanaClusterMoniker[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return Object.keys(defaultRpcUrlsByMoniker) as SolanaClusterMoniker[];\n}\n\n/**\n * Validates if a string is a valid Solana cluster moniker\n */\nexport async function isValidSolanaCluster(cluster: string): Promise<boolean> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return cluster in defaultRpcUrlsByMoniker;\n}\n","// Export utils with dynamic initialization\nexport * from './utils';\n\n// Export types only, not implementations\nexport type { SolanaClusterMoniker } from 'gill';\n\n// Import types from satellite-react/solana\nimport { OrbitAdapter } from '@tuwaio/orbit-core';\nimport { SolanaConnectorsWatcher } from '@tuwaio/satellite-react/solana';\nimport { ConnectorSolana, SolanaConnection } from '@tuwaio/satellite-solana';\n\n// Re-export the types\nexport type { ConnectorSolana, SolanaConnection };\n\n// Re-export the component\nexport { SolanaConnectorsWatcher };\n\n// Dynamic exports that will be loaded at runtime\nexport async function getSolanaExports() {\n try {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/satellite-react/solana\").catch(error => { console.warn(\"Failed to load Solana exports:\", error); return null; })',\n );\n\n const satelliteReactSolana = await importSolanaModule();\n\n if (!satelliteReactSolana) {\n return {\n available: false,\n error: 'Failed to load Solana exports',\n };\n }\n\n // Instead of trying to modify exports directly, we'll return the actual component\n // implementation and let the consumer handle the assignment\n const actualSolanaConnectorsWatcher = satelliteReactSolana.SolanaConnectorsWatcher;\n\n return {\n ...satelliteReactSolana,\n available: true,\n SolanaConnectorsWatcher: actualSolanaConnectorsWatcher,\n };\n } catch (error) {\n console.warn('Failed to load Solana exports:', error);\n return {\n available: false,\n error: error instanceof Error ? error.message : 'Unknown error loading Solana exports',\n };\n }\n}\n\n// Extend the main interface with Solana-specific config\n// This will override the default `any` type with specific SolanaClusterMoniker typing\n// eslint-disable-next-line\n// @ts-ignore - Need for declaration merging\ndeclare module '@tuwaio/nova-connect' {\n interface AllChainConfigs {\n /**\n * Solana RPC URLs configuration - enhanced from default any type\n * @override Replaces default `any` with specific SolanaClusterMoniker typing when gill is available\n */\n // eslint-disable-next-line\n // @ts-ignore - Need for declaration merging\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>;\n }\n}\n\n// Extend the satellite-react interfaces with Solana-specific types\n// eslint-disable-next-line\n// @ts-ignore - Need for declaration merging\ndeclare module '@tuwaio/satellite-react' {\n export interface AllConnections {\n [OrbitAdapter.SOLANA]: SolanaConnection;\n }\n export interface AllConnectors {\n [OrbitAdapter.SOLANA]: ConnectorSolana;\n }\n}\n"]}
|
package/dist/solana/index.d.cts
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { SolanaClusterMoniker as SolanaClusterMoniker$1 } from 'gill';
|
|
2
2
|
export { SolanaClusterMoniker } from 'gill';
|
|
3
3
|
import { C as ChainIdentifierArray } from '../types-DGsiEwne.cjs';
|
|
4
|
+
import { OrbitAdapter } from '@tuwaio/orbit-core';
|
|
4
5
|
export { SolanaConnectorsWatcher } from '@tuwaio/satellite-react/solana';
|
|
5
|
-
import {
|
|
6
|
+
import { SolanaConnection, ConnectorSolana } from '@tuwaio/satellite-solana';
|
|
7
|
+
export { ConnectorSolana, SolanaConnection } from '@tuwaio/satellite-solana';
|
|
6
8
|
|
|
7
9
|
/**
|
|
8
10
|
* Initializes Solana utilities by dynamically loading dependencies.
|
|
@@ -28,7 +30,6 @@ declare function getAvailableSolanaClusters(): Promise<SolanaClusterMoniker$1[]>
|
|
|
28
30
|
*/
|
|
29
31
|
declare function isValidSolanaCluster(cluster: string): Promise<boolean>;
|
|
30
32
|
|
|
31
|
-
type SolanaConnection = Connection;
|
|
32
33
|
declare function getSolanaExports(): Promise<any>;
|
|
33
34
|
declare module '@tuwaio/nova-connect' {
|
|
34
35
|
interface AllChainConfigs {
|
|
@@ -39,5 +40,13 @@ declare module '@tuwaio/nova-connect' {
|
|
|
39
40
|
solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>;
|
|
40
41
|
}
|
|
41
42
|
}
|
|
43
|
+
declare module '@tuwaio/satellite-react' {
|
|
44
|
+
interface AllConnections {
|
|
45
|
+
[OrbitAdapter.SOLANA]: SolanaConnection;
|
|
46
|
+
}
|
|
47
|
+
interface AllConnectors {
|
|
48
|
+
[OrbitAdapter.SOLANA]: ConnectorSolana;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
42
51
|
|
|
43
|
-
export {
|
|
52
|
+
export { getAvailableSolanaClusters, getSolanaClusters, getSolanaExports, initializeSolanaUtils, isSolanaChainList, isValidSolanaCluster };
|
package/dist/solana/index.d.ts
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { SolanaClusterMoniker as SolanaClusterMoniker$1 } from 'gill';
|
|
2
2
|
export { SolanaClusterMoniker } from 'gill';
|
|
3
3
|
import { C as ChainIdentifierArray } from '../types-DGsiEwne.js';
|
|
4
|
+
import { OrbitAdapter } from '@tuwaio/orbit-core';
|
|
4
5
|
export { SolanaConnectorsWatcher } from '@tuwaio/satellite-react/solana';
|
|
5
|
-
import {
|
|
6
|
+
import { SolanaConnection, ConnectorSolana } from '@tuwaio/satellite-solana';
|
|
7
|
+
export { ConnectorSolana, SolanaConnection } from '@tuwaio/satellite-solana';
|
|
6
8
|
|
|
7
9
|
/**
|
|
8
10
|
* Initializes Solana utilities by dynamically loading dependencies.
|
|
@@ -28,7 +30,6 @@ declare function getAvailableSolanaClusters(): Promise<SolanaClusterMoniker$1[]>
|
|
|
28
30
|
*/
|
|
29
31
|
declare function isValidSolanaCluster(cluster: string): Promise<boolean>;
|
|
30
32
|
|
|
31
|
-
type SolanaConnection = Connection;
|
|
32
33
|
declare function getSolanaExports(): Promise<any>;
|
|
33
34
|
declare module '@tuwaio/nova-connect' {
|
|
34
35
|
interface AllChainConfigs {
|
|
@@ -39,5 +40,13 @@ declare module '@tuwaio/nova-connect' {
|
|
|
39
40
|
solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>;
|
|
40
41
|
}
|
|
41
42
|
}
|
|
43
|
+
declare module '@tuwaio/satellite-react' {
|
|
44
|
+
interface AllConnections {
|
|
45
|
+
[OrbitAdapter.SOLANA]: SolanaConnection;
|
|
46
|
+
}
|
|
47
|
+
interface AllConnectors {
|
|
48
|
+
[OrbitAdapter.SOLANA]: ConnectorSolana;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
42
51
|
|
|
43
|
-
export {
|
|
52
|
+
export { getAvailableSolanaClusters, getSolanaClusters, getSolanaExports, initializeSolanaUtils, isSolanaChainList, isValidSolanaCluster };
|
package/dist/solana/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{SolanaConnectorsWatcher}from'@tuwaio/satellite-react/solana';var t={};async function l(){try{if(Object.keys(t).length===0){let
|
|
1
|
+
export{SolanaConnectorsWatcher}from'@tuwaio/satellite-react/solana';var t={};async function l(){try{if(Object.keys(t).length===0){let n=await new Function('return import("@tuwaio/orbit-solana").catch(error => { console.warn("Failed to load Solana dependencies:", error); return null; })')();if(!n)return !1;t=n.defaultRpcUrlsByMoniker;}return !0}catch(r){return console.warn("Failed to initialize Solana utilities:",r),false}}function c(r){let n=r.split(":");if(n.length<2)return null;let e=n[1];e==="mainnet-beta"&&(e="mainnet");let a=e;return a in t?a:null}function u(r,n){let e={},a=Object.keys(n||t);for(let i of r){if(typeof i!="string")continue;let o=c(i);if(!o||!a.includes(o))continue;let s=n?.[o]??t[o];s&&(e[o]=s);}return e}async function p(r,n){if(await l(),n&&n.length>0){let e=u(n,r);return Object.keys(e)}return Object.keys(r||t)}function S(r){return r.length>0&&r.every(n=>typeof n=="string")}async function f(){return await l(),Object.keys(t)}async function d(r){return await l(),r in t}async function g(){try{let n=await new Function('return import("@tuwaio/satellite-react/solana").catch(error => { console.warn("Failed to load Solana exports:", error); return null; })')();if(!n)return {available:!1,error:"Failed to load Solana exports"};let e=n.SolanaConnectorsWatcher;return {...n,available:!0,SolanaConnectorsWatcher:e}}catch(r){return console.warn("Failed to load Solana exports:",r),{available:false,error:r instanceof Error?r.message:"Unknown error loading Solana exports"}}}export{f as getAvailableSolanaClusters,p as getSolanaClusters,g as getSolanaExports,l as initializeSolanaUtils,S as isSolanaChainList,d as isValidSolanaCluster};//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/solana/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/solana/utils.ts","../../src/solana/index.ts"],"names":["defaultRpcUrlsByMoniker","initializeSolanaUtils","orbitSolana","error","extractSolanaCluster","chainId","parts","cluster","moniker","buildSolanaRpcUrls","chains","solanaRPCUrls","availableRpcUrls","allowedClusters","rpcUrl","getSolanaClusters","isSolanaChainList","chain","getAvailableSolanaClusters","isValidSolanaCluster","getSolanaExports","satelliteReactSolana"],"mappings":"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","file":"index.js","sourcesContent":["import type { SolanaClusterMoniker } from 'gill';\nimport { ChainIdentifierArray } from '../index';\n\n// Use a local type definition to avoid direct imports\ntype SolanaRPCUrlsType = {\n rpcUrls: Partial<Record<string, string>>;\n};\n\n// Default values that will be populated at runtime if the package is available\nlet defaultRpcUrlsByMoniker: Record<string, string> = {};\n\n/**\n * Initializes Solana utilities by dynamically loading dependencies.\n * This function should be called before using any Solana-specific functionality.\n * \n * @returns Promise resolving to true if initialization was successful\n */\nexport async function initializeSolanaUtils(): Promise<boolean> {\n try {\n // Only try to load if not already initialized\n if (Object.keys(defaultRpcUrlsByMoniker).length === 0) {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/orbit-solana\").catch(error => { console.warn(\"Failed to load Solana dependencies:\", error); return null; })'\n );\n\n const orbitSolana = await importSolanaModule();\n\n if (!orbitSolana) {\n return false;\n }\n\n // Populate default values\n defaultRpcUrlsByMoniker = orbitSolana.defaultRpcUrlsByMoniker;\n }\n return true;\n } catch (error) {\n console.warn('Failed to initialize Solana utilities:', error);\n return false;\n }\n}\n\n/**\n * Extracts Solana cluster from chain identifier\n */\nfunction extractSolanaCluster(chainId: string): SolanaClusterMoniker | null {\n const parts = chainId.split(':');\n if (parts.length < 2) return null;\n\n let cluster = parts[1];\n // Map mainnet-beta to mainnet to match orbit-solana keys\n if (cluster === 'mainnet-beta') {\n cluster = 'mainnet';\n }\n\n const moniker = cluster as SolanaClusterMoniker;\n // Validate that it's a known cluster\n return moniker in defaultRpcUrlsByMoniker ? moniker : null;\n}\n\n/**\n * Builds available Solana RPC URLs from chain identifiers\n */\nfunction buildSolanaRpcUrls(\n chains: ChainIdentifierArray,\n solanaRPCUrls?: SolanaRPCUrlsType['rpcUrls'],\n): SolanaRPCUrlsType['rpcUrls'] {\n const availableRpcUrls: SolanaRPCUrlsType['rpcUrls'] = {};\n\n // If config is provided, we only consider clusters defined in it.\n // If not provided, we consider all default clusters.\n const allowedClusters = solanaRPCUrls ? Object.keys(solanaRPCUrls) : Object.keys(defaultRpcUrlsByMoniker);\n\n for (const chainId of chains) {\n if (typeof chainId !== 'string') continue;\n\n const cluster = extractSolanaCluster(chainId);\n if (!cluster) continue;\n\n // Check if this cluster is allowed by app config\n if (!allowedClusters.includes(cluster)) continue;\n\n // Get RPC URL with fallback to default\n const rpcUrl = solanaRPCUrls?.[cluster] ?? defaultRpcUrlsByMoniker[cluster];\n\n if (rpcUrl) {\n availableRpcUrls[cluster] = rpcUrl;\n }\n }\n\n return availableRpcUrls;\n}\n\n/**\n * Get Solana clusters from configuration\n */\nexport async function getSolanaClusters(\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>,\n chains?: ChainIdentifierArray,\n): Promise<string[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n\n if (chains && chains.length > 0) {\n // For Solana, build RPC URLs and return cluster names\n const availableRpcUrls = buildSolanaRpcUrls(chains, solanaRPCUrls);\n return Object.keys(availableRpcUrls);\n }\n\n // Return configured clusters or defaults\n return Object.keys(solanaRPCUrls || defaultRpcUrlsByMoniker);\n}\n\n/**\n * Type guard to check if a chain list contains Solana cluster names\n */\nexport function isSolanaChainList(chains: (string | number)[]): chains is string[] {\n return chains.length > 0 && chains.every((chain) => typeof chain === 'string');\n}\n\n/**\n * Gets available Solana clusters from the default configuration\n */\nexport async function getAvailableSolanaClusters(): Promise<SolanaClusterMoniker[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return Object.keys(defaultRpcUrlsByMoniker) as SolanaClusterMoniker[];\n}\n\n/**\n * Validates if a string is a valid Solana cluster moniker\n */\nexport async function isValidSolanaCluster(cluster: string): Promise<boolean> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return cluster in defaultRpcUrlsByMoniker;\n}\n","// Export utils with dynamic initialization\nexport * from './utils';\n\n// Export types only, not implementations\nexport type { SolanaClusterMoniker } from 'gill';\n\n// Export components directly to satisfy static imports\nexport { SolanaConnectorsWatcher } from '@tuwaio/satellite-react/solana';\n\n// Re-export the Connection type from satellite-react and create a type alias for Solana\nimport { Connection } from '@tuwaio/satellite-react';\nexport type SolanaConnection = Connection;\n\n// Dynamic exports that will be loaded at runtime\nexport async function getSolanaExports() {\n try {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/satellite-react/solana\").catch(error => { console.warn(\"Failed to load Solana exports:\", error); return null; })'\n );\n\n const satelliteReactSolana = await importSolanaModule();\n\n if (!satelliteReactSolana) {\n return {\n available: false,\n error: 'Failed to load Solana exports',\n };\n }\n\n return {\n ...satelliteReactSolana,\n available: true,\n };\n } catch (error) {\n console.warn('Failed to load Solana exports:', error);\n return {\n available: false,\n error: error instanceof Error ? error.message : 'Unknown error loading Solana exports',\n };\n }\n}\n\n// Extend the main interface with Solana-specific config\n// This will override the default `any` type with specific SolanaClusterMoniker typing\n// eslint-disable-next-line\n// @ts-ignore - Need for declaration merging\ndeclare module '@tuwaio/nova-connect' {\n interface AllChainConfigs {\n /**\n * Solana RPC URLs configuration - enhanced from default any type\n * @override Replaces default `any` with specific SolanaClusterMoniker typing when gill is available\n */\n // eslint-disable-next-line\n // @ts-ignore - Need for declaration merging\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/solana/utils.ts","../../src/solana/index.ts"],"names":["defaultRpcUrlsByMoniker","initializeSolanaUtils","orbitSolana","error","extractSolanaCluster","chainId","parts","cluster","moniker","buildSolanaRpcUrls","chains","solanaRPCUrls","availableRpcUrls","allowedClusters","rpcUrl","getSolanaClusters","isSolanaChainList","chain","getAvailableSolanaClusters","isValidSolanaCluster","getSolanaExports","satelliteReactSolana","actualSolanaConnectorsWatcher"],"mappings":"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","file":"index.js","sourcesContent":["import type { SolanaClusterMoniker } from 'gill';\n\nimport { ChainIdentifierArray } from '../index';\n\n// Use a local type definition to avoid direct imports\ntype SolanaRPCUrlsType = {\n rpcUrls: Partial<Record<string, string>>;\n};\n\n// Default values that will be populated at runtime if the package is available\nlet defaultRpcUrlsByMoniker: Record<string, string> = {};\n\n/**\n * Initializes Solana utilities by dynamically loading dependencies.\n * This function should be called before using any Solana-specific functionality.\n *\n * @returns Promise resolving to true if initialization was successful\n */\nexport async function initializeSolanaUtils(): Promise<boolean> {\n try {\n // Only try to load if not already initialized\n if (Object.keys(defaultRpcUrlsByMoniker).length === 0) {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/orbit-solana\").catch(error => { console.warn(\"Failed to load Solana dependencies:\", error); return null; })',\n );\n\n const orbitSolana = await importSolanaModule();\n\n if (!orbitSolana) {\n return false;\n }\n\n // Populate default values\n defaultRpcUrlsByMoniker = orbitSolana.defaultRpcUrlsByMoniker;\n }\n return true;\n } catch (error) {\n console.warn('Failed to initialize Solana utilities:', error);\n return false;\n }\n}\n\n/**\n * Extracts Solana cluster from chain identifier\n */\nfunction extractSolanaCluster(chainId: string): SolanaClusterMoniker | null {\n const parts = chainId.split(':');\n if (parts.length < 2) return null;\n\n let cluster = parts[1];\n // Map mainnet-beta to mainnet to match orbit-solana keys\n if (cluster === 'mainnet-beta') {\n cluster = 'mainnet';\n }\n\n const moniker = cluster as SolanaClusterMoniker;\n // Validate that it's a known cluster\n return moniker in defaultRpcUrlsByMoniker ? moniker : null;\n}\n\n/**\n * Builds available Solana RPC URLs from chain identifiers\n */\nfunction buildSolanaRpcUrls(\n chains: ChainIdentifierArray,\n solanaRPCUrls?: SolanaRPCUrlsType['rpcUrls'],\n): SolanaRPCUrlsType['rpcUrls'] {\n const availableRpcUrls: SolanaRPCUrlsType['rpcUrls'] = {};\n\n // If config is provided, we only consider clusters defined in it.\n // If not provided, we consider all default clusters.\n const allowedClusters = solanaRPCUrls ? Object.keys(solanaRPCUrls) : Object.keys(defaultRpcUrlsByMoniker);\n\n for (const chainId of chains) {\n if (typeof chainId !== 'string') continue;\n\n const cluster = extractSolanaCluster(chainId);\n if (!cluster) continue;\n\n // Check if this cluster is allowed by app config\n if (!allowedClusters.includes(cluster)) continue;\n\n // Get RPC URL with fallback to default\n const rpcUrl = solanaRPCUrls?.[cluster] ?? defaultRpcUrlsByMoniker[cluster];\n\n if (rpcUrl) {\n availableRpcUrls[cluster] = rpcUrl;\n }\n }\n\n return availableRpcUrls;\n}\n\n/**\n * Get Solana clusters from configuration\n */\nexport async function getSolanaClusters(\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>,\n chains?: ChainIdentifierArray,\n): Promise<string[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n\n if (chains && chains.length > 0) {\n // For Solana, build RPC URLs and return cluster names\n const availableRpcUrls = buildSolanaRpcUrls(chains, solanaRPCUrls);\n return Object.keys(availableRpcUrls);\n }\n\n // Return configured clusters or defaults\n return Object.keys(solanaRPCUrls || defaultRpcUrlsByMoniker);\n}\n\n/**\n * Type guard to check if a chain list contains Solana cluster names\n */\nexport function isSolanaChainList(chains: (string | number)[]): chains is string[] {\n return chains.length > 0 && chains.every((chain) => typeof chain === 'string');\n}\n\n/**\n * Gets available Solana clusters from the default configuration\n */\nexport async function getAvailableSolanaClusters(): Promise<SolanaClusterMoniker[]> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return Object.keys(defaultRpcUrlsByMoniker) as SolanaClusterMoniker[];\n}\n\n/**\n * Validates if a string is a valid Solana cluster moniker\n */\nexport async function isValidSolanaCluster(cluster: string): Promise<boolean> {\n // Initialize Solana utilities first\n await initializeSolanaUtils();\n return cluster in defaultRpcUrlsByMoniker;\n}\n","// Export utils with dynamic initialization\nexport * from './utils';\n\n// Export types only, not implementations\nexport type { SolanaClusterMoniker } from 'gill';\n\n// Import types from satellite-react/solana\nimport { OrbitAdapter } from '@tuwaio/orbit-core';\nimport { SolanaConnectorsWatcher } from '@tuwaio/satellite-react/solana';\nimport { ConnectorSolana, SolanaConnection } from '@tuwaio/satellite-solana';\n\n// Re-export the types\nexport type { ConnectorSolana, SolanaConnection };\n\n// Re-export the component\nexport { SolanaConnectorsWatcher };\n\n// Dynamic exports that will be loaded at runtime\nexport async function getSolanaExports() {\n try {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSolanaModule = new Function(\n 'return import(\"@tuwaio/satellite-react/solana\").catch(error => { console.warn(\"Failed to load Solana exports:\", error); return null; })',\n );\n\n const satelliteReactSolana = await importSolanaModule();\n\n if (!satelliteReactSolana) {\n return {\n available: false,\n error: 'Failed to load Solana exports',\n };\n }\n\n // Instead of trying to modify exports directly, we'll return the actual component\n // implementation and let the consumer handle the assignment\n const actualSolanaConnectorsWatcher = satelliteReactSolana.SolanaConnectorsWatcher;\n\n return {\n ...satelliteReactSolana,\n available: true,\n SolanaConnectorsWatcher: actualSolanaConnectorsWatcher,\n };\n } catch (error) {\n console.warn('Failed to load Solana exports:', error);\n return {\n available: false,\n error: error instanceof Error ? error.message : 'Unknown error loading Solana exports',\n };\n }\n}\n\n// Extend the main interface with Solana-specific config\n// This will override the default `any` type with specific SolanaClusterMoniker typing\n// eslint-disable-next-line\n// @ts-ignore - Need for declaration merging\ndeclare module '@tuwaio/nova-connect' {\n interface AllChainConfigs {\n /**\n * Solana RPC URLs configuration - enhanced from default any type\n * @override Replaces default `any` with specific SolanaClusterMoniker typing when gill is available\n */\n // eslint-disable-next-line\n // @ts-ignore - Need for declaration merging\n solanaRPCUrls?: Partial<Record<SolanaClusterMoniker, string>>;\n }\n}\n\n// Extend the satellite-react interfaces with Solana-specific types\n// eslint-disable-next-line\n// @ts-ignore - Need for declaration merging\ndeclare module '@tuwaio/satellite-react' {\n export interface AllConnections {\n [OrbitAdapter.SOLANA]: SolanaConnection;\n }\n export interface AllConnectors {\n [OrbitAdapter.SOLANA]: ConnectorSolana;\n }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';async function n(){try{return await import('./solana/index.cjs')}catch(a){return console.warn("Solana utilities not available:",a),null}}async function i(){let a=await n();return {async getChains(t,e){return a?.getSolanaClusters?await a.getSolanaClusters(t,e):t&&typeof t=="object"?Object.keys(t):[]},isChainList(t){return a?.isSolanaChainList?a.isSolanaChainList(t):t.length>0&&t.every(e=>typeof e=="string")},async getAvailableClusters(){return a?.getAvailableSolanaClusters?await a.getAvailableSolanaClusters():[]},async isValidCluster(t){return a?.isValidSolanaCluster?await a.isValidSolanaCluster(t):false}}}async function r(){try{return await import('./solana/index.cjs'),!0}catch{return false}}exports.createSolanaAdapter=i;exports.isSolanaAdapterAvailable=r;//# sourceMappingURL=solana-
|
|
2
|
-
//# sourceMappingURL=solana-
|
|
1
|
+
'use strict';async function n(){try{return await import('./solana/index.cjs')}catch(a){return console.warn("Solana utilities not available:",a),null}}async function i(){let a=await n();return {async getChains(t,e){return a?.getSolanaClusters?await a.getSolanaClusters(t,e):t&&typeof t=="object"?Object.keys(t):[]},isChainList(t){return a?.isSolanaChainList?a.isSolanaChainList(t):t.length>0&&t.every(e=>typeof e=="string")},async getAvailableClusters(){return a?.getAvailableSolanaClusters?await a.getAvailableSolanaClusters():[]},async isValidCluster(t){return a?.isValidSolanaCluster?await a.isValidSolanaCluster(t):false}}}async function r(){try{return await import('./solana/index.cjs'),!0}catch{return false}}exports.createSolanaAdapter=i;exports.isSolanaAdapterAvailable=r;//# sourceMappingURL=solana-H5F4APJH.cjs.map
|
|
2
|
+
//# sourceMappingURL=solana-H5F4APJH.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/adapters/solana.ts"],"names":["getSolanaUtils","error","createSolanaAdapter","solanaUtils","solanaRPCUrls","chains","chain","cluster","isSolanaAdapterAvailable"],"mappings":"aAkCA,eAAeA,CAAAA,EAAoD,CACjE,GAAI,CAGF,OADoB,MAAM,OAAO,oBAAc,CAEjD,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,KAAK,iCAAA,CAAmCA,CAAK,CAAA,CAC9C,IACT,CACF,CAiCA,eAAsBC,CAAAA,EAA6C,CACjE,IAAMC,CAAAA,CAAc,MAAMH,CAAAA,EAAe,CAEzC,OAAO,CAQL,MAAM,SAAA,CAAUI,CAAAA,CAAoBC,CAAAA,CAA4C,CAE9E,OAAIF,CAAAA,EAAa,iBAAA,CACR,MAAMA,CAAAA,CAAY,iBAAA,CAAkBC,CAAAA,CAAeC,CAAM,CAAA,CAI9DD,CAAAA,EAAiB,OAAOA,CAAAA,EAAkB,QAAA,CACrC,MAAA,CAAO,IAAA,CAAKA,CAAa,CAAA,CAE3B,EACT,CAAA,CASA,WAAA,CAAYC,CAAAA,CAAsC,CAChD,OAAIF,GAAa,iBAAA,CACRA,CAAAA,CAAY,iBAAA,CAAkBE,CAAM,CAAA,CAItCA,CAAAA,CAAO,MAAA,CAAS,CAAA,EAAKA,CAAAA,CAAO,KAAA,CAAOC,CAAAA,EAAU,OAAOA,CAAAA,EAAU,QAAQ,CAC/E,CAAA,CAcA,MAAM,oBAAA,EAA0C,CAC9C,OAAIH,CAAAA,EAAa,0BAAA,CACR,MAAMA,CAAAA,CAAY,0BAAA,EAA2B,CAE/C,EACT,CAAA,CAkBA,MAAM,eAAeI,CAAAA,CAAmC,CACtD,OAAIJ,CAAAA,EAAa,oBAAA,CACR,MAAMA,CAAAA,CAAY,oBAAA,CAAqBI,CAAO,CAAA,CAEhD,KACT,CACF,CACF,CAuBA,eAAsBC,CAAAA,EAA6C,CACjE,GAAI,CACF,OAAA,MAAM,OAAO,oBAAc,CAAA,CACpB,CAAA,CACT,CAAA,KAAQ,CACN,OAAO,MACT,CACF","file":"solana-
|
|
1
|
+
{"version":3,"sources":["../src/utils/adapters/solana.ts"],"names":["getSolanaUtils","error","createSolanaAdapter","solanaUtils","solanaRPCUrls","chains","chain","cluster","isSolanaAdapterAvailable"],"mappings":"aAkCA,eAAeA,CAAAA,EAAoD,CACjE,GAAI,CAGF,OADoB,MAAM,OAAO,oBAAc,CAEjD,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,KAAK,iCAAA,CAAmCA,CAAK,CAAA,CAC9C,IACT,CACF,CAiCA,eAAsBC,CAAAA,EAA6C,CACjE,IAAMC,CAAAA,CAAc,MAAMH,CAAAA,EAAe,CAEzC,OAAO,CAQL,MAAM,SAAA,CAAUI,CAAAA,CAAoBC,CAAAA,CAA4C,CAE9E,OAAIF,CAAAA,EAAa,iBAAA,CACR,MAAMA,CAAAA,CAAY,iBAAA,CAAkBC,CAAAA,CAAeC,CAAM,CAAA,CAI9DD,CAAAA,EAAiB,OAAOA,CAAAA,EAAkB,QAAA,CACrC,MAAA,CAAO,IAAA,CAAKA,CAAa,CAAA,CAE3B,EACT,CAAA,CASA,WAAA,CAAYC,CAAAA,CAAsC,CAChD,OAAIF,GAAa,iBAAA,CACRA,CAAAA,CAAY,iBAAA,CAAkBE,CAAM,CAAA,CAItCA,CAAAA,CAAO,MAAA,CAAS,CAAA,EAAKA,CAAAA,CAAO,KAAA,CAAOC,CAAAA,EAAU,OAAOA,CAAAA,EAAU,QAAQ,CAC/E,CAAA,CAcA,MAAM,oBAAA,EAA0C,CAC9C,OAAIH,CAAAA,EAAa,0BAAA,CACR,MAAMA,CAAAA,CAAY,0BAAA,EAA2B,CAE/C,EACT,CAAA,CAkBA,MAAM,eAAeI,CAAAA,CAAmC,CACtD,OAAIJ,CAAAA,EAAa,oBAAA,CACR,MAAMA,CAAAA,CAAY,oBAAA,CAAqBI,CAAO,CAAA,CAEhD,KACT,CACF,CACF,CAuBA,eAAsBC,CAAAA,EAA6C,CACjE,GAAI,CACF,OAAA,MAAM,OAAO,oBAAc,CAAA,CACpB,CAAA,CACT,CAAA,KAAQ,CACN,OAAO,MACT,CACF","file":"solana-H5F4APJH.cjs","sourcesContent":["import type { ChainAdapter } from './types';\n\n/**\n * Solana utilities module interface for dynamic imports.\n *\n * @internal\n * @since 1.0.0\n */\ninterface SolanaUtilsModule {\n getSolanaClusters?: (solanaRPCUrls: any, chains?: any) => Promise<string[]>;\n isSolanaChainList?: (chains: (string | number)[]) => boolean;\n getAvailableSolanaClusters?: () => Promise<string[]>;\n isValidSolanaCluster?: (cluster: string) => Promise<boolean>;\n initializeSolanaUtils?: () => Promise<boolean>;\n}\n\n/**\n * Dynamically imports and checks availability of Solana utilities.\n * This function attempts to load Solana-specific utilities without throwing errors\n * if the Solana package is not installed in the current environment.\n *\n * @internal\n * @returns Promise resolving to Solana utilities module or null if not available\n *\n * @example\n * ```typescript\n * const solanaUtils = await getSolanaUtils();\n * if (solanaUtils?.getSolanaClusters) {\n * const clusters = solanaUtils.getSolanaClusters(rpcUrls);\n * }\n * ```\n *\n * @since 1.0.0\n */\nasync function getSolanaUtils(): Promise<SolanaUtilsModule | null> {\n try {\n // Dynamic import of Solana utilities - fails gracefully if package not installed\n const solanaUtils = await import('../../solana');\n return solanaUtils;\n } catch (error) {\n console.warn('Solana utilities not available:', error);\n return null;\n }\n}\n\n/**\n * Creates a Solana chain adapter with dynamic loading and fallback support.\n *\n * This adapter provides Solana-specific functionality while gracefully handling\n * environments where Solana utilities are not available. It includes Solana-specific\n * methods like cluster management that are unique to the Solana blockchain architecture.\n *\n * @returns Promise resolving to a configured Solana ChainAdapter\n *\n * @example\n * ```typescript\n * const adapter = await createSolanaAdapter();\n *\n * // Get Solana cluster names from RPC configuration\n * const clusters = adapter.getChains({\n * 'mainnet-beta': 'https://api.mainnet-beta.solana.com',\n * devnet: 'https://api.devnet.solana.com'\n * });\n * console.log(clusters); // ['mainnet-beta', 'devnet']\n *\n * // Validate cluster list format\n * const isValid = adapter.isChainList(['mainnet-beta', 'devnet']);\n * console.log(isValid); // true (string identifiers are valid for Solana)\n *\n * // Get available clusters\n * const availableClusters = adapter.getAvailableClusters?.();\n * console.log(availableClusters); // All configured cluster names\n * ```\n *\n * @since 1.0.0\n */\nexport async function createSolanaAdapter(): Promise<ChainAdapter> {\n const solanaUtils = await getSolanaUtils();\n\n return {\n /**\n * Extracts cluster names from Solana RPC URL configuration.\n *\n * @param solanaRPCUrls Object mapping cluster names to RPC URLs\n * @param chains Optional array of specific chains to filter\n * @returns Array of cluster names (strings)\n */\n async getChains(solanaRPCUrls: any, chains?: any): Promise<(string | number)[]> {\n // Use imported Solana utilities if available\n if (solanaUtils?.getSolanaClusters) {\n return await solanaUtils.getSolanaClusters(solanaRPCUrls, chains);\n }\n\n // Fallback implementation for basic cluster extraction\n if (solanaRPCUrls && typeof solanaRPCUrls === 'object') {\n return Object.keys(solanaRPCUrls);\n }\n return [];\n },\n\n /**\n * Validates whether the provided chains list conforms to Solana cluster format.\n * Solana clusters are typically identified by string names like 'mainnet-beta', 'devnet'.\n *\n * @param chains Array of chain identifiers to validate\n * @returns True if the chain list is valid for Solana\n */\n isChainList(chains: (string | number)[]): boolean {\n if (solanaUtils?.isSolanaChainList) {\n return solanaUtils.isSolanaChainList(chains);\n }\n\n // Fallback validation: Solana clusters should be strings\n return chains.length > 0 && chains.every((chain) => typeof chain === 'string');\n },\n\n /**\n * Gets all available Solana clusters from the current configuration.\n * This is a Solana-specific method that returns cluster names that can be used.\n *\n * @returns Array of available cluster names\n *\n * @example\n * ```typescript\n * const clusters = await adapter.getAvailableClusters?.();\n * // Might return: ['mainnet-beta', 'devnet', 'testnet']\n * ```\n */\n async getAvailableClusters(): Promise<string[]> {\n if (solanaUtils?.getAvailableSolanaClusters) {\n return await solanaUtils.getAvailableSolanaClusters();\n }\n return [];\n },\n\n /**\n * Validates whether a cluster name is valid for Solana.\n * Checks against known Solana cluster monikers and custom configurations.\n *\n * @param cluster Cluster name to validate\n * @returns True if the cluster name is valid\n *\n * @example\n * ```typescript\n * const isValid = await adapter.isValidCluster?.('mainnet-beta');\n * console.log(isValid); // true\n *\n * const isInvalid = await adapter.isValidCluster?.('invalid-cluster');\n * console.log(isInvalid); // false\n * ```\n */\n async isValidCluster(cluster: string): Promise<boolean> {\n if (solanaUtils?.isValidSolanaCluster) {\n return await solanaUtils.isValidSolanaCluster(cluster);\n }\n return false;\n },\n };\n}\n\n/**\n * Checks if the Solana adapter can be created in the current environment.\n * This function verifies that the required Solana utilities are available\n * by attempting to import them.\n *\n * @returns Promise resolving to true if Solana adapter is available\n *\n * @example\n * ```typescript\n * const hasSolana = await isSolanaAdapterAvailable();\n * if (hasSolana) {\n * const adapter = await createSolanaAdapter();\n * // Use Solana functionality\n * const clusters = adapter.getAvailableClusters?.();\n * } else {\n * console.log('Solana support not available in this build');\n * }\n * ```\n *\n * @since 1.0.0\n */\nexport async function isSolanaAdapterAvailable(): Promise<boolean> {\n try {\n await import('../../solana');\n return true;\n } catch {\n return false;\n }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
async function n(){try{return await import('./solana/index.js')}catch(a){return console.warn("Solana utilities not available:",a),null}}async function i(){let a=await n();return {async getChains(t,e){return a?.getSolanaClusters?await a.getSolanaClusters(t,e):t&&typeof t=="object"?Object.keys(t):[]},isChainList(t){return a?.isSolanaChainList?a.isSolanaChainList(t):t.length>0&&t.every(e=>typeof e=="string")},async getAvailableClusters(){return a?.getAvailableSolanaClusters?await a.getAvailableSolanaClusters():[]},async isValidCluster(t){return a?.isValidSolanaCluster?await a.isValidSolanaCluster(t):false}}}async function r(){try{return await import('./solana/index.js'),!0}catch{return false}}export{i as createSolanaAdapter,r as isSolanaAdapterAvailable};//# sourceMappingURL=solana-
|
|
2
|
-
//# sourceMappingURL=solana-
|
|
1
|
+
async function n(){try{return await import('./solana/index.js')}catch(a){return console.warn("Solana utilities not available:",a),null}}async function i(){let a=await n();return {async getChains(t,e){return a?.getSolanaClusters?await a.getSolanaClusters(t,e):t&&typeof t=="object"?Object.keys(t):[]},isChainList(t){return a?.isSolanaChainList?a.isSolanaChainList(t):t.length>0&&t.every(e=>typeof e=="string")},async getAvailableClusters(){return a?.getAvailableSolanaClusters?await a.getAvailableSolanaClusters():[]},async isValidCluster(t){return a?.isValidSolanaCluster?await a.isValidSolanaCluster(t):false}}}async function r(){try{return await import('./solana/index.js'),!0}catch{return false}}export{i as createSolanaAdapter,r as isSolanaAdapterAvailable};//# sourceMappingURL=solana-TKICEEDG.js.map
|
|
2
|
+
//# sourceMappingURL=solana-TKICEEDG.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/adapters/solana.ts"],"names":["getSolanaUtils","error","createSolanaAdapter","solanaUtils","solanaRPCUrls","chains","chain","cluster","isSolanaAdapterAvailable"],"mappings":"AAkCA,eAAeA,CAAAA,EAAoD,CACjE,GAAI,CAGF,OADoB,MAAM,OAAO,mBAAc,CAEjD,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,KAAK,iCAAA,CAAmCA,CAAK,CAAA,CAC9C,IACT,CACF,CAiCA,eAAsBC,CAAAA,EAA6C,CACjE,IAAMC,CAAAA,CAAc,MAAMH,CAAAA,EAAe,CAEzC,OAAO,CAQL,MAAM,SAAA,CAAUI,CAAAA,CAAoBC,CAAAA,CAA4C,CAE9E,OAAIF,CAAAA,EAAa,iBAAA,CACR,MAAMA,CAAAA,CAAY,iBAAA,CAAkBC,CAAAA,CAAeC,CAAM,CAAA,CAI9DD,CAAAA,EAAiB,OAAOA,CAAAA,EAAkB,QAAA,CACrC,MAAA,CAAO,IAAA,CAAKA,CAAa,CAAA,CAE3B,EACT,CAAA,CASA,WAAA,CAAYC,CAAAA,CAAsC,CAChD,OAAIF,GAAa,iBAAA,CACRA,CAAAA,CAAY,iBAAA,CAAkBE,CAAM,CAAA,CAItCA,CAAAA,CAAO,MAAA,CAAS,CAAA,EAAKA,CAAAA,CAAO,KAAA,CAAOC,CAAAA,EAAU,OAAOA,CAAAA,EAAU,QAAQ,CAC/E,CAAA,CAcA,MAAM,oBAAA,EAA0C,CAC9C,OAAIH,CAAAA,EAAa,0BAAA,CACR,MAAMA,CAAAA,CAAY,0BAAA,EAA2B,CAE/C,EACT,CAAA,CAkBA,MAAM,eAAeI,CAAAA,CAAmC,CACtD,OAAIJ,CAAAA,EAAa,oBAAA,CACR,MAAMA,CAAAA,CAAY,oBAAA,CAAqBI,CAAO,CAAA,CAEhD,KACT,CACF,CACF,CAuBA,eAAsBC,CAAAA,EAA6C,CACjE,GAAI,CACF,OAAA,MAAM,OAAO,mBAAc,CAAA,CACpB,CAAA,CACT,CAAA,KAAQ,CACN,OAAO,MACT,CACF","file":"solana-
|
|
1
|
+
{"version":3,"sources":["../src/utils/adapters/solana.ts"],"names":["getSolanaUtils","error","createSolanaAdapter","solanaUtils","solanaRPCUrls","chains","chain","cluster","isSolanaAdapterAvailable"],"mappings":"AAkCA,eAAeA,CAAAA,EAAoD,CACjE,GAAI,CAGF,OADoB,MAAM,OAAO,mBAAc,CAEjD,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,KAAK,iCAAA,CAAmCA,CAAK,CAAA,CAC9C,IACT,CACF,CAiCA,eAAsBC,CAAAA,EAA6C,CACjE,IAAMC,CAAAA,CAAc,MAAMH,CAAAA,EAAe,CAEzC,OAAO,CAQL,MAAM,SAAA,CAAUI,CAAAA,CAAoBC,CAAAA,CAA4C,CAE9E,OAAIF,CAAAA,EAAa,iBAAA,CACR,MAAMA,CAAAA,CAAY,iBAAA,CAAkBC,CAAAA,CAAeC,CAAM,CAAA,CAI9DD,CAAAA,EAAiB,OAAOA,CAAAA,EAAkB,QAAA,CACrC,MAAA,CAAO,IAAA,CAAKA,CAAa,CAAA,CAE3B,EACT,CAAA,CASA,WAAA,CAAYC,CAAAA,CAAsC,CAChD,OAAIF,GAAa,iBAAA,CACRA,CAAAA,CAAY,iBAAA,CAAkBE,CAAM,CAAA,CAItCA,CAAAA,CAAO,MAAA,CAAS,CAAA,EAAKA,CAAAA,CAAO,KAAA,CAAOC,CAAAA,EAAU,OAAOA,CAAAA,EAAU,QAAQ,CAC/E,CAAA,CAcA,MAAM,oBAAA,EAA0C,CAC9C,OAAIH,CAAAA,EAAa,0BAAA,CACR,MAAMA,CAAAA,CAAY,0BAAA,EAA2B,CAE/C,EACT,CAAA,CAkBA,MAAM,eAAeI,CAAAA,CAAmC,CACtD,OAAIJ,CAAAA,EAAa,oBAAA,CACR,MAAMA,CAAAA,CAAY,oBAAA,CAAqBI,CAAO,CAAA,CAEhD,KACT,CACF,CACF,CAuBA,eAAsBC,CAAAA,EAA6C,CACjE,GAAI,CACF,OAAA,MAAM,OAAO,mBAAc,CAAA,CACpB,CAAA,CACT,CAAA,KAAQ,CACN,OAAO,MACT,CACF","file":"solana-TKICEEDG.js","sourcesContent":["import type { ChainAdapter } from './types';\n\n/**\n * Solana utilities module interface for dynamic imports.\n *\n * @internal\n * @since 1.0.0\n */\ninterface SolanaUtilsModule {\n getSolanaClusters?: (solanaRPCUrls: any, chains?: any) => Promise<string[]>;\n isSolanaChainList?: (chains: (string | number)[]) => boolean;\n getAvailableSolanaClusters?: () => Promise<string[]>;\n isValidSolanaCluster?: (cluster: string) => Promise<boolean>;\n initializeSolanaUtils?: () => Promise<boolean>;\n}\n\n/**\n * Dynamically imports and checks availability of Solana utilities.\n * This function attempts to load Solana-specific utilities without throwing errors\n * if the Solana package is not installed in the current environment.\n *\n * @internal\n * @returns Promise resolving to Solana utilities module or null if not available\n *\n * @example\n * ```typescript\n * const solanaUtils = await getSolanaUtils();\n * if (solanaUtils?.getSolanaClusters) {\n * const clusters = solanaUtils.getSolanaClusters(rpcUrls);\n * }\n * ```\n *\n * @since 1.0.0\n */\nasync function getSolanaUtils(): Promise<SolanaUtilsModule | null> {\n try {\n // Dynamic import of Solana utilities - fails gracefully if package not installed\n const solanaUtils = await import('../../solana');\n return solanaUtils;\n } catch (error) {\n console.warn('Solana utilities not available:', error);\n return null;\n }\n}\n\n/**\n * Creates a Solana chain adapter with dynamic loading and fallback support.\n *\n * This adapter provides Solana-specific functionality while gracefully handling\n * environments where Solana utilities are not available. It includes Solana-specific\n * methods like cluster management that are unique to the Solana blockchain architecture.\n *\n * @returns Promise resolving to a configured Solana ChainAdapter\n *\n * @example\n * ```typescript\n * const adapter = await createSolanaAdapter();\n *\n * // Get Solana cluster names from RPC configuration\n * const clusters = adapter.getChains({\n * 'mainnet-beta': 'https://api.mainnet-beta.solana.com',\n * devnet: 'https://api.devnet.solana.com'\n * });\n * console.log(clusters); // ['mainnet-beta', 'devnet']\n *\n * // Validate cluster list format\n * const isValid = adapter.isChainList(['mainnet-beta', 'devnet']);\n * console.log(isValid); // true (string identifiers are valid for Solana)\n *\n * // Get available clusters\n * const availableClusters = adapter.getAvailableClusters?.();\n * console.log(availableClusters); // All configured cluster names\n * ```\n *\n * @since 1.0.0\n */\nexport async function createSolanaAdapter(): Promise<ChainAdapter> {\n const solanaUtils = await getSolanaUtils();\n\n return {\n /**\n * Extracts cluster names from Solana RPC URL configuration.\n *\n * @param solanaRPCUrls Object mapping cluster names to RPC URLs\n * @param chains Optional array of specific chains to filter\n * @returns Array of cluster names (strings)\n */\n async getChains(solanaRPCUrls: any, chains?: any): Promise<(string | number)[]> {\n // Use imported Solana utilities if available\n if (solanaUtils?.getSolanaClusters) {\n return await solanaUtils.getSolanaClusters(solanaRPCUrls, chains);\n }\n\n // Fallback implementation for basic cluster extraction\n if (solanaRPCUrls && typeof solanaRPCUrls === 'object') {\n return Object.keys(solanaRPCUrls);\n }\n return [];\n },\n\n /**\n * Validates whether the provided chains list conforms to Solana cluster format.\n * Solana clusters are typically identified by string names like 'mainnet-beta', 'devnet'.\n *\n * @param chains Array of chain identifiers to validate\n * @returns True if the chain list is valid for Solana\n */\n isChainList(chains: (string | number)[]): boolean {\n if (solanaUtils?.isSolanaChainList) {\n return solanaUtils.isSolanaChainList(chains);\n }\n\n // Fallback validation: Solana clusters should be strings\n return chains.length > 0 && chains.every((chain) => typeof chain === 'string');\n },\n\n /**\n * Gets all available Solana clusters from the current configuration.\n * This is a Solana-specific method that returns cluster names that can be used.\n *\n * @returns Array of available cluster names\n *\n * @example\n * ```typescript\n * const clusters = await adapter.getAvailableClusters?.();\n * // Might return: ['mainnet-beta', 'devnet', 'testnet']\n * ```\n */\n async getAvailableClusters(): Promise<string[]> {\n if (solanaUtils?.getAvailableSolanaClusters) {\n return await solanaUtils.getAvailableSolanaClusters();\n }\n return [];\n },\n\n /**\n * Validates whether a cluster name is valid for Solana.\n * Checks against known Solana cluster monikers and custom configurations.\n *\n * @param cluster Cluster name to validate\n * @returns True if the cluster name is valid\n *\n * @example\n * ```typescript\n * const isValid = await adapter.isValidCluster?.('mainnet-beta');\n * console.log(isValid); // true\n *\n * const isInvalid = await adapter.isValidCluster?.('invalid-cluster');\n * console.log(isInvalid); // false\n * ```\n */\n async isValidCluster(cluster: string): Promise<boolean> {\n if (solanaUtils?.isValidSolanaCluster) {\n return await solanaUtils.isValidSolanaCluster(cluster);\n }\n return false;\n },\n };\n}\n\n/**\n * Checks if the Solana adapter can be created in the current environment.\n * This function verifies that the required Solana utilities are available\n * by attempting to import them.\n *\n * @returns Promise resolving to true if Solana adapter is available\n *\n * @example\n * ```typescript\n * const hasSolana = await isSolanaAdapterAvailable();\n * if (hasSolana) {\n * const adapter = await createSolanaAdapter();\n * // Use Solana functionality\n * const clusters = adapter.getAvailableClusters?.();\n * } else {\n * console.log('Solana support not available in this build');\n * }\n * ```\n *\n * @since 1.0.0\n */\nexport async function isSolanaAdapterAvailable(): Promise<boolean> {\n try {\n await import('../../solana');\n return true;\n } catch {\n return false;\n }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tuwaio/nova-connect",
|
|
3
|
-
"version": "1.0.0-fix-indep-alpha.
|
|
3
|
+
"version": "1.0.0-fix-indep-alpha.8.549f0ed",
|
|
4
4
|
"private": false,
|
|
5
5
|
"author": "Oleksandr Tkach",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -199,7 +199,7 @@
|
|
|
199
199
|
"@radix-ui/react-select": "^2.2.6",
|
|
200
200
|
"@tuwaio/orbit-core": "^0.2.0",
|
|
201
201
|
"@tuwaio/orbit-evm": "^0.2.2",
|
|
202
|
-
"@tuwaio/satellite-react": "
|
|
202
|
+
"@tuwaio/satellite-react": "1.0.0-fix-adapters-independ-alpha.1.82df95a",
|
|
203
203
|
"@tuwaio/orbit-solana": "^0.2.0",
|
|
204
204
|
"@tuwaio/satellite-core": "^0.2.0",
|
|
205
205
|
"@tuwaio/satellite-evm": "^0.2.2",
|
|
@@ -229,8 +229,8 @@
|
|
|
229
229
|
"tw-animate-css": "^1.4.0",
|
|
230
230
|
"typescript": "^5.9.3",
|
|
231
231
|
"tsup": "^8.5.1",
|
|
232
|
-
"@tuwaio/nova-core": "^1.0.0-fix-indep-alpha.
|
|
233
|
-
"@tuwaio/nova-transactions": "^1.0.0-fix-indep-alpha.
|
|
232
|
+
"@tuwaio/nova-core": "^1.0.0-fix-indep-alpha.8.549f0ed",
|
|
233
|
+
"@tuwaio/nova-transactions": "^1.0.0-fix-indep-alpha.8.549f0ed"
|
|
234
234
|
},
|
|
235
235
|
"scripts": {
|
|
236
236
|
"start": "tsup src/index.ts --watch",
|
package/dist/chunk-6ZNK56AI.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export{AllConnectors as b,Connection as c,Connector as d,SatelliteConnectProvider as e,SatelliteConnectProviderProps as f,SatelliteStoreContext as g,useInitializeAutoConnect as h,useSatelliteConnectStore as i}from'@tuwaio/satellite-react';async function r(){try{let t=await new Function('return import("@tuwaio/satellite-react").catch(error => { console.warn("Failed to load Satellite exports:", error); return null; })')();return t?{...t,available:!0}:{available:!1,error:"Failed to load Satellite exports"}}catch(e){return console.warn("Failed to load Satellite exports:",e),{available:false,error:e instanceof Error?e.message:"Unknown error loading Satellite exports"}}}export{r as a};//# sourceMappingURL=chunk-6ZNK56AI.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-6ZNK56AI.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/satellite/index.ts"],"names":["getSatelliteExports","satelliteReact","error"],"mappings":"+OAaA,eAAsBA,CAAAA,EAAsB,CAC1C,GAAI,CAOF,IAAMC,CAAAA,CAAiB,MAJO,IAAI,QAAA,CAChC,qIACF,GAEmD,CAEnD,OAAKA,CAAAA,CAOE,CACL,GAAGA,CAAAA,CACH,SAAA,CAAW,CAAA,CACb,CAAA,CATS,CACL,SAAA,CAAW,CAAA,CAAA,CACX,KAAA,CAAO,kCACT,CAOJ,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,IAAA,CAAK,mCAAA,CAAqCA,CAAK,CAAA,CAChD,CACL,SAAA,CAAW,KAAA,CACX,KAAA,CAAOA,CAAAA,YAAiB,KAAA,CAAQA,CAAAA,CAAM,OAAA,CAAU,yCAClD,CACF,CACF","file":"chunk-6ZNK56AI.js","sourcesContent":["// Export all types and components directly to satisfy static imports\nexport {\n AllConnectors,\n Connection,\n Connector,\n SatelliteConnectProvider,\n SatelliteConnectProviderProps,\n SatelliteStoreContext,\n useInitializeAutoConnect,\n useSatelliteConnectStore,\n} from '@tuwaio/satellite-react';\n\n// Dynamic exports that will be loaded at runtime\nexport async function getSatelliteExports() {\n try {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSatelliteModule = new Function(\n 'return import(\"@tuwaio/satellite-react\").catch(error => { console.warn(\"Failed to load Satellite exports:\", error); return null; })'\n );\n\n const satelliteReact = await importSatelliteModule();\n\n if (!satelliteReact) {\n return {\n available: false,\n error: 'Failed to load Satellite exports',\n };\n }\n\n return {\n ...satelliteReact,\n available: true,\n };\n } catch (error) {\n console.warn('Failed to load Satellite exports:', error);\n return {\n available: false,\n error: error instanceof Error ? error.message : 'Unknown error loading Satellite exports',\n };\n }\n}\n"]}
|
package/dist/chunk-7EUQO34W.js
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import {a as a$1,i as i$1}from'./chunk-4GXQK7LW.js';import {a}from'./chunk-3BMX6JWH.js';import {i}from'./chunk-6ZNK56AI.js';import {textCenterEllipsis}from'@tuwaio/nova-core';import {OrbitAdapter,getAdapterFromConnectorType,formatConnectorName}from'@tuwaio/orbit-core';import {createContext,useContext,useMemo,useState,useRef,useCallback,useEffect}from'react';function he(e){let{abbreviateSymbols:t=12,maxNameLength:n=30,autoRetry:o=false,retryDelay:s=3e3}=e,a=i(f=>f.activeConnection),i$1=i(f=>f.getAdapter),r=useMemo(()=>a?.address,[a?.address]),u=useMemo(()=>a?.connectorType,[a?.connectorType]),c=useMemo(()=>u?i$1(getAdapterFromConnectorType(u??`${OrbitAdapter.EVM}:not-connected`)):null,[i$1,u]),[d,b]=useState(null),[F,p]=useState(null),[g,m]=useState(false),[N,h]=useState(null),x=useRef(null),T=useRef(null),I=useMemo(()=>{if(!c)return {hasNameResolver:false,hasAvatarResolver:false};let f="getName"in c&&typeof c.getName=="function",C="getAvatar"in c&&typeof c.getAvatar=="function";return {hasNameResolver:f,hasAvatarResolver:C}},[c]),v=useCallback(()=>{x.current&&(x.current.abort(),x.current=null),T.current!==null&&(clearTimeout(T.current),T.current=null);},[]),L=useCallback(async()=>{if(v(),!r||!c||!I.hasNameResolver){b(null),p(null),m(false),h(null);return}x.current=new AbortController;let{signal:f}=x.current;m(true),h(null),b(null),p(null);try{if(f.aborted)return;let C=await c.getName?.(r);if(f.aborted)return;if(C&&(b(C),I.hasAvatarResolver))try{let S=await c.getAvatar?.(C);f.aborted||p(S??null);}catch(S){console.warn("Failed to fetch avatar:",S),f.aborted||p(null);}}catch(C){if(f.aborted)return;let S=C instanceof Error?C.message:"Failed to fetch name service data";console.error("Failed to fetch name service data:",C),h(S),b(null),p(null),o&&(T.current=setTimeout(()=>{L();},s));}finally{f.aborted||m(false);}},[r,c,I,o,s,v]),ee=useCallback(()=>{h(null),L();},[L]);useEffect(()=>(L(),v),[L,v]),useEffect(()=>v,[v]);let te=useMemo(()=>d?d.length>n?textCenterEllipsis(d,t,t):d:r?textCenterEllipsis(r,t,t):void 0,[d,r,n,t]);return {ensName:d,ensAvatar:F,isLoading:g,ensNameAbbreviated:te,error:N,retry:ee}}var R=class extends Error{constructor(t="useNovaConnect must be used within NovaConnectProvider"){super(t),this.name="NovaConnectProviderError";}},V=createContext(void 0),Ae=()=>{let e=useContext(V);if(!e)throw new R;return e},Ne=()=>useContext(V)!==void 0,xe=()=>useContext(V)??null;var ce=createContext(a),D=()=>useContext(ce),ke=e=>D()[e],we=e=>{let t=D(),n={};for(let o of e)n[o]=t[o];return n},Ee=(e,t)=>!!e[t]?.trim(),Be=e=>{let t=D(),o={actions:["connectWallet","disconnect","connecting","connected","tryAgain","back","connect","close"],states:["success","error","replaced","loading","idle"],accessibility:["chainSelector","closeModal","selectChain","walletControls","openWalletModal"],transactions:["transactionLoading","transactionSuccess","transactionError","transactionReplaced","recent"]}[e],s={};for(let a of o)s[a]=t[a];return s},Ie=e=>e===a,Me=(e,t,n)=>{let o=e[t];return o&&o.trim()?o:n||a[t]||t.toString()},Pe=(e,t)=>{let n={};for(let o of t)n[o]=e[o];return n};function U(e){if(typeof e!="string")return false;let t=e.trim();return !!/^0x[a-fA-F0-9]{40}$/.test(t)}function _(e){if(typeof e!="string")return false;let t=e.trim();return /^[1-9A-HJ-NP-Za-km-z]{32,44}$/.test(t)}function We(e,t="auto"){if(!e||typeof e!="string")return false;let n=e.trim();switch(t){case "evm":return U(n);case "solana":return _(n);case "auto":default:return U(n)||_(n)}}var y={[OrbitAdapter.EVM]:1,[OrbitAdapter.SOLANA]:"mainnet",[OrbitAdapter.Starknet]:"0x534e5f4d41494e"};function Ge({selectedAdapter:e,appChains:t,solanaRPCUrls:n}){switch(e){case OrbitAdapter.EVM:{let o=t?.[0];return o?.id&&typeof o.id=="number"?o.id:(process.env.NODE_ENV==="development"&&!t?.length&&console.warn("getConnectChainId: No EVM chains configured, using Ethereum Mainnet"),y[OrbitAdapter.EVM])}case OrbitAdapter.SOLANA:{if(n&&typeof n=="object"){let o=Object.keys(n);if(o.length>0)return o[0]}return process.env.NODE_ENV==="development"&&!n&&console.warn("getConnectChainId: No Solana RPC URLs configured, using mainnet"),y[OrbitAdapter.SOLANA]}case OrbitAdapter.Starknet:return process.env.NODE_ENV==="development"&&console.info("getConnectChainId: Using default Starknet chain ID"),y[OrbitAdapter.Starknet];default:return process.env.NODE_ENV==="development"&&console.error("getConnectChainId: Unknown adapter:",e),y[OrbitAdapter.EVM]}}function Fe({selectedAdapter:e,appChains:t,solanaRPCUrls:n}){switch(e){case OrbitAdapter.EVM:return t?.map(o=>o.id).filter(Boolean)??[y[OrbitAdapter.EVM]];case OrbitAdapter.SOLANA:return n?Object.keys(n):[y[OrbitAdapter.SOLANA]];case OrbitAdapter.Starknet:return [y[OrbitAdapter.Starknet]];default:return [y[OrbitAdapter.EVM]]}}function ie(e,t){if(!e||typeof e!="object")return null;let n=e;if(!n.name||typeof n.name!="string")return null;let o;if("icon"in n){let s=n.icon;if(typeof s=="string")o=s;else if(s&&typeof s=="object"&&"toString"in s&&typeof s.toString=="function")try{o=s.toString();}catch{}}return {name:n.name,icon:o,adapter:t,originalConnector:n}}function H({connectors:e,excludeConnectors:t=["injected"]}={connectors:{}}){if(!e||Object.keys(e).length===0)return [];let n=new Set(t.map(a=>formatConnectorName(a))),o=[];Object.entries(e).forEach(([a,i])=>{if(Array.isArray(i)){let r=a;i.forEach(u=>{let c=ie(u,r);if(c){let d=formatConnectorName(c.name);n.has(d)||o.push(c);}});}});let s=new Map;return o.forEach(a=>{let i=formatConnectorName(a.name);s.has(i)||s.set(i,{name:a.name,icon:a.icon,adapters:[],connectors:[]});let r=s.get(i);r.adapters.includes(a.adapter)||r.adapters.push(a.adapter);let u=Object.assign({},a.originalConnector,{adapter:a.adapter});r.connectors.push(u),!r.icon&&a.icon&&(r.icon=a.icon);}),Array.from(s.values()).sort((a,i)=>a.name.localeCompare(i.name,void 0,{sensitivity:"base"}))}function Ue(e){return Object.values(e).some(t=>Array.isArray(t)&&t.length>0)}function le(e){try{if(e&&typeof e=="object"&&e.adapter)return e.adapter}catch{}}function z(e,t){return le(e)===t}function Je({connectors:e,selectedAdapter:t}){if(!e||Object.keys(e).length===0)return [];let n=H({connectors:e});return t?n.filter(o=>o.adapters.includes(t)&&o.connectors.some(s=>z(s,t))).map(o=>{let s=o.connectors.filter(a=>z(a,t));return {...o,adapters:[t],connectors:s}}).filter(o=>o.connectors.length>0):n}function Ze(e,t){let n=e[t];return Array.isArray(n)&&n.length>0}var Xe=e=>{switch(e){case OrbitAdapter.EVM:return {chainId:1,name:"Ethereum"};case OrbitAdapter.SOLANA:return {chainId:"solana:mainnet",name:"Solana"}}};var tt={[OrbitAdapter.EVM]:{aboutNetwork:"https://ethereum.org/developers/docs/intro-to-ethereum/",choseWallet:"https://ethereum.org/wallets/find-wallet/",about:"https://ethereum.org/wallets/"},[OrbitAdapter.SOLANA]:{aboutNetwork:"https://solana.com/en/learn/what-is-solana",choseWallet:"https://solana.com/en/solana-wallets",about:"https://solana.com/en/learn/what-is-a-wallet"}};function ft(){return console.warn("getAvailableSolanaClusters: Using synchronous fallback with limited functionality. Use getAvailableSolanaClustersAsync for complete cluster detection."),[]}function Ct(e){return console.warn("isValidSolanaCluster: Using synchronous fallback with basic validation. Use isValidSolanaClusterAsync for comprehensive cluster validation."),["mainnet","devnet","testnet","localnet"].includes(e)}function Et({activeConnection:e,appChains:t,solanaRPCUrls:n}){let[o,s]=useState([]),[a,i]=useState(false);return useEffect(()=>{let r=true;return (async()=>{i(true);try{if(!e){let b=await a$1({connectorType:`${OrbitAdapter.EVM}:not-connected`,appChains:t,solanaRPCUrls:n,chains:[]});r&&s(b);return}let c=i$1(e),d=await a$1({connectorType:e.connectorType,appChains:t,solanaRPCUrls:n,chains:c});r&&s(d);}catch(c){console.error("Failed to fetch chains list:",c),r&&s([]);}finally{r&&i(false);}})(),()=>{r=false;}},[e,t,n]),{chainsList:o,isLoading:a}}function Rt(){let[e,t]=useState({}),[n,o]=useState(false),s=useRef(null),a=i(p=>p.activeConnection),i$1=i(p=>p.getAdapter),r=useMemo(()=>a?.chainId&&a?.address?`${a.address}-${a.chainId}`:null,[a?.chainId,a?.address]),u=useMemo(()=>a?.connectorType?i$1(getAdapterFromConnectorType(a.connectorType)):null,[i$1,a?.connectorType]),c=useMemo(()=>u&&"getBalance"in u&&typeof u.getBalance=="function",[u]),d=useCallback(async(p=false)=>{if(!a?.address||!u||!a?.chainId||!r||!c){o(false);return}let g=`${r}-${Date.now()}`;if(s.current=g,!p&&e[r]){o(false);return}o(true);try{let m=await u.getBalance(a.address,a.chainId);s.current===g&&t(N=>({...N,[r]:m}));}catch(m){console.error(`Failed to fetch native balance for ${r}:`,m),p&&s.current===g&&t(N=>{let h={...N};return delete h[r],h});}finally{s.current===g&&o(false);}},[a?.address,u,a?.chainId,r,c,e]),b=useCallback(()=>{d(true);},[d]);return useEffect(()=>{r&&c&&!e[r]?d(false):(!r||!c)&&o(false);},[r,c,e,d]),useEffect(()=>()=>{s.current=null;},[]),{balance:useMemo(()=>r&&e[r]||null,[r,e]),isLoading:n,refetch:b}}
|
|
2
|
-
export{Et as A,Rt as B,he as a,R as b,V as c,Ae as d,Ne as e,xe as f,ce as g,D as h,ke as i,we as j,Ee as k,Be as l,Ie as m,Me as n,Pe as o,We as p,Ge as q,Fe as r,H as s,Ue as t,Je as u,Ze as v,Xe as w,tt as x,ft as y,Ct as z};//# sourceMappingURL=chunk-7EUQO34W.js.map
|
|
3
|
-
//# sourceMappingURL=chunk-7EUQO34W.js.map
|
package/dist/chunk-PUEGOPQT.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';var satelliteReact=require('@tuwaio/satellite-react');async function r(){try{let t=await new Function('return import("@tuwaio/satellite-react").catch(error => { console.warn("Failed to load Satellite exports:", error); return null; })')();return t?{...t,available:!0}:{available:!1,error:"Failed to load Satellite exports"}}catch(e){return console.warn("Failed to load Satellite exports:",e),{available:false,error:e instanceof Error?e.message:"Unknown error loading Satellite exports"}}}Object.defineProperty(exports,"b",{enumerable:true,get:function(){return satelliteReact.AllConnectors}});Object.defineProperty(exports,"c",{enumerable:true,get:function(){return satelliteReact.Connection}});Object.defineProperty(exports,"d",{enumerable:true,get:function(){return satelliteReact.Connector}});Object.defineProperty(exports,"e",{enumerable:true,get:function(){return satelliteReact.SatelliteConnectProvider}});Object.defineProperty(exports,"f",{enumerable:true,get:function(){return satelliteReact.SatelliteConnectProviderProps}});Object.defineProperty(exports,"g",{enumerable:true,get:function(){return satelliteReact.SatelliteStoreContext}});Object.defineProperty(exports,"h",{enumerable:true,get:function(){return satelliteReact.useInitializeAutoConnect}});Object.defineProperty(exports,"i",{enumerable:true,get:function(){return satelliteReact.useSatelliteConnectStore}});exports.a=r;//# sourceMappingURL=chunk-PUEGOPQT.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-PUEGOPQT.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/satellite/index.ts"],"names":["getSatelliteExports","satelliteReact","error"],"mappings":"mEAaA,eAAsBA,CAAAA,EAAsB,CAC1C,GAAI,CAOF,IAAMC,CAAAA,CAAiB,MAJO,IAAI,QAAA,CAChC,qIACF,GAEmD,CAEnD,OAAKA,CAAAA,CAOE,CACL,GAAGA,CAAAA,CACH,SAAA,CAAW,CAAA,CACb,CAAA,CATS,CACL,SAAA,CAAW,CAAA,CAAA,CACX,KAAA,CAAO,kCACT,CAOJ,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,IAAA,CAAK,mCAAA,CAAqCA,CAAK,CAAA,CAChD,CACL,SAAA,CAAW,KAAA,CACX,KAAA,CAAOA,CAAAA,YAAiB,KAAA,CAAQA,CAAAA,CAAM,OAAA,CAAU,yCAClD,CACF,CACF","file":"chunk-PUEGOPQT.cjs","sourcesContent":["// Export all types and components directly to satisfy static imports\nexport {\n AllConnectors,\n Connection,\n Connector,\n SatelliteConnectProvider,\n SatelliteConnectProviderProps,\n SatelliteStoreContext,\n useInitializeAutoConnect,\n useSatelliteConnectStore,\n} from '@tuwaio/satellite-react';\n\n// Dynamic exports that will be loaded at runtime\nexport async function getSatelliteExports() {\n try {\n // Use a more indirect approach to prevent bundlers from resolving imports at build time\n // This creates a function that will be called at runtime\n const importSatelliteModule = new Function(\n 'return import(\"@tuwaio/satellite-react\").catch(error => { console.warn(\"Failed to load Satellite exports:\", error); return null; })'\n );\n\n const satelliteReact = await importSatelliteModule();\n\n if (!satelliteReact) {\n return {\n available: false,\n error: 'Failed to load Satellite exports',\n };\n }\n\n return {\n ...satelliteReact,\n available: true,\n };\n } catch (error) {\n console.warn('Failed to load Satellite exports:', error);\n return {\n available: false,\n error: error instanceof Error ? error.message : 'Unknown error loading Satellite exports',\n };\n }\n}\n"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkEWPT6HNX_cjs=require('./chunk-EWPT6HNX.cjs');Object.defineProperty(exports,"getAdapterStatus",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.k}});Object.defineProperty(exports,"getAllAdaptersStatus",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.l}});Object.defineProperty(exports,"getAvailableSolanaClusters",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.g}});Object.defineProperty(exports,"getChainsListByConnectorType",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.a}});Object.defineProperty(exports,"getChainsListByConnectorTypeSync",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.b}});Object.defineProperty(exports,"getWalletChains",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.i}});Object.defineProperty(exports,"isEvmChainList",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.c}});Object.defineProperty(exports,"isEvmChainListSync",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.e}});Object.defineProperty(exports,"isSolanaChainList",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.d}});Object.defineProperty(exports,"isSolanaChainListSync",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.f}});Object.defineProperty(exports,"isValidSolanaCluster",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.h}});Object.defineProperty(exports,"preloadChainAdapters",{enumerable:true,get:function(){return chunkEWPT6HNX_cjs.j}});//# sourceMappingURL=getChainsListByConnectorType-RKKDUHIO.cjs.map
|
|
2
|
-
//# sourceMappingURL=getChainsListByConnectorType-RKKDUHIO.cjs.map
|