@tuwaio/nova-connect 1.0.0-fix-indep-alpha.2.19e398f → 1.0.0-fix-indep-alpha.4.34e33fc

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.
Files changed (60) hide show
  1. package/dist/{chunk-OEG3F2P2.js → chunk-5NO4S3N6.js} +3 -3
  2. package/dist/{chunk-OEG3F2P2.js.map → chunk-5NO4S3N6.js.map} +1 -1
  3. package/dist/chunk-AIK5PZKK.js +2 -0
  4. package/dist/chunk-AIK5PZKK.js.map +1 -0
  5. package/dist/chunk-HD3XOSPF.cjs +2 -0
  6. package/dist/chunk-HD3XOSPF.cjs.map +1 -0
  7. package/dist/{chunk-SHVZSXXR.cjs → chunk-HGNQGX55.cjs} +4 -4
  8. package/dist/{chunk-SHVZSXXR.cjs.map → chunk-HGNQGX55.cjs.map} +1 -1
  9. package/dist/{chunk-JGLDANME.js → chunk-IJAOXAYK.js} +3 -3
  10. package/dist/{chunk-JGLDANME.js.map → chunk-IJAOXAYK.js.map} +1 -1
  11. package/dist/{chunk-S2OWIMXG.cjs → chunk-UKICC3L6.cjs} +3 -3
  12. package/dist/{chunk-S2OWIMXG.cjs.map → chunk-UKICC3L6.cjs.map} +1 -1
  13. package/dist/components/index.cjs +1 -1
  14. package/dist/components/index.js +1 -1
  15. package/dist/evm/index.cjs +1 -1
  16. package/dist/evm/index.cjs.map +1 -1
  17. package/dist/evm/index.d.cts +24 -4
  18. package/dist/evm/index.d.ts +24 -4
  19. package/dist/evm/index.js +1 -1
  20. package/dist/evm/index.js.map +1 -1
  21. package/dist/evm-6ZNRGFP6.js +2 -0
  22. package/dist/evm-6ZNRGFP6.js.map +1 -0
  23. package/dist/evm-HHXFWYBL.cjs +2 -0
  24. package/dist/evm-HHXFWYBL.cjs.map +1 -0
  25. package/dist/getChainsListByConnectorType-5S4LY67B.cjs +2 -0
  26. package/dist/{getChainsListByConnectorType-ZDMZCWJQ.cjs.map → getChainsListByConnectorType-5S4LY67B.cjs.map} +1 -1
  27. package/dist/{getChainsListByConnectorType-W6UDLFBJ.js → getChainsListByConnectorType-VKIEDNV7.js} +2 -2
  28. package/dist/{getChainsListByConnectorType-W6UDLFBJ.js.map → getChainsListByConnectorType-VKIEDNV7.js.map} +1 -1
  29. package/dist/hooks/index.cjs +1 -1
  30. package/dist/hooks/index.js +1 -1
  31. package/dist/index.cjs +1 -1
  32. package/dist/index.cjs.map +1 -1
  33. package/dist/index.d.cts +11 -11
  34. package/dist/index.d.ts +11 -11
  35. package/dist/index.js +1 -1
  36. package/dist/index.js.map +1 -1
  37. package/dist/solana/index.cjs +1 -1
  38. package/dist/solana/index.cjs.map +1 -1
  39. package/dist/solana/index.d.cts +21 -6
  40. package/dist/solana/index.d.ts +21 -6
  41. package/dist/solana/index.js +1 -1
  42. package/dist/solana/index.js.map +1 -1
  43. package/dist/solana-3TFK54UZ.js +2 -0
  44. package/dist/solana-3TFK54UZ.js.map +1 -0
  45. package/dist/solana-KOGSMKO4.cjs +2 -0
  46. package/dist/solana-KOGSMKO4.cjs.map +1 -0
  47. package/package.json +3 -3
  48. package/dist/chunk-GEKUE6DA.js +0 -2
  49. package/dist/chunk-GEKUE6DA.js.map +0 -1
  50. package/dist/chunk-TCSUZ35B.cjs +0 -2
  51. package/dist/chunk-TCSUZ35B.cjs.map +0 -1
  52. package/dist/evm-HEAZFJ7Q.js +0 -2
  53. package/dist/evm-HEAZFJ7Q.js.map +0 -1
  54. package/dist/evm-OMPZNXHK.cjs +0 -2
  55. package/dist/evm-OMPZNXHK.cjs.map +0 -1
  56. package/dist/getChainsListByConnectorType-ZDMZCWJQ.cjs +0 -2
  57. package/dist/solana-MGGAOLA3.cjs +0 -2
  58. package/dist/solana-MGGAOLA3.cjs.map +0 -1
  59. package/dist/solana-XBTO6NEP.js +0 -2
  60. package/dist/solana-XBTO6NEP.js.map +0 -1
package/dist/index.d.cts CHANGED
@@ -689,26 +689,26 @@ interface ChainAdapter {
689
689
  *
690
690
  * @param config Chain configuration data (format varies by blockchain)
691
691
  * @param chains Optional array of specific chains to filter or process
692
- * @returns Array of chain identifiers (numbers for EVM, strings for Solana)
692
+ * @returns Promise resolving to array of chain identifiers (numbers for EVM, strings for Solana)
693
693
  *
694
694
  * @example
695
695
  * ```typescript
696
696
  * // EVM chains
697
- * const evmChains = adapter.getChains([
697
+ * const evmChains = await adapter.getChains([
698
698
  * { id: 1, name: 'Ethereum' },
699
699
  * { id: 56, name: 'BSC' }
700
700
  * ]);
701
701
  * // Returns: [1, 56]
702
702
  *
703
703
  * // Solana clusters
704
- * const solanaClusters = adapter.getChains({
704
+ * const solanaClusters = await adapter.getChains({
705
705
  * 'mainnet-beta': 'https://api.mainnet-beta.solana.com',
706
706
  * devnet: 'https://api.devnet.solana.com'
707
707
  * });
708
708
  * // Returns: ['mainnet-beta', 'devnet']
709
709
  * ```
710
710
  */
711
- getChains(config: any, chains?: any): (string | number)[];
711
+ getChains(config: any, chains?: any): Promise<(string | number)[]>;
712
712
  /**
713
713
  * Validates whether a chain identifier array conforms to this adapter's expected format.
714
714
  *
@@ -738,17 +738,17 @@ interface ChainAdapter {
738
738
  * This method is specific to Solana and returns the configured cluster names
739
739
  * that can be used for connections. Not applicable to other blockchain types.
740
740
  *
741
- * @returns Array of available cluster names
741
+ * @returns Promise resolving to array of available cluster names
742
742
  * @optional This method is only available on Solana adapters
743
743
  *
744
744
  * @example
745
745
  * ```typescript
746
746
  * const solanaAdapter = await createSolanaAdapter();
747
- * const clusters = solanaAdapter.getAvailableClusters?.();
747
+ * const clusters = await solanaAdapter.getAvailableClusters?.();
748
748
  * // Might return: ['mainnet-beta', 'devnet', 'testnet', 'localnet']
749
749
  * ```
750
750
  */
751
- getAvailableClusters?(): string[];
751
+ getAvailableClusters?(): Promise<string[]>;
752
752
  /**
753
753
  * Validates whether a cluster name is valid for Solana.
754
754
  *
@@ -756,17 +756,17 @@ interface ChainAdapter {
756
756
  * is a known/valid Solana cluster moniker. Not applicable to other blockchain types.
757
757
  *
758
758
  * @param cluster Cluster name to validate
759
- * @returns True if the cluster name is valid for Solana
759
+ * @returns Promise resolving to true if the cluster name is valid for Solana
760
760
  * @optional This method is only available on Solana adapters
761
761
  *
762
762
  * @example
763
763
  * ```typescript
764
764
  * const solanaAdapter = await createSolanaAdapter();
765
- * const isValid = solanaAdapter.isValidCluster?.('mainnet-beta'); // true
766
- * const isInvalid = solanaAdapter.isValidCluster?.('invalid-cluster'); // false
765
+ * const isValid = await solanaAdapter.isValidCluster?.('mainnet-beta'); // true
766
+ * const isInvalid = await solanaAdapter.isValidCluster?.('invalid-cluster'); // false
767
767
  * ```
768
768
  */
769
- isValidCluster?(cluster: string): boolean;
769
+ isValidCluster?(cluster: string): Promise<boolean>;
770
770
  }
771
771
  /**
772
772
  * Represents the current loading state of a blockchain adapter.
package/dist/index.d.ts CHANGED
@@ -689,26 +689,26 @@ interface ChainAdapter {
689
689
  *
690
690
  * @param config Chain configuration data (format varies by blockchain)
691
691
  * @param chains Optional array of specific chains to filter or process
692
- * @returns Array of chain identifiers (numbers for EVM, strings for Solana)
692
+ * @returns Promise resolving to array of chain identifiers (numbers for EVM, strings for Solana)
693
693
  *
694
694
  * @example
695
695
  * ```typescript
696
696
  * // EVM chains
697
- * const evmChains = adapter.getChains([
697
+ * const evmChains = await adapter.getChains([
698
698
  * { id: 1, name: 'Ethereum' },
699
699
  * { id: 56, name: 'BSC' }
700
700
  * ]);
701
701
  * // Returns: [1, 56]
702
702
  *
703
703
  * // Solana clusters
704
- * const solanaClusters = adapter.getChains({
704
+ * const solanaClusters = await adapter.getChains({
705
705
  * 'mainnet-beta': 'https://api.mainnet-beta.solana.com',
706
706
  * devnet: 'https://api.devnet.solana.com'
707
707
  * });
708
708
  * // Returns: ['mainnet-beta', 'devnet']
709
709
  * ```
710
710
  */
711
- getChains(config: any, chains?: any): (string | number)[];
711
+ getChains(config: any, chains?: any): Promise<(string | number)[]>;
712
712
  /**
713
713
  * Validates whether a chain identifier array conforms to this adapter's expected format.
714
714
  *
@@ -738,17 +738,17 @@ interface ChainAdapter {
738
738
  * This method is specific to Solana and returns the configured cluster names
739
739
  * that can be used for connections. Not applicable to other blockchain types.
740
740
  *
741
- * @returns Array of available cluster names
741
+ * @returns Promise resolving to array of available cluster names
742
742
  * @optional This method is only available on Solana adapters
743
743
  *
744
744
  * @example
745
745
  * ```typescript
746
746
  * const solanaAdapter = await createSolanaAdapter();
747
- * const clusters = solanaAdapter.getAvailableClusters?.();
747
+ * const clusters = await solanaAdapter.getAvailableClusters?.();
748
748
  * // Might return: ['mainnet-beta', 'devnet', 'testnet', 'localnet']
749
749
  * ```
750
750
  */
751
- getAvailableClusters?(): string[];
751
+ getAvailableClusters?(): Promise<string[]>;
752
752
  /**
753
753
  * Validates whether a cluster name is valid for Solana.
754
754
  *
@@ -756,17 +756,17 @@ interface ChainAdapter {
756
756
  * is a known/valid Solana cluster moniker. Not applicable to other blockchain types.
757
757
  *
758
758
  * @param cluster Cluster name to validate
759
- * @returns True if the cluster name is valid for Solana
759
+ * @returns Promise resolving to true if the cluster name is valid for Solana
760
760
  * @optional This method is only available on Solana adapters
761
761
  *
762
762
  * @example
763
763
  * ```typescript
764
764
  * const solanaAdapter = await createSolanaAdapter();
765
- * const isValid = solanaAdapter.isValidCluster?.('mainnet-beta'); // true
766
- * const isInvalid = solanaAdapter.isValidCluster?.('invalid-cluster'); // false
765
+ * const isValid = await solanaAdapter.isValidCluster?.('mainnet-beta'); // true
766
+ * const isInvalid = await solanaAdapter.isValidCluster?.('invalid-cluster'); // false
767
767
  * ```
768
768
  */
769
- isValidCluster?(cluster: string): boolean;
769
+ isValidCluster?(cluster: string): Promise<boolean>;
770
770
  }
771
771
  /**
772
772
  * Represents the current loading state of a blockchain adapter.
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- import {A,v,z,s,C,y,B,r,D}from'./chunk-JGLDANME.js';import {d,h as h$1,u,q,p,x,g,c}from'./chunk-OEG3F2P2.js';export{g as NovaConnectLabelsContext,c as NovaConnectProviderContext,b as NovaConnectProviderError,o as createLabelsSubset,r as getAvailableChainIds,y as getAvailableSolanaClusters,q as getConnectChainId,u as getFilteredConnectors,s as getGroupedConnectors,n as getLabelWithFallback,w as getNetworkIcon,t as hasAvailableConnectors,v as hasConnectorsForAdapter,k as hasLabel,p as isAddress,m as isDefaultLabels,z as isValidSolanaCluster,x as networksLinks,a as useGetWalletNameAndAvatar,e as useHasNovaConnectContext,l as useLabelsByCategory,d as useNovaConnect,i as useNovaConnectLabel,h as useNovaConnectLabels,j as useNovaConnectLabelsSubset,f as useNovaConnectOptional,A as useWalletChainsList,B as useWalletNativeBalance}from'./chunk-OEG3F2P2.js';export{k as getAdapterStatus,l as getAllAdaptersStatus,g as getAvailableSolanaClustersAsync,b as getChainsListByConnectorType,a as getChainsListByConnectorTypeAsync,b as getChainsListByConnectorTypeSync,i as getWalletChains,e as isEvmChainList,c as isEvmChainListAsync,e as isEvmChainListSync,f as isSolanaChainList,d as isSolanaChainListAsync,f as isSolanaChainListSync,h as isValidSolanaClusterAsync,j as preloadChainAdapters}from'./chunk-GEKUE6DA.js';import {a}from'./chunk-3BMX6JWH.js';import {h,f}from'./chunk-2T6SPFUT.js';import {waitFor,delay,formatConnectorName,getConnectorTypeFromName,impersonatedHelpers,OrbitAdapter}from'@tuwaio/orbit-core';import {cn,DialogHeader,DialogTitle,DialogClose,CloseIcon,standardButtonClasses,Dialog,DialogContent,ToastCloseButton,deepMerge}from'@tuwaio/nova-core';import {forwardRef,memo,useContext,useMemo,useEffect,useCallback,useRef,useState}from'react';import {toast,Bounce,ToastContainer}from'react-toastify';import {jsx,jsxs,Fragment}from'react/jsx-runtime';import {InformationCircleIcon}from'@heroicons/react/24/outline';import {motion}from'framer-motion';var Ce=({title:o,rawError:e,onCopyComplete:r,errorType:a,isConnected:t,...f})=>jsx(D,{title:o,rawError:e,onCopyComplete:r,customization:f.customization}),fe=o=>{let e=h$1();return jsx(ToastContainer,{...o,role:"alert","aria-live":"assertive","aria-label":e.somethingWentWrong})},ve=(o,e)=>{o(e.title,e.rawError,e.errorKey);},be=o=>{o();},ge=(o,e)=>{o&&process.env.NODE_ENV==="development"&&console.log("Error copied to clipboard:",e.substring(0,100));},ye=o=>o,Te=o=>o;function No({containerId:o="nova-connect-errors",position:e="top-center",autoClose:r=7e3,draggable:a=false,customization:t}){let f=h$1(),u=h(c=>c.switchNetworkError),R=h(c=>c.activeConnection),B=h(c=>c.connectionError),{ToastError:N=Ce,Container:b=fe}=t?.components??{},{showError:d=ve,dismissError:O=be,onCopyComplete:H=ge}=t?.handlers??{},{errorTitle:T=ye,errorHash:E=Te}=t??{},P=useRef(new Set),x=useRef(null),s=useMemo(()=>{let c=!!B,y=!!u,M=!!R?.isConnected;return {hasWalletError:c,hasSwitchError:y,isConnected:M,hasAnyError:c||y,primaryError:B||u||null,errorType:c?"wallet":y?"switch":null}},[B,u,R?.isConnected]),z=useMemo(()=>{switch(s.errorType){case "wallet":return f.connectionError;case "switch":return f.errorWhenChainSwitching;default:return f.somethingWentWrong}},[s.errorType,f]),m=useMemo(()=>T(z,{errorType:s.errorType}),[T,z,s.errorType]),W=useMemo(()=>s.primaryError?`${s.errorType}-${s.primaryError.substring(0,50)}`:null,[s.primaryError,s.errorType]),C=useMemo(()=>E(W,{primaryError:s.primaryError,errorType:s.errorType}),[E,W,s.primaryError,s.errorType]),D=useCallback(()=>{O(()=>{x.current&&(toast.dismiss(x.current),x.current=null),toast.dismiss({containerId:o});});},[o,O]),F=useCallback((c,y)=>{H(c,y,s.errorType);},[H,s.errorType]),n=useCallback((c,y,M)=>{if(D(),!P.current.has(M))try{let V={containerId:o,toastId:M,onClose:()=>{P.current.delete(M),x.current=null;}},_=t?.toastOptions?.error?.({title:c,rawError:y,errorType:s.errorType,isConnected:s.isConnected}),q={...V,..._};toast.error(jsx(N,{title:c,rawError:y,errorType:s.errorType,isConnected:s.isConnected,onCopyComplete:J=>F(J,y),customization:t?.toastErrorCustomization}),q),P.current.add(M),x.current=M;}catch(V){console.error("Failed to show error toast:",V);}},[D,o,t?.toastOptions?.error,t?.toastErrorCustomization,N,s.errorType,s.isConnected,F]),v=useCallback((c,y,M)=>{d(n,{title:c,rawError:y,errorKey:M,errorType:s.errorType});},[n,d,s.errorType]);useEffect(()=>{let{hasAnyError:c,isConnected:y,primaryError:M}=s;if(y&&!c){D(),P.current.clear();return}if(c&&M&&C){if(y&&s.errorType!=="switch")return;v(m,M,C);}},[s,m,C,v,D]),useEffect(()=>()=>{D(),P.current.clear();},[D]);let g=useMemo(()=>t?.classNames?.container?t.classNames.container({hasErrors:s.hasAnyError,errorType:s.errorType}):"novacon:p-0 novacon:bg-transparent",[t,s.hasAnyError,s.errorType]),p=useMemo(()=>({containerId:o,position:e,closeOnClick:false,icon:false,closeButton:ToastCloseButton,autoClose:r,hideProgressBar:false,newestOnTop:false,pauseOnFocusLoss:false,draggable:a,pauseOnHover:true,theme:"light",transition:Bounce}),[o,e,r,a]),h$2=useMemo(()=>({...p,...t?.containerProps,className:g}),[p,t?.containerProps,g]);return jsx(b,{...h$2})}No.displayName="ErrorsProvider";function Eo({labels:o,children:e}){let r=useMemo(()=>o,[o]);if(process.env.NODE_ENV==="development"){(!o||typeof o!="object")&&console.warn("NovaConnectLabelsProvider: labels prop should be an object");let t=["connectWallet","disconnect","connecting","connected","error","success"].filter(f=>!(f in o));t.length>0&&console.warn(`NovaConnectLabelsProvider: Missing required labels: ${t.join(", ")}`);}return jsx(g.Provider,{value:r,children:e})}Eo.displayName="NovaConnectLabelsProvider";function ze(o,e){if(!o||!Array.isArray(o)||!e)return;let r=o.find(a=>a&&typeof a=="object"&&"name"in a&&typeof a.name=="string"?formatConnectorName(a.name)===e:false);return r&&typeof r=="object"&&"name"in r&&typeof r.name=="string"?r.name:void 0}var Qo=forwardRef(({className:o,children:e,modalData:r,...a},t)=>jsx("div",{ref:t,className:cn("novacon:relative novacon:flex novacon:w-full novacon:flex-col",o),...a,children:e}));Qo.displayName="DefaultModalContainer";var Xo=forwardRef(({className:o,children:e,modalData:r,...a},t)=>jsx("div",{ref:t,className:o,...a,children:jsx(DialogHeader,{children:e})}));Xo.displayName="DefaultModalHeader";var Yo=forwardRef(({className:o,onClick:e,modalData:r,...a},t)=>jsx("button",{ref:t,className:cn("novacon:cursor-pointer novacon:text-[var(--tuwa-text-secondary)] novacon:transition novacon:duration-300 novacon:ease-in-out novacon:active:scale-75 novacon:hover:scale-110",o),type:"button",onClick:e,...a,children:jsx(InformationCircleIcon,{width:20,height:20,className:"novacon:mr-1","aria-hidden":"true"})}));Yo.displayName="DefaultInfoButton";var Zo=forwardRef(({className:o,children:e,modalData:r,...a},t)=>jsx(DialogTitle,{ref:t,className:cn("novacon:flex novacon:items-center",o),...a,children:e}));Zo.displayName="DefaultTitle";var oe=forwardRef(({className:o,onClick:e,modalData:r,...a},t)=>jsx(DialogClose,{asChild:true,children:jsx("button",{ref:t,type:"button",onClick:e,className:cn("novacon:cursor-pointer novacon:rounded-full novacon:p-1 novacon:text-[var(--tuwa-text-tertiary)] novacon:transition-colors novacon:hover:bg-[var(--tuwa-bg-muted)] novacon:hover:text-[var(--tuwa-text-primary)]",o),...a,children:jsx(CloseIcon,{"aria-hidden":"true"})})}));oe.displayName="DefaultCloseButton";var ee=forwardRef(({className:o,children:e,modalData:r,...a},t)=>jsx("main",{ref:t,className:cn("novacon:flex novacon:flex-col novacon:gap-4 novacon:p-4",o),id:"connect-modal-content",role:"main",...a,children:e}));ee.displayName="DefaultMainContent";var te=forwardRef(({className:o,children:e,modalData:r,...a},t)=>jsx("footer",{ref:t,className:cn("novacon:flex novacon:w-full novacon:items-center novacon:justify-between novacon:border-t novacon:border-[var(--tuwa-border-primary)] novacon:p-4",o),role:"contentinfo",...a,children:e}));te.displayName="DefaultFooter";var ne=forwardRef(({className:o,onClick:e,children:r,modalData:a,...t},f)=>jsx("button",{ref:f,type:"button",onClick:e,className:cn(standardButtonClasses,o),...t,children:r}));ne.displayName="DefaultBackButton";var re=forwardRef(({className:o,onClick:e,children:r,disabled:a,loading:t,buttonConfig:f,modalData:u,...R},B)=>jsx("button",{ref:B,type:"button",onClick:e,disabled:a||t,className:cn(standardButtonClasses,o),...R,children:t?"Loading...":r}));re.displayName="DefaultActionButton";var ae=forwardRef(({className:o,children:e,modalData:r,...a},t)=>jsx("span",{ref:t,className:cn("novacon:sr-only",o),...a,children:e}));ae.displayName="DefaultActionDescription";var se=forwardRef(({children:o,className:e,...r},a)=>{let{modalData:t,...f}=r;return jsx("div",{ref:a,className:e,...f,children:o})});se.displayName="DefaultEmptyState";var ho=memo(({appChains:o,solanaRPCUrls:e,withImpersonated:r,customization:a={}})=>{let{isConnectModalOpen:t,setIsConnectModalOpen:f$1,setConnectModalContentType:u$1,setActiveConnector:R,setImpersonatedAddress:B$1,setIsConnected:N,connectModalContentType:b,selectedAdapter:d$1,setSelectedAdapter:O,isConnected:H,activeConnector:T,impersonatedAddress:E}=d(),P=h(l=>l.connectionError),x$1=h(l=>l.getConnectors),s$1=h(l=>l.connect),z$1=h(l=>l.activeConnection),m=h$1(),W=useContext(f),C$1=useMemo(()=>{if(t)return x$1()},[t,x$1]),D=useMemo(()=>u({connectors:C$1,selectedAdapter:d$1}),[C$1,d$1]),F=useMemo(()=>P?typeof P=="string"?new Error(P):P:null,[P]),n=useMemo(()=>({contentType:b,selectedAdapter:d$1,activeConnector:T,impersonatedAddress:E,isConnected:H,isOpen:t,error:F,connectors:C$1,filteredConnectors:D,labels:m}),[b,d$1,T,E,H,t,F,C$1,D,m]);useEffect(()=>{t&&(u$1("connectors"),O(void 0),R(void 0),B$1(""),N(false));},[t]);let{components:v$1={},classNames:g={},handlers:p$1={},config:h$2={},childComponents:c={}}=a,y$1=v$1.ModalContainer||Qo,M=v$1.ModalHeader||Xo,V=v$1.InfoButton||Yo,_=v$1.Title||Zo,q$1=v$1.CloseButton||oe,J=v$1.MainContent||ee,Q=v$1.Footer||te,so=v$1.BackButton||ne,X=v$1.ActionButton||re,io=v$1.ActionDescription||ae,G=v$1.EmptyState||se,vo=v$1.Dialog||Dialog,co=v$1.DialogContent||DialogContent,eo=v$1.MotionDiv||motion.div,to=useCallback(()=>{switch(b){case "about":return m.aboutWallets;case "getWallet":return m.getWallet;case "connecting":return d$1&&T&&C$1&&ze(C$1[d$1],T)||m.connectingEllipsis;case "impersonate":return m.connectImpersonatedWallet;default:return m.connectWallet}},[b,d$1,T,C$1,m]),Y=useCallback(()=>"connectors",[b]),Z=useCallback(l=>{p$1?.onOpenChange?p$1.onOpenChange(l,n):f$1(l);},[p$1?.onOpenChange,n,f$1]),bo=useCallback(()=>{let l=()=>u$1(Y());p$1?.onBack?p$1.onBack(n,l):l();},[p$1?.onBack,n,u$1,Y]),go=useCallback(()=>{p$1?.onInfoClick?p$1.onInfoClick(n):u$1("about");},[p$1?.onInfoClick,n,u$1]),j=useCallback(async(l,yo)=>{await s$1({connectorType:l,chainId:q({appChains:o,selectedAdapter:yo,solanaRPCUrls:e})});try{await waitFor(()=>W?.getState().activeConnection?.isConnected),N(!0);let To=setTimeout(()=>f$1(!1),400),de=setTimeout(()=>N(!1),500);await delay(null,500),clearTimeout(To),clearTimeout(de);}catch(To){console.error(To);}},[s$1,o,d$1,e]),$=useCallback(async(l,yo)=>{O(l),u$1("connecting"),await j(yo,l);},[j]),Bo=useCallback(l=>{R(formatConnectorName(l.name)),l.adapters.length===1?(O(l.adapters[0]),u$1(formatConnectorName(l.name)==="impersonatedwallet"?"impersonate":"connecting")):d$1?u$1(formatConnectorName(l.name)==="impersonatedwallet"?"impersonate":"connecting"):formatConnectorName(l.name)==="impersonatedwallet"?u$1("impersonate"):u$1("network");},[d$1]),ce=useCallback(()=>{switch(b){case "network":return jsx(B,{activeConnector:T,connectors:D,onClick:$,customization:c.networkSelections});case "connectors":return C$1?jsxs(Fragment,{children:[jsx(C,{networks:Object.keys(C$1),selectedAdapter:d$1,onSelect:l=>O(l),customization:c.networkTabs}),jsx(y,{isOnlyOneNetwork:Object.keys(C$1).length===1,connectors:D,selectedAdapter:d$1,onClick:Bo,setContentType:u$1,appChains:o,solanaRPCUrls:e,setIsConnected:N,setIsOpen:f$1,withImpersonated:r,customization:c.connectorsSelections})]}):jsx(G,{className:g.emptyConnectors?.({modalData:n}),modalData:n,children:"No connectors available"});case "about":return jsx(s,{customization:c.aboutWallets});case "getWallet":return jsx(z,{customization:c.getWallet});case "connecting":return jsx(v,{selectedAdapter:d$1,connectors:D,activeConnector:T,isConnected:H,customization:c.connecting});case "impersonate":return jsx(A,{selectedAdapter:d$1,impersonatedAddress:E,setImpersonatedAddress:B$1,customization:c.impersonateForm})}},[b,T,D,$,c,C$1,d$1,Bo,H,E]),K=useCallback(()=>{switch(b){case "connectors":return {title:m.iDontHaveWallet,onClick:()=>{p$1.onActionClick?.connectors?p$1.onActionClick.connectors(n):u$1("getWallet");}};case "getWallet":return {title:m.choseWallet,onClick:()=>{p$1.onActionClick?.getWallet?p$1.onActionClick.getWallet(n):window.open(x[d$1??Object.keys(C$1)[0]]?.choseWallet,"_blank","noopener,noreferrer");}};case "about":return {title:m.learnMore,onClick:()=>{p$1.onActionClick?.about?p$1.onActionClick.about(n):window.open(x[d$1??Object.keys(C$1)[0]]?.about,"_blank","noopener,noreferrer");}};case "impersonate":return {title:m.connect,onClick:async()=>{if(p$1.onActionClick?.impersonate)await p$1.onActionClick.impersonate(n);else {let l=E.trim();if(P||!l||p(l)||z$1?.isConnected)return;impersonatedHelpers.setImpersonated(l),u$1("connecting"),await j(getConnectorTypeFromName(d$1??OrbitAdapter.EVM,T??""),d$1??OrbitAdapter.EVM);}}};case "connecting":return P&&d$1&&T?{title:m.tryAgain,onClick:async()=>{p$1.onActionClick?.connecting?await p$1.onActionClick.connecting(n):await j(getConnectorTypeFromName(d$1,T),d$1);}}:void 0}},[b,m,p$1,n,d$1,C$1,E,P,j,T])(),le=useCallback(()=>{switch(b){case "getWallet":return "Opens external wallet selection page";case "about":return "Opens external documentation";case "impersonate":return "Connects with impersonated wallet address";case "connecting":return "Retries wallet connection";default:return ""}},[b]);return jsx(vo,{open:t,onOpenChange:Z,children:jsx(co,{className:cn("novacon:w-full novacon:sm:max-w-md"),children:jsx(eo,{layout:true,transition:{layout:{duration:h$2.animation?.disabled?0:h$2.animation?.layoutDuration??1e-4}},children:jsxs(y$1,{className:g.modalContainer?.({modalData:n}),modalData:n,children:[jsxs(M,{className:g.header?.({modalData:n}),modalData:n,children:[jsxs(_,{className:g.title?.({modalData:n}),modalData:n,children:[b==="connectors"&&jsx(V,{className:g.infoButton?.({modalData:n}),onClick:go,"aria-label":h$2.ariaLabels?.infoButton?.(n)||`${m.learnMore} ${m.aboutWallets}`,modalData:n}),to()]}),jsx(q$1,{className:g.closeButton?.({modalData:n}),onClick:()=>Z(false),"aria-label":h$2.ariaLabels?.closeButton?.(n)||m.closeModal,modalData:n})]}),jsx(J,{className:g.mainContent?.({modalData:n}),modalData:n,children:ce()}),jsxs(Q,{className:g.footer?.({modalData:n}),modalData:n,children:[jsx("div",{className:"novacon:flex novacon:items-center novacon:gap-4",children:b!=="connectors"&&jsx(so,{className:g.backButton?.({modalData:n}),onClick:bo,"aria-label":h$2.ariaLabels?.backButton?.(n)||`${m.back} to previous step`,modalData:n,children:m.back})}),K&&jsxs("div",{className:"novacon:flex novacon:items-center novacon:gap-3",children:[jsx(X,{className:g.actionButton?.({modalData:n,buttonConfig:K}),onClick:K.onClick,disabled:K.disabled,loading:K.loading,"aria-describedby":"bottom-action-description",modalData:n,buttonConfig:K,children:K.title}),jsx(io,{id:"bottom-action-description",className:g.actionDescription?.({modalData:n}),modalData:n,children:le()})]})]})]})})})})});ho.displayName="ConnectModal";var Fe=({labels:o,children:e})=>jsx(Eo,{labels:o,children:e}),Ve=({customization:o})=>jsx(No,{customization:o}),Ue=(o,e)=>deepMerge(o,e||{}),Ge=o=>o,je=o=>o,$e=(o,e,r)=>o;function Ke({labels:o,children:e,appChains:r$1,solanaRPCUrls:a$1,transactionPool:t,pulsarAdapter:f,withImpersonated:u,withBalance:R,withChain:B,customization:N}){let b=h($=>$.activeConnection),d=h($=>$.connectionError),{LabelsProvider:O=Fe,ErrorsProvider:H=Ve}=N?.components??{},{merge:T=Ue,transform:E=Ge}=N?.labels??{},{transform:P=je}=N?.contextValue??{},{providerTree:x=$e}=N?.rendering??{},s=useMemo(()=>T(a,o||{}),[o,T]),[z,m]=useState(false),[W,C]=useState(false),[D,F]=useState(false),[n,v]=useState(false),[g,p]=useState("idle"),[h$1,c$1]=useState("connectors"),[y,M]=useState(void 0),[V,_]=useState(void 0),[q,J]=useState(""),[Q,so]=useState(false),[X,io]=useState("main"),G=useMemo(()=>({isConnected:Q,activeConnection:b,connectionError:d,modalStates:{isConnectModalOpen:z,isConnectedModalOpen:W,isChainsListOpen:D,isChainsListOpenMobile:n},contentTypes:{connectModal:h$1,connectedModal:X},statuses:{connectedButton:g}}),[Q,b,d,z,W,D,n,h$1,X,g]),vo=useMemo(()=>E(s,G),[s,E,G]),co=useMemo(()=>P({appChains:r$1,solanaRPCUrls:a$1,withImpersonated:u,withBalance:R,withChain:B,isConnectModalOpen:z,setIsConnectModalOpen:m,isConnectedModalOpen:W,setIsConnectedModalOpen:C,isChainsListOpen:D,setIsChainsListOpen:F,isChainsListOpenMobile:n,setIsChainsListOpenMobile:v,connectedButtonStatus:g,setConnectedButtonStatus:p,connectedModalContentType:X,setConnectedModalContentType:io,connectModalContentType:h$1,setConnectModalContentType:c$1,selectedAdapter:y,setSelectedAdapter:M,activeConnector:V,setActiveConnector:_,impersonatedAddress:q,setImpersonatedAddress:J,isConnected:Q,setIsConnected:so},G),[r$1,a$1,u,R,B,z,m,W,C,D,F,n,v,g,p,X,io,h$1,c$1,y,M,V,_,q,J,Q,so,P,G]),eo=jsx(H,{customization:N?.errors}),to=jsx(O,{labels:vo,children:e}),Y=r$1||a$1?jsx(ho,{withImpersonated:u,solanaRPCUrls:a$1,appChains:r$1,customization:N?.modals?.connectModal}):null,Z=r$1||a$1?jsx(r,{solanaRPCUrls:a$1,appChains:r$1,transactionPool:t,pulsarAdapter:f,customization:N?.modals?.connectedModal}):null,bo=jsxs(c.Provider,{value:co,children:[eo,to,Y,Z]}),go=jsxs(c.Provider,{value:co,children:[eo,to,Y,Z]}),j=x(go,{ErrorsProvider:eo,LabelsProvider:to,MainContent:bo,ConnectModal:Y||jsx(Fragment,{}),ConnectedModal:Z||jsx(Fragment,{})},G);return jsx(Fragment,{children:j})}Ke.displayName="NovaConnectProvider";async function Jn(){let{getAllAdaptersStatus:o}=await import('./getChainsListByConnectorType-W6UDLFBJ.js');return {hasEvmUtils:await Co(),hasSolanaUtils:await fo(),adaptersStatus:o()}}async function Co(){try{return await import('viem'),await import('@tuwaio/orbit-evm'),!0}catch{return false}}async function fo(){try{return await import('gill'),await import('@tuwaio/orbit-solana'),!0}catch{return false}}async function Qn(){try{return await Co()?{available:!0,...await import('./evm/index.js')}:{available:!1,error:"EVM packages (viem, @tuwaio/orbit-evm) not available"}}catch(o){return {available:false,error:o instanceof Error?o.message:"EVM utilities not available"}}}async function Xn(){try{return await fo()?{available:!0,...await import('./solana/index.js')}:{available:!1,error:"Solana packages (gill, @tuwaio/orbit-solana) not available"}}catch(o){return {available:false,error:o instanceof Error?o.message:"Solana utilities not available"}}}async function Yn(){let o={evm:false,solana:false,errors:[]};try{let e=await Co(),r=await fo();if(e||r){let{preloadChainAdapters:a}=await import('./getChainsListByConnectorType-W6UDLFBJ.js'),t=[];e&&t.push(OrbitAdapter.EVM),r&&t.push(OrbitAdapter.SOLANA),await a(t),o.evm=e,o.solana=r;}else o.errors.push("No blockchain packages available for initialization");}catch(e){let r=e instanceof Error?e.message:"Unknown initialization error";o.errors.push(r);}return o}async function Zn(o){switch(o){case OrbitAdapter.EVM:return Co();case OrbitAdapter.SOLANA:return fo();case OrbitAdapter.Starknet:return false;default:return false}}export{No as ErrorsProvider,Eo as NovaConnectLabelsProvider,Ke as NovaConnectProvider,Jn as getBlockchainUtilities,Qn as getEvmUtils,Xn as getSolanaUtils,Yn as initializeBlockchainSupport,Zn as isAdapterSupported};//# sourceMappingURL=index.js.map
1
+ import {A,v,z,s,C,y,B,r,D}from'./chunk-IJAOXAYK.js';import {d,h as h$1,u,q,p,x,g,c}from'./chunk-5NO4S3N6.js';export{g as NovaConnectLabelsContext,c as NovaConnectProviderContext,b as NovaConnectProviderError,o as createLabelsSubset,r as getAvailableChainIds,y as getAvailableSolanaClusters,q as getConnectChainId,u as getFilteredConnectors,s as getGroupedConnectors,n as getLabelWithFallback,w as getNetworkIcon,t as hasAvailableConnectors,v as hasConnectorsForAdapter,k as hasLabel,p as isAddress,m as isDefaultLabels,z as isValidSolanaCluster,x as networksLinks,a as useGetWalletNameAndAvatar,e as useHasNovaConnectContext,l as useLabelsByCategory,d as useNovaConnect,i as useNovaConnectLabel,h as useNovaConnectLabels,j as useNovaConnectLabelsSubset,f as useNovaConnectOptional,A as useWalletChainsList,B as useWalletNativeBalance}from'./chunk-5NO4S3N6.js';export{k as getAdapterStatus,l as getAllAdaptersStatus,g as getAvailableSolanaClustersAsync,b as getChainsListByConnectorType,a as getChainsListByConnectorTypeAsync,b as getChainsListByConnectorTypeSync,i as getWalletChains,e as isEvmChainList,c as isEvmChainListAsync,e as isEvmChainListSync,f as isSolanaChainList,d as isSolanaChainListAsync,f as isSolanaChainListSync,h as isValidSolanaClusterAsync,j as preloadChainAdapters}from'./chunk-AIK5PZKK.js';import {a}from'./chunk-3BMX6JWH.js';import {h,f}from'./chunk-2T6SPFUT.js';import {waitFor,delay,formatConnectorName,getConnectorTypeFromName,impersonatedHelpers,OrbitAdapter}from'@tuwaio/orbit-core';import {cn,DialogHeader,DialogTitle,DialogClose,CloseIcon,standardButtonClasses,Dialog,DialogContent,ToastCloseButton,deepMerge}from'@tuwaio/nova-core';import {forwardRef,memo,useContext,useMemo,useEffect,useCallback,useRef,useState}from'react';import {toast,Bounce,ToastContainer}from'react-toastify';import {jsx,jsxs,Fragment}from'react/jsx-runtime';import {InformationCircleIcon}from'@heroicons/react/24/outline';import {motion}from'framer-motion';var fe=({title:o,rawError:t,onCopyComplete:r,errorType:n,isConnected:e,...l})=>jsx(D,{title:o,rawError:t,onCopyComplete:r,customization:l.customization}),ve=o=>{let t=h$1();return jsx(ToastContainer,{...o,role:"alert","aria-live":"assertive","aria-label":t.somethingWentWrong})},ge=(o,t)=>{o(t.title,t.rawError,t.errorKey);},be=o=>{o();},ye=(o,t)=>{o&&process.env.NODE_ENV==="development"&&console.log("Error copied to clipboard:",t.substring(0,100));},Te=o=>o,Ee=o=>o;function Po({containerId:o="nova-connect-errors",position:t="top-center",autoClose:r=7e3,draggable:n=false,customization:e}){let l=h$1(),s=h(d=>d.switchNetworkError),x=h(d=>d.activeConnection),k=h(d=>d.connectionError),{ToastError:h$2=fe,Container:g=ve}=e?.components??{},{showError:u=ge,dismissError:O=be,onCopyComplete:H=ye}=e?.handlers??{},{errorTitle:T=Te,errorHash:P=Ee}=e??{},M=useRef(new Set),R=useRef(null),i=useMemo(()=>{let d=!!k,y=!!s,D=!!x?.isConnected;return {hasWalletError:d,hasSwitchError:y,isConnected:D,hasAnyError:d||y,primaryError:k||s||null,errorType:d?"wallet":y?"switch":null}},[k,s,x?.isConnected]),z=useMemo(()=>{switch(i.errorType){case "wallet":return l.connectionError;case "switch":return l.errorWhenChainSwitching;default:return l.somethingWentWrong}},[i.errorType,l]),p=useMemo(()=>T(z,{errorType:i.errorType}),[T,z,i.errorType]),I=useMemo(()=>i.primaryError?`${i.errorType}-${i.primaryError.substring(0,50)}`:null,[i.primaryError,i.errorType]),f=useMemo(()=>P(I,{primaryError:i.primaryError,errorType:i.errorType}),[P,I,i.primaryError,i.errorType]),E=useCallback(()=>{O(()=>{R.current&&(toast.dismiss(R.current),R.current=null),toast.dismiss({containerId:o});});},[o,O]),F=useCallback((d,y)=>{H(d,y,i.errorType);},[H,i.errorType]),a=useCallback((d,y,D)=>{if(E(),!M.current.has(D))try{let V={containerId:o,toastId:D,onClose:()=>{M.current.delete(D),R.current=null;}},K=e?.toastOptions?.error?.({title:d,rawError:y,errorType:i.errorType,isConnected:i.isConnected}),J={...V,...K};toast.error(jsx(h$2,{title:d,rawError:y,errorType:i.errorType,isConnected:i.isConnected,onCopyComplete:Q=>F(Q,y),customization:e?.toastErrorCustomization}),J),M.current.add(D),R.current=D;}catch(V){console.error("Failed to show error toast:",V);}},[E,o,e?.toastOptions?.error,e?.toastErrorCustomization,h$2,i.errorType,i.isConnected,F]),v=useCallback((d,y,D)=>{u(a,{title:d,rawError:y,errorKey:D,errorType:i.errorType});},[a,u,i.errorType]);useEffect(()=>{let{hasAnyError:d,isConnected:y,primaryError:D}=i;if(y&&!d){E(),M.current.clear();return}if(d&&D&&f){if(y&&i.errorType!=="switch")return;v(p,D,f);}},[i,p,f,v,E]),useEffect(()=>()=>{E(),M.current.clear();},[E]);let b=useMemo(()=>e?.classNames?.container?e.classNames.container({hasErrors:i.hasAnyError,errorType:i.errorType}):"novacon:p-0 novacon:bg-transparent",[e,i.hasAnyError,i.errorType]),C=useMemo(()=>({containerId:o,position:t,closeOnClick:false,icon:false,closeButton:ToastCloseButton,autoClose:r,hideProgressBar:false,newestOnTop:false,pauseOnFocusLoss:false,draggable:n,pauseOnHover:true,theme:"light",transition:Bounce}),[o,t,r,n]),N=useMemo(()=>({...C,...e?.containerProps,className:b}),[C,e?.containerProps,b]);return jsx(g,{...N})}Po.displayName="ErrorsProvider";function No({labels:o,children:t}){let r=useMemo(()=>o,[o]);if(process.env.NODE_ENV==="development"){(!o||typeof o!="object")&&console.warn("NovaConnectLabelsProvider: labels prop should be an object");let e=["connectWallet","disconnect","connecting","connected","error","success"].filter(l=>!(l in o));e.length>0&&console.warn(`NovaConnectLabelsProvider: Missing required labels: ${e.join(", ")}`);}return jsx(g.Provider,{value:r,children:t})}No.displayName="NovaConnectLabelsProvider";function Ie(o,t){if(!o||!Array.isArray(o)||!t)return;let r=o.find(n=>n&&typeof n=="object"&&"name"in n&&typeof n.name=="string"?formatConnectorName(n.name)===t:false);return r&&typeof r=="object"&&"name"in r&&typeof r.name=="string"?r.name:void 0}var Xo=forwardRef(({className:o,children:t,modalData:r,...n},e)=>jsx("div",{ref:e,className:cn("novacon:relative novacon:flex novacon:w-full novacon:flex-col",o),...n,children:t}));Xo.displayName="DefaultModalContainer";var Yo=forwardRef(({className:o,children:t,modalData:r,...n},e)=>jsx("div",{ref:e,className:o,...n,children:jsx(DialogHeader,{children:t})}));Yo.displayName="DefaultModalHeader";var Zo=forwardRef(({className:o,onClick:t,modalData:r,...n},e)=>jsx("button",{ref:e,className:cn("novacon:cursor-pointer novacon:text-[var(--tuwa-text-secondary)] novacon:transition novacon:duration-300 novacon:ease-in-out novacon:active:scale-75 novacon:hover:scale-110",o),type:"button",onClick:t,...n,children:jsx(InformationCircleIcon,{width:20,height:20,className:"novacon:mr-1","aria-hidden":"true"})}));Zo.displayName="DefaultInfoButton";var oe=forwardRef(({className:o,children:t,modalData:r,...n},e)=>jsx(DialogTitle,{ref:e,className:cn("novacon:flex novacon:items-center",o),...n,children:t}));oe.displayName="DefaultTitle";var ee=forwardRef(({className:o,onClick:t,modalData:r,...n},e)=>jsx(DialogClose,{asChild:true,children:jsx("button",{ref:e,type:"button",onClick:t,className:cn("novacon:cursor-pointer novacon:rounded-full novacon:p-1 novacon:text-[var(--tuwa-text-tertiary)] novacon:transition-colors novacon:hover:bg-[var(--tuwa-bg-muted)] novacon:hover:text-[var(--tuwa-text-primary)]",o),...n,children:jsx(CloseIcon,{"aria-hidden":"true"})})}));ee.displayName="DefaultCloseButton";var te=forwardRef(({className:o,children:t,modalData:r,...n},e)=>jsx("main",{ref:e,className:cn("novacon:flex novacon:flex-col novacon:gap-4 novacon:p-4",o),id:"connect-modal-content",role:"main",...n,children:t}));te.displayName="DefaultMainContent";var ne=forwardRef(({className:o,children:t,modalData:r,...n},e)=>jsx("footer",{ref:e,className:cn("novacon:flex novacon:w-full novacon:items-center novacon:justify-between novacon:border-t novacon:border-[var(--tuwa-border-primary)] novacon:p-4",o),role:"contentinfo",...n,children:t}));ne.displayName="DefaultFooter";var re=forwardRef(({className:o,onClick:t,children:r,modalData:n,...e},l)=>jsx("button",{ref:l,type:"button",onClick:t,className:cn(standardButtonClasses,o),...e,children:r}));re.displayName="DefaultBackButton";var ae=forwardRef(({className:o,onClick:t,children:r,disabled:n,loading:e,buttonConfig:l,modalData:s,...x},k)=>jsx("button",{ref:k,type:"button",onClick:t,disabled:n||e,className:cn(standardButtonClasses,o),...x,children:e?"Loading...":r}));ae.displayName="DefaultActionButton";var se=forwardRef(({className:o,children:t,modalData:r,...n},e)=>jsx("span",{ref:e,className:cn("novacon:sr-only",o),...n,children:t}));se.displayName="DefaultActionDescription";var ie=forwardRef(({children:o,className:t,...r},n)=>{let{modalData:e,...l}=r;return jsx("div",{ref:n,className:t,...l,children:o})});ie.displayName="DefaultEmptyState";var wo=memo(({appChains:o,solanaRPCUrls:t,withImpersonated:r,customization:n={}})=>{let{isConnectModalOpen:e,setIsConnectModalOpen:l,setConnectModalContentType:s$1,setActiveConnector:x$1,setImpersonatedAddress:k,setIsConnected:h$2,connectModalContentType:g,selectedAdapter:u$1,setSelectedAdapter:O,isConnected:H,activeConnector:T,impersonatedAddress:P}=d(),M=h(m=>m.connectionError),R=h(m=>m.getConnectors),i=h(m=>m.connect),z$1=h(m=>m.activeConnection),p$1=h$1(),I=useContext(f),f$1=useMemo(()=>{if(e)return R()},[e,R]),E=useMemo(()=>u({connectors:f$1,selectedAdapter:u$1}),[f$1,u$1]),F=useMemo(()=>M?typeof M=="string"?new Error(M):M:null,[M]),a=useMemo(()=>({contentType:g,selectedAdapter:u$1,activeConnector:T,impersonatedAddress:P,isConnected:H,isOpen:e,error:F,connectors:f$1,filteredConnectors:E,labels:p$1}),[g,u$1,T,P,H,e,F,f$1,E,p$1]);useEffect(()=>{e&&(s$1("connectors"),O(void 0),x$1(void 0),k(""),h$2(false));},[e]);let{components:v$1={},classNames:b={},handlers:C$1={},config:N={},childComponents:d$1={}}=n,y$1=v$1.ModalContainer||Xo,D=v$1.ModalHeader||Yo,V=v$1.InfoButton||Zo,K=v$1.Title||oe,J=v$1.CloseButton||ee,Q=v$1.MainContent||te,X=v$1.Footer||ne,io=v$1.BackButton||re,Y=v$1.ActionButton||ae,lo=v$1.ActionDescription||se,G=v$1.EmptyState||ie,go=v$1.Dialog||Dialog,co=v$1.DialogContent||DialogContent,to=v$1.MotionDiv||motion.div,no=useCallback(()=>{switch(g){case "about":return p$1.aboutWallets;case "getWallet":return p$1.getWallet;case "connecting":return u$1&&T&&f$1&&Ie(f$1[u$1],T)||p$1.connectingEllipsis;case "impersonate":return p$1.connectImpersonatedWallet;default:return p$1.connectWallet}},[g,u$1,T,f$1,p$1]),Z=useCallback(()=>"connectors",[g]),oo=useCallback(m=>{C$1?.onOpenChange?C$1.onOpenChange(m,a):l(m);},[C$1?.onOpenChange,a,l]),bo=useCallback(()=>{let m=()=>s$1(Z());C$1?.onBack?C$1.onBack(a,m):m();},[C$1?.onBack,a,s$1,Z]),yo=useCallback(()=>{C$1?.onInfoClick?C$1.onInfoClick(a):s$1("about");},[C$1?.onInfoClick,a,s$1]),_=useCallback(async(m,To)=>{await i({connectorType:m,chainId:q({appChains:o,selectedAdapter:To,solanaRPCUrls:t})});try{await waitFor(()=>I?.getState().activeConnection?.isConnected),h$2(!0);let Eo=setTimeout(()=>l(!1),400),me=setTimeout(()=>h$2(!1),500);await delay(null,500),clearTimeout(Eo),clearTimeout(me);}catch(Eo){console.error(Eo);}},[i,o,u$1,t]),j=useCallback(async(m,To)=>{O(m),s$1("connecting"),await _(To,m);},[_]),Bo=useCallback(m=>{x$1(formatConnectorName(m.name)),m.adapters.length===1?(O(m.adapters[0]),s$1(formatConnectorName(m.name)==="impersonatedwallet"?"impersonate":"connecting")):u$1?s$1(formatConnectorName(m.name)==="impersonatedwallet"?"impersonate":"connecting"):formatConnectorName(m.name)==="impersonatedwallet"?s$1("impersonate"):s$1("network");},[u$1]),ce=useCallback(()=>{switch(g){case "network":return jsx(B,{activeConnector:T,connectors:E,onClick:j,customization:d$1.networkSelections});case "connectors":return f$1?jsxs(Fragment,{children:[jsx(C,{networks:Object.keys(f$1),selectedAdapter:u$1,onSelect:m=>O(m),customization:d$1.networkTabs}),jsx(y,{isOnlyOneNetwork:Object.keys(f$1).length===1,connectors:E,selectedAdapter:u$1,onClick:Bo,setContentType:s$1,appChains:o,solanaRPCUrls:t,setIsConnected:h$2,setIsOpen:l,withImpersonated:r,customization:d$1.connectorsSelections})]}):jsx(G,{className:b.emptyConnectors?.({modalData:a}),modalData:a,children:"No connectors available"});case "about":return jsx(s,{customization:d$1.aboutWallets});case "getWallet":return jsx(z,{customization:d$1.getWallet});case "connecting":return jsx(v,{selectedAdapter:u$1,connectors:E,activeConnector:T,isConnected:H,customization:d$1.connecting});case "impersonate":return jsx(A,{selectedAdapter:u$1,impersonatedAddress:P,setImpersonatedAddress:k,customization:d$1.impersonateForm})}},[g,T,E,j,d$1,f$1,u$1,Bo,H,P]),$=useCallback(()=>{switch(g){case "connectors":return {title:p$1.iDontHaveWallet,onClick:()=>{C$1.onActionClick?.connectors?C$1.onActionClick.connectors(a):s$1("getWallet");}};case "getWallet":return {title:p$1.choseWallet,onClick:()=>{C$1.onActionClick?.getWallet?C$1.onActionClick.getWallet(a):window.open(x[u$1??Object.keys(f$1)[0]]?.choseWallet,"_blank","noopener,noreferrer");}};case "about":return {title:p$1.learnMore,onClick:()=>{C$1.onActionClick?.about?C$1.onActionClick.about(a):window.open(x[u$1??Object.keys(f$1)[0]]?.about,"_blank","noopener,noreferrer");}};case "impersonate":return {title:p$1.connect,onClick:async()=>{if(C$1.onActionClick?.impersonate)await C$1.onActionClick.impersonate(a);else {let m=P.trim();if(M||!m||p(m)||z$1?.isConnected)return;impersonatedHelpers.setImpersonated(m),s$1("connecting"),await _(getConnectorTypeFromName(u$1??OrbitAdapter.EVM,T??""),u$1??OrbitAdapter.EVM);}}};case "connecting":return M&&u$1&&T?{title:p$1.tryAgain,onClick:async()=>{C$1.onActionClick?.connecting?await C$1.onActionClick.connecting(a):await _(getConnectorTypeFromName(u$1,T),u$1);}}:void 0}},[g,p$1,C$1,a,u$1,f$1,P,M,_,T])(),de=useCallback(()=>{switch(g){case "getWallet":return "Opens external wallet selection page";case "about":return "Opens external documentation";case "impersonate":return "Connects with impersonated wallet address";case "connecting":return "Retries wallet connection";default:return ""}},[g]);return jsx(go,{open:e,onOpenChange:oo,children:jsx(co,{className:cn("novacon:w-full novacon:sm:max-w-md"),children:jsx(to,{layout:true,transition:{layout:{duration:N.animation?.disabled?0:N.animation?.layoutDuration??1e-4}},children:jsxs(y$1,{className:b.modalContainer?.({modalData:a}),modalData:a,children:[jsxs(D,{className:b.header?.({modalData:a}),modalData:a,children:[jsxs(K,{className:b.title?.({modalData:a}),modalData:a,children:[g==="connectors"&&jsx(V,{className:b.infoButton?.({modalData:a}),onClick:yo,"aria-label":N.ariaLabels?.infoButton?.(a)||`${p$1.learnMore} ${p$1.aboutWallets}`,modalData:a}),no()]}),jsx(J,{className:b.closeButton?.({modalData:a}),onClick:()=>oo(false),"aria-label":N.ariaLabels?.closeButton?.(a)||p$1.closeModal,modalData:a})]}),jsx(Q,{className:b.mainContent?.({modalData:a}),modalData:a,children:ce()}),jsxs(X,{className:b.footer?.({modalData:a}),modalData:a,children:[jsx("div",{className:"novacon:flex novacon:items-center novacon:gap-4",children:g!=="connectors"&&jsx(io,{className:b.backButton?.({modalData:a}),onClick:bo,"aria-label":N.ariaLabels?.backButton?.(a)||`${p$1.back} to previous step`,modalData:a,children:p$1.back})}),$&&jsxs("div",{className:"novacon:flex novacon:items-center novacon:gap-3",children:[jsx(Y,{className:b.actionButton?.({modalData:a,buttonConfig:$}),onClick:$.onClick,disabled:$.disabled,loading:$.loading,"aria-describedby":"bottom-action-description",modalData:a,buttonConfig:$,children:$.title}),jsx(lo,{id:"bottom-action-description",className:b.actionDescription?.({modalData:a}),modalData:a,children:de()})]})]})]})})})})});wo.displayName="ConnectModal";var Ve=({labels:o,children:t})=>jsx(No,{labels:o,children:t}),Ue=({customization:o})=>jsx(Po,{customization:o}),qe=(o,t)=>deepMerge(o,t||{}),Ge=o=>o,_e=o=>o,je=(o,t,r)=>o;function $e({labels:o,children:t,appChains:r$1,solanaRPCUrls:n,transactionPool:e,pulsarAdapter:l,withImpersonated:s,withBalance:x,withChain:k,customization:h$1}){let g=h(j=>j.activeConnection),u=h(j=>j.connectionError),{LabelsProvider:O=Ve,ErrorsProvider:H=Ue}=h$1?.components??{},{merge:T=qe,transform:P=Ge}=h$1?.labels??{},{transform:M=_e}=h$1?.contextValue??{},{providerTree:R=je}=h$1?.rendering??{},i=useMemo(()=>T(a,o||{}),[o,T]),[z,p]=useState(false),[I,f]=useState(false),[E,F]=useState(false),[a$1,v]=useState(false),[b,C]=useState("idle"),[N,d]=useState("connectors"),[y,D]=useState(void 0),[V,K]=useState(void 0),[J,Q]=useState(""),[X,io]=useState(false),[Y,lo]=useState("main"),G=useMemo(()=>({isConnected:X,activeConnection:g,connectionError:u,modalStates:{isConnectModalOpen:z,isConnectedModalOpen:I,isChainsListOpen:E,isChainsListOpenMobile:a$1},contentTypes:{connectModal:N,connectedModal:Y},statuses:{connectedButton:b}}),[X,g,u,z,I,E,a$1,N,Y,b]),go=useMemo(()=>P(i,G),[i,P,G]),co=useMemo(()=>M({appChains:r$1,solanaRPCUrls:n,withImpersonated:s,withBalance:x,withChain:k,isConnectModalOpen:z,setIsConnectModalOpen:p,isConnectedModalOpen:I,setIsConnectedModalOpen:f,isChainsListOpen:E,setIsChainsListOpen:F,isChainsListOpenMobile:a$1,setIsChainsListOpenMobile:v,connectedButtonStatus:b,setConnectedButtonStatus:C,connectedModalContentType:Y,setConnectedModalContentType:lo,connectModalContentType:N,setConnectModalContentType:d,selectedAdapter:y,setSelectedAdapter:D,activeConnector:V,setActiveConnector:K,impersonatedAddress:J,setImpersonatedAddress:Q,isConnected:X,setIsConnected:io},G),[r$1,n,s,x,k,z,p,I,f,E,F,a$1,v,b,C,Y,lo,N,d,y,D,V,K,J,Q,X,io,M,G]),to=jsx(H,{customization:h$1?.errors}),no=jsx(O,{labels:go,children:t}),Z=r$1||n?jsx(wo,{withImpersonated:s,solanaRPCUrls:n,appChains:r$1,customization:h$1?.modals?.connectModal}):null,oo=r$1||n?jsx(r,{solanaRPCUrls:n,appChains:r$1,transactionPool:e,pulsarAdapter:l,customization:h$1?.modals?.connectedModal}):null,bo=jsxs(c.Provider,{value:co,children:[to,no,Z,oo]}),yo=jsxs(c.Provider,{value:co,children:[to,no,Z,oo]}),_=R(yo,{ErrorsProvider:to,LabelsProvider:no,MainContent:bo,ConnectModal:Z||jsx(Fragment,{}),ConnectedModal:oo||jsx(Fragment,{})},G);return jsx(Fragment,{children:_})}$e.displayName="NovaConnectProvider";var so=typeof process<"u"&&process.env?.NODE_ENV==="production";async function Qn(){let{getAllAdaptersStatus:o}=await import('./getChainsListByConnectorType-VKIEDNV7.js');return {hasEvmUtils:await fo(),hasSolanaUtils:await vo(),adaptersStatus:o()}}async function fo(){if(so)try{return new Function('try { return Boolean(require("@tuwaio/orbit-evm") && require("viem")); } catch { return false; }')()}catch{return false}try{return await import('viem'),await import('@tuwaio/orbit-evm'),!0}catch{return false}}async function vo(){if(so)try{return new Function('try { return Boolean(require("@tuwaio/orbit-solana") && require("gill")); } catch { return false; }')()}catch{return false}try{return await import('gill'),await import('@tuwaio/orbit-solana'),!0}catch{return false}}async function Xn(){try{if(!await fo())return {available:!1,error:"EVM packages (viem, @tuwaio/orbit-evm) not available"};if(so)try{let e=new Function('try { return require("./evm"); } catch { return null; }')();return e?new Promise(l=>{if(typeof e.getEvmExports!="function"){l({available:!1,error:"EVM module does not have getEvmExports function"});return}e.getEvmExports().then(s=>{if(!s.available){l({available:!1,error:s.error||"Failed to load EVM exports"});return}l({...e,...s});}).catch(s=>{l({available:!1,error:s instanceof Error?s.message:"Failed to load EVM exports"});});}):{available:!1,error:"Failed to load EVM module"}}catch(n){return {available:!1,error:n instanceof Error?n.message:"Failed to load EVM module"}}let t=await import('./evm/index.js'),r=await t.getEvmExports();return r.available?{...t,...r}:{available:!1,error:r.error||"Failed to load EVM exports"}}catch(o){return {available:false,error:o instanceof Error?o.message:"EVM utilities not available"}}}async function Yn(){try{if(!await vo())return {available:!1,error:"Solana packages (gill, @tuwaio/orbit-solana) not available"};if(so)try{let e=new Function('try { return require("./solana"); } catch { return null; }')();return e?new Promise(l=>{if(typeof e.getSolanaExports!="function"){l({available:!1,error:"Solana module does not have getSolanaExports function"});return}e.getSolanaExports().then(s=>{if(!s.available){l({available:!1,error:s.error||"Failed to load Solana exports"});return}l({...e,...s});}).catch(s=>{l({available:!1,error:s instanceof Error?s.message:"Failed to load Solana exports"});});}):{available:!1,error:"Failed to load Solana module"}}catch(n){return {available:!1,error:n instanceof Error?n.message:"Failed to load Solana module"}}let t=await import('./solana/index.js'),r=await t.getSolanaExports();return r.available?{...t,...r}:{available:!1,error:r.error||"Failed to load Solana exports"}}catch(o){return {available:false,error:o instanceof Error?o.message:"Solana utilities not available"}}}async function Zn(){let o={evm:false,solana:false,errors:[]};try{let t=await fo(),r=await vo();if(t||r)if(so)try{let e=new Function('try { return require("./utils/getChainsListByConnectorType"); } catch { return null; }')();if(!e)return o.errors.push("Failed to load chain adapter utilities"),o;let l=[];t&&l.push(OrbitAdapter.EVM),r&&l.push(OrbitAdapter.SOLANA),await e.preloadChainAdapters(l),o.evm=t,o.solana=r;}catch(n){let e=n instanceof Error?n.message:"Failed to initialize chain adapters";o.errors.push(e);}else {let{preloadChainAdapters:n}=await import('./getChainsListByConnectorType-VKIEDNV7.js'),e=[];t&&e.push(OrbitAdapter.EVM),r&&e.push(OrbitAdapter.SOLANA),await n(e),o.evm=t,o.solana=r;}else o.errors.push("No blockchain packages available for initialization");}catch(t){let r=t instanceof Error?t.message:"Unknown initialization error";o.errors.push(r);}return o}async function or(o){return o===OrbitAdapter.Starknet||o!==OrbitAdapter.EVM&&o!==OrbitAdapter.SOLANA?false:o===OrbitAdapter.EVM?fo():vo()}export{Po as ErrorsProvider,No as NovaConnectLabelsProvider,$e as NovaConnectProvider,Qn as getBlockchainUtilities,Xn as getEvmUtils,Yn as getSolanaUtils,Zn as initializeBlockchainSupport,or as isAdapterSupported};//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map