@tuwaio/nova-connect 0.1.0 → 0.1.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/README.md +21 -96
- package/dist/ToastError-CSlbvXKT.d.cts +106 -0
- package/dist/ToastError-CSlbvXKT.d.ts +106 -0
- package/dist/chunk-A2677K5M.cjs +2 -0
- package/dist/chunk-A2677K5M.cjs.map +1 -0
- package/dist/chunk-CEGEQMI2.cjs +2 -0
- package/dist/chunk-CEGEQMI2.cjs.map +1 -0
- package/dist/chunk-DYDY3FCT.cjs +2 -0
- package/dist/chunk-DYDY3FCT.cjs.map +1 -0
- package/dist/{chunk-KKCRUSJT.js → chunk-J4TY3CJF.js} +2 -2
- package/dist/{chunk-KKCRUSJT.js.map → chunk-J4TY3CJF.js.map} +1 -1
- package/dist/chunk-LF6FTUUQ.js +2 -0
- package/dist/chunk-LF6FTUUQ.js.map +1 -0
- package/dist/chunk-MPEJHQKC.js +2 -0
- package/dist/chunk-MPEJHQKC.js.map +1 -0
- package/dist/{chunk-NJDPFYUJ.js → chunk-MQGDTFY7.js} +2 -2
- package/dist/{chunk-NJDPFYUJ.js.map → chunk-MQGDTFY7.js.map} +1 -1
- package/dist/chunk-NMQZA377.cjs +2 -0
- package/dist/chunk-NMQZA377.cjs.map +1 -0
- package/dist/chunk-OA6MB7CZ.cjs +2 -0
- package/dist/chunk-OA6MB7CZ.cjs.map +1 -0
- package/dist/chunk-QERPNHKX.cjs +2 -0
- package/dist/chunk-QERPNHKX.cjs.map +1 -0
- package/dist/chunk-RUYOUU6Q.cjs +6 -0
- package/dist/chunk-RUYOUU6Q.cjs.map +1 -0
- package/dist/chunk-TAV7EL23.js +2 -0
- package/dist/chunk-TAV7EL23.js.map +1 -0
- package/dist/chunk-Z2NDRIEI.js +6 -0
- package/dist/chunk-Z2NDRIEI.js.map +1 -0
- package/dist/components/index.cjs +2 -0
- package/dist/components/index.cjs.map +1 -0
- package/dist/components/index.d.cts +6430 -0
- package/dist/components/index.d.ts +6430 -0
- package/dist/components/index.js +2 -0
- package/dist/components/index.js.map +1 -0
- package/dist/evm/index.cjs +1 -1
- package/dist/evm/index.cjs.map +1 -1
- package/dist/evm/index.d.cts +24 -0
- package/dist/evm/index.d.ts +24 -0
- package/dist/evm/index.js +1 -1
- package/dist/evm/index.js.map +1 -1
- package/dist/evm-7NHOTSAK.cjs +2 -0
- package/dist/evm-7NHOTSAK.cjs.map +1 -0
- package/dist/getChainsListByWalletType-CDPECVNS.cjs +2 -0
- package/dist/getChainsListByWalletType-CDPECVNS.cjs.map +1 -0
- package/dist/{getChainsListByWalletType-KXWMBNB4.js → getChainsListByWalletType-VMQ4BO2B.js} +2 -2
- package/dist/{getChainsListByWalletType-KXWMBNB4.js.map → getChainsListByWalletType-VMQ4BO2B.js.map} +1 -1
- package/dist/hooks/index.cjs +1 -1
- package/dist/hooks/index.cjs.map +1 -1
- package/dist/hooks/index.d.cts +70 -0
- package/dist/hooks/index.d.ts +70 -0
- package/dist/hooks/index.js +1 -1
- package/dist/hooks/index.js.map +1 -1
- package/dist/i18n/index.cjs +2 -0
- package/dist/i18n/index.cjs.map +1 -0
- package/dist/i18n/index.d.cts +15 -0
- package/dist/i18n/index.d.ts +15 -0
- package/dist/i18n/index.js +2 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/index.cjs +1 -5
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +791 -7818
- package/dist/index.d.ts +791 -7818
- package/dist/index.js +1 -5
- package/dist/index.js.map +1 -1
- package/dist/satellite/index.cjs +2 -0
- package/dist/satellite/index.cjs.map +1 -0
- package/dist/satellite/index.d.cts +1 -0
- package/dist/satellite/index.d.ts +1 -0
- package/dist/satellite/index.js +2 -0
- package/dist/satellite/index.js.map +1 -0
- package/dist/solana/index.cjs +1 -1
- package/dist/solana/index.cjs.map +1 -1
- package/dist/solana/index.d.cts +33 -0
- package/dist/solana/index.d.ts +33 -0
- package/dist/solana/index.js +1 -1
- package/dist/solana/index.js.map +1 -1
- package/dist/{providers/solana-WHT5KTOF.js → solana-GLHHYZDQ.js} +2 -2
- package/dist/{solana-2MXIY6UT.js.map → solana-GLHHYZDQ.js.map} +1 -1
- package/dist/solana-JUU54KQ3.cjs +2 -0
- package/dist/solana-JUU54KQ3.cjs.map +1 -0
- package/dist/types-D4Vti05g.d.cts +98 -0
- package/dist/types-D4Vti05g.d.ts +98 -0
- package/dist/types-DGsiEwne.d.cts +50 -0
- package/dist/types-DGsiEwne.d.ts +50 -0
- package/dist/useWalletNativeBalance-6RVzdGvM.d.ts +312 -0
- package/dist/useWalletNativeBalance-D8Ehciju.d.cts +312 -0
- package/dist/utils-DZB4ZTS4.cjs +2 -0
- package/dist/utils-DZB4ZTS4.cjs.map +1 -0
- package/dist/utils-H5O25MTI.cjs +2 -0
- package/dist/utils-H5O25MTI.cjs.map +1 -0
- package/dist/utils-SUIRQJIA.js +2 -0
- package/dist/{utils-72MDY3OH.js.map → utils-SUIRQJIA.js.map} +1 -1
- package/package.json +20 -12
- package/dist/evm-F7OJEDX3.js +0 -2
- package/dist/evm-F7OJEDX3.js.map +0 -1
- package/dist/providers/evm-5323YCLC.js +0 -2
- package/dist/providers/evm-5323YCLC.js.map +0 -1
- package/dist/providers/index.cjs +0 -6
- package/dist/providers/index.cjs.map +0 -1
- package/dist/providers/index.d.cts +0 -506
- package/dist/providers/index.d.ts +0 -506
- package/dist/providers/index.js +0 -6
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/solana-WHT5KTOF.js.map +0 -1
- package/dist/providers/utils-FHHKXQ5Z.js +0 -2
- package/dist/providers/utils-FHHKXQ5Z.js.map +0 -1
- package/dist/providers/utils-L6CFHW4B.js +0 -2
- package/dist/providers/utils-L6CFHW4B.js.map +0 -1
- package/dist/solana-2MXIY6UT.js +0 -2
- package/dist/solana-EV65GS7Q.js +0 -2
- package/dist/solana-EV65GS7Q.js.map +0 -1
- package/dist/utils-72MDY3OH.js +0 -2
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export{y as AboutWallets,a as ChainListRenderer,p as ChainSelector,M as ConnectButton,B as ConnectCard,K as ConnectedContent,x as ConnectedModal,q as ConnectedModalFooter,v as ConnectedModalMainContent,s as ConnectedModalNameAndBalance,w as ConnectedModalTxHistory,z as Connecting,C as ConnectorsBlock,E as ConnectorsSelections,D as Disclaimer,F as GetWallet,u as IconButton,G as ImpersonateForm,H as NetworkSelections,I as NetworkTabs,A as RecentBadge,o as ScrollableChainList,n as SelectContentAnimated,J as StatusIcon,l as ToBottomButton,m as ToTopButton,N as ToastError,L as WaitForConnectionContent,r as WalletAvatar,t as WalletIcon}from'../chunk-Z2NDRIEI.js';import'../chunk-MQGDTFY7.js';import'../chunk-LF6FTUUQ.js';import'../chunk-TAV7EL23.js';import'../chunk-MPEJHQKC.js';//# sourceMappingURL=index.js.map
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
|
package/dist/evm/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';
|
|
1
|
+
'use strict';var chunkCEGEQMI2_cjs=require('../chunk-CEGEQMI2.cjs'),evm=require('@tuwaio/satellite-react/evm');Object.defineProperty(exports,"getEvmChains",{enumerable:true,get:function(){return chunkCEGEQMI2_cjs.a}});Object.defineProperty(exports,"isEvmChainList",{enumerable:true,get:function(){return chunkCEGEQMI2_cjs.b}});Object.keys(evm).forEach(function(k){if(k!=='default'&&!Object.prototype.hasOwnProperty.call(exports,k))Object.defineProperty(exports,k,{enumerable:true,get:function(){return evm[k]}})});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/evm/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":[
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.cjs","sourcesContent":[]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Chain } from 'viem/chains';
|
|
2
|
+
export { Chain } from 'viem/chains';
|
|
3
|
+
export * from '@tuwaio/satellite-react/evm';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Get EVM chain IDs from app chains configuration
|
|
7
|
+
*/
|
|
8
|
+
declare function getEvmChains(appChains?: readonly [Chain, ...Chain[]]): number[];
|
|
9
|
+
/**
|
|
10
|
+
* Type guard to check if a chain list contains EVM chain IDs
|
|
11
|
+
*/
|
|
12
|
+
declare function isEvmChainList(chains: (string | number)[]): chains is number[];
|
|
13
|
+
|
|
14
|
+
declare module '@tuwaio/nova-connect' {
|
|
15
|
+
interface AllChainConfigs {
|
|
16
|
+
/**
|
|
17
|
+
* EVM chains configuration - enhanced from default any type
|
|
18
|
+
* @override Replaces default `any` with specific Chain typing when viem is available
|
|
19
|
+
*/
|
|
20
|
+
appChains?: readonly [Chain, ...Chain[]];
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export { getEvmChains, isEvmChainList };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Chain } from 'viem/chains';
|
|
2
|
+
export { Chain } from 'viem/chains';
|
|
3
|
+
export * from '@tuwaio/satellite-react/evm';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Get EVM chain IDs from app chains configuration
|
|
7
|
+
*/
|
|
8
|
+
declare function getEvmChains(appChains?: readonly [Chain, ...Chain[]]): number[];
|
|
9
|
+
/**
|
|
10
|
+
* Type guard to check if a chain list contains EVM chain IDs
|
|
11
|
+
*/
|
|
12
|
+
declare function isEvmChainList(chains: (string | number)[]): chains is number[];
|
|
13
|
+
|
|
14
|
+
declare module '@tuwaio/nova-connect' {
|
|
15
|
+
interface AllChainConfigs {
|
|
16
|
+
/**
|
|
17
|
+
* EVM chains configuration - enhanced from default any type
|
|
18
|
+
* @override Replaces default `any` with specific Chain typing when viem is available
|
|
19
|
+
*/
|
|
20
|
+
appChains?: readonly [Chain, ...Chain[]];
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export { getEvmChains, isEvmChainList };
|
package/dist/evm/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export{a as getEvmChains,b as isEvmChainList}from'../chunk-RR5G7U5F.js';export*from'@tuwaio/satellite-react/evm';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/evm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":[
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.js","sourcesContent":[]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';async function n(){try{return await import('./utils-DZB4ZTS4.cjs')}catch(r){return console.warn("EVM utilities not available:",r),null}}async function i(){let r=await n();return {getChains(e){return r?.getEvmChains?r.getEvmChains(e):!Array.isArray(e)||e.length===0?[]:e.map(t=>typeof t=="object"&&t?.id!==void 0?t.id:typeof t=="number"||typeof t=="string"?t:null).filter(t=>t!==null&&(typeof t=="string"||typeof t=="number"))},isChainList(e){return r?.isEvmChainList?r.isEvmChainList(e):e.length>0&&e.every(t=>typeof t=="number")}}}async function s(){try{return await import('./utils-DZB4ZTS4.cjs'),!0}catch{return false}}exports.createEvmAdapter=i;exports.isEvmAdapterAvailable=s;//# sourceMappingURL=evm-7NHOTSAK.cjs.map
|
|
2
|
+
//# sourceMappingURL=evm-7NHOTSAK.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/utils/adapters/evm.ts"],"names":["getEvmUtils","error","createEvmAdapter","evmUtils","appChains","chain","id","chains","isEvmAdapterAvailable"],"mappings":"aA+BA,eAAeA,CAAAA,EAA8C,CAC3D,GAAI,CAGF,OADiB,MAAM,OAAO,sBAAiB,CAEjD,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,OAAA,CAAQ,KAAK,8BAAA,CAAgCA,CAAK,CAAA,CAC3C,IACT,CACF,CA6BA,eAAsBC,CAAAA,EAA0C,CAC9D,IAAMC,CAAAA,CAAW,MAAMH,CAAAA,EAAY,CAEnC,OAAO,CAOL,SAAA,CAAUI,CAAAA,CAAqC,CAE7C,OAAID,CAAAA,EAAU,YAAA,CACLA,CAAAA,CAAS,YAAA,CAAaC,CAAS,CAAA,CAIpC,CAAC,KAAA,CAAM,OAAA,CAAQA,CAAS,CAAA,EAAKA,CAAAA,CAAU,MAAA,GAAW,CAAA,CAC7C,EAAC,CAGHA,CAAAA,CACJ,GAAA,CAAKC,CAAAA,EAEA,OAAOA,CAAAA,EAAU,QAAA,EAAYA,CAAAA,EAAO,EAAA,GAAO,MAAA,CACtCA,EAAM,EAAA,CAGX,OAAOA,CAAAA,EAAU,QAAA,EAAY,OAAOA,CAAAA,EAAU,QAAA,CACzCA,CAAAA,CAEF,IACR,CAAA,CACA,MAAA,CAAQC,CAAAA,EAAmCA,CAAAA,GAAO,IAAA,GAAS,OAAOA,CAAAA,EAAO,QAAA,EAAY,OAAOA,CAAAA,EAAO,QAAA,CAAS,CACjH,CAAA,CASA,WAAA,CAAYC,CAAAA,CAAsC,CAChD,OAAIJ,CAAAA,EAAU,cAAA,CACLA,CAAAA,CAAS,cAAA,CAAeI,CAAM,CAAA,CAIhCA,CAAAA,CAAO,MAAA,CAAS,CAAA,EAAKA,CAAAA,CAAO,KAAA,CAAOF,CAAAA,EAAU,OAAOA,CAAAA,EAAU,QAAQ,CAC/E,CACF,CACF,CAsBA,eAAsBG,CAAAA,EAA0C,CAC9D,GAAI,CACF,OAAA,MAAM,OAAO,sBAAiB,CAAA,CACvB,CAAA,CACT,CAAA,KAAQ,CACN,OAAO,MACT,CACF","file":"evm-7NHOTSAK.cjs","sourcesContent":["import type { ChainAdapter } from './types';\n\n/**\n * EVM utilities module interface for dynamic imports.\n *\n * @internal\n * @since 1.0.0\n */\ninterface EvmUtilsModule {\n getEvmChains?: (appChains: any) => (string | number)[];\n isEvmChainList?: (chains: (string | number)[]) => boolean;\n}\n\n/**\n * Dynamically imports and checks availability of EVM utilities.\n * This function attempts to load EVM-specific utilities without throwing errors\n * if the EVM package is not installed in the current environment.\n *\n * @internal\n * @returns Promise resolving to EVM utilities module or null if not available\n *\n * @example\n * ```typescript\n * const evmUtils = await getEvmUtils();\n * if (evmUtils?.getEvmChains) {\n * const chains = evmUtils.getEvmChains(appChains);\n * }\n * ```\n *\n * @since 1.0.0\n */\nasync function getEvmUtils(): Promise<EvmUtilsModule | null> {\n try {\n // Dynamic import of EVM utilities - fails gracefully if package not installed\n const evmUtils = await import('../../evm/utils');\n return evmUtils;\n } catch (error) {\n console.warn('EVM utilities not available:', error);\n return null;\n }\n}\n\n/**\n * Creates an EVM chain adapter with dynamic loading and fallback support.\n *\n * This adapter provides EVM-specific functionality while gracefully handling\n * environments where EVM utilities are not available. It uses intelligent\n * fallbacks to ensure basic functionality even without the full EVM package.\n *\n * @returns Promise resolving to a configured EVM ChainAdapter\n *\n * @example\n * ```typescript\n * const adapter = await createEvmAdapter();\n *\n * // Get EVM chain IDs from app configuration\n * const chainIds = adapter.getChains([\n * { id: 1, name: 'Ethereum' },\n * { id: 137, name: 'Polygon' }\n * ]);\n * console.log(chainIds); // [1, 137]\n *\n * // Validate chain list format\n * const isValid = adapter.isChainList([1, 137, 56]);\n * console.log(isValid); // true (numeric IDs are valid for EVM)\n * ```\n *\n * @since 1.0.0\n */\nexport async function createEvmAdapter(): Promise<ChainAdapter> {\n const evmUtils = await getEvmUtils();\n\n return {\n /**\n * Extracts chain IDs from EVM app chain configuration.\n *\n * @param appChains Array of chain configurations or chain identifiers\n * @returns Array of chain IDs (numbers or strings)\n */\n getChains(appChains: any): (string | number)[] {\n // Use imported EVM utilities if available\n if (evmUtils?.getEvmChains) {\n return evmUtils.getEvmChains(appChains);\n }\n\n // Fallback implementation for basic chain extraction\n if (!Array.isArray(appChains) || appChains.length === 0) {\n return [];\n }\n\n return appChains\n .map((chain: any) => {\n // Handle chain objects with id property\n if (typeof chain === 'object' && chain?.id !== undefined) {\n return chain.id;\n }\n // Handle direct chain identifiers\n if (typeof chain === 'number' || typeof chain === 'string') {\n return chain;\n }\n return null;\n })\n .filter((id: any): id is string | number => id !== null && (typeof id === 'string' || typeof id === 'number'));\n },\n\n /**\n * Validates whether the provided chains list conforms to EVM chain format.\n * EVM chains are typically identified by numeric IDs.\n *\n * @param chains Array of chain identifiers to validate\n * @returns True if the chain list is valid for EVM\n */\n isChainList(chains: (string | number)[]): boolean {\n if (evmUtils?.isEvmChainList) {\n return evmUtils.isEvmChainList(chains);\n }\n\n // Fallback validation: EVM chains should be numbers\n return chains.length > 0 && chains.every((chain) => typeof chain === 'number');\n },\n };\n}\n\n/**\n * Checks if the EVM adapter can be created in the current environment.\n * This function verifies that the required EVM utilities are available\n * by attempting to import them.\n *\n * @returns Promise resolving to true if EVM adapter is available\n *\n * @example\n * ```typescript\n * const hasEvm = await isEvmAdapterAvailable();\n * if (hasEvm) {\n * const adapter = await createEvmAdapter();\n * // Use EVM functionality\n * } else {\n * console.log('EVM support not available in this build');\n * }\n * ```\n *\n * @since 1.0.0\n */\nexport async function isEvmAdapterAvailable(): Promise<boolean> {\n try {\n await import('../../evm/utils');\n return true;\n } catch {\n return false;\n }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkNMQZA377_cjs=require('./chunk-NMQZA377.cjs');Object.defineProperty(exports,"getAdapterStatus",{enumerable:true,get:function(){return chunkNMQZA377_cjs.k}});Object.defineProperty(exports,"getAllAdaptersStatus",{enumerable:true,get:function(){return chunkNMQZA377_cjs.l}});Object.defineProperty(exports,"getAvailableSolanaClusters",{enumerable:true,get:function(){return chunkNMQZA377_cjs.g}});Object.defineProperty(exports,"getChainsListByWalletType",{enumerable:true,get:function(){return chunkNMQZA377_cjs.a}});Object.defineProperty(exports,"getChainsListByWalletTypeSync",{enumerable:true,get:function(){return chunkNMQZA377_cjs.b}});Object.defineProperty(exports,"getWalletChains",{enumerable:true,get:function(){return chunkNMQZA377_cjs.i}});Object.defineProperty(exports,"isEvmChainList",{enumerable:true,get:function(){return chunkNMQZA377_cjs.c}});Object.defineProperty(exports,"isEvmChainListSync",{enumerable:true,get:function(){return chunkNMQZA377_cjs.e}});Object.defineProperty(exports,"isSolanaChainList",{enumerable:true,get:function(){return chunkNMQZA377_cjs.d}});Object.defineProperty(exports,"isSolanaChainListSync",{enumerable:true,get:function(){return chunkNMQZA377_cjs.f}});Object.defineProperty(exports,"isValidSolanaCluster",{enumerable:true,get:function(){return chunkNMQZA377_cjs.h}});Object.defineProperty(exports,"preloadChainAdapters",{enumerable:true,get:function(){return chunkNMQZA377_cjs.j}});//# sourceMappingURL=getChainsListByWalletType-CDPECVNS.cjs.map
|
|
2
|
+
//# sourceMappingURL=getChainsListByWalletType-CDPECVNS.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"getChainsListByWalletType-CDPECVNS.cjs"}
|
package/dist/{getChainsListByWalletType-KXWMBNB4.js → getChainsListByWalletType-VMQ4BO2B.js}
RENAMED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{k as getAdapterStatus,l as getAllAdaptersStatus,g as getAvailableSolanaClusters,a as getChainsListByWalletType,b as getChainsListByWalletTypeSync,i as getWalletChains,c as isEvmChainList,e as isEvmChainListSync,d as isSolanaChainList,f as isSolanaChainListSync,h as isValidSolanaCluster,j as preloadChainAdapters}from'./chunk-
|
|
2
|
-
//# sourceMappingURL=getChainsListByWalletType-
|
|
1
|
+
export{k as getAdapterStatus,l as getAllAdaptersStatus,g as getAvailableSolanaClusters,a as getChainsListByWalletType,b as getChainsListByWalletTypeSync,i as getWalletChains,c as isEvmChainList,e as isEvmChainListSync,d as isSolanaChainList,f as isSolanaChainListSync,h as isValidSolanaCluster,j as preloadChainAdapters}from'./chunk-MQGDTFY7.js';//# sourceMappingURL=getChainsListByWalletType-VMQ4BO2B.js.map
|
|
2
|
+
//# sourceMappingURL=getChainsListByWalletType-VMQ4BO2B.js.map
|
package/dist/{getChainsListByWalletType-KXWMBNB4.js.map → getChainsListByWalletType-VMQ4BO2B.js.map}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":[],"names":[],"mappings":"","file":"getChainsListByWalletType-
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"getChainsListByWalletType-VMQ4BO2B.js"}
|
package/dist/hooks/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkA2677K5M_cjs=require('../chunk-A2677K5M.cjs');require('../chunk-QERPNHKX.cjs'),require('../chunk-OA6MB7CZ.cjs');Object.defineProperty(exports,"NovaConnectLabelsContext",{enumerable:true,get:function(){return chunkA2677K5M_cjs.g}});Object.defineProperty(exports,"NovaConnectProviderContext",{enumerable:true,get:function(){return chunkA2677K5M_cjs.c}});Object.defineProperty(exports,"NovaConnectProviderError",{enumerable:true,get:function(){return chunkA2677K5M_cjs.b}});Object.defineProperty(exports,"createLabelsSubset",{enumerable:true,get:function(){return chunkA2677K5M_cjs.o}});Object.defineProperty(exports,"getLabelWithFallback",{enumerable:true,get:function(){return chunkA2677K5M_cjs.n}});Object.defineProperty(exports,"hasLabel",{enumerable:true,get:function(){return chunkA2677K5M_cjs.k}});Object.defineProperty(exports,"isDefaultLabels",{enumerable:true,get:function(){return chunkA2677K5M_cjs.m}});Object.defineProperty(exports,"useGetWalletNameAndAvatar",{enumerable:true,get:function(){return chunkA2677K5M_cjs.a}});Object.defineProperty(exports,"useHasNovaConnectContext",{enumerable:true,get:function(){return chunkA2677K5M_cjs.e}});Object.defineProperty(exports,"useLabelsByCategory",{enumerable:true,get:function(){return chunkA2677K5M_cjs.l}});Object.defineProperty(exports,"useNovaConnect",{enumerable:true,get:function(){return chunkA2677K5M_cjs.d}});Object.defineProperty(exports,"useNovaConnectLabel",{enumerable:true,get:function(){return chunkA2677K5M_cjs.i}});Object.defineProperty(exports,"useNovaConnectLabels",{enumerable:true,get:function(){return chunkA2677K5M_cjs.h}});Object.defineProperty(exports,"useNovaConnectLabelsSubset",{enumerable:true,get:function(){return chunkA2677K5M_cjs.j}});Object.defineProperty(exports,"useNovaConnectOptional",{enumerable:true,get:function(){return chunkA2677K5M_cjs.f}});Object.defineProperty(exports,"useWalletNativeBalance",{enumerable:true,get:function(){return chunkA2677K5M_cjs.p}});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/hooks/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/hooks/useGetWalletNameAndAvatar.ts","../../src/hooks/useWalletNativeBalance.ts"],"names":["useGetWalletNameAndAvatar","options","abbreviateSymbols","maxNameLength","autoRetry","retryDelay","store","getAdapter","walletAddress","useMemo","walletType","foundAdapter","getAdapterFromWalletType","OrbitAdapter","ensName","setEnsName","useState","ensAvatar","setEnsAvatar","isLoading","setIsLoading","error","setError","abortControllerRef","useRef","retryTimeoutRef","adapterCapabilities","hasNameResolver","hasAvatarResolver","cleanup","useCallback","fetchNameData","signal","name","avatar","avatarError","errorMessage","retry","useEffect","ensNameAbbreviated","textCenterEllipsis","useWalletNativeBalance","activeWallet","balanceCache","setBalanceCache","fetchOperationRef","cacheKey","hasBalanceResolver","fetchBalance","forceRefresh","operationId","balanceResult","prevCache","newCache","refetch"],"mappings":"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","file":"index.cjs","sourcesContent":["import { textCenterEllipsis } from '@tuwaio/nova-core';\nimport { getAdapterFromWalletType, OrbitAdapter } from '@tuwaio/orbit-core';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { NovaConnectProviderProps, NovaConnectProviderType } from './useNovaConnect';\n\nexport interface WalletNameAndAvatarData {\n /** The resolved name from the Name Service (e.g., ENS, like \"alice.eth\"), or null if not found. */\n ensName: string | null;\n /** The URL of the avatar associated with the name, or null if not found. */\n ensAvatar: string | null;\n /** True while the name service data is being fetched. */\n isLoading: boolean;\n /** A truncated version of the name for display, or the abbreviated address if no name. */\n ensNameAbbreviated: string | undefined;\n /** Error message if the name resolution failed. */\n error: string | null;\n /** Function to retry the name resolution manually. */\n retry: () => void;\n}\n\ninterface UseGetWalletNameAndAvatarOptions\n extends Pick<NovaConnectProviderProps, 'store'>,\n Pick<NovaConnectProviderType, 'activeWallet'> {\n /** Number of characters to show on each side when abbreviating (default: 12) */\n abbreviateSymbols?: number;\n /** Maximum length before abbreviation is applied (default: 30) */\n maxNameLength?: number;\n /** Whether to automatically retry on failure (default: false) */\n autoRetry?: boolean;\n /** Retry delay in milliseconds (default: 3000) */\n retryDelay?: number;\n}\n\n/**\n * A custom hook to fetch the Name Service (e.g., ENS) name and avatar\n * for the currently active wallet.\n *\n * This hook automatically detects the active wallet and its corresponding\n * adapter via the `useSatelliteConnectStore` and attempts to resolve the\n * wallet address to a human-readable name and avatar.\n *\n * @param options Configuration options for the hook\n * @returns An object containing the resolved name, avatar, loading state, and utility functions\n *\n * @example\n * ```typescript\n * import { useGetWalletNameAndAvatar } from './useGetWalletNameAndAvatar';\n *\n * function DisplayWalletInfo() {\n * const { ensName, ensAvatar, isLoading, ensNameAbbreviated, error, retry } = useGetWalletNameAndAvatar({\n * abbreviateSymbols: 8,\n * maxNameLength: 25\n * });\n *\n * if (isLoading) {\n * return <div>Resolving name...</div>;\n * }\n *\n * if (error) {\n * return <div>Error: {error} <button onClick={retry}>Retry</button></div>;\n * }\n *\n * return (\n * <div className=\"wallet-info\">\n * {ensAvatar && <img src={ensAvatar} alt=\"Wallet Avatar\" />}\n * <p title={ensName || ''}>{ensNameAbbreviated || 'No Name Found'}</p>\n * </div>\n * );\n * }\n * ```\n */\nexport function useGetWalletNameAndAvatar(options: UseGetWalletNameAndAvatarOptions): WalletNameAndAvatarData {\n const { abbreviateSymbols = 12, maxNameLength = 30, autoRetry = false, retryDelay = 3000, store } = options;\n\n // Store state selectors - memoized for performance\n const getAdapter = store.getState().getAdapter;\n\n // Memoize wallet address and adapter for dependency tracking\n const walletAddress = useMemo(() => options.activeWallet?.address, [options.activeWallet?.address]);\n const walletType = useMemo(() => options.activeWallet?.walletType, [options.activeWallet?.walletType]);\n\n const foundAdapter = useMemo(() => {\n if (!walletType) return null;\n return getAdapter(getAdapterFromWalletType(walletType ?? `${OrbitAdapter.EVM}:not-connected`));\n }, [getAdapter, walletType]);\n\n // State variables\n const [ensName, setEnsName] = useState<string | null>(null);\n const [ensAvatar, setEnsAvatar] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n // Refs for cleanup and retry functionality\n const abortControllerRef = useRef<AbortController | null>(null);\n const retryTimeoutRef = useRef<number | null>(null);\n\n // Memoize adapter capabilities\n const adapterCapabilities = useMemo(() => {\n if (!foundAdapter) {\n return { hasNameResolver: false, hasAvatarResolver: false };\n }\n\n const hasNameResolver = 'getName' in foundAdapter && typeof foundAdapter.getName === 'function';\n const hasAvatarResolver = 'getAvatar' in foundAdapter && typeof foundAdapter.getAvatar === 'function';\n\n return { hasNameResolver, hasAvatarResolver };\n }, [foundAdapter]);\n\n // Cleanup function\n const cleanup = useCallback(() => {\n if (abortControllerRef.current) {\n abortControllerRef.current.abort();\n abortControllerRef.current = null;\n }\n if (retryTimeoutRef.current !== null) {\n clearTimeout(retryTimeoutRef.current);\n retryTimeoutRef.current = null;\n }\n }, []);\n\n // Main fetch function\n const fetchNameData = useCallback(async () => {\n cleanup();\n\n // Exit conditions\n if (!walletAddress || !foundAdapter || !adapterCapabilities.hasNameResolver) {\n setEnsName(null);\n setEnsAvatar(null);\n setIsLoading(false);\n setError(null);\n return;\n }\n\n // Create new abort controller for this request\n abortControllerRef.current = new AbortController();\n const { signal } = abortControllerRef.current;\n\n // Start loading\n setIsLoading(true);\n setError(null);\n setEnsName(null);\n setEnsAvatar(null);\n\n try {\n // Check if request was aborted\n if (signal.aborted) return;\n\n // Attempt to resolve the name\n const name = await foundAdapter.getName?.(walletAddress);\n\n if (signal.aborted) return;\n\n if (name) {\n setEnsName(name);\n\n // If avatar resolution is supported, fetch the avatar\n if (adapterCapabilities.hasAvatarResolver) {\n try {\n const avatar = await foundAdapter.getAvatar?.(name);\n if (!signal.aborted) {\n // Handle undefined case by converting to null\n setEnsAvatar(avatar ?? null);\n }\n } catch (avatarError) {\n // Avatar fetch failed, but name succeeded - not critical\n console.warn('Failed to fetch avatar:', avatarError);\n if (!signal.aborted) {\n setEnsAvatar(null);\n }\n }\n }\n }\n } catch (error) {\n if (signal.aborted) return;\n\n const errorMessage = error instanceof Error ? error.message : 'Failed to fetch name service data';\n console.error('Failed to fetch name service data:', error);\n\n setError(errorMessage);\n setEnsName(null);\n setEnsAvatar(null);\n\n // Auto retry if enabled\n if (autoRetry) {\n retryTimeoutRef.current = setTimeout(() => {\n fetchNameData();\n }, retryDelay) as unknown as number;\n }\n } finally {\n if (!signal.aborted) {\n setIsLoading(false);\n }\n }\n }, [walletAddress, foundAdapter, adapterCapabilities, autoRetry, retryDelay, cleanup]);\n\n // Manual retry function\n const retry = useCallback(() => {\n setError(null);\n fetchNameData();\n }, [fetchNameData]);\n\n // Effect to fetch data when dependencies change\n useEffect(() => {\n fetchNameData();\n return cleanup;\n }, [fetchNameData, cleanup]);\n\n // Cleanup on unmount\n useEffect(() => {\n return cleanup;\n }, [cleanup]);\n\n // Memoized abbreviated name computation\n const ensNameAbbreviated = useMemo(() => {\n if (ensName) {\n return ensName.length > maxNameLength\n ? textCenterEllipsis(ensName, abbreviateSymbols, abbreviateSymbols)\n : ensName;\n }\n\n return walletAddress ? textCenterEllipsis(walletAddress, abbreviateSymbols, abbreviateSymbols) : undefined;\n }, [ensName, walletAddress, maxNameLength, abbreviateSymbols]);\n\n return {\n ensName,\n ensAvatar,\n isLoading,\n ensNameAbbreviated,\n error,\n retry,\n };\n}\n","import { getAdapterFromWalletType } from '@tuwaio/orbit-core';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { NovaConnectProviderProps, NovaConnectProviderType } from './useNovaConnect';\n\n/**\n * @interface NativeBalanceResult\n * Represents the native token balance returned by the adapter.\n * The value is already formatted for human readability.\n * @property {string} value The native token balance formatted to standard decimals (e.g., \"1.5\").\n * @property {string} symbol The symbol of the native token (e.g., \"ETH\").\n */\nexport interface NativeBalanceResult {\n value: string;\n symbol: string;\n}\n\n// Type for the balance state within the hook (the fetched data or null).\ntype NativeBalanceState = NativeBalanceResult | null;\n\n// Type for the local cache: \"walletAddress-chainId\" -> { value, symbol }.\ntype BalanceCache = Record<string, NativeBalanceResult>;\n\n/**\n * @interface NativeBalanceData\n * The object returned by the useWalletNativeBalance hook.\n * @property {NativeBalanceState} balance The native token balance and symbol, or null.\n * @property {boolean} isLoading True while the balance is being fetched for the current wallet/chain combination.\n * @property {() => void} refetch Function to manually trigger a balance refresh.\n */\ninterface NativeBalanceData {\n balance: NativeBalanceState;\n isLoading: boolean;\n refetch: () => void;\n}\n\n/**\n * Custom hook to fetch the native token balance for the currently connected wallet\n * on the active chain. It includes a local cache layer to prevent redundant network calls\n * when switching between components or on re-renders for the same wallet/chain.\n *\n * @returns {NativeBalanceData} An object containing the balance data and loading state.\n *\n * @example\n * ```typescript\n * import { useWalletNativeBalance } from './useWalletNativeBalance';\n *\n * function NativeTokenDisplay() {\n * const { balance, isLoading, refetch } = useWalletNativeBalance();\n *\n * if (isLoading) {\n * return <p>Loading balance...</p>;\n * }\n *\n * // Display the formatted balance and symbol\n * return (\n * <div>\n * <p>Balance: {balance ? `${balance.value} ${balance.symbol}` : '0.00'}</p>\n * <button onClick={refetch}>Refresh</button>\n * </div>\n * );\n * }\n * ```\n */\nexport function useWalletNativeBalance({\n store,\n activeWallet,\n}: Pick<NovaConnectProviderProps, 'store'> & Pick<NovaConnectProviderType, 'activeWallet'>): NativeBalanceData {\n // --- 1. STATE & CACHE SETUP ---\n\n // Local cache storage. Keys combine wallet address and chain ID.\n const [balanceCache, setBalanceCache] = useState<BalanceCache>({});\n\n // Local loading state, managed alongside the cache check.\n const [isLoading, setIsLoading] = useState<boolean>(false);\n\n // Track the current fetch operation to prevent race conditions\n const fetchOperationRef = useRef<string | null>(null);\n\n // Store state selectors - memoized for performance\n const getAdapter = store.getState().getAdapter;\n\n // --- 2. COMPUTED INPUTS ---\n\n // Create the unique key for cache lookups: \"address-chainId\".\n const cacheKey = useMemo(() => {\n return activeWallet?.chainId && activeWallet?.address ? `${activeWallet.address}-${activeWallet.chainId}` : null;\n }, [activeWallet?.chainId, activeWallet?.address]);\n\n // Find the actual adapter object from the adapter map.\n const foundAdapter = useMemo(() => {\n if (!activeWallet?.walletType) return null;\n return getAdapter(getAdapterFromWalletType(activeWallet.walletType));\n }, [getAdapter, activeWallet?.walletType]);\n\n // Check if the adapter has balance functionality\n const hasBalanceResolver = useMemo(() => {\n return foundAdapter && 'getBalance' in foundAdapter && typeof foundAdapter.getBalance === 'function';\n }, [foundAdapter]);\n\n // --- 3. BALANCE FETCHING LOGIC ---\n\n const fetchBalance = useCallback(\n async (forceRefresh = false) => {\n // Exit early if essential data is missing (not connected).\n if (!activeWallet?.address || !foundAdapter || !activeWallet?.chainId || !cacheKey || !hasBalanceResolver) {\n setIsLoading(false);\n return;\n }\n\n // Set the current operation ID to prevent race conditions\n const operationId = `${cacheKey}-${Date.now()}`;\n fetchOperationRef.current = operationId;\n\n // Check cache unless forcing a refresh\n if (!forceRefresh) {\n const cachedBalance = balanceCache[cacheKey];\n if (cachedBalance) {\n setIsLoading(false);\n return;\n }\n }\n\n setIsLoading(true);\n\n try {\n // Call the adapter's getBalance method\n const balanceResult: NativeBalanceResult = await foundAdapter.getBalance(\n activeWallet.address,\n activeWallet.chainId,\n );\n\n // Only update if this operation is still the latest one\n if (fetchOperationRef.current === operationId) {\n setBalanceCache((prevCache) => ({\n ...prevCache,\n [cacheKey]: balanceResult,\n }));\n }\n } catch (error) {\n console.error(`Failed to fetch native balance for ${cacheKey}:`, error);\n\n // Optionally clear cache entry on error (if you want to retry on next call)\n if (forceRefresh && fetchOperationRef.current === operationId) {\n setBalanceCache((prevCache) => {\n const newCache = { ...prevCache };\n delete newCache[cacheKey];\n return newCache;\n });\n }\n } finally {\n // Only update loading state if this operation is still current\n if (fetchOperationRef.current === operationId) {\n setIsLoading(false);\n }\n }\n },\n [activeWallet?.address, foundAdapter, activeWallet?.chainId, cacheKey, hasBalanceResolver, balanceCache],\n );\n\n // Memoized refetch function that forces a refresh\n const refetch = useCallback(() => {\n fetchBalance(true);\n }, [fetchBalance]);\n\n // --- 4. EFFECT FOR INITIAL FETCH ---\n\n useEffect(() => {\n // Only fetch if we have all required data and no cached result\n if (cacheKey && hasBalanceResolver && !balanceCache[cacheKey]) {\n fetchBalance(false);\n } else if (!cacheKey || !hasBalanceResolver) {\n // Reset loading state if we can't fetch\n setIsLoading(false);\n }\n }, [cacheKey, hasBalanceResolver, balanceCache, fetchBalance]);\n\n // --- 5. CLEANUP EFFECT ---\n\n useEffect(() => {\n return () => {\n // Cancel any ongoing operations when component unmounts\n fetchOperationRef.current = null;\n };\n }, []);\n\n // --- 6. RETURNED DATA ---\n\n // The definitive balance is always derived from the cache based on the current key.\n const balance: NativeBalanceState = useMemo(() => {\n return cacheKey ? balanceCache[cacheKey] || null : null;\n }, [cacheKey, balanceCache]);\n\n // Return the fetched balance data and the loading status.\n return {\n balance, // { value: \"1.5\", symbol: \"ETH\" } or null\n isLoading,\n refetch,\n };\n}\n"]}
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.cjs"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export { B as ButtonTxStatus, C as ConnectContentType, a as ConnectedContentType, L as LabelCategory, p as NativeBalanceResult, g as NovaConnectLabelsContext, d as NovaConnectProviderContext, c as NovaConnectProviderError, b as NovaConnectProviderProps, N as NovaConnectProviderType, W as WalletBalance, o as createLabelsSubset, n as getLabelWithFallback, k as hasLabel, m as isDefaultLabels, e as useHasNovaConnectContext, l as useLabelsByCategory, u as useNovaConnect, i as useNovaConnectLabel, h as useNovaConnectLabels, j as useNovaConnectLabelsSubset, f as useNovaConnectOptional, q as useWalletNativeBalance } from '../useWalletNativeBalance-D8Ehciju.cjs';
|
|
2
|
+
import 'react';
|
|
3
|
+
import '@tuwaio/orbit-core';
|
|
4
|
+
import '../types-D4Vti05g.cjs';
|
|
5
|
+
|
|
6
|
+
interface WalletNameAndAvatarData {
|
|
7
|
+
/** The resolved name from the Name Service (e.g., ENS, like "alice.eth"), or null if not found. */
|
|
8
|
+
ensName: string | null;
|
|
9
|
+
/** The URL of the avatar associated with the name, or null if not found. */
|
|
10
|
+
ensAvatar: string | null;
|
|
11
|
+
/** True while the name service data is being fetched. */
|
|
12
|
+
isLoading: boolean;
|
|
13
|
+
/** A truncated version of the name for display, or the abbreviated address if no name. */
|
|
14
|
+
ensNameAbbreviated: string | undefined;
|
|
15
|
+
/** Error message if the name resolution failed. */
|
|
16
|
+
error: string | null;
|
|
17
|
+
/** Function to retry the name resolution manually. */
|
|
18
|
+
retry: () => void;
|
|
19
|
+
}
|
|
20
|
+
interface UseGetWalletNameAndAvatarOptions {
|
|
21
|
+
/** Number of characters to show on each side when abbreviating (default: 12) */
|
|
22
|
+
abbreviateSymbols?: number;
|
|
23
|
+
/** Maximum length before abbreviation is applied (default: 30) */
|
|
24
|
+
maxNameLength?: number;
|
|
25
|
+
/** Whether to automatically retry on failure (default: false) */
|
|
26
|
+
autoRetry?: boolean;
|
|
27
|
+
/** Retry delay in milliseconds (default: 3000) */
|
|
28
|
+
retryDelay?: number;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* A custom hook to fetch the Name Service (e.g., ENS) name and avatar
|
|
32
|
+
* for the currently active wallet.
|
|
33
|
+
*
|
|
34
|
+
* This hook automatically detects the active wallet and its corresponding
|
|
35
|
+
* adapter via the `useSatelliteConnectStore` and attempts to resolve the
|
|
36
|
+
* wallet address to a human-readable name and avatar.
|
|
37
|
+
*
|
|
38
|
+
* @param options Configuration options for the hook
|
|
39
|
+
* @returns An object containing the resolved name, avatar, loading state, and utility functions
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```typescript
|
|
43
|
+
* import { useGetWalletNameAndAvatar } from './useGetWalletNameAndAvatar';
|
|
44
|
+
*
|
|
45
|
+
* function DisplayWalletInfo() {
|
|
46
|
+
* const { ensName, ensAvatar, isLoading, ensNameAbbreviated, error, retry } = useGetWalletNameAndAvatar({
|
|
47
|
+
* abbreviateSymbols: 8,
|
|
48
|
+
* maxNameLength: 25
|
|
49
|
+
* });
|
|
50
|
+
*
|
|
51
|
+
* if (isLoading) {
|
|
52
|
+
* return <div>Resolving name...</div>;
|
|
53
|
+
* }
|
|
54
|
+
*
|
|
55
|
+
* if (error) {
|
|
56
|
+
* return <div>Error: {error} <button onClick={retry}>Retry</button></div>;
|
|
57
|
+
* }
|
|
58
|
+
*
|
|
59
|
+
* return (
|
|
60
|
+
* <div className="wallet-info">
|
|
61
|
+
* {ensAvatar && <img src={ensAvatar} alt="Wallet Avatar" />}
|
|
62
|
+
* <p title={ensName || ''}>{ensNameAbbreviated || 'No Name Found'}</p>
|
|
63
|
+
* </div>
|
|
64
|
+
* );
|
|
65
|
+
* }
|
|
66
|
+
* ```
|
|
67
|
+
*/
|
|
68
|
+
declare function useGetWalletNameAndAvatar(options: UseGetWalletNameAndAvatarOptions): WalletNameAndAvatarData;
|
|
69
|
+
|
|
70
|
+
export { type WalletNameAndAvatarData, useGetWalletNameAndAvatar };
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export { B as ButtonTxStatus, C as ConnectContentType, a as ConnectedContentType, L as LabelCategory, p as NativeBalanceResult, g as NovaConnectLabelsContext, d as NovaConnectProviderContext, c as NovaConnectProviderError, b as NovaConnectProviderProps, N as NovaConnectProviderType, W as WalletBalance, o as createLabelsSubset, n as getLabelWithFallback, k as hasLabel, m as isDefaultLabels, e as useHasNovaConnectContext, l as useLabelsByCategory, u as useNovaConnect, i as useNovaConnectLabel, h as useNovaConnectLabels, j as useNovaConnectLabelsSubset, f as useNovaConnectOptional, q as useWalletNativeBalance } from '../useWalletNativeBalance-6RVzdGvM.js';
|
|
2
|
+
import 'react';
|
|
3
|
+
import '@tuwaio/orbit-core';
|
|
4
|
+
import '../types-D4Vti05g.js';
|
|
5
|
+
|
|
6
|
+
interface WalletNameAndAvatarData {
|
|
7
|
+
/** The resolved name from the Name Service (e.g., ENS, like "alice.eth"), or null if not found. */
|
|
8
|
+
ensName: string | null;
|
|
9
|
+
/** The URL of the avatar associated with the name, or null if not found. */
|
|
10
|
+
ensAvatar: string | null;
|
|
11
|
+
/** True while the name service data is being fetched. */
|
|
12
|
+
isLoading: boolean;
|
|
13
|
+
/** A truncated version of the name for display, or the abbreviated address if no name. */
|
|
14
|
+
ensNameAbbreviated: string | undefined;
|
|
15
|
+
/** Error message if the name resolution failed. */
|
|
16
|
+
error: string | null;
|
|
17
|
+
/** Function to retry the name resolution manually. */
|
|
18
|
+
retry: () => void;
|
|
19
|
+
}
|
|
20
|
+
interface UseGetWalletNameAndAvatarOptions {
|
|
21
|
+
/** Number of characters to show on each side when abbreviating (default: 12) */
|
|
22
|
+
abbreviateSymbols?: number;
|
|
23
|
+
/** Maximum length before abbreviation is applied (default: 30) */
|
|
24
|
+
maxNameLength?: number;
|
|
25
|
+
/** Whether to automatically retry on failure (default: false) */
|
|
26
|
+
autoRetry?: boolean;
|
|
27
|
+
/** Retry delay in milliseconds (default: 3000) */
|
|
28
|
+
retryDelay?: number;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* A custom hook to fetch the Name Service (e.g., ENS) name and avatar
|
|
32
|
+
* for the currently active wallet.
|
|
33
|
+
*
|
|
34
|
+
* This hook automatically detects the active wallet and its corresponding
|
|
35
|
+
* adapter via the `useSatelliteConnectStore` and attempts to resolve the
|
|
36
|
+
* wallet address to a human-readable name and avatar.
|
|
37
|
+
*
|
|
38
|
+
* @param options Configuration options for the hook
|
|
39
|
+
* @returns An object containing the resolved name, avatar, loading state, and utility functions
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```typescript
|
|
43
|
+
* import { useGetWalletNameAndAvatar } from './useGetWalletNameAndAvatar';
|
|
44
|
+
*
|
|
45
|
+
* function DisplayWalletInfo() {
|
|
46
|
+
* const { ensName, ensAvatar, isLoading, ensNameAbbreviated, error, retry } = useGetWalletNameAndAvatar({
|
|
47
|
+
* abbreviateSymbols: 8,
|
|
48
|
+
* maxNameLength: 25
|
|
49
|
+
* });
|
|
50
|
+
*
|
|
51
|
+
* if (isLoading) {
|
|
52
|
+
* return <div>Resolving name...</div>;
|
|
53
|
+
* }
|
|
54
|
+
*
|
|
55
|
+
* if (error) {
|
|
56
|
+
* return <div>Error: {error} <button onClick={retry}>Retry</button></div>;
|
|
57
|
+
* }
|
|
58
|
+
*
|
|
59
|
+
* return (
|
|
60
|
+
* <div className="wallet-info">
|
|
61
|
+
* {ensAvatar && <img src={ensAvatar} alt="Wallet Avatar" />}
|
|
62
|
+
* <p title={ensName || ''}>{ensNameAbbreviated || 'No Name Found'}</p>
|
|
63
|
+
* </div>
|
|
64
|
+
* );
|
|
65
|
+
* }
|
|
66
|
+
* ```
|
|
67
|
+
*/
|
|
68
|
+
declare function useGetWalletNameAndAvatar(options: UseGetWalletNameAndAvatarOptions): WalletNameAndAvatarData;
|
|
69
|
+
|
|
70
|
+
export { type WalletNameAndAvatarData, useGetWalletNameAndAvatar };
|
package/dist/hooks/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export{g as NovaConnectLabelsContext,c as NovaConnectProviderContext,b as NovaConnectProviderError,o as createLabelsSubset,n as getLabelWithFallback,k as hasLabel,m as isDefaultLabels,a as useGetWalletNameAndAvatar,e as useHasNovaConnectContext,l as useLabelsByCategory,d as useNovaConnect,i as useNovaConnectLabel,h as useNovaConnectLabels,j as useNovaConnectLabelsSubset,f as useNovaConnectOptional,p as useWalletNativeBalance}from'../chunk-LF6FTUUQ.js';import'../chunk-TAV7EL23.js';import'../chunk-MPEJHQKC.js';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/hooks/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/hooks/useGetWalletNameAndAvatar.ts","../../src/hooks/useWalletNativeBalance.ts"],"names":["useGetWalletNameAndAvatar","options","abbreviateSymbols","maxNameLength","autoRetry","retryDelay","store","getAdapter","walletAddress","useMemo","walletType","foundAdapter","getAdapterFromWalletType","OrbitAdapter","ensName","setEnsName","useState","ensAvatar","setEnsAvatar","isLoading","setIsLoading","error","setError","abortControllerRef","useRef","retryTimeoutRef","adapterCapabilities","hasNameResolver","hasAvatarResolver","cleanup","useCallback","fetchNameData","signal","name","avatar","avatarError","errorMessage","retry","useEffect","ensNameAbbreviated","textCenterEllipsis","useWalletNativeBalance","activeWallet","balanceCache","setBalanceCache","fetchOperationRef","cacheKey","hasBalanceResolver","fetchBalance","forceRefresh","operationId","balanceResult","prevCache","newCache","refetch"],"mappings":"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","file":"index.js","sourcesContent":["import { textCenterEllipsis } from '@tuwaio/nova-core';\nimport { getAdapterFromWalletType, OrbitAdapter } from '@tuwaio/orbit-core';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { NovaConnectProviderProps, NovaConnectProviderType } from './useNovaConnect';\n\nexport interface WalletNameAndAvatarData {\n /** The resolved name from the Name Service (e.g., ENS, like \"alice.eth\"), or null if not found. */\n ensName: string | null;\n /** The URL of the avatar associated with the name, or null if not found. */\n ensAvatar: string | null;\n /** True while the name service data is being fetched. */\n isLoading: boolean;\n /** A truncated version of the name for display, or the abbreviated address if no name. */\n ensNameAbbreviated: string | undefined;\n /** Error message if the name resolution failed. */\n error: string | null;\n /** Function to retry the name resolution manually. */\n retry: () => void;\n}\n\ninterface UseGetWalletNameAndAvatarOptions\n extends Pick<NovaConnectProviderProps, 'store'>,\n Pick<NovaConnectProviderType, 'activeWallet'> {\n /** Number of characters to show on each side when abbreviating (default: 12) */\n abbreviateSymbols?: number;\n /** Maximum length before abbreviation is applied (default: 30) */\n maxNameLength?: number;\n /** Whether to automatically retry on failure (default: false) */\n autoRetry?: boolean;\n /** Retry delay in milliseconds (default: 3000) */\n retryDelay?: number;\n}\n\n/**\n * A custom hook to fetch the Name Service (e.g., ENS) name and avatar\n * for the currently active wallet.\n *\n * This hook automatically detects the active wallet and its corresponding\n * adapter via the `useSatelliteConnectStore` and attempts to resolve the\n * wallet address to a human-readable name and avatar.\n *\n * @param options Configuration options for the hook\n * @returns An object containing the resolved name, avatar, loading state, and utility functions\n *\n * @example\n * ```typescript\n * import { useGetWalletNameAndAvatar } from './useGetWalletNameAndAvatar';\n *\n * function DisplayWalletInfo() {\n * const { ensName, ensAvatar, isLoading, ensNameAbbreviated, error, retry } = useGetWalletNameAndAvatar({\n * abbreviateSymbols: 8,\n * maxNameLength: 25\n * });\n *\n * if (isLoading) {\n * return <div>Resolving name...</div>;\n * }\n *\n * if (error) {\n * return <div>Error: {error} <button onClick={retry}>Retry</button></div>;\n * }\n *\n * return (\n * <div className=\"wallet-info\">\n * {ensAvatar && <img src={ensAvatar} alt=\"Wallet Avatar\" />}\n * <p title={ensName || ''}>{ensNameAbbreviated || 'No Name Found'}</p>\n * </div>\n * );\n * }\n * ```\n */\nexport function useGetWalletNameAndAvatar(options: UseGetWalletNameAndAvatarOptions): WalletNameAndAvatarData {\n const { abbreviateSymbols = 12, maxNameLength = 30, autoRetry = false, retryDelay = 3000, store } = options;\n\n // Store state selectors - memoized for performance\n const getAdapter = store.getState().getAdapter;\n\n // Memoize wallet address and adapter for dependency tracking\n const walletAddress = useMemo(() => options.activeWallet?.address, [options.activeWallet?.address]);\n const walletType = useMemo(() => options.activeWallet?.walletType, [options.activeWallet?.walletType]);\n\n const foundAdapter = useMemo(() => {\n if (!walletType) return null;\n return getAdapter(getAdapterFromWalletType(walletType ?? `${OrbitAdapter.EVM}:not-connected`));\n }, [getAdapter, walletType]);\n\n // State variables\n const [ensName, setEnsName] = useState<string | null>(null);\n const [ensAvatar, setEnsAvatar] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n // Refs for cleanup and retry functionality\n const abortControllerRef = useRef<AbortController | null>(null);\n const retryTimeoutRef = useRef<number | null>(null);\n\n // Memoize adapter capabilities\n const adapterCapabilities = useMemo(() => {\n if (!foundAdapter) {\n return { hasNameResolver: false, hasAvatarResolver: false };\n }\n\n const hasNameResolver = 'getName' in foundAdapter && typeof foundAdapter.getName === 'function';\n const hasAvatarResolver = 'getAvatar' in foundAdapter && typeof foundAdapter.getAvatar === 'function';\n\n return { hasNameResolver, hasAvatarResolver };\n }, [foundAdapter]);\n\n // Cleanup function\n const cleanup = useCallback(() => {\n if (abortControllerRef.current) {\n abortControllerRef.current.abort();\n abortControllerRef.current = null;\n }\n if (retryTimeoutRef.current !== null) {\n clearTimeout(retryTimeoutRef.current);\n retryTimeoutRef.current = null;\n }\n }, []);\n\n // Main fetch function\n const fetchNameData = useCallback(async () => {\n cleanup();\n\n // Exit conditions\n if (!walletAddress || !foundAdapter || !adapterCapabilities.hasNameResolver) {\n setEnsName(null);\n setEnsAvatar(null);\n setIsLoading(false);\n setError(null);\n return;\n }\n\n // Create new abort controller for this request\n abortControllerRef.current = new AbortController();\n const { signal } = abortControllerRef.current;\n\n // Start loading\n setIsLoading(true);\n setError(null);\n setEnsName(null);\n setEnsAvatar(null);\n\n try {\n // Check if request was aborted\n if (signal.aborted) return;\n\n // Attempt to resolve the name\n const name = await foundAdapter.getName?.(walletAddress);\n\n if (signal.aborted) return;\n\n if (name) {\n setEnsName(name);\n\n // If avatar resolution is supported, fetch the avatar\n if (adapterCapabilities.hasAvatarResolver) {\n try {\n const avatar = await foundAdapter.getAvatar?.(name);\n if (!signal.aborted) {\n // Handle undefined case by converting to null\n setEnsAvatar(avatar ?? null);\n }\n } catch (avatarError) {\n // Avatar fetch failed, but name succeeded - not critical\n console.warn('Failed to fetch avatar:', avatarError);\n if (!signal.aborted) {\n setEnsAvatar(null);\n }\n }\n }\n }\n } catch (error) {\n if (signal.aborted) return;\n\n const errorMessage = error instanceof Error ? error.message : 'Failed to fetch name service data';\n console.error('Failed to fetch name service data:', error);\n\n setError(errorMessage);\n setEnsName(null);\n setEnsAvatar(null);\n\n // Auto retry if enabled\n if (autoRetry) {\n retryTimeoutRef.current = setTimeout(() => {\n fetchNameData();\n }, retryDelay) as unknown as number;\n }\n } finally {\n if (!signal.aborted) {\n setIsLoading(false);\n }\n }\n }, [walletAddress, foundAdapter, adapterCapabilities, autoRetry, retryDelay, cleanup]);\n\n // Manual retry function\n const retry = useCallback(() => {\n setError(null);\n fetchNameData();\n }, [fetchNameData]);\n\n // Effect to fetch data when dependencies change\n useEffect(() => {\n fetchNameData();\n return cleanup;\n }, [fetchNameData, cleanup]);\n\n // Cleanup on unmount\n useEffect(() => {\n return cleanup;\n }, [cleanup]);\n\n // Memoized abbreviated name computation\n const ensNameAbbreviated = useMemo(() => {\n if (ensName) {\n return ensName.length > maxNameLength\n ? textCenterEllipsis(ensName, abbreviateSymbols, abbreviateSymbols)\n : ensName;\n }\n\n return walletAddress ? textCenterEllipsis(walletAddress, abbreviateSymbols, abbreviateSymbols) : undefined;\n }, [ensName, walletAddress, maxNameLength, abbreviateSymbols]);\n\n return {\n ensName,\n ensAvatar,\n isLoading,\n ensNameAbbreviated,\n error,\n retry,\n };\n}\n","import { getAdapterFromWalletType } from '@tuwaio/orbit-core';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { NovaConnectProviderProps, NovaConnectProviderType } from './useNovaConnect';\n\n/**\n * @interface NativeBalanceResult\n * Represents the native token balance returned by the adapter.\n * The value is already formatted for human readability.\n * @property {string} value The native token balance formatted to standard decimals (e.g., \"1.5\").\n * @property {string} symbol The symbol of the native token (e.g., \"ETH\").\n */\nexport interface NativeBalanceResult {\n value: string;\n symbol: string;\n}\n\n// Type for the balance state within the hook (the fetched data or null).\ntype NativeBalanceState = NativeBalanceResult | null;\n\n// Type for the local cache: \"walletAddress-chainId\" -> { value, symbol }.\ntype BalanceCache = Record<string, NativeBalanceResult>;\n\n/**\n * @interface NativeBalanceData\n * The object returned by the useWalletNativeBalance hook.\n * @property {NativeBalanceState} balance The native token balance and symbol, or null.\n * @property {boolean} isLoading True while the balance is being fetched for the current wallet/chain combination.\n * @property {() => void} refetch Function to manually trigger a balance refresh.\n */\ninterface NativeBalanceData {\n balance: NativeBalanceState;\n isLoading: boolean;\n refetch: () => void;\n}\n\n/**\n * Custom hook to fetch the native token balance for the currently connected wallet\n * on the active chain. It includes a local cache layer to prevent redundant network calls\n * when switching between components or on re-renders for the same wallet/chain.\n *\n * @returns {NativeBalanceData} An object containing the balance data and loading state.\n *\n * @example\n * ```typescript\n * import { useWalletNativeBalance } from './useWalletNativeBalance';\n *\n * function NativeTokenDisplay() {\n * const { balance, isLoading, refetch } = useWalletNativeBalance();\n *\n * if (isLoading) {\n * return <p>Loading balance...</p>;\n * }\n *\n * // Display the formatted balance and symbol\n * return (\n * <div>\n * <p>Balance: {balance ? `${balance.value} ${balance.symbol}` : '0.00'}</p>\n * <button onClick={refetch}>Refresh</button>\n * </div>\n * );\n * }\n * ```\n */\nexport function useWalletNativeBalance({\n store,\n activeWallet,\n}: Pick<NovaConnectProviderProps, 'store'> & Pick<NovaConnectProviderType, 'activeWallet'>): NativeBalanceData {\n // --- 1. STATE & CACHE SETUP ---\n\n // Local cache storage. Keys combine wallet address and chain ID.\n const [balanceCache, setBalanceCache] = useState<BalanceCache>({});\n\n // Local loading state, managed alongside the cache check.\n const [isLoading, setIsLoading] = useState<boolean>(false);\n\n // Track the current fetch operation to prevent race conditions\n const fetchOperationRef = useRef<string | null>(null);\n\n // Store state selectors - memoized for performance\n const getAdapter = store.getState().getAdapter;\n\n // --- 2. COMPUTED INPUTS ---\n\n // Create the unique key for cache lookups: \"address-chainId\".\n const cacheKey = useMemo(() => {\n return activeWallet?.chainId && activeWallet?.address ? `${activeWallet.address}-${activeWallet.chainId}` : null;\n }, [activeWallet?.chainId, activeWallet?.address]);\n\n // Find the actual adapter object from the adapter map.\n const foundAdapter = useMemo(() => {\n if (!activeWallet?.walletType) return null;\n return getAdapter(getAdapterFromWalletType(activeWallet.walletType));\n }, [getAdapter, activeWallet?.walletType]);\n\n // Check if the adapter has balance functionality\n const hasBalanceResolver = useMemo(() => {\n return foundAdapter && 'getBalance' in foundAdapter && typeof foundAdapter.getBalance === 'function';\n }, [foundAdapter]);\n\n // --- 3. BALANCE FETCHING LOGIC ---\n\n const fetchBalance = useCallback(\n async (forceRefresh = false) => {\n // Exit early if essential data is missing (not connected).\n if (!activeWallet?.address || !foundAdapter || !activeWallet?.chainId || !cacheKey || !hasBalanceResolver) {\n setIsLoading(false);\n return;\n }\n\n // Set the current operation ID to prevent race conditions\n const operationId = `${cacheKey}-${Date.now()}`;\n fetchOperationRef.current = operationId;\n\n // Check cache unless forcing a refresh\n if (!forceRefresh) {\n const cachedBalance = balanceCache[cacheKey];\n if (cachedBalance) {\n setIsLoading(false);\n return;\n }\n }\n\n setIsLoading(true);\n\n try {\n // Call the adapter's getBalance method\n const balanceResult: NativeBalanceResult = await foundAdapter.getBalance(\n activeWallet.address,\n activeWallet.chainId,\n );\n\n // Only update if this operation is still the latest one\n if (fetchOperationRef.current === operationId) {\n setBalanceCache((prevCache) => ({\n ...prevCache,\n [cacheKey]: balanceResult,\n }));\n }\n } catch (error) {\n console.error(`Failed to fetch native balance for ${cacheKey}:`, error);\n\n // Optionally clear cache entry on error (if you want to retry on next call)\n if (forceRefresh && fetchOperationRef.current === operationId) {\n setBalanceCache((prevCache) => {\n const newCache = { ...prevCache };\n delete newCache[cacheKey];\n return newCache;\n });\n }\n } finally {\n // Only update loading state if this operation is still current\n if (fetchOperationRef.current === operationId) {\n setIsLoading(false);\n }\n }\n },\n [activeWallet?.address, foundAdapter, activeWallet?.chainId, cacheKey, hasBalanceResolver, balanceCache],\n );\n\n // Memoized refetch function that forces a refresh\n const refetch = useCallback(() => {\n fetchBalance(true);\n }, [fetchBalance]);\n\n // --- 4. EFFECT FOR INITIAL FETCH ---\n\n useEffect(() => {\n // Only fetch if we have all required data and no cached result\n if (cacheKey && hasBalanceResolver && !balanceCache[cacheKey]) {\n fetchBalance(false);\n } else if (!cacheKey || !hasBalanceResolver) {\n // Reset loading state if we can't fetch\n setIsLoading(false);\n }\n }, [cacheKey, hasBalanceResolver, balanceCache, fetchBalance]);\n\n // --- 5. CLEANUP EFFECT ---\n\n useEffect(() => {\n return () => {\n // Cancel any ongoing operations when component unmounts\n fetchOperationRef.current = null;\n };\n }, []);\n\n // --- 6. RETURNED DATA ---\n\n // The definitive balance is always derived from the cache based on the current key.\n const balance: NativeBalanceState = useMemo(() => {\n return cacheKey ? balanceCache[cacheKey] || null : null;\n }, [cacheKey, balanceCache]);\n\n // Return the fetched balance data and the loading status.\n return {\n balance, // { value: \"1.5\", symbol: \"ETH\" } or null\n isLoading,\n refetch,\n };\n}\n"]}
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkQERPNHKX_cjs=require('../chunk-QERPNHKX.cjs');Object.defineProperty(exports,"defaultLabels",{enumerable:true,get:function(){return chunkQERPNHKX_cjs.a}});Object.defineProperty(exports,"ukrainianLabels",{enumerable:true,get:function(){return chunkQERPNHKX_cjs.b}});//# sourceMappingURL=index.cjs.map
|
|
2
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.cjs"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { N as NovaConnectLabels } from '../types-D4Vti05g.cjs';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Default English translations for NovaConnect component
|
|
5
|
+
* All text strings extracted from component files
|
|
6
|
+
*/
|
|
7
|
+
declare const defaultLabels: NovaConnectLabels;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Українські переклади для компонента NovaConnect
|
|
11
|
+
* Всі текстові рядки витягнуті з файлів компонентів
|
|
12
|
+
*/
|
|
13
|
+
declare const ukrainianLabels: NovaConnectLabels;
|
|
14
|
+
|
|
15
|
+
export { NovaConnectLabels, defaultLabels, ukrainianLabels };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { N as NovaConnectLabels } from '../types-D4Vti05g.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Default English translations for NovaConnect component
|
|
5
|
+
* All text strings extracted from component files
|
|
6
|
+
*/
|
|
7
|
+
declare const defaultLabels: NovaConnectLabels;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Українські переклади для компонента NovaConnect
|
|
11
|
+
* Всі текстові рядки витягнуті з файлів компонентів
|
|
12
|
+
*/
|
|
13
|
+
declare const ukrainianLabels: NovaConnectLabels;
|
|
14
|
+
|
|
15
|
+
export { NovaConnectLabels, defaultLabels, ukrainianLabels };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
|