@tuwaio/nova-connect 0.1.0 → 0.1.1
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/chunk-6S5OTERL.cjs +2 -0
- package/dist/chunk-6S5OTERL.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-NJDPFYUJ.js → chunk-FNWARYJY.js} +2 -2
- package/dist/{chunk-NJDPFYUJ.js.map → chunk-FNWARYJY.js.map} +1 -1
- package/dist/{chunk-KKCRUSJT.js → chunk-J4TY3CJF.js} +2 -2
- package/dist/{chunk-KKCRUSJT.js.map → chunk-J4TY3CJF.js.map} +1 -1
- 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-KXWMBNB4.js → getChainsListByWalletType-EO6A7Q5A.js} +2 -2
- package/dist/{getChainsListByWalletType-KXWMBNB4.js.map → getChainsListByWalletType-EO6A7Q5A.js.map} +1 -1
- package/dist/getChainsListByWalletType-ZU7OPWTP.cjs +2 -0
- package/dist/getChainsListByWalletType-ZU7OPWTP.cjs.map +1 -0
- package/dist/index.cjs +3 -3
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +6081 -6112
- package/dist/index.d.ts +6081 -6112
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- 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-DGsiEwne.d.cts +50 -0
- package/dist/types-DGsiEwne.d.ts +50 -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 +6 -18
- package/dist/evm-F7OJEDX3.js +0 -2
- package/dist/evm-F7OJEDX3.js.map +0 -1
- package/dist/hooks/index.cjs +0 -2
- package/dist/hooks/index.cjs.map +0 -1
- package/dist/hooks/index.js +0 -2
- package/dist/hooks/index.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
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/i18n/en.ts","../../src/hooks/useNovaConnectLabels.ts","../../src/components/Chains/ChainListRenderer.tsx","../../src/hooks/useNovaConnect.ts","../../src/utils/adapters/registry.ts","../../src/utils/getChainsListByWalletType.ts","../../src/utils/getConnectedChainId.ts","../../src/utils/getGroupedConnectors.ts","../../src/utils/getFilteredConnectors.ts","../../src/utils/getNetworIcon.ts","../../src/utils/networksLinks.ts","../../src/components/ToBottomButton.tsx","../../src/components/ToTopButton.tsx","../../src/components/SelectContentAnimated.tsx","../../src/components/Chains/ScrollableChainList.tsx","../../src/components/Chains/ChainSelector.tsx","../../src/hooks/useGetWalletNameAndAvatar.ts","../../src/hooks/useWalletNativeBalance.ts","../../src/components/ConnectedModal/ConnectedModalFooter.tsx","../../src/components/WalletAvatar.tsx","../../src/components/ConnectedModal/ConnectedModalNameAndBalance.tsx","../../src/components/WalletIcon.tsx","../../src/components/ConnectedModal/IconButton.tsx","../../src/components/ConnectedModal/ConnectedModalMainContent.tsx","../../src/components/ConnectedModal/ConnectedModalTxHistory.tsx","../../src/components/ConnectedModal/ConnectedModal.tsx","../../src/components/ConnectModal/images/digitalPassportImage.ts","../../src/components/ConnectModal/images/walletImage.ts","../../src/components/ConnectModal/AboutWallets.tsx","../../src/components/ConnectModal/Connecting.tsx","../../src/components/ConnectModal/RecentBadge.tsx","../../src/components/ConnectModal/ConnectCard.tsx","../../src/components/ConnectModal/ConnectorsBlock.tsx","../../src/components/ConnectModal/Disclaimer.tsx","../../src/components/ConnectModal/ConnectorsSelections.tsx","../../src/components/ConnectModal/GetWallet.tsx","../../src/components/ConnectModal/ImpersonatedForm.tsx","../../src/components/ConnectModal/NetworkSelections.tsx","../../src/components/ConnectModal/NetworkTabs.tsx","../../src/components/ConnectModal/ConnectModal.tsx","../../src/components/ConnectButton/StatusIcon.tsx","../../src/components/ConnectButton/ConnectedContent.tsx","../../src/components/ConnectButton/WaitForConnectionContent.tsx","../../src/components/ConnectButton/ConnectButton.tsx","../../src/components/ConnectButton/index.tsx","../../src/components/ToastError.tsx","../../src/providers/ErrorsProvider.tsx","../../src/providers/NovaConnectLabelsProvider.tsx","../../src/providers/NovaConnectProvider.tsx"],"names":["defaultLabels","NovaConnectLabelsContext","createContext","useNovaConnectLabels","useContext","DefaultChainIcon","chainId","className","props","jsx","Web3Icon","DefaultChainContent","icon","children","jsxs","DefaultActiveIndicator","isActive","label","Fragment","cn","SelectItemBase","forwardRef","forwardedRef","labels","ot","ChainListRenderer","chainsList","selectValue","handleValueChange","getChainData","onClose","isMobile","itemClassName","customization","ariaLabel","isLoading","error","ChainIcon","ChainContent","ActiveIndicator","animations","behavior","containerClasses","useMemo","customClasses","createClickHandler","useCallback","formattedChainId","chainName","originalHandler","createKeyDownHandler","clickHandler","e","event","loadingMessage","renderChainItem","chain","getChainName","itemClasses","iconClasses","chainNameClasses","handleClick","handleKeyDown","contentElement","activeIndicatorClasses","activeIndicator","MotionItem","motion","motionProps","MotionContainer","containerMotionProps","NovaConnectProviderError","message","NovaConnectProviderContext","useNovaConnect","context","LazyAdapterRegistry","type","info","adapter","OrbitAdapter","createEvmAdapter","createSolanaAdapter","err","attempts","maxAttempts","pollInterval","resolve","types","adapterInfo","adapterRegistry","isValidChainId","id","getChainsListByWalletType","params","walletType","chains","config","adapterType","getAdapterFromWalletType","getFallbackChains","getChainsListByWalletTypeSync","appChains","solanaRPCUrls","getWalletChains","activeWallet","DEFAULT_CHAIN_IDS","getConnectChainId","selectedAdapter","firstChain","networks","processConnector","connector","connectorObj","getGroupedConnectors","connectors","excludeConnectors","excludeSet","name","formatWalletName","processedConnectors","adapterKey","adapterConnectors","processed","formattedName","groupedMap","group","a","b","getConnectorAdapter","connectorMatchesAdapter","getFilteredConnectors","groupedConnectors","filteredConnectors","getNetworkIcon","networksLinks","DefaultIcon","disabled","ChevronDownIcon","DefaultContent","defaultClickHandler","defaultKeyDownHandler","ToBottomButton","onClick","ref","Icon","Content","customOnClickHandler","customOnKeyDownHandler","syntheticEvent","buttonClasses","iconElement","buttonProps","ChevronUpIcon","ToTopButton","SelectContentAnimated","contentClassName","viewportClassName","position","reduceMotion","maxHeight","animationDuration","showScrollButtons","topButtonProps","bottomButtonProps","topButtonCustomization","bottomButtonCustomization","animationConfig","contentClasses","selectContentClasses","viewportClasses","selectContentStyles","finalAriaLabel","AnimatePresence","DefaultScrollContainer","React","onKeyDown","DefaultWrapper","DefaultButtonAnimationWrapper","isVisible","animationKey","ScrollableChainList","containerRef","useRef","showTopButton","setShowTopButton","useState","showBottomButton","setShowBottomButton","isScrolling","setIsScrolling","hasScrollableContent","setHasScrollableContent","scrollContext","setScrollContext","ScrollContainer","Wrapper","ButtonAnimationWrapper","scrollBehavior","buttonConfig","scrollBehaviorType","pageScrollPercentage","updateScrollContext","container","scrollTop","scrollHeight","clientHeight","updateScrollButtons","hasContent","useEffect","scrollTimeout","handleScroll","resizeObserver","scrollToExtreme","isTop","handleTopButtonClick","handleBottomButtonClick","wrapperClasses","topButtonWrapperClasses","bottomButtonWrapperClasses","createButtonWrapper","wrapperStyles","wrapperElement","DefaultTriggerIcon","DefaultTriggerContent","eo","DefaultTriggerArrow","isOpen","ChevronArrowWithAnim","DefaultLoadingState","DefaultSingleChainDisplay","DefaultDesktopSelector","DefaultMobileSelector","DefaultDialogHeader","title","DialogHeader","DialogTitle","DialogClose","CloseIcon","_event","_context","defaultChainChangeHandler","newChainId","defaultDialogCloseHandler","ChainTriggerButton","currentFormattedChainId","isChainsListOpen","onToggle","hasMultipleChains","Arrow","customClickHandler","customKeyDownHandler","layoutAnimation","innerContentAnimation","innerContentClasses","innerContent","arrowElement","ariaExpanded","ariaHaspopup","mobileButtonProps","selectTriggerProps","ChainSelector","store","setIsChainsListOpen","isChainsListOpenMobile","setIsChainsListOpenMobile","setChainsList","isLoadingChains","setIsLoadingChains","loadingRef","walletTypeRef","LoadingState","SingleChainDisplay","DesktopSelector","MobileSelector","customChainChangeHandler","customDialogCloseHandler","loadingStateClasses","singleChainDisplayClasses","desktopWrapperClasses","mobileWrapperClasses","dialogContentClasses","dialogInnerContainerClasses","handleChainChange","formatWalletChainId","walletChains","asyncChains","asyncError","syncChains","syncError","handleDialogClose","Dialog","DialogContent","useGetWalletNameAndAvatar","options","abbreviateSymbols","maxNameLength","autoRetry","retryDelay","getAdapter","walletAddress","foundAdapter","ensName","setEnsName","ensAvatar","setEnsAvatar","setIsLoading","setError","abortControllerRef","retryTimeoutRef","adapterCapabilities","hasNameResolver","hasAvatarResolver","cleanup","fetchNameData","signal","avatar","avatarError","errorMessage","retry","ensNameAbbreviated","textCenterEllipsis","useWalletNativeBalance","balanceCache","setBalanceCache","fetchOperationRef","cacheKey","hasBalanceResolver","fetchBalance","forceRefresh","operationId","balanceResult","prevCache","newCache","refetch","DEFAULT_PATH_ANIMATION_VARIANTS","DefaultDisconnectButton","testId","ariaDescribedBy","standardButtonClasses","DefaultDisconnectIcon","DefaultExplorerLink","href","isValidUrl","iconPath","DefaultExplorerIcon","pathData","variants","strokeWidth","strokeLinecap","strokeLinejoin","animation","isAnimated","DefaultFooterContent","disconnectButton","explorerLink","ConnectedModalFooter","setIsOpen","disconnect","DisconnectButton","ExplorerLink","FooterContent","showDisconnectButton","showExplorerLink","disconnectButtonTestId","explorerLinkTestId","closeModalAfterDisconnect","explorerUrlFallback","finalLabels","explorerUrl","isValidExplorerUrl","handleDisconnect","handleExplorerClick","disconnectButtonElement","explorerLinkElement","containerProps","isHex","value","strict","zeroAddress","sizeClasses","DefaultLoadingOverlay","showLoading","disableAnimation","loadingClasses","DefaultAvatarImage","src","onLoad","onError","address","DefaultFallbackContent","formattedAddress","defaultGenerateBlockie","makeBlockie","defaultGenerateBgColor","colorHex","defaultFormatAddress","WalletAvatar","altText","size","onImageLoad","onImageError","imageSrc","setImageSrc","hasError","setHasError","LoadingOverlay","AvatarImage","FallbackContent","generateBlockie","generateBgColor","formatAddress","blockie","bgColor","imageAltText","currentEnsAvatar","handleImageLoad","handleImageError","currentImageSrc","DEFAULT_CONTAINER_ANIMATION_VARIANTS","DEFAULT_COPY_ICON_ANIMATION_VARIANTS","DEFAULT_CHECK_ICON_ANIMATION_VARIANTS","DEFAULT_LOADING_ANIMATION_VARIANTS","DefaultWalletNameDisplay","DefaultCopyButton","isCopied","onCopy","getCopyButtonAriaLabel","baseLabel","addressInfo","CheckIcon","DocumentDuplicateIcon","DefaultBalanceDisplay","balance","balanceLoading","balanceDisplay","DefaultScreenReaderFeedback","DefaultLiveRegion","ConnectedModalNameAndBalance","copy","useCopyToClipboard","WalletNameDisplay","CopyButton","BalanceDisplay","ScreenReaderFeedback","LiveRegion","ariaLabels","hasActiveWallet","hasBalance","handleCopyAddress","containerVariants","content","DefaultErrorIndicator","walletName","DefaultFallbackIcon","WalletIcon","lazy","ErrorIndicator","FallbackIcon","cleanIconUrl","trimmedIcon","imageClasses","imageStyle","imageProps","DEFAULT_BUTTON_ANIMATION_VARIANTS","DefaultWalletIconContainer","walletIcon","DefaultChainIconContainer","walletChainId","DefaultChevronContainer","loading","DefaultButtonContent","walletIconContainer","chainIconContainer","chevronContainer","loadingOverlay","IconButton","items","WalletIconContainer","ChainIconContainer","ChevronContainer","ButtonContent","showWalletIcon","showChainIcon","showChevron","showLoadingOverlay","buttonTestId","chainIdFormatter","isClickable","hasWalletIcon","hasChainIcon","hasChevron","hasMultipleIcons","accessibleLabel","customAriaLabel","parts","tooltipText","customTooltip","customButtonClasses","handleMouseEnter","customHoverHandler","handleMouseLeave","handleFocus","customFocusHandler","handleBlur","customBlurHandler","walletIconCustomClasses","chainIconCustomClasses","chevronCustomClasses","loadingCustomClasses","buttonVariants","baseButtonProps","buttonContent","DEFAULT_AVATAR_SECTION_ANIMATION_VARIANTS","DEFAULT_INFO_SECTION_ANIMATION_VARIANTS","DEFAULT_TRANSACTIONS_ANIMATION_VARIANTS","DefaultLoadingIndicator","DefaultAvatarSection","connectorsCount","onSwitchWallet","onSwitchNetwork","DefaultInfoSection","DefaultTransactionsSection","walletTransactions","hasPendingTransactions","onViewTransactions","showPendingIndicators","DefaultNoTransactionsIndicator","ConnectedModalMainContent","transactionPool","avatarIsLoading","setConnectedModalContentType","setIsConnectedModalOpen","setIsConnectModalOpen","getConnectors","customComponents","customConfig","customHandlers","LoadingIndicator","AvatarSection","InfoSection","TransactionsSection","NoTransactionsIndicator","showLoadingIndicators","handleSwitchWallet","handleSwitchNetwork","handleViewTransactions","tx","hasTransactions","pendingCount","DEFAULT_ERROR_ANIMATION_VARIANTS","TransactionsHistory","module","DefaultLoadingContainer","DefaultErrorContainer","ExclamationTriangleIcon","DefaultNoWalletContainer","DefaultTransactionsHistoryWrapper","activeWalletAddress","PulsarAdapterRequired","iconContainerClasses","titleClasses","descriptionClasses","errorVariants","PuzzlePieceIcon","ErrorBoundary","Component","errorInfo","ConnectedModalTxHistory","pulsarAdapter","LoadingContainer","ErrorContainer","NoWalletContainer","TransactionsHistoryWrapper","packageName","hasValidAdapter","handlePackageLoadingFailure","loadingComponent","errorComponent","noWalletComponent","Suspense","DEFAULT_MODAL_ANIMATION_VARIANTS","DefaultBackButton","onBack","ChevronLeftIcon","DefaultTitle","DefaultCloseButton","DefaultHeader","contentType","DefaultMainContent","onChainChange","renderContent","ConnectedModal","isConnectedModalOpen","connectedModalContentType","CustomDialog","CustomDialogContent","CustomHeader","CustomMainContent","CustomFooter","autoResetToMain","hooksConfig","walletNameConfig","handleOpenChange","open","getTitle","handleBackToMain","handleCloseModal","currentTitle","modalVariants","layoutTransition","digitalPassportImage","walletImage","DEFAULT_SLIDES_CONFIG","DEFAULT_SLIDE_VARIANTS","direction","DEFAULT_IMAGE_VARIANTS","TOUCH_CONFIG","ANIMATION_CONFIG","DefaultSection","DefaultSlideContainer","StarsBackground","DefaultImageSection","slide","imageLoaded","slideIndex","DefaultContentSection","DefaultIndicator","index","DefaultNavigation","slides","currentSlide","onSlideChange","DefaultSlide","totalSlides","imageLoadedStates","slideVariants","slideTransition","DefaultStatus","currentSlideData","isAutoPlaying","AboutWallets","slidesConfig","CustomSection","CustomSlideContainer","CustomSlide","CustomNavigation","CustomStatus","disableAutoPlay","initialSlide","touchConfig","setCurrentSlide","setDirection","setIsAutoPlaying","userInteracted","setUserInteracted","setImageLoadedStates","touchState","setTouchState","autoPlayIntervalRef","resumeTimeoutRef","goToSlide","newDirection","goToNextSlide","nextIndex","goToPreviousSlide","prevIndex","prev","newValue","next","touch","deltaX","DefaultContainer","_statusData","restProps","DefaultStatusContainer","DefaultSpinner","DefaultStatusIcon","statusData","IconComponent","CheckCircleIcon","ExclamationCircleIcon","DefaultMessageContainer","DefaultStatusMessage","DefaultErrorMessage","DefaultErrorDetails","DefaultLoadingPlaceholder","Connecting","memo","activeConnector","isConnected","customErrorMessage","showDetailedError","walletConnectionError","isMountedRef","prevStateRef","prevStatusDataRef","cleanupCalled","CustomContainer","CustomStatusContainer","CustomSpinner","CustomStatusIcon","CustomWalletIconContainer","CustomMessageContainer","CustomStatusMessage","CustomErrorMessage","CustomErrorDetails","CustomLoadingPlaceholder","currentConnector","performDefaultCleanup","connectionState","displayMessage","statusContainerClasses","element","containerAriaLabel","defaultAnimationConfig","defaultGradientConfig","DefaultAnimatedGradient","animated","gradientConfig","gradientBackground","stops","stop","animatedStyle","DefaultBackgroundOverlay","RecentBadge","CustomAnimatedGradient","CustomBackgroundOverlay","CustomContent","isTouch","isTouchDevice","getContainerClasses","animatedGradientClasses","backgroundOverlayClasses","getAriaLabel","DefaultNetworkIconsContainer","cardData","DefaultNetworkIcon","networkData","DefaultNetworkOverflow","NetworkIcons","adapters","isOnlyOneNetwork","CustomNetworkIcon","CustomOverflowIndicator","visibleNetworksData","overflowCount","DefaultCardContainer","DefaultCardContent","DefaultIconContainer","DefaultIconWrapper","DefaultTextContainer","DefaultSubtitle","DefaultInfoLink","DefaultRecentBadgeWrapper","DefaultChevron","ConnectCard","infoLink","subtitle","isRecent","CustomIconContainer","CustomIconWrapper","CustomTextContainer","CustomTitle","CustomSubtitle","CustomInfoLink","CustomRecentBadgeWrapper","CustomChevron","networkStats","networkCount","visibleNetworks","cardAriaLabel","recentText","subtitleText","handleInfoClick","InformationCircleIcon","ChevronRightIcon","_blockData","DefaultConnectorsList","DefaultConnectorItem","_itemData","DefaultEmptyState","ConnectorsBlock","waitForPredict","setIsConnected","isTitleBold","connectInProgressRef","CustomConnectorsList","CustomConnectorItem","CustomEmptyState","connect","recentWallets","recentConnectedWalletHelpers","sectionId","blockData","layoutClasses","touchClasses","mouseClasses","connectorItems","handleConnectorClick","targetAdapter","getWalletTypeFromConnectorName","waitFor","modalCloseTime","isConnectedTimer","delay","handleConnectorClickWrapper","itemData","cssClasses","listAriaLabel","isLink","action","DefaultDescription","DefaultAdditionalContent","DefaultActions","DefaultLinkButton","DefaultActionButton","Disclaimer","description","learnMoreAction","listAction","compact","announceToScreenReader","uniqueId","useId","CustomContentSection","CustomDescription","CustomAdditionalContent","CustomActions","CustomLinkButton","CustomActionButton","disclaimerId","buttonTestIds","renderActionButton","buttonText","isPrimary","isLinkAction","_selectionsData","DefaultContentWrapper","DefaultConnectorsArea","DefaultImpersonateSection","_impersonateData","DefaultImpersonateTitle","DefaultDisclaimerSection","ConnectorsSelections","setContentType","withImpersonated","CustomContentWrapper","CustomConnectorsArea","CustomImpersonateSection","CustomImpersonateTitle","CustomDisclaimerSection","connectorGroups","installedConnectorsInitial","installedConnectors","isSafeApp","popularConnectors","impersonatedConnector","selectionsData","impersonateData","touchConnectorsClasses","mouseConnectorsClasses","touchContentClasses","mouseContentClasses","handleImpersonateClick","handleImpersonateClickWrapper","connectorsAreaAriaLabel","impersonateAriaLabel","defaultWalletIcons","DefaultAnimationSection","DefaultStarsBackground","show","DefaultGradientOverlay","DefaultAnimationWrapper","enableAnimations","animationDelay","DefaultWalletIcon","walletKey","positionClasses","classes","animationClasses","animationStyle","DefaultScreenReader","GetWallet","customWalletIcons","showStarsBackground","CustomAnimationSection","CustomStarsBackground","CustomGradientOverlay","CustomAnimationWrapper","CustomWalletIcon","CustomScreenReader","walletIcons","icons","durationMultiplier","delayMultiplier","defaultClasses","animationSectionClasses","starsBackgroundClasses","gradientOverlayClasses","animationWrapperClasses","contentSectionClasses","screenReaderClasses","iconConfig","defaultValidationConfig","DefaultLabel","DefaultInput","_","ImpersonateForm","impersonatedAddress","setImpersonatedAddress","CustomLabel","CustomInput","resetWalletConnectionError","setWalletConnectionError","hasInteracted","setHasInteracted","timeoutRef","validationConfig","getValidateAddress","customError","isAddress","validateAddress","getDebouncedValidate","debouncedValidate","getHandleAddressChange","handleAddressChange","getHandleBlur","getLabelClasses","labelClasses","getInputClasses","inputClasses","getErrorMessageClasses","errorMessageClasses","inputId","errorId","placeholder","autoComplete","spellCheck","DefaultNetworkList","DefaultNetworkItem","DefaultErrorIcon","DefaultErrorTitle","NetworkSelections","CustomNetworkList","CustomNetworkItem","CustomErrorContainer","CustomErrorIcon","CustomErrorTitle","activeConnectors","networkInfo","touchListClasses","mouseListClasses","handleNetworkClick","network","n","selectedNetwork","getTextVariant","DefaultTabList","DefaultTab","DefaultTabButton","DefaultTabText","NetworkTabs","onSelect","CustomTabList","CustomTab","CustomTabButton","CustomTabText","CustomIndicator","textVariant","shouldRender","minNetworks","localNetworks","getNetworkDisplayNameGen","networkKey","getNetworkDisplayName","getNetworkAriaLabelGen","isSelected","displayName","tabPrefix","selectedSuffix","getNetworkAriaLabel","getHandleTabSelect","tabData","handleTabSelect","tabsData","getTabListClasses","tabListClasses","tabKey","tabClasses","tabButtonClasses","tabTextClasses","indicatorClasses","GlobeAltIcon","getConnectorName","c","DefaultModalContainer","modalData","DefaultModalHeader","DefaultInfoButton","DefaultFooter","DefaultActionDescription","_modalData","ConnectModal","isConnectModalOpen","setConnectModalContentType","setActiveConnector","connectModalContentType","setSelectedAdapter","storeGetters","normalizedError","components","classNames","handlers","childComponents","ModalContainer","ModalHeader","InfoButton","Title","CloseButton","MainContent","Footer","BackButton","ActionButton","ActionDescription","CustomMotionDiv","goBackContentType","handleBack","handleConnect","renderMainContent","bottomButtonConfig","trimmedAddress","impersonatedHelpers","getActionDescription","DEFAULT_MOTION_PATH_VARIANTS","DEFAULT_CONTAINER_VARIANTS","DefaultSvg","ariaHidden","focusable","DefaultPath","StatusIcon","txStatus","colorVar","Svg","Path","defaultAriaLabel","svgClasses","pathClasses","pathVariants","containerAnimation","pathAnimation","shouldReduceMotion","isAnimationDisabled","svgElement","baseProps","createElement","DefaultBalanceContainer","formattedBalance","statusDisplay","withBalance","DefaultLoadingAnimation","connectedButtonStatus","DefaultBalanceDivider","ConnectedContent","setConnectedButtonStatus","prevTxPoolRef","BalanceContainer","LoadingAnimation","BalanceDivider","statusResetTimeout","showLoadingAnimation","showBalanceDivider","currentPool","prevPool","newStatus","currentTx","prevTx","TransactionStatus","timer","getStatusAriaLabel","status","baseAriaLabel","handleBalanceClick","DefaultText","text","role","WaitForConnectionContent","Text","hideWhenConnected","customText","displayText","defaultPathData","textClasses","textElement","buttonData","DefaultButtonContainer","DefaultButton","ConnectButton","withChain","Navigation","Container","ButtonContainer","Button","handleConnectButtonClick","buttonAriaLabel","navigationAriaLabel","DefaultRootContainer","_providerData","NovaConnectButton","connectButtonProps","providerCustomization","connectButtonCustomization","RootContainer","CustomProvider","NovaConnectProvider","CustomConnectButton","providerData","providerProps","titleId","rawError","descriptionId","copyLabel","copiedLabel","idCounter","ToastError","onCopyComplete","Description","errorToCopy","handleCopy","DefaultToastError","errorType","ToastContainer","defaultShowErrorHandler","defaultDismissErrorHandler","defaultCopyCompleteHandler","success","defaultErrorTitleGenerator","defaultTitle","defaultErrorHashGenerator","defaultHash","ErrorsProvider","containerId","autoClose","draggable","switchNetworkError","CustomToastError","customShowErrorHandler","customDismissErrorHandler","customCopyCompleteHandler","customErrorTitleGenerator","customErrorHashGenerator","displayedErrorsRef","currentToastIdRef","errorState","hasWalletError","hasSwitchError","defaultErrorTitle","errorTitle","defaultErrorHash","errorHash","dismissCurrentToast","toast","handleCopyComplete","originalErrorHandler","t","r","k","defaultToastOptions","customToastOptions","toastOptions","showErrorToast","errorKey","hasAnyError","primaryError","defaultContainerProps","ToastCloseButton","Bounce","NovaConnectLabelsProvider","memoizedLabels","missingLabels","key","DefaultLabelsProvider","DefaultErrorsProvider","defaultLabelsMerge","userLabels","deepMerge","defaultLabelsTransform","mergedLabels","defaultStoreSubscribedHandler","defaultConnectionStateChangeHandler","defaultErrorStateChangeHandler","defaultContextValueTransform","defaultValue","defaultProviderTreeRenderer","defaultTree","LabelsProvider","CustomErrorsProvider","customLabelsMerge","customLabelsTransform","customStoreSubscribedHandler","customConnectionStateChangeHandler","customErrorStateChangeHandler","customContextValueTransform","customProviderTreeRenderer","setActiveWallet","providerContext","handleConnectionStateChange","newIsConnected","newActiveWallet","handleErrorStateChange","newError","unsubscribe","state","contextValue","errorsProviderElement","labelsProviderElement","mainContentElement","defaultProviderTree","finalProviderTree"],"mappings":"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","file":"index.js","sourcesContent":["import { NovaConnectLabels } from './types';\n\n/**\n * Default English translations for NovaConnect component\n * All text strings extracted from component files\n */\nexport const defaultLabels: NovaConnectLabels = {\n // Core actions - Primary user interactions\n connectWallet: 'Connect Wallet',\n disconnect: 'Disconnect',\n connecting: 'Connecting...',\n connected: 'Connected',\n tryAgain: 'Try again',\n back: 'Back',\n connect: 'Connect',\n close: 'Close',\n all: 'All',\n\n // Connection states - Status messages for wallet connection flow\n connectionError: 'Connection error',\n connectedSuccessfully: 'Connected successfully!',\n connectingTo: 'Connecting to',\n walletConnectionError: 'Wallet connection error',\n errorWhenChainSwitching: 'Error when chain switching',\n cannotConnectWallet: 'Cannot connect to the wallet. Please try again or use another connector.',\n\n // Transaction states - Status indicators for blockchain transactions\n success: 'Success',\n error: 'Error',\n replaced: 'Replaced',\n recent: 'Recent',\n transactionLoading: 'Transaction loading',\n transactionSuccess: 'Transaction successful',\n transactionError: 'Transaction failed',\n transactionReplaced: 'Transaction replaced',\n\n // Modal titles - Headers for different modal dialogs\n aboutWallets: 'About wallets',\n getWallet: 'Get a wallet',\n connectImpersonatedWallet: 'Connect impersonated wallet',\n transactionsInApp: 'Transactions in app',\n switchNetwork: 'Switch network',\n switchNetworks: 'Switch Networks',\n connectingEllipsis: 'Connecting...',\n\n // Wallet sections - Categories for wallet connector grouping\n installed: 'Installed',\n popular: 'Popular',\n impersonate: 'Impersonate',\n readOnlyMode: 'Read-only mode',\n\n // Information and descriptions - Educational content and explanations\n whatIsWallet: 'What is a wallet?',\n walletDescription:\n 'Wallets are essential for managing your crypto—they let you send, receive, and securely hold digital assets. Connecting your wallet grants you safe access and interaction with decentralized applications (dApps).',\n whatIsNetwork: 'What is a network?',\n networkDescription:\n 'A network (or blockchain) is a decentralized digital ledger that records transactions. Selecting a network lets you choose which blockchain you want to connect to.',\n learnMore: 'Learn more',\n listOfNetworks: 'List of networks',\n viewOnExplorer: 'View on explorer',\n viewTransactions: 'View transactions',\n\n // Impersonation form - Labels for wallet address impersonation feature\n enterWalletAddress: 'Enter wallet address to impersonate',\n walletAddressPlaceholder: '0x...',\n\n // Error messages - User-facing error notifications and descriptions\n noConnectorsFound: 'No Connectors Found',\n noConnectorsDescription: \"We couldn't find any wallets or connection methods for the selected network.\",\n somethingWentWrong: 'Something went wrong',\n networkPickingError: 'Something went wrong with wallet network selection. Please go back and try again.',\n pulsarAdapterRequired: 'Pulsar Adapter Required',\n pulsarAdapterDescription:\n 'Additional configuration is needed for viewing transactions in app. Please contact your admin.',\n selectAvailableNetwork: 'Select one of available network',\n\n // Get Wallet section - Onboarding content for new users without wallets\n startExploringWeb3: 'Start Exploring Web3',\n walletKeyToDigitalWorld:\n 'Your wallet is the key to the digital world and the technology that makes exploring web3 possible.',\n iDontHaveWallet: \"I don't have a wallet\",\n choseWallet: 'Choose a wallet',\n\n // About Wallets slides - Educational carousel content explaining wallet benefits\n keyToNewInternet: 'The Key to a New Internet',\n keyToNewInternetDescription:\n 'Your wallet is more than just storage. Think of it as your digital passport that lets you truly own, display, and exchange every digital asset you hold, from crypto tokens to unique NFTs.',\n logInWithoutHassle: 'Log In Without the Hassle',\n logInWithoutHassleDescription:\n 'Skip the endless sign-up forms! Your wallet is your unique access pass. Just connect it, and the website instantly recognizes you. It saves you time and protects your privacy.',\n\n // Copy functionality and UI feedback - Clipboard operations and user feedback\n copyRawError: 'Copy raw error',\n copied: 'Copied!',\n\n // Accessibility labels - Screen reader and ARIA labels for better accessibility\n chainSelector: 'Chain Selector',\n closeModal: 'Close modal',\n selectChain: 'Select chain',\n chainOption: 'Chain option',\n openChainSelector: 'Open chain selector',\n currentChain: 'Current chain',\n scrollToTop: 'Scroll to top',\n scrollToBottom: 'Scroll to bottom',\n chainListContainer: 'Chain list container',\n walletControls: 'Wallet controls',\n openWalletModal: 'Open wallet modal',\n walletConnected: 'Wallet connected',\n walletNotConnected: 'Wallet not connected',\n walletBalance: 'Wallet balance',\n walletAddress: 'Wallet address',\n transactionStatus: 'Transaction status',\n successIcon: 'Success icon',\n errorIcon: 'Error icon',\n replacedIcon: 'Replaced icon',\n statusIcon: 'Status icon',\n\n // Additional states - Supplementary status indicators\n loading: 'Loading',\n idle: 'Idle',\n\n // Wallet Avatar labels\n unknownWallet: 'Unknown wallet',\n walletAvatar: 'Wallet avatar',\n ensAvatar: 'ENS avatar',\n walletIcon: 'Wallet icon',\n\n // Impersonate errors\n impersonateAddressEmpty: 'Enter a wallet address to impersonate.',\n impersonateAddressNotCorrect: 'Entered wallet address is not correct. Please try again.',\n impersonateAddressConnected: 'First disconnect the wallet to impersonate another address.',\n};\n","import { createContext, useContext } from 'react';\n\nimport { defaultLabels } from '../i18n/en';\nimport { NovaConnectLabels } from '../i18n/types';\n\n/**\n * React Context for storing and providing the UI labels.\n * It is initialized with the default English labels, ensuring that components\n * work even without an explicit provider.\n */\nexport const NovaConnectLabelsContext = createContext<NovaConnectLabels>(defaultLabels);\n\n/**\n * A custom hook to easily access the i18n labels from any component\n * within the `NovaConnectLabelsProvider` tree.\n *\n * This hook provides type-safe access to all UI labels and automatically\n * falls back to default English labels if no provider is found.\n *\n * @returns {NovaConnectLabels} The complete object of UI labels for the current locale.\n *\n * @example\n * ```typescript\n * import { useNovaConnectLabels } from './hooks/useNovaConnectLabels';\n *\n * function MyComponent() {\n * const labels = useNovaConnectLabels();\n *\n * return (\n * <div>\n * <h1>{labels.connectWallet}</h1>\n * <button>{labels.connect}</button>\n * <p aria-label={labels.walletBalance}>{formattedBalance}</p>\n * </div>\n * );\n * }\n * ```\n *\n * @example\n * ```typescript\n * // Destructuring specific labels for better performance\n * function ConnectButton() {\n * const { connectWallet, connecting, connected } = useNovaConnectLabels();\n *\n * return (\n * <button>\n * {isConnecting ? connecting : isConnected ? connected : connectWallet}\n * </button>\n * );\n * }\n * ```\n */\nexport const useNovaConnectLabels = (): NovaConnectLabels => {\n return useContext(NovaConnectLabelsContext);\n};\n\n/**\n * Hook to get a specific label by key path with type safety\n *\n * @param key The label key to retrieve\n * @returns The specific label value\n *\n * @example\n * ```typescript\n * function MyComponent() {\n * const connectLabel = useNovaConnectLabel('connectWallet');\n * const errorLabel = useNovaConnectLabel('connectionError');\n *\n * return <button>{connectLabel}</button>;\n * }\n * ```\n */\nexport const useNovaConnectLabel = <K extends keyof NovaConnectLabels>(key: K): NovaConnectLabels[K] => {\n const labels = useNovaConnectLabels();\n return labels[key];\n};\n\n/**\n * Hook to get multiple specific labels for better performance\n *\n * @param keys Array of label keys to retrieve\n * @returns Object with only the requested labels\n *\n * @example\n * ```typescript\n * function ConnectModal() {\n * const { connectWallet, connecting, disconnect } = useNovaConnectLabelsSubset(['connectWallet', 'connecting', 'disconnect']);\n *\n * return (\n * <div>\n * <h2>{connectWallet}</h2>\n * <span>{connecting}</span>\n * <button>{disconnect}</button>\n * </div>\n * );\n * }\n * ```\n */\nexport const useNovaConnectLabelsSubset = <K extends keyof NovaConnectLabels>(\n keys: K[],\n): Pick<NovaConnectLabels, K> => {\n const allLabels = useNovaConnectLabels();\n\n const subset = {} as Pick<NovaConnectLabels, K>;\n for (const key of keys) {\n subset[key] = allLabels[key];\n }\n\n return subset;\n};\n\n/**\n * Type-safe helper to check if a label exists\n *\n * @param labels The labels object\n * @param key The key to check\n * @returns Whether the key exists and has a non-empty value\n */\nexport const hasLabel = (labels: NovaConnectLabels, key: keyof NovaConnectLabels): boolean => {\n return Boolean(labels[key]?.trim());\n};\n\n/**\n * Utility type for extracting label keys by category\n */\nexport type LabelCategory = {\n actions: Extract<\n keyof NovaConnectLabels,\n 'connectWallet' | 'disconnect' | 'connecting' | 'connected' | 'tryAgain' | 'back' | 'connect' | 'close'\n >;\n states: Extract<keyof NovaConnectLabels, 'success' | 'error' | 'replaced' | 'loading' | 'idle'>;\n accessibility: Extract<\n keyof NovaConnectLabels,\n 'chainSelector' | 'closeModal' | 'selectChain' | 'walletControls' | 'openWalletModal'\n >;\n transactions: Extract<\n keyof NovaConnectLabels,\n 'transactionLoading' | 'transactionSuccess' | 'transactionError' | 'transactionReplaced' | 'recent'\n >;\n};\n\n/**\n * Hook to get labels by category for better organization\n *\n * @param category The category of labels to retrieve\n * @returns Object with labels from the specified category\n */\nexport const useLabelsByCategory = <T extends keyof LabelCategory>(\n category: T,\n): Pick<NovaConnectLabels, LabelCategory[T]> => {\n const allLabels = useNovaConnectLabels();\n\n const categoryKeys: Record<keyof LabelCategory, (keyof NovaConnectLabels)[]> = {\n actions: ['connectWallet', 'disconnect', 'connecting', 'connected', 'tryAgain', 'back', 'connect', 'close'],\n states: ['success', 'error', 'replaced', 'loading', 'idle'],\n accessibility: ['chainSelector', 'closeModal', 'selectChain', 'walletControls', 'openWalletModal'],\n transactions: ['transactionLoading', 'transactionSuccess', 'transactionError', 'transactionReplaced', 'recent'],\n };\n\n const keys = categoryKeys[category] as LabelCategory[T][];\n const categoryLabels = {} as Pick<NovaConnectLabels, LabelCategory[T]>;\n\n for (const key of keys) {\n // eslint-disable-next-line\n (categoryLabels as any)[key] = allLabels[key as keyof NovaConnectLabels];\n }\n\n return categoryLabels;\n};\n\n/**\n * Utility function to check if labels are default ones (for external use)\n * This is a regular function, not a hook, so it can be used anywhere\n *\n * @param labels The labels to check\n * @returns Whether the labels are the default English labels\n *\n * @example\n * ```typescript\n * function SomeUtilityFunction(labels: NovaConnectLabels) {\n * if (isDefaultLabels(labels)) {\n * console.log('Using default English labels');\n * }\n * }\n * ```\n */\nexport const isDefaultLabels = (labels: NovaConnectLabels): boolean => {\n return labels === defaultLabels;\n};\n\n/**\n * Utility function to get a formatted label with fallback\n *\n * @param labels The labels object\n * @param key The label key\n * @param fallback Optional fallback text\n * @returns The label value or fallback\n *\n * @example\n * ```typescript\n * const buttonText = getLabelWithFallback(labels, 'connectWallet', 'Connect');\n * ```\n */\nexport const getLabelWithFallback = (\n labels: NovaConnectLabels,\n key: keyof NovaConnectLabels,\n fallback?: string,\n): string => {\n const value = labels[key];\n if (value && value.trim()) {\n return value;\n }\n return fallback || defaultLabels[key] || key.toString();\n};\n\n/**\n * Utility function to create a labels subset (for use outside of React components)\n *\n * @param labels The source labels object\n * @param keys Array of keys to extract\n * @returns Object with only the requested labels\n *\n * @example\n * ```typescript\n * const actionLabels = createLabelsSubset(labels, ['connect', 'disconnect', 'tryAgain']);\n * ```\n */\nexport const createLabelsSubset = <K extends keyof NovaConnectLabels>(\n labels: NovaConnectLabels,\n keys: K[],\n): Pick<NovaConnectLabels, K> => {\n const subset = {} as Pick<NovaConnectLabels, K>;\n for (const key of keys) {\n subset[key] = labels[key];\n }\n return subset;\n};\n","/**\n * @file Highly customizable chain list renderer with comprehensive styling and behavior control.\n * @module ChainListRenderer\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { getChainName } from '@bgd-labs/react-web3-icons/dist/utils';\nimport * as Select from '@radix-ui/react-select';\nimport { cn } from '@tuwaio/nova-core';\nimport {\n type AnyResolvedKeyframe,\n type LegacyAnimationControls,\n motion,\n type TargetAndTransition,\n type Transition,\n type VariantLabels,\n} from 'framer-motion';\nimport React, {\n type ComponentPropsWithoutRef,\n type ComponentType,\n type ElementRef,\n forwardRef,\n ReactNode,\n useCallback,\n useMemo,\n} from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\n\n// === TYPES AND INTERFACES ===\n\n/**\n * Chain data structure returned by getChainData function\n */\ninterface ChainData {\n formattedChainId: string | number;\n chain: string | number;\n}\n\n/**\n * Props for custom chain icon component\n */\ninterface CustomChainIconProps {\n chainId: string | number;\n className?: string;\n 'aria-hidden'?: boolean;\n}\n\n/**\n * Props for custom chain content component\n */\ninterface CustomChainContentProps {\n chainId: string | number;\n isActive: boolean;\n icon: ReactNode;\n children?: ReactNode;\n}\n\n/**\n * Props for custom active indicator component\n */\ninterface CustomActiveIndicatorProps {\n isActive: boolean;\n label: string;\n className?: string;\n}\n\n/**\n * Animation configuration for container\n */\ninterface ContainerAnimationConfig {\n initial?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n animate?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n exit?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n transition?: Transition<AnyResolvedKeyframe>;\n}\n\n/**\n * Animation configuration for items\n */\ninterface ItemAnimationConfig {\n initial?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n animate?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n transition?: Transition<AnyResolvedKeyframe>;\n}\n\n/**\n * Comprehensive customization options for ChainListRenderer\n */\nexport interface ChainListRendererCustomization {\n /** Custom components */\n components?: {\n /** Custom chain icon component */\n ChainIcon?: ComponentType<CustomChainIconProps>;\n /** Custom chain content layout component */\n ChainContent?: ComponentType<CustomChainContentProps>;\n /** Custom active indicator component */\n ActiveIndicator?: ComponentType<CustomActiveIndicatorProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Container classes */\n container?: (params: { isMobile: boolean; itemCount: number }) => string;\n /** Item classes */\n item?: (params: { isActive: boolean; isMobile: boolean; chainId: string | number }) => string;\n /** Content wrapper classes */\n content?: (params: { isActive: boolean; isMobile: boolean }) => string;\n /** Icon classes */\n icon?: (params: { isActive: boolean; chainId: string | number }) => string;\n /** Chain name classes */\n chainName?: (params: { isActive: boolean; isMobile: boolean }) => string;\n /** Active indicator classes */\n activeIndicator?: (params: { isMobile: boolean }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom click handler wrapper */\n onClick?: (\n originalHandler: () => void,\n context: { chainId: string | number; chainName: string; isActive: boolean },\n ) => void;\n /** Custom keydown handler wrapper */\n onKeyDown?: (\n originalHandler: (event: React.KeyboardEvent) => void,\n event: React.KeyboardEvent,\n context: { chainId: string | number; chainName: string; isActive: boolean },\n ) => void;\n /** Chain selection handler wrapper */\n onSelect?: (\n originalHandler: (chainId: string) => void,\n chainId: string,\n context: { chainName: string; isActive: boolean },\n ) => void;\n };\n /** Animation configuration */\n animations?: {\n /** Container animation */\n container?: ContainerAnimationConfig;\n /** Item animation */\n item?: ItemAnimationConfig;\n };\n /** Behavior configuration */\n behavior?: {\n /** Auto-focus first item */\n autoFocus?: boolean;\n /** Enable animation on mount */\n animateOnMount?: boolean;\n /** Show loading states */\n showLoading?: boolean;\n /** Custom loading message */\n loadingMessage?: string;\n };\n}\n\n/**\n * Props for the ChainListRenderer component\n */\nexport interface ChainListRendererProps {\n /** List of chain identifiers to render */\n chainsList: (string | number)[];\n /** Currently selected chain value */\n selectValue: string;\n /** Handler for chain selection changes */\n handleValueChange: (newChainId: string) => void;\n /** Function to get formatted chain data */\n getChainData: (chain: string | number) => ChainData;\n /** Handler called when list should close */\n onClose: () => void;\n /** Whether this is being rendered on mobile */\n isMobile?: boolean;\n /** Custom CSS classes for container (added to defaults) */\n className?: string;\n /** Custom CSS classes for individual items (added to defaults) */\n itemClassName?: string;\n /** Comprehensive customization options */\n customization?: ChainListRendererCustomization;\n /** ARIA label for the list container */\n 'aria-label'?: string;\n /** Loading state */\n isLoading?: boolean;\n /** Error state */\n error?: string | null;\n}\n\n// === DEFAULT COMPONENTS ===\n\n/**\n * Default chain icon component using Web3Icon\n */\nconst DefaultChainIcon: React.FC<CustomChainIconProps> = ({ chainId, className, ...props }) => (\n <Web3Icon chainId={chainId} className={className} {...props} />\n);\n\n/**\n * Default chain content component\n */\nconst DefaultChainContent: React.FC<CustomChainContentProps> = ({ icon, children }) => (\n <div className=\"novacon:flex novacon:items-center novacon:space-x-3 novacon:[&_img]:w-6 novacon:[&_img]:h-6\">\n <div aria-hidden=\"true\">{icon}</div>\n {children}\n </div>\n);\n\n/**\n * Default active indicator component\n */\nconst DefaultActiveIndicator: React.FC<CustomActiveIndicatorProps> = ({ isActive, label, className }) => {\n if (!isActive) return null;\n\n return (\n <>\n <span\n className={cn(\n 'novacon:ml-auto novacon:text-xs novacon:font-semibold novacon:w-2 novacon:h-2 novacon:rounded-full novacon:bg-[var(--tuwa-success-text)]',\n className,\n )}\n aria-label={label}\n role=\"status\"\n />\n <span className=\"novacon:sr-only\">{label}</span>\n </>\n );\n};\n\n/**\n * Enhanced SelectItem component for desktop use\n */\nconst SelectItemBase = forwardRef<ElementRef<typeof Select.Item>, ComponentPropsWithoutRef<typeof Select.Item>>(\n ({ children, className, ...props }, forwardedRef) => {\n const labels = useNovaConnectLabels();\n const isActive = props.value === props['aria-selected'];\n return (\n <Select.Item\n ref={forwardedRef}\n className={cn(\n // Base styles\n 'novacon:flex novacon:items-center novacon:w-full novacon:text-left novacon:px-2 novacon:py-2',\n 'novacon:rounded-md novacon:transition-colors novacon:space-x-3 novacon:cursor-pointer novacon:outline-none',\n // Interactive states\n 'novacon:text-[var(--tuwa-text-primary)] novacon:hover:bg-[var(--tuwa-bg-muted)]',\n 'novacon:focus:bg-[var(--tuwa-bg-muted)] novacon:focus:outline-none',\n 'novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)] novacon:focus:ring-offset-2',\n // Active state\n { 'novacon:bg-[var(--tuwa-bg-muted)]': isActive },\n // Custom classes\n className,\n )}\n role=\"option\"\n aria-selected={isActive}\n tabIndex={0}\n {...props}\n >\n {children}\n {isActive && <DefaultActiveIndicator isActive={true} label={labels.connected} className=\"novacon:ml-auto\" />}\n </Select.Item>\n );\n },\n);\nSelectItemBase.displayName = 'SelectItemBase';\n\n// === MAIN COMPONENT ===\n\n/**\n * Highly customizable chain list renderer with comprehensive styling and behavior control.\n */\nexport const ChainListRenderer: React.FC<ChainListRendererProps> = ({\n chainsList,\n selectValue,\n handleValueChange,\n getChainData,\n onClose,\n isMobile = false,\n className,\n itemClassName,\n customization,\n 'aria-label': ariaLabel,\n isLoading = false,\n error = null,\n}) => {\n const labels = useNovaConnectLabels();\n\n // Extract customization options with defaults\n const {\n ChainIcon = DefaultChainIcon,\n ChainContent = DefaultChainContent,\n ActiveIndicator = DefaultActiveIndicator,\n } = customization?.components ?? {};\n\n const animations = customization?.animations;\n const behavior = customization?.behavior ?? {};\n\n // Memoize container classes and styles\n const containerClasses = useMemo(() => {\n const customClasses = customization?.classNames?.container?.({ isMobile, itemCount: chainsList.length });\n return cn(customClasses, className);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, isMobile, chainsList.length, className]);\n\n // Create event handlers at top level to avoid hooks violations\n const createClickHandler = useCallback(\n (formattedChainId: string | number, chainName: string, isActive: boolean) => {\n const originalHandler = () => {\n if (customization?.handlers?.onSelect) {\n customization.handlers.onSelect(handleValueChange, String(formattedChainId), { chainName, isActive });\n } else {\n handleValueChange(String(formattedChainId));\n }\n onClose();\n };\n\n return () => {\n if (customization?.handlers?.onClick) {\n customization.handlers.onClick(originalHandler, {\n chainId: formattedChainId,\n chainName,\n isActive,\n });\n } else {\n originalHandler();\n }\n };\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.handlers?.onSelect, customization?.handlers?.onClick, handleValueChange, onClose],\n );\n\n const createKeyDownHandler = useCallback(\n (clickHandler: () => void, formattedChainId: string | number, chainName: string, isActive: boolean) => {\n const originalHandler = (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n clickHandler();\n }\n };\n\n return (event: React.KeyboardEvent) => {\n if (customization?.handlers?.onKeyDown) {\n customization.handlers.onKeyDown(originalHandler, event, {\n chainId: formattedChainId,\n chainName,\n isActive,\n });\n } else {\n originalHandler(event);\n }\n };\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.handlers?.onKeyDown],\n );\n\n // Handle loading state\n if (isLoading) {\n const loadingMessage = behavior.loadingMessage || `${labels.loading}...`;\n return (\n <div\n className={cn('novacon:flex novacon:justify-center novacon:items-center novacon:py-4', containerClasses)}\n role=\"status\"\n aria-label={loadingMessage}\n >\n <span className=\"novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]\">{loadingMessage}</span>\n </div>\n );\n }\n\n // Handle error state\n if (error) {\n return (\n <div\n className={cn('novacon:flex novacon:justify-center novacon:items-center novacon:py-4', containerClasses)}\n role=\"alert\"\n aria-live=\"assertive\"\n >\n <span className=\"novacon:text-sm novacon:text-[var(--tuwa-text-error)]\">{error}</span>\n </div>\n );\n }\n\n // Handle empty state\n if (chainsList.length === 0) {\n return (\n <div\n className={cn('novacon:flex novacon:justify-center novacon:items-center novacon:py-4', containerClasses)}\n role=\"status\"\n >\n <span className=\"novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]\">{labels.noConnectorsFound}</span>\n </div>\n );\n }\n\n // Main render method for individual chain items\n const renderChainItem = (chain: string | number) => {\n const { formattedChainId } = getChainData(chain);\n const isActive = String(formattedChainId) === selectValue;\n const chainName = getChainName(formattedChainId);\n\n // Generate custom classes and styles\n const itemClasses = customization?.classNames?.item?.({ isActive, isMobile, chainId: formattedChainId })\n ? customization?.classNames?.item?.({ isActive, isMobile, chainId: formattedChainId })\n : cn(\n // Default item styles\n 'novacon:flex novacon:items-center novacon:w-full novacon:text-left novacon:px-2 novacon:py-2',\n 'novacon:rounded-md novacon:transition-colors novacon:space-x-3 novacon:cursor-pointer novacon:outline-none',\n 'novacon:text-[var(--tuwa-text-primary)] novacon:hover:bg-[var(--tuwa-bg-muted)]',\n 'novacon:focus:bg-[var(--tuwa-bg-muted)] novacon:focus:outline-none',\n 'novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)] novacon:focus:ring-offset-2',\n { 'novacon:bg-[var(--tuwa-bg-muted)]': isActive, 'novacon:justify-between': isMobile },\n // Custom classes\n itemClassName,\n );\n\n const iconClasses = customization?.classNames?.icon?.({ isActive, chainId: formattedChainId });\n\n const chainNameClasses = customization?.classNames?.chainName?.({ isActive, isMobile });\n\n // Create event handlers\n const handleClick = createClickHandler(formattedChainId, chainName, isActive);\n const handleKeyDown = createKeyDownHandler(handleClick, formattedChainId, chainName, isActive);\n\n // Create icon element\n const iconElement = <ChainIcon chainId={formattedChainId} className={iconClasses} aria-hidden={true} />;\n\n // Create content element\n const contentElement = (\n <ChainContent chainId={formattedChainId} isActive={isActive} icon={iconElement}>\n <span className={cn('novacon:text-sm novacon:font-medium', chainNameClasses)}>{chainName}</span>\n </ChainContent>\n );\n\n // Create active indicator\n const activeIndicatorClasses = customization?.classNames?.activeIndicator?.({ isMobile });\n\n const activeIndicator = isMobile ? (\n <div className=\"novacon:flex novacon:items-center novacon:space-x-2 novacon:text-xs novacon:font-semibold novacon:text-[var(--tuwa-text-tertiary)]\">\n <span aria-label={labels.connected}>{labels.connected}</span>\n <ActiveIndicator isActive={isActive} label={labels.connected} className={activeIndicatorClasses} />\n </div>\n ) : (\n <ActiveIndicator isActive={isActive} label={labels.connected} className={activeIndicatorClasses} />\n );\n\n const ariaLabel = `${labels.chainOption}: ${chainName}`;\n\n // Render mobile version\n if (isMobile) {\n const MotionItem = animations?.item ? motion.div : 'div';\n const motionProps = animations?.item || {};\n\n return (\n <MotionItem\n key={chain}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n className={itemClasses}\n role=\"option\"\n aria-selected={isActive}\n aria-label={ariaLabel}\n tabIndex={0}\n {...motionProps}\n >\n {contentElement}\n {activeIndicator}\n </MotionItem>\n );\n }\n\n // Render desktop version with Select.Item\n return (\n <SelectItemBase\n key={chain}\n value={String(formattedChainId)}\n aria-label={ariaLabel}\n onSelect={handleClick}\n className={itemClasses}\n >\n {contentElement}\n </SelectItemBase>\n );\n };\n\n // Container animation wrapper\n const MotionContainer = animations?.container ? motion.div : 'div';\n const containerMotionProps = animations?.container || {};\n\n return (\n <MotionContainer\n role=\"listbox\"\n aria-label={ariaLabel || labels.selectChain}\n className={containerClasses}\n {...containerMotionProps}\n >\n {chainsList.map(renderChainItem)}\n </MotionContainer>\n );\n};\n","import { OrbitAdapter } from '@tuwaio/orbit-core';\nimport { ISatelliteConnectStore } from '@tuwaio/satellite-core';\nimport { BaseWallet } from '@tuwaio/satellite-core';\nimport { createContext, useContext } from 'react';\nimport { StoreApi } from 'zustand/index';\n\nimport { NovaConnectLabels } from '../i18n/types';\nimport { Connector, Wallet } from '../types';\n\nexport type ButtonTxStatus = 'idle' | 'loading' | 'succeed' | 'failed' | 'replaced';\nexport type ConnectContentType = 'network' | 'connectors' | 'about' | 'getWallet' | 'connecting' | 'impersonate';\nexport type ConnectedContentType = 'main' | 'transactions' | 'chains';\n\n// Provider props interface\nexport interface NovaConnectProviderProps {\n store: StoreApi<ISatelliteConnectStore<Connector, Wallet>>;\n children: React.ReactNode;\n labels?: Partial<NovaConnectLabels>;\n}\n\n// Balance type for better type safety\nexport interface WalletBalance {\n value: string;\n symbol: string;\n}\n\n// Provider context type with better organization\nexport interface NovaConnectProviderType {\n activeWallet: BaseWallet | undefined;\n walletConnectionError: string | undefined;\n // Modal states\n isConnectModalOpen: boolean;\n setIsConnectModalOpen: (value: boolean) => void;\n isConnectedModalOpen: boolean;\n setIsConnectedModalOpen: (value: boolean) => void;\n\n // Chain selection states\n isChainsListOpen: boolean;\n setIsChainsListOpen: (value: boolean) => void;\n isChainsListOpenMobile: boolean;\n setIsChainsListOpenMobile: (value: boolean) => void;\n\n // Connection states\n connectedButtonStatus: ButtonTxStatus;\n setConnectedButtonStatus: (value: ButtonTxStatus) => void;\n isConnected: boolean;\n setIsConnected: (value: boolean) => void;\n\n // Modal content types\n connectedModalContentType: ConnectedContentType;\n setConnectedModalContentType: (value: ConnectedContentType) => void;\n connectModalContentType: ConnectContentType;\n setConnectModalContentType: (value: ConnectContentType) => void;\n\n // Adapter and connector states\n selectedAdapter: OrbitAdapter | undefined;\n setSelectedAdapter: (value: OrbitAdapter | undefined) => void;\n activeConnector: string | undefined;\n setActiveConnector: (value: string | undefined) => void;\n\n // Impersonation\n impersonatedAddress: string;\n setImpersonatedAddress: (value: string) => void;\n}\n\n// Custom error for hook usage outside provider\nexport class NovaConnectProviderError extends Error {\n constructor(message = 'useNovaConnect must be used within NovaConnectProvider') {\n super(message);\n this.name = 'NovaConnectProviderError';\n }\n}\n\n// Create context with undefined default to enforce provider usage\nexport const NovaConnectProviderContext = createContext<NovaConnectProviderType | undefined>(undefined);\n\n/**\n * Hook to access NovaConnect context\n *\n * @throws {NovaConnectProviderError} When used outside of NovaConnectProvider\n * @returns {NovaConnectProviderType} The NovaConnect context value\n *\n * @example\n * ```typescript\n * function MyComponent() {\n * const { isConnected, handleConnectButtonClick } = useNovaConnect();\n *\n * return (\n * <button onClick={handleConnectButtonClick}>\n * {isConnected ? 'Connected' : 'Connect Wallet'}\n * </button>\n * );\n * }\n * ```\n */\nexport const useNovaConnect = (): NovaConnectProviderType => {\n const context = useContext(NovaConnectProviderContext);\n\n if (!context) {\n throw new NovaConnectProviderError();\n }\n\n return context;\n};\n\n/**\n * Hook to check if NovaConnect context is available\n *\n * @returns {boolean} True if context is available, false otherwise\n *\n * @example\n * ```typescript\n * function ConditionalComponent() {\n * const hasContext = useHasNovaConnectContext();\n *\n * if (!hasContext) {\n * return <div>NovaConnect provider not found</div>;\n * }\n *\n * return <ConnectedComponent />;\n * }\n * ```\n */\nexport const useHasNovaConnectContext = (): boolean => {\n const context = useContext(NovaConnectProviderContext);\n return context !== undefined;\n};\n\n/**\n * Optional hook that returns null if provider is not available\n *\n * @returns {NovaConnectProviderType | null} Context value or null if not available\n *\n * @example\n * ```typescript\n * function OptionalComponent() {\n * const context = useNovaConnectOptional();\n *\n * if (!context) {\n * return <div>No wallet provider available</div>;\n * }\n *\n * return <div>Connected: {context.isConnected}</div>;\n * }\n * ```\n */\nexport const useNovaConnectOptional = (): NovaConnectProviderType | null => {\n const context = useContext(NovaConnectProviderContext);\n return context ?? null;\n};\n","import { OrbitAdapter } from '@tuwaio/orbit-core';\n\nimport type { AdapterInfo, AdapterLoadStatus, ChainAdapter } from './types';\n\n/**\n * Registry for blockchain adapters with lazy loading and intelligent caching.\n *\n * This class manages the lifecycle of blockchain adapters, providing:\n * - Lazy loading of adapters only when needed\n * - Intelligent caching to avoid redundant loads\n * - Graceful error handling and retry logic\n * - Thread-safe loading with concurrent request handling\n *\n * @internal\n * @since 1.0.0\n */\nclass LazyAdapterRegistry {\n /**\n * Internal cache mapping adapter types to their loading information.\n * @private\n */\n private adapters = new Map<OrbitAdapter, AdapterInfo>();\n\n /**\n * Gets an adapter with automatic loading and caching.\n *\n * This method implements intelligent loading logic:\n * - Returns immediately if adapter is already loaded\n * - Waits for completion if adapter is currently loading\n * - Retries loading if previous attempt failed\n * - Initiates new load if adapter hasn't been requested before\n *\n * @param type The blockchain adapter type to retrieve\n * @returns Promise resolving to the loaded adapter or null if unavailable\n *\n * @example\n * ```typescript\n * const evmAdapter = await registry.getAdapter(OrbitAdapter.EVM);\n * if (evmAdapter) {\n * const chains = evmAdapter.getChains(appChains);\n * }\n * ```\n *\n * @since 1.0.0\n */\n async getAdapter(type: OrbitAdapter): Promise<ChainAdapter | null> {\n const info = this.adapters.get(type);\n\n // Return cached adapter if already loaded\n if (info?.status === 'loaded' && info.adapter) {\n return info.adapter;\n }\n\n // Wait for completion if currently loading\n if (info?.status === 'loading') {\n return this.waitForAdapter(type);\n }\n\n // Retry loading if previous attempt failed\n if (info?.status === 'error') {\n console.warn(`Retrying to load ${type} adapter after previous error`);\n }\n\n // Start new loading process\n return this.loadAdapter(type);\n }\n\n /**\n * Loads a specific adapter with error handling and state management.\n *\n * @private\n * @param type The adapter type to load\n * @returns Promise resolving to the loaded adapter or null on failure\n *\n * @since 1.0.0\n */\n private async loadAdapter(type: OrbitAdapter): Promise<ChainAdapter | null> {\n // Set loading status to prevent concurrent loads\n this.adapters.set(type, { status: 'loading' });\n\n try {\n let adapter: ChainAdapter;\n\n switch (type) {\n case OrbitAdapter.EVM: {\n const { createEvmAdapter } = await import('./evm');\n adapter = await createEvmAdapter();\n break;\n }\n case OrbitAdapter.SOLANA: {\n const { createSolanaAdapter } = await import('./solana');\n adapter = await createSolanaAdapter();\n break;\n }\n case OrbitAdapter.Starknet: {\n // Future implementation placeholder\n console.warn('Starknet adapter not implemented yet');\n this.adapters.set(type, {\n status: 'error',\n error: new Error('Starknet adapter not yet implemented'),\n });\n return null;\n }\n default: {\n const error = new Error(`Unknown adapter type: ${type}`);\n this.adapters.set(type, { status: 'error', error });\n return null;\n }\n }\n\n // Mark as successfully loaded\n this.adapters.set(type, { status: 'loaded', adapter });\n return adapter;\n } catch (error) {\n const err = error instanceof Error ? error : new Error(`Failed to load ${type} adapter`);\n console.warn(`Failed to load ${type} adapter:`, err);\n this.adapters.set(type, { status: 'error', error: err });\n return null;\n }\n }\n\n /**\n * Waits for an adapter that's currently loading to complete.\n *\n * Implements polling with timeout to handle concurrent loading requests.\n * Multiple calls to getAdapter() for the same type will wait for a single\n * loading operation to complete rather than starting multiple loads.\n *\n * @private\n * @param type The adapter type to wait for\n * @returns Promise resolving to the loaded adapter or null on timeout/error\n *\n * @since 1.0.0\n */\n private async waitForAdapter(type: OrbitAdapter): Promise<ChainAdapter | null> {\n let attempts = 0;\n const maxAttempts = 50; // 5 seconds with 100ms intervals\n const pollInterval = 100; // milliseconds\n\n while (attempts < maxAttempts) {\n const info = this.adapters.get(type);\n\n if (info?.status === 'loaded' && info.adapter) {\n return info.adapter;\n }\n\n if (info?.status === 'error') {\n return null;\n }\n\n // Wait before next poll\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n attempts++;\n }\n\n console.warn(`Timeout waiting for ${type} adapter to load after ${maxAttempts * pollInterval}ms`);\n return null;\n }\n\n /**\n * Synchronously retrieves an already loaded adapter.\n *\n * This method only returns adapters that have been successfully loaded\n * and cached. It will not trigger loading of new adapters.\n *\n * @param type The adapter type to retrieve\n * @returns The loaded adapter or null if not available/loaded\n *\n * @example\n * ```typescript\n * // Check if adapter is already loaded\n * const adapter = registry.getLoadedAdapter(OrbitAdapter.EVM);\n * if (adapter) {\n * // Use immediately without waiting\n * const isValid = adapter.isChainList([1, 137]);\n * }\n * ```\n *\n * @since 1.0.0\n */\n getLoadedAdapter(type: OrbitAdapter): ChainAdapter | null {\n const info = this.adapters.get(type);\n return info?.status === 'loaded' ? info.adapter || null : null;\n }\n\n /**\n * Gets the current loading status of a specific adapter.\n *\n * @param type The adapter type to check\n * @returns Current status of the adapter\n *\n * @example\n * ```typescript\n * const status = registry.getAdapterStatus(OrbitAdapter.EVM);\n * console.log(`EVM adapter status: ${status}`);\n * // Possible values: 'idle', 'loading', 'loaded', 'error'\n * ```\n *\n * @since 1.0.0\n */\n getAdapterStatus(type: OrbitAdapter): AdapterLoadStatus {\n return this.adapters.get(type)?.status || 'idle';\n }\n\n /**\n * Checks if an adapter is available by attempting to load it.\n *\n * @param type The adapter type to check for availability\n * @returns Promise resolving to true if adapter can be loaded successfully\n *\n * @example\n * ```typescript\n * const hasEvm = await registry.isAdapterAvailable(OrbitAdapter.EVM);\n * const hasSolana = await registry.isAdapterAvailable(OrbitAdapter.SOLANA);\n *\n * if (hasEvm && hasSolana) {\n * console.log('Multi-chain support available');\n * }\n * ```\n *\n * @since 1.0.0\n */\n async isAdapterAvailable(type: OrbitAdapter): Promise<boolean> {\n const adapter = await this.getAdapter(type);\n return adapter !== null;\n }\n\n /**\n * Preloads multiple adapters for improved performance.\n *\n * This method is useful for application initialization to load commonly\n * used adapters ahead of time. All loading operations run concurrently.\n *\n * @param types Array of adapter types to preload (defaults to EVM and Solana)\n * @returns Promise that resolves when all loading attempts complete\n *\n * @example\n * ```typescript\n * // Preload during app startup\n * await registry.preloadAdapters([OrbitAdapter.EVM, OrbitAdapter.SOLANA]);\n *\n * // Later usage will be instant for loaded adapters\n * const evmAdapter = registry.getLoadedAdapter(OrbitAdapter.EVM);\n * ```\n *\n * @since 1.0.0\n */\n async preloadAdapters(types: OrbitAdapter[] = [OrbitAdapter.EVM, OrbitAdapter.SOLANA]): Promise<void> {\n // Use Promise.allSettled to continue even if some adapters fail\n await Promise.allSettled(types.map((type) => this.getAdapter(type)));\n }\n\n /**\n * Clears all cached adapters and resets the registry state.\n *\n * This method is useful for testing scenarios or when you need to\n * force reload of all adapters (e.g., after configuration changes).\n *\n * @example\n * ```typescript\n * // Clear cache to force reload\n * registry.clearCache();\n *\n * // Next getAdapter() call will reload from scratch\n * const adapter = await registry.getAdapter(OrbitAdapter.EVM);\n * ```\n *\n * @since 1.0.0\n */\n clearCache(): void {\n this.adapters.clear();\n }\n\n /**\n * Gets comprehensive information about all registered adapters.\n *\n * @returns Record mapping adapter types to their current loading status\n *\n * @example\n * ```typescript\n * const info = registry.getAdaptersInfo();\n * console.log('Adapter status overview:', info);\n * // Output: { \"evm\": \"loaded\", \"solana\": \"loading\", \"starknet\": \"idle\" }\n *\n * // Check specific status\n * if (info.evm === 'loaded') {\n * console.log('EVM adapter ready for use');\n * }\n * ```\n *\n * @since 1.0.0\n */\n getAdaptersInfo(): Record<string, AdapterLoadStatus> {\n const info: Record<string, AdapterLoadStatus> = {};\n for (const [type, adapterInfo] of this.adapters.entries()) {\n info[type] = adapterInfo.status;\n }\n return info;\n }\n}\n\n/**\n * Global singleton instance of the adapter registry.\n *\n * This is the primary interface for accessing blockchain adapters throughout\n * the application. The registry handles all loading, caching, and lifecycle\n * management automatically.\n *\n * @example\n * ```typescript\n * import { adapterRegistry } from './registry';\n *\n * // Get an adapter (loads if needed)\n * const evmAdapter = await adapterRegistry.getAdapter(OrbitAdapter.EVM);\n *\n * // Check loading status\n * const status = adapterRegistry.getAdapterStatus(OrbitAdapter.EVM);\n *\n * // Preload adapters during initialization\n * await adapterRegistry.preloadAdapters();\n * ```\n *\n * @since 1.0.0\n */\nexport const adapterRegistry = new LazyAdapterRegistry();\n","import { getAdapterFromWalletType, OrbitAdapter, WalletType } from '@tuwaio/orbit-core';\n\nimport { ChainIdentifierArray, InitialChains } from '../types';\nimport { adapterRegistry } from './adapters/registry';\n\n/**\n * Parameters for retrieving chain lists based on wallet configuration.\n *\n * Combines chain configuration with wallet-specific requirements to determine\n * which chains should be available for a given wallet type.\n *\n * @interface GetChainsListParams\n * @extends InitialChains\n * @since 1.0.0\n *\n * @example\n * ```typescript\n * const params: GetChainsListParams = {\n * walletType: WalletType.EVM_METAMASK,\n * appChains: [\n * { id: 1, name: 'Ethereum' },\n * { id: 137, name: 'Polygon' }\n * ],\n * chains: [1, 137] // Optional filter\n * };\n * ```\n */\ninterface GetChainsListParams extends InitialChains {\n /** The wallet type to determine chain compatibility */\n walletType: WalletType;\n /** Optional array of specific chain identifiers to filter or validate */\n chains?: ChainIdentifierArray;\n}\n\n/**\n * Type guard that validates if a value represents a valid chain identifier.\n *\n * Chain identifiers can be strings (for Solana clusters) or numbers (for EVM chain IDs).\n * This function filters out null, undefined, and other invalid values.\n *\n * @param id - Value to check for validity as chain identifier\n * @returns True if the value is a valid string or number chain ID\n *\n * @example\n * ```typescript\n * const rawChains = [1, 'mainnet-beta', null, undefined, 137];\n * const validChains = rawChains.filter(isValidChainId);\n * // Result: [1, 'mainnet-beta', 137]\n * ```\n *\n * @since 1.0.0\n */\nfunction isValidChainId(id: unknown): id is string | number {\n return id !== undefined && id !== null && (typeof id === 'string' || typeof id === 'number');\n}\n\n/**\n * Retrieves chain list for a specific wallet type with automatic adapter loading.\n *\n * This is the primary function for getting blockchain-compatible chains based on\n * wallet type and configuration. It automatically determines the correct adapter,\n * loads it if necessary, and falls back to safe defaults if loading fails.\n *\n * The function supports all major blockchain types:\n * - EVM chains: Returns numeric chain IDs from app configuration\n * - Solana clusters: Returns string cluster names from RPC configuration\n * - Future blockchains: Extensible through the adapter pattern\n *\n * @param params - Configuration object with wallet type and chain data\n * @returns Promise resolving to array of chain identifiers\n *\n * @example\n * ```typescript\n * // Get EVM chains for MetaMask\n * const evmChains = await getChainsListByWalletType({\n * walletType: WalletType.EVM_METAMASK,\n * appChains: [\n * { id: 1, name: 'Ethereum' },\n * { id: 137, name: 'Polygon' }\n * ]\n * });\n * // Returns: [1, 137]\n *\n * // Get Solana clusters for Phantom\n * const solanaClusters = await getChainsListByWalletType({\n * walletType: WalletType.SOLANA_PHANTOM,\n * solanaRPCUrls: {\n * 'mainnet-beta': 'https://api.mainnet-beta.solana.com',\n * 'devnet': 'https://api.devnet.solana.com'\n * }\n * });\n * // Returns: ['mainnet-beta', 'devnet']\n * ```\n *\n * @since 1.0.0\n */\nexport async function getChainsListByWalletType(params: GetChainsListParams): Promise<(string | number)[]> {\n const { walletType, chains = [], ...config } = params;\n\n if (!walletType) {\n console.warn('getChainsListByWalletType: walletType is required');\n return [];\n }\n\n const adapterType = getAdapterFromWalletType(walletType);\n const adapter = await adapterRegistry.getAdapter(adapterType);\n\n if (!adapter) {\n console.warn(`No adapter available for ${adapterType}, using fallback`);\n return getFallbackChains(adapterType, config);\n }\n\n try {\n if (adapterType === OrbitAdapter.SOLANA) {\n return adapter.getChains(config.solanaRPCUrls, chains);\n } else {\n return adapter.getChains(config.appChains);\n }\n } catch (error) {\n console.warn(`Error getting chains for ${adapterType}:`, error);\n return getFallbackChains(adapterType, config);\n }\n}\n\n/**\n * Synchronous version that only works with pre-loaded adapters.\n *\n * This function provides immediate results by using only adapters that have\n * already been loaded into the registry cache. It will not trigger new\n * loading operations, making it safe for synchronous contexts but potentially\n * less complete than the async version.\n *\n * Use this function when:\n * - You've pre-loaded adapters during app initialization\n * - You need immediate results without async overhead\n * - You're in a synchronous context where async calls aren't feasible\n *\n * @param params - Configuration object with wallet type and chain data\n * @returns Array of chain identifiers (empty if adapter not loaded)\n *\n * @example\n * ```typescript\n * // Pre-load adapters first\n * await preloadChainAdapters([OrbitAdapter.EVM, OrbitAdapter.SOLANA]);\n *\n * // Now safe to use sync version\n * const chains = getChainsListByWalletTypeSync({\n * walletType: WalletType.EVM_METAMASK,\n * appChains: evmConfiguration\n * });\n * ```\n *\n * @since 1.0.0\n */\nexport function getChainsListByWalletTypeSync(params: GetChainsListParams): (string | number)[] {\n const { walletType, chains = [], ...config } = params;\n\n if (!walletType) {\n console.warn('getChainsListByWalletType: walletType is required');\n return [];\n }\n\n const adapterType = getAdapterFromWalletType(walletType);\n const adapter = adapterRegistry.getLoadedAdapter(adapterType);\n\n if (adapter) {\n try {\n if (adapterType === OrbitAdapter.SOLANA) {\n return adapter.getChains(config.solanaRPCUrls, chains);\n } else {\n return adapter.getChains(config.appChains);\n }\n } catch (error) {\n console.warn(`Error with loaded adapter for ${adapterType}:`, error);\n }\n }\n\n return getFallbackChains(adapterType, config);\n}\n\n/**\n * Provides fallback chain extraction without external dependencies.\n *\n * This function implements basic chain extraction logic that works without\n * requiring blockchain-specific packages to be installed. It provides a\n * safety net when adapters fail to load or aren't available.\n *\n * Fallback behaviors:\n * - EVM: Extracts `id` field from chain objects or direct identifiers\n * - Solana: Extracts keys from RPC URL configuration objects\n * - Unknown: Returns empty array\n *\n * @private\n * @param adapterType - The blockchain adapter type\n * @param config - Configuration object containing chain data\n * @returns Array of extracted chain identifiers\n *\n * @since 1.0.0\n */\nfunction getFallbackChains(adapterType: OrbitAdapter, config: any): (string | number)[] {\n switch (adapterType) {\n case OrbitAdapter.EVM: {\n const appChains = config.appChains;\n if (!Array.isArray(appChains)) return [];\n\n return appChains\n .map((chain: any) => {\n // Handle chain objects with id property (e.g., { id: 1, name: 'Ethereum' })\n if (typeof chain === 'object' && chain?.id) return chain.id;\n // Handle direct chain identifiers (numbers or strings)\n if (typeof chain === 'number' || typeof chain === 'string') return chain;\n return null;\n })\n .filter(isValidChainId);\n }\n case OrbitAdapter.SOLANA: {\n const solanaRPCUrls = config.solanaRPCUrls;\n // Extract cluster names from RPC URL configuration\n return solanaRPCUrls && typeof solanaRPCUrls === 'object' ? Object.keys(solanaRPCUrls) : [];\n }\n default:\n return [];\n }\n}\n\n// ========================================\n// Chain List Validation Functions\n// ========================================\n\n/**\n * Validates if a chain list conforms to EVM format (with adapter loading).\n *\n * Uses the EVM adapter to perform comprehensive validation, falling back to\n * basic type checking if the adapter isn't available. EVM chains typically\n * use numeric identifiers.\n *\n * @param chains - Array of chain identifiers to validate\n * @returns Promise resolving to true if chains are valid for EVM\n *\n * @example\n * ```typescript\n * const isEvm = await isEvmChainList([1, 137, 56]); // true\n * const notEvm = await isEvmChainList(['mainnet-beta']); // false\n * ```\n *\n * @since 1.0.0\n */\nexport async function isEvmChainList(chains: (string | number)[]): Promise<boolean> {\n const adapter = await adapterRegistry.getAdapter(OrbitAdapter.EVM);\n return adapter?.isChainList(chains) ?? chains.every((chain) => typeof chain === 'number');\n}\n\n/**\n * Validates if a chain list conforms to Solana format (with adapter loading).\n *\n * Uses the Solana adapter to perform comprehensive validation, falling back to\n * basic type checking if the adapter isn't available. Solana chains typically\n * use string cluster names.\n *\n * @param chains - Array of chain identifiers to validate\n * @returns Promise resolving to true if chains are valid for Solana\n *\n * @example\n * ```typescript\n * const isSolana = await isSolanaChainList(['mainnet-beta', 'devnet']); // true\n * const notSolana = await isSolanaChainList([1, 137]); // false\n * ```\n *\n * @since 1.0.0\n */\nexport async function isSolanaChainList(chains: (string | number)[]): Promise<boolean> {\n const adapter = await adapterRegistry.getAdapter(OrbitAdapter.SOLANA);\n return adapter?.isChainList(chains) ?? chains.every((chain) => typeof chain === 'string');\n}\n\n/**\n * Synchronous EVM chain list validation using pre-loaded adapters.\n *\n * Provides immediate validation results without triggering adapter loading.\n * Falls back to basic type checking if adapter isn't pre-loaded.\n *\n * @param chains - Array of chain identifiers to validate\n * @returns True if chains are valid for EVM\n *\n * @example\n * ```typescript\n * const isEvm = isEvmChainListSync([1, 137, 56]); // true (immediate result)\n * ```\n *\n * @since 1.0.0\n */\nexport function isEvmChainListSync(chains: (string | number)[]): boolean {\n const adapter = adapterRegistry.getLoadedAdapter(OrbitAdapter.EVM);\n return adapter?.isChainList(chains) ?? chains.every((chain) => typeof chain === 'number');\n}\n\n/**\n * Synchronous Solana chain list validation using pre-loaded adapters.\n *\n * Provides immediate validation results without triggering adapter loading.\n * Falls back to basic type checking if adapter isn't pre-loaded.\n *\n * @param chains - Array of chain identifiers to validate\n * @returns True if chains are valid for Solana\n *\n * @example\n * ```typescript\n * const isSolana = isSolanaChainListSync(['mainnet-beta', 'devnet']); // true\n * ```\n *\n * @since 1.0.0\n */\nexport function isSolanaChainListSync(chains: (string | number)[]): boolean {\n const adapter = adapterRegistry.getLoadedAdapter(OrbitAdapter.SOLANA);\n return adapter?.isChainList(chains) ?? chains.every((chain) => typeof chain === 'string');\n}\n\n// ========================================\n// Solana-Specific Utilities\n// ========================================\n\n/**\n * Retrieves all available Solana clusters from the current configuration.\n *\n * This function loads the Solana adapter and queries it for all configured\n * cluster names. Useful for populating UI dropdowns or validating cluster\n * availability before connection attempts.\n *\n * @returns Promise resolving to array of available cluster names\n *\n * @example\n * ```typescript\n * const clusters = await getAvailableSolanaClusters();\n * console.log('Available clusters:', clusters);\n * // Might log: ['mainnet-beta', 'devnet', 'testnet', 'localnet']\n *\n * // Use for UI population\n * const clusterOptions = clusters.map(cluster => ({\n * value: cluster,\n * label: cluster.replace('-', ' ').toUpperCase()\n * }));\n * ```\n *\n * @since 1.0.0\n */\nexport async function getAvailableSolanaClusters(): Promise<string[]> {\n const adapter = await adapterRegistry.getAdapter(OrbitAdapter.SOLANA);\n return adapter?.getAvailableClusters?.() ?? [];\n}\n\n/**\n * Validates whether a cluster name is valid for Solana connections.\n *\n * This function loads the Solana adapter and uses it to validate cluster\n * names against known Solana cluster monikers and custom configurations.\n *\n * @param cluster - Cluster name to validate\n * @returns Promise resolving to true if cluster is valid\n *\n * @example\n * ```typescript\n * const isValid = await isValidSolanaCluster('mainnet-beta'); // true\n * const isInvalid = await isValidSolanaCluster('invalid-cluster'); // false\n *\n * // Use for form validation\n * if (await isValidSolanaCluster(userInput)) {\n * // Proceed with connection\n * } else {\n * // Show error message\n * }\n * ```\n *\n * @since 1.0.0\n */\nexport async function isValidSolanaCluster(cluster: string): Promise<boolean> {\n const adapter = await adapterRegistry.getAdapter(OrbitAdapter.SOLANA);\n return adapter?.isValidCluster?.(cluster) ?? false;\n}\n\n// ========================================\n// Wallet Chain Extraction Utilities\n// ========================================\n\n/**\n * Safely extracts chain information from a wallet object.\n *\n * This utility function handles the complex nested structure of wallet objects\n * and safely extracts chain information without throwing errors. It performs\n * comprehensive type checking to ensure data integrity.\n *\n * The function expects wallet objects with this structure:\n * ```\n * {\n * connectedWallet: {\n * chains: [chain1, chain2, ...]\n * }\n * }\n * ```\n *\n * @param activeWallet - Wallet object to extract chains from\n * @returns Array of chain identifiers or undefined if not found/invalid\n *\n * @example\n * ```typescript\n * // With valid wallet structure\n * const wallet = {\n * connectedWallet: {\n * chains: [1, 137, 56]\n * }\n * };\n * const chains = getWalletChains(wallet); // [1, 137, 56]\n *\n * // With invalid/missing structure\n * const invalidWallet = { someOtherProperty: true };\n * const noChains = getWalletChains(invalidWallet); // undefined\n *\n * // Use in conditional logic\n * const walletChains = getWalletChains(activeWallet);\n * if (walletChains) {\n * console.log('Wallet supports chains:', walletChains);\n * }\n * ```\n *\n * @since 1.0.0\n */\nexport function getWalletChains(activeWallet: any): (string | number)[] | undefined {\n if (\n activeWallet &&\n typeof activeWallet === 'object' &&\n 'connectedWallet' in activeWallet &&\n activeWallet.connectedWallet &&\n typeof activeWallet.connectedWallet === 'object' &&\n 'chains' in activeWallet.connectedWallet\n ) {\n const chains = activeWallet.connectedWallet.chains;\n if (Array.isArray(chains)) {\n return chains;\n }\n }\n return undefined;\n}\n\n// ========================================\n// Adapter Management Utilities\n// ========================================\n\n/**\n * Pre-loads blockchain adapters for improved application performance.\n *\n * This function should be called during application initialization to load\n * commonly used adapters ahead of time. This eliminates loading delays when\n * users first interact with wallet connections.\n *\n * All loading operations run concurrently for maximum efficiency, and the\n * function completes even if some adapters fail to load (partial success).\n *\n * @param types - Array of adapter types to preload (defaults to EVM and Solana)\n * @returns Promise that resolves when all loading attempts complete\n *\n * @example\n * ```typescript\n * // During app initialization\n * export async function initializeApp() {\n * // Preload common adapters\n * await preloadChainAdapters([OrbitAdapter.EVM, OrbitAdapter.SOLANA]);\n *\n * // Continue with other initialization\n * // ...\n * }\n *\n * // Later usage will be instant for loaded adapters\n * const evmChains = getChainsListByWalletTypeSync({\n * walletType: WalletType.EVM_METAMASK,\n * appChains: configuration\n * }); // Instant result since adapter is pre-loaded\n * ```\n *\n * @since 1.0.0\n */\nexport async function preloadChainAdapters(\n types: OrbitAdapter[] = [OrbitAdapter.EVM, OrbitAdapter.SOLANA],\n): Promise<void> {\n await adapterRegistry.preloadAdapters(types);\n}\n\n/**\n * Gets the current loading status of a specific adapter.\n *\n * Returns the current state of an adapter in the loading lifecycle. Useful\n * for UI indicators, debugging, or conditional logic based on adapter\n * availability.\n *\n * @param type - The adapter type to check\n * @returns Current loading status of the adapter\n *\n * @example\n * ```typescript\n * const evmStatus = getAdapterStatus(OrbitAdapter.EVM);\n *\n * switch (evmStatus) {\n * case 'idle':\n * console.log('EVM adapter not yet requested');\n * break;\n * case 'loading':\n * // Show loading spinner\n * break;\n * case 'loaded':\n * // Enable EVM features\n * break;\n * case 'error':\n * // Show fallback UI\n * break;\n * }\n * ```\n *\n * @since 1.0.0\n */\nexport function getAdapterStatus(type: OrbitAdapter) {\n return adapterRegistry.getAdapterStatus(type);\n}\n\n/**\n * Gets comprehensive status information for all registered adapters.\n *\n * Returns a complete overview of all adapter states, useful for debugging,\n * monitoring, or displaying system status in admin interfaces.\n *\n * @returns Record mapping adapter types to their current loading status\n *\n * @example\n * ```typescript\n * const allStatuses = getAllAdaptersStatus();\n * console.log('System overview:', allStatuses);\n * // Output: { \"evm\": \"loaded\", \"solana\": \"loading\", \"starknet\": \"idle\" }\n *\n * // Use for system health monitoring\n * const loadedAdapters = Object.entries(allStatuses)\n * .filter(([_, status]) => status === 'loaded')\n * .map(([type, _]) => type);\n *\n * console.log('Available blockchain support:', loadedAdapters);\n * ```\n *\n * @since 1.0.0\n */\nexport function getAllAdaptersStatus() {\n return adapterRegistry.getAdaptersInfo();\n}\n","import { OrbitAdapter } from '@tuwaio/orbit-core';\n\nimport { InitialChains } from '../types';\n\n// Default fallback chain IDs\nconst DEFAULT_CHAIN_IDS = {\n [OrbitAdapter.EVM]: 1, // Ethereum Mainnet\n [OrbitAdapter.SOLANA]: 'mainnet',\n [OrbitAdapter.Starknet]: '0x534e5f4d41494e',\n} as const;\n\n/**\n * Basic interface for chain objects to handle the any type safely\n */\ninterface BasicChain {\n id: number | string;\n [key: string]: any;\n}\n\n/**\n * Gets the appropriate chain ID for connecting based on the selected adapter.\n * Returns the first available chain for the adapter, or a sensible default.\n *\n * @param params - Configuration object\n * @param params.selectedAdapter - The blockchain adapter to use\n * @param params.appChains - Available EVM chains\n * @param params.solanaRPCUrls - Available Solana networks\n * @returns Chain ID (number for EVM/Starknet, string for Solana)\n */\nexport function getConnectChainId({\n selectedAdapter,\n appChains,\n solanaRPCUrls,\n}: { selectedAdapter: OrbitAdapter } & InitialChains): number | string {\n switch (selectedAdapter) {\n case OrbitAdapter.EVM: {\n // Return first available EVM chain or default to Ethereum\n const firstChain = appChains?.[0];\n if (firstChain?.id && typeof firstChain.id === 'number') {\n return firstChain.id;\n }\n\n if (process.env.NODE_ENV === 'development' && !appChains?.length) {\n console.warn('getConnectChainId: No EVM chains configured, using Ethereum Mainnet');\n }\n\n return DEFAULT_CHAIN_IDS[OrbitAdapter.EVM];\n }\n\n case OrbitAdapter.SOLANA: {\n // Return first available Solana network or default to mainnet\n if (solanaRPCUrls && typeof solanaRPCUrls === 'object') {\n const networks = Object.keys(solanaRPCUrls);\n if (networks.length > 0) {\n return networks[0];\n }\n }\n\n if (process.env.NODE_ENV === 'development' && !solanaRPCUrls) {\n console.warn('getConnectChainId: No Solana RPC URLs configured, using mainnet');\n }\n\n return DEFAULT_CHAIN_IDS[OrbitAdapter.SOLANA];\n }\n\n case OrbitAdapter.Starknet: {\n if (process.env.NODE_ENV === 'development') {\n console.info('getConnectChainId: Using default Starknet chain ID');\n }\n\n return DEFAULT_CHAIN_IDS[OrbitAdapter.Starknet];\n }\n\n default: {\n // Handle unknown adapter types gracefully\n if (process.env.NODE_ENV === 'development') {\n console.error('getConnectChainId: Unknown adapter:', selectedAdapter);\n }\n\n return DEFAULT_CHAIN_IDS[OrbitAdapter.EVM];\n }\n }\n}\n\n/**\n * Helper to get all available chain IDs for an adapter\n */\nexport function getAvailableChainIds({\n selectedAdapter,\n appChains,\n solanaRPCUrls,\n}: { selectedAdapter: OrbitAdapter } & InitialChains): Array<number | string> {\n switch (selectedAdapter) {\n case OrbitAdapter.EVM:\n return appChains?.map((chain: BasicChain) => chain.id).filter(Boolean) ?? [DEFAULT_CHAIN_IDS[OrbitAdapter.EVM]];\n\n case OrbitAdapter.SOLANA:\n return solanaRPCUrls ? Object.keys(solanaRPCUrls) : [DEFAULT_CHAIN_IDS[OrbitAdapter.SOLANA]];\n\n case OrbitAdapter.Starknet:\n return [DEFAULT_CHAIN_IDS[OrbitAdapter.Starknet]];\n\n default:\n return [DEFAULT_CHAIN_IDS[OrbitAdapter.EVM]];\n }\n}\n","import { formatWalletName, OrbitAdapter } from '@tuwaio/orbit-core';\n\nimport { Connector } from '../types';\n\nexport interface GroupedConnector {\n name: string;\n icon?: string;\n adapters: OrbitAdapter[];\n connectors: (Connector & { adapter: OrbitAdapter })[];\n}\n\ninterface GetGroupedConnectorsParams {\n connectors: Partial<Record<OrbitAdapter, Connector[]>>;\n excludeConnectors?: string[];\n}\n\n/**\n * Type for a safely processed connector\n */\ntype ProcessedConnector = {\n name: string;\n icon?: string;\n adapter: OrbitAdapter;\n originalConnector: Connector;\n};\n\n/**\n * Safely processes a connector and extracts its properties\n */\nfunction processConnector(connector: unknown, adapter: OrbitAdapter): ProcessedConnector | null {\n if (!connector || typeof connector !== 'object') {\n return null;\n }\n\n const connectorObj = connector as Record<string, Connector>;\n\n if (!connectorObj.name || typeof connectorObj.name !== 'string') {\n return null;\n }\n\n return {\n name: connectorObj.name,\n icon: connectorObj.icon,\n adapter,\n originalConnector: connectorObj as Connector,\n };\n}\n\n/**\n * Groups wallet connectors by their formatted names across different adapters.\n * Filters out specified excluded connectors (like 'injected' wallets).\n */\nexport function getGroupedConnectors(\n { connectors, excludeConnectors = ['injected'] }: GetGroupedConnectorsParams = { connectors: {} },\n): GroupedConnector[] {\n // Input validation\n if (!connectors || Object.keys(connectors).length === 0) {\n return [];\n }\n\n // Create exclusion set for efficient lookup\n const excludeSet = new Set(excludeConnectors.map((name) => formatWalletName(name)));\n\n // Process and collect all valid connectors\n const processedConnectors: ProcessedConnector[] = [];\n\n Object.entries(connectors).forEach(([adapterKey, adapterConnectors]) => {\n if (Array.isArray(adapterConnectors)) {\n const adapter = adapterKey as OrbitAdapter;\n\n adapterConnectors.forEach((connector) => {\n const processed = processConnector(connector, adapter);\n if (processed) {\n const formattedName = formatWalletName(processed.name);\n if (!excludeSet.has(formattedName)) {\n processedConnectors.push(processed);\n }\n }\n });\n }\n });\n\n // Group by formatted wallet name using Map for better performance\n const groupedMap = new Map<string, GroupedConnector>();\n\n processedConnectors.forEach((processed) => {\n const formattedName = formatWalletName(processed.name);\n\n if (!groupedMap.has(formattedName)) {\n groupedMap.set(formattedName, {\n name: processed.name,\n icon: processed.icon,\n adapters: [],\n connectors: [],\n });\n }\n\n const group = groupedMap.get(formattedName)!;\n\n // Add unique adapter\n if (!group.adapters.includes(processed.adapter)) {\n group.adapters.push(processed.adapter);\n }\n // @ts-expect-error - connectors property is not typed on package level\n group.connectors.push({ ...(processed.originalConnector as Connector), adapter: processed.adapter } as Connector & {\n adapter: OrbitAdapter;\n });\n\n // Update icon if not set\n if (!group.icon && processed.icon) {\n group.icon = processed.icon;\n }\n });\n\n // Return sorted array for consistent ordering\n return Array.from(groupedMap.values()).sort((a, b) =>\n a.name.localeCompare(b.name, undefined, { sensitivity: 'base' }),\n );\n}\n\n/**\n * Quick helper to check if connectors are available\n */\nexport function hasAvailableConnectors(connectors: Partial<Record<OrbitAdapter, Connector[]>>): boolean {\n return Object.values(connectors).some(\n (adapterConnectors) => Array.isArray(adapterConnectors) && adapterConnectors.length > 0,\n );\n}\n","import { OrbitAdapter } from '@tuwaio/orbit-core';\n\nimport { Connector } from '../types';\nimport { getGroupedConnectors, GroupedConnector } from './getGroupedConnectors';\n\ninterface GetFilteredConnectorsParams {\n connectors: Partial<Record<OrbitAdapter, Connector[]>>;\n selectedAdapter?: OrbitAdapter;\n}\n\n/**\n * Type for connector with adapter information\n */\ntype ConnectorWithAdapter = Connector & { adapter: OrbitAdapter };\n\n/**\n * Helper function to safely access connector adapter property\n * Uses any type to avoid TypeScript inference issues with complex types\n */\nfunction getConnectorAdapter(connector: any): OrbitAdapter | undefined {\n // Safe property access without type guards\n try {\n if (connector && typeof connector === 'object' && connector.adapter) {\n return connector.adapter as OrbitAdapter;\n }\n } catch {\n // Silently handle any errors in property access\n }\n return undefined;\n}\n\n/**\n * Helper function to check if connector matches the selected adapter\n */\nfunction connectorMatchesAdapter(connector: any, selectedAdapter: OrbitAdapter): boolean {\n const connectorAdapter = getConnectorAdapter(connector);\n return connectorAdapter === selectedAdapter;\n}\n\n/**\n * Filters grouped connectors by the selected adapter.\n * Returns all connectors if no adapter is selected, or only connectors\n * that support the specified adapter if one is provided.\n *\n * @param params Configuration object with connectors and optional adapter filter\n * @returns Filtered array of grouped connectors\n */\nexport function getFilteredConnectors({\n connectors,\n selectedAdapter,\n}: GetFilteredConnectorsParams): GroupedConnector[] {\n // Input validation\n if (!connectors || Object.keys(connectors).length === 0) {\n return [];\n }\n\n const groupedConnectors = getGroupedConnectors({ connectors });\n\n // Return all connectors if no filter is applied\n if (!selectedAdapter) {\n return groupedConnectors;\n }\n\n // Filter and transform connector groups\n return groupedConnectors\n .filter((group) => {\n // Only include groups that support the selected adapter\n return (\n group.adapters.includes(selectedAdapter) &&\n group.connectors.some((connector) => connectorMatchesAdapter(connector, selectedAdapter))\n );\n })\n .map((group) => {\n // Create new group with filtered connectors\n const filteredConnectors = group.connectors.filter((connector) =>\n connectorMatchesAdapter(connector, selectedAdapter),\n );\n\n return {\n ...group,\n // Narrow down to only the selected adapter\n adapters: [selectedAdapter],\n // Cast to proper type since we know these connectors have the adapter property\n connectors: filteredConnectors as ConnectorWithAdapter[],\n };\n })\n .filter((group) => group.connectors.length > 0); // Remove empty groups\n}\n\n/**\n * Quick helper to check if any connectors exist for an adapter\n */\nexport function hasConnectorsForAdapter(\n connectors: Partial<Record<OrbitAdapter, Connector[]>>,\n adapter: OrbitAdapter,\n): boolean {\n const adapterConnectors = connectors[adapter];\n return Array.isArray(adapterConnectors) && adapterConnectors.length > 0;\n}\n","import { OrbitAdapter } from '@tuwaio/orbit-core';\n\nexport const getNetworkIcon = (adapter: OrbitAdapter) => {\n switch (adapter) {\n case OrbitAdapter.EVM:\n return {\n chainId: 1,\n name: 'Ethereum',\n };\n case OrbitAdapter.SOLANA:\n return {\n chainId: 'solana:mainnet',\n name: 'Solana',\n };\n }\n};\n","import { OrbitAdapter } from '@tuwaio/orbit-core';\n\nexport const networksLinks: Partial<\n Record<OrbitAdapter, { aboutNetwork: string; choseWallet: string; about: string }>\n> = {\n [OrbitAdapter.EVM]: {\n aboutNetwork: 'https://ethereum.org/developers/docs/intro-to-ethereum/',\n choseWallet: 'https://ethereum.org/wallets/find-wallet/',\n about: 'https://ethereum.org/wallets/',\n },\n [OrbitAdapter.SOLANA]: {\n aboutNetwork: 'https://solana.com/en/learn/what-is-solana',\n choseWallet: 'https://solana.com/en/solana-wallets',\n about: 'https://solana.com/en/learn/what-is-a-wallet',\n },\n};\n","/**\n * @file This file contains the `ToBottomButton` component, a customizable scroll-to-bottom button with full styling control.\n */\n\nimport { ChevronDownIcon } from '@heroicons/react/24/solid';\nimport { cn } from '@tuwaio/nova-core';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useCallback, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\n\n// --- Types for Customization ---\ntype CustomIconProps = {\n disabled: boolean;\n className?: string;\n 'aria-hidden'?: boolean;\n};\n\ntype CustomContentProps = {\n icon: ReactNode;\n disabled: boolean;\n ariaLabel?: string;\n};\n\n/**\n * Customization options for ToBottomButton component\n */\nexport type ToBottomButtonCustomization = {\n /** Override button element props */\n buttonProps?: Partial<ComponentPropsWithoutRef<'button'>>;\n /** Custom components */\n components?: {\n /** Custom icon component */\n Icon?: ComponentType<CustomIconProps>;\n /** Custom button content component (wraps the icon) */\n Content?: ComponentType<CustomContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate button classes */\n button?: (params: { disabled: boolean; hasOnClick: boolean }) => string;\n /** Function to generate icon classes */\n icon?: (params: { disabled: boolean }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom click handler wrapper */\n onClick?: (\n originalHandler: (event: React.MouseEvent<HTMLButtonElement>) => void,\n event: React.MouseEvent<HTMLButtonElement>,\n ) => void;\n /** Custom keydown handler wrapper */\n onKeyDown?: (\n originalHandler: (event: React.KeyboardEvent<HTMLButtonElement>) => void,\n event: React.KeyboardEvent<HTMLButtonElement>,\n ) => void;\n };\n};\n\nexport interface ToBottomButtonProps\n extends Omit<ComponentPropsWithoutRef<'button'>, 'type' | 'onClick' | 'onKeyDown' | 'style'> {\n /** Custom CSS classes for the button */\n className?: string;\n /** Custom aria-label for the button */\n 'aria-label'?: string;\n /** Callback fired when button is clicked */\n onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n /** Whether the button is disabled */\n disabled?: boolean;\n /** Customization options */\n customization?: ToBottomButtonCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultIcon = ({ disabled, className, ...props }: CustomIconProps) => {\n return (\n <ChevronDownIcon\n className={cn(\n 'novacon:w-4 novacon:h-4 novacon:transition-transform novacon:duration-200',\n {\n 'novacon:opacity-50': disabled,\n },\n className,\n )}\n {...props}\n />\n );\n};\n\nconst DefaultContent = ({ icon }: CustomContentProps) => {\n return <>{icon}</>;\n};\n\n// --- Default Event Handlers ---\nconst defaultClickHandler = (\n originalHandler: (event: React.MouseEvent<HTMLButtonElement>) => void,\n event: React.MouseEvent<HTMLButtonElement>,\n) => {\n originalHandler(event);\n};\n\nconst defaultKeyDownHandler = (\n originalHandler: (event: React.KeyboardEvent<HTMLButtonElement>) => void,\n event: React.KeyboardEvent<HTMLButtonElement>,\n) => {\n originalHandler(event);\n};\n\n/**\n * A highly customizable scroll-to-bottom button component with extensive styling options and accessibility features.\n * Provides comprehensive customization for appearance, behavior, and event handling while maintaining keyboard navigation support.\n */\nexport const ToBottomButton = forwardRef<HTMLButtonElement, ToBottomButtonProps>(\n ({ className, 'aria-label': ariaLabel, onClick, disabled = false, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract custom components and handlers\n const { Icon = DefaultIcon, Content = DefaultContent } = customization?.components ?? {};\n\n const {\n onClick: customOnClickHandler = defaultClickHandler,\n onKeyDown: customOnKeyDownHandler = defaultKeyDownHandler,\n } = customization?.handlers ?? {};\n\n // Handle click events\n const handleClick = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n const originalHandler = (e: React.MouseEvent<HTMLButtonElement>) => {\n // Prevent default scroll behavior if custom handler provided\n if (onClick) {\n e.preventDefault();\n onClick(e);\n }\n };\n\n customOnClickHandler(originalHandler, event);\n },\n [onClick, customOnClickHandler],\n );\n\n // Handle keyboard events\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLButtonElement>) => {\n const originalHandler = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n // Handle keyboard activation\n if ((e.key === 'Enter' || e.key === ' ') && onClick) {\n e.preventDefault();\n // Create a synthetic mouse event for onClick compatibility\n const syntheticEvent = {\n ...e,\n button: 0,\n buttons: 1,\n clientX: 0,\n clientY: 0,\n movementX: 0,\n movementY: 0,\n offsetX: 0,\n offsetY: 0,\n pageX: 0,\n pageY: 0,\n relatedTarget: null,\n screenX: 0,\n screenY: 0,\n x: 0,\n y: 0,\n getModifierState: () => false,\n initMouseEvent: () => {},\n };\n // eslint-disable-next-line\n onClick(syntheticEvent as any);\n }\n };\n\n customOnKeyDownHandler(originalHandler, event);\n },\n [onClick, customOnKeyDownHandler],\n );\n\n // Generate button classes\n const buttonClasses = useMemo(() => {\n if (customization?.classNames?.button) {\n return customization.classNames.button({ disabled, hasOnClick: Boolean(onClick) });\n }\n return cn(\n 'novacon:flex novacon:w-full novacon:h-6 novacon:items-center novacon:justify-center',\n 'novacon:bg-[var(--tuwa-bg-secondary)] novacon:text-[var(--tuwa-text-primary)]',\n 'novacon:transition-colors novacon:duration-200',\n 'novacon:hover:bg-[var(--tuwa-bg-tertiary)] novacon:hover:text-[var(--tuwa-text-secondary)]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-text-accent)] novacon:focus:ring-inset',\n 'novacon:active:bg-[var(--tuwa-bg-quaternary)]',\n 'novacon:disabled:opacity-50 novacon:disabled:cursor-not-allowed novacon:disabled:hover:bg-[var(--tuwa-bg-secondary)] novacon:cursor-default',\n {\n 'novacon:cursor-pointer': onClick,\n },\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.button, disabled, onClick, className]);\n\n // Generate icon classes\n const iconClasses = useMemo(() => {\n if (customization?.classNames?.icon) {\n return customization.classNames.icon({ disabled });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.icon, disabled]);\n\n // Create icon element\n const iconElement = useMemo(\n () => <Icon disabled={disabled} className={iconClasses} aria-hidden />,\n [Icon, disabled, iconClasses],\n );\n\n // Merge button props\n const buttonProps = useMemo(\n () => ({\n ...customization?.buttonProps,\n ...props,\n ref,\n type: 'button' as const,\n onClick: handleClick,\n onKeyDown: handleKeyDown,\n disabled,\n className: buttonClasses,\n 'aria-label': ariaLabel || labels.scrollToBottom,\n title: ariaLabel || labels.scrollToBottom,\n }),\n [\n customization?.buttonProps,\n props,\n ref,\n handleClick,\n handleKeyDown,\n disabled,\n buttonClasses,\n ariaLabel,\n labels.scrollToBottom,\n ],\n );\n\n return (\n <button {...buttonProps}>\n <Content icon={iconElement} disabled={disabled} ariaLabel={ariaLabel} />\n </button>\n );\n },\n);\n\nToBottomButton.displayName = 'ToBottomButton';\n","/**\n * @file This file contains the `ToTopButton` component, a customizable scroll-to-top button with full styling control.\n */\n\nimport { ChevronUpIcon } from '@heroicons/react/24/solid';\nimport { cn } from '@tuwaio/nova-core';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useCallback, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\n\n// --- Types for Customization ---\ntype CustomIconProps = {\n disabled: boolean;\n className?: string;\n 'aria-hidden'?: boolean;\n};\n\ntype CustomContentProps = {\n icon: ReactNode;\n disabled: boolean;\n ariaLabel?: string;\n};\n\n/**\n * Customization options for ToTopButton component\n */\nexport type ToTopButtonCustomization = {\n /** Override button element props */\n buttonProps?: Partial<ComponentPropsWithoutRef<'button'>>;\n /** Custom components */\n components?: {\n /** Custom icon component */\n Icon?: ComponentType<CustomIconProps>;\n /** Custom button content component (wraps the icon) */\n Content?: ComponentType<CustomContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate button classes */\n button?: (params: { disabled: boolean; hasOnClick: boolean }) => string;\n /** Function to generate icon classes */\n icon?: (params: { disabled: boolean }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom click handler wrapper */\n onClick?: (\n originalHandler: (event: React.MouseEvent<HTMLButtonElement>) => void,\n event: React.MouseEvent<HTMLButtonElement>,\n ) => void;\n /** Custom keydown handler wrapper */\n onKeyDown?: (\n originalHandler: (event: React.KeyboardEvent<HTMLButtonElement>) => void,\n event: React.KeyboardEvent<HTMLButtonElement>,\n ) => void;\n };\n};\n\nexport interface ToTopButtonProps\n extends Omit<ComponentPropsWithoutRef<'button'>, 'type' | 'onClick' | 'onKeyDown' | 'style'> {\n /** Custom CSS classes for the button */\n className?: string;\n /** Custom aria-label for the button */\n 'aria-label'?: string;\n /** Callback fired when button is clicked */\n onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n /** Whether the button is disabled */\n disabled?: boolean;\n /** Customization options */\n customization?: ToTopButtonCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultIcon = ({ disabled, className, ...props }: CustomIconProps) => {\n return (\n <ChevronUpIcon\n className={cn(\n 'novacon:w-4 novacon:h-4 novacon:transition-transform novacon:duration-200',\n disabled && 'novacon:opacity-50',\n className,\n )}\n {...props}\n />\n );\n};\n\nconst DefaultContent = ({ icon }: CustomContentProps) => {\n return <>{icon}</>;\n};\n\n// --- Default Event Handlers ---\nconst defaultClickHandler = (\n originalHandler: (event: React.MouseEvent<HTMLButtonElement>) => void,\n event: React.MouseEvent<HTMLButtonElement>,\n) => {\n originalHandler(event);\n};\n\nconst defaultKeyDownHandler = (\n originalHandler: (event: React.KeyboardEvent<HTMLButtonElement>) => void,\n event: React.KeyboardEvent<HTMLButtonElement>,\n) => {\n originalHandler(event);\n};\n\n/**\n * A highly customizable scroll-to-top button component with extensive styling options and accessibility features.\n * Provides comprehensive customization for appearance, behavior, and event handling while maintaining keyboard navigation support.\n */\nexport const ToTopButton = forwardRef<HTMLButtonElement, ToTopButtonProps>(\n ({ className, 'aria-label': ariaLabel, onClick, disabled = false, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract custom components and handlers\n const { Icon = DefaultIcon, Content = DefaultContent } = customization?.components ?? {};\n\n const {\n onClick: customOnClickHandler = defaultClickHandler,\n onKeyDown: customOnKeyDownHandler = defaultKeyDownHandler,\n } = customization?.handlers ?? {};\n\n // Handle click events\n const handleClick = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n const originalHandler = (e: React.MouseEvent<HTMLButtonElement>) => {\n // Prevent default scroll behavior if custom handler provided\n if (onClick) {\n e.preventDefault();\n onClick(e);\n }\n };\n\n customOnClickHandler(originalHandler, event);\n },\n [onClick, customOnClickHandler],\n );\n\n // Handle keyboard events\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLButtonElement>) => {\n const originalHandler = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n // Handle keyboard activation\n if ((e.key === 'Enter' || e.key === ' ') && onClick) {\n e.preventDefault();\n // Create a synthetic mouse event for onClick compatibility\n const syntheticEvent = {\n ...e,\n button: 0,\n buttons: 1,\n clientX: 0,\n clientY: 0,\n movementX: 0,\n movementY: 0,\n offsetX: 0,\n offsetY: 0,\n pageX: 0,\n pageY: 0,\n relatedTarget: null,\n screenX: 0,\n screenY: 0,\n x: 0,\n y: 0,\n getModifierState: () => false,\n initMouseEvent: () => {},\n };\n // eslint-disable-next-line\n onClick(syntheticEvent as any);\n }\n };\n\n customOnKeyDownHandler(originalHandler, event);\n },\n [onClick, customOnKeyDownHandler],\n );\n\n // Generate button classes\n const buttonClasses = useMemo(() => {\n if (customization?.classNames?.button) {\n return customization.classNames.button({ disabled, hasOnClick: Boolean(onClick) });\n }\n return cn(\n 'novacon:flex novacon:w-full novacon:h-6 novacon:items-center novacon:justify-center',\n 'novacon:bg-[var(--tuwa-bg-secondary)] novacon:text-[var(--tuwa-text-primary)]',\n 'novacon:transition-colors novacon:duration-200',\n 'novacon:hover:bg-[var(--tuwa-bg-tertiary)] novacon:hover:text-[var(--tuwa-text-secondary)]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-text-accent)] novacon:focus:ring-inset',\n 'novacon:active:bg-[var(--tuwa-bg-quaternary)]',\n 'novacon:disabled:opacity-50 novacon:disabled:cursor-not-allowed novacon:disabled:hover:bg-[var(--tuwa-bg-secondary)] novacon:cursor-default',\n {\n 'novacon:cursor-pointer': onClick,\n },\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.button, disabled, onClick, className]);\n\n // Generate icon classes\n const iconClasses = useMemo(() => {\n if (customization?.classNames?.icon) {\n return customization.classNames.icon({ disabled });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.icon, disabled]);\n\n // Create icon element\n const iconElement = useMemo(\n () => <Icon disabled={disabled} className={iconClasses} aria-hidden />,\n [Icon, disabled, iconClasses],\n );\n\n // Merge button props\n const buttonProps = useMemo(\n () => ({\n ...customization?.buttonProps,\n ...props,\n ref,\n type: 'button' as const,\n onClick: handleClick,\n onKeyDown: handleKeyDown,\n disabled,\n className: buttonClasses,\n 'aria-label': ariaLabel || labels.scrollToTop,\n title: ariaLabel || labels.scrollToTop,\n }),\n [\n customization?.buttonProps,\n props,\n ref,\n handleClick,\n handleKeyDown,\n disabled,\n buttonClasses,\n ariaLabel,\n labels.scrollToTop,\n ],\n );\n\n return (\n <button {...buttonProps}>\n <Content icon={iconElement} disabled={disabled} ariaLabel={ariaLabel} />\n </button>\n );\n },\n);\n\nToTopButton.displayName = 'ToTopButton';\n","/**\n * @file Animated select content component with comprehensive customization capabilities.\n * @module SelectContentAnimated\n */\n\nimport * as Select from '@radix-ui/react-select';\nimport { cn } from '@tuwaio/nova-core';\nimport { AnimatePresence, type Easing, motion } from 'framer-motion';\nimport { type ComponentPropsWithoutRef, type ElementRef, forwardRef, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\nimport { ToBottomButton, type ToBottomButtonCustomization } from './ToBottomButton';\nimport { ToTopButton, type ToTopButtonCustomization } from './ToTopButton';\n\n/**\n * Props for the SelectContentAnimated component\n */\nexport interface SelectContentAnimatedProps extends ComponentPropsWithoutRef<typeof Select.Content> {\n /** Custom CSS classes to apply to the select content container (added to defaults) */\n className?: string;\n /** Custom CSS classes to apply to the animated inner content (added to defaults) */\n contentClassName?: string;\n /** Custom CSS classes to apply to the viewport (added to defaults) */\n viewportClassName?: string;\n /** ARIA label for the select content */\n 'aria-label'?: string;\n /** Whether the select content should have reduced motion for accessibility */\n reduceMotion?: boolean;\n /** Maximum height for the content in pixels */\n maxHeight?: number;\n /** Custom animation duration in seconds */\n animationDuration?: number;\n /** Whether to show scroll buttons */\n showScrollButtons?: boolean;\n /** Custom props for the ToTopButton */\n topButtonProps?: Omit<ComponentPropsWithoutRef<typeof ToTopButton>, 'ref'>;\n /** Custom props for the ToBottomButton */\n bottomButtonProps?: Omit<ComponentPropsWithoutRef<typeof ToBottomButton>, 'ref'>;\n /** Customization options for ToTopButton */\n topButtonCustomization?: ToTopButtonCustomization;\n /** Customization options for ToBottomButton */\n bottomButtonCustomization?: ToBottomButtonCustomization;\n}\n\n/**\n * Animated select content component with smooth enter/exit animations.\n *\n * This component provides animated dropdown content for select components\n * with accessibility support and extensive customization capabilities.\n *\n * Features:\n * - Smooth enter/exit animations with Framer Motion\n * - Accessibility-first design with ARIA support\n * - Fully customizable scroll buttons with ToTopButton/ToBottomButton\n * - Reduced motion support for accessibility\n * - Customizable max height and animation duration\n * - Full control over styling via className props (additive, not replacement)\n * - Separate styling for container, content, and viewport\n * - Custom button props and customization options\n *\n * @example Basic usage\n * ```tsx\n * <Select.Root>\n * <Select.Trigger>Select an option</Select.Trigger>\n * <SelectContentAnimated>\n * <Select.Item value=\"option1\">Option 1</Select.Item>\n * <Select.Item value=\"option2\">Option 2</Select.Item>\n * </SelectContentAnimated>\n * </Select.Root>\n * ```\n *\n * @example With full customization\n * ```tsx\n * <SelectContentAnimated\n * className=\"novacon:shadow-2xl novacon:border-2\"\n * contentClassName=\"novacon:p-4 novacon:bg-gradient-to-b\"\n * viewportClassName=\"novacon:scrollbar-thin\"\n * maxHeight={400}\n * animationDuration={0.3}\n * reduceMotion={false}\n * showScrollButtons={true}\n * topButtonProps={{\n * className: \"novacon:bg-blue-500\",\n * onClick: () => console.log(\"Top button clicked\"),\n * }}\n * topButtonCustomization={{\n * classNames: {\n * button: () => \"novacon:bg-red-500 novacon:hover:bg-red-600\",\n * },\n * }}\n * bottomButtonCustomization={{\n * components: {\n * Icon: ({ className }) => <div className={className}>⬇️</div>,\n * },\n * }}\n * >\n * <Select.Item value=\"item1\">Item 1</Select.Item>\n * </SelectContentAnimated>\n * ```\n */\nexport const SelectContentAnimated = forwardRef<\n Omit<ElementRef<typeof Select.Content>, 'style'>,\n SelectContentAnimatedProps\n>(\n (\n {\n className,\n contentClassName,\n viewportClassName,\n children,\n position = 'popper',\n 'aria-label': ariaLabel,\n reduceMotion = false,\n maxHeight = 300,\n animationDuration = 0.2,\n showScrollButtons = true,\n topButtonProps,\n bottomButtonProps,\n topButtonCustomization,\n bottomButtonCustomization,\n ...props\n },\n forwardedRef,\n ) => {\n const labels = useNovaConnectLabels();\n\n // Memoize animation configuration based on reduce motion preference\n const animationConfig = useMemo(() => {\n if (reduceMotion) {\n return {\n initial: { opacity: 0 },\n animate: { opacity: 1 },\n exit: { opacity: 0 },\n transition: { duration: 0.15, layout: { duration: 0 } },\n };\n }\n\n return {\n initial: { opacity: 0, scaleY: 0.8, y: -5 },\n animate: { opacity: 1, scaleY: 1, y: 0 },\n exit: { opacity: 0, scaleY: 0.8, y: -5 },\n transition: {\n duration: animationDuration,\n ease: 'easeOut' as Easing,\n layout: {\n duration: 0.15,\n ease: 'easeOut' as Easing,\n },\n },\n };\n }, [reduceMotion, animationDuration]);\n\n // Memoize content container classes (additive approach)\n const contentClasses = useMemo(\n () =>\n cn(\n // Default styles always applied\n 'novacon:p-1 novacon:bg-[var(--tuwa-bg-secondary)] novacon:rounded-lg novacon:shadow-xl',\n 'novacon:ring-1 novacon:ring-[var(--tuwa-border-primary)] novacon:overflow-hidden',\n // Custom classes added to defaults\n contentClassName,\n ),\n [contentClassName],\n );\n\n // Memoize select content classes (additive approach)\n const selectContentClasses = useMemo(\n () =>\n cn(\n // Default styles always applied\n 'novacon:overflow-hidden',\n 'novacon:w-[--radix-select-trigger-width]',\n 'novacon:data-[state=open]:animate-in novacon:data-[state=closed]:animate-out',\n 'novacon:data-[state=closed]:fade-out-0 novacon:data-[state=open]:fade-in-0',\n 'novacon:data-[state=closed]:zoom-out-95 novacon:data-[state=open]:zoom-in-95',\n 'novacon:data-[side=bottom]:slide-in-from-top-2 novacon:data-[side=left]:slide-in-from-right-2',\n 'novacon:data-[side=right]:slide-in-from-left-2 novacon:data-[side=top]:slide-in-from-bottom-2',\n // Custom classes added to defaults\n className,\n ),\n [className],\n );\n\n // Memoize viewport classes (additive approach)\n const viewportClasses = useMemo(\n () =>\n cn(\n // Default viewport styles (minimal by default)\n '',\n // Custom classes added\n viewportClassName,\n ),\n [viewportClassName],\n );\n\n // Memoize inline styles for containers\n const selectContentStyles = useMemo(\n () => ({\n // Apply maxHeight as inline style (can be overridden by style prop)\n maxHeight: `${maxHeight}px`,\n }),\n [maxHeight],\n );\n\n // Generate ARIA label\n const finalAriaLabel = ariaLabel || labels.chainListContainer;\n\n return (\n <Select.Portal>\n <Select.Content\n className={selectContentClasses}\n style={selectContentStyles}\n // @ts-expect-error - type changed for better using\n ref={forwardedRef}\n position={position}\n role=\"listbox\"\n aria-label={finalAriaLabel}\n {...props}\n >\n {/* Scroll to top button - only render if showScrollButtons is true */}\n {showScrollButtons && (\n <Select.ScrollUpButton asChild>\n <ToTopButton customization={topButtonCustomization} {...topButtonProps} />\n </Select.ScrollUpButton>\n )}\n\n {/* Main content viewport */}\n <Select.Viewport role=\"presentation\" className={viewportClasses}>\n <AnimatePresence mode=\"wait\" initial={false}>\n <motion.div\n initial={animationConfig.initial}\n animate={animationConfig.animate}\n exit={animationConfig.exit}\n transition={animationConfig.transition}\n className={contentClasses}\n layout={!reduceMotion}\n role=\"group\"\n aria-live=\"polite\"\n >\n {children}\n </motion.div>\n </AnimatePresence>\n </Select.Viewport>\n\n {/* Scroll to bottom button - only render if showScrollButtons is true */}\n {showScrollButtons && (\n <Select.ScrollDownButton asChild>\n <ToBottomButton customization={bottomButtonCustomization} {...bottomButtonProps} />\n </Select.ScrollDownButton>\n )}\n </Select.Content>\n </Select.Portal>\n );\n },\n);\n\nSelectContentAnimated.displayName = 'SelectContentAnimated';\n","/**\n * @file Highly customizable scrollable chain list with comprehensive styling and behavior control.\n * @module ScrollableChainList\n */\n\nimport {\n AnimatePresence,\n type AnyResolvedKeyframe,\n type LegacyAnimationControls,\n motion,\n type TargetAndTransition,\n type Transition,\n type VariantLabels,\n} from 'framer-motion';\nimport React, { type ComponentType, ReactNode, useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { ToBottomButton, type ToBottomButtonCustomization } from '../ToBottomButton';\nimport { ToTopButton, type ToTopButtonCustomization } from '../ToTopButton';\nimport { ChainListRenderer, type ChainListRendererCustomization } from './ChainListRenderer';\n\n// === TYPES AND INTERFACES ===\n\n/**\n * Chain data structure returned by getChainData function\n */\ninterface ChainData {\n formattedChainId: string | number;\n chain: string | number;\n}\n\n/**\n * Scroll button state context\n */\ninterface ScrollButtonContext {\n showTopButton: boolean;\n showBottomButton: boolean;\n isScrolling: boolean;\n scrollTop: number;\n scrollHeight: number;\n clientHeight: number;\n}\n\n/**\n * Props for custom scroll container component\n */\ninterface CustomScrollContainerProps {\n children: ReactNode;\n ref: React.RefObject<HTMLDivElement | null>;\n onKeyDown: (event: React.KeyboardEvent<HTMLDivElement>) => void;\n className?: string;\n role: string;\n 'aria-label': string;\n tabIndex: number;\n}\n\n/**\n * Props for custom wrapper component\n */\ninterface CustomWrapperProps {\n children: ReactNode;\n className?: string;\n role: string;\n 'aria-label': string;\n}\n\n/**\n * Props for custom button animations wrapper\n */\ninterface CustomButtonAnimationWrapperProps {\n children: ReactNode;\n isVisible: boolean;\n position: 'top' | 'bottom';\n animationKey: string;\n}\n\n/**\n * Animation configuration for scroll buttons\n */\ninterface ScrollButtonAnimationConfig {\n initial?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n animate?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n exit?: TargetAndTransition | VariantLabels | LegacyAnimationControls | undefined;\n transition?: Transition<AnyResolvedKeyframe>;\n}\n\n/**\n * Comprehensive customization options for ScrollableChainList\n */\nexport interface ScrollableChainListCustomization {\n /** Custom components */\n components?: {\n /** Custom scroll container component */\n ScrollContainer?: ComponentType<CustomScrollContainerProps>;\n /** Custom wrapper component */\n Wrapper?: ComponentType<CustomWrapperProps>;\n /** Custom button animation wrapper */\n ButtonAnimationWrapper?: ComponentType<CustomButtonAnimationWrapperProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Wrapper classes */\n wrapper?: (params: { itemCount: number; hasScrollableContent: boolean }) => string;\n /** Scroll container classes */\n container?: (params: {\n itemCount: number;\n hasScrollableContent: boolean;\n showTopButton: boolean;\n showBottomButton: boolean;\n }) => string;\n /** Button animation wrapper classes */\n buttonWrapper?: (params: { position: 'top' | 'bottom'; isVisible: boolean }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom scroll handler wrapper */\n onScroll?: (originalHandler: () => void, event: Event, context: ScrollButtonContext) => void;\n /** Custom key handler wrapper for container */\n onKeyDown?: (\n originalHandler: (event: React.KeyboardEvent<HTMLDivElement>) => void,\n event: React.KeyboardEvent<HTMLDivElement>,\n context: { scrollContainer: HTMLDivElement | null },\n ) => void;\n /** Custom top button click handler wrapper */\n onTopButtonClick?: (originalHandler: () => void, context: ScrollButtonContext) => void;\n /** Custom bottom button click handler wrapper */\n onBottomButtonClick?: (originalHandler: () => void, context: ScrollButtonContext) => void;\n };\n /** Animation configuration */\n animations?: {\n /** Button animation */\n scrollButtons?: ScrollButtonAnimationConfig;\n };\n /** Scroll behavior configuration */\n scrollBehavior?: {\n /** Scroll behavior type */\n behavior?: ScrollBehavior;\n /** Page scroll percentage (0-1) */\n pageScrollPercentage?: number;\n /** Scroll update throttle in ms */\n updateThrottle?: number;\n /** Enable auto-scroll to active item */\n autoScrollToActive?: boolean;\n };\n /** Button customization */\n buttons?: {\n /** Top button customization */\n topButton?: ToTopButtonCustomization;\n /** Bottom button customization */\n bottomButton?: ToBottomButtonCustomization;\n /** Hide buttons when content fits */\n hideWhenContentFits?: boolean;\n };\n /** Chain list renderer customization */\n chainListRenderer?: ChainListRendererCustomization;\n}\n\n/**\n * Props for the ScrollableChainList component\n */\nexport interface ScrollableChainListProps {\n /** List of chain identifiers to render */\n chainsList: (string | number)[];\n /** Currently selected chain value */\n selectValue: string;\n /** Handler for chain selection changes */\n handleValueChange: (newChainId: string) => void;\n /** Function to get formatted chain data */\n getChainData: (chain: string | number) => ChainData;\n /** Handler called when list should close */\n onClose: () => void;\n /** Comprehensive customization options */\n customization?: ScrollableChainListCustomization;\n /** ARIA label for the wrapper */\n 'aria-label'?: string;\n /** Loading state */\n isLoading?: boolean;\n /** Error state */\n error?: string | null;\n}\n\n// === DEFAULT COMPONENTS ===\n\n/**\n * Default scroll container component\n */\nconst DefaultScrollContainer: React.FC<CustomScrollContainerProps> = React.forwardRef<\n HTMLDivElement,\n CustomScrollContainerProps\n>(({ children, className, onKeyDown, ...props }, ref) => (\n <div ref={ref} className={className} onKeyDown={onKeyDown} {...props}>\n {children}\n </div>\n));\n\nDefaultScrollContainer.displayName = 'DefaultScrollContainer';\n\n/**\n * Default wrapper component\n */\nconst DefaultWrapper: React.FC<CustomWrapperProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\n/**\n * Default button animation wrapper\n */\nconst DefaultButtonAnimationWrapper: React.FC<CustomButtonAnimationWrapperProps> = ({\n children,\n isVisible,\n animationKey,\n}) => {\n if (!isVisible) return null;\n\n return (\n <motion.div\n key={animationKey}\n initial={{ opacity: 0 }}\n animate={{ opacity: 1 }}\n exit={{ opacity: 0 }}\n transition={{ duration: 0.2 }}\n >\n {children}\n </motion.div>\n );\n};\n\n// === MAIN COMPONENT ===\n\n/**\n * Highly customizable scrollable chain list with comprehensive styling and behavior control.\n */\nexport const ScrollableChainList: React.FC<ScrollableChainListProps> = ({\n chainsList,\n selectValue,\n handleValueChange,\n getChainData,\n onClose,\n customization,\n 'aria-label': ariaLabel,\n isLoading = false,\n error = null,\n}) => {\n const labels = useNovaConnectLabels();\n const containerRef = useRef<HTMLDivElement>(null);\n const [showTopButton, setShowTopButton] = useState(false);\n const [showBottomButton, setShowBottomButton] = useState(false);\n const [isScrolling, setIsScrolling] = useState(false);\n const [hasScrollableContent, setHasScrollableContent] = useState(false);\n const [scrollContext, setScrollContext] = useState<ScrollButtonContext>({\n showTopButton: false,\n showBottomButton: false,\n isScrolling: false,\n scrollTop: 0,\n scrollHeight: 0,\n clientHeight: 0,\n });\n\n // Extract customization options with defaults\n const {\n ScrollContainer = DefaultScrollContainer,\n Wrapper = DefaultWrapper,\n ButtonAnimationWrapper = DefaultButtonAnimationWrapper,\n } = customization?.components ?? {};\n\n const scrollBehavior = customization?.scrollBehavior ?? {};\n const buttonConfig = customization?.buttons ?? {};\n const animations = customization?.animations;\n\n // Scroll behavior settings\n const scrollBehaviorType = scrollBehavior.behavior ?? 'smooth';\n const pageScrollPercentage = scrollBehavior.pageScrollPercentage ?? 0.8;\n\n // Update scroll context\n const updateScrollContext = useCallback(() => {\n const container = containerRef.current;\n if (!container) return;\n\n const { scrollTop, scrollHeight, clientHeight } = container;\n setScrollContext({\n showTopButton,\n showBottomButton,\n isScrolling,\n scrollTop,\n scrollHeight,\n clientHeight,\n });\n }, [showTopButton, showBottomButton, isScrolling]);\n\n // Update scroll buttons visibility\n const updateScrollButtons = useCallback(() => {\n const container = containerRef.current;\n if (!container) return;\n\n const { scrollTop, scrollHeight, clientHeight } = container;\n const hasContent = scrollHeight > clientHeight;\n\n setHasScrollableContent(hasContent);\n\n if (buttonConfig.hideWhenContentFits && !hasContent) {\n setShowTopButton(false);\n setShowBottomButton(false);\n return;\n }\n\n setShowTopButton(scrollTop > 0);\n setShowBottomButton(scrollTop + clientHeight < scrollHeight - 1);\n\n // Call custom scroll handler if provided\n if (customization?.handlers?.onScroll) {\n customization.handlers.onScroll(() => {}, new Event('scroll'), {\n showTopButton: scrollTop > 0,\n showBottomButton: scrollTop + clientHeight < scrollHeight - 1,\n isScrolling,\n scrollTop,\n scrollHeight,\n clientHeight,\n });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [buttonConfig.hideWhenContentFits, customization?.handlers?.onScroll, isScrolling]);\n\n // Update context after button states change\n useEffect(() => {\n updateScrollContext();\n }, [updateScrollContext]);\n\n // Setup scroll listeners and observers\n useEffect(() => {\n const container = containerRef.current;\n if (!container) return;\n\n let scrollTimeout: NodeJS.Timeout;\n\n const handleScroll = () => {\n setIsScrolling(true);\n updateScrollButtons();\n\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n setIsScrolling(false);\n }, 150);\n };\n\n updateScrollButtons();\n container.addEventListener('scroll', handleScroll);\n\n const resizeObserver = new ResizeObserver(updateScrollButtons);\n resizeObserver.observe(container);\n\n return () => {\n container.removeEventListener('scroll', handleScroll);\n resizeObserver.disconnect();\n clearTimeout(scrollTimeout);\n };\n }, [chainsList, updateScrollButtons]);\n\n // Scroll to extreme positions\n const scrollToExtreme = useCallback(\n (isTop: boolean) => {\n const container = containerRef.current;\n if (container) {\n container.scrollTo({\n top: isTop ? 0 : container.scrollHeight,\n behavior: scrollBehaviorType,\n });\n }\n },\n [scrollBehaviorType],\n );\n\n // Handle scroll button clicks\n const handleTopButtonClick = useCallback(() => {\n const originalHandler = () => scrollToExtreme(true);\n\n if (customization?.handlers?.onTopButtonClick) {\n customization.handlers.onTopButtonClick(originalHandler, scrollContext);\n } else {\n originalHandler();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.handlers?.onTopButtonClick, scrollToExtreme, scrollContext]);\n\n const handleBottomButtonClick = useCallback(() => {\n const originalHandler = () => scrollToExtreme(false);\n\n if (customization?.handlers?.onBottomButtonClick) {\n customization.handlers.onBottomButtonClick(originalHandler, scrollContext);\n } else {\n originalHandler();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.handlers?.onBottomButtonClick, scrollToExtreme, scrollContext]);\n\n // Handle keyboard navigation\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n const originalHandler = (e: React.KeyboardEvent<HTMLDivElement>) => {\n // Handle arrow key navigation within the scrollable area\n if (e.key === 'ArrowUp' || e.key === 'ArrowDown') {\n // Let the ChainListRenderer handle the focus management\n return;\n }\n\n // Handle Page Up/Page Down for large scrolls\n if (e.key === 'PageUp') {\n e.preventDefault();\n const container = containerRef.current;\n if (container) {\n container.scrollBy({\n top: -container.clientHeight * pageScrollPercentage,\n behavior: scrollBehaviorType,\n });\n }\n }\n\n if (e.key === 'PageDown') {\n e.preventDefault();\n const container = containerRef.current;\n if (container) {\n container.scrollBy({\n top: container.clientHeight * pageScrollPercentage,\n behavior: scrollBehaviorType,\n });\n }\n }\n };\n\n if (customization?.handlers?.onKeyDown) {\n customization.handlers.onKeyDown(originalHandler, event, {\n scrollContainer: containerRef.current,\n });\n } else {\n originalHandler(event);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.handlers?.onKeyDown, pageScrollPercentage, scrollBehaviorType],\n );\n\n // Generate wrapper classes and styles\n const wrapperClasses = useMemo(() => {\n const customClasses = customization?.classNames?.wrapper?.({\n itemCount: chainsList.length,\n hasScrollableContent,\n });\n return customClasses || 'novacon:relative novacon:py-[24px]';\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.wrapper, chainsList.length, hasScrollableContent]);\n\n // Generate container classes and styles\n const containerClasses = useMemo(() => {\n const customClasses = customization?.classNames?.container?.({\n itemCount: chainsList.length,\n hasScrollableContent,\n showTopButton,\n showBottomButton,\n });\n return (\n customClasses ||\n 'NovaCustomScroll novacon:relative novacon:flex novacon:w-full novacon:flex-col novacon:p-2 novacon:gap-1 novacon:max-h-[312px] novacon:overflow-x-hidden novacon:overflow-y-auto'\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, chainsList.length, hasScrollableContent, showTopButton, showBottomButton]);\n\n // Button animation wrapper classes and styles\n const topButtonWrapperClasses = useMemo(() => {\n return (\n customization?.classNames?.buttonWrapper?.({ position: 'top', isVisible: showTopButton }) ||\n 'novacon:absolute novacon:top-0 novacon:z-10 novacon:w-full'\n );\n }, [customization, showTopButton]);\n\n const bottomButtonWrapperClasses = useMemo(() => {\n return (\n customization?.classNames?.buttonWrapper?.({ position: 'bottom', isVisible: showBottomButton }) ||\n 'novacon:absolute novacon:bottom-0 novacon:z-10 novacon:w-full'\n );\n }, [customization, showBottomButton]);\n\n // Create button animation wrapper with custom animations\n const createButtonWrapper = useCallback(\n (\n children: ReactNode,\n isVisible: boolean,\n position: 'top' | 'bottom',\n wrapperClasses: string,\n wrapperStyles?: React.CSSProperties,\n ) => {\n const animationConfig = animations?.scrollButtons;\n const animationKey = `${position}-button`;\n\n const wrapperElement = (\n <div className={wrapperClasses} style={wrapperStyles}>\n {children}\n </div>\n );\n\n return (\n <ButtonAnimationWrapper isVisible={isVisible} position={position} animationKey={animationKey}>\n {animationConfig ? <motion.div {...animationConfig}>{wrapperElement}</motion.div> : wrapperElement}\n </ButtonAnimationWrapper>\n );\n },\n [animations, ButtonAnimationWrapper],\n );\n\n return (\n <Wrapper className={wrapperClasses} role=\"region\" aria-label={ariaLabel || labels.chainListContainer}>\n <AnimatePresence>\n {createButtonWrapper(\n <ToTopButton\n onClick={handleTopButtonClick}\n aria-label={labels.scrollToTop}\n className=\"novacon:w-full\"\n customization={buttonConfig.topButton}\n />,\n showTopButton,\n 'top',\n topButtonWrapperClasses,\n )}\n </AnimatePresence>\n\n <ScrollContainer\n ref={containerRef}\n className={containerClasses}\n role=\"listbox\"\n aria-label={labels.selectChain}\n tabIndex={0}\n onKeyDown={handleKeyDown}\n >\n <ChainListRenderer\n chainsList={chainsList}\n selectValue={selectValue}\n handleValueChange={handleValueChange}\n getChainData={getChainData}\n onClose={onClose}\n isMobile={true}\n isLoading={isLoading}\n error={error}\n customization={customization?.chainListRenderer}\n />\n </ScrollContainer>\n\n <AnimatePresence>\n {createButtonWrapper(\n <ToBottomButton\n onClick={handleBottomButtonClick}\n aria-label={labels.scrollToBottom}\n className=\"novacon:w-full\"\n customization={buttonConfig.bottomButton}\n />,\n showBottomButton,\n 'bottom',\n bottomButtonWrapperClasses,\n )}\n </AnimatePresence>\n </Wrapper>\n );\n};\n","/**\n * @file ChainSelector component - A highly customizable chain selector with support for desktop and mobile devices.\n * @module ChainSelector\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { getChainName } from '@bgd-labs/react-web3-icons/dist/utils';\nimport * as Select from '@radix-ui/react-select';\nimport {\n ChevronArrowWithAnim,\n CloseIcon,\n cn,\n Dialog,\n DialogClose,\n DialogContent,\n DialogHeader,\n DialogTitle,\n} from '@tuwaio/nova-core';\nimport { formatWalletChainId } from '@tuwaio/orbit-core';\nimport { getAdapterFromWalletType } from '@tuwaio/orbit-core';\nimport { motion, type Transition } from 'framer-motion';\nimport React, {\n ComponentPropsWithoutRef,\n ComponentType,\n ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { InitialChains } from '../../types';\nimport { getChainsListByWalletType, getChainsListByWalletTypeAsync, getWalletChains } from '../../utils';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\nimport { SelectContentAnimated, SelectContentAnimatedProps } from '../SelectContentAnimated';\nimport { ChainListRenderer, ChainListRendererCustomization } from './ChainListRenderer';\nimport { ScrollableChainList, ScrollableChainListCustomization } from './ScrollableChainList';\n\n/**\n * Context for the chain selection trigger button.\n */\ntype ChainTriggerButtonContext = {\n /** The currently formatted chain ID */\n currentFormattedChainId: string | number;\n /** Value for the Select component */\n selectValue: string;\n /** Whether the chain list is open */\n isChainsListOpen: boolean;\n /** Whether the device is mobile */\n isMobile: boolean;\n /** The name of the chain */\n chainName: string;\n};\n\n/**\n * Props for a custom trigger icon component.\n */\ntype CustomTriggerIconProps = {\n /** Chain ID */\n chainId: string | number;\n /** CSS class */\n className?: string;\n /** Whether hidden from screen readers */\n 'aria-hidden'?: boolean;\n};\n\n/**\n * Props for a custom trigger content component.\n */\ntype CustomTriggerContentProps = {\n /** Chain icon */\n icon: ReactNode;\n /** Chain name */\n chainName: string;\n /** Whether the device is mobile */\n isMobile: boolean;\n /** Whether the list is open */\n isOpen: boolean;\n /** The currently formatted chain ID */\n currentFormattedChainId: string | number;\n};\n\n/**\n * Props for a custom trigger arrow component.\n */\ntype CustomTriggerArrowProps = {\n /** Whether the list is open */\n isOpen: boolean;\n /** CSS class */\n className?: string;\n /** Whether hidden from screen readers */\n 'aria-hidden'?: boolean;\n};\n\n/**\n * Props for a custom loading state display.\n */\ntype CustomLoadingStateProps = {\n /** CSS class */\n className?: string;\n /** ARIA label */\n 'aria-label': string;\n};\n\n/**\n * Props for a custom display for a single chain (when no selector is needed).\n */\ntype CustomSingleChainDisplayProps = {\n /** Chain ID */\n chainId: string | number;\n /** Chain name */\n chainName: string;\n /** CSS class */\n className?: string;\n /** ARIA label */\n 'aria-label': string;\n};\n\n/**\n * Props for a custom desktop selector wrapper.\n */\ntype CustomDesktopSelectorProps = {\n /** Child elements */\n children: ReactNode;\n /** CSS class */\n className?: string;\n /** ARIA label */\n 'aria-label': string;\n};\n\n/**\n * Props for a custom mobile selector wrapper.\n */\ntype CustomMobileSelectorProps = {\n /** Child elements */\n children: ReactNode;\n /** CSS class */\n className?: string;\n /** ARIA label */\n 'aria-label': string;\n};\n\n/**\n * Props for a custom dialog header component.\n */\ntype CustomDialogHeaderProps = {\n /** Title text */\n title: string;\n /** Close handler */\n onClose: () => void;\n /** CSS class */\n className?: string;\n};\n\n/**\n * Animation easing parameters for framer-motion.\n */\ntype AnimationEasing = [number, number, number, number] | string;\n\n/**\n * Customization options for the ChainTriggerButton.\n */\nexport type ChainTriggerButtonCustomization = {\n /** Overrides for the button/trigger props */\n buttonProps?: Partial<ComponentPropsWithoutRef<'button'>>;\n /** Overrides for the Select.Trigger props (desktop only) */\n selectTriggerProps?: Partial<ComponentPropsWithoutRef<typeof Select.Trigger>>;\n /** Custom component overrides */\n components?: {\n /** Custom chain icon component */\n Icon?: ComponentType<CustomTriggerIconProps>;\n /** Custom trigger content wrapper */\n Content?: ComponentType<CustomTriggerContentProps>;\n /** Custom arrow/chevron component */\n Arrow?: ComponentType<CustomTriggerArrowProps>;\n };\n /** Custom CSS class generators */\n classNames?: {\n /** Function to generate wrapper classes */\n wrapper?: (params: { isMobile: boolean; isOpen: boolean }) => string;\n /** Function to generate button/trigger classes */\n button?: (params: { isMobile: boolean; isOpen: boolean; hasMultipleChains: boolean }) => string;\n /** Function to generate inner content classes */\n innerContent?: (params: { isMobile: boolean; isOpen: boolean }) => string;\n /** Function to generate icon wrapper classes */\n iconWrapper?: (params: { isMobile: boolean }) => string;\n /** Function to generate chain name classes */\n chainName?: (params: { isMobile: boolean; isVisible: boolean }) => string;\n /** Function to generate arrow wrapper classes */\n arrowWrapper?: (params: { isMobile: boolean }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Wrapper for the click handler */\n onClick?: (\n originalHandler: () => void,\n event: React.MouseEvent<HTMLButtonElement>,\n context: ChainTriggerButtonContext,\n ) => void;\n /** Wrapper for the key down handler */\n onKeyDown?: (\n originalHandler: (event: React.KeyboardEvent) => void,\n event: React.KeyboardEvent,\n context: ChainTriggerButtonContext,\n ) => void;\n };\n /** Animation settings */\n animations?: {\n /** Layout animation settings */\n layout?: {\n duration?: number;\n ease?: AnimationEasing;\n };\n /** Inner content animation settings */\n innerContent?: {\n duration?: number;\n };\n };\n};\n\n/**\n * Comprehensive customization options for the ChainSelector.\n */\nexport type ChainSelectorCustomization = {\n /** Custom component overrides */\n components?: {\n /** Custom loading state component */\n LoadingState?: ComponentType<CustomLoadingStateProps>;\n /** Custom component for displaying a single chain */\n SingleChainDisplay?: ComponentType<CustomSingleChainDisplayProps>;\n /** Custom wrapper for the desktop selector */\n DesktopSelector?: ComponentType<CustomDesktopSelectorProps>;\n /** Custom wrapper for the mobile selector */\n MobileSelector?: ComponentType<CustomMobileSelectorProps>;\n /** Custom dialog header component */\n DialogHeader?: ComponentType<CustomDialogHeaderProps>;\n };\n /** Custom CSS class generators */\n classNames?: {\n /** Classes for the main container */\n container?: (params: { hasMultipleChains: boolean; isLoading: boolean }) => string;\n /** Classes for the desktop wrapper */\n desktopWrapper?: (params: { chainCount: number }) => string;\n /** Classes for the mobile wrapper */\n mobileWrapper?: (params: { chainCount: number }) => string;\n /** Classes for the loading state */\n loadingState?: () => string;\n /** Classes for the single chain display */\n singleChainDisplay?: () => string;\n /** Classes for the dialog content */\n dialogContent?: (params: { chainCount: number }) => string;\n /** Classes for the dialog inner container */\n dialogInnerContainer?: () => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Wrapper for the chain change handler */\n onChainChange?: (originalHandler: (newChainId: string) => void, newChainId: string) => void;\n /** Wrapper for the dialog close handler */\n onDialogClose?: (originalHandler: () => void) => void;\n };\n /** Customization for sub-components */\n triggerButton?: ChainTriggerButtonCustomization;\n /** Customization for the Select content */\n selectContent?: Partial<SelectContentAnimatedProps>;\n /** Customization for the chain list renderer (desktop) */\n chainListRenderer?: ChainListRendererCustomization;\n /** Customization for the scrollable chain list (mobile) */\n scrollableChainList?: ScrollableChainListCustomization;\n};\n\n/**\n * Props for the ChainTriggerButton component.\n */\ninterface ChainTriggerButtonProps {\n /** The currently formatted chain ID */\n currentFormattedChainId: string | number;\n /** The value of the select component */\n selectValue: string;\n /** Whether the chain list is currently open */\n isChainsListOpen: boolean;\n /** Function to toggle the visibility of the chain list */\n onToggle: () => void;\n /** Whether it's displayed on a mobile device */\n isMobile: boolean;\n /** Whether multiple chains are available */\n hasMultipleChains?: boolean;\n /** Customization options */\n customization?: ChainTriggerButtonCustomization;\n}\n\n// --- Default Components ---\n\n/**\n * Default trigger icon.\n */\nconst DefaultTriggerIcon = ({ chainId, className, ...props }: CustomTriggerIconProps) => {\n return <Web3Icon chainId={chainId} className={className} {...props} />;\n};\n\n/**\n * Default trigger content.\n */\nconst DefaultTriggerContent = ({ icon, chainName, isMobile }: CustomTriggerContentProps) => {\n return (\n <>\n <div className=\"novacon:flex novacon:items-center novacon:sm:space-x-2 novacon:[&_img]:w-6 novacon:[&_img]:h-6\">\n <div aria-hidden=\"true\">{icon}</div>\n {isMobile ? (\n <span className=\"novacon:hidden novacon:sm:inline-block novacon:sr-only novacon:sm:not-sr-only\">\n {chainName}\n </span>\n ) : (\n <Select.Value asChild>\n <span className=\"novacon:hidden novacon:sm:inline-block novacon:sr-only novacon:sm:not-sr-only\">\n {chainName}\n </span>\n </Select.Value>\n )}\n </div>\n </>\n );\n};\n\n/**\n * Default trigger arrow.\n */\nconst DefaultTriggerArrow = ({ isOpen, className, ...props }: CustomTriggerArrowProps) => {\n return <ChevronArrowWithAnim isOpen={isOpen} className={className} {...props} />;\n};\n\n/**\n * Default loading state component.\n */\nconst DefaultLoadingState = ({ className, 'aria-label': ariaLabel }: CustomLoadingStateProps) => {\n return (\n <div className={className} role=\"status\" aria-label={ariaLabel}>\n <div className=\"novacon:w-6 novacon:h-6 novacon:bg-gray-300 novacon:rounded-full\" aria-hidden=\"true\" />\n <div className=\"novacon:w-20 novacon:h-4 novacon:bg-gray-300 novacon:rounded\" aria-hidden=\"true\" />\n </div>\n );\n};\n\n/**\n * Default display for a single chain.\n */\nconst DefaultSingleChainDisplay = ({\n chainId,\n chainName,\n className,\n 'aria-label': ariaLabel,\n}: CustomSingleChainDisplayProps) => {\n return (\n <div className={className} role=\"img\" aria-label={ariaLabel}>\n <Web3Icon chainId={chainId} />\n <span className=\"novacon:sr-only\">{chainName}</span>\n </div>\n );\n};\n\n/**\n * Default desktop selector wrapper.\n */\nconst DefaultDesktopSelector = ({ children, className, 'aria-label': ariaLabel }: CustomDesktopSelectorProps) => {\n return (\n <div className={className} role=\"region\" aria-label={ariaLabel}>\n {children}\n </div>\n );\n};\n\n/**\n * Default mobile selector wrapper.\n */\nconst DefaultMobileSelector = ({ children, className, 'aria-label': ariaLabel }: CustomMobileSelectorProps) => {\n return (\n <div className={className} role=\"region\" aria-label={ariaLabel}>\n {children}\n </div>\n );\n};\n\n/**\n * Default dialog header component.\n */\nconst DefaultDialogHeader = ({ title, onClose, className }: CustomDialogHeaderProps) => {\n const labels = useNovaConnectLabels();\n\n return (\n <DialogHeader className={className}>\n <DialogTitle>{title}</DialogTitle>\n <DialogClose asChild>\n <button\n type=\"button\"\n aria-label={labels.closeModal}\n className=\"novacon:cursor-pointer novacon:rounded-full novacon:p-1\n novacon:text-[var(--tuwa-text-tertiary)] novacon:transition-colors\n novacon:hover:bg-[var(--tuwa-bg-muted)] novacon:hover:text-[var(--tuwa-text-primary)]\n novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)] novacon:focus:ring-offset-2\"\n onClick={onClose}\n >\n <CloseIcon />\n </button>\n </DialogClose>\n </DialogHeader>\n );\n};\n\n// --- Default Event Handlers ---\n\n/**\n * Default click handler.\n */\nconst defaultClickHandler = (\n originalHandler: () => void,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n _event: React.MouseEvent<HTMLButtonElement>,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n _context: ChainTriggerButtonContext,\n) => {\n originalHandler();\n};\n\n/**\n * Default key down handler.\n */\nconst defaultKeyDownHandler = (\n originalHandler: (event: React.KeyboardEvent) => void,\n event: React.KeyboardEvent,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n _context: ChainTriggerButtonContext,\n) => {\n originalHandler(event);\n};\n\n/**\n * Default chain change handler.\n */\nconst defaultChainChangeHandler = (originalHandler: (newChainId: string) => void, newChainId: string) => {\n originalHandler(newChainId);\n};\n\n/**\n * Default dialog close handler.\n */\nconst defaultDialogCloseHandler = (originalHandler: () => void) => {\n originalHandler();\n};\n\n/**\n * Trigger button component for chain selection.\n */\nconst ChainTriggerButton: React.FC<ChainTriggerButtonProps> = ({\n currentFormattedChainId,\n isChainsListOpen,\n onToggle,\n isMobile,\n hasMultipleChains = true,\n customization,\n}) => {\n const labels = useNovaConnectLabels();\n const chainName = getChainName(currentFormattedChainId);\n\n // Extract custom components\n const {\n Icon = DefaultTriggerIcon,\n Content = DefaultTriggerContent,\n Arrow = DefaultTriggerArrow,\n } = customization?.components ?? {};\n\n const { onClick: customClickHandler = defaultClickHandler, onKeyDown: customKeyDownHandler = defaultKeyDownHandler } =\n customization?.handlers ?? {};\n\n // Animation configuration\n const layoutAnimation = customization?.animations?.layout ?? {\n duration: 0.2,\n ease: [0.4, 1, 0.4, 1] as AnimationEasing,\n };\n const innerContentAnimation = useMemo(\n () => customization?.animations?.innerContent ?? { duration: 0.0001 },\n [customization?.animations?.innerContent],\n );\n\n /**\n * Handles keyboard navigation for the trigger button.\n */\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent) => {\n const context: ChainTriggerButtonContext = {\n currentFormattedChainId,\n selectValue: String(currentFormattedChainId),\n isChainsListOpen,\n isMobile,\n chainName,\n };\n\n const originalHandler = (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n onToggle();\n }\n if (e.key === 'Escape' && isChainsListOpen) {\n e.preventDefault();\n onToggle();\n }\n };\n\n customKeyDownHandler(originalHandler, event, context);\n },\n [customKeyDownHandler, currentFormattedChainId, isChainsListOpen, isMobile, chainName, onToggle],\n );\n\n /**\n * Handles click events for the mobile button.\n */\n const handleClick = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n const context: ChainTriggerButtonContext = {\n currentFormattedChainId,\n selectValue: String(currentFormattedChainId),\n isChainsListOpen,\n isMobile,\n chainName,\n };\n\n customClickHandler(onToggle, event, context);\n },\n [customClickHandler, currentFormattedChainId, isChainsListOpen, isMobile, chainName, onToggle],\n );\n\n // Generate classes and styles\n const wrapperClasses = useMemo(() => {\n if (customization?.classNames?.wrapper) {\n return customization.classNames.wrapper({ isMobile, isOpen: isChainsListOpen });\n }\n return 'novacon:relative';\n }, [customization, isMobile, isChainsListOpen]);\n\n const buttonClasses = useMemo(() => {\n if (customization?.classNames?.button) {\n return customization.classNames.button({ isMobile, isOpen: isChainsListOpen, hasMultipleChains });\n }\n\n return cn(\n 'novacon:cursor-pointer novacon:inline-flex novacon:items-center novacon:justify-center',\n 'novacon:rounded-xl novacon:font-medium novacon:text-sm novacon:transition-all novacon:duration-200',\n 'novacon:hover:scale-[1.02] novacon:active:scale-[0.98]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-offset-2 novacon:focus:ring-offset-[var(--tuwa-bg-primary)] novacon:focus:ring-[var(--tuwa-border-primary)]',\n 'novacon:bg-[var(--tuwa-bg-secondary)] novacon:text-[var(--tuwa-text-primary)] novacon:hover:bg-[var(--tuwa-bg-muted)]',\n {\n 'novacon:ring-2 novacon:ring-[var(--tuwa-text-accent)] novacon:border novacon:border-transparent':\n isChainsListOpen,\n 'novacon:border novacon:border-[var(--tuwa-border-primary)]': !isChainsListOpen,\n },\n 'novacon:[&_img]:w-4 novacon:[&_img]:h-4',\n );\n }, [customization, isMobile, isChainsListOpen, hasMultipleChains]);\n\n const innerContentClasses = useMemo(() => {\n if (customization?.classNames?.innerContent) {\n return customization.classNames.innerContent({ isMobile, isOpen: isChainsListOpen });\n }\n return 'novacon:inline-flex novacon:items-center novacon:justify-center novacon:gap-2 novacon:px-2 sm:novacon:px-4 novacon:min-w-[60px] novacon:min-h-[42px] novacon:py-1';\n }, [customization, isMobile, isChainsListOpen]);\n\n /**\n * Creates the inner content with the correct motion wrapper.\n */\n const innerContent = useMemo(() => {\n const iconElement = <Icon chainId={currentFormattedChainId} aria-hidden={true} />;\n const arrowElement = <Arrow isOpen={isChainsListOpen} aria-hidden={true} />;\n\n return (\n <motion.div\n layout\n className={innerContentClasses}\n transition={{ layout: { duration: innerContentAnimation.duration } }}\n >\n <Content\n icon={iconElement}\n chainName={chainName}\n isMobile={isMobile}\n isOpen={isChainsListOpen}\n currentFormattedChainId={currentFormattedChainId}\n />\n\n {isMobile ? (\n <div aria-hidden=\"true\">{arrowElement}</div>\n ) : (\n <Select.Icon asChild>\n <div aria-hidden=\"true\">{arrowElement}</div>\n </Select.Icon>\n )}\n </motion.div>\n );\n }, [\n Icon,\n Arrow,\n Content,\n currentFormattedChainId,\n isChainsListOpen,\n chainName,\n isMobile,\n innerContentClasses,\n innerContentAnimation,\n ]);\n\n /**\n * Accessibility attributes for screen readers.\n */\n const ariaLabel = `${labels.chainSelector}: ${labels.currentChain} ${chainName}. ${labels.openChainSelector}`;\n const ariaExpanded = isChainsListOpen;\n const ariaHaspopup = 'listbox' as const;\n\n // Merge button props\n const mobileButtonProps = useMemo(\n () => ({\n ...customization?.buttonProps,\n type: 'button' as const,\n 'aria-label': ariaLabel,\n 'aria-expanded': ariaExpanded,\n 'aria-haspopup': ariaHaspopup,\n className: buttonClasses,\n onClick: handleClick,\n onKeyDown: handleKeyDown,\n }),\n [customization?.buttonProps, ariaLabel, ariaExpanded, buttonClasses, handleClick, handleKeyDown],\n );\n\n const selectTriggerProps = useMemo(\n () => ({\n ...customization?.selectTriggerProps,\n 'aria-label': ariaLabel,\n className: buttonClasses,\n onKeyDown: handleKeyDown,\n }),\n [customization?.selectTriggerProps, ariaLabel, buttonClasses, handleKeyDown],\n );\n\n return (\n <motion.div layout className={wrapperClasses} transition={{ layout: layoutAnimation } as Transition}>\n {isMobile ? (\n <button {...mobileButtonProps}>{innerContent}</button>\n ) : (\n <Select.Trigger {...selectTriggerProps}>{innerContent}</Select.Trigger>\n )}\n </motion.div>\n );\n};\n\n/**\n * Props for the ChainSelector component.\n */\nexport interface ChainSelectorProps extends InitialChains, Pick<ConnectButtonProps, 'store'> {\n /** Comprehensive customization options */\n customization?: ChainSelectorCustomization;\n /** Custom CSS classes for the main container */\n className?: string;\n /** Custom ARIA label for the selector */\n 'aria-label'?: string;\n}\n\n/**\n * The main chain selector component.\n * Supports both desktop (dropdown) and mobile (dialog modal) interfaces.\n *\n * @param props - Props for the ChainSelector component\n * @returns The chain selector component or null if no wallet is connected\n */\nexport function ChainSelector({\n appChains,\n solanaRPCUrls,\n store,\n customization,\n className,\n 'aria-label': ariaLabel,\n}: ChainSelectorProps) {\n const labels = useNovaConnectLabels();\n const { activeWallet } = useNovaConnect();\n const { isChainsListOpen, setIsChainsListOpen, isChainsListOpenMobile, setIsChainsListOpenMobile } = useNovaConnect();\n\n // State to manage dynamic chain loading\n const [chainsList, setChainsList] = useState<(string | number)[]>([]);\n const [isLoadingChains, setIsLoadingChains] = useState(false);\n\n // Use refs to track loading state and prevent parallel fetches\n const loadingRef = useRef(false);\n const walletTypeRef = useRef<string | null>(null);\n\n // Extract custom components\n const {\n LoadingState = DefaultLoadingState,\n SingleChainDisplay = DefaultSingleChainDisplay,\n DesktopSelector = DefaultDesktopSelector,\n MobileSelector = DefaultMobileSelector,\n DialogHeader = DefaultDialogHeader,\n } = customization?.components ?? {};\n\n const {\n onChainChange: customChainChangeHandler = defaultChainChangeHandler,\n onDialogClose: customDialogCloseHandler = defaultDialogCloseHandler,\n } = customization?.handlers ?? {};\n\n // Generate all classes and styles upfront to avoid conditional useMemo\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({\n hasMultipleChains: chainsList.length > 1,\n isLoading: isLoadingChains,\n });\n }\n return className;\n // eslint-disable-next-line\n }, [customization?.classNames?.container, chainsList.length, isLoadingChains, className]);\n\n const loadingStateClasses = useMemo(() => {\n if (customization?.classNames?.loadingState) {\n return customization.classNames.loadingState();\n }\n return 'novacon:flex novacon:items-center novacon:space-x-2 novacon:[&_img]:w-6 novacon:[&_img]:h-6 novacon:animate-pulse';\n // eslint-disable-next-line\n }, [customization?.classNames?.loadingState]);\n\n const singleChainDisplayClasses = useMemo(() => {\n if (customization?.classNames?.singleChainDisplay) {\n return customization.classNames.singleChainDisplay();\n }\n return 'novacon:flex novacon:items-center novacon:space-x-2 novacon:[&_img]:w-6 novacon:[&_img]:h-6';\n // eslint-disable-next-line\n }, [customization?.classNames?.singleChainDisplay]);\n\n const desktopWrapperClasses = useMemo(() => {\n if (customization?.classNames?.desktopWrapper) {\n return customization.classNames.desktopWrapper({ chainCount: chainsList.length });\n }\n return 'novacon:hidden novacon:sm:block';\n // eslint-disable-next-line\n }, [customization?.classNames?.desktopWrapper, chainsList.length]);\n\n const mobileWrapperClasses = useMemo(() => {\n if (customization?.classNames?.mobileWrapper) {\n return customization.classNames.mobileWrapper({ chainCount: chainsList.length });\n }\n return 'novacon:sm:hidden';\n // eslint-disable-next-line\n }, [customization?.classNames?.mobileWrapper, chainsList.length]);\n\n const dialogContentClasses = useMemo(() => {\n if (customization?.classNames?.dialogContent) {\n return customization.classNames.dialogContent({ chainCount: chainsList.length });\n }\n return cn('novacon:w-full novacon:sm:max-w-md');\n // eslint-disable-next-line\n }, [customization?.classNames?.dialogContent, chainsList.length]);\n\n const dialogInnerContainerClasses = useMemo(() => {\n if (customization?.classNames?.dialogInnerContainer) {\n return customization.classNames.dialogInnerContainer();\n }\n return cn('novacon:relative novacon:flex novacon:w-full novacon:flex-col');\n // eslint-disable-next-line\n }, [customization?.classNames?.dialogInnerContainer]);\n\n /**\n * Handles switching networks when the user selects a different chain.\n */\n const handleChainChange = useCallback(\n (newChainId: string) => {\n const originalHandler = (chainId: string) => {\n store?.getState().switchNetwork(chainId);\n };\n\n customChainChangeHandler(originalHandler, newChainId);\n },\n [store, customChainChangeHandler],\n );\n\n /**\n * Retrieves chain formatting data for display purposes.\n */\n const getChainData = useCallback(\n (chain: string | number) => {\n if (!activeWallet) return { formattedChainId: chain, chain };\n\n return {\n formattedChainId: formatWalletChainId(chain, getAdapterFromWalletType(activeWallet.walletType)),\n chain,\n };\n },\n [activeWallet],\n );\n\n /**\n * Loads the chain list dynamically with async and fallback support.\n */\n useEffect(() => {\n // Reset state on wallet change/disconnect\n if (!activeWallet) {\n setChainsList([]);\n setIsLoadingChains(false);\n loadingRef.current = false;\n walletTypeRef.current = null;\n return;\n }\n\n // Don't fetch if same wallet type and already loading/loaded\n if (walletTypeRef.current === activeWallet.walletType && (loadingRef.current || chainsList.length > 0)) {\n return;\n }\n\n // Setup loading state\n if (loadingRef.current) return;\n loadingRef.current = true;\n walletTypeRef.current = activeWallet.walletType;\n setIsLoadingChains(true);\n\n // Safely extract wallet chains using common utility\n const walletChains = getWalletChains(activeWallet);\n\n const loadChains = async () => {\n try {\n // Try async version first for better functionality\n const asyncChains = await getChainsListByWalletTypeAsync({\n walletType: activeWallet.walletType,\n appChains,\n solanaRPCUrls,\n chains: walletChains,\n });\n\n if (asyncChains.length > 0) {\n setChainsList(asyncChains);\n return;\n }\n } catch (asyncError) {\n console.warn('Async chain loading failed, falling back to sync method:', asyncError);\n }\n\n // Fallback to sync version\n try {\n const syncChains = getChainsListByWalletType({\n walletType: activeWallet.walletType,\n appChains,\n solanaRPCUrls,\n chains: walletChains,\n });\n\n setChainsList(syncChains);\n } catch (syncError) {\n console.error('Both async and sync chain loading failed:', syncError);\n setChainsList([]); // Ensure valid array\n } finally {\n setIsLoadingChains(false);\n loadingRef.current = false;\n }\n };\n\n loadChains();\n }, [activeWallet, appChains, solanaRPCUrls, chainsList.length]);\n\n /**\n * Handles closing the mobile dialog.\n */\n const handleDialogClose = useCallback(() => {\n const originalHandler = () => setIsChainsListOpenMobile(false);\n customDialogCloseHandler(originalHandler);\n }, [customDialogCloseHandler, setIsChainsListOpenMobile]);\n\n /**\n * Memoized loading state check.\n */\n const isLoading = useMemo(() => isLoadingChains && chainsList.length === 0, [isLoadingChains, chainsList.length]);\n\n // Early return if no wallet is connected\n if (!activeWallet) return null;\n\n // Current chain info\n const currentFormattedChainId = formatWalletChainId(\n activeWallet.chainId,\n getAdapterFromWalletType(activeWallet.walletType),\n );\n\n const selectValue = String(currentFormattedChainId);\n const chainName = getChainName(currentFormattedChainId);\n\n // Show loading state while chains are fetching\n if (isLoading) {\n return <LoadingState className={loadingStateClasses} aria-label={`${labels.loading}...`} />;\n }\n\n // Display single chain - no selector needed\n if (chainsList.length <= 1) {\n return (\n <SingleChainDisplay\n chainId={currentFormattedChainId}\n chainName={chainName}\n className={singleChainDisplayClasses}\n aria-label={`${labels.currentChain}: ${chainName}`}\n />\n );\n }\n\n const finalAriaLabel = ariaLabel || labels.chainSelector;\n\n // Main selector UI for multiple chains\n return (\n <div className={containerClasses}>\n {/* Desktop View - Dropdown */}\n <DesktopSelector className={desktopWrapperClasses} aria-label={finalAriaLabel}>\n <Select.Root\n value={selectValue}\n onValueChange={handleChainChange}\n open={isChainsListOpen}\n onOpenChange={setIsChainsListOpen}\n >\n <ChainTriggerButton\n currentFormattedChainId={currentFormattedChainId}\n isChainsListOpen={isChainsListOpen}\n onToggle={() => setIsChainsListOpen(!isChainsListOpen)}\n selectValue={selectValue}\n isMobile={false}\n hasMultipleChains={chainsList.length > 1}\n customization={customization?.triggerButton}\n />\n <SelectContentAnimated className=\"novacon:w-[210px]\" {...customization?.selectContent}>\n <ChainListRenderer\n chainsList={chainsList}\n selectValue={selectValue}\n handleValueChange={handleChainChange}\n getChainData={getChainData}\n onClose={() => setIsChainsListOpen(false)}\n isMobile={false}\n customization={customization?.chainListRenderer}\n />\n </SelectContentAnimated>\n </Select.Root>\n </DesktopSelector>\n\n {/* Mobile View - Dialog Modal */}\n <MobileSelector className={mobileWrapperClasses} aria-label={finalAriaLabel}>\n <ChainTriggerButton\n currentFormattedChainId={currentFormattedChainId}\n isChainsListOpen={isChainsListOpenMobile}\n onToggle={() => setIsChainsListOpenMobile(true)}\n selectValue={selectValue}\n isMobile={true}\n hasMultipleChains={chainsList.length > 1}\n customization={customization?.triggerButton}\n />\n\n <Dialog open={isChainsListOpenMobile} onOpenChange={setIsChainsListOpenMobile}>\n <DialogContent className={dialogContentClasses} aria-describedby=\"chain-selector-description\">\n <div className={dialogInnerContainerClasses}>\n <DialogHeader title={labels.switchNetworks} onClose={handleDialogClose} />\n\n <div id=\"chain-selector-description\" className=\"novacon:sr-only\">\n {labels.selectChain}\n </div>\n\n <ScrollableChainList\n chainsList={chainsList}\n selectValue={selectValue}\n handleValueChange={handleChainChange}\n getChainData={getChainData}\n onClose={() => setIsChainsListOpenMobile(false)}\n customization={customization?.scrollableChainList}\n />\n </div>\n </DialogContent>\n </Dialog>\n </MobileSelector>\n </div>\n );\n}\n","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","/**\n * @file ConnectedModalFooter component with comprehensive customization options and wallet control actions.\n */\n\nimport { cn, standardButtonClasses } from '@tuwaio/nova-core';\nimport { getAdapterFromWalletType } from '@tuwaio/orbit-core';\nimport { type Easing, motion, type Variants } from 'framer-motion';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useCallback, useMemo } from 'react';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\n\n// --- Default Motion Variants ---\nconst DEFAULT_PATH_ANIMATION_VARIANTS: Variants = {\n hidden: { pathLength: 0, opacity: 0 },\n visible: { pathLength: 1, opacity: 1 },\n};\n\n// --- Types for Customization ---\ntype CustomDisconnectButtonProps = {\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n labels: Record<string, string>;\n className?: string;\n 'data-testid'?: string;\n 'aria-describedby'?: string;\n disabled?: boolean;\n};\n\ntype CustomExplorerLinkProps = {\n href: string;\n labels: Record<string, string>;\n walletAddress: string;\n isValidUrl: boolean;\n className?: string;\n 'data-testid'?: string;\n 'aria-describedby'?: string;\n onClick?: (event: React.MouseEvent<HTMLAnchorElement>) => void;\n};\n\ntype CustomDisconnectIconProps = {\n pathData: string;\n variants?: Variants;\n className?: string;\n strokeWidth?: string | number;\n strokeLinecap?: 'butt' | 'round' | 'square';\n strokeLinejoin?: 'miter' | 'bevel' | 'round';\n animation?: {\n duration?: number;\n ease?: Easing | Easing[];\n delay?: number;\n };\n};\n\ntype CustomExplorerIconProps = {\n pathData: string;\n variants?: Variants;\n className?: string;\n strokeWidth?: string | number;\n strokeLinecap?: 'butt' | 'round' | 'square';\n strokeLinejoin?: 'miter' | 'bevel' | 'round';\n isAnimated?: boolean;\n animation?: {\n duration?: number;\n ease?: Easing | Easing[];\n delay?: number;\n };\n};\n\ntype CustomFooterContentProps = {\n disconnectButton: ReactNode;\n explorerLink: ReactNode;\n isValidExplorerUrl: boolean;\n walletAddress: string;\n labels: Record<string, string>;\n};\n\n/**\n * Customization options for ConnectedModalFooter component\n */\nexport type ConnectedModalFooterCustomization = {\n /** Override container element props */\n containerProps?: Partial<ComponentPropsWithoutRef<'footer'>>;\n /** Custom components */\n components?: {\n /** Custom disconnect button component */\n DisconnectButton?: ComponentType<CustomDisconnectButtonProps>;\n /** Custom explorer link component */\n ExplorerLink?: ComponentType<CustomExplorerLinkProps>;\n /** Custom disconnect icon component */\n DisconnectIcon?: ComponentType<CustomDisconnectIconProps>;\n /** Custom explorer icon component */\n ExplorerIcon?: ComponentType<CustomExplorerIconProps>;\n /** Custom footer content component (wraps everything) */\n FooterContent?: ComponentType<CustomFooterContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { isValidExplorerUrl: boolean; walletAddress: string }) => string;\n /** Function to generate disconnect button classes */\n disconnectButton?: (params: { disabled?: boolean }) => string;\n /** Function to generate explorer link classes */\n explorerLink?: (params: { isValidUrl: boolean; disabled?: boolean }) => string;\n /** Function to generate disconnect icon container classes */\n disconnectIconContainer?: () => string;\n /** Function to generate explorer icon container classes */\n explorerIconContainer?: () => string;\n /** Function to generate disconnect icon classes */\n disconnectIcon?: () => string;\n /** Function to generate explorer icon classes */\n explorerIcon?: (params: { isValidUrl: boolean }) => string;\n /** Function to generate button text classes */\n buttonText?: (params: { buttonType: 'disconnect' | 'explorer' }) => string;\n /** Function to generate screen reader text classes */\n screenReaderText?: () => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Disconnect icon animation variants */\n disconnectIcon?: Variants;\n /** Explorer icon animation variants */\n explorerIcon?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Disconnect icon animation configuration */\n disconnectIcon?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Explorer icon animation configuration */\n explorerIcon?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom SVG properties */\n svg?: {\n /** Custom disconnect icon path */\n disconnectIconPath?: string;\n /** Custom explorer icon path */\n explorerIconPath?: string;\n /** Custom disconnect icon viewBox */\n disconnectIconViewBox?: string;\n /** Custom explorer icon viewBox */\n explorerIconViewBox?: string;\n /** Custom disconnect icon stroke width */\n disconnectIconStrokeWidth?: string | number;\n /** Custom explorer icon stroke width */\n explorerIconStrokeWidth?: string | number;\n /** Custom disconnect icon stroke linecap */\n disconnectIconStrokeLinecap?: 'butt' | 'round' | 'square';\n /** Custom explorer icon stroke linecap */\n explorerIconStrokeLinecap?: 'butt' | 'round' | 'square';\n /** Custom disconnect icon stroke linejoin */\n disconnectIconStrokeLinejoin?: 'miter' | 'bevel' | 'round';\n /** Custom explorer icon stroke linejoin */\n explorerIconStrokeLinejoin?: 'miter' | 'bevel' | 'round';\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for disconnect button click */\n onDisconnectClick?: (originalHandler: () => void, event: React.MouseEvent<HTMLButtonElement>) => void;\n /** Custom handler for explorer link click */\n onExplorerClick?: (explorerUrl: string, walletAddress: string, event: React.MouseEvent<HTMLAnchorElement>) => void;\n /** Custom handler before disconnect */\n onBeforeDisconnect?: () => boolean | Promise<boolean>;\n /** Custom handler after disconnect */\n onAfterDisconnect?: () => void;\n };\n /** Custom text and aria labels */\n labels?: {\n /** Custom disconnect button text */\n disconnectText?: string;\n /** Custom explorer link text */\n explorerText?: string;\n /** Custom disconnect description for screen readers */\n disconnectDescription?: string;\n /** Custom explorer description for screen readers */\n explorerDescription?: string;\n /** Custom footer aria label */\n footerAriaLabel?: string;\n /** Custom explorer unavailable message */\n explorerUnavailableMessage?: string;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Whether to show disconnect button */\n showDisconnectButton?: boolean;\n /** Whether to show explorer link */\n showExplorerLink?: boolean;\n /** Custom disconnect button test id */\n disconnectButtonTestId?: string;\n /** Custom explorer link test id */\n explorerLinkTestId?: string;\n /** Whether to close modal after disconnect */\n closeModalAfterDisconnect?: boolean;\n /** Custom explorer URL fallback */\n explorerUrlFallback?: string;\n };\n};\n\n/**\n * Props for the ConnectedModalFooter component\n */\nexport interface ConnectedModalFooterProps extends Pick<ConnectButtonProps, 'store'> {\n /** Callback to control modal visibility */\n setIsOpen: (isOpen: boolean) => void;\n /** Custom CSS classes for the container */\n className?: string;\n /** Custom aria-label for the container */\n 'aria-label'?: string;\n /** Customization options */\n customization?: ConnectedModalFooterCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultDisconnectButton: React.FC<\n CustomDisconnectButtonProps & Omit<ComponentPropsWithoutRef<'button'>, 'onClick' | 'style'>\n> = ({\n onClick,\n labels,\n className,\n 'data-testid': testId,\n 'aria-describedby': ariaDescribedBy,\n disabled = false,\n ...props\n}) => {\n const iconPath =\n 'M8.25 9V5.25A2.25 2.25 0 0 1 10.5 3h6a2.25 2.25 0 0 1 2.25 2.25v13.5A2.25 2.25 0 0 1 16.5 21h-6a2.25 2.25 0 0 1-2.25-2.25V15m-3 0-3-3m0 0 3-3m-3 3H15';\n\n return (\n <button\n type=\"button\"\n className={cn(standardButtonClasses, className)}\n onClick={onClick}\n aria-describedby={ariaDescribedBy}\n data-testid={testId}\n disabled={disabled}\n {...props}\n >\n <DefaultDisconnectIcon pathData={iconPath} />\n <span id={ariaDescribedBy} className=\"novacon:sr-only\">\n {labels.disconnect} wallet and close modal\n </span>\n {labels.disconnect}\n </button>\n );\n};\n\nconst DefaultExplorerLink: React.FC<\n CustomExplorerLinkProps &\n Omit<ComponentPropsWithoutRef<'a'>, 'onClick' | 'style'> &\n Pick<ComponentPropsWithoutRef<'button'>, 'type'>\n> = ({\n href,\n labels,\n walletAddress,\n isValidUrl,\n className,\n 'data-testid': testId,\n 'aria-describedby': ariaDescribedBy,\n onClick,\n type,\n ...props\n}) => {\n const iconPath =\n 'M13.5 6H5.25A2.25 2.25 0 0 0 3 8.25v10.5A2.25 2.25 0 0 0 5.25 21h10.5A2.25 2.25 0 0 0 18 18.75V10.5m-10.5 6L21 3m0 0h-5.25M21 3v5.25';\n\n if (isValidUrl) {\n return (\n <a\n href={href}\n className={cn(standardButtonClasses, className)}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n aria-describedby={ariaDescribedBy}\n data-testid={testId}\n onClick={onClick}\n {...props}\n >\n <span className=\"novacon:flex novacon:items-center novacon:gap-2\">\n {labels.viewOnExplorer}\n <DefaultExplorerIcon pathData={iconPath} isAnimated={true} />\n </span>\n <span id={ariaDescribedBy} className=\"novacon:sr-only\">\n Opens in new tab - View wallet address {walletAddress} on blockchain explorer\n </span>\n </a>\n );\n }\n\n return (\n <button\n type={type ?? 'button'}\n className={cn(standardButtonClasses, 'novacon:opacity-50 novacon:cursor-not-allowed', className)}\n disabled\n aria-describedby={ariaDescribedBy}\n title=\"Explorer not available for this network\"\n >\n <span className=\"novacon:flex novacon:items-center novacon:gap-2\">\n {labels.viewOnExplorer}\n <DefaultExplorerIcon pathData={iconPath} isAnimated={false} />\n </span>\n <span id={ariaDescribedBy} className=\"novacon:sr-only\">\n Blockchain explorer is not available for this network\n </span>\n </button>\n );\n};\n\nconst DefaultDisconnectIcon: React.FC<CustomDisconnectIconProps & Omit<ComponentPropsWithoutRef<'svg'>, 'style'>> = ({\n pathData,\n variants = DEFAULT_PATH_ANIMATION_VARIANTS,\n className,\n strokeWidth = 1.5,\n strokeLinecap = 'round',\n strokeLinejoin = 'round',\n animation,\n ...props\n}) => {\n const animationConfig = {\n duration: animation?.duration ?? 0.5,\n ease: animation?.ease ?? 'easeInOut',\n delay: animation?.delay ?? 0,\n };\n\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={strokeWidth}\n stroke=\"currentColor\"\n className={cn('novacon:w-5 novacon:h-5', className)}\n aria-hidden=\"true\"\n {...props}\n >\n <motion.path\n d={pathData}\n strokeLinecap={strokeLinecap}\n strokeLinejoin={strokeLinejoin}\n variants={variants}\n initial=\"hidden\"\n animate=\"visible\"\n transition={animationConfig}\n />\n </svg>\n );\n};\n\nconst DefaultExplorerIcon: React.FC<CustomExplorerIconProps & Omit<ComponentPropsWithoutRef<'svg'>, 'style'>> = ({\n pathData,\n variants = DEFAULT_PATH_ANIMATION_VARIANTS,\n className,\n strokeWidth = 1.5,\n strokeLinecap = 'round',\n strokeLinejoin = 'round',\n isAnimated = true,\n animation,\n ...props\n}) => {\n const animationConfig = {\n duration: animation?.duration ?? 0.5,\n ease: animation?.ease ?? 'easeInOut',\n delay: animation?.delay ?? 0,\n };\n\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={strokeWidth}\n stroke=\"currentColor\"\n className={cn('novacon:w-4 novacon:h-4', className)}\n aria-hidden=\"true\"\n {...props}\n >\n {isAnimated ? (\n <motion.path\n d={pathData}\n strokeLinecap={strokeLinecap}\n strokeLinejoin={strokeLinejoin}\n variants={variants}\n initial=\"hidden\"\n animate=\"visible\"\n transition={animationConfig}\n />\n ) : (\n <path d={pathData} strokeLinecap={strokeLinecap} strokeLinejoin={strokeLinejoin} />\n )}\n </svg>\n );\n};\n\nconst DefaultFooterContent: React.FC<Pick<CustomFooterContentProps, 'disconnectButton' | 'explorerLink'>> = ({\n disconnectButton,\n explorerLink,\n}) => {\n return (\n <>\n {disconnectButton}\n {explorerLink}\n </>\n );\n};\n\n/**\n * ConnectedModalFooter provides wallet control actions with comprehensive customization options.\n * Displays disconnect button and explorer link with full accessibility support and animation capabilities.\n *\n * Features:\n * - Disconnect button with animated icon and modal closure\n * - Explorer link with external indicator and validation\n * - Comprehensive customization for all UI elements and behaviors\n * - Full accessibility support with ARIA labels and screen reader descriptions\n * - Responsive design with mobile-first approach\n * - Custom event handlers for enhanced interactivity\n * - Animation customization with reduced motion support\n * - Custom SVG icons and paths\n * - Error handling for explorer URL generation\n * - Disabled state for unavailable explorer links\n * - Performance-optimized with memoized calculations\n *\n * @example Basic usage\n * ```tsx\n * <ConnectedModalFooter\n * setIsOpen={(open) => setModalOpen(open)}\n * store={walletStore}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectedModalFooter\n * setIsOpen={setModalOpen}\n * store={walletStore}\n * customization={{\n * classNames: {\n * container: ({ isValidExplorerUrl }) =>\n * `custom-footer ${isValidExplorerUrl ? 'with-explorer' : 'no-explorer'}`,\n * disconnectButton: () => \"custom-disconnect-btn bg-red-500 text-white\",\n * explorerLink: ({ isValidUrl }) =>\n * `custom-explorer-link ${isValidUrl ? 'active' : 'disabled'}`,\n * },\n * components: {\n * DisconnectButton: ({ onClick, labels, className }) =>\n * <button className={className} onClick={onClick}>Custom {labels.disconnect}</button>,\n * },\n * handlers: {\n * onDisconnectClick: (originalHandler, event) => {\n * console.log(\"Disconnecting...\");\n * originalHandler();\n * },\n * onBeforeDisconnect: async () => {\n * const confirmed = await showConfirmDialog();\n * return confirmed;\n * },\n * onAfterDisconnect: () => {\n * showNotification(\"Wallet disconnected\");\n * },\n * },\n * animation: {\n * disconnectIcon: { duration: 0.8, ease: \"easeOut\" },\n * explorerIcon: { duration: 0.6, delay: 0.1 },\n * },\n * svg: {\n * disconnectIconPath: \"M12 2L2 7v10l10 5 10-5V7L12 2z\",\n * explorerIconPath: \"M8 2L2 8v8l6 6h8l6-6V8L16 2H8z\",\n * disconnectIconStrokeWidth: 2,\n * },\n * config: {\n * closeModalAfterDisconnect: false,\n * showDisconnectButton: true,\n * showExplorerLink: true,\n * reduceMotion: false,\n * },\n * }}\n * />\n * ```\n */\nexport const ConnectedModalFooter = forwardRef<HTMLElement, ConnectedModalFooterProps>(\n ({ setIsOpen, store, className, 'aria-label': ariaLabel, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n const { activeWallet } = useNovaConnect();\n\n // Get wallet state and actions from store\n const getAdapter = store.getState().getAdapter;\n const disconnect = store.getState().disconnect;\n\n // Extract custom components and config\n const {\n DisconnectButton = DefaultDisconnectButton,\n ExplorerLink = DefaultExplorerLink,\n FooterContent = DefaultFooterContent,\n } = customization?.components ?? {};\n\n const {\n showDisconnectButton = true,\n showExplorerLink = true,\n disconnectButtonTestId = 'disconnect-button',\n explorerLinkTestId = 'explorer-link',\n closeModalAfterDisconnect = true,\n explorerUrlFallback = '#',\n } = customization?.config ?? {};\n\n // Memoize custom labels\n const finalLabels = useMemo(\n () => ({\n ...labels,\n ...(customization?.labels && {\n disconnect: customization.labels.disconnectText ?? labels.disconnect,\n viewOnExplorer: customization.labels.explorerText ?? labels.viewOnExplorer,\n walletControls: customization.labels.footerAriaLabel ?? labels.walletControls,\n }),\n }),\n [labels, customization?.labels],\n );\n\n /**\n * Generate explorer URL for the current wallet address\n * Memoized to prevent unnecessary recalculations\n */\n const explorerUrl = useMemo(() => {\n if (!activeWallet) return explorerUrlFallback;\n\n try {\n const adapter = getAdapter(getAdapterFromWalletType(activeWallet.walletType));\n return adapter?.getExplorerUrl(`/address/${activeWallet.address}`, activeWallet.chainId) || explorerUrlFallback;\n } catch (error) {\n console.warn('Failed to generate explorer URL:', error);\n return explorerUrlFallback;\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [activeWallet?.walletType, activeWallet?.address, activeWallet?.chainId, getAdapter, explorerUrlFallback]);\n\n /**\n * Check if explorer URL is valid for link functionality\n */\n const isValidExplorerUrl = useMemo(\n () => explorerUrl !== '#' && explorerUrl !== explorerUrlFallback,\n [explorerUrl, explorerUrlFallback],\n );\n\n /**\n * Handle wallet disconnection with custom hooks\n */\n const handleDisconnect = useCallback(\n async (event: React.MouseEvent<HTMLButtonElement>) => {\n try {\n // Custom before disconnect handler\n if (customization?.handlers?.onBeforeDisconnect) {\n const shouldProceed = await customization.handlers.onBeforeDisconnect();\n if (!shouldProceed) return;\n }\n\n // Custom disconnect click handler\n const originalHandler = () => {\n disconnect();\n if (closeModalAfterDisconnect) {\n setIsOpen(false);\n }\n };\n\n if (customization?.handlers?.onDisconnectClick) {\n customization.handlers.onDisconnectClick(originalHandler, event);\n } else {\n originalHandler();\n }\n\n // Custom after disconnect handler\n if (customization?.handlers?.onAfterDisconnect) {\n customization.handlers.onAfterDisconnect();\n }\n } catch (error) {\n console.error('Error during disconnect:', error);\n }\n },\n [disconnect, setIsOpen, customization, closeModalAfterDisconnect],\n );\n\n /**\n * Handle explorer link click with custom handler\n */\n const handleExplorerClick = useCallback(\n (event: React.MouseEvent<HTMLAnchorElement>) => {\n if (customization?.handlers?.onExplorerClick && activeWallet) {\n customization.handlers.onExplorerClick(explorerUrl, activeWallet.address, event);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.handlers?.onExplorerClick, explorerUrl, activeWallet?.address],\n );\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container && activeWallet) {\n return customization.classNames.container({\n isValidExplorerUrl,\n walletAddress: activeWallet.address,\n });\n }\n return cn(\n 'novacon:flex novacon:flex-wrap novacon:gap-4 novacon:w-full novacon:items-center novacon:justify-between novacon:border-t novacon:border-[var(--tuwa-border-primary)] novacon:p-4 novacon:flex-col-reverse novacon:sm:flex-row',\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, isValidExplorerUrl, activeWallet?.address, className]);\n\n // Generate disconnect button element\n const disconnectButtonElement = useMemo(() => {\n if (!showDisconnectButton || !activeWallet) return null;\n\n return (\n <DisconnectButton\n onClick={handleDisconnect}\n labels={finalLabels}\n className={customization?.classNames?.disconnectButton?.({})}\n data-testid={disconnectButtonTestId}\n aria-describedby=\"disconnect-description\"\n />\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n showDisconnectButton,\n activeWallet,\n DisconnectButton,\n handleDisconnect,\n finalLabels,\n customization?.classNames?.disconnectButton,\n disconnectButtonTestId,\n ]);\n\n // Generate explorer link element\n const explorerLinkElement = useMemo(() => {\n if (!showExplorerLink || !activeWallet) return null;\n\n return (\n <ExplorerLink\n href={explorerUrl}\n labels={finalLabels}\n walletAddress={activeWallet.address}\n isValidUrl={isValidExplorerUrl}\n className={customization?.classNames?.explorerLink?.({\n isValidUrl: isValidExplorerUrl,\n disabled: !isValidExplorerUrl,\n })}\n data-testid={explorerLinkTestId}\n aria-describedby=\"explorer-description\"\n onClick={handleExplorerClick}\n />\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n showExplorerLink,\n activeWallet,\n ExplorerLink,\n explorerUrl,\n finalLabels,\n isValidExplorerUrl,\n customization?.classNames?.explorerLink,\n explorerLinkTestId,\n handleExplorerClick,\n ]);\n\n // Merge container props\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'contentinfo',\n 'aria-label': ariaLabel || finalLabels.walletControls,\n }),\n [customization?.containerProps, props, ref, containerClasses, ariaLabel, finalLabels],\n );\n\n // Early return if no active wallet\n if (!activeWallet) return null;\n\n return (\n <footer {...containerProps}>\n <FooterContent\n disconnectButton={disconnectButtonElement}\n explorerLink={explorerLinkElement}\n isValidExplorerUrl={isValidExplorerUrl}\n walletAddress={activeWallet.address}\n labels={finalLabels}\n />\n </footer>\n );\n },\n);\n\nConnectedModalFooter.displayName = 'ConnectedModalFooter';\n","/**\n * @file This file contains the `WalletAvatar` component, a customizable user avatar renderer with ENS support and blockie fallback.\n */\n\nimport { cn } from '@tuwaio/nova-core';\nimport makeBlockie from 'ethereum-blockies-base64';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, useCallback, useMemo, useState } from 'react';\n\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\n\n// --- Types for Customization ---\ntype CustomLoadingOverlayProps = {\n isLoading: boolean;\n showLoading: boolean;\n disableAnimation: boolean;\n size: WalletAvatarSize;\n};\n\ntype CustomAvatarImageProps = {\n src: string;\n isLoading: boolean;\n onLoad: () => void;\n onError: (event: React.SyntheticEvent<HTMLImageElement, Event>) => void;\n address: string;\n ensAvatar?: string | null;\n size: WalletAvatarSize;\n};\n\ntype CustomFallbackContentProps = {\n address: string;\n formattedAddress: string;\n size: WalletAvatarSize;\n};\n\nexport type WalletAvatarSize = 'sm' | 'md' | 'lg' | 'xl';\n\n/**\n * Customization options for WalletAvatar component\n */\nexport type WalletAvatarCustomization = {\n /** Override container element props */\n containerProps?: Partial<ComponentPropsWithoutRef<'div'>>;\n /** Override image element props */\n imageProps?: Partial<ComponentPropsWithoutRef<'img'>>;\n /** Custom components */\n components?: {\n /** Custom loading overlay component */\n LoadingOverlay?: ComponentType<CustomLoadingOverlayProps>;\n /** Custom avatar image component */\n AvatarImage?: ComponentType<CustomAvatarImageProps>;\n /** Custom fallback content component for extreme error cases */\n FallbackContent?: ComponentType<CustomFallbackContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { size: WalletAvatarSize; bgColor: string; address: string }) => string;\n /** Function to generate loading overlay classes */\n loadingOverlay?: (params: { isLoading: boolean; showLoading: boolean; disableAnimation: boolean }) => string;\n /** Function to generate image classes */\n image?: (params: { isLoading: boolean; size: WalletAvatarSize; hasError: boolean }) => string;\n /** Function to generate fallback content classes */\n fallbackContent?: (params: { size: WalletAvatarSize; address: string }) => string;\n };\n /** Custom utilities */\n utils?: {\n /** Custom blockie generator function */\n generateBlockie?: (address: string) => string | null;\n /** Custom background color generator function */\n generateBgColor?: (address: string) => string;\n /** Custom address formatter function */\n formatAddress?: (address: string, labels: any) => string;\n };\n};\n\nexport interface WalletAvatarProps extends Omit<ComponentPropsWithoutRef<'div'>, 'role'> {\n /** The user's wallet address, used for the blockie fallback and background color. */\n address: string;\n /** An optional URL for the user's ENS avatar image. */\n ensAvatar?: string | null;\n /** Custom alt text for the avatar image */\n altText?: string;\n /** Size variant for the avatar */\n size?: WalletAvatarSize;\n /** Whether to show loading animation */\n showLoading?: boolean;\n /** Callback fired when image loads successfully */\n onImageLoad?: () => void;\n /** Callback fired when image fails to load */\n onImageError?: (error: Event) => void;\n /** Whether to disable the pulse animation */\n disableAnimation?: boolean;\n /** Customization options */\n customization?: WalletAvatarCustomization;\n}\n\n// --- Utility Functions ---\nfunction isHex(value: unknown, { strict = true }: { strict?: boolean | undefined } = {}): value is `0x${string}` {\n if (!value) return false;\n if (typeof value !== 'string') return false;\n return strict ? /^0x[0-9a-fA-F]*$/.test(value) : value.startsWith('0x');\n}\n\nconst zeroAddress = '0x0000000000000000000000000000000000000000';\n\n// Size mapping for different avatar sizes\nconst sizeClasses = {\n sm: 'novacon:h-4 novacon:w-4',\n md: 'novacon:h-6 novacon:w-6',\n lg: 'novacon:h-8 novacon:w-8',\n xl: 'novacon:h-12 novacon:w-12',\n} as const;\n\n// --- Default Sub-Components ---\nconst DefaultLoadingOverlay = ({ isLoading, showLoading, disableAnimation }: CustomLoadingOverlayProps) => {\n const loadingClasses = cn(\n 'novacon:absolute novacon:inset-0 novacon:rounded-full novacon:bg-[var(--tuwa-bg-muted)]',\n {\n 'novacon:animate-pulse': !disableAnimation && showLoading && isLoading,\n 'novacon:opacity-0': !isLoading || !showLoading,\n },\n 'novacon:transition-opacity novacon:duration-300',\n );\n\n return <div className={loadingClasses} aria-hidden=\"true\" />;\n};\n\nconst DefaultAvatarImage = ({ src, isLoading, onLoad, onError, address, ensAvatar }: CustomAvatarImageProps) => {\n return (\n <img\n key={`${ensAvatar || 'blockie'}-${address}`}\n className={cn(\n 'novacon:h-full novacon:w-full novacon:rounded-full novacon:object-cover novacon:relative novacon:z-10',\n 'novacon:transition-opacity novacon:duration-300 novacon:opacity-100',\n {\n 'novacon:opacity-0': isLoading,\n },\n )}\n src={src}\n alt=\"\"\n onLoad={onLoad}\n onError={onError}\n loading=\"lazy\"\n decoding=\"async\"\n draggable={false}\n />\n );\n};\n\nconst DefaultFallbackContent = ({ formattedAddress }: CustomFallbackContentProps) => {\n return (\n <div\n className=\"novacon:absolute novacon:inset-0 novacon:flex novacon:items-center novacon:justify-center novacon:text-white novacon:text-xs novacon:font-mono\"\n aria-hidden=\"true\"\n >\n {formattedAddress.slice(0, 2)}\n </div>\n );\n};\n\n// --- Default Utility Functions ---\nconst defaultGenerateBlockie = (address: string): string | null => {\n try {\n return makeBlockie(isHex(address) ? address : zeroAddress);\n } catch (error) {\n console.warn('Failed to generate blockie for address:', address, error);\n return null;\n }\n};\n\nconst defaultGenerateBgColor = (address: string): string => {\n try {\n if (!isHex(address)) return '#6B7280';\n const colorHex = address.slice(2, 8);\n return colorHex.length === 6 ? `#${colorHex}` : '#6B7280';\n } catch {\n return '#6B7280';\n }\n};\n\nconst defaultFormatAddress = (address: string, labels: any): string => {\n if (!address) return labels.unknownWallet;\n return `${address.slice(0, 6)}...${address.slice(-4)}`;\n};\n\n/**\n * A highly customizable wallet avatar component with ENS support, blockie fallback, and extensive styling options.\n * Provides comprehensive customization for container, image, loading states, and fallback content while maintaining accessibility.\n */\nexport const WalletAvatar = forwardRef<HTMLDivElement, WalletAvatarProps>(\n (\n {\n address,\n ensAvatar,\n className,\n altText,\n size = 'md',\n showLoading = true,\n onImageLoad,\n onImageError,\n disableAnimation = false,\n customization,\n ...props\n },\n ref,\n ) => {\n const labels = useNovaConnectLabels();\n\n // State management\n const [imageSrc, setImageSrc] = useState<string | null>(ensAvatar ?? null);\n const [isLoading, setIsLoading] = useState(Boolean(ensAvatar));\n const [hasError, setHasError] = useState(false);\n\n // Extract custom components and utilities\n const {\n LoadingOverlay = DefaultLoadingOverlay,\n AvatarImage = DefaultAvatarImage,\n FallbackContent = DefaultFallbackContent,\n } = customization?.components ?? {};\n\n const {\n generateBlockie = defaultGenerateBlockie,\n generateBgColor = defaultGenerateBgColor,\n formatAddress = defaultFormatAddress,\n } = customization?.utils ?? {};\n\n // Generate blockie using custom or default function\n const blockie = useMemo(() => generateBlockie(address), [address, generateBlockie]);\n\n // Generate background color using custom or default function\n const bgColor = useMemo(() => generateBgColor(address), [address, generateBgColor]);\n\n // Format address using custom or default function\n const formattedAddress = useMemo(() => formatAddress(address, labels), [address, labels, formatAddress]);\n\n // Generate alt text for accessibility\n const imageAltText = useMemo(() => {\n if (altText) return altText;\n if (hasError || !ensAvatar) {\n return `${labels.walletAvatar} ${formattedAddress}`;\n }\n return `${labels.ensAvatar} ${formattedAddress}`;\n }, [altText, hasError, ensAvatar, formattedAddress, labels.walletAvatar, labels.ensAvatar]);\n\n // Reset image source when ensAvatar changes\n const currentEnsAvatar = useMemo(() => ensAvatar ?? null, [ensAvatar]);\n\n useMemo(() => {\n setImageSrc(currentEnsAvatar);\n setIsLoading(Boolean(currentEnsAvatar));\n setHasError(false);\n }, [currentEnsAvatar]);\n\n // Handle image load success\n const handleImageLoad = useCallback(() => {\n setIsLoading(false);\n setHasError(false);\n onImageLoad?.();\n }, [onImageLoad]);\n\n // Handle image load error\n const handleImageError = useCallback(\n (event: React.SyntheticEvent<HTMLImageElement, Event>) => {\n setIsLoading(false);\n setHasError(true);\n setImageSrc(blockie);\n onImageError?.(event.nativeEvent);\n },\n [blockie, onImageError],\n );\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ size, bgColor, address });\n }\n return cn(\n sizeClasses[size],\n 'novacon:flex-shrink-0 novacon:rounded-full novacon:relative novacon:overflow-hidden',\n 'novacon:ring-1 novacon:ring-[var(--tuwa-border-primary)]',\n 'novacon:focus-within:ring-2 novacon:focus-within:ring-[var(--tuwa-text-accent)]',\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, size, bgColor, address, className]);\n\n // Get current image source with fallback\n const currentImageSrc = imageSrc || blockie || '';\n\n // Merge container props\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'img' as const,\n 'aria-label': imageAltText,\n title: imageAltText,\n }),\n [customization?.containerProps, props, ref, containerClasses, imageAltText],\n );\n\n return (\n <div {...containerProps}>\n {/* Loading overlay */}\n <LoadingOverlay\n isLoading={isLoading}\n showLoading={showLoading}\n disableAnimation={disableAnimation}\n size={size}\n />\n\n {/* Avatar image */}\n {currentImageSrc && (\n <AvatarImage\n src={currentImageSrc}\n isLoading={isLoading}\n onLoad={handleImageLoad}\n onError={handleImageError}\n address={address}\n ensAvatar={ensAvatar}\n size={size}\n />\n )}\n\n {/* Fallback content for extreme error cases */}\n {!currentImageSrc && <FallbackContent address={address} formattedAddress={formattedAddress} size={size} />}\n </div>\n );\n },\n);\n\nWalletAvatar.displayName = 'WalletAvatar';\n","/**\n * @file ConnectedModalNameAndBalance component with comprehensive customization options for wallet name and balance display.\n */\n\nimport { CheckIcon, DocumentDuplicateIcon } from '@heroicons/react/24/solid';\nimport { cn, useCopyToClipboard } from '@tuwaio/nova-core';\nimport { AnimatePresence, type Easing, motion, type Variants } from 'framer-motion';\nimport React, { ComponentPropsWithoutRef, ComponentType, forwardRef, useCallback, useMemo } from 'react';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { ConnectedModalMainContentProps } from './ConnectedModalMainContent';\n\n// --- Default Motion Variants ---\nconst DEFAULT_CONTAINER_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, y: 8 },\n animate: { opacity: 1, y: 0, transition: { duration: 0.3, ease: 'easeOut' } },\n exit: { opacity: 0, y: -8, transition: { duration: 0.2, ease: 'easeIn' } },\n};\n\nconst DEFAULT_COPY_ICON_ANIMATION_VARIANTS: Variants = {\n initial: { scale: 0.6, opacity: 0, rotate: 90 },\n animate: { scale: 1, opacity: 1, rotate: 0, transition: { duration: 0.2, ease: 'easeInOut' } },\n exit: { scale: 0.6, opacity: 0, rotate: -90, transition: { duration: 0.2, ease: 'easeInOut' } },\n};\n\nconst DEFAULT_CHECK_ICON_ANIMATION_VARIANTS: Variants = {\n initial: { scale: 0.6, opacity: 0, rotate: -90 },\n animate: { scale: 1, opacity: 1, rotate: 0, transition: { duration: 0.2, ease: 'easeInOut' } },\n exit: { scale: 0.6, opacity: 0, rotate: 90, transition: { duration: 0.2, ease: 'easeInOut' } },\n};\n\nconst DEFAULT_LOADING_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, scale: 0.95 },\n animate: { opacity: 1, scale: 1, transition: { duration: 0.2, ease: 'easeOut' } },\n exit: { opacity: 0, scale: 0.95, transition: { duration: 0.15, ease: 'easeIn' } },\n};\n\n// --- Types for Customization ---\ntype WalletNameDisplayProps = {\n ensNameAbbreviated?: string;\n activeWallet: NonNullable<ReturnType<typeof useNovaConnect>['activeWallet']>;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype CopyButtonProps = {\n isCopied: boolean;\n onCopy: () => Promise<void>;\n activeWallet: NonNullable<ReturnType<typeof useNovaConnect>['activeWallet']>;\n labels: Record<string, string>;\n className?: string;\n disabled?: boolean;\n};\n\ntype BalanceDisplayProps = {\n balance?: ConnectedModalMainContentProps['balance'];\n balanceLoading: boolean;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype ScreenReaderFeedbackProps = {\n isCopied: boolean;\n activeWallet: NonNullable<ReturnType<typeof useNovaConnect>['activeWallet']>;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype LiveRegionProps = {\n balanceLoading: boolean;\n balance?: ConnectedModalMainContentProps['balance'];\n labels: Record<string, string>;\n className?: string;\n};\n\n/**\n * Customization options for ConnectedModalNameAndBalance component\n */\nexport type ConnectedModalNameAndBalanceCustomization = {\n /** Override root container props */\n containerProps?: Partial<\n Omit<\n ComponentPropsWithoutRef<'section'>,\n | 'popover'\n | 'onDrag'\n | 'onDragEnd'\n | 'onDragExit'\n | 'onDragStart'\n | 'onDragStartCapture'\n | 'onAnimationStart'\n | 'onAnimationEnd'\n | 'onAnimationStartCapture'\n | 'onAnimationEndCapture'\n | 'onAnimationIteration'\n | 'onAnimationIterationCapture'\n >\n >;\n /** Custom components */\n components?: {\n /** Custom wallet name display component */\n WalletNameDisplay?: ComponentType<WalletNameDisplayProps>;\n /** Custom copy button component */\n CopyButton?: ComponentType<CopyButtonProps>;\n /** Custom balance display component */\n BalanceDisplay?: ComponentType<BalanceDisplayProps>;\n /** Custom screen reader feedback component */\n ScreenReaderFeedback?: ComponentType<ScreenReaderFeedbackProps>;\n /** Custom live region component */\n LiveRegion?: ComponentType<LiveRegionProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: {\n hasActiveWallet: boolean;\n isCopied: boolean;\n balanceLoading: boolean;\n hasBalance: boolean;\n }) => string;\n /** Function to generate wallet name header container classes */\n walletNameHeaderContainer?: () => string;\n /** Function to generate wallet name display classes */\n walletNameDisplay?: (params: { ensNameAbbreviated?: string }) => string;\n /** Function to generate copy button classes */\n copyButton?: (params: { isCopied: boolean; disabled: boolean }) => string;\n /** Function to generate copy icon classes */\n copyIcon?: () => string;\n /** Function to generate check icon classes */\n checkIcon?: () => string;\n /** Function to generate balance container classes */\n balanceContainer?: () => string;\n /** Function to generate balance loading classes */\n balanceLoading?: () => string;\n /** Function to generate balance display classes */\n balanceDisplay?: () => string;\n /** Function to generate balance value classes */\n balanceValue?: () => string;\n /** Function to generate balance symbol classes */\n balanceSymbol?: () => string;\n /** Function to generate no balance classes */\n noBalance?: () => string;\n /** Function to generate screen reader feedback classes */\n screenReaderFeedback?: () => string;\n /** Function to generate live region classes */\n liveRegion?: () => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Container animation variants */\n container?: Variants;\n /** Copy icon animation variants */\n copyIcon?: Variants;\n /** Check icon animation variants */\n checkIcon?: Variants;\n /** Loading animation variants */\n loading?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Container animation configuration */\n container?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Icon animation configuration */\n icon?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Loading animation configuration */\n loading?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for copy success */\n onCopySuccess?: (address: string) => void;\n /** Custom handler for copy error */\n onCopyError?: (error: Error, address: string) => void;\n /** Custom handler for balance format */\n onBalanceFormat?: (balance: ConnectedModalMainContentProps['balance']) => string | null;\n /** Custom handler for keyboard interactions */\n onKeyboardInteraction?: (event: React.KeyboardEvent, action: 'copy') => void;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Custom copy button position */\n copyButtonPosition?: 'right' | 'left' | 'top' | 'bottom';\n /** Custom ARIA labels for different states */\n ariaLabels?: {\n container?: string;\n walletNameHeader?: string;\n walletNameDisplay?: string;\n copyButton?: string;\n balanceContainer?: string;\n balanceLoading?: string;\n balanceDisplay?: string;\n noBalance?: string;\n screenReaderFeedback?: string;\n liveRegion?: string;\n };\n };\n};\n\n/**\n * Props for the ConnectedModalNameAndBalance component\n */\nexport interface ConnectedModalNameAndBalanceProps\n extends Pick<ConnectedModalMainContentProps, 'balanceLoading' | 'ensNameAbbreviated' | 'balance'> {\n /** Additional CSS classes for the container */\n className?: string;\n /** Custom aria-label for the container */\n 'aria-label'?: string;\n /** Customization options */\n customization?: ConnectedModalNameAndBalanceCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultWalletNameDisplay: React.FC<WalletNameDisplayProps> = ({ ensNameAbbreviated, className }) => {\n return (\n <h3\n className={cn('novacon:text-xl novacon:font-bold', className)}\n role=\"heading\"\n aria-level={3}\n aria-label={`Wallet name: ${ensNameAbbreviated || 'Loading wallet name'}`}\n >\n {ensNameAbbreviated}\n </h3>\n );\n};\n\nconst DefaultCopyButton: React.FC<CopyButtonProps> = ({\n isCopied,\n onCopy,\n activeWallet,\n labels,\n className,\n disabled,\n}) => {\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent) => {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n void onCopy();\n }\n },\n [onCopy],\n );\n\n const getCopyButtonAriaLabel = useCallback(() => {\n const baseLabel = isCopied ? labels.copied : `Copy ${labels.walletAddress}`;\n const addressInfo = activeWallet?.address ? ` (${activeWallet.address})` : '';\n return `${baseLabel}${addressInfo}`;\n }, [isCopied, labels, activeWallet]);\n\n return (\n <button\n type=\"button\"\n onClick={() => void onCopy()}\n onKeyDown={handleKeyDown}\n className={cn(\n 'novacon:cursor-pointer novacon:flex novacon:items-center novacon:justify-center novacon:text-sm novacon:transition-all novacon:duration-200 novacon:absolute novacon:right-[-40px]',\n 'novacon:rounded-md novacon:p-1.5 novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-text-accent)] novacon:focus:ring-opacity-50',\n 'novacon:hover:scale-110 novacon:active:scale-95',\n isCopied\n ? [\n 'novacon:text-[var(--tuwa-success-text)]',\n 'novacon:hover:text-[var(--tuwa-success-text)]',\n 'novacon:bg-[var(--tuwa-success-text)] novacon:bg-opacity-10',\n ]\n : [\n 'novacon:text-[var(--tuwa-text-tertiary)]',\n 'novacon:hover:text-[var(--tuwa-text-primary)]',\n 'novacon:hover:bg-[var(--tuwa-bg-muted)]',\n ],\n className,\n )}\n aria-label={getCopyButtonAriaLabel()}\n aria-describedby=\"copy-feedback\"\n disabled={disabled}\n data-testid=\"copy-address-button\"\n >\n {/* Animated Icon Transition */}\n <AnimatePresence mode=\"wait\" initial={false}>\n {isCopied ? (\n <motion.div\n key=\"check-icon\"\n variants={DEFAULT_CHECK_ICON_ANIMATION_VARIANTS}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n >\n <CheckIcon className=\"novacon:w-5 novacon:h-5\" aria-hidden=\"true\" />\n </motion.div>\n ) : (\n <motion.div\n key=\"copy-icon\"\n variants={DEFAULT_COPY_ICON_ANIMATION_VARIANTS}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n >\n <DocumentDuplicateIcon className=\"novacon:w-5 novacon:h-5\" aria-hidden=\"true\" />\n </motion.div>\n )}\n </AnimatePresence>\n </button>\n );\n};\n\nconst DefaultBalanceDisplay: React.FC<BalanceDisplayProps> = ({ balance, balanceLoading, labels, className }) => {\n const balanceDisplay = useMemo(() => {\n if (!balance?.value || !balance?.symbol) return null;\n return `${balance.value} ${balance.symbol}`;\n }, [balance]);\n\n if (balanceLoading) {\n return (\n <motion.div\n variants={DEFAULT_LOADING_ANIMATION_VARIANTS}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n className={cn(\n 'novacon:animate-pulse novacon:rounded-xl novacon:h-5 novacon:w-24 novacon:bg-[var(--tuwa-bg-muted)]',\n className,\n )}\n role=\"status\"\n aria-label={labels.loading}\n >\n <span className=\"novacon:sr-only\">\n {labels.loading} {labels.walletBalance}\n </span>\n </motion.div>\n );\n }\n\n if (balanceDisplay) {\n return (\n <p\n className={cn(\n 'novacon:flex novacon:items-center novacon:gap-1 novacon:text-sm novacon:text-[var(--tuwa-text-tertiary)]',\n className,\n )}\n role=\"text\"\n aria-label={`${labels.walletBalance}: ${balanceDisplay}`}\n >\n <span aria-hidden=\"true\">{balance?.value}</span>\n <span aria-hidden=\"true\">{balance?.symbol}</span>\n\n {/* Screen reader friendly version */}\n <span className=\"novacon:sr-only\">\n {labels.walletBalance}: {balanceDisplay}\n </span>\n </p>\n );\n }\n\n return (\n <p\n className={cn('novacon:text-sm novacon:text-[var(--tuwa-text-tertiary)] novacon:opacity-75', className)}\n role=\"text\"\n aria-label=\"No balance information available\"\n >\n <span aria-hidden=\"true\">—</span>\n <span className=\"novacon:sr-only\">No balance information available</span>\n </p>\n );\n};\n\nconst DefaultScreenReaderFeedback: React.FC<ScreenReaderFeedbackProps> = ({\n isCopied,\n activeWallet,\n labels,\n className,\n}) => {\n return (\n <span id=\"copy-feedback\" className={cn('novacon:sr-only', className)} aria-live=\"polite\" role=\"status\">\n {isCopied ? `${labels.copied} ${activeWallet.address}` : ''}\n </span>\n );\n};\n\nconst DefaultLiveRegion: React.FC<LiveRegionProps> = ({ balanceLoading, balance, className }) => {\n const balanceDisplay = useMemo(() => {\n if (!balance?.value || !balance?.symbol) return null;\n return `${balance.value} ${balance.symbol}`;\n }, [balance]);\n\n return (\n <div className={cn('novacon:sr-only', className)} aria-live=\"polite\" aria-atomic=\"true\" role=\"status\">\n {/* This will announce balance updates to screen readers */}\n {!balanceLoading && balanceDisplay && `Balance updated: ${balanceDisplay}`}\n </div>\n );\n};\n\n/**\n * Component that displays wallet name/ENS and balance information with copy functionality and comprehensive customization options.\n *\n * This component provides a comprehensive display of wallet identification and balance:\n * - ENS name or abbreviated wallet address\n * - Animated copy button with visual feedback\n * - Loading states for balance information\n * - Proper accessibility support with ARIA labels\n * - Smooth animations for state transitions\n * - Comprehensive customization for all UI elements and behaviors\n * - Animation support with reduced motion options\n * - Custom event handlers for enhanced interactivity\n * - Performance-optimized with memoized calculations\n *\n * The component automatically handles wallet address copying with visual feedback\n * and provides screen reader friendly content throughout all interactions.\n *\n * @example Basic usage\n * ```tsx\n * <ConnectedModalNameAndBalance\n * ensNameAbbreviated=\"wallet.eth\"\n * balanceLoading={false}\n * balance={{ value: \"1.23\", symbol: \"ETH\" }}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectedModalNameAndBalance\n * ensNameAbbreviated=\"wallet.eth\"\n * balanceLoading={false}\n * balance={{ value: \"1.23\", symbol: \"ETH\" }}\n * customization={{\n * classNames: {\n * container: ({ hasActiveWallet }) =>\n * `custom-container ${hasActiveWallet ? 'has-wallet' : 'no-wallet'}`,\n * walletNameDisplay: () => \"text-2xl font-bold text-blue-600\",\n * copyButton: ({ isCopied }) =>\n * `copy-btn ${isCopied ? 'success' : 'default'}`,\n * },\n * components: {\n * WalletNameDisplay: ({ ensNameAbbreviated, className }) =>\n * <h2 className={className}>{ensNameAbbreviated}</h2>,\n * },\n * handlers: {\n * onCopySuccess: (address) => console.log(`Copied: ${address}`),\n * onCopyError: (error, address) =>\n * console.error(`Failed to copy ${address}:`, error),\n * },\n * config: {\n * copyButtonPosition: 'left',\n * ariaLabels: {\n * container: 'Wallet information section',\n * },\n * },\n * }}\n * />\n * ```\n */\nexport const ConnectedModalNameAndBalance = forwardRef<HTMLElement, ConnectedModalNameAndBalanceProps>(\n (\n { ensNameAbbreviated, balanceLoading, balance, className, 'aria-label': ariaLabel, customization, ...props },\n ref,\n ) => {\n const labels = useNovaConnectLabels();\n const { activeWallet } = useNovaConnect();\n const { copy, isCopied } = useCopyToClipboard();\n\n // Extract custom components and config\n const {\n WalletNameDisplay = DefaultWalletNameDisplay,\n CopyButton = DefaultCopyButton,\n BalanceDisplay = DefaultBalanceDisplay,\n ScreenReaderFeedback = DefaultScreenReaderFeedback,\n LiveRegion = DefaultLiveRegion,\n } = customization?.components ?? {};\n\n const { disableAnimation = false, reduceMotion = false, ariaLabels } = customization?.config ?? {};\n\n /**\n * Memoized calculations for state\n */\n const hasActiveWallet = useMemo(() => Boolean(activeWallet?.isConnected), [activeWallet?.isConnected]);\n const hasBalance = useMemo(() => Boolean(balance?.value && balance?.symbol), [balance]);\n\n /**\n * Handle copying wallet address with proper error handling and custom handlers\n */\n const handleCopyAddress = useCallback(async () => {\n if (!activeWallet?.address) {\n console.warn('No wallet address available to copy');\n return;\n }\n\n try {\n await copy(activeWallet.address);\n customization?.handlers?.onCopySuccess?.(activeWallet.address);\n } catch (error) {\n console.error('Failed to copy wallet address:', error);\n customization?.handlers?.onCopyError?.(error as Error, activeWallet.address);\n }\n }, [activeWallet?.address, copy, customization?.handlers]);\n\n /**\n * Generate container classes with custom generator\n */\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({\n hasActiveWallet,\n isCopied,\n balanceLoading,\n hasBalance,\n });\n }\n return cn(\n 'novacon:flex novacon:w-full novacon:flex-col novacon:items-center novacon:justify-start novacon:gap-2 novacon:min-h-[60px]',\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, hasActiveWallet, isCopied, balanceLoading, hasBalance, className]);\n\n /**\n * Animation variants\n */\n const containerVariants = customization?.variants?.container || DEFAULT_CONTAINER_ANIMATION_VARIANTS;\n\n /**\n * Merge container props\n */\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'region',\n 'aria-label':\n ariaLabel || ariaLabels?.container || `${labels.walletBalance} and ${labels.walletAddress} information`,\n }),\n [\n customization?.containerProps,\n props,\n ref,\n containerClasses,\n ariaLabel,\n ariaLabels?.container,\n labels.walletBalance,\n labels.walletAddress,\n ],\n );\n\n // Early return if no active wallet\n if (!hasActiveWallet || !activeWallet) {\n return null;\n }\n\n const content = (\n <>\n {/* Wallet Name/ENS and Copy Button */}\n <div\n className={cn(\n 'novacon:flex novacon:items-center novacon:gap-3 novacon:relative novacon:text-[var(--tuwa-text-primary)]',\n customization?.classNames?.walletNameHeaderContainer?.(),\n )}\n role=\"group\"\n aria-label={`${labels.walletAddress}: ${ensNameAbbreviated || 'Loading...'}`}\n >\n {/* Wallet Name/ENS Display */}\n <WalletNameDisplay\n ensNameAbbreviated={ensNameAbbreviated}\n activeWallet={activeWallet}\n labels={labels}\n className={customization?.classNames?.walletNameDisplay?.({ ensNameAbbreviated })}\n />\n\n {/* Copy Address Button */}\n <CopyButton\n isCopied={isCopied}\n onCopy={handleCopyAddress}\n activeWallet={activeWallet}\n labels={labels}\n className={customization?.classNames?.copyButton?.({\n isCopied,\n disabled: !activeWallet?.address,\n })}\n disabled={!activeWallet?.address}\n />\n\n {/* Screen Reader Only Feedback */}\n <ScreenReaderFeedback\n isCopied={isCopied}\n activeWallet={activeWallet}\n labels={labels}\n className={customization?.classNames?.screenReaderFeedback?.()}\n />\n </div>\n\n {/* Balance Information */}\n <div\n className={cn(\n 'novacon:flex novacon:items-center novacon:justify-center',\n customization?.classNames?.balanceContainer?.(),\n )}\n role=\"group\"\n aria-label={labels.walletBalance}\n >\n <BalanceDisplay\n balance={balance}\n balanceLoading={balanceLoading}\n labels={labels}\n className={customization?.classNames?.balanceDisplay?.()}\n />\n </div>\n\n {/* Hidden Live Region for Dynamic Updates */}\n <LiveRegion\n balanceLoading={balanceLoading}\n balance={balance}\n labels={labels}\n className={customization?.classNames?.liveRegion?.()}\n />\n </>\n );\n\n if (disableAnimation || reduceMotion) {\n return <section {...containerProps}>{content}</section>;\n }\n\n return (\n <motion.section\n {...containerProps}\n variants={containerVariants}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n transition={{\n duration: customization?.animation?.container?.duration ?? 0.3,\n ease: customization?.animation?.container?.ease ?? 'easeOut',\n delay: customization?.animation?.container?.delay ?? 0,\n }}\n >\n {content}\n </motion.section>\n );\n },\n);\n\nConnectedModalNameAndBalance.displayName = 'ConnectedModalNameAndBalance';\n","/**\n * @file This file contains the `WalletIcon` component, a customizable wallet icon renderer with fallback support.\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { cn } from '@tuwaio/nova-core';\nimport { formatWalletName } from '@tuwaio/orbit-core';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, useCallback, useMemo, useState } from 'react';\n\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\n\n// --- Types for Customization ---\ntype CustomLoadingOverlayProps = {\n size: number;\n isLoading: boolean;\n};\n\ntype CustomErrorIndicatorProps = {\n walletName: string;\n hasError: boolean;\n};\n\ntype CustomFallbackIconProps = {\n walletName: string;\n size: number;\n className?: string;\n};\n\n/**\n * Customization options for WalletIcon component\n */\nexport type WalletIconCustomization = {\n /** Override container element props */\n containerProps?: Partial<ComponentPropsWithoutRef<'div'>>;\n /** Override image element props */\n imageProps?: Partial<ComponentPropsWithoutRef<'img'>>;\n /** Custom components */\n components?: {\n /** Custom loading overlay component */\n LoadingOverlay?: ComponentType<CustomLoadingOverlayProps>;\n /** Custom error indicator component (only shown in development) */\n ErrorIndicator?: ComponentType<CustomErrorIndicatorProps>;\n /** Custom fallback icon component */\n FallbackIcon?: ComponentType<CustomFallbackIconProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { isLoading: boolean; showLoading: boolean; size: number }) => string;\n /** Function to generate image classes */\n image?: (params: { isLoading: boolean; showLoading: boolean; hasError: boolean }) => string;\n };\n};\n\nexport interface WalletIconProps extends Omit<ComponentPropsWithoutRef<'div'>, 'role'> {\n /** Custom icon URL for the wallet */\n icon?: string;\n /** Name of the wallet */\n name: string;\n /** Size of the icon in pixels */\n size?: number;\n /** Custom alt text for the icon */\n altText?: string;\n /** Whether to show loading state */\n showLoading?: boolean;\n /** Callback fired when image loads successfully */\n onImageLoad?: () => void;\n /** Callback fired when image fails to load */\n onImageError?: () => void;\n /** Enable lazy loading for non-critical images */\n lazy?: boolean;\n /** Customization options */\n customization?: WalletIconCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultLoadingOverlay = ({ isLoading }: CustomLoadingOverlayProps) => {\n if (!isLoading) return null;\n\n return (\n <div\n className=\"novacon:absolute novacon:inset-0 novacon:bg-[var(--tuwa-bg-muted)] novacon:animate-pulse novacon:rounded-full\"\n aria-hidden=\"true\"\n />\n );\n};\n\nconst DefaultErrorIndicator = ({ walletName, hasError }: CustomErrorIndicatorProps) => {\n if (!hasError || process.env.NODE_ENV !== 'development') return null;\n\n return (\n <div\n className=\"novacon:absolute novacon:top-0 novacon:right-0 novacon:w-2 novacon:h-2 novacon:bg-red-500 novacon:rounded-full\"\n title={`Failed to load icon for ${walletName}`}\n aria-hidden=\"true\"\n />\n );\n};\n\nconst DefaultFallbackIcon = ({ walletName, className }: CustomFallbackIconProps) => {\n return <Web3Icon walletKey={walletName} className={cn('novacon:flex-shrink-0', className)} />;\n};\n\n/**\n * A highly customizable wallet icon component with loading states, error handling, and fallback support.\n * Provides extensive customization options for container, image, and sub-components while maintaining accessibility.\n */\nexport const WalletIcon = forwardRef<HTMLDivElement, WalletIconProps>(\n (\n {\n icon,\n name,\n size = 32,\n className,\n altText,\n showLoading = false,\n onImageLoad,\n onImageError,\n lazy = false,\n customization,\n ...props\n },\n ref,\n ) => {\n const labels = useNovaConnectLabels();\n const [hasError, setHasError] = useState(false);\n const [isLoading, setIsLoading] = useState(Boolean(icon));\n\n // Extract custom components\n const {\n LoadingOverlay = DefaultLoadingOverlay,\n ErrorIndicator = DefaultErrorIndicator,\n FallbackIcon = DefaultFallbackIcon,\n } = customization?.components ?? {};\n\n // Format wallet name for consistency\n const walletName = useMemo(() => formatWalletName(name), [name]);\n\n // Generate alt text for accessibility\n const imageAltText = useMemo(() => {\n if (altText) return altText;\n return `${walletName} ${labels.walletIcon}`;\n }, [altText, walletName, labels.walletIcon]);\n\n // Clean and validate icon URL\n const cleanIconUrl = useMemo(() => {\n if (!icon) return null;\n\n try {\n const trimmedIcon = icon.trim();\n if (!trimmedIcon) return null;\n\n // Basic URL validation\n if (\n trimmedIcon.startsWith('http://') ||\n trimmedIcon.startsWith('https://') ||\n trimmedIcon.startsWith('/') ||\n trimmedIcon.startsWith('data:')\n ) {\n return trimmedIcon;\n }\n\n return null;\n } catch {\n return null;\n }\n }, [icon]);\n\n // Handle image load success\n const handleImageLoad = useCallback(() => {\n setIsLoading(false);\n setHasError(false);\n onImageLoad?.();\n }, [onImageLoad]);\n\n // Handle image load error\n const handleImageError = useCallback(() => {\n setIsLoading(false);\n setHasError(true);\n onImageError?.();\n }, [onImageError]);\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ isLoading, showLoading, size });\n }\n return cn(\n 'novacon:relative novacon:inline-flex novacon:items-center novacon:justify-center novacon:flex-shrink-0',\n 'novacon:overflow-hidden',\n {\n 'novacon:animate-pulse novacon:bg-[var(--tuwa-bg-muted)]': showLoading && isLoading,\n },\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, isLoading, showLoading, size, className]);\n\n // Generate image classes\n const imageClasses = useMemo(() => {\n if (customization?.classNames?.image) {\n return customization.classNames.image({ isLoading, showLoading, hasError });\n }\n\n return cn(\n 'novacon:object-cover novacon:transition-opacity novacon:duration-200',\n 'novacon:max-w-full novacon:max-h-full',\n 'novacon:opacity-100',\n {\n 'novacon:opacity-0': isLoading && showLoading,\n },\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.image, isLoading, showLoading, hasError]);\n\n // Image style object\n const imageStyle = useMemo(\n () => ({\n width: size,\n height: size,\n }),\n [size],\n );\n\n // Merge container props\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'img' as const,\n 'aria-label': imageAltText,\n title: imageAltText,\n style: { lineHeight: 0, ...customization?.containerProps?.style, ...props.style },\n }),\n [customization?.containerProps, props, ref, containerClasses, imageAltText],\n );\n\n // Merge image props\n const imageProps = useMemo(\n () => ({\n ...customization?.imageProps,\n src: cleanIconUrl!,\n alt: '', // Empty alt since parent div has role=\"img\" and aria-label\n className: cn(imageClasses, customization?.imageProps?.className),\n style: { ...imageStyle, ...customization?.imageProps?.style },\n onLoad: handleImageLoad,\n onError: handleImageError,\n loading: (lazy ? 'lazy' : 'eager') as 'lazy' | 'eager',\n decoding: 'async' as const,\n crossOrigin: 'anonymous' as const,\n referrerPolicy: 'no-referrer' as const,\n }),\n [customization?.imageProps, cleanIconUrl, imageClasses, imageStyle, handleImageLoad, handleImageError, lazy],\n );\n\n return (\n <div {...containerProps}>\n {/* Loading overlay */}\n <LoadingOverlay size={size} isLoading={showLoading && isLoading} />\n\n {/* Custom icon with error fallback */}\n {cleanIconUrl && !hasError ? (\n <img {...imageProps} />\n ) : (\n <FallbackIcon walletName={walletName} size={size} className={imageClasses} />\n )}\n\n {/* Error state indicator */}\n <ErrorIndicator walletName={walletName} hasError={hasError} />\n </div>\n );\n },\n);\n\nWalletIcon.displayName = 'WalletIcon';\n","/**\n * @file IconButton component with comprehensive customization options for wallet and chain interactions.\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { ChevronArrowWithAnim, cn } from '@tuwaio/nova-core';\nimport { OrbitAdapter } from '@tuwaio/orbit-core';\nimport { type Easing, motion, type Variants } from 'framer-motion';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useCallback, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { WalletIcon, type WalletIconCustomization } from '../WalletIcon';\n\n// --- Default Motion Variants ---\nconst DEFAULT_BUTTON_ANIMATION_VARIANTS: Variants = {\n idle: { scale: 1, rotate: 0 },\n hover: { scale: 1.05, transition: { duration: 0.2 } },\n tap: { scale: 0.95, transition: { duration: 0.1 } },\n loading: { rotate: 360, transition: { duration: 2, repeat: Infinity, ease: 'linear' } },\n};\n\n// --- Types for Customization ---\ntype CustomWalletIconContainerProps = {\n walletName?: string;\n walletIcon?: string;\n showLoading: boolean;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype CustomChainIconContainerProps = {\n chainId: string | number;\n walletChainId?: string | number;\n className?: string;\n};\n\ntype CustomChevronContainerProps = {\n isOpen: boolean;\n className?: string;\n};\n\ntype CustomLoadingOverlayProps = {\n loading: boolean;\n className?: string;\n};\n\ntype CustomButtonContentProps = {\n walletIconContainer: ReactNode;\n chainIconContainer: ReactNode;\n chevronContainer: ReactNode;\n loadingOverlay: ReactNode;\n hasWalletIcon: boolean;\n hasChainIcon: boolean;\n hasChevron: boolean;\n loading: boolean;\n disabled: boolean;\n isClickable: boolean;\n};\n\n/**\n * Customization options for IconButton component\n */\nexport type IconButtonCustomization = {\n /** Override button element props */\n buttonProps?: Partial<\n Omit<\n ComponentPropsWithoutRef<'button'>,\n | 'popover'\n | 'onDrag'\n | 'onDragEnd'\n | 'onDragExit'\n | 'onDragStart'\n | 'onDragStartCapture'\n | 'onAnimationStart'\n | 'onAnimationEnd'\n | 'onAnimationStartCapture'\n | 'onAnimationEndCapture'\n | 'onAnimationIteration'\n | 'onAnimationIterationCapture'\n >\n >;\n /** Custom components */\n components?: {\n /** Custom wallet icon container component */\n WalletIconContainer?: ComponentType<CustomWalletIconContainerProps>;\n /** Custom chain icon container component */\n ChainIconContainer?: ComponentType<CustomChainIconContainerProps>;\n /** Custom chevron container component */\n ChevronContainer?: ComponentType<CustomChevronContainerProps>;\n /** Custom loading overlay component */\n LoadingOverlay?: ComponentType<CustomLoadingOverlayProps>;\n /** Custom button content wrapper component */\n ButtonContent?: ComponentType<CustomButtonContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate button classes */\n button?: (params: {\n isClickable: boolean;\n disabled: boolean;\n loading: boolean;\n hasMultipleIcons: boolean;\n }) => string;\n /** Function to generate wallet icon container classes */\n walletIconContainer?: (params: { showLoading: boolean; hasWalletIcon: boolean }) => string;\n /** Function to generate chain icon container classes */\n chainIconContainer?: (params: { hasChainIcon: boolean }) => string;\n /** Function to generate chevron container classes */\n chevronContainer?: (params: { isOpen: boolean; isClickable: boolean }) => string;\n /** Function to generate loading overlay classes */\n loadingOverlay?: (params: { loading: boolean }) => string;\n /** Function to generate loading spinner classes */\n loadingSpinner?: () => string;\n };\n /** Customization options for child components */\n childCustomizations?: {\n /** WalletIcon customization */\n walletIcon?: WalletIconCustomization;\n };\n /** Custom animation variants */\n variants?: {\n /** Button animation variants */\n button?: Variants;\n /** Chevron animation variants */\n chevron?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Button animation configuration */\n button?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Chevron animation configuration */\n chevron?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for button click */\n onClick?: (originalHandler: () => void, event: React.MouseEvent<HTMLButtonElement>) => void;\n /** Custom handler for button hover */\n onHover?: (isHovering: boolean, event: React.MouseEvent<HTMLButtonElement>) => void;\n /** Custom handler for button focus */\n onFocus?: (event: React.FocusEvent<HTMLButtonElement>) => void;\n /** Custom handler for button blur */\n onBlur?: (event: React.FocusEvent<HTMLButtonElement>) => void;\n };\n /** Custom aria labels and accessibility */\n accessibility?: {\n /** Custom aria-label generator */\n ariaLabel?: (params: {\n walletName?: string;\n walletChainId?: string | number;\n isClickable: boolean;\n loading: boolean;\n disabled: boolean;\n }) => string;\n /** Custom tooltip generator */\n tooltip?: (params: {\n walletName?: string;\n walletChainId?: string | number;\n isClickable: boolean;\n loading: boolean;\n disabled: boolean;\n }) => string;\n /** Custom role attribute */\n role?: string;\n /** Custom aria-describedby */\n ariaDescribedBy?: string;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Custom chain ID formatting */\n chainIdFormatter?: (chainId: string | number) => string | number;\n /** Whether to show wallet icon */\n showWalletIcon?: boolean;\n /** Whether to show chain icon */\n showChainIcon?: boolean;\n /** Whether to show chevron */\n showChevron?: boolean;\n /** Whether to show loading overlay */\n showLoadingOverlay?: boolean;\n /** Custom button test id */\n buttonTestId?: string;\n };\n};\n\n/**\n * Props for the IconButton component\n */\nexport interface IconButtonProps {\n /** Custom icon URL for the wallet */\n walletIcon?: string;\n /** Name of the wallet */\n walletName?: string;\n /** Chain ID for the network icon */\n walletChainId?: string | number;\n /** Number of available items/options (shows chevron if > 1) */\n items?: number;\n /** Click handler for the button */\n onClick?: () => void;\n /** Additional CSS classes for styling */\n className?: string;\n /** Whether the button is currently disabled */\n disabled?: boolean;\n /** Whether to show loading state */\n loading?: boolean;\n /** Custom aria-label for accessibility */\n 'aria-label'?: string;\n /** Custom tooltip text */\n title?: string;\n /** Whether chevron should show as open */\n isOpen?: boolean;\n /** Custom button id */\n id?: string;\n /** Customization options */\n customization?: IconButtonCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultWalletIconContainer: React.FC<CustomWalletIconContainerProps> = ({\n walletName,\n walletIcon,\n showLoading,\n labels,\n className,\n}) => {\n if (!walletName) return null;\n\n return (\n <div className={cn('novacon:flex-shrink-0 novacon:leading-[0]', className)}>\n <WalletIcon\n name={walletName}\n icon={walletIcon}\n altText={`${walletName} ${labels.walletIcon}`}\n showLoading={showLoading}\n />\n </div>\n );\n};\n\nconst DefaultChainIconContainer: React.FC<CustomChainIconContainerProps> = ({ chainId, walletChainId, className }) => {\n return (\n <div className={cn('novacon:flex-shrink-0 novacon:leading-[0]', className)}>\n <Web3Icon chainId={chainId} title={`Network: ${walletChainId}`} className=\"novacon:w-6 novacon:h-6\" />\n </div>\n );\n};\n\nconst DefaultChevronContainer: React.FC<CustomChevronContainerProps> = ({ isOpen, className }) => {\n return (\n <div className={cn('novacon:flex-shrink-0 novacon:leading-[0]', className)}>\n <ChevronArrowWithAnim isOpen={isOpen} className=\"novacon:w-4 novacon:h-4\" aria-hidden=\"true\" />\n </div>\n );\n};\n\nconst DefaultLoadingOverlay: React.FC<CustomLoadingOverlayProps> = ({ loading, className }) => {\n if (!loading) return null;\n\n return (\n <div\n className={cn(\n 'novacon:absolute novacon:inset-0 novacon:bg-[var(--tuwa-bg-primary)]/50 novacon:rounded-full novacon:flex novacon:items-center novacon:justify-center',\n className,\n )}\n aria-hidden=\"true\"\n >\n <div className=\"novacon:w-3 novacon:h-3 novacon:border-2 novacon:border-[var(--tuwa-text-accent)] novacon:border-t-transparent novacon:rounded-full novacon:animate-spin\" />\n </div>\n );\n};\n\nconst DefaultButtonContent: React.FC<CustomButtonContentProps> = ({\n walletIconContainer,\n chainIconContainer,\n chevronContainer,\n loadingOverlay,\n}) => {\n return (\n <>\n {walletIconContainer}\n {chainIconContainer}\n {chevronContainer}\n {loadingOverlay}\n </>\n );\n};\n\n/**\n * Multi-purpose icon button component for wallets and chains with comprehensive customization.\n *\n * This component provides a unified interface for displaying wallet and chain information:\n * - Displays wallet icon with fallback to Web3Icon\n * - Shows chain/network icon when chain ID is provided\n * - Conditional chevron arrow for dropdown indicators\n * - Full WCAG accessibility support with proper ARIA labels\n * - Loading and disabled states with visual feedback\n * - Hover, active, and focus animations\n * - Comprehensive customization for all UI elements and behaviors\n * - Responsive design with consistent sizing\n * - Custom event handlers for enhanced interactivity\n * - Animation customization with reduced motion support\n * - Performance-optimized with memoized calculations\n *\n * The button automatically becomes interactive when onClick is provided and items > 1.\n * It supports both EVM chain IDs (numbers) and Solana network identifiers (strings).\n *\n * @example Basic usage\n * ```tsx\n * <IconButton\n * walletName=\"MetaMask\"\n * walletIcon=\"https://example.com/metamask-icon.png\"\n * />\n * ```\n *\n * @example Interactive chain selector with customization\n * ```tsx\n * <IconButton\n * walletName=\"Phantom\"\n * walletChainId=\"mainnet-beta\"\n * items={3}\n * onClick={handleChainSelect}\n * isOpen={isDropdownOpen}\n * customization={{\n * classNames: {\n * button: ({ isClickable }) =>\n * `custom-button ${isClickable ? 'clickable' : 'static'}`,\n * chevronContainer: ({ isOpen }) =>\n * `custom-chevron ${isOpen ? 'open' : 'closed'}`,\n * },\n * handlers: {\n * onClick: (originalHandler, event) => {\n * console.log(\"Button clicked\");\n * originalHandler();\n * },\n * onHover: (isHovering) => {\n * setTooltipVisible(isHovering);\n * },\n * },\n * animation: {\n * button: { duration: 0.3, ease: \"easeOut\" },\n * chevron: { duration: 0.2 },\n * },\n * config: {\n * showLoadingOverlay: true,\n * reduceMotion: false,\n * },\n * }}\n * />\n * ```\n */\nexport const IconButton = forwardRef<Omit<HTMLButtonElement, 'style'>, IconButtonProps>(\n (\n {\n walletIcon,\n walletName,\n walletChainId,\n items = 0,\n onClick,\n className,\n disabled = false,\n loading = false,\n 'aria-label': ariaLabel,\n title,\n isOpen = false,\n id,\n customization,\n },\n ref,\n ) => {\n const labels = useNovaConnectLabels();\n\n // Extract custom components and config\n const {\n WalletIconContainer = DefaultWalletIconContainer,\n ChainIconContainer = DefaultChainIconContainer,\n ChevronContainer = DefaultChevronContainer,\n LoadingOverlay = DefaultLoadingOverlay,\n ButtonContent = DefaultButtonContent,\n } = customization?.components ?? {};\n\n const {\n showWalletIcon = true,\n showChainIcon = true,\n showChevron = true,\n showLoadingOverlay = true,\n buttonTestId = 'icon-button',\n chainIdFormatter,\n disableAnimation = false,\n reduceMotion = false,\n } = customization?.config ?? {};\n\n /**\n * Determine if the button should be interactive\n */\n const isClickable = useMemo(\n () => Boolean(onClick && !disabled && !loading && items > 1),\n [onClick, disabled, loading, items],\n );\n\n /**\n * Generate chain ID for Web3Icon with custom formatting\n */\n const formattedChainId = useMemo(() => {\n if (!walletChainId) return undefined;\n\n if (chainIdFormatter) {\n return chainIdFormatter(walletChainId);\n }\n\n // If it's a string, assume it's a Solana network identifier\n if (typeof walletChainId === 'string') {\n return `${OrbitAdapter.SOLANA}:${walletChainId}`;\n }\n\n // If it's a number, use it directly as EVM chain ID\n return walletChainId;\n }, [walletChainId, chainIdFormatter]);\n\n /**\n * Check which icons are present\n */\n const hasWalletIcon = Boolean(walletName && showWalletIcon);\n const hasChainIcon = Boolean(formattedChainId && showChainIcon);\n const hasChevron = Boolean(isClickable && showChevron);\n const hasMultipleIcons = [hasWalletIcon, hasChainIcon, hasChevron].filter(Boolean).length > 1;\n\n /**\n * Generate accessible label with custom generator\n */\n const accessibleLabel = useMemo(() => {\n const customAriaLabel = customization?.accessibility?.ariaLabel;\n if (customAriaLabel) {\n return customAriaLabel({\n walletName,\n walletChainId,\n isClickable,\n loading,\n disabled,\n });\n }\n\n if (ariaLabel) return ariaLabel;\n\n const parts: string[] = [];\n\n if (walletName) parts.push(`${walletName} wallet`);\n if (walletChainId) parts.push('network selector');\n if (isClickable) parts.push('button');\n if (loading) parts.push('loading');\n if (disabled) parts.push('disabled');\n\n return parts.join(', ') || 'Wallet controls';\n }, [customization?.accessibility?.ariaLabel, ariaLabel, walletName, walletChainId, isClickable, loading, disabled]);\n\n /**\n * Generate tooltip text with custom generator\n */\n const tooltipText = useMemo(() => {\n const customTooltip = customization?.accessibility?.tooltip;\n if (customTooltip) {\n return customTooltip({\n walletName,\n walletChainId,\n isClickable,\n loading,\n disabled,\n });\n }\n\n if (title) return title;\n if (loading) return 'Loading...';\n if (disabled) return 'Button is disabled';\n if (isClickable) return `Click to select ${walletName ? walletName + ' ' : ''}options`;\n return walletName ? `${walletName} wallet` : 'Wallet information';\n }, [customization?.accessibility?.tooltip, title, loading, disabled, isClickable, walletName, walletChainId]);\n\n /**\n * Generate button classes with custom generator\n */\n const buttonClasses = useMemo(() => {\n const customButtonClasses = customization?.classNames?.button;\n if (customButtonClasses) {\n return customButtonClasses({\n isClickable,\n disabled,\n loading,\n hasMultipleIcons,\n });\n }\n\n return cn(\n // Base styles\n 'novacon:flex novacon:items-center novacon:justify-center novacon:gap-1 novacon:rounded-full novacon:leading-[0]',\n 'novacon:bg-[var(--tuwa-bg-primary)] novacon:border novacon:border-[var(--tuwa-border-primary)]',\n 'novacon:p-1.5 novacon:transition-all novacon:duration-200 novacon:relative',\n\n // Icon sizing\n 'novacon:[&_img]:w-6! novacon:[&_img]:h-6! novacon:[&_img]:transition-transform novacon:[&_img]:duration-200',\n\n // Interactive states\n {\n 'novacon:cursor-pointer novacon:hover:[&_img]:scale-95 novacon:active:[&_img]:scale-85 novacon:hover:shadow-sm':\n isClickable,\n 'novacon:cursor-not-allowed novacon:opacity-50': disabled && !loading,\n 'novacon:cursor-wait novacon:opacity-75': loading,\n 'novacon:cursor-default': !isClickable && !disabled && !loading,\n },\n\n // Focus states for accessibility\n 'novacon:focus-visible:outline-none novacon:focus-visible:ring-2 novacon:focus-visible:ring-[var(--tuwa-border-accent)] novacon:focus-visible:ring-offset-2',\n\n className,\n );\n }, [customization?.classNames?.button, isClickable, disabled, loading, hasMultipleIcons, className]);\n\n /**\n * Event handlers with customization support\n */\n const handleClick = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n if (isClickable && onClick) {\n const originalHandler = () => onClick();\n\n const customClickHandler = customization?.handlers?.onClick;\n if (customClickHandler) {\n customClickHandler(originalHandler, event);\n } else {\n originalHandler();\n }\n }\n },\n [isClickable, onClick, customization?.handlers?.onClick],\n );\n\n const handleMouseEnter = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n const customHoverHandler = customization?.handlers?.onHover;\n if (customHoverHandler) {\n customHoverHandler(true, event);\n }\n },\n [customization?.handlers?.onHover],\n );\n\n const handleMouseLeave = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n const customHoverHandler = customization?.handlers?.onHover;\n if (customHoverHandler) {\n customHoverHandler(false, event);\n }\n },\n [customization?.handlers?.onHover],\n );\n\n const handleFocus = useCallback(\n (event: React.FocusEvent<HTMLButtonElement>) => {\n const customFocusHandler = customization?.handlers?.onFocus;\n if (customFocusHandler) {\n customFocusHandler(event);\n }\n },\n [customization?.handlers?.onFocus],\n );\n\n const handleBlur = useCallback(\n (event: React.FocusEvent<HTMLButtonElement>) => {\n const customBlurHandler = customization?.handlers?.onBlur;\n if (customBlurHandler) {\n customBlurHandler(event);\n }\n },\n [customization?.handlers?.onBlur],\n );\n\n /**\n * Generate child components\n */\n const walletIconContainer = useMemo(() => {\n if (!hasWalletIcon) return null;\n\n const walletIconCustomClasses = customization?.classNames?.walletIconContainer;\n\n return (\n <WalletIconContainer\n walletName={walletName}\n walletIcon={walletIcon}\n showLoading={loading}\n labels={labels}\n className={walletIconCustomClasses?.({\n showLoading: loading,\n hasWalletIcon,\n })}\n />\n );\n }, [\n hasWalletIcon,\n WalletIconContainer,\n walletName,\n walletIcon,\n loading,\n labels,\n customization?.classNames?.walletIconContainer,\n ]);\n\n const chainIconContainer = useMemo(() => {\n if (!hasChainIcon || !formattedChainId) return null;\n\n const chainIconCustomClasses = customization?.classNames?.chainIconContainer;\n\n return (\n <ChainIconContainer\n chainId={formattedChainId}\n walletChainId={walletChainId}\n className={chainIconCustomClasses?.({ hasChainIcon })}\n />\n );\n }, [\n hasChainIcon,\n formattedChainId,\n ChainIconContainer,\n walletChainId,\n customization?.classNames?.chainIconContainer,\n ]);\n\n const chevronContainer = useMemo(() => {\n if (!hasChevron) return null;\n const chevronCustomClasses = customization?.classNames?.chevronContainer;\n return <ChevronContainer isOpen={isOpen} className={chevronCustomClasses?.({ isOpen, isClickable })} />;\n }, [hasChevron, ChevronContainer, isOpen, isClickable, customization?.classNames?.chevronContainer]);\n\n const loadingOverlay = useMemo(() => {\n if (!showLoadingOverlay) return null;\n const loadingCustomClasses = customization?.classNames?.loadingOverlay;\n return <LoadingOverlay loading={loading} className={loadingCustomClasses?.({ loading })} />;\n }, [showLoadingOverlay, LoadingOverlay, loading, customization?.classNames?.loadingOverlay]);\n\n /**\n * Animation variants\n */\n const buttonVariants = customization?.variants?.button || DEFAULT_BUTTON_ANIMATION_VARIANTS;\n\n /**\n * Base button props without motion-specific properties\n */\n const baseButtonProps = useMemo(\n () => ({\n type: 'button' as const,\n id,\n className: buttonClasses,\n onClick: handleClick,\n onMouseEnter: handleMouseEnter,\n onMouseLeave: handleMouseLeave,\n onFocus: handleFocus,\n onBlur: handleBlur,\n disabled: disabled || loading,\n 'aria-label': accessibleLabel,\n 'aria-describedby': customization?.accessibility?.ariaDescribedBy,\n title: tooltipText,\n role: customization?.accessibility?.role || 'button',\n tabIndex: disabled || loading ? -1 : 0,\n 'data-testid': buttonTestId,\n ...customization?.buttonProps,\n }),\n [\n id,\n buttonClasses,\n handleClick,\n handleMouseEnter,\n handleMouseLeave,\n handleFocus,\n handleBlur,\n disabled,\n loading,\n accessibleLabel,\n customization?.accessibility?.ariaDescribedBy,\n tooltipText,\n customization?.accessibility?.role,\n buttonTestId,\n customization?.buttonProps,\n ],\n );\n\n const buttonContent = (\n <ButtonContent\n walletIconContainer={walletIconContainer}\n chainIconContainer={chainIconContainer}\n chevronContainer={chevronContainer}\n loadingOverlay={loadingOverlay}\n hasWalletIcon={hasWalletIcon}\n hasChainIcon={hasChainIcon}\n hasChevron={hasChevron}\n loading={loading}\n disabled={disabled}\n isClickable={isClickable}\n />\n );\n\n if (disableAnimation || reduceMotion) {\n return (\n <button ref={ref as React.ForwardedRef<HTMLButtonElement>} {...baseButtonProps}>\n {buttonContent}\n </button>\n );\n }\n\n return (\n <motion.button\n ref={ref as React.ForwardedRef<HTMLButtonElement>}\n {...baseButtonProps}\n variants={buttonVariants}\n initial=\"idle\"\n whileHover={isClickable ? 'hover' : 'idle'}\n whileTap={isClickable ? 'tap' : 'idle'}\n animate={loading ? 'loading' : 'idle'}\n transition={{\n duration: customization?.animation?.button?.duration ?? 0.2,\n ease: customization?.animation?.button?.ease ?? 'easeInOut',\n delay: customization?.animation?.button?.delay ?? 0,\n }}\n >\n {buttonContent}\n </motion.button>\n );\n },\n);\n\nIconButton.displayName = 'IconButton';\n","/**\n * @file ConnectedModalMainContent component with comprehensive customization options for all child components.\n */\n\nimport { cn, standardButtonClasses } from '@tuwaio/nova-core';\nimport { getAdapterFromWalletType } from '@tuwaio/orbit-core';\nimport { Transaction } from '@tuwaio/pulsar-core';\nimport { AnimatePresence, type Easing, motion, type Variants } from 'framer-motion';\nimport React, { ComponentPropsWithoutRef, ComponentType, forwardRef, useCallback, useMemo } from 'react';\n\nimport { NativeBalanceResult } from '../../hooks';\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\nimport { WalletAvatar, WalletAvatarProps } from '../WalletAvatar';\nimport {\n ConnectedModalNameAndBalance,\n ConnectedModalNameAndBalanceCustomization,\n ConnectedModalNameAndBalanceProps,\n} from './ConnectedModalNameAndBalance';\nimport { IconButton, IconButtonProps } from './IconButton';\n\n// --- Default Motion Variants ---\nconst DEFAULT_CONTAINER_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, scale: 0.95, y: 20 },\n animate: {\n opacity: 1,\n scale: 1,\n y: 0,\n transition: { duration: 0.4, ease: 'easeOut', staggerChildren: 0.1 },\n },\n exit: {\n opacity: 0,\n scale: 0.95,\n y: -20,\n transition: { duration: 0.3, ease: 'easeIn' },\n },\n};\n\nconst DEFAULT_LOADING_ANIMATION_VARIANTS: Variants = {\n initial: { scale: 0.6, opacity: 0 },\n animate: { scale: 1, opacity: 1, transition: { duration: 0.4 } },\n exit: { scale: 0.6, opacity: 0, transition: { duration: 0.3 } },\n};\n\nconst DEFAULT_AVATAR_SECTION_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, y: 10 },\n animate: { opacity: 1, y: 0, transition: { duration: 0.3, delay: 0.1 } },\n exit: { opacity: 0, y: -10, transition: { duration: 0.2 } },\n};\n\nconst DEFAULT_INFO_SECTION_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, y: 10 },\n animate: { opacity: 1, y: 0, transition: { duration: 0.3, delay: 0.2 } },\n exit: { opacity: 0, y: -10, transition: { duration: 0.2 } },\n};\n\nconst DEFAULT_TRANSACTIONS_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, y: 10 },\n animate: { opacity: 1, y: 0, transition: { duration: 0.3, delay: 0.3 } },\n exit: { opacity: 0, y: -10, transition: { duration: 0.2 } },\n};\n\n// --- Types for Customization ---\ntype LoadingIndicatorProps = {\n isLoading: boolean;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype AvatarSectionProps = {\n activeWallet: NonNullable<ReturnType<typeof useNovaConnect>['activeWallet']>;\n ensAvatar: string | null;\n walletName: string;\n connectorsCount: number;\n chainsList: (string | number)[];\n labels: Record<string, string>;\n onSwitchWallet: () => void;\n onSwitchNetwork: () => void;\n className?: string;\n};\n\ntype InfoSectionProps = {\n balanceLoading: boolean;\n balance: NativeBalanceResult | null;\n ensNameAbbreviated: string | undefined;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype TransactionsSectionProps = {\n walletTransactions: Transaction[];\n hasPendingTransactions: boolean;\n labels: Record<string, string>;\n onViewTransactions: () => void;\n showPendingIndicators?: boolean;\n className?: string;\n};\n\ntype NoTransactionsIndicatorProps = {\n className?: string;\n};\n\n/**\n * Customization options for ConnectedModalMainContent component\n */\nexport type ConnectedModalMainContentCustomization = {\n /** Override root container props */\n containerProps?: Partial<\n Omit<\n ComponentPropsWithoutRef<'div'>,\n | 'popover'\n | 'onDrag'\n | 'onDragEnd'\n | 'onDragExit'\n | 'onDragStart'\n | 'onDragStartCapture'\n | 'onAnimationStart'\n | 'onAnimationEnd'\n | 'onAnimationStartCapture'\n | 'onAnimationEndCapture'\n | 'onAnimationIteration'\n | 'onAnimationIterationCapture'\n >\n >;\n /** Custom components */\n components?: {\n /** Custom loading indicator component */\n LoadingIndicator?: ComponentType<LoadingIndicatorProps>;\n /** Custom avatar section component */\n AvatarSection?: ComponentType<AvatarSectionProps>;\n /** Custom wallet avatar component */\n WalletAvatar?: ComponentType<WalletAvatarProps>;\n /** Custom switch wallet icon button component */\n SwitchWalletButton?: ComponentType<IconButtonProps>;\n /** Custom switch network icon button component */\n SwitchNetworkButton?: ComponentType<IconButtonProps>;\n /** Custom info section component */\n InfoSection?: ComponentType<InfoSectionProps>;\n /** Custom name and balance component */\n NameAndBalance?: ComponentType<ConnectedModalNameAndBalanceProps>;\n /** Custom transactions section component */\n TransactionsSection?: ComponentType<TransactionsSectionProps>;\n /** Custom no transactions indicator component */\n NoTransactionsIndicator?: ComponentType<NoTransactionsIndicatorProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: {\n hasActiveWallet: boolean;\n isLoading: boolean;\n hasTransactions: boolean;\n hasPendingTransactions: boolean;\n }) => string;\n /** Function to generate loading indicator classes */\n loadingIndicator?: (params: { isLoading: boolean }) => string;\n /** Function to generate loading spinner classes */\n loadingSpinner?: () => string;\n /** Function to generate avatar section classes */\n avatarSection?: () => string;\n /** Function to generate wallet avatar classes */\n walletAvatar?: (params: { ensAvatar: string | null }) => string;\n /** Function to generate switch wallet button classes */\n switchWalletButton?: (params: { connectorsCount: number }) => string;\n /** Function to generate switch network button classes */\n switchNetworkButton?: (params: { chainsCount: number }) => string;\n /** Function to generate info section classes */\n infoSection?: () => string;\n /** Function to generate transactions section classes */\n transactionsSection?: (params: { transactionsCount: number; hasPendingTransactions: boolean }) => string;\n /** Function to generate transactions button classes */\n transactionsButton?: () => string;\n /** Function to generate pending indicator classes */\n pendingIndicator?: () => string;\n /** Function to generate pending spinner classes */\n pendingSpinner?: () => string;\n /** Function to generate no transactions classes */\n noTransactions?: () => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Container animation variants */\n container?: Variants;\n /** Loading animation variants */\n loading?: Variants;\n /** Avatar section animation variants */\n avatarSection?: Variants;\n /** Info section animation variants */\n infoSection?: Variants;\n /** Transactions animation variants */\n transactions?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Container animation configuration */\n container?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n /** Children stagger delay */\n staggerChildren?: number;\n };\n /** Loading animation configuration */\n loading?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Sections animation configuration */\n sections?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for wallet switch */\n onSwitchWallet?: () => void;\n /** Custom handler for network switch */\n onSwitchNetwork?: () => void;\n /** Custom handler for view transactions */\n onViewTransactions?: () => void;\n /** Custom handler for loading state changes */\n onLoadingStateChange?: (isLoading: boolean) => void;\n /** Custom handler for transaction updates */\n onTransactionsUpdate?: (transactions: Transaction[], pendingCount: number) => void;\n };\n /** Child component customizations */\n childCustomizations?: {\n /** Customization for ConnectedModalNameAndBalance component */\n nameAndBalance?: ConnectedModalNameAndBalanceCustomization;\n /** Customization for WalletAvatar component */\n walletAvatar?: Partial<WalletAvatarProps>;\n /** Customization for switch wallet IconButton */\n switchWalletButton?: Partial<IconButtonProps>;\n /** Customization for switch network IconButton */\n switchNetworkButton?: Partial<IconButtonProps>;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Whether to show loading indicators */\n showLoadingIndicators?: boolean;\n /** Whether to show pending transaction indicators */\n showPendingIndicators?: boolean;\n /** Custom ARIA labels for different states */\n ariaLabels?: {\n container?: string;\n loadingIndicator?: string;\n avatarSection?: string;\n infoSection?: string;\n transactionsSection?: string;\n noTransactions?: string;\n };\n };\n};\n\n/**\n * Props for the ConnectedModalMainContent component\n */\nexport interface ConnectedModalMainContentProps extends Pick<ConnectButtonProps, 'transactionPool' | 'store'> {\n /** List of available chains for the current wallet */\n chainsList: (string | number)[];\n ensAvatar: string | null;\n avatarIsLoading: boolean;\n balanceLoading: boolean;\n ensNameAbbreviated: string | undefined;\n balance: NativeBalanceResult | null;\n /** Additional CSS classes for the container */\n className?: string;\n /** Custom aria-label for the container */\n 'aria-label'?: string;\n /** Customization options */\n customization?: ConnectedModalMainContentCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultLoadingIndicator: React.FC<LoadingIndicatorProps> = ({ isLoading, labels, className }) => {\n if (!isLoading) return null;\n\n return (\n <motion.div\n variants={DEFAULT_LOADING_ANIMATION_VARIANTS}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n className={cn('novacon:absolute novacon:right-5 novacon:top-2 novacon:w-5 novacon:h-5', className)}\n role=\"status\"\n aria-label={labels.loading}\n >\n <div className=\"Toastify__spinner\" aria-hidden=\"true\" />\n <span className=\"novacon:sr-only\">{labels.loading}</span>\n </motion.div>\n );\n};\n\nconst DefaultAvatarSection: React.FC<AvatarSectionProps> = ({\n activeWallet,\n ensAvatar,\n walletName,\n connectorsCount,\n chainsList,\n labels,\n onSwitchWallet,\n onSwitchNetwork,\n className,\n}) => {\n return (\n <motion.div\n variants={DEFAULT_AVATAR_SECTION_ANIMATION_VARIANTS}\n className={cn('novacon:mb-6 novacon:relative', className)}\n role=\"group\"\n aria-label={labels.walletControls}\n >\n {/* Wallet Switch Button */}\n <IconButton\n className=\"novacon:absolute novacon:z-[11] novacon:bottom-[-10px] novacon:left-[-10px]\"\n walletIcon={activeWallet.walletIcon}\n walletName={walletName}\n items={connectorsCount}\n onClick={onSwitchWallet}\n aria-label={`${labels.connectWallet} - ${connectorsCount} ${labels.connectWallet.toLowerCase()} available`}\n data-testid=\"switch-wallet-button\"\n />\n\n {/* Network Switch Button */}\n <IconButton\n className=\"novacon:absolute novacon:z-[11] novacon:bottom-[-10px] novacon:right-[-10px]\"\n walletChainId={activeWallet.chainId}\n items={chainsList.length}\n onClick={onSwitchNetwork}\n aria-label={`${labels.switchNetwork} - ${chainsList.length} ${labels.listOfNetworks.toLowerCase()} available`}\n data-testid=\"switch-network-button\"\n />\n\n {/* Main Wallet Avatar */}\n <WalletAvatar\n ensAvatar={ensAvatar}\n address={activeWallet.address}\n className=\"novacon:w-28 novacon:h-28 novacon:sm:w-32 novacon:sm:h-32\"\n aria-describedby=\"wallet-info\"\n />\n </motion.div>\n );\n};\n\nconst DefaultInfoSection: React.FC<InfoSectionProps> = ({\n balanceLoading,\n balance,\n ensNameAbbreviated,\n labels,\n className,\n}) => {\n return (\n <motion.div\n variants={DEFAULT_INFO_SECTION_ANIMATION_VARIANTS}\n id=\"wallet-info\"\n className={className}\n role=\"region\"\n aria-label={labels.walletBalance}\n >\n <ConnectedModalNameAndBalance\n balanceLoading={balanceLoading}\n balance={balance}\n ensNameAbbreviated={ensNameAbbreviated}\n />\n </motion.div>\n );\n};\n\nconst DefaultTransactionsSection: React.FC<TransactionsSectionProps> = ({\n walletTransactions,\n hasPendingTransactions,\n labels,\n onViewTransactions,\n showPendingIndicators = true,\n className,\n}) => {\n if (walletTransactions.length === 0) return null;\n\n return (\n <motion.div\n variants={DEFAULT_TRANSACTIONS_ANIMATION_VARIANTS}\n className={cn(\n 'novacon:relative novacon:flex novacon:items-center novacon:justify-center novacon:gap-2',\n className,\n )}\n role=\"group\"\n aria-label={`${labels.transactionsInApp} - ${walletTransactions.length} transactions`}\n >\n <button\n type=\"button\"\n className={standardButtonClasses}\n onClick={onViewTransactions}\n aria-describedby=\"transaction-count\"\n data-testid=\"view-transactions-button\"\n >\n {labels.viewTransactions}\n\n <span id=\"transaction-count\" className=\"novacon:sr-only\">\n {walletTransactions.length} transactions available\n {hasPendingTransactions && `, ${labels.transactionLoading}`}\n </span>\n </button>\n\n {/* Pending Transactions Indicator */}\n {showPendingIndicators && (\n <AnimatePresence>\n {hasPendingTransactions && (\n <motion.div\n initial={{ scale: 0.6, opacity: 0 }}\n animate={{ scale: 1, opacity: 1 }}\n exit={{ scale: 0.6, opacity: 0 }}\n transition={{ duration: 0.4 }}\n className=\"novacon:block novacon:absolute novacon:left-[110%] novacon:w-4 novacon:h-4\"\n role=\"status\"\n aria-label={labels.transactionLoading}\n >\n <span className=\"novacon:block Toastify__spinner\" aria-hidden=\"true\" />\n <span className=\"novacon:sr-only\">{labels.transactionLoading}</span>\n </motion.div>\n )}\n </AnimatePresence>\n )}\n </motion.div>\n );\n};\n\nconst DefaultNoTransactionsIndicator: React.FC<NoTransactionsIndicatorProps> = ({ className }) => {\n return (\n <div className={cn('novacon:sr-only', className)} role=\"status\" aria-live=\"polite\">\n No transactions found for this wallet\n </div>\n );\n};\n\n/**\n * Main content component for the connected wallet modal with comprehensive customization options.\n *\n * This component displays the primary interface for connected wallet management:\n * - Large wallet avatar with ENS support\n * - Wallet and network switching controls via IconButton components\n * - Loading indicators for avatar and balance states\n * - Transaction history access when transactions are available\n * - Animated pending transaction indicator\n * - Comprehensive customization for all UI elements and behaviors\n * - Animation support with reduced motion options\n * - Custom event handlers for enhanced interactivity\n * - Performance-optimized with memoized calculations\n * - Full customization of child components through parent\n *\n * The component provides full WCAG compliance with proper ARIA labels,\n * semantic HTML structure, and keyboard navigation support.\n *\n * @example Basic usage\n * ```tsx\n * <ConnectedModalMainContent\n * transactionPool={transactionPool}\n * chainsList={availableChains}\n * ensAvatar={ensAvatar}\n * avatarIsLoading={false}\n * balanceLoading={false}\n * ensNameAbbreviated=\"wallet.eth\"\n * balance={{ value: \"1.23\", symbol: \"ETH\" }}\n * store={store}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectedModalMainContent\n * transactionPool={transactionPool}\n * chainsList={availableChains}\n * ensAvatar={ensAvatar}\n * avatarIsLoading={false}\n * balanceLoading={false}\n * ensNameAbbreviated=\"wallet.eth\"\n * balance={{ value: \"1.23\", symbol: \"ETH\" }}\n * store={store}\n * customization={{\n * classNames: {\n * container: ({ hasActiveWallet }) =>\n * `custom-container ${hasActiveWallet ? 'has-wallet' : 'no-wallet'}`,\n * avatarSection: () => \"custom-avatar-section\",\n * transactionsSection: ({ transactionsCount }) =>\n * `transactions-section transactions-count-${transactionsCount}`,\n * },\n * components: {\n * LoadingIndicator: ({ isLoading }) =>\n * isLoading ? <div className=\"custom-spinner\" /> : null,\n * AvatarSection: ({ activeWallet, onSwitchWallet }) => (\n * <div onClick={onSwitchWallet}>Custom Avatar: {activeWallet.address}</div>\n * ),\n * },\n * childCustomizations: {\n * nameAndBalance: {\n * classNames: {\n * container: () => \"custom-name-balance-container\",\n * },\n * components: {\n * WalletNameDisplay: ({ ensNameAbbreviated }) =>\n * <h2>{ensNameAbbreviated}</h2>,\n * },\n * },\n * walletAvatar: {\n * className: \"custom-wallet-avatar\",\n * },\n * },\n * handlers: {\n * onSwitchWallet: () => console.log('Custom wallet switch'),\n * onViewTransactions: () => console.log('Custom view transactions'),\n * onTransactionsUpdate: (transactions, pendingCount) =>\n * console.log(`Transactions: ${transactions.length}, Pending: ${pendingCount}`),\n * },\n * config: {\n * showLoadingIndicators: true,\n * showPendingIndicators: true,\n * ariaLabels: {\n * container: 'Wallet management interface',\n * },\n * },\n * }}\n * />\n * ```\n */\nexport const ConnectedModalMainContent = forwardRef<HTMLDivElement, ConnectedModalMainContentProps>(\n (\n {\n transactionPool,\n chainsList,\n ensAvatar,\n avatarIsLoading,\n balanceLoading,\n ensNameAbbreviated,\n balance,\n store,\n className,\n 'aria-label': ariaLabel,\n customization,\n ...props\n },\n ref,\n ) => {\n // Get localized labels for UI text\n const labels = useNovaConnectLabels();\n // Get modal controls and state from hook\n const { setConnectedModalContentType, setIsConnectedModalOpen, setIsConnectModalOpen, activeWallet } =\n useNovaConnect();\n\n // Get wallet state from store\n const getConnectors = store.getState().getConnectors;\n\n // Extract custom components and config with stable references\n const customComponents = customization?.components;\n const customConfig = customization?.config;\n const customHandlers = customization?.handlers;\n\n const {\n LoadingIndicator = DefaultLoadingIndicator,\n AvatarSection = DefaultAvatarSection,\n InfoSection = DefaultInfoSection,\n TransactionsSection = DefaultTransactionsSection,\n NoTransactionsIndicator = DefaultNoTransactionsIndicator,\n } = customComponents ?? {};\n\n const {\n disableAnimation = false,\n reduceMotion = false,\n showLoadingIndicators = true,\n showPendingIndicators = true,\n ariaLabels,\n } = customConfig ?? {};\n\n /**\n * Handle wallet switching by closing connected modal and opening connect modal\n * Provides seamless transition between modal views\n */\n const handleSwitchWallet = useCallback(() => {\n if (customHandlers?.onSwitchWallet) {\n customHandlers.onSwitchWallet();\n } else {\n setIsConnectedModalOpen(false);\n setIsConnectModalOpen(true);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onSwitchWallet, setIsConnectedModalOpen, setIsConnectModalOpen]);\n\n /**\n * Handle network switching by changing to chains view\n */\n const handleSwitchNetwork = useCallback(() => {\n if (customHandlers?.onSwitchNetwork) {\n customHandlers.onSwitchNetwork();\n } else {\n setConnectedModalContentType('chains');\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onSwitchNetwork, setConnectedModalContentType]);\n\n /**\n * Handle viewing transactions by changing to transactions view\n */\n const handleViewTransactions = useCallback(() => {\n if (customHandlers?.onViewTransactions) {\n customHandlers.onViewTransactions();\n } else {\n setConnectedModalContentType('transactions');\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onViewTransactions, setConnectedModalContentType]);\n\n /**\n * Memoized connectors to prevent unnecessary recalculations\n */\n const connectors = useMemo(() => getConnectors(), [getConnectors]);\n\n /**\n * Memoized wallet transactions filtered by current wallet address\n * Only includes transactions from the currently connected wallet\n */\n const walletTransactions = useMemo(() => {\n if (!activeWallet || !transactionPool) return [];\n return Object.values(transactionPool).filter(\n (tx) => tx.from.toLowerCase() === activeWallet.address.toLowerCase(),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [activeWallet?.address, transactionPool]);\n\n /**\n * Check if there are pending transactions for loading indicator\n */\n const hasPendingTransactions = useMemo(() => {\n return walletTransactions.some((tx) => tx.pending);\n }, [walletTransactions]);\n\n /**\n * Get number of available connectors for the current wallet type\n */\n const connectorsCount = useMemo(() => {\n if (!activeWallet) return 0;\n return connectors[getAdapterFromWalletType(activeWallet.walletType)]?.length || 0;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [activeWallet?.walletType, connectors]);\n\n /**\n * Get wallet name from wallet type for display\n */\n const walletName = useMemo(() => {\n return activeWallet?.walletType?.split(':')[1] || labels.unknownWallet;\n }, [activeWallet?.walletType, labels.unknownWallet]);\n\n /**\n * Memoized calculations for state\n */\n const hasActiveWallet = useMemo(() => Boolean(activeWallet?.isConnected), [activeWallet?.isConnected]);\n const isLoading = useMemo(() => avatarIsLoading || balanceLoading, [avatarIsLoading, balanceLoading]);\n const hasTransactions = useMemo(() => walletTransactions.length > 0, [walletTransactions]);\n\n /**\n * Effect for transaction updates\n */\n const pendingCount = useMemo(() => {\n return walletTransactions.filter((tx) => tx.pending).length;\n }, [walletTransactions]);\n\n // Call transaction update handler when transactions change\n React.useEffect(() => {\n if (customHandlers?.onTransactionsUpdate) {\n customHandlers.onTransactionsUpdate(walletTransactions, pendingCount);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [walletTransactions, pendingCount, customHandlers?.onTransactionsUpdate]);\n\n // Call loading state change handler when loading state changes\n React.useEffect(() => {\n if (customHandlers?.onLoadingStateChange) {\n customHandlers.onLoadingStateChange(isLoading);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isLoading, customHandlers?.onLoadingStateChange]);\n\n /**\n * Generate container classes with custom generator\n */\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({\n hasActiveWallet,\n isLoading,\n hasTransactions,\n hasPendingTransactions,\n });\n }\n\n return cn(\n 'novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:gap-2 novacon:p-4',\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n customization?.classNames?.container,\n hasActiveWallet,\n isLoading,\n hasTransactions,\n hasPendingTransactions,\n className,\n ]);\n\n /**\n * Animation variants\n */\n const containerVariants = customization?.variants?.container || DEFAULT_CONTAINER_ANIMATION_VARIANTS;\n\n /**\n * Merge container props\n */\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'main',\n 'aria-label': ariaLabel || ariaLabels?.container || `${labels.walletConnected} - ${walletName}`,\n }),\n [\n customization?.containerProps,\n props,\n ref,\n containerClasses,\n ariaLabel,\n ariaLabels?.container,\n labels.walletConnected,\n walletName,\n ],\n );\n\n // Early return if no active wallet\n if (!hasActiveWallet || !activeWallet) {\n return null;\n }\n\n const content = (\n <>\n {/* Loading Indicator */}\n {showLoadingIndicators && (\n <AnimatePresence>\n <LoadingIndicator\n isLoading={isLoading}\n labels={labels}\n className={customization?.classNames?.loadingIndicator?.({ isLoading })}\n />\n </AnimatePresence>\n )}\n\n {/* Wallet Avatar with Control Buttons */}\n <AvatarSection\n activeWallet={activeWallet}\n ensAvatar={ensAvatar}\n walletName={walletName}\n connectorsCount={connectorsCount}\n chainsList={chainsList}\n labels={labels}\n onSwitchWallet={handleSwitchWallet}\n onSwitchNetwork={handleSwitchNetwork}\n className={customization?.classNames?.avatarSection?.()}\n />\n\n {/* Wallet Name and Balance */}\n <InfoSection\n balanceLoading={balanceLoading}\n balance={balance}\n ensNameAbbreviated={ensNameAbbreviated}\n labels={labels}\n className={customization?.classNames?.infoSection?.()}\n />\n\n {/* Transactions Section */}\n <TransactionsSection\n walletTransactions={walletTransactions}\n hasPendingTransactions={hasPendingTransactions}\n labels={labels}\n onViewTransactions={handleViewTransactions}\n showPendingIndicators={showPendingIndicators}\n className={customization?.classNames?.transactionsSection?.({\n transactionsCount: walletTransactions.length,\n hasPendingTransactions,\n })}\n />\n\n {/* No Transactions State */}\n {walletTransactions.length === 0 && (\n <NoTransactionsIndicator className={customization?.classNames?.noTransactions?.()} />\n )}\n </>\n );\n\n if (disableAnimation || reduceMotion) {\n return <div {...containerProps}>{content}</div>;\n }\n\n return (\n <motion.div\n {...containerProps}\n variants={containerVariants}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n transition={{\n duration: customization?.animation?.container?.duration ?? 0.4,\n ease: customization?.animation?.container?.ease ?? 'easeOut',\n delay: customization?.animation?.container?.delay ?? 0,\n staggerChildren: customization?.animation?.container?.staggerChildren ?? 0.1,\n }}\n >\n {content}\n </motion.div>\n );\n },\n);\n\nConnectedModalMainContent.displayName = 'ConnectedModalMainContent';\n","/**\n * @file ConnectedModalTxHistory component with comprehensive customization options for transaction history display.\n */\n\nimport { ExclamationTriangleIcon, PuzzlePieceIcon } from '@heroicons/react/24/solid';\nimport { cn } from '@tuwaio/nova-core';\nimport { type Easing, motion, type Variants } from 'framer-motion';\nimport React, {\n Component,\n ComponentPropsWithoutRef,\n ComponentType,\n forwardRef,\n lazy,\n ReactNode,\n Suspense,\n useCallback,\n useMemo,\n} from 'react';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\n\n// --- Default Motion Variants ---\nconst DEFAULT_CONTAINER_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, y: 10 },\n animate: { opacity: 1, y: 0, transition: { duration: 0.3, ease: 'easeOut' } },\n exit: { opacity: 0, y: -10, transition: { duration: 0.2, ease: 'easeIn' } },\n};\n\nconst DEFAULT_ERROR_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, scale: 0.95 },\n animate: { opacity: 1, scale: 1, transition: { duration: 0.2, ease: 'easeOut' } },\n exit: { opacity: 0, scale: 0.95, transition: { duration: 0.15, ease: 'easeIn' } },\n};\n\n// --- Types for Customization ---\ntype CustomLoadingContainerProps = {\n labels: Record<string, string>;\n className?: string;\n};\n\ntype CustomErrorContainerProps = {\n className?: string;\n};\n\ntype CustomNoWalletContainerProps = {\n className?: string;\n};\n\ntype CustomTransactionsHistoryWrapperProps = {\n children: ReactNode;\n activeWalletAddress: string;\n transactionPool: NonNullable<ConnectButtonProps['transactionPool']>;\n pulsarAdapter: NonNullable<ConnectButtonProps['pulsarAdapter']>;\n labels: Record<string, string>;\n className?: string;\n};\n\n/**\n * Customization options for ConnectedModalTxHistory component\n */\nexport type ConnectedModalTxHistoryCustomization = {\n /** Override root container props */\n containerProps?: Partial<\n Omit<\n ComponentPropsWithoutRef<'div'>,\n | 'popover'\n | 'onDrag'\n | 'onDragEnd'\n | 'onDragExit'\n | 'onDragStart'\n | 'onDragStartCapture'\n | 'onAnimationStart'\n | 'onAnimationEnd'\n | 'onAnimationStartCapture'\n | 'onAnimationEndCapture'\n | 'onAnimationIteration'\n | 'onAnimationIterationCapture'\n >\n >;\n /** Custom components */\n components?: {\n /** Custom loading container component */\n LoadingContainer?: ComponentType<CustomLoadingContainerProps>;\n /** Custom error container component */\n ErrorContainer?: ComponentType<CustomErrorContainerProps>;\n /** Custom no wallet container component */\n NoWalletContainer?: ComponentType<CustomNoWalletContainerProps>;\n /** Custom transactions history wrapper component */\n TransactionsHistoryWrapper?: ComponentType<CustomTransactionsHistoryWrapperProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { hasActiveWallet: boolean; hasValidAdapter: boolean }) => string;\n /** Function to generate loading container classes */\n loadingContainer?: () => string;\n /** Function to generate loading spinner classes */\n loadingSpinner?: () => string;\n /** Function to generate loading text classes */\n loadingText?: () => string;\n /** Function to generate error container classes */\n errorContainer?: () => string;\n /** Function to generate error icon container classes */\n errorIconContainer?: () => string;\n /** Function to generate error icon classes */\n errorIcon?: () => string;\n /** Function to generate error content classes */\n errorContent?: () => string;\n /** Function to generate error title classes */\n errorTitle?: () => string;\n /** Function to generate error description classes */\n errorDescription?: () => string;\n /** Function to generate no wallet container classes */\n noWalletContainer?: () => string;\n /** Function to generate no wallet text classes */\n noWalletText?: () => string;\n /** Function to generate pulsar required container classes */\n pulsarRequiredContainer?: () => string;\n /** Function to generate pulsar required icon container classes */\n pulsarRequiredIconContainer?: () => string;\n /** Function to generate pulsar required icon classes */\n pulsarRequiredIcon?: () => string;\n /** Function to generate pulsar required content classes */\n pulsarRequiredContent?: () => string;\n /** Function to generate pulsar required title classes */\n pulsarRequiredTitle?: () => string;\n /** Function to generate pulsar required description classes */\n pulsarRequiredDescription?: () => string;\n /** Function to generate transactions history wrapper classes */\n transactionsHistoryWrapper?: () => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Container animation variants */\n container?: Variants;\n /** Error animation variants */\n error?: Variants;\n /** Loading animation variants */\n loading?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Container animation configuration */\n container?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Error animation configuration */\n error?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Loading animation configuration */\n loading?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for error retry actions */\n onErrorRetry?: (error: Error, event: React.MouseEvent<HTMLButtonElement>) => void;\n /** Custom handler for package loading failure */\n onPackageLoadingFailure?: (packageName: string, error: Error) => void;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Custom package name for error messages */\n packageName?: string;\n /** Custom aria labels for different states */\n ariaLabels?: {\n loading?: string;\n error?: string;\n noWallet?: string;\n pulsarRequired?: string;\n transactionsHistory?: string;\n };\n };\n};\n\n/**\n * Props for the ConnectedModalTxHistory component\n */\nexport interface ConnectedModalTxHistoryProps extends Pick<ConnectButtonProps, 'transactionPool' | 'pulsarAdapter'> {\n /** Additional CSS classes for the container */\n className?: string;\n /** Custom aria-label for the container */\n 'aria-label'?: string;\n /** Customization options */\n customization?: ConnectedModalTxHistoryCustomization;\n}\n\n/**\n * Lazy import of TransactionsHistory component with error handling\n * This allows the component to work even if the @tuwaio/nova-transactions package is not available\n */\nconst TransactionsHistory = lazy(() => {\n try {\n return import('@tuwaio/nova-transactions').then((module) => ({\n default: module.TransactionsHistory,\n }));\n } catch (error) {\n console.warn('Failed to load @tuwaio/nova-transactions package:', error);\n // Return a promise that never resolves to trigger error boundary\n return new Promise(() => {});\n }\n});\n\n// --- Default Sub-Components ---\nconst DefaultLoadingContainer: React.FC<CustomLoadingContainerProps> = ({ labels, className }) => {\n return (\n <div\n className={cn(\n 'novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:p-8 novacon:gap-4',\n className,\n )}\n role=\"status\"\n aria-live=\"polite\"\n >\n <div className=\"novacon:animate-spin novacon:rounded-full novacon:h-8 novacon:w-8 novacon:border-2 novacon:border-[var(--tuwa-text-accent)] novacon:border-t-transparent\" />\n <p className=\"novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]\">\n {labels.loading} {labels.transactionsInApp.toLowerCase()}...\n </p>\n </div>\n );\n};\n\nconst DefaultErrorContainer: React.FC<CustomErrorContainerProps> = ({ className }) => {\n return (\n <motion.div\n initial={{ opacity: 0, y: 20 }}\n animate={{ opacity: 1, y: 0 }}\n transition={{ duration: 0.3, ease: 'easeOut' }}\n className={cn(\n 'novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:text-center novacon:gap-4 novacon:p-6',\n className,\n )}\n role=\"alert\"\n aria-live=\"assertive\"\n >\n <div className=\"novacon:w-12 novacon:h-12 novacon:p-2 novacon:rounded-full novacon:bg-[var(--tuwa-warning-bg)] novacon:text-[var(--tuwa-warning-text)]\">\n <ExclamationTriangleIcon className=\"novacon:w-full novacon:h-full\" />\n </div>\n\n <div className=\"novacon:space-y-2\">\n <h2 className=\"novacon:text-lg novacon:font-semibold novacon:text-[var(--tuwa-text-primary)]\">\n Transaction History Not Available\n </h2>\n <p className=\"novacon:text-sm novacon:text-[var(--tuwa-text-secondary)] novacon:max-w-md\">\n Transaction history is not supported by this application at the moment. The required package is not installed\n or configured.\n </p>\n </div>\n </motion.div>\n );\n};\n\nconst DefaultNoWalletContainer: React.FC<CustomNoWalletContainerProps> = ({ className }) => {\n return (\n <div\n className={cn('novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:p-6', className)}\n role=\"status\"\n >\n <p className=\"novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]\">No wallet connected</p>\n </div>\n );\n};\n\nconst DefaultTransactionsHistoryWrapper: React.FC<CustomTransactionsHistoryWrapperProps> = ({\n children,\n activeWalletAddress,\n labels,\n className,\n}) => {\n return (\n <div\n className={cn('novacon:w-full', className)}\n aria-label={`${labels.transactionsInApp} for ${activeWalletAddress}`}\n >\n {children}\n </div>\n );\n};\n\n/**\n * Pulsar adapter required fallback component\n */\nfunction PulsarAdapterRequired({\n labels,\n customization,\n}: {\n labels: Record<string, string>;\n customization?: ConnectedModalTxHistoryCustomization;\n}) {\n const containerClasses =\n customization?.classNames?.pulsarRequiredContainer?.() ??\n 'novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:text-center novacon:gap-4 novacon:p-6';\n const iconContainerClasses =\n customization?.classNames?.pulsarRequiredIconContainer?.() ??\n 'novacon:w-12 novacon:h-12 novacon:p-2 novacon:rounded-full novacon:bg-gradient-to-r novacon:from-[var(--tuwa-button-gradient-from)] novacon:to-[var(--tuwa-button-gradient-to)] novacon:text-[var(--tuwa-text-on-accent)]';\n const iconClasses = customization?.classNames?.pulsarRequiredIcon?.() ?? 'novacon:w-full novacon:h-full';\n const contentClasses = customization?.classNames?.pulsarRequiredContent?.() ?? 'novacon:space-y-2';\n const titleClasses =\n customization?.classNames?.pulsarRequiredTitle?.() ??\n 'novacon:text-lg novacon:font-semibold novacon:text-[var(--tuwa-text-primary)]';\n const descriptionClasses =\n customization?.classNames?.pulsarRequiredDescription?.() ??\n 'novacon:text-sm novacon:text-[var(--tuwa-text-secondary)] novacon:max-w-md novacon:leading-relaxed';\n\n const errorVariants = customization?.variants?.error || DEFAULT_ERROR_ANIMATION_VARIANTS;\n const disableAnimation = customization?.config?.disableAnimation || customization?.config?.reduceMotion;\n\n const content = (\n <div className={containerClasses} role=\"alert\">\n <div className={iconContainerClasses}>\n <PuzzlePieceIcon className={iconClasses} />\n </div>\n\n <div className={contentClasses}>\n <h2 className={titleClasses}>{labels.pulsarAdapterRequired}</h2>\n <p className={descriptionClasses}>{labels.pulsarAdapterDescription}</p>\n </div>\n </div>\n );\n\n if (disableAnimation) {\n return content;\n }\n\n return (\n <motion.div\n variants={errorVariants}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n transition={{\n duration: customization?.animation?.error?.duration ?? 0.2,\n ease: customization?.animation?.error?.ease ?? 'easeOut',\n delay: customization?.animation?.error?.delay ?? 0,\n }}\n >\n {content}\n </motion.div>\n );\n}\n\n/**\n * Simple Error Boundary component for handling TransactionsHistory loading errors\n */\ninterface ErrorBoundaryState {\n hasError: boolean;\n error?: Error;\n}\n\ninterface ErrorBoundaryProps {\n children: React.ReactNode;\n fallback: React.ReactNode;\n onError?: (error: Error, errorInfo: React.ErrorInfo) => void;\n}\n\nclass ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {\n constructor(props: ErrorBoundaryProps) {\n super(props);\n this.state = { hasError: false };\n }\n\n static getDerivedStateFromError(error: Error): ErrorBoundaryState {\n return { hasError: true, error };\n }\n\n componentDidCatch(error: Error, errorInfo: React.ErrorInfo) {\n console.warn('TransactionsHistory component failed to load:', error, errorInfo);\n\n if (this.props.onError) {\n this.props.onError(error, errorInfo);\n }\n }\n\n render() {\n if (this.state.hasError) {\n return this.props.fallback;\n }\n\n return this.props.children;\n }\n}\n\n/**\n * Component for displaying transaction history with comprehensive customization options.\n *\n * This component provides comprehensive transaction history functionality:\n * - Conditional loading of the @tuwaio/nova-transactions package\n * - Graceful fallback when the package is not available\n * - Loading states with proper accessibility support\n * - Error handling for missing configuration\n * - Full WCAG compliance with ARIA labels\n * - Comprehensive customization for all UI elements and behaviors\n * - Animation support with reduced motion options\n * - Custom event handlers for enhanced interactivity\n * - Performance-optimized with memoized calculations\n *\n * The component automatically detects if the required dependencies are available\n * and provides appropriate fallbacks for different scenarios.\n *\n * @example Basic usage\n * ```tsx\n * <ConnectedModalTxHistory\n * transactionPool={txPool}\n * pulsarAdapter={adapter}\n * className=\"custom-styling\"\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectedModalTxHistory\n * transactionPool={txPool}\n * pulsarAdapter={adapter}\n * customization={{\n * classNames: {\n * container: ({ hasActiveWallet }) =>\n * `custom-container ${hasActiveWallet ? 'has-wallet' : 'no-wallet'}`,\n * loadingContainer: () => \"custom-loading bg-blue-100\",\n * errorContainer: () => \"custom-error bg-red-100\",\n * },\n * components: {\n * LoadingContainer: ({ className }) =>\n * <div className={cn(\"custom-spinner\", className)} />,\n * },\n * handlers: {\n * onPackageLoadingFailure: (packageName, error) =>\n * console.error(`Failed to load ${packageName}:`, error),\n * },\n * config: {\n * packageName: '@custom/transactions',\n * ariaLabels: {\n * loading: 'Loading transaction history...',\n * error: 'Error loading transactions',\n * },\n * },\n * animation: {\n * container: { duration: 0.3, ease: 'easeOut' },\n * error: { duration: 0.2, ease: 'easeIn' },\n * },\n * }}\n * />\n * ```\n */\nexport const ConnectedModalTxHistory = forwardRef<HTMLDivElement, ConnectedModalTxHistoryProps>(\n ({ transactionPool, pulsarAdapter, className, 'aria-label': ariaLabel, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n const { activeWallet } = useNovaConnect();\n\n // Extract custom components and config\n const {\n LoadingContainer = DefaultLoadingContainer,\n ErrorContainer = DefaultErrorContainer,\n NoWalletContainer = DefaultNoWalletContainer,\n TransactionsHistoryWrapper = DefaultTransactionsHistoryWrapper,\n } = customization?.components ?? {};\n\n const {\n disableAnimation = false,\n reduceMotion = false,\n packageName = '@tuwaio/nova-transactions',\n ariaLabels,\n } = customization?.config ?? {};\n\n /**\n * Memoized check for active wallet availability\n */\n const hasActiveWallet = useMemo(() => Boolean(activeWallet?.isConnected), [activeWallet?.isConnected]);\n\n /**\n * Memoized check for adapter availability\n */\n const hasValidAdapter = useMemo(() => Boolean(transactionPool && pulsarAdapter), [transactionPool, pulsarAdapter]);\n\n /**\n * Generate container classes with custom generator\n */\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ hasActiveWallet, hasValidAdapter });\n }\n return cn('novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:p-4', className);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, hasActiveWallet, hasValidAdapter, className]);\n\n /**\n * Error handler callbacks\n */\n const handlePackageLoadingFailure = useCallback(\n (error: Error) => {\n if (customization?.handlers?.onPackageLoadingFailure) {\n customization.handlers.onPackageLoadingFailure(packageName, error);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.handlers?.onPackageLoadingFailure, packageName],\n );\n\n /**\n * Animation variants\n */\n const containerVariants = customization?.variants?.container || DEFAULT_CONTAINER_ANIMATION_VARIANTS;\n\n /**\n * Merge container props\n */\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n 'aria-label': ariaLabel || ariaLabels?.transactionsHistory || `${labels.transactionsInApp}`,\n }),\n [\n customization?.containerProps,\n props,\n ref,\n containerClasses,\n ariaLabel,\n ariaLabels?.transactionsHistory,\n labels.transactionsInApp,\n ],\n );\n\n /**\n * Loading component with customization\n */\n const loadingComponent = useMemo(\n () => <LoadingContainer labels={labels} className={customization?.classNames?.loadingContainer?.()} />,\n [LoadingContainer, labels, customization?.classNames],\n );\n\n /**\n * Error fallback component with customization\n */\n const errorComponent = useMemo(\n () => <ErrorContainer className={customization?.classNames?.errorContainer?.()} />,\n [ErrorContainer, customization?.classNames],\n );\n\n /**\n * No wallet component with customization\n */\n const noWalletComponent = useMemo(\n () => <NoWalletContainer className={customization?.classNames?.noWalletContainer?.()} />,\n [NoWalletContainer, customization?.classNames],\n );\n\n const content = useMemo(() => {\n // Early return if no active wallet\n if (!hasActiveWallet) {\n return noWalletComponent;\n }\n\n if (hasValidAdapter && transactionPool && pulsarAdapter) {\n return (\n <Suspense fallback={loadingComponent}>\n <ErrorBoundary fallback={errorComponent} onError={handlePackageLoadingFailure}>\n <TransactionsHistoryWrapper\n activeWalletAddress={activeWallet!.address}\n transactionPool={transactionPool}\n pulsarAdapter={pulsarAdapter}\n labels={labels}\n className={customization?.classNames?.transactionsHistoryWrapper?.()}\n >\n <TransactionsHistory\n transactionsPool={transactionPool}\n adapter={pulsarAdapter}\n connectedWalletAddress={activeWallet!.address}\n className=\"novacon:w-full\"\n />\n </TransactionsHistoryWrapper>\n </ErrorBoundary>\n </Suspense>\n );\n }\n\n return <PulsarAdapterRequired labels={labels} customization={customization} />;\n }, [\n hasActiveWallet,\n hasValidAdapter,\n transactionPool,\n pulsarAdapter,\n activeWallet,\n noWalletComponent,\n loadingComponent,\n errorComponent,\n handlePackageLoadingFailure,\n TransactionsHistoryWrapper,\n labels,\n customization,\n ]);\n\n if (disableAnimation || reduceMotion) {\n return <div {...containerProps}>{content}</div>;\n }\n\n return (\n <motion.div\n {...containerProps}\n variants={containerVariants}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n transition={{\n duration: customization?.animation?.container?.duration ?? 0.3,\n ease: customization?.animation?.container?.ease ?? 'easeOut',\n delay: customization?.animation?.container?.delay ?? 0,\n }}\n >\n {content}\n </motion.div>\n );\n },\n);\n\nConnectedModalTxHistory.displayName = 'ConnectedModalTxHistory';\n","/**\n * @file ConnectedModal component with comprehensive customization options for all child components.\n */\n\nimport { ChevronLeftIcon } from '@heroicons/react/24/solid';\nimport { CloseIcon, cn, Dialog, DialogClose, DialogContent, DialogHeader, DialogTitle } from '@tuwaio/nova-core';\nimport { formatWalletChainId, getAdapterFromWalletType, OrbitAdapter, WalletType } from '@tuwaio/orbit-core';\nimport { type Easing, motion, type Transition, type Variants } from 'framer-motion';\nimport React, { ComponentPropsWithoutRef, ComponentType, forwardRef, useCallback, useEffect, useMemo } from 'react';\n\nimport { NativeBalanceResult, useGetWalletNameAndAvatar, useWalletNativeBalance } from '../../hooks';\nimport { NovaConnectProviderType, useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { getChainsListByWalletType, getWalletChains } from '../../utils';\nimport { ScrollableChainList, type ScrollableChainListProps } from '../Chains/ScrollableChainList';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\nimport { ConnectedModalFooter, type ConnectedModalFooterProps } from './ConnectedModalFooter';\nimport {\n ConnectedModalMainContent,\n type ConnectedModalMainContentCustomization,\n type ConnectedModalMainContentProps,\n} from './ConnectedModalMainContent';\nimport { ConnectedModalTxHistory, type ConnectedModalTxHistoryProps } from './ConnectedModalTxHistory';\n\n// --- Default Motion Variants ---\nconst DEFAULT_MODAL_ANIMATION_VARIANTS: Variants = {\n initial: { opacity: 0, scale: 0.95, y: 10 },\n animate: {\n opacity: 1,\n scale: 1,\n y: 0,\n transition: { duration: 0.3, ease: 'easeOut' },\n },\n exit: {\n opacity: 0,\n scale: 0.95,\n y: -10,\n transition: { duration: 0.2, ease: 'easeIn' },\n },\n};\n\n// --- Content Types ---\ntype ConnectedModalContentType = 'main' | 'transactions' | 'chains';\n\n// --- Component Props Types ---\ntype HeaderProps = {\n contentType: ConnectedModalContentType;\n title: string;\n onBack: () => void;\n onClose: () => void;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype BackButtonProps = {\n onBack: () => void;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype TitleProps = {\n title: string;\n className?: string;\n};\n\ntype CloseButtonProps = {\n onClose: () => void;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype MainContentProps = Pick<ConnectButtonProps, 'transactionPool' | 'store' | 'pulsarAdapter'> &\n Pick<NovaConnectProviderType, 'activeWallet'> & {\n contentType: ConnectedModalContentType;\n balance: NativeBalanceResult | null;\n ensNameAbbreviated: string | undefined;\n avatarIsLoading: boolean;\n balanceLoading: boolean;\n ensAvatar: string | null;\n chainsList: (string | number)[];\n onChainChange: (chainId: string) => void;\n onBack: () => void;\n getChainData: (chain: string | number) => { formattedChainId: string | number; chain: string | number };\n className?: string;\n };\n\n// --- Wallet Name Hook Config Type ---\ntype WalletNameConfig = {\n abbreviateSymbols?: number;\n maxNameLength?: number;\n autoRetry?: boolean;\n retryDelay?: number;\n};\n\n/**\n * Customization options for ConnectedModal component\n */\nexport type ConnectedModalCustomization = {\n /** Override root dialog props */\n dialogProps?: Partial<ComponentPropsWithoutRef<typeof Dialog>>;\n /** Override dialog content props */\n dialogContentProps?: Partial<ComponentPropsWithoutRef<typeof DialogContent>>;\n /** Custom components */\n components?: {\n /** Custom dialog component */\n Dialog?: ComponentType<ComponentPropsWithoutRef<typeof Dialog>>;\n /** Custom dialog content component */\n DialogContent?: ComponentType<ComponentPropsWithoutRef<typeof DialogContent>>;\n /** Custom dialog header component */\n DialogHeader?: ComponentType<ComponentPropsWithoutRef<'div'>>;\n /** Custom dialog title component */\n DialogTitle?: ComponentType<ComponentPropsWithoutRef<'h2'>>;\n /** Custom header component */\n Header?: ComponentType<HeaderProps>;\n /** Custom back button component */\n BackButton?: ComponentType<BackButtonProps>;\n /** Custom title component */\n Title?: ComponentType<TitleProps>;\n /** Custom close button component */\n CloseButton?: ComponentType<CloseButtonProps>;\n /** Custom main content component */\n MainContent?: ComponentType<MainContentProps>;\n /** Custom main content renderer for main view */\n MainContentRenderer?: ComponentType<ConnectedModalMainContentProps>;\n /** Custom transactions content renderer */\n TransactionsContentRenderer?: ComponentType<ConnectedModalTxHistoryProps>;\n /** Custom chains content renderer */\n ChainsContentRenderer?: ComponentType<ScrollableChainListProps>;\n /** Custom footer component */\n Footer?: ComponentType<ConnectedModalFooterProps>;\n /** Custom motion container */\n MotionContainer?: ComponentType<ComponentPropsWithoutRef<typeof motion.div>>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate dialog classes */\n dialog?: () => string;\n /** Function to generate dialog content classes */\n dialogContent?: (params: { contentType: ConnectedModalContentType; hasActiveWallet: boolean }) => string;\n /** Function to generate motion container classes */\n motionContainer?: () => string;\n /** Function to generate content container classes */\n contentContainer?: (params: { contentType: ConnectedModalContentType }) => string;\n /** Function to generate header classes */\n header?: (params: { contentType: ConnectedModalContentType }) => string;\n /** Function to generate back button classes */\n backButton?: () => string;\n /** Function to generate title classes */\n title?: (params: { contentType: ConnectedModalContentType }) => string;\n /** Function to generate close button classes */\n closeButton?: () => string;\n /** Function to generate main content classes */\n mainContent?: (params: { contentType: ConnectedModalContentType }) => string;\n /** Function to generate footer classes */\n footer?: () => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Modal animation variants */\n modal?: Variants;\n /** Content animation variants */\n content?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Modal animation configuration */\n modal?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Content animation configuration */\n content?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Layout animation configuration */\n layout?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n };\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for modal open state change */\n onOpenChange?: (open: boolean) => void;\n /** Custom handler for back navigation */\n onBack?: () => void;\n /** Custom handler for modal close */\n onClose?: () => void;\n /** Custom handler for chain change */\n onChainChange?: (chainId: string) => void;\n /** Custom handler for content type change */\n onContentTypeChange?: (type: ConnectedModalContentType) => void;\n };\n /** Child component customizations */\n childCustomizations?: {\n /** Customization for ConnectedModalMainContent component */\n mainContent?: ConnectedModalMainContentCustomization;\n /** Customization for ConnectedModalTxHistory component */\n txHistory?: Record<string, unknown>; // Will be properly typed when that component is updated\n /** Customization for ScrollableChainList component */\n chainList?: Record<string, unknown>; // Will be properly typed when that component is updated\n /** Customization for ConnectedModalFooter component */\n footer?: Record<string, unknown>; // Will be properly typed when that component is updated\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Whether to auto-reset to main view when opening */\n autoResetToMain?: boolean;\n /** Custom ARIA labels for different states */\n ariaLabels?: {\n dialog?: string;\n header?: string;\n backButton?: string;\n closeButton?: string;\n mainContent?: string;\n };\n /** Hook configurations */\n hooks?: {\n /** Configuration for wallet name and avatar hook */\n walletNameAndAvatar?: WalletNameConfig;\n };\n };\n};\n\n/**\n * Props for the ConnectedModal component\n */\nexport interface ConnectedModalProps extends Omit<ConnectButtonProps, 'className' | 'customization'> {\n /** Additional CSS classes for the modal */\n className?: string;\n /** Customization options */\n customization?: ConnectedModalCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultBackButton: React.FC<BackButtonProps> = ({ onBack, labels, className }) => (\n <button\n type=\"button\"\n onClick={onBack}\n aria-label={labels.back}\n className={cn(\n 'novacon:cursor-pointer novacon:rounded-full novacon:p-1',\n 'novacon:text-[var(--tuwa-text-tertiary)] novacon:transition-colors',\n 'novacon:hover:bg-[var(--tuwa-bg-muted)] novacon:hover:text-[var(--tuwa-text-primary)]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)]',\n className,\n )}\n >\n <ChevronLeftIcon className=\"novacon:h-5 novacon:w-5\" />\n </button>\n);\n\nconst DefaultTitle: React.FC<TitleProps> = ({ title, className }) => (\n <span className={cn('novacon:flex-1 novacon:text-center novacon:font-semibold', className)}>{title}</span>\n);\n\nconst DefaultCloseButton: React.FC<CloseButtonProps> = ({ onClose, labels, className }) => (\n <DialogClose asChild>\n <button\n type=\"button\"\n onClick={onClose}\n aria-label={labels.closeModal}\n className={cn(\n 'novacon:cursor-pointer novacon:rounded-full novacon:p-1',\n 'novacon:text-[var(--tuwa-text-tertiary)] novacon:transition-colors',\n 'novacon:hover:bg-[var(--tuwa-bg-muted)] novacon:hover:text-[var(--tuwa-text-primary)]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)]',\n className,\n )}\n >\n <CloseIcon />\n </button>\n </DialogClose>\n);\n\nconst DefaultHeader: React.FC<HeaderProps> = ({ contentType, title, onBack, onClose, labels, className }) => (\n <DialogHeader className={className}>\n <DialogTitle>\n <div className=\"novacon:flex novacon:items-center novacon:justify-between novacon:gap-2\">\n {contentType !== 'main' && <DefaultBackButton onBack={onBack} labels={labels} />}\n <DefaultTitle title={title} />\n </div>\n </DialogTitle>\n <DefaultCloseButton onClose={onClose} labels={labels} />\n </DialogHeader>\n);\n\nconst DefaultMainContent: React.FC<MainContentProps> = ({\n contentType,\n balance,\n ensNameAbbreviated,\n avatarIsLoading,\n balanceLoading,\n store,\n ensAvatar,\n chainsList,\n transactionPool,\n pulsarAdapter,\n activeWallet,\n onChainChange,\n onBack,\n getChainData,\n className,\n}) => {\n const renderContent = () => {\n switch (contentType) {\n case 'main':\n return (\n <ConnectedModalMainContent\n balance={balance}\n ensNameAbbreviated={ensNameAbbreviated}\n avatarIsLoading={avatarIsLoading}\n balanceLoading={balanceLoading}\n store={store}\n ensAvatar={ensAvatar}\n chainsList={chainsList}\n transactionPool={transactionPool}\n />\n );\n case 'transactions':\n return <ConnectedModalTxHistory transactionPool={transactionPool} pulsarAdapter={pulsarAdapter} />;\n case 'chains':\n if (!activeWallet) return null;\n return (\n <ScrollableChainList\n chainsList={chainsList}\n selectValue={String(\n formatWalletChainId(\n (activeWallet as { chainId: string | number }).chainId,\n getAdapterFromWalletType((activeWallet as { walletType: WalletType }).walletType),\n ),\n )}\n handleValueChange={onChainChange}\n getChainData={getChainData}\n onClose={onBack}\n />\n );\n default:\n return null;\n }\n };\n\n return (\n <main\n className={cn('novacon:relative', className)}\n id=\"connected-modal-description\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {renderContent()}\n </main>\n );\n};\n\n/**\n * Modal component that displays wallet connection status and provides access to wallet controls with comprehensive customization options.\n *\n * This modal serves as the main interface for connected wallet management, offering:\n * - Wallet connection status and information\n * - Network switching capabilities\n * - Transaction history viewing\n * - Wallet disconnection controls\n * - Comprehensive customization for all UI elements and behaviors\n * - Animation support with reduced motion options\n * - Custom event handlers for enhanced interactivity\n * - Performance-optimized with memoized calculations\n * - Full customization of child components through parent\n *\n * The modal adapts its content based on the current view state and provides\n * full WCAG compliance with proper ARIA labels and keyboard navigation support.\n *\n * @example Basic usage\n * ```tsx\n * <ConnectedModal\n * solanaRPCUrls={solanaConfig}\n * transactionPool={txPool}\n * pulsarAdapter={adapter}\n * appChains={chainConfig}\n * store={store}\n * />\n * ```\n */\nexport const ConnectedModal = forwardRef<HTMLDivElement, ConnectedModalProps>(\n ({ solanaRPCUrls, transactionPool, pulsarAdapter, appChains, className, store, customization }, ref) => {\n // Get localized labels for UI text\n const labels = useNovaConnectLabels();\n\n // Get modal state and controls from hook\n const {\n setConnectedModalContentType,\n isConnectedModalOpen,\n setIsConnectedModalOpen,\n connectedModalContentType,\n activeWallet,\n } = useNovaConnect();\n\n // Extract customization options with stable references\n const {\n Dialog: CustomDialog = Dialog,\n DialogContent: CustomDialogContent = DialogContent,\n Header: CustomHeader = DefaultHeader,\n MainContent: CustomMainContent = DefaultMainContent,\n Footer: CustomFooter = ConnectedModalFooter,\n MotionContainer = motion.div,\n } = customization?.components ?? {};\n\n const {\n disableAnimation = false,\n reduceMotion = false,\n autoResetToMain = true,\n ariaLabels,\n hooks: hooksConfig,\n } = customization?.config ?? {};\n\n // Memoize handler references\n const customHandlers = useMemo(() => customization?.handlers, [customization?.handlers]);\n\n // Hook configurations\n const walletNameConfig: WalletNameConfig = useMemo(\n () =>\n hooksConfig?.walletNameAndAvatar ?? {\n abbreviateSymbols: 6,\n maxNameLength: 30,\n autoRetry: false,\n retryDelay: 3000,\n },\n [hooksConfig?.walletNameAndAvatar],\n );\n\n const {\n ensAvatar,\n ensNameAbbreviated,\n isLoading: avatarIsLoading,\n } = useGetWalletNameAndAvatar({\n activeWallet,\n store,\n ...walletNameConfig,\n });\n\n const { balance, isLoading: balanceLoading } = useWalletNativeBalance({ store, activeWallet });\n\n /**\n * Handles network switching when user selects a different chain\n */\n const handleChainChange = useCallback(\n (newChainId: string) => {\n if (customHandlers?.onChainChange) {\n customHandlers.onChainChange(newChainId);\n } else {\n (store?.getState() as { switchNetwork: (chainId: string) => void })?.switchNetwork(newChainId);\n }\n },\n [customHandlers, store],\n );\n\n /**\n * Handle modal open state changes\n */\n const handleOpenChange = useCallback(\n (open: boolean) => {\n if (customHandlers?.onOpenChange) {\n customHandlers.onOpenChange(open);\n } else {\n setIsConnectedModalOpen(open);\n }\n },\n [customHandlers, setIsConnectedModalOpen],\n );\n\n /**\n * Reset modal content to main view when modal opens\n * This ensures consistent initial state every time the modal is opened\n */\n useEffect(() => {\n if (isConnectedModalOpen && autoResetToMain) {\n setConnectedModalContentType('main');\n }\n }, [isConnectedModalOpen, autoResetToMain, setConnectedModalContentType]);\n\n /**\n * Memoized chains list to prevent unnecessary recalculations\n * Only recalculates when wallet type or configuration changes\n */\n const chainsList = useMemo(() => {\n if (!activeWallet) {\n return getChainsListByWalletType({\n walletType: `${OrbitAdapter.EVM}:not-connected`,\n appChains,\n solanaRPCUrls,\n chains: [],\n });\n }\n\n // Safely extract wallet chains using shared utility\n const walletChains = getWalletChains(activeWallet);\n\n return getChainsListByWalletType({\n walletType: (activeWallet as { walletType: WalletType }).walletType,\n appChains,\n solanaRPCUrls,\n chains: walletChains,\n });\n }, [activeWallet, appChains, solanaRPCUrls]);\n\n /**\n * Helper function to format chain data for display and selection\n * @param chain - Chain identifier (string or number)\n * @returns Object with formatted chain ID and original chain value\n */\n const getChainData = useCallback(\n (chain: string | number) => {\n if (!activeWallet) {\n return { formattedChainId: chain, chain };\n }\n\n return {\n formattedChainId: formatWalletChainId(\n chain,\n getAdapterFromWalletType((activeWallet as { walletType: WalletType }).walletType),\n ),\n chain,\n };\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [activeWallet?.walletType],\n );\n\n /**\n * Get localized title based on current modal content type\n * @returns Appropriate title string from labels\n */\n const getTitle = useCallback((): string => {\n switch (connectedModalContentType) {\n case 'transactions':\n return labels.transactionsInApp;\n case 'chains':\n return labels.switchNetwork;\n default:\n return labels.connected;\n }\n }, [connectedModalContentType, labels]);\n\n /**\n * Navigate back to main modal content\n * Used by back button in sub-views\n */\n const handleBackToMain = useCallback(() => {\n if (customHandlers?.onBack) {\n customHandlers.onBack();\n } else {\n setConnectedModalContentType('main');\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onBack, setConnectedModalContentType]);\n\n /**\n * Close the entire modal\n * Resets state and closes modal dialog\n */\n const handleCloseModal = useCallback(() => {\n if (customHandlers?.onClose) {\n customHandlers.onClose();\n } else {\n setIsConnectedModalOpen(false);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onClose, setIsConnectedModalOpen]);\n\n /**\n * Memoized state calculations\n */\n const hasActiveWallet = useMemo(\n () => Boolean(activeWallet && (activeWallet as { isConnected?: boolean }).isConnected),\n [activeWallet],\n );\n const currentTitle = useMemo(() => getTitle(), [getTitle]);\n\n /**\n * Generate dialog content classes\n */\n const dialogContentClasses = useMemo(() => {\n if (customization?.classNames?.dialogContent) {\n return customization.classNames.dialogContent({\n contentType: connectedModalContentType,\n hasActiveWallet,\n });\n }\n return cn('novacon:w-full novacon:sm:max-w-md', className);\n }, [customization, connectedModalContentType, hasActiveWallet, className]);\n\n /**\n * Animation variants\n */\n const modalVariants = useMemo(\n () => customization?.variants?.modal || DEFAULT_MODAL_ANIMATION_VARIANTS,\n [customization?.variants?.modal],\n );\n\n /**\n * Motion props configuration\n */\n const motionProps = useMemo(() => {\n if (disableAnimation || reduceMotion) {\n return {};\n }\n\n const layoutTransition: Transition = {\n duration: customization?.animation?.layout?.duration ?? 0.0001,\n ease: customization?.animation?.layout?.ease,\n };\n\n return {\n layout: true,\n variants: modalVariants,\n initial: 'initial' as const,\n animate: 'animate' as const,\n exit: 'exit' as const,\n transition: {\n layout: layoutTransition,\n duration: customization?.animation?.modal?.duration ?? 0.3,\n ease: customization?.animation?.modal?.ease ?? 'easeOut',\n delay: customization?.animation?.modal?.delay ?? 0,\n },\n };\n }, [disableAnimation, reduceMotion, modalVariants, customization]);\n\n // Early return if no active wallet - prevents rendering empty modal\n if (!hasActiveWallet || !activeWallet) {\n return null;\n }\n\n const content = (\n <>\n {/* Modal header with navigation and close controls */}\n <CustomHeader\n contentType={connectedModalContentType}\n title={currentTitle}\n onBack={handleBackToMain}\n onClose={handleCloseModal}\n labels={labels}\n className={customization?.classNames?.header?.({ contentType: connectedModalContentType })}\n />\n\n {/* Main content area - changes based on current view */}\n <CustomMainContent\n contentType={connectedModalContentType}\n balance={balance}\n ensNameAbbreviated={ensNameAbbreviated}\n avatarIsLoading={avatarIsLoading}\n balanceLoading={balanceLoading}\n store={store}\n ensAvatar={ensAvatar}\n chainsList={chainsList}\n transactionPool={transactionPool}\n pulsarAdapter={pulsarAdapter}\n activeWallet={activeWallet}\n onChainChange={handleChainChange}\n onBack={handleBackToMain}\n getChainData={getChainData}\n className={customization?.classNames?.mainContent?.({ contentType: connectedModalContentType })}\n />\n\n {/* Footer with additional controls */}\n <CustomFooter\n store={store}\n setIsOpen={setIsConnectedModalOpen}\n className={customization?.classNames?.footer?.()}\n />\n </>\n );\n\n return (\n <CustomDialog open={isConnectedModalOpen} onOpenChange={handleOpenChange} {...customization?.dialogProps}>\n <CustomDialogContent\n ref={ref}\n className={dialogContentClasses}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-label={ariaLabels?.dialog}\n {...customization?.dialogContentProps}\n >\n <MotionContainer className={customization?.classNames?.motionContainer?.()} {...motionProps}>\n <div\n className={\n customization?.classNames?.contentContainer?.({ contentType: connectedModalContentType })\n ? customization?.classNames?.contentContainer?.({ contentType: connectedModalContentType })\n : cn('novacon:relative novacon:flex novacon:w-full novacon:flex-col')\n }\n >\n {content}\n </div>\n </MotionContainer>\n </CustomDialogContent>\n </CustomDialog>\n );\n },\n);\n\nConnectedModal.displayName = 'ConnectedModal';\n","export const digitalPassportImage =\n '';\n","export const walletImage =\n '';\n","/**\n * @file AboutWallets component with comprehensive customization options and touch support.\n */\n\nimport { cn, StarsBackground } from '@tuwaio/nova-core';\nimport { AnimatePresence, motion, type Transition, type Variants } from 'framer-motion';\nimport React, {\n ComponentPropsWithoutRef,\n ComponentType,\n forwardRef,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { digitalPassportImage } from './images/digitalPassportImage';\nimport { walletImage } from './images/walletImage';\n\n// --- Types ---\ntype SlideConfig = {\n id: number;\n image: string;\n titleKey: keyof Record<string, string>;\n descriptionKey: keyof Record<string, string>;\n};\n\ntype SlideDirection = -1 | 0 | 1;\n\ntype TouchState = {\n isDragging: boolean;\n startX: number;\n currentX: number;\n threshold: number;\n};\n\n// --- Component Props Types ---\ntype SectionProps = {\n className?: string;\n children: React.ReactNode;\n onKeyDown?: (event: React.KeyboardEvent) => void;\n tabIndex?: number;\n role?: string;\n 'aria-label'?: string;\n 'aria-roledescription'?: string;\n} & React.RefAttributes<HTMLElement>;\n\ntype SlideContainerProps = {\n className?: string;\n children: React.ReactNode;\n 'aria-live'?: 'polite' | 'assertive' | 'off';\n 'aria-atomic'?: boolean;\n};\n\ntype SlideProps = {\n slide: SlideConfig;\n slideIndex: number;\n totalSlides: number;\n direction: SlideDirection;\n imageLoadedStates: Record<number, boolean>;\n onImageLoad: (slideIndex: number) => void;\n onImageError: (slideIndex: number) => void;\n className?: string;\n labels: Record<string, string>;\n slideVariants?: Variants;\n slideTransition?: Transition;\n};\n\ntype ImageSectionProps = {\n slide: SlideConfig;\n imageLoaded: boolean;\n onImageLoad: () => void;\n onImageError: () => void;\n slideIndex: number;\n className?: string;\n labels: Record<string, string>;\n};\n\ntype ContentSectionProps = {\n slide: SlideConfig;\n slideIndex: number;\n className?: string;\n labels: Record<string, string>;\n};\n\ntype NavigationProps = {\n slides: SlideConfig[];\n currentSlide: number;\n onSlideChange: (index: number) => void;\n className?: string;\n labels: Record<string, string>;\n};\n\ntype IndicatorProps = {\n slide: SlideConfig;\n index: number;\n isActive: boolean;\n onClick: () => void;\n className?: string;\n labels: Record<string, string>;\n};\n\ntype StatusProps = {\n currentSlide: number;\n totalSlides: number;\n currentSlideData: SlideConfig;\n isAutoPlaying: boolean;\n className?: string;\n labels: Record<string, string>;\n};\n\n// --- Default slide configuration ---\nconst DEFAULT_SLIDES_CONFIG: SlideConfig[] = [\n {\n id: 1,\n image: digitalPassportImage,\n titleKey: 'keyToNewInternet',\n descriptionKey: 'keyToNewInternetDescription',\n },\n {\n id: 2,\n image: walletImage,\n titleKey: 'logInWithoutHassle',\n descriptionKey: 'logInWithoutHassleDescription',\n },\n];\n\n// --- Default motion variants ---\nconst DEFAULT_SLIDE_VARIANTS: Variants = {\n enter: (direction: SlideDirection) => ({\n x: direction > 0 ? '35%' : '-35%',\n opacity: 0,\n }),\n center: {\n zIndex: 1,\n x: '0%',\n opacity: 1,\n },\n exit: (direction: SlideDirection) => ({\n zIndex: 0,\n x: direction < 0 ? '35%' : '-35%',\n opacity: 0,\n top: 0,\n left: 0,\n right: 0,\n }),\n};\n\nconst DEFAULT_IMAGE_VARIANTS: Variants = {\n initial: { opacity: 0, scale: 0.4 },\n animate: { opacity: 1, scale: 1 },\n exit: { opacity: 0, scale: 0.4 },\n};\n\n// --- Touch configuration ---\nconst TOUCH_CONFIG = {\n threshold: 50,\n velocityThreshold: 500,\n dampingFactor: 0.3,\n} as const;\n\n// --- Animation configuration ---\nconst ANIMATION_CONFIG = {\n autoPlayInterval: 25000,\n resumeDelay: 10000,\n slideTransition: {\n x: { type: 'spring' as const, stiffness: 200, damping: 20, duration: 0.1 },\n opacity: { duration: 0.2 },\n } as Transition,\n imageTransition: {\n duration: 0.2,\n } as Transition,\n} as const;\n\n/**\n * Customization options for AboutWallets component\n */\nexport type AboutWalletsCustomization = {\n /** Override slide configuration */\n slidesConfig?: SlideConfig[];\n /** Custom components */\n components?: {\n /** Custom section wrapper */\n Section?: ComponentType<SectionProps>;\n /** Custom slide container */\n SlideContainer?: ComponentType<SlideContainerProps>;\n /** Custom slide component */\n Slide?: ComponentType<SlideProps>;\n /** Custom image section */\n ImageSection?: ComponentType<ImageSectionProps>;\n /** Custom content section */\n ContentSection?: ComponentType<ContentSectionProps>;\n /** Custom navigation */\n Navigation?: ComponentType<NavigationProps>;\n /** Custom indicator */\n Indicator?: ComponentType<IndicatorProps>;\n /** Custom status announcer */\n Status?: ComponentType<StatusProps>;\n /** Custom stars background */\n StarsBackground?: ComponentType<ComponentPropsWithoutRef<typeof StarsBackground>>;\n /** Custom motion container */\n MotionDiv?: ComponentType<ComponentPropsWithoutRef<typeof motion.div>>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate section classes */\n section?: () => string;\n /** Function to generate slide container classes */\n slideContainer?: () => string;\n /** Function to generate slide classes */\n slide?: (params: { slideIndex: number; totalSlides: number }) => string;\n /** Function to generate image section classes */\n imageSection?: (params: { slideIndex: number }) => string;\n /** Function to generate image classes */\n image?: (params: { slideIndex: number; imageLoaded: boolean }) => string;\n /** Function to generate content section classes */\n contentSection?: (params: { slideIndex: number }) => string;\n /** Function to generate title classes */\n title?: (params: { slideIndex: number }) => string;\n /** Function to generate description classes */\n description?: (params: { slideIndex: number }) => string;\n /** Function to generate navigation classes */\n navigation?: () => string;\n /** Function to generate indicator classes */\n indicator?: (params: { index: number; isActive: boolean }) => string;\n /** Function to generate status classes */\n status?: () => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Slide animation variants */\n slide?: Variants;\n /** Image animation variants */\n image?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Auto-play interval in milliseconds */\n autoPlayInterval?: number;\n /** Resume delay after user interaction in milliseconds */\n resumeDelay?: number;\n /** Slide transition configuration */\n slideTransition?: Transition;\n /** Image transition configuration */\n imageTransition?: Transition;\n };\n /** Touch interaction configuration */\n touch?: {\n /** Enable/disable touch interactions */\n enabled?: boolean;\n /** Minimum distance to trigger slide change */\n threshold?: number;\n /** Minimum velocity for quick swipe */\n velocityThreshold?: number;\n /** How much to dampen the drag */\n dampingFactor?: number;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for slide change */\n onSlideChange?: (index: number) => void;\n /** Custom handler for auto-play state change */\n onAutoPlayChange?: (isPlaying: boolean) => void;\n /** Custom handler for user interaction */\n onUserInteraction?: () => void;\n /** Custom handler for image load */\n onImageLoad?: (slideIndex: number) => void;\n /** Custom handler for image error */\n onImageError?: (slideIndex: number) => void;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable auto-play */\n disableAutoPlay?: boolean;\n /** Initial slide index */\n initialSlide?: number;\n /** Custom ARIA labels */\n ariaLabels?: {\n carousel?: string;\n slide?: (slideIndex: number, totalSlides: number) => string;\n navigation?: string;\n indicator?: (slideIndex: number, slideTitle: string) => string;\n };\n };\n};\n\n/**\n * Props for the AboutWallets component\n */\nexport interface AboutWalletsProps {\n /** Additional CSS classes */\n className?: string;\n /** Customization options */\n customization?: AboutWalletsCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultSection = forwardRef<HTMLElement, SectionProps>(({ children, className, ...props }, ref) => (\n <section ref={ref} className={cn('novacon:relative novacon:m-[-16px]', className)} {...props}>\n {children}\n </section>\n));\nDefaultSection.displayName = 'DefaultSection';\n\nconst DefaultSlideContainer: React.FC<SlideContainerProps> = ({ children, className, ...props }) => (\n <div className={cn('novacon:relative novacon:z-1 novacon:overflow-hidden novacon:h-full', className)} {...props}>\n <StarsBackground starsCount={250} />\n <div\n className=\"novacon:absolute novacon:inset-0 novacon:z-1 novacon:bg-[radial-gradient(ellipse_80%_80%_at_50%_-20%,rgba(120,119,198,0.15),rgba(255,255,255,0))]\"\n aria-hidden=\"true\"\n />\n\n <div className=\"novacon:relative novacon:z-2 novacon:h-full\">{children}</div>\n </div>\n);\n\nconst DefaultImageSection: React.FC<ImageSectionProps> = ({\n slide,\n imageLoaded,\n onImageLoad,\n onImageError,\n slideIndex,\n className,\n labels,\n}) => (\n <div className={cn('novacon:flex novacon:justify-center novacon:relative novacon:pt-4', className)}>\n <AnimatePresence mode=\"wait\">\n <motion.div\n key={`image-${slideIndex}`}\n variants={DEFAULT_IMAGE_VARIANTS}\n initial=\"initial\"\n animate=\"animate\"\n exit=\"exit\"\n transition={ANIMATION_CONFIG.imageTransition}\n className=\"novacon:relative\"\n >\n <div className=\"novacon:relative\">\n <img\n src={slide.image}\n alt={labels[slide.titleKey as string]}\n width={250}\n height={250}\n className={cn(\n 'novacon:rounded-full novacon:transition-opacity novacon:duration-300',\n 'novacon:object-cover',\n imageLoaded ? 'novacon:opacity-100' : 'novacon:opacity-0',\n )}\n style={{ width: 250, height: 250 }}\n onLoad={onImageLoad}\n onError={onImageError}\n loading=\"eager\"\n decoding=\"async\"\n />\n\n {!imageLoaded && (\n <div\n className=\"novacon:absolute novacon:inset-0 novacon:bg-[var(--tuwa-bg-muted)] novacon:animate-pulse novacon:rounded-full novacon:flex novacon:items-center novacon:justify-center\"\n style={{ width: 250, height: 250 }}\n aria-hidden=\"true\"\n >\n <div className=\"novacon:w-12 novacon:h-12 novacon:border-2 novacon:border-[var(--tuwa-text-accent)] novacon:border-t-transparent novacon:rounded-full novacon:animate-spin\" />\n </div>\n )}\n </div>\n </motion.div>\n </AnimatePresence>\n </div>\n);\n\nconst DefaultContentSection: React.FC<ContentSectionProps> = ({ slide, slideIndex, className, labels }) => (\n <div className={cn('novacon:text-center novacon:relative novacon:p-4', className)}>\n <h2\n className=\"novacon:text-xl novacon:font-bold novacon:text-[var(--tuwa-text-primary)] novacon:mb-2\"\n id={`slide-title-${slideIndex}`}\n >\n {labels[slide.titleKey as string]}\n </h2>\n <p\n className=\"novacon:text-[var(--tuwa-text-secondary)] novacon:leading-relaxed\"\n aria-describedby={`slide-title-${slideIndex}`}\n >\n {labels[slide.descriptionKey as string]}\n </p>\n </div>\n);\n\nconst DefaultIndicator: React.FC<IndicatorProps> = ({ slide, index, isActive, onClick, className, labels }) => (\n <button\n onClick={onClick}\n className={cn(\n 'novacon:cursor-pointer novacon:h-2 novacon:rounded-full novacon:transition-all novacon:duration-300',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-text-accent)] novacon:focus:ring-offset-2',\n 'novacon:bg-[var(--tuwa-border-primary)] novacon:w-2 novacon:hover:bg-[var(--tuwa-text-accent)]',\n {\n 'novacon:bg-[var(--tuwa-text-accent)] novacon:w-6': isActive,\n },\n className,\n )}\n role=\"tab\"\n aria-selected={isActive}\n aria-controls={`slide-${index}`}\n aria-label={`Go to slide ${index + 1}: ${labels[slide.titleKey as string]}`}\n tabIndex={isActive ? 0 : -1}\n />\n);\n\nconst DefaultNavigation: React.FC<NavigationProps> = ({ slides, currentSlide, onSlideChange, className, labels }) => (\n <nav\n className={cn(\n 'novacon:flex novacon:justify-center novacon:space-x-2 novacon:mt-6 novacon:relative novacon:z-3 novacon:mx-4 novacon:mb-4',\n className,\n )}\n role=\"tablist\"\n aria-label={`${labels.aboutWallets} navigation`}\n >\n <div\n className=\"novacon:absolute novacon:left-1/2 novacon:top-1/2 novacon:transform novacon:-translate-x-1/2 novacon:-translate-y-1/2 novacon:z-1 novacon:h-[2px] novacon:w-full novacon:bg-[var(--tuwa-border-primary)]\"\n aria-hidden=\"true\"\n />\n <div className=\"novacon:flex novacon:gap-2 novacon:px-4 novacon:bg-[var(--tuwa-bg-primary)] novacon:relative novacon:z-2\">\n {slides.map((slide, index) => (\n <DefaultIndicator\n key={slide.id}\n slide={slide}\n index={index}\n isActive={currentSlide === index}\n onClick={() => onSlideChange(index)}\n labels={labels}\n />\n ))}\n </div>\n </nav>\n);\n\nconst DefaultSlide: React.FC<SlideProps> = ({\n slide,\n slideIndex,\n totalSlides,\n direction,\n imageLoadedStates,\n onImageLoad,\n onImageError,\n className,\n labels,\n slideVariants = DEFAULT_SLIDE_VARIANTS,\n slideTransition = ANIMATION_CONFIG.slideTransition,\n}) => (\n <motion.div\n key={slideIndex}\n custom={direction}\n variants={slideVariants}\n initial=\"enter\"\n animate=\"center\"\n exit=\"exit\"\n transition={slideTransition}\n className={cn('novacon:flex novacon:flex-col novacon:justify-start novacon:w-full novacon:h-full', className)}\n role=\"tabpanel\"\n aria-label={`Slide ${slideIndex + 1} of ${totalSlides}`}\n >\n <DefaultImageSection\n slide={slide}\n imageLoaded={imageLoadedStates[slideIndex] || false}\n onImageLoad={() => onImageLoad(slideIndex)}\n onImageError={() => onImageError(slideIndex)}\n slideIndex={slideIndex}\n labels={labels}\n />\n <DefaultContentSection slide={slide} slideIndex={slideIndex} labels={labels} />\n </motion.div>\n);\n\nconst DefaultStatus: React.FC<StatusProps> = ({\n currentSlide,\n totalSlides,\n currentSlideData,\n isAutoPlaying,\n className,\n labels,\n}) => (\n <div className={cn('novacon:sr-only', className)} aria-live=\"polite\" role=\"status\">\n {`Slide ${currentSlide + 1} of ${totalSlides}: ${labels[currentSlideData.titleKey as string]}`}\n {isAutoPlaying ? ' (Auto-playing)' : ' (Paused)'}\n </div>\n);\n\n/**\n * Educational carousel component about wallet functionality with comprehensive customization and touch support.\n *\n * This component provides an interactive slideshow explaining wallet benefits:\n * - Animated slide transitions with Framer Motion\n * - Touch/swipe gestures for mobile navigation\n * - Keyboard navigation support for accessibility\n * - Auto-play functionality with pause on user interaction\n * - Internationalization support with translation keys\n * - WCAG compliant with proper ARIA labels and semantics\n * - Responsive design with embedded base64 images\n * - Visual indicators for current slide position\n * - Full customization of all child components\n * - Performance-optimized with memoized calculations\n *\n * @example Basic usage\n * ```tsx\n * <AboutWallets />\n * ```\n */\nexport const AboutWallets = forwardRef<HTMLElement, AboutWalletsProps>(({ className, customization }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract customization options\n const slidesConfig = customization?.slidesConfig ?? DEFAULT_SLIDES_CONFIG;\n const slideVariants = customization?.variants?.slide ?? DEFAULT_SLIDE_VARIANTS;\n const {\n Section: CustomSection = DefaultSection,\n SlideContainer: CustomSlideContainer = DefaultSlideContainer,\n Slide: CustomSlide = DefaultSlide,\n Navigation: CustomNavigation = DefaultNavigation,\n Status: CustomStatus = DefaultStatus,\n } = customization?.components ?? {};\n\n const { disableAutoPlay = false, initialSlide = 0, ariaLabels } = customization?.config ?? {};\n\n const touchConfig = { enabled: true, ...TOUCH_CONFIG, ...customization?.touch };\n const animationConfig = { ...ANIMATION_CONFIG, ...customization?.animation };\n const customHandlers = customization?.handlers;\n\n // State management\n const [currentSlide, setCurrentSlide] = useState(initialSlide);\n const [direction, setDirection] = useState<SlideDirection>(0);\n const [isAutoPlaying, setIsAutoPlaying] = useState(!disableAutoPlay);\n const [userInteracted, setUserInteracted] = useState(false);\n const [imageLoadedStates, setImageLoadedStates] = useState<Record<number, boolean>>({});\n const [touchState, setTouchState] = useState<TouchState>({\n isDragging: false,\n startX: 0,\n currentX: 0,\n threshold: touchConfig.threshold,\n });\n\n // Refs for cleanup\n const autoPlayIntervalRef = useRef<number | null>(null);\n const resumeTimeoutRef = useRef<number | null>(null);\n\n /**\n * Navigate to a specific slide with proper direction calculation\n */\n const goToSlide = useCallback(\n (index: number) => {\n if (index === currentSlide || index < 0 || index >= slidesConfig.length) return;\n\n const newDirection: SlideDirection = index > currentSlide ? 1 : -1;\n setDirection(newDirection);\n setCurrentSlide(index);\n setUserInteracted(true);\n setIsAutoPlaying(false);\n\n customHandlers?.onSlideChange?.(index);\n customHandlers?.onUserInteraction?.();\n },\n [currentSlide, slidesConfig.length, customHandlers],\n );\n\n /**\n * Navigate to the next slide in sequence\n */\n const goToNextSlide = useCallback(() => {\n const nextIndex = (currentSlide + 1) % slidesConfig.length;\n goToSlide(nextIndex);\n }, [currentSlide, slidesConfig.length, goToSlide]);\n\n /**\n * Navigate to the previous slide in sequence\n */\n const goToPreviousSlide = useCallback(() => {\n const prevIndex = currentSlide === 0 ? slidesConfig.length - 1 : currentSlide - 1;\n goToSlide(prevIndex);\n }, [currentSlide, slidesConfig.length, goToSlide]);\n\n /**\n * Handle keyboard navigation for accessibility\n */\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent) => {\n switch (event.key) {\n case 'ArrowLeft':\n case 'ArrowUp':\n event.preventDefault();\n goToPreviousSlide();\n break;\n case 'ArrowRight':\n case 'ArrowDown':\n event.preventDefault();\n goToNextSlide();\n break;\n case 'Home':\n event.preventDefault();\n goToSlide(0);\n break;\n case 'End':\n event.preventDefault();\n goToSlide(slidesConfig.length - 1);\n break;\n case ' ':\n case 'Enter':\n event.preventDefault();\n setIsAutoPlaying((prev) => {\n const newValue = !prev;\n customHandlers?.onAutoPlayChange?.(newValue);\n return newValue;\n });\n break;\n }\n },\n [goToPreviousSlide, goToNextSlide, goToSlide, slidesConfig.length, customHandlers],\n );\n\n /**\n * Handle image loading by slide index\n */\n const handleImageLoad = useCallback(\n (slideIndex: number) => {\n setImageLoadedStates((prev) => ({\n ...prev,\n [slideIndex]: true,\n }));\n customHandlers?.onImageLoad?.(slideIndex);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customHandlers?.onImageLoad],\n );\n\n /**\n * Handle image error by slide index\n */\n const handleImageError = useCallback(\n (slideIndex: number) => {\n console.warn(`Failed to load slide image for slide ${slideIndex + 1}`);\n setImageLoadedStates((prev) => ({\n ...prev,\n [slideIndex]: true,\n }));\n customHandlers?.onImageError?.(slideIndex);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customHandlers?.onImageError],\n );\n\n /**\n * Auto-play functionality\n */\n useEffect(() => {\n if (autoPlayIntervalRef.current !== null) {\n window.clearInterval(autoPlayIntervalRef.current);\n autoPlayIntervalRef.current = null;\n }\n\n if (!isAutoPlaying || userInteracted || disableAutoPlay) return;\n\n autoPlayIntervalRef.current = window.setInterval(() => {\n setCurrentSlide((prev) => {\n const next = (prev + 1) % slidesConfig.length;\n setDirection(1);\n return next;\n });\n }, animationConfig.autoPlayInterval);\n\n return () => {\n if (autoPlayIntervalRef.current !== null) {\n window.clearInterval(autoPlayIntervalRef.current);\n autoPlayIntervalRef.current = null;\n }\n };\n }, [isAutoPlaying, userInteracted, disableAutoPlay, slidesConfig.length, animationConfig.autoPlayInterval]);\n\n /**\n * Resume auto-play after user interaction\n */\n useEffect(() => {\n if (resumeTimeoutRef.current !== null) {\n window.clearTimeout(resumeTimeoutRef.current);\n resumeTimeoutRef.current = null;\n }\n\n if (!userInteracted) return;\n\n resumeTimeoutRef.current = window.setTimeout(() => {\n setUserInteracted(false);\n setIsAutoPlaying(true);\n }, animationConfig.resumeDelay);\n\n return () => {\n if (resumeTimeoutRef.current !== null) {\n window.clearTimeout(resumeTimeoutRef.current);\n resumeTimeoutRef.current = null;\n }\n };\n }, [userInteracted, animationConfig.resumeDelay]);\n\n /**\n * Cleanup on unmount\n */\n useEffect(() => {\n return () => {\n if (autoPlayIntervalRef.current !== null) {\n window.clearInterval(autoPlayIntervalRef.current);\n }\n if (resumeTimeoutRef.current !== null) {\n window.clearTimeout(resumeTimeoutRef.current);\n }\n };\n }, []);\n\n const currentSlideData = slidesConfig[currentSlide];\n\n return (\n <CustomSection\n ref={ref}\n className={customization?.classNames?.section?.() ?? className}\n role=\"region\"\n aria-label={ariaLabels?.carousel ?? labels.aboutWallets}\n aria-roledescription=\"carousel\"\n onKeyDown={handleKeyDown}\n tabIndex={0}\n >\n <CustomSlideContainer\n className={customization?.classNames?.slideContainer?.()}\n aria-live=\"polite\"\n aria-atomic={false}\n >\n <div\n className=\"novacon:h-full novacon:touch-pan-x\"\n onTouchStart={(e) => {\n if (!touchConfig.enabled) return;\n const touch = e.touches[0];\n setTouchState((prev) => ({\n ...prev,\n isDragging: true,\n startX: touch.clientX,\n currentX: touch.clientX,\n }));\n customHandlers?.onUserInteraction?.();\n }}\n onTouchMove={(e) => {\n if (!touchConfig.enabled || !touchState.isDragging) return;\n const touch = e.touches[0];\n setTouchState((prev) => ({\n ...prev,\n currentX: touch.clientX,\n }));\n }}\n onTouchEnd={() => {\n if (!touchConfig.enabled || !touchState.isDragging) return;\n\n const deltaX = touchState.currentX - touchState.startX;\n const shouldChangeSlide = Math.abs(deltaX) > touchConfig.threshold;\n\n if (shouldChangeSlide) {\n if (deltaX > 0) {\n goToPreviousSlide();\n } else {\n goToNextSlide();\n }\n }\n\n setTouchState((prev) => ({\n ...prev,\n isDragging: false,\n startX: 0,\n currentX: 0,\n }));\n }}\n >\n <AnimatePresence initial={false} custom={direction} mode=\"wait\">\n <CustomSlide\n key={currentSlide}\n slide={currentSlideData}\n slideIndex={currentSlide}\n totalSlides={slidesConfig.length}\n direction={direction}\n imageLoadedStates={imageLoadedStates}\n onImageLoad={handleImageLoad}\n onImageError={handleImageError}\n slideVariants={slideVariants}\n slideTransition={animationConfig.slideTransition}\n className={customization?.classNames?.slide?.({\n slideIndex: currentSlide,\n totalSlides: slidesConfig.length,\n })}\n labels={labels}\n />\n </AnimatePresence>\n </div>\n </CustomSlideContainer>\n\n <CustomNavigation\n slides={slidesConfig}\n currentSlide={currentSlide}\n onSlideChange={goToSlide}\n className={customization?.classNames?.navigation?.()}\n labels={labels}\n />\n\n <CustomStatus\n currentSlide={currentSlide}\n totalSlides={slidesConfig.length}\n currentSlideData={currentSlideData}\n isAutoPlaying={isAutoPlaying}\n className={customization?.classNames?.status?.()}\n labels={labels}\n />\n\n <div className=\"novacon:sr-only\">\n Use arrow keys to navigate slides, Space or Enter to pause/resume auto-play, Home to go to first slide, End to\n go to last slide. Swipe left or right to navigate on touch devices.\n </div>\n </CustomSection>\n );\n});\n\nAboutWallets.displayName = 'AboutWallets';\n","/**\n * @file Connecting component with comprehensive customization options and connection status display.\n */\n\nimport { CheckCircleIcon, ExclamationCircleIcon } from '@heroicons/react/24/solid';\nimport { cn } from '@tuwaio/nova-core';\nimport { formatWalletName, OrbitAdapter } from '@tuwaio/orbit-core';\nimport React, { ComponentType, forwardRef, memo, useEffect, useMemo, useRef } from 'react';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { WalletIcon } from '../WalletIcon';\nimport { GroupedConnector } from './ConnectModal';\n\n// --- Types ---\n\n/**\n * Connection states\n */\nexport type ConnectionState = 'connecting' | 'success' | 'error';\n\n/**\n * Connection status data\n */\nexport interface ConnectingStatusData {\n /** Connection state */\n state: ConnectionState;\n /** Display message */\n message: string;\n /** Error message if any */\n errorMessage: string | null;\n /** Currently active connector */\n activeConnector: string | undefined;\n /** Selected adapter */\n selectedAdapter: OrbitAdapter | undefined;\n /** Current connector configuration */\n currentConnector: GroupedConnector | null;\n /** Whether to show detailed error */\n showDetailedError: boolean;\n /** Raw error object */\n rawError: unknown;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n 'aria-live'?: 'polite' | 'assertive' | 'off';\n 'aria-atomic'?: boolean;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLElement>;\n\ntype StatusContainerProps = {\n className?: string;\n children: React.ReactNode;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype SpinnerProps = {\n className?: string;\n role?: string;\n 'aria-label'?: string;\n 'aria-describedby'?: string;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype StatusIconProps = {\n className?: string;\n role?: string;\n 'aria-label'?: string;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype WalletIconContainerProps = {\n className?: string;\n children: React.ReactNode;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype MessageContainerProps = {\n className?: string;\n children: React.ReactNode;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype StatusMessageProps = {\n className?: string;\n children: React.ReactNode;\n id?: string;\n role?: string;\n 'aria-level'?: number;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLHeadingElement>;\n\ntype ErrorMessageProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-describedby'?: string;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLParagraphElement>;\n\ntype ErrorDetailsProps = {\n className?: string;\n children: React.ReactNode;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDetailsElement>;\n\ntype LoadingPlaceholderProps = {\n className?: string;\n role?: string;\n 'aria-label'?: string;\n statusData: ConnectingStatusData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * Customization options for Connecting component\n */\nexport type ConnectingCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom status container */\n StatusContainer?: ComponentType<StatusContainerProps>;\n /** Custom loading spinner */\n Spinner?: ComponentType<SpinnerProps>;\n /** Custom status icon */\n StatusIcon?: ComponentType<StatusIconProps>;\n /** Custom wallet icon container */\n WalletIconContainer?: ComponentType<WalletIconContainerProps>;\n /** Custom message container */\n MessageContainer?: ComponentType<MessageContainerProps>;\n /** Custom status message */\n StatusMessage?: ComponentType<StatusMessageProps>;\n /** Custom error message */\n ErrorMessage?: ComponentType<ErrorMessageProps>;\n /** Custom error details */\n ErrorDetails?: ComponentType<ErrorDetailsProps>;\n /** Custom loading placeholder */\n LoadingPlaceholder?: ComponentType<LoadingPlaceholderProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate status container classes */\n statusContainer?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate spinner classes */\n spinner?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate status icon classes */\n statusIcon?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate wallet icon container classes */\n walletIconContainer?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate message container classes */\n messageContainer?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate status message classes */\n statusMessage?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate error message classes */\n errorMessage?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate error details classes */\n errorDetails?: (params: { statusData: ConnectingStatusData }) => string;\n /** Function to generate loading placeholder classes */\n loadingPlaceholder?: (params: { statusData: ConnectingStatusData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for state change */\n onStateChange?: (state: ConnectionState, statusData: ConnectingStatusData) => void;\n /** Custom handler for error occurrence */\n onError?: (error: unknown, statusData: ConnectingStatusData) => void;\n /** Custom handler for successful connection */\n onSuccess?: (statusData: ConnectingStatusData) => void;\n /** Custom handler for connection start */\n onConnectingStart?: (statusData: ConnectingStatusData) => void;\n /** Custom cleanup handler called on unmount */\n onCleanup?: (statusData: ConnectingStatusData) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: string;\n spinner?: string;\n successIcon?: string;\n errorIcon?: string;\n loading?: string;\n };\n /** Custom animation settings */\n animation?: {\n spinnerDuration?: string;\n transitionDuration?: string;\n };\n /** Custom icon settings */\n icons?: {\n showSuccessIcon?: boolean;\n showErrorIcon?: boolean;\n customSuccessIcon?: ComponentType<{ className?: string }>;\n customErrorIcon?: ComponentType<{ className?: string }>;\n };\n };\n};\n\n/**\n * Connection status component props interface\n */\nexport interface ConnectingProps {\n /** Currently active connector identifier */\n activeConnector: string | undefined;\n /** Selected orbit adapter for the connection */\n selectedAdapter: OrbitAdapter | undefined;\n /** Array of available wallet connectors */\n connectors: GroupedConnector[];\n /** Whether the wallet connection is successfully established */\n isConnected: boolean;\n /** Optional custom error message to display */\n customErrorMessage?: string;\n /** Whether to show detailed error information */\n showDetailedError?: boolean;\n /** Custom CSS classes for styling the container */\n className?: string;\n /** Customization options */\n customization?: ConnectingCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLElement, ContainerProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { statusData: _statusData, ...restProps } = props;\n return (\n <section ref={ref} className={className} {...restProps}>\n {children}\n </section>\n );\n});\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultStatusContainer = forwardRef<HTMLDivElement, StatusContainerProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ children, className, statusData: _statusData }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n ),\n);\nDefaultStatusContainer.displayName = 'DefaultStatusContainer';\n\nconst DefaultSpinner = forwardRef<HTMLDivElement, SpinnerProps>(({ className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { statusData: _statusData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n <span className=\"novacon:sr-only\">Loading...</span>\n </div>\n );\n});\nDefaultSpinner.displayName = 'DefaultSpinner';\n\nconst DefaultStatusIcon = forwardRef<HTMLDivElement, StatusIconProps>(({ className, statusData, ...props }, ref) => {\n const isSuccess = statusData.state === 'success';\n const IconComponent = isSuccess ? CheckCircleIcon : ExclamationCircleIcon;\n\n return (\n <div ref={ref} className={className} {...props}>\n <IconComponent className=\"novacon:w-6 novacon:h-6 novacon:text-white\" aria-hidden=\"true\" />\n </div>\n );\n});\nDefaultStatusIcon.displayName = 'DefaultStatusIcon';\n\nconst DefaultWalletIconContainer = forwardRef<HTMLDivElement, WalletIconContainerProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ children, className, statusData: _statusData }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n ),\n);\nDefaultWalletIconContainer.displayName = 'DefaultWalletIconContainer';\n\nconst DefaultMessageContainer = forwardRef<HTMLDivElement, MessageContainerProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ children, className, statusData: _statusData }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n ),\n);\nDefaultMessageContainer.displayName = 'DefaultMessageContainer';\n\nconst DefaultStatusMessage = forwardRef<HTMLHeadingElement, StatusMessageProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { statusData: _statusData, ...restProps } = props;\n return (\n <h2 ref={ref} className={className} {...restProps}>\n {children}\n </h2>\n );\n },\n);\nDefaultStatusMessage.displayName = 'DefaultStatusMessage';\n\nconst DefaultErrorMessage = forwardRef<HTMLParagraphElement, ErrorMessageProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { statusData: _statusData, ...restProps } = props;\n return (\n <p ref={ref} className={className} {...restProps}>\n {children}\n </p>\n );\n },\n);\nDefaultErrorMessage.displayName = 'DefaultErrorMessage';\n\nconst DefaultErrorDetails = forwardRef<HTMLDetailsElement, ErrorDetailsProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ children, className, statusData: _statusData }, ref) => (\n <details ref={ref} className={className}>\n {children}\n </details>\n ),\n);\nDefaultErrorDetails.displayName = 'DefaultErrorDetails';\n\nconst DefaultLoadingPlaceholder = forwardRef<HTMLDivElement, LoadingPlaceholderProps>(\n ({ className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { statusData: _statusData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n <div className=\"novacon:animate-pulse novacon:rounded-xl novacon:h-32 novacon:w-32 novacon:bg-[var(--tuwa-bg-muted)]\" />\n <div className=\"novacon:animate-pulse novacon:rounded-xl novacon:h-6 novacon:w-48 novacon:bg-[var(--tuwa-bg-muted)]\" />\n </div>\n );\n },\n);\nDefaultLoadingPlaceholder.displayName = 'DefaultLoadingPlaceholder';\n\n/**\n * Connection status display component for wallet connection flow\n *\n * This component provides comprehensive visual feedback during wallet connection:\n * - Animated loading spinner for connection in progress\n * - Success state with checkmark icon for completed connections\n * - Error state with warning icon and detailed error messages\n * - Fully internationalized text content with translation support\n * - WCAG compliant accessibility with proper ARIA labels and live regions\n * - Responsive design that adapts to different screen sizes\n * - Visual status indicators with semantic colors and icons\n * - Screen reader announcements for state changes\n *\n * The component automatically detects connection state and displays appropriate\n * visual feedback with proper semantic markup for accessibility tools.\n *\n * @param activeConnector - Identifier of the currently connecting wallet\n * @param selectedAdapter - Orbit adapter instance for the connection\n * @param connectors - Array of available wallet connector options\n * @param isConnected - Boolean flag indicating successful connection\n * @param customErrorMessage - Optional custom error message override\n * @param showDetailedError - Flag to show detailed error information\n * @returns JSX element displaying connection status with visual feedback\n *\n * @example\n * ```tsx\n * <Connecting\n * activeConnector=\"metamask\"\n * selectedAdapter={ethereumAdapter}\n * connectors={availableConnectors}\n * isConnected={false}\n * />\n * ```\n *\n * @example\n * ```tsx\n * // With custom error handling\n * <Connecting\n * activeConnector=\"walletconnect\"\n * selectedAdapter={polygonAdapter}\n * connectors={connectors}\n * isConnected={false}\n * customErrorMessage=\"Custom connection error occurred\"\n * showDetailedError={true}\n * />\n * ```\n *\n * @example\n * ```tsx\n * // Successful connection state\n * <Connecting\n * activeConnector=\"phantom\"\n * selectedAdapter={solanaAdapter}\n * connectors={solanaConnectors}\n * isConnected={true}\n * />\n * ```\n *\n * @public\n */\nexport const Connecting = memo(\n forwardRef<HTMLDivElement, ConnectingProps>(\n (\n {\n activeConnector,\n selectedAdapter,\n connectors,\n isConnected,\n customErrorMessage,\n showDetailedError = false,\n className,\n customization,\n },\n ref,\n ) => {\n const labels = useNovaConnectLabels();\n const { walletConnectionError } = useNovaConnect();\n\n const isMountedRef = useRef(true);\n const prevStateRef = useRef<ConnectionState | null>(null);\n const prevStatusDataRef = useRef<ConnectingStatusData | null>(null);\n const cleanupCalled = useRef(false);\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n StatusContainer: CustomStatusContainer = DefaultStatusContainer,\n Spinner: CustomSpinner = DefaultSpinner,\n StatusIcon: CustomStatusIcon = DefaultStatusIcon,\n WalletIconContainer: CustomWalletIconContainer = DefaultWalletIconContainer,\n MessageContainer: CustomMessageContainer = DefaultMessageContainer,\n StatusMessage: CustomStatusMessage = DefaultStatusMessage,\n ErrorMessage: CustomErrorMessage = DefaultErrorMessage,\n ErrorDetails: CustomErrorDetails = DefaultErrorDetails,\n LoadingPlaceholder: CustomLoadingPlaceholder = DefaultLoadingPlaceholder,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Find the current connector configuration\n */\n const currentConnector = useMemo(() => {\n if (!activeConnector) {\n performDefaultCleanup();\n return null;\n }\n return connectors.find((connector) => formatWalletName(connector.name) === activeConnector) || null;\n }, [connectors, activeConnector]);\n\n /**\n * Determine current connection state\n */\n const connectionState = useMemo((): ConnectionState => {\n if (walletConnectionError || customErrorMessage) return 'error';\n if (isConnected) return 'success';\n return 'connecting';\n }, [walletConnectionError, customErrorMessage, isConnected]);\n\n /**\n * Memoized display message\n */\n const displayMessage = useMemo(() => {\n switch (connectionState) {\n case 'error':\n return customErrorMessage || labels.connectionError;\n case 'success':\n return labels.connectedSuccessfully;\n case 'connecting':\n default:\n return activeConnector ? `${labels.connectingTo} ${activeConnector}...` : labels.connectingEllipsis;\n }\n }, [connectionState, customErrorMessage, labels, activeConnector]);\n\n /**\n * Memoized error message\n */\n const errorMessage = useMemo(() => {\n if (connectionState !== 'error') return null;\n\n if (customErrorMessage && showDetailedError) {\n return customErrorMessage;\n }\n\n return labels.cannotConnectWallet;\n }, [connectionState, customErrorMessage, showDetailedError, labels]);\n\n /**\n * Memoized status data\n */\n const statusData = useMemo(\n (): ConnectingStatusData => ({\n state: connectionState,\n message: displayMessage,\n errorMessage,\n activeConnector,\n selectedAdapter,\n currentConnector,\n showDetailedError,\n rawError: walletConnectionError,\n }),\n [\n connectionState,\n displayMessage,\n errorMessage,\n activeConnector,\n selectedAdapter,\n currentConnector,\n showDetailedError,\n walletConnectionError,\n ],\n );\n\n /**\n * Memoized container classes\n */\n const containerClasses = useMemo(\n () =>\n customization?.classNames?.container?.({ statusData }) ??\n cn(\n 'novacon:flex novacon:flex-col novacon:gap-4 novacon:items-center novacon:justify-center novacon:w-full',\n className,\n ),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.container, statusData, className],\n );\n\n /**\n * Memoized status container classes based on connection state\n */\n const statusContainerClasses = useMemo(() => {\n if (customization?.classNames?.statusContainer) {\n return customization.classNames.statusContainer({ statusData });\n }\n\n const baseClasses = [\n 'novacon:relative novacon:flex novacon:items-center novacon:justify-center',\n 'novacon:min-w-[110px] novacon:min-h-[110px] novacon:md:min-w-[150px] novacon:md:min-h-[150px]',\n 'novacon:border-2 novacon:rounded-full',\n 'novacon:p-4 novacon:md:p-6',\n 'novacon:transition-all novacon:duration-300 novacon:ease-in-out',\n ];\n\n const stateClasses = {\n error: [\n 'novacon:border-[var(--tuwa-error-text)]',\n 'novacon:bg-[var(--tuwa-error-text)] novacon:bg-opacity-5',\n ],\n success: [\n 'novacon:border-[var(--tuwa-success-text)]',\n 'novacon:bg-[var(--tuwa-success-text)] novacon:bg-opacity-5',\n ],\n connecting: ['novacon:border-[var(--tuwa-border-primary)]', 'novacon:bg-[var(--tuwa-bg-primary)]'],\n };\n\n return cn(baseClasses, stateClasses[statusData.state]);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.statusContainer, statusData]);\n\n const performDefaultCleanup = () => {\n if (cleanupCalled.current) return;\n\n cleanupCalled.current = true;\n\n isMountedRef.current = false;\n prevStateRef.current = null;\n prevStatusDataRef.current = null;\n\n if (typeof window !== 'undefined') {\n const element = document.querySelector('[data-connecting-component]');\n if (element) {\n element.getAnimations?.().forEach((animation) => animation.cancel());\n }\n }\n };\n\n useEffect(() => {\n if (!isMountedRef.current) return;\n\n if (prevStateRef.current !== connectionState) {\n customHandlers?.onStateChange?.(connectionState, statusData);\n\n if (connectionState === 'error') {\n customHandlers?.onError?.(walletConnectionError, statusData);\n } else if (connectionState === 'success') {\n customHandlers?.onSuccess?.(statusData);\n } else if (connectionState === 'connecting') {\n customHandlers?.onConnectingStart?.(statusData);\n }\n\n prevStateRef.current = connectionState;\n }\n\n prevStatusDataRef.current = statusData;\n }, [connectionState, statusData, customHandlers, walletConnectionError]);\n\n useEffect(() => {\n isMountedRef.current = true;\n cleanupCalled.current = false;\n\n // Cleanup function\n return () => {\n if (customHandlers?.onCleanup && prevStatusDataRef.current) {\n try {\n customHandlers.onCleanup(prevStatusDataRef.current);\n } catch (error) {\n console.warn('Error in custom cleanup handler:', error);\n }\n }\n performDefaultCleanup();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onCleanup]);\n\n useEffect(() => {\n return () => {\n if (!cleanupCalled.current && customHandlers?.onCleanup && prevStatusDataRef.current) {\n try {\n customHandlers.onCleanup(prevStatusDataRef.current);\n } catch (error) {\n console.warn('Error in custom cleanup handler on dependency change:', error);\n }\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onCleanup]);\n\n // Early return for missing required data\n if (!selectedAdapter || !activeConnector || !currentConnector) {\n return (\n <CustomLoadingPlaceholder\n ref={ref}\n className={\n customization?.classNames?.loadingPlaceholder?.({ statusData }) ??\n cn(\n 'novacon:flex novacon:flex-col novacon:gap-4 novacon:items-center novacon:justify-center novacon:w-full novacon:py-8',\n )\n }\n role=\"status\"\n aria-label={customConfig?.ariaLabels?.loading ?? labels.loading}\n statusData={statusData}\n data-connecting-component=\"true\"\n />\n );\n }\n\n const containerAriaLabel = customConfig?.ariaLabels?.container ?? `Connection status: ${displayMessage}`;\n\n return (\n <CustomContainer\n ref={ref as React.ForwardedRef<HTMLElement>}\n className={containerClasses}\n role=\"status\"\n aria-label={containerAriaLabel}\n aria-live=\"polite\"\n aria-atomic={true}\n statusData={statusData}\n data-connecting-component=\"true\"\n >\n {/* Connection Status Container */}\n <CustomStatusContainer className={statusContainerClasses} statusData={statusData}>\n {/* Loading Spinner for Connecting State */}\n {connectionState === 'connecting' && (\n <CustomSpinner\n className={\n customization?.classNames?.spinner?.({ statusData }) ??\n cn(\n 'novacon:absolute novacon:animate-spin novacon:rounded-full novacon:-inset-[2px]',\n 'novacon:w-[calc(100%_+_4px)] novacon:h-[calc(100%_+_4px)]',\n 'novacon:border-2 novacon:border-[var(--tuwa-pending-text)]',\n 'novacon:border-t-transparent',\n )\n }\n role=\"progressbar\"\n aria-label={customConfig?.ariaLabels?.spinner ?? labels.connecting}\n aria-describedby=\"connecting-message\"\n statusData={statusData}\n />\n )}\n\n {/* Success/Error Icons */}\n {(connectionState === 'success' || connectionState === 'error') && (\n <CustomStatusIcon\n className={\n customization?.classNames?.statusIcon?.({ statusData }) ??\n cn(\n 'novacon:absolute novacon:-top-2 novacon:-right-2 novacon:w-8 novacon:h-8 novacon:rounded-full novacon:flex novacon:items-center novacon:justify-center novacon:bg-[var(--tuwa-error-text)]',\n {\n 'novacon:bg-[var(--tuwa-success-text)]': connectionState === 'success',\n },\n )\n }\n role=\"img\"\n aria-label={\n connectionState === 'success'\n ? (customConfig?.ariaLabels?.successIcon ?? labels.successIcon)\n : (customConfig?.ariaLabels?.errorIcon ?? labels.errorIcon)\n }\n statusData={statusData}\n />\n )}\n\n {/* Wallet Icon */}\n <CustomWalletIconContainer\n className={\n customization?.classNames?.walletIconContainer?.({ statusData }) ??\n cn('novacon:[&_img]:w-[60px]! novacon:[&_img]:h-[auto]! novacon:md:[&_img]:w-[80px]!')\n }\n statusData={statusData}\n >\n <WalletIcon\n icon={currentConnector.icon}\n name={activeConnector}\n altText={`${activeConnector} ${labels.walletIcon}`}\n showLoading={connectionState === 'connecting'}\n />\n </CustomWalletIconContainer>\n </CustomStatusContainer>\n\n {/* Status Message */}\n <CustomMessageContainer\n className={\n customization?.classNames?.messageContainer?.({ statusData }) ??\n cn('novacon:text-center novacon:space-y-2 novacon:max-w-md')\n }\n statusData={statusData}\n >\n <CustomStatusMessage\n id=\"connecting-message\"\n className={\n customization?.classNames?.statusMessage?.({ statusData }) ??\n cn('novacon:text-lg novacon:font-semibold novacon:transition-colors novacon:duration-300', {\n 'novacon:text-[var(--tuwa-error-text)]': connectionState === 'error',\n 'novacon:text-[var(--tuwa-success-text)]': connectionState === 'success',\n 'novacon:text-[var(--tuwa-text-primary)]': connectionState === 'connecting',\n })\n }\n role=\"heading\"\n aria-level={2}\n statusData={statusData}\n >\n {displayMessage}\n </CustomStatusMessage>\n\n {/* Error Details */}\n {errorMessage && (\n <CustomErrorMessage\n className={\n customization?.classNames?.errorMessage?.({ statusData }) ??\n cn(\n 'novacon:text-sm novacon:text-[var(--tuwa-error-text)] novacon:text-center novacon:leading-relaxed',\n )\n }\n role=\"alert\"\n aria-describedby=\"connecting-message\"\n statusData={statusData}\n >\n {errorMessage}\n </CustomErrorMessage>\n )}\n\n {/* Additional Error Information */}\n {connectionState === 'error' && showDetailedError && walletConnectionError && (\n <CustomErrorDetails\n className={\n customization?.classNames?.errorDetails?.({ statusData }) ?? cn('novacon:mt-3 novacon:text-left')\n }\n statusData={statusData}\n >\n <summary className=\"novacon:text-sm novacon:text-[var(--tuwa-text-secondary)] novacon:cursor-pointer novacon:hover:text-[var(--tuwa-text-primary)] novacon:transition-colors\">\n {labels.copyRawError}\n </summary>\n <pre className=\"novacon:mt-2 novacon:p-3 novacon:bg-[var(--tuwa-bg-muted)] novacon:rounded-md novacon:text-xs novacon:font-mono novacon:text-[var(--tuwa-text-secondary)] novacon:overflow-auto novacon:max-h-32\">\n {JSON.stringify(walletConnectionError, null, 2)}\n </pre>\n </CustomErrorDetails>\n )}\n </CustomMessageContainer>\n\n {/* Screen Reader Announcements */}\n <div className=\"novacon:sr-only\" aria-live=\"assertive\" role=\"status\">\n {connectionState === 'connecting' && `${labels.connecting} ${activeConnector}`}\n {connectionState === 'success' && `${labels.connectedSuccessfully} ${activeConnector}`}\n {connectionState === 'error' && `${labels.connectionError} ${activeConnector}`}\n </div>\n\n {/* Hidden Content for Screen Readers */}\n <div className=\"novacon:sr-only\">\n <p>\n Wallet: {activeConnector}, Network: {selectedAdapter}, Status: {connectionState}\n </p>\n </div>\n </CustomContainer>\n );\n },\n ),\n);\n\nConnecting.displayName = 'Connecting';\n","/**\n * @file RecentBadge component with comprehensive customization options and animated gradient border.\n */\n\nimport { cn, isTouchDevice } from '@tuwaio/nova-core';\nimport { motion } from 'framer-motion';\nimport React, { ComponentType, forwardRef, memo, useCallback, useMemo } from 'react';\n\n// --- Types ---\n\n/**\n * Animation configuration for the gradient border effect\n */\nexport interface BadgeAnimationConfig {\n /** Animation duration in seconds */\n duration: number;\n /** Animation easing function - using valid framer-motion easing values */\n ease:\n | 'linear'\n | 'easeIn'\n | 'easeOut'\n | 'easeInOut'\n | 'circIn'\n | 'circOut'\n | 'circInOut'\n | 'backIn'\n | 'backOut'\n | 'backInOut'\n | 'anticipate';\n /** Whether animation should repeat infinitely */\n repeat: boolean;\n /** Initial background position */\n initialPosition: string;\n /** Final background position */\n finalPosition: string;\n}\n\n/**\n * Gradient configuration for the border effect\n */\nexport interface BadgeGradientConfig {\n /** Direction of the gradient (e.g., '90deg', '45deg') */\n direction: string;\n /** Color stops for the gradient */\n stops: Array<{\n /** Position percentage (0-100) */\n position: number;\n /** Color value (CSS color, CSS variable, or rgba) */\n color: string;\n }>;\n /** Background size for animation effect */\n backgroundSize: string;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n} & React.RefAttributes<HTMLSpanElement>;\n\ntype AnimatedGradientProps = {\n className?: string;\n animated: boolean;\n animationConfig: BadgeAnimationConfig;\n gradientConfig: BadgeGradientConfig;\n};\n\ntype BackgroundOverlayProps = {\n className?: string;\n};\n\ntype ContentProps = {\n className?: string;\n children: React.ReactNode;\n};\n\n/**\n * Customization options for RecentBadge component\n */\nexport type RecentBadgeCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom animated gradient component */\n AnimatedGradient?: ComponentType<AnimatedGradientProps>;\n /** Custom background overlay */\n BackgroundOverlay?: ComponentType<BackgroundOverlayProps>;\n /** Custom content wrapper */\n Content?: ComponentType<ContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { isTouch: boolean; animated: boolean }) => string;\n /** Function to generate animated gradient classes */\n animatedGradient?: () => string;\n /** Function to generate background overlay classes */\n backgroundOverlay?: () => string;\n /** Function to generate content classes */\n content?: () => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for animation start */\n onAnimationStart?: () => void;\n /** Custom handler for animation complete */\n onAnimationComplete?: () => void;\n /** Custom handler for component mount */\n onMount?: () => void;\n /** Custom handler for component unmount */\n onUnmount?: () => void;\n };\n /** Configuration options */\n config?: {\n /** Custom animation configuration */\n animation?: Partial<BadgeAnimationConfig>;\n /** Custom gradient configuration */\n gradient?: Partial<BadgeGradientConfig>;\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: string;\n };\n /** Touch device detection override */\n touchDevice?: boolean;\n };\n};\n\n/**\n * Props for the RecentBadge component\n */\nexport interface RecentBadgeProps {\n /** Custom CSS classes for styling the container */\n className?: string;\n /** Content to display inside the badge */\n children?: React.ReactNode;\n /** Whether the gradient animation should be enabled */\n animated?: boolean;\n /** Custom ARIA label for accessibility */\n 'aria-label'?: string;\n /** Customization options */\n customization?: RecentBadgeCustomization;\n}\n\n/**\n * Default animation configuration\n */\nconst defaultAnimationConfig: BadgeAnimationConfig = {\n duration: 4,\n ease: 'linear',\n repeat: true,\n initialPosition: '100%',\n finalPosition: '-100%',\n};\n\n/**\n * Default gradient configuration\n */\nconst defaultGradientConfig: BadgeGradientConfig = {\n direction: '90deg',\n stops: [\n { position: 0, color: 'rgba(255, 255, 255, 0)' },\n { position: 20, color: 'var(--tuwa-text-secondary)' },\n { position: 40, color: 'rgba(255, 255, 255, 0)' },\n ],\n backgroundSize: '200% 100%',\n};\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLSpanElement, ContainerProps>(({ children, className, ...props }, ref) => (\n <span ref={ref} className={className} {...props}>\n {children}\n </span>\n));\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultAnimatedGradient: React.FC<AnimatedGradientProps> = ({\n className,\n animated,\n animationConfig,\n gradientConfig,\n}) => {\n const gradientBackground = useMemo(() => {\n const stops = gradientConfig.stops.map((stop) => `${stop.color} ${stop.position}%`).join(', ');\n return `linear-gradient(${gradientConfig.direction}, ${stops})`;\n }, [gradientConfig.direction, gradientConfig.stops]);\n\n const animatedStyle = useMemo(\n () => ({\n background: gradientBackground,\n backgroundSize: gradientConfig.backgroundSize,\n }),\n [gradientBackground, gradientConfig.backgroundSize],\n );\n\n if (!animated) {\n return <span className={className} style={animatedStyle} />;\n }\n\n return (\n <motion.span\n className={className}\n style={animatedStyle}\n initial={{ backgroundPositionX: animationConfig.initialPosition }}\n animate={{ backgroundPositionX: animationConfig.finalPosition }}\n transition={{\n duration: animationConfig.duration,\n ease: animationConfig.ease,\n repeat: animationConfig.repeat ? Infinity : 0,\n }}\n />\n );\n};\n\nconst DefaultBackgroundOverlay: React.FC<BackgroundOverlayProps> = ({ className }) => <span className={className} />;\n\nconst DefaultContent: React.FC<ContentProps> = ({ children, className }) => (\n <span className={className}>{children}</span>\n);\n\n/**\n * Badge component with animated gradient border effect and comprehensive customization\n *\n * This component provides a visually appealing badge with:\n * - Animated gradient border effect with customizable timing and colors\n * - Touch-device responsive sizing for optimal mobile experience\n * - Full accessibility support with proper ARIA labeling\n * - Performance optimizations with memoized calculations\n * - Customizable animations and gradient configurations\n * - Full customization of all child components\n * - Proper semantic HTML structure\n *\n * Visual features:\n * - Smooth animated gradient border effect\n * - Touch-responsive sizing (smaller on touch devices)\n * - Customizable gradient colors and direction\n * - Configurable animation timing and easing\n * - Proper z-index layering for visual effects\n *\n * Accessibility features:\n * - Proper ARIA role and labels\n * - Screen reader friendly content structure\n * - Semantic HTML with appropriate roles\n * - Motion reduction respect (can be controlled via customization)\n *\n * @example Basic usage\n * ```tsx\n * <RecentBadge>Recent</RecentBadge>\n * ```\n *\n * @example With custom animation\n * ```tsx\n * <RecentBadge\n * animated={false}\n * customization={{\n * config: {\n * animation: {\n * duration: 2,\n * ease: 'easeInOut'\n * }\n * }\n * }}\n * >\n * Custom\n * </RecentBadge>\n * ```\n *\n * @example With full customization\n * ```tsx\n * <RecentBadge\n * customization={{\n * components: {\n * AnimatedGradient: CustomGradient,\n * Content: CustomContent\n * },\n * config: {\n * gradient: {\n * direction: '45deg',\n * stops: [\n * { position: 0, color: 'transparent' },\n * { position: 50, color: 'rgba(59, 130, 246, 0.8)' },\n * { position: 100, color: 'transparent' }\n * ]\n * }\n * }\n * }}\n * >\n * Premium\n * </RecentBadge>\n * ```\n */\nexport const RecentBadge = memo(\n forwardRef<HTMLSpanElement, RecentBadgeProps>(\n ({ className, children = 'Recent', animated = true, 'aria-label': ariaLabel, customization }, ref) => {\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n AnimatedGradient: CustomAnimatedGradient = DefaultAnimatedGradient,\n BackgroundOverlay: CustomBackgroundOverlay = DefaultBackgroundOverlay,\n Content: CustomContent = DefaultContent,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n // Detect touch device with customization override\n const isTouch = useMemo(() => customConfig?.touchDevice ?? isTouchDevice(), [customConfig?.touchDevice]);\n\n /**\n * Memoized animation configuration with customization\n */\n const animationConfig = useMemo(\n (): BadgeAnimationConfig => ({\n ...defaultAnimationConfig,\n ...customConfig?.animation,\n }),\n [customConfig?.animation],\n );\n\n /**\n * Memoized gradient configuration with customization\n */\n const gradientConfig = useMemo(\n (): BadgeGradientConfig => ({\n ...defaultGradientConfig,\n ...customConfig?.gradient,\n stops: customConfig?.gradient?.stops ?? defaultGradientConfig.stops,\n }),\n [customConfig?.gradient],\n );\n\n /**\n * Generate container classes with proper memoization dependencies\n */\n const getContainerClasses = useCallback(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ isTouch, animated });\n }\n\n const sizeClasses = isTouch\n ? 'novacon:px-1.5 novacon:py-0 novacon:text-[10px]'\n : 'novacon:px-2.5 novacon:py-0.5 novacon:text-xs';\n\n return cn(\n 'novacon:inline-flex novacon:items-center novacon:rounded-full novacon:font-medium novacon:relative novacon:overflow-hidden',\n 'novacon:text-[var(--tuwa-text-secondary)] novacon:border novacon:border-[var(--tuwa-border-primary)]',\n sizeClasses,\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isTouch, animated, customization?.classNames?.container, className]);\n\n /**\n * Memoized container classes\n */\n const containerClasses = useMemo(getContainerClasses, [getContainerClasses]);\n\n /**\n * Memoized animated gradient classes\n */\n const animatedGradientClasses = useMemo(\n () =>\n customization?.classNames?.animatedGradient?.() ??\n 'novacon:absolute novacon:inset-0 novacon:z-0 novacon:pointer-events-none novacon:rounded-full',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.animatedGradient],\n );\n\n /**\n * Memoized background overlay classes\n */\n const backgroundOverlayClasses = useMemo(\n () =>\n customization?.classNames?.backgroundOverlay?.() ??\n 'novacon:absolute novacon:z-10 novacon:pointer-events-none novacon:rounded-full novacon:bg-[var(--tuwa-bg-primary)] novacon:inset-[1px]',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.backgroundOverlay],\n );\n\n /**\n * Memoized content classes\n */\n const contentClasses = useMemo(\n () => customization?.classNames?.content?.() ?? 'novacon:relative novacon:z-20 novacon:whitespace-nowrap',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.content],\n );\n\n /**\n * Generate ARIA label with proper memoization dependencies\n */\n const getAriaLabel = useCallback(() => {\n if (customConfig?.ariaLabels?.container) return customConfig.ariaLabels.container;\n if (ariaLabel) return ariaLabel;\n if (typeof children === 'string') return children;\n return 'Recent';\n }, [customConfig?.ariaLabels?.container, ariaLabel, children]);\n\n /**\n * Memoized ARIA label\n */\n const finalAriaLabel = useMemo(() => getAriaLabel(), [getAriaLabel]);\n\n // Handle mount/unmount effects\n React.useEffect(() => {\n customHandlers?.onMount?.();\n return () => customHandlers?.onUnmount?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onMount, customHandlers?.onUnmount]);\n\n return (\n <CustomContainer ref={ref} className={containerClasses} role=\"status\" aria-label={finalAriaLabel}>\n {/* Animated gradient border */}\n <CustomAnimatedGradient\n className={animatedGradientClasses}\n animated={animated}\n animationConfig={animationConfig}\n gradientConfig={gradientConfig}\n />\n\n {/* Background overlay */}\n <CustomBackgroundOverlay className={backgroundOverlayClasses} />\n\n {/* Content */}\n <CustomContent className={contentClasses}>{children}</CustomContent>\n </CustomContainer>\n );\n },\n ),\n);\n\nRecentBadge.displayName = 'RecentBadge';\n","/**\n * @file ConnectCard component with comprehensive customization options for wallet connection cards.\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { InformationCircleIcon } from '@heroicons/react/24/outline';\nimport { ChevronRightIcon } from '@heroicons/react/24/solid';\nimport { cn, isTouchDevice } from '@tuwaio/nova-core';\nimport { OrbitAdapter } from '@tuwaio/orbit-core';\nimport React, { ComponentType, forwardRef, memo, useCallback, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { getNetworkIcon } from '../../utils';\nimport { RecentBadge } from './RecentBadge';\n\n// --- Types ---\n\n/**\n * Network data for display\n */\ninterface NetworkData {\n /** Network adapter */\n adapter: OrbitAdapter;\n /** Chain ID for icon display */\n chainId?: number | string;\n /** Network display name */\n name?: string;\n /** Network index in list */\n index: number;\n}\n\n/**\n * Connect card data\n */\nexport interface ConnectCardData {\n /** Primary title/name */\n title: string;\n /** Optional subtitle */\n subtitle?: string;\n /** Whether card is recent */\n isRecent: boolean;\n /** Whether touch device */\n isTouch: boolean;\n /** Info link URL */\n infoLink?: string;\n /** Network adapters */\n adapters?: OrbitAdapter[];\n /** Whether only one network */\n isOnlyOneNetwork?: boolean;\n /** Network count for overflow */\n networkCount: number;\n /** Visible networks */\n visibleNetworks: NetworkData[];\n /** Overflow count */\n overflowCount: number;\n}\n\n// --- Network Icons Component Props ---\ntype NetworkIconsContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype NetworkIconProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n networkData: NetworkData;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype NetworkOverflowProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n overflowCount: number;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * NetworkIcons customization options\n */\nexport type NetworkIconsCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<NetworkIconsContainerProps>;\n /** Custom network icon */\n NetworkIcon?: ComponentType<NetworkIconProps>;\n /** Custom overflow indicator */\n OverflowIndicator?: ComponentType<NetworkOverflowProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate network icon classes */\n networkIcon?: (params: { networkData: NetworkData; cardData: ConnectCardData }) => string;\n /** Function to generate overflow indicator classes */\n overflowIndicator?: (params: { overflowCount: number; cardData: ConnectCardData }) => string;\n };\n};\n\n/**\n * Props for the NetworkIcons component\n */\ninterface NetworkIconsProps {\n /** Array of network adapters to display as icons */\n adapters?: OrbitAdapter[];\n /** Whether only one network is available */\n isOnlyOneNetwork?: boolean;\n /** Card data for context */\n cardData: ConnectCardData;\n /** Customization options */\n customization?: NetworkIconsCustomization;\n}\n\n// --- Connect Card Component Props ---\ntype CardContainerProps = {\n className?: string;\n children: React.ReactNode;\n type?: 'button';\n onClick?: () => void;\n 'aria-label'?: string;\n 'aria-describedby'?: string;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLButtonElement>;\n\ntype CardContentProps = {\n className?: string;\n children: React.ReactNode;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype IconContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype IconWrapperProps = {\n className?: string;\n children: React.ReactNode;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TextContainerProps = {\n className?: string;\n children: React.ReactNode;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TitleProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-level'?: number;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLSpanElement>;\n\ntype SubtitleProps = {\n className?: string;\n children: React.ReactNode;\n id?: string;\n role?: string;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLSpanElement>;\n\ntype InfoLinkProps = {\n className?: string;\n children: React.ReactNode;\n onClick?: (e: React.MouseEvent) => void;\n href?: string;\n target?: string;\n rel?: string;\n 'aria-label'?: string;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLAnchorElement>;\n\ntype RecentBadgeWrapperProps = {\n className?: string;\n children: React.ReactNode;\n 'aria-label'?: string;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ChevronProps = {\n className?: string;\n children: React.ReactNode;\n 'aria-hidden'?: boolean;\n cardData: ConnectCardData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * ConnectCard customization options\n */\nexport type ConnectCardCustomization = {\n /** Custom components */\n components?: {\n /** Custom card container */\n Container?: ComponentType<CardContainerProps>;\n /** Custom card content */\n Content?: ComponentType<CardContentProps>;\n /** Custom icon container */\n IconContainer?: ComponentType<IconContainerProps>;\n /** Custom icon wrapper */\n IconWrapper?: ComponentType<IconWrapperProps>;\n /** Custom text container */\n TextContainer?: ComponentType<TextContainerProps>;\n /** Custom title */\n Title?: ComponentType<TitleProps>;\n /** Custom subtitle */\n Subtitle?: ComponentType<SubtitleProps>;\n /** Custom info link */\n InfoLink?: ComponentType<InfoLinkProps>;\n /** Custom recent badge wrapper */\n RecentBadgeWrapper?: ComponentType<RecentBadgeWrapperProps>;\n /** Custom chevron */\n Chevron?: ComponentType<ChevronProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate content classes */\n content?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate icon container classes */\n iconContainer?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate icon wrapper classes */\n iconWrapper?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate text container classes */\n textContainer?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate title classes */\n title?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate subtitle classes */\n subtitle?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate info link classes */\n infoLink?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate recent badge wrapper classes */\n recentBadgeWrapper?: (params: { cardData: ConnectCardData }) => string;\n /** Function to generate chevron classes */\n chevron?: (params: { cardData: ConnectCardData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom click handler */\n onClick?: (cardData: ConnectCardData, originalHandler: () => void) => void;\n /** Custom info link click handler */\n onInfoClick?: (cardData: ConnectCardData, event: React.MouseEvent) => void;\n /** Custom hover handler */\n onHover?: (cardData: ConnectCardData, isHovering: boolean) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n card?: (cardData: ConnectCardData) => string;\n icon?: (cardData: ConnectCardData) => string;\n infoLink?: (cardData: ConnectCardData) => string;\n recentBadge?: (cardData: ConnectCardData) => string;\n };\n /** Custom animation settings */\n animation?: {\n hoverScale?: string;\n transitionDuration?: string;\n chevronTransform?: string;\n };\n };\n /** NetworkIcons customization */\n networkIcons?: NetworkIconsCustomization;\n};\n\n/**\n * Props for the ConnectCard component\n */\ninterface ConnectCardProps {\n /** Click handler for the connect card */\n onClick: () => void;\n /** Icon element to display for the wallet/connector */\n icon: React.ReactNode;\n /** Primary title/name of the wallet/connector */\n title: string;\n /** Optional subtitle/description text */\n subtitle?: string;\n /** Optional URL for additional information */\n infoLink?: string;\n /** Whether this connector was recently used */\n isRecent?: boolean;\n /** Array of network adapters to display as icons */\n adapters?: OrbitAdapter[];\n /** Whether only one network is available */\n isOnlyOneNetwork?: boolean;\n /** Custom CSS classes for styling the container */\n className?: string;\n /** Customization options */\n customization?: ConnectCardCustomization;\n}\n\n// --- Default NetworkIcons Sub-Components ---\nconst DefaultNetworkIconsContainer = forwardRef<HTMLDivElement, NetworkIconsContainerProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultNetworkIconsContainer.displayName = 'DefaultNetworkIconsContainer';\n\nconst DefaultNetworkIcon = forwardRef<HTMLDivElement, NetworkIconProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, networkData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultNetworkIcon.displayName = 'DefaultNetworkIcon';\n\nconst DefaultNetworkOverflow = forwardRef<HTMLDivElement, NetworkOverflowProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultNetworkOverflow.displayName = 'DefaultNetworkOverflow';\n\n/**\n * NetworkIcons component - Displays network chain icons for supported networks with full customization\n *\n * Shows up to 3 network icons with an overflow indicator for additional networks.\n * Hidden when only one network is available or no adapters are provided.\n * Supports complete customization of all child components and styling.\n *\n * @example Basic usage\n * ```tsx\n * <NetworkIcons\n * adapters={[ethereum, polygon]}\n * isOnlyOneNetwork={false}\n * cardData={cardData}\n * />\n * ```\n *\n * @example With customization\n * ```tsx\n * <NetworkIcons\n * adapters={networkAdapters}\n * isOnlyOneNetwork={false}\n * cardData={cardData}\n * customization={{\n * components: {\n * NetworkIcon: CustomNetworkIcon\n * },\n * classNames: {\n * container: ({ cardData }) => `custom-networks ${cardData.isTouch ? 'touch' : 'mouse'}`\n * }\n * }}\n * />\n * ```\n */\nconst NetworkIcons = memo(\n forwardRef<HTMLDivElement, NetworkIconsProps>(({ adapters, isOnlyOneNetwork, cardData, customization }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultNetworkIconsContainer,\n NetworkIcon: CustomNetworkIcon = DefaultNetworkIcon,\n OverflowIndicator: CustomOverflowIndicator = DefaultNetworkOverflow,\n } = customization?.components ?? {};\n\n /**\n * Generate visible networks data\n */\n const visibleNetworksData = useMemo(() => {\n if (!adapters?.length) return [];\n return adapters.slice(0, 3).map(\n (adapter, index): NetworkData => ({\n adapter,\n chainId: getNetworkIcon(adapter)?.chainId,\n name: getNetworkIcon(adapter)?.name,\n index,\n }),\n );\n }, [adapters]);\n\n /**\n * Calculate overflow count\n */\n // eslint-disable-next-line\n const overflowCount = useMemo(() => {\n return adapters?.length ? Math.max(0, adapters.length - 3) : 0;\n }, [adapters?.length]);\n\n // Early returns\n if (!adapters?.length) return null;\n if (isOnlyOneNetwork) return null;\n\n return (\n <CustomContainer\n ref={ref}\n className={\n customization?.classNames?.container?.({ cardData }) ??\n cn(\n 'novacon:absolute novacon:-bottom-1 novacon:-right-1 novacon:w-full novacon:flex novacon:items-center novacon:justify-end',\n )\n }\n role=\"group\"\n aria-label={labels.listOfNetworks}\n cardData={cardData}\n >\n {visibleNetworksData.map((networkData) => (\n <CustomNetworkIcon\n key={networkData.adapter}\n className={\n customization?.classNames?.networkIcon?.({ networkData, cardData }) ??\n cn(\n 'novacon:w-4 novacon:h-4 novacon:rounded-full novacon:border novacon:border-[var(--tuwa-border-primary)] novacon:bg-[var(--tuwa-bg-primary)] novacon:flex novacon:items-center novacon:justify-center',\n {\n 'novacon:-ml-2': networkData.index > 0,\n },\n )\n }\n role=\"img\"\n aria-label={`Network ${networkData.chainId || networkData.adapter}`}\n networkData={networkData}\n cardData={cardData}\n >\n <Web3Icon chainId={networkData.chainId} />\n </CustomNetworkIcon>\n ))}\n {overflowCount > 0 && (\n <CustomOverflowIndicator\n className={\n customization?.classNames?.overflowIndicator?.({ overflowCount, cardData }) ??\n cn(\n 'novacon:w-4 novacon:h-4 novacon:rounded-full novacon:border novacon:border-[var(--tuwa-border-primary)] novacon:bg-[var(--tuwa-bg-primary)] novacon:-ml-2 novacon:flex novacon:items-center novacon:justify-center novacon:text-[8px]',\n )\n }\n role=\"img\"\n aria-label={`${overflowCount} additional networks`}\n overflowCount={overflowCount}\n cardData={cardData}\n >\n +{overflowCount}\n </CustomOverflowIndicator>\n )}\n </CustomContainer>\n );\n }),\n);\nNetworkIcons.displayName = 'NetworkIcons';\n\n// --- Default ConnectCard Sub-Components ---\nconst DefaultCardContainer = forwardRef<HTMLButtonElement, CardContainerProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <button ref={ref} className={className} {...props}>\n {children}\n </button>\n ),\n);\nDefaultCardContainer.displayName = 'DefaultCardContainer';\n\nconst DefaultCardContent = forwardRef<HTMLDivElement, CardContentProps>(\n // eslint-disable-next-line\n ({ children, className, cardData }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n ),\n);\nDefaultCardContent.displayName = 'DefaultCardContent';\n\nconst DefaultIconContainer = forwardRef<HTMLDivElement, IconContainerProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultIconContainer.displayName = 'DefaultIconContainer';\n\nconst DefaultIconWrapper = forwardRef<HTMLDivElement, IconWrapperProps>(\n // eslint-disable-next-line\n ({ children, className, cardData }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n ),\n);\nDefaultIconWrapper.displayName = 'DefaultIconWrapper';\n\nconst DefaultTextContainer = forwardRef<HTMLDivElement, TextContainerProps>(\n // eslint-disable-next-line\n ({ children, className, cardData }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n ),\n);\nDefaultTextContainer.displayName = 'DefaultTextContainer';\n\nconst DefaultTitle = forwardRef<HTMLSpanElement, TitleProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <span ref={ref} className={className} {...props}>\n {children}\n </span>\n ),\n);\nDefaultTitle.displayName = 'DefaultTitle';\n\nconst DefaultSubtitle = forwardRef<HTMLSpanElement, SubtitleProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <span ref={ref} className={className} {...props}>\n {children}\n </span>\n ),\n);\nDefaultSubtitle.displayName = 'DefaultSubtitle';\n\nconst DefaultInfoLink = forwardRef<HTMLAnchorElement, InfoLinkProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <a ref={ref} className={className} {...props}>\n {children}\n </a>\n ),\n);\nDefaultInfoLink.displayName = 'DefaultInfoLink';\n\nconst DefaultRecentBadgeWrapper = forwardRef<HTMLDivElement, RecentBadgeWrapperProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultRecentBadgeWrapper.displayName = 'DefaultRecentBadgeWrapper';\n\nconst DefaultChevron = forwardRef<HTMLDivElement, ChevronProps>(\n // eslint-disable-next-line\n ({ children, className, cardData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultChevron.displayName = 'DefaultChevron';\n\n/**\n * ConnectCard component - Interactive card for wallet connection options with comprehensive customization\n *\n * This component provides a clickable card interface for wallet connectors with:\n * - Responsive design adapting to touch/mouse interfaces\n * - Network icons overlay showing supported networks\n * - Recent usage indicator badge\n * - Information link with external documentation\n * - Hover animations and visual feedback\n * - Full accessibility support with ARIA labels\n * - Keyboard navigation support\n * - Complete customization of all child components and styling\n *\n * @example Basic usage\n * ```tsx\n * <ConnectCard\n * onClick={() => connect('metamask')}\n * title=\"MetaMask\"\n * subtitle=\"Browser Extension\"\n * icon={<MetaMaskIcon />}\n * adapters={[evm]}\n * isRecent={true}\n * infoLink=\"https://metamask.io/learn\"\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectCard\n * onClick={() => connect('walletconnect')}\n * title=\"WalletConnect\"\n * icon={<WalletConnectIcon />}\n * adapters={[ethereum, polygon]}\n * customization={{\n * components: {\n * Container: CustomCardContainer,\n * Title: CustomTitle\n * },\n * classNames: {\n * container: ({ cardData }) => cardData.isTouch ? 'touch-card' : 'desktop-card'\n * },\n * handlers: {\n * onClick: (cardData, originalHandler) => {\n * analytics.track('card_clicked', { title: cardData.title });\n * originalHandler();\n * }\n * }\n * }}\n * />\n * ```\n */\nexport const ConnectCard = memo(\n forwardRef<HTMLButtonElement, ConnectCardProps>(\n (\n {\n onClick,\n title,\n icon,\n adapters,\n infoLink,\n subtitle,\n isRecent = false,\n isOnlyOneNetwork = false,\n className,\n customization,\n },\n ref,\n ) => {\n const labels = useNovaConnectLabels();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultCardContainer,\n Content: CustomContent = DefaultCardContent,\n IconContainer: CustomIconContainer = DefaultIconContainer,\n IconWrapper: CustomIconWrapper = DefaultIconWrapper,\n TextContainer: CustomTextContainer = DefaultTextContainer,\n Title: CustomTitle = DefaultTitle,\n Subtitle: CustomSubtitle = DefaultSubtitle,\n InfoLink: CustomInfoLink = DefaultInfoLink,\n RecentBadgeWrapper: CustomRecentBadgeWrapper = DefaultRecentBadgeWrapper,\n Chevron: CustomChevron = DefaultChevron,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized touch device detection\n */\n const isTouch = useMemo(() => isTouchDevice(), []);\n\n /**\n * Memoized network data calculations\n */\n const networkStats = useMemo(() => {\n const networkCount = adapters?.length || 0;\n const visibleNetworks =\n adapters?.slice(0, 3).map(\n (adapter, index): NetworkData => ({\n adapter,\n chainId: getNetworkIcon(adapter)?.chainId,\n name: String(adapter),\n index,\n }),\n ) || [];\n const overflowCount = Math.max(0, networkCount - 3);\n\n return {\n networkCount,\n visibleNetworks,\n overflowCount,\n };\n }, [adapters]);\n\n /**\n * Memoized card data\n */\n const cardData = useMemo(\n (): ConnectCardData => ({\n title,\n subtitle,\n isRecent,\n isTouch,\n infoLink,\n adapters,\n isOnlyOneNetwork,\n ...networkStats,\n }),\n [title, subtitle, isRecent, isTouch, infoLink, adapters, isOnlyOneNetwork, networkStats],\n );\n\n /**\n * Memoized container classes\n */\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ cardData });\n }\n\n const baseClasses =\n 'novacon:group novacon:cursor-pointer novacon:p-4 novacon:rounded-xl novacon:transition-colors novacon:relative novacon:border novacon:border-[var(--tuwa-border-primary)] novacon:disabled:opacity-50 novacon:disabled:cursor-not-allowed novacon:bg-[var(--tuwa-bg-secondary)] novacon:hover:bg-[var(--tuwa-bg-muted)]';\n\n const touchClasses =\n 'novacon:w-[125px] novacon:h-[125px] novacon:p-2 novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:text-center';\n\n const mouseClasses = [\n 'novacon:w-full novacon:h-auto',\n 'novacon:flex novacon:items-center novacon:justify-between',\n ];\n\n return cn(baseClasses, className, mouseClasses, { [touchClasses]: isTouch });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, cardData, className, isTouch]);\n\n /**\n * Memoized aria label\n */\n const cardAriaLabel = useMemo(() => {\n if (customConfig?.ariaLabels?.card) {\n return customConfig.ariaLabels.card(cardData);\n }\n\n const baseLabel = `${labels.connect} ${title}`;\n const recentText = isRecent ? ` (${labels.recent})` : '';\n const subtitleText = subtitle ? `, ${subtitle}` : '';\n const networkCount = adapters?.length ? `, supports ${adapters.length} networks` : '';\n\n return `${baseLabel}${recentText}${subtitleText}${networkCount}`;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n customConfig?.ariaLabels?.card,\n cardData,\n labels.connect,\n labels.recent,\n title,\n isRecent,\n subtitle,\n adapters?.length,\n ]);\n\n /**\n * Handle click with customization\n */\n const handleClick = useCallback(() => {\n if (customHandlers?.onClick) {\n customHandlers.onClick(cardData, onClick);\n } else {\n onClick();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onClick, cardData, onClick]);\n\n /**\n * Handle info link click\n */\n const handleInfoClick = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n if (customHandlers?.onInfoClick) {\n customHandlers.onInfoClick(cardData, e);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customHandlers?.onInfoClick, cardData],\n );\n\n return (\n <CustomContainer\n ref={ref}\n type=\"button\"\n className={containerClasses}\n onClick={handleClick}\n aria-label={cardAriaLabel}\n aria-describedby={subtitle ? `${title}-subtitle` : undefined}\n cardData={cardData}\n >\n <CustomContent\n className={\n customization?.classNames?.content?.({ cardData }) ??\n cn(\n 'novacon:flex novacon:gap-3 novacon:transition novacon:duration-300 novacon:ease-in-out novacon:text-[var(--tuwa-text-primary)] novacon:group-hover:text-[var(--tuwa-text-accent)] novacon:items-center',\n {\n 'novacon:flex-col novacon:items-center novacon:gap-1': isTouch,\n },\n )\n }\n cardData={cardData}\n >\n <CustomIconContainer\n className={\n customization?.classNames?.iconContainer?.({ cardData }) ??\n cn(\n 'novacon:flex novacon:relative novacon:transition novacon:duration-300 novacon:ease-in-out group-hover:novacon:scale-115',\n )\n }\n role=\"img\"\n aria-label={\n customConfig?.ariaLabels?.icon\n ? customConfig.ariaLabels.icon(cardData)\n : `${title} ${labels.walletIcon}`\n }\n cardData={cardData}\n >\n <CustomIconWrapper\n className={\n customization?.classNames?.iconWrapper?.({ cardData }) ??\n cn('novacon:[&_img]:w-[42px]! novacon:[&_img]:h-[auto]! novacon:sm:[&_img]:w-[32px]!')\n }\n cardData={cardData}\n >\n {icon}\n </CustomIconWrapper>\n <NetworkIcons\n adapters={adapters}\n isOnlyOneNetwork={isOnlyOneNetwork}\n cardData={cardData}\n customization={customization?.networkIcons}\n />\n </CustomIconContainer>\n\n <CustomTextContainer\n className={\n customization?.classNames?.textContainer?.({ cardData }) ??\n cn('novacon:flex novacon:flex-col novacon:gap-0.5 novacon:items-start', {\n 'novacon:items-center novacon:text-sm': isTouch,\n })\n }\n cardData={cardData}\n >\n <CustomTitle\n className={customization?.classNames?.title?.({ cardData }) ?? cn({ 'novacon:font-medium': isTouch })}\n role=\"heading\"\n aria-level={3}\n cardData={cardData}\n >\n {title}\n </CustomTitle>\n {subtitle && (\n <CustomSubtitle\n className={\n customization?.classNames?.subtitle?.({ cardData }) ??\n cn('novacon:text-[var(--tuwa-text-secondary)] novacon:text-sm', {\n 'novacon:text-[10px]': isTouch,\n })\n }\n id={`${title}-subtitle`}\n role=\"text\"\n cardData={cardData}\n >\n {subtitle}\n </CustomSubtitle>\n )}\n </CustomTextContainer>\n </CustomContent>\n\n {infoLink && (\n <CustomInfoLink\n className={\n customization?.classNames?.infoLink?.({ cardData }) ??\n cn(\n 'novacon:absolute novacon:top-[2px] novacon:right-[2px] novacon:text-[var(--tuwa-text-secondary)] novacon:transition novacon:duration-300 novacon:ease-in-out novacon:active:scale-75 novacon:hover:scale-110 novacon:group-hover:text-[var(--tuwa-text-primary)]',\n )\n }\n onClick={handleInfoClick}\n href={infoLink}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n aria-label={\n customConfig?.ariaLabels?.infoLink\n ? customConfig.ariaLabels.infoLink(cardData)\n : `${labels.learnMore} ${labels.aboutWallets} ${title}`\n }\n cardData={cardData}\n >\n <InformationCircleIcon width={16} height={16} aria-hidden=\"true\" />\n </CustomInfoLink>\n )}\n\n {isRecent && (\n <CustomRecentBadgeWrapper\n className={\n customization?.classNames?.recentBadgeWrapper?.({ cardData }) ??\n cn(\n 'novacon:absolute novacon:top-0.5 novacon:right-0.5 novacon:transition novacon:group-hover:opacity-0 novacon:group-hover:scale-90',\n )\n }\n aria-label={\n customConfig?.ariaLabels?.recentBadge\n ? customConfig.ariaLabels.recentBadge(cardData)\n : `${title} ${labels.recent}`\n }\n cardData={cardData}\n >\n <RecentBadge>{labels.recent}</RecentBadge>\n </CustomRecentBadgeWrapper>\n )}\n\n {!isTouch && (\n <CustomChevron\n className={\n customization?.classNames?.chevron?.({ cardData }) ??\n cn(\n 'novacon:w-5 novacon:h-5 novacon:transition novacon:duration-300 novacon:ease-in-out novacon:translate-x-[-10px] novacon:opacity-0 novacon:group-hover:translate-x-0 novacon:group-hover:opacity-100 novacon:text-[var(--tuwa-text-secondary)]',\n )\n }\n aria-hidden={true}\n cardData={cardData}\n >\n <ChevronRightIcon />\n </CustomChevron>\n )}\n </CustomContainer>\n );\n },\n ),\n);\n\nConnectCard.displayName = 'ConnectCard';\n","/**\n * @file ConnectorsBlock component with comprehensive customization options and connector group display.\n */\n\nimport { cn, isTouchDevice } from '@tuwaio/nova-core';\nimport {\n delay,\n formatWalletName,\n getWalletTypeFromConnectorName,\n OrbitAdapter,\n recentConnectedWalletHelpers,\n waitFor,\n WalletType,\n} from '@tuwaio/orbit-core';\nimport React, { ComponentType, forwardRef, memo, useCallback, useMemo, useRef } from 'react';\n\nimport { getConnectChainId } from '../../utils';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\nimport { WalletIcon } from '../WalletIcon';\nimport { ConnectCard, ConnectCardCustomization } from './ConnectCard';\nimport { GroupedConnector } from './ConnectModal';\nimport { ConnectorsSelectionsProps } from './ConnectorsSelections';\n\n// --- Types ---\n\n/**\n * Connector block data for customization context\n */\nexport interface ConnectorsBlockData {\n /** Currently selected network adapter */\n selectedAdapter: OrbitAdapter | undefined;\n /** Array of grouped wallet connectors to display */\n connectors: GroupedConnector[];\n /** Title text for the connector group */\n title: string;\n /** Whether to render the title in bold accent color */\n isTitleBold: boolean;\n /** Whether only one network is available */\n isOnlyOneNetwork: boolean;\n /** Whether device is touch-enabled */\n isTouch: boolean;\n /** Whether there are connectors to display */\n hasConnectors: boolean;\n /** Recent wallets data */\n recentWallets: Record<string, Record<string, boolean>> | null;\n /** Section ID for accessibility */\n sectionId: string;\n}\n\n/**\n * Individual connector item data\n */\nexport interface ConnectorItemData {\n /** Grouped connector configuration */\n group: GroupedConnector;\n /** Formatted wallet name */\n name: string;\n /** Whether this wallet was recently used */\n isRecent: boolean;\n /** Item index in the list */\n index: number;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-labelledby'?: string;\n 'aria-label'?: string;\n blockData: ConnectorsBlockData;\n} & React.RefAttributes<HTMLElement>;\n\ntype TitleProps = {\n className?: string;\n children: React.ReactNode;\n id?: string;\n role?: string;\n 'aria-level'?: number;\n onClick?: () => void;\n blockData: ConnectorsBlockData;\n} & React.RefAttributes<HTMLHeadingElement>;\n\ntype ConnectorsListProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n blockData: ConnectorsBlockData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ConnectorItemProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n itemData: ConnectorItemData;\n blockData: ConnectorsBlockData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype EmptyStateProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n onClick?: () => void;\n blockData: ConnectorsBlockData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * Customization options for ConnectorsBlock component\n */\nexport type ConnectorsBlockCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom title component */\n Title?: ComponentType<TitleProps>;\n /** Custom connectors list */\n ConnectorsList?: ComponentType<ConnectorsListProps>;\n /** Custom connector item wrapper */\n ConnectorItem?: ComponentType<ConnectorItemProps>;\n /** Custom empty state component */\n EmptyState?: ComponentType<EmptyStateProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { blockData: ConnectorsBlockData }) => string;\n /** Function to generate title classes */\n title?: (params: { blockData: ConnectorsBlockData }) => string;\n /** Function to generate connectors list classes */\n connectorsList?: (params: { blockData: ConnectorsBlockData }) => string;\n /** Function to generate connector item classes */\n connectorItem?: (params: { itemData: ConnectorItemData; blockData: ConnectorsBlockData }) => string;\n /** Function to generate empty state classes */\n emptyState?: (params: { blockData: ConnectorsBlockData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom connector click handler */\n onConnectorClick?: (\n itemData: ConnectorItemData,\n blockData: ConnectorsBlockData,\n originalHandler: (group: GroupedConnector) => Promise<void>,\n ) => void;\n /** Custom title click handler */\n onTitleClick?: (blockData: ConnectorsBlockData) => void;\n /** Custom empty state action handler */\n onEmptyStateAction?: (blockData: ConnectorsBlockData) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: (blockData: ConnectorsBlockData) => string;\n connectorsList?: (blockData: ConnectorsBlockData) => string;\n emptyState?: (blockData: ConnectorsBlockData) => string;\n };\n /** Custom layout configuration */\n layout?: {\n /** Touch device gap between items */\n touchGap?: string;\n /** Mouse device gap between items */\n mouseGap?: string;\n /** Custom touch layout classes */\n touchClasses?: string[];\n /** Custom mouse layout classes */\n mouseClasses?: string[];\n };\n /** Show/hide features */\n features?: {\n /** Whether to show empty state */\n showEmptyState?: boolean;\n /** Whether to show title when no connectors */\n showTitleWhenEmpty?: boolean;\n /** Whether to show recent indicators */\n showRecentIndicators?: boolean;\n };\n };\n /** ConnectCard customization for each connector card */\n connectCard?: ConnectCardCustomization;\n};\n\n/**\n * Props for the ConnectorsBlock component\n */\ninterface ConnectorsBlockProps\n extends Pick<\n ConnectorsSelectionsProps,\n 'waitForPredict' | 'setIsOpen' | 'setIsConnected' | 'onClick' | 'appChains' | 'solanaRPCUrls'\n >,\n Pick<ConnectButtonProps, 'store'> {\n /** Currently selected network adapter */\n selectedAdapter: OrbitAdapter | undefined;\n /** Array of grouped wallet connectors to display */\n connectors: GroupedConnector[];\n /** Title text for the connector group */\n title: string;\n /** Whether to render the title in bold accent color */\n isTitleBold?: boolean;\n /** Whether only one network is available */\n isOnlyOneNetwork?: boolean;\n /** Customization options */\n customization?: ConnectorsBlockCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLElement, ContainerProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { blockData: _blockData, ...restProps } = props;\n return (\n <section ref={ref} className={className} {...restProps}>\n {children}\n </section>\n );\n});\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultTitle = forwardRef<HTMLHeadingElement, TitleProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { blockData: _blockData, ...restProps } = props;\n return (\n <h3 ref={ref} className={className} {...restProps}>\n {children}\n </h3>\n );\n});\nDefaultTitle.displayName = 'DefaultTitle';\n\nconst DefaultConnectorsList = forwardRef<HTMLDivElement, ConnectorsListProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { blockData: _blockData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n },\n);\nDefaultConnectorsList.displayName = 'DefaultConnectorsList';\n\nconst DefaultConnectorItem = forwardRef<HTMLDivElement, ConnectorItemProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { itemData: _itemData, blockData: _blockData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n },\n);\nDefaultConnectorItem.displayName = 'DefaultConnectorItem';\n\nconst DefaultEmptyState = forwardRef<HTMLDivElement, EmptyStateProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { blockData: _blockData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n});\nDefaultEmptyState.displayName = 'DefaultEmptyState';\n\n/**\n * ConnectorsBlock component - Displays a grouped section of wallet connectors with full customization\n *\n * This component renders a section of wallet connectors with:\n * - Responsive layout adapting to touch/mouse interfaces\n * - Support for multi-network wallet selection\n * - Automatic connection handling for single-network wallets\n * - Recent wallet indicators and prioritization\n * - Full accessibility support with proper labeling\n * - Error handling and connection retry logic\n * - Complete customization of all child components and styling\n *\n * Layout features:\n * - Touch devices: Horizontal scrolling layout with cards\n * - Mouse devices: Vertical stacked layout for better readability\n * - Dynamic title styling based on section importance\n * - Consistent spacing and visual hierarchy\n * - Customizable layout parameters and responsive behavior\n *\n * Connection flow:\n * - Single adapter: Direct connection attempt\n * - Multiple adapters without selection: Triggers network selection\n * - Selected adapter: Uses specific adapter for connection\n * - Recent wallets: Visual indicators for previously used wallets\n * - Error handling with retry mechanisms\n *\n * Accessibility features:\n * - Semantic heading structure with proper levels\n * - Group labeling for related connector sets\n * - Screen reader friendly section descriptions\n * - Proper focus management and keyboard navigation\n * - ARIA live regions for dynamic content updates\n *\n * @example Basic usage\n * ```tsx\n * <ConnectorsBlock\n * selectedAdapter={OrbitAdapter.EVM}\n * connectors={installedConnectors}\n * title=\"Installed\"\n * isTitleBold={true}\n * isOnlyOneNetwork={false}\n * onClick={(group) => handleWalletSelection(group)}\n * appChains={appConfiguration}\n * solanaRPCUrls={rpcConfig}\n * store={walletStore}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectorsBlock\n * selectedAdapter={undefined}\n * connectors={popularConnectors}\n * title=\"Popular\"\n * isTitleBold={false}\n * isOnlyOneNetwork={true}\n * onClick={(group) => initiateConnection(group)}\n * customization={{\n * components: {\n * Container: CustomConnectorsContainer,\n * Title: CustomSectionTitle\n * },\n * classNames: {\n * connectorsList: ({ blockData }) =>\n * blockData.isTouch ? 'horizontal-scroll' : 'vertical-stack',\n * connectorItem: ({ itemData, blockData }) =>\n * itemData.isRecent ? 'recent-connector' : 'standard-connector'\n * },\n * handlers: {\n * onConnectorClick: (itemData, blockData, originalHandler) => {\n * analytics.track('connector_clicked', { wallet: itemData.name });\n * originalHandler(itemData.group);\n * }\n * },\n * connectCard: {\n * classNames: {\n * container: ({ cardData }) =>\n * cardData.isRecent ? 'bg-accent' : 'bg-default'\n * }\n * }\n * }}\n * />\n * ```\n */\nexport const ConnectorsBlock = memo(\n forwardRef<HTMLElement, ConnectorsBlockProps>(\n (\n {\n selectedAdapter,\n connectors,\n solanaRPCUrls,\n appChains,\n waitForPredict,\n setIsConnected,\n setIsOpen,\n onClick,\n title,\n isTitleBold = false,\n isOnlyOneNetwork = false,\n store,\n customization,\n },\n ref,\n ) => {\n const isMountedRef = useRef(true);\n const connectInProgressRef = useRef(false);\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n Title: CustomTitle = DefaultTitle,\n ConnectorsList: CustomConnectorsList = DefaultConnectorsList,\n ConnectorItem: CustomConnectorItem = DefaultConnectorItem,\n EmptyState: CustomEmptyState = DefaultEmptyState,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized touch device detection\n */\n const isTouch = useMemo(() => isTouchDevice(), []);\n\n /**\n * Memoized store functions\n */\n const connect = useMemo(() => store.getState().connect, [store]);\n\n /**\n * Memoized recent wallets data with proper type handling\n */\n const recentWallets = useMemo(() => {\n const result = recentConnectedWalletHelpers.getRecentConnectedWallet();\n return result ?? null;\n }, []);\n\n /**\n * Memoized section ID\n */\n const sectionId = useMemo(() => `connectors-${title.toLowerCase().replace(/\\s+/g, '-')}`, [title]);\n\n /**\n * Memoized block data\n */\n const blockData = useMemo(\n (): ConnectorsBlockData => ({\n selectedAdapter,\n connectors,\n title,\n isTitleBold,\n isOnlyOneNetwork,\n isTouch,\n hasConnectors: Boolean(connectors?.length),\n recentWallets,\n sectionId,\n }),\n [selectedAdapter, connectors, title, isTitleBold, isOnlyOneNetwork, isTouch, recentWallets, sectionId],\n );\n\n /**\n * Memoized CSS classes for layout\n */\n const layoutClasses = useMemo(() => {\n const touchClasses = customConfig?.layout?.touchClasses ?? [\n 'novacon:flex-row',\n customConfig?.layout?.touchGap ?? 'novacon:gap-3',\n ];\n\n const mouseClasses = customConfig?.layout?.mouseClasses ?? [\n 'novacon:flex-col',\n customConfig?.layout?.mouseGap ?? 'novacon:gap-2',\n ];\n\n return {\n touchClasses,\n mouseClasses,\n };\n }, [customConfig?.layout]);\n\n /**\n * Memoized connector items data\n */\n const connectorItems = useMemo((): ConnectorItemData[] => {\n if (!connectors?.length) return [];\n\n return connectors.map((group, index) => {\n const name = formatWalletName(group.name);\n const isRecent =\n customConfig?.features?.showRecentIndicators !== false\n ? Boolean(recentWallets && recentWallets[group.adapters[0]] && recentWallets[group.adapters[0]][name])\n : false;\n\n return {\n group,\n name,\n isRecent,\n index,\n };\n });\n }, [connectors, recentWallets, customConfig?.features?.showRecentIndicators]);\n\n /**\n * Handle connector click with connection logic\n */\n const handleConnectorClick = useCallback(\n async (group: GroupedConnector) => {\n if (!isMountedRef.current || connectInProgressRef.current) return;\n\n const name = formatWalletName(group.name);\n\n try {\n connectInProgressRef.current = true;\n\n // If multiple adapters available and no specific adapter selected, show network selection\n if (group.adapters.length > 1 && !selectedAdapter) {\n onClick(group);\n return;\n }\n\n // Use the selected adapter or the first available adapter\n const targetAdapter = selectedAdapter || group.adapters[0];\n const walletType = getWalletTypeFromConnectorName(targetAdapter, name) as WalletType;\n\n onClick(group);\n\n await connect({\n walletType,\n chainId: getConnectChainId({ appChains, selectedAdapter: targetAdapter, solanaRPCUrls }),\n });\n\n await waitFor(waitForPredict);\n setIsConnected(true);\n const modalCloseTime = setTimeout(() => setIsOpen(false), 400);\n const isConnectedTimer = setTimeout(() => setIsConnected(false), 500);\n await delay(null, 500);\n clearTimeout(modalCloseTime);\n clearTimeout(isConnectedTimer);\n } catch (error) {\n console.error('Connection error:', error);\n } finally {\n connectInProgressRef.current = false;\n }\n },\n [selectedAdapter, onClick, connect, appChains, solanaRPCUrls, waitForPredict, setIsConnected, setIsOpen],\n );\n\n /**\n * Wrapper for custom connector click handler\n */\n const handleConnectorClickWrapper = useCallback(\n (itemData: ConnectorItemData) => {\n if (customHandlers?.onConnectorClick) {\n customHandlers.onConnectorClick(itemData, blockData, handleConnectorClick);\n } else {\n handleConnectorClick(itemData.group);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customHandlers?.onConnectorClick, blockData, handleConnectorClick],\n );\n\n /**\n * Memoized CSS classes\n */\n const cssClasses = useMemo(\n () => ({\n container:\n customization?.classNames?.container?.({ blockData }) ?? 'novacon:flex novacon:flex-col novacon:gap-2',\n\n title:\n customization?.classNames?.title?.({ blockData }) ??\n cn('novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]', {\n 'novacon:font-bold novacon:text-[var(--tuwa-text-accent)]': blockData.isTitleBold,\n }),\n\n connectorsList:\n customization?.classNames?.connectorsList?.({ blockData }) ??\n cn('novacon:flex', blockData.isTouch ? layoutClasses.touchClasses : layoutClasses.mouseClasses),\n\n emptyState:\n customization?.classNames?.emptyState?.({ blockData }) ??\n 'novacon:flex novacon:items-center novacon:justify-center novacon:p-4 novacon:text-sm novacon:text-[var(--tuwa-text-secondary)] novacon:bg-[var(--tuwa-bg-muted)] novacon:rounded-lg',\n }),\n [customization?.classNames, blockData, layoutClasses],\n );\n\n // Cleanup effect\n React.useEffect(() => {\n isMountedRef.current = true;\n\n return () => {\n isMountedRef.current = false;\n connectInProgressRef.current = false;\n };\n }, []);\n\n // Early return for empty state\n if (!blockData.hasConnectors) {\n if (customConfig?.features?.showEmptyState === false) {\n return null;\n }\n\n return (\n <CustomContainer\n ref={ref}\n className={cssClasses.container}\n role=\"group\"\n aria-labelledby={\n customConfig?.features?.showTitleWhenEmpty !== false ? `${blockData.sectionId}-title` : undefined\n }\n blockData={blockData}\n >\n {customConfig?.features?.showTitleWhenEmpty !== false && (\n <CustomTitle\n id={`${blockData.sectionId}-title`}\n className={cssClasses.title}\n role=\"heading\"\n aria-level={3}\n blockData={blockData}\n onClick={customHandlers?.onTitleClick ? () => customHandlers.onTitleClick!(blockData) : undefined}\n >\n {title}\n </CustomTitle>\n )}\n\n <CustomEmptyState\n className={cssClasses.emptyState}\n role=\"status\"\n aria-label={\n customConfig?.ariaLabels?.emptyState?.(blockData) ?? `No ${title.toLowerCase()} connectors available`\n }\n blockData={blockData}\n onClick={\n customHandlers?.onEmptyStateAction ? () => customHandlers.onEmptyStateAction!(blockData) : undefined\n }\n >\n No {title.toLowerCase()} wallets available\n </CustomEmptyState>\n </CustomContainer>\n );\n }\n\n const containerAriaLabel =\n customConfig?.ariaLabels?.container?.(blockData) ?? `${title} wallet connectors section`;\n const listAriaLabel = customConfig?.ariaLabels?.connectorsList?.(blockData) ?? `${title} wallet connectors`;\n\n return (\n <CustomContainer\n ref={ref}\n className={cssClasses.container}\n role=\"group\"\n aria-labelledby={`${blockData.sectionId}-title`}\n aria-label={containerAriaLabel}\n blockData={blockData}\n >\n <CustomTitle\n id={`${blockData.sectionId}-title`}\n className={cssClasses.title}\n role=\"heading\"\n aria-level={3}\n blockData={blockData}\n onClick={customHandlers?.onTitleClick ? () => customHandlers.onTitleClick!(blockData) : undefined}\n >\n {title}\n </CustomTitle>\n\n <CustomConnectorsList\n className={cssClasses.connectorsList}\n role=\"list\"\n aria-label={listAriaLabel}\n blockData={blockData}\n >\n {connectorItems.map((itemData) => {\n const itemClasses =\n customization?.classNames?.connectorItem?.({ itemData, blockData }) ??\n cn(blockData.isTouch && 'novacon:flex-shrink-0');\n\n return (\n <CustomConnectorItem\n key={`${itemData.name}-${itemData.group.adapters.join('-')}`}\n className={itemClasses}\n role=\"listitem\"\n itemData={itemData}\n blockData={blockData}\n >\n <ConnectCard\n icon={<WalletIcon icon={itemData.group.icon} name={itemData.name} />}\n adapters={!selectedAdapter ? itemData.group.adapters : undefined}\n onClick={() => handleConnectorClickWrapper(itemData)}\n title={itemData.group.name}\n isOnlyOneNetwork={isOnlyOneNetwork}\n isRecent={itemData.isRecent}\n customization={customization?.connectCard}\n />\n </CustomConnectorItem>\n );\n })}\n </CustomConnectorsList>\n </CustomContainer>\n );\n },\n ),\n);\n\nConnectorsBlock.displayName = 'ConnectorsBlock';\n","/**\n * @file Disclaimer component with comprehensive customization options.\n */\n\nimport { cn, standardButtonClasses } from '@tuwaio/nova-core';\nimport React, { ComponentType, forwardRef, useCallback, useId, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\n\n// --- Types ---\n/**\n * Type definition for button actions\n * Can be either a URL string for external links or a callback function\n */\ntype ButtonAction = string | (() => void);\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n 'aria-describedby'?: string;\n 'data-testid'?: string;\n 'aria-live'?: 'polite' | 'assertive' | 'off';\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ContentSectionProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-labelledby'?: string;\n};\n\ntype TitleProps = {\n id: string;\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-level'?: number;\n};\n\ntype DescriptionProps = {\n id: string;\n className?: string;\n children: React.ReactNode;\n role?: string;\n};\n\ntype AdditionalContentProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n};\n\ntype ActionsProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n};\n\ntype ButtonProps = {\n action: ButtonAction;\n children: React.ReactNode;\n 'aria-label'?: string;\n className?: string;\n 'data-testid'?: string;\n};\n\ntype StatusProps = {\n className?: string;\n children?: React.ReactNode;\n 'aria-live'?: 'polite' | 'assertive' | 'off';\n 'aria-atomic'?: boolean;\n role?: string;\n};\n\n/**\n * Customization options for Disclaimer component\n */\nexport type DisclaimerCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom content section */\n ContentSection?: ComponentType<ContentSectionProps>;\n /** Custom title component */\n Title?: ComponentType<TitleProps>;\n /** Custom description component */\n Description?: ComponentType<DescriptionProps>;\n /** Custom additional content wrapper */\n AdditionalContent?: ComponentType<AdditionalContentProps>;\n /** Custom actions section */\n Actions?: ComponentType<ActionsProps>;\n /** Custom link button */\n LinkButton?: ComponentType<ButtonProps>;\n /** Custom action button */\n ActionButton?: ComponentType<ButtonProps>;\n /** Custom status component */\n Status?: ComponentType<StatusProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { compact: boolean }) => string;\n /** Function to generate content section classes */\n contentSection?: (params: { compact: boolean }) => string;\n /** Function to generate title classes */\n title?: (params: { compact: boolean }) => string;\n /** Function to generate description classes */\n description?: () => string;\n /** Function to generate additional content classes */\n additionalContent?: () => string;\n /** Function to generate actions classes */\n actions?: () => string;\n /** Function to generate button classes */\n button?: (params: { isLink: boolean; isPrimary: boolean }) => string;\n /** Function to generate status classes */\n status?: () => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for primary button action */\n onLearnMoreAction?: () => void;\n /** Custom handler for secondary button action */\n onListAction?: () => void;\n /** Custom handler for component mount */\n onMount?: () => void;\n /** Custom handler for component unmount */\n onUnmount?: () => void;\n };\n /** Configuration options */\n config?: {\n /** Custom button labels */\n buttonLabels?: {\n learnMore?: string;\n listAction?: string;\n };\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: string;\n contentSection?: string;\n actions?: string;\n additionalContent?: string;\n };\n };\n};\n\n/**\n * Props for the Disclaimer component\n */\nexport interface DisclaimerProps {\n /** Main title text for the disclaimer */\n title: string;\n /** Descriptive text explaining the disclaimer content */\n description: string;\n /** Action for the primary \"Learn More\" button - can be URL or callback */\n learnMoreAction: ButtonAction;\n /** Optional action for the secondary \"List of Networks\" button */\n listAction?: ButtonAction;\n /** Custom CSS classes for styling the disclaimer container */\n className?: string;\n /** Optional custom ARIA label for enhanced accessibility */\n 'aria-label'?: string;\n /** Whether to show the disclaimer in compact mode */\n compact?: boolean;\n /** Additional content to display below the description */\n children?: React.ReactNode;\n /** Custom test ID for testing purposes */\n 'data-testid'?: string;\n /** Whether the disclaimer should be announced to screen readers */\n announceToScreenReader?: boolean;\n /** Customization options */\n customization?: DisclaimerCustomization;\n}\n\n/**\n * Type guard to determine if action is a URL string\n * @param action - The action to check\n * @returns True if action is a string (URL), false if it's a function\n */\nconst isLink = (action: ButtonAction): action is string => typeof action === 'string';\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLDivElement, ContainerProps>(({ children, className, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n));\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultContentSection: React.FC<ContentSectionProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\nconst DefaultTitle: React.FC<TitleProps> = ({ children, className, ...props }) => (\n <h3 className={className} {...props}>\n {children}\n </h3>\n);\n\nconst DefaultDescription: React.FC<DescriptionProps> = ({ children, className, ...props }) => (\n <p className={className} {...props}>\n {children}\n </p>\n);\n\nconst DefaultAdditionalContent: React.FC<AdditionalContentProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\nconst DefaultActions: React.FC<ActionsProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\nconst DefaultLinkButton: React.FC<ButtonProps> = ({\n action,\n children,\n 'aria-label': ariaLabel,\n className,\n 'data-testid': testId,\n}) => {\n const labels = useNovaConnectLabels();\n\n // Type guard to ensure action is string for href\n if (!isLink(action)) {\n console.error('LinkButton received non-string action:', action);\n return null;\n }\n\n return (\n <a\n href={action}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className={className}\n aria-label={ariaLabel || `${children} (${labels.learnMore})`}\n data-testid={testId}\n role=\"button\"\n >\n {children}\n {/* Screen reader indication for external link */}\n <span className=\"novacon:sr-only\"> (opens in new tab)</span>\n </a>\n );\n};\n\nconst DefaultActionButton: React.FC<ButtonProps> = ({\n action,\n children,\n 'aria-label': ariaLabel,\n className,\n 'data-testid': testId,\n}) => {\n const handleClick = useCallback(() => {\n if (typeof action === 'function') {\n action();\n }\n }, [action]);\n\n return (\n <button type=\"button\" onClick={handleClick} className={className} aria-label={ariaLabel} data-testid={testId}>\n {children}\n </button>\n );\n};\n\nconst DefaultStatus: React.FC<StatusProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\n/**\n * Educational disclaimer component with call-to-action buttons\n *\n * This component provides educational content with actionable buttons for:\n * - Informational disclaimers about wallets, networks, or other concepts\n * - Educational content with \"Learn More\" functionality\n * - Network information with optional \"List of Networks\" access\n * - Responsive layout with proper spacing and visual hierarchy\n * - Full WCAG accessibility compliance with screen reader support\n * - Keyboard navigation with proper focus management\n * - Semantic HTML structure with comprehensive ARIA labeling\n * - Internationalization support for button labels\n * - Support for both internal callbacks and external links\n * - Flexible content areas with optional children support\n * - Full customization of all child components\n *\n * The component automatically handles different action types:\n * - **String actions**: Rendered as external links with security attributes\n * - **Function actions**: Rendered as buttons with callback execution\n * - **Mixed actions**: Can combine both types for different buttons\n *\n * @example Basic usage\n * ```tsx\n * <Disclaimer\n * title=\"What is a wallet?\"\n * description=\"Wallets are essential for managing your crypto...\"\n * learnMoreAction={() => setContentType('about')}\n * listAction=\"https://example.com/networks\"\n * />\n * ```\n *\n * @example With customization\n * ```tsx\n * <Disclaimer\n * title=\"Network Information\"\n * description=\"Choose the right network for your transactions\"\n * learnMoreAction={handleLearnMore}\n * compact\n * customization={{\n * classNames: {\n * container: ({ compact }) => compact ? 'custom-compact' : 'custom-full',\n * title: () => 'custom-title-styling'\n * },\n * components: {\n * LinkButton: CustomLinkButton\n * }\n * }}\n * />\n * ```\n */\nexport const Disclaimer = forwardRef<HTMLDivElement, DisclaimerProps>(\n (\n {\n title,\n description,\n learnMoreAction,\n listAction,\n className,\n 'aria-label': ariaLabel,\n compact = false,\n children,\n 'data-testid': testId,\n announceToScreenReader = false,\n customization,\n },\n ref,\n ) => {\n // Get localized labels for UI text\n const labels = useNovaConnectLabels();\n\n // Generate unique ID using React's useId hook\n const uniqueId = useId();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n ContentSection: CustomContentSection = DefaultContentSection,\n Title: CustomTitle = DefaultTitle,\n Description: CustomDescription = DefaultDescription,\n AdditionalContent: CustomAdditionalContent = DefaultAdditionalContent,\n Actions: CustomActions = DefaultActions,\n LinkButton: CustomLinkButton = DefaultLinkButton,\n ActionButton: CustomActionButton = DefaultActionButton,\n Status: CustomStatus = DefaultStatus,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized container classes based on compact mode\n */\n const containerClasses = useMemo(\n () =>\n cn(\n customization?.classNames?.container?.({ compact }) ??\n cn(\n 'novacon:p-2 novacon:rounded-xl novacon:border novacon:border-[var(--tuwa-border-primary)] novacon:flex novacon:flex-col',\n compact\n ? 'novacon:gap-2 novacon:sm:p-3 novacon:sm:gap-3'\n : 'novacon:gap-2 novacon:sm:p-4 novacon:sm:gap-4',\n ),\n className,\n ),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [compact, className, customization?.classNames?.container],\n );\n\n /**\n * Memoized content classes based on compact mode\n */\n const contentClasses = useMemo(\n () =>\n customization?.classNames?.contentSection?.({ compact }) ??\n cn('novacon:flex novacon:flex-col', compact ? 'novacon:gap-1' : 'novacon:gap-2'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [compact, customization?.classNames?.contentSection],\n );\n\n /**\n * Memoized title classes based on compact mode\n */\n const titleClasses = useMemo(\n () =>\n customization?.classNames?.title?.({ compact }) ??\n cn(\n 'novacon:font-bold novacon:text-[var(--tuwa-text-primary)]',\n compact ? 'novacon:text-base' : 'novacon:text-lg',\n ),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [compact, customization?.classNames?.title],\n );\n\n /**\n * Generate unique ID for the disclaimer content using React's useId\n */\n const disclaimerId = useMemo(() => {\n const sanitizedTitle = title.toLowerCase().replace(/\\s+/g, '-');\n return `disclaimer-${sanitizedTitle}-${uniqueId}`;\n }, [title, uniqueId]);\n\n /**\n * Generate button test IDs based on main test ID\n */\n const buttonTestIds = useMemo(\n () => ({\n learnMore: testId ? `${testId}-learn-more` : undefined,\n listAction: testId ? `${testId}-list-action` : undefined,\n }),\n [testId],\n );\n\n /**\n * Handle rendering of action buttons with proper type checking\n */\n const renderActionButton = useCallback(\n (action: ButtonAction, buttonText: string, ariaLabel: string, testId?: string, isPrimary = false) => {\n const isLinkAction = isLink(action);\n const buttonClasses = cn(\n customization?.classNames?.button?.({ isLink: isLinkAction, isPrimary }) ?? standardButtonClasses,\n );\n\n if (isLinkAction) {\n return (\n <CustomLinkButton action={action} aria-label={ariaLabel} data-testid={testId} className={buttonClasses}>\n {buttonText}\n </CustomLinkButton>\n );\n } else {\n return (\n <CustomActionButton action={action} aria-label={ariaLabel} data-testid={testId} className={buttonClasses}>\n {buttonText}\n </CustomActionButton>\n );\n }\n },\n [customization, CustomLinkButton, CustomActionButton],\n );\n\n // Handle mount/unmount effects\n React.useEffect(() => {\n customHandlers?.onMount?.();\n return () => customHandlers?.onUnmount?.();\n }, [customHandlers]);\n\n return (\n <CustomContainer\n ref={ref}\n className={containerClasses}\n role=\"complementary\"\n aria-label={customConfig?.ariaLabels?.container ?? ariaLabel ?? `${title} disclaimer`}\n aria-describedby={`${disclaimerId}-description`}\n data-testid={testId}\n {...(announceToScreenReader && { 'aria-live': 'polite' as const })}\n >\n {/* Content Section */}\n <CustomContentSection className={contentClasses} role=\"group\" aria-labelledby={`${disclaimerId}-title`}>\n {/* Title */}\n <CustomTitle id={`${disclaimerId}-title`} className={titleClasses} role=\"heading\" aria-level={3}>\n {title}\n </CustomTitle>\n\n {/* Description */}\n <CustomDescription\n id={`${disclaimerId}-description`}\n className={\n customization?.classNames?.description?.() ?? 'novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]'\n }\n role=\"text\"\n >\n {description}\n </CustomDescription>\n\n {/* Additional Content */}\n {children && (\n <CustomAdditionalContent\n className={customization?.classNames?.additionalContent?.() ?? 'novacon:mt-1'}\n role=\"group\"\n aria-label={customConfig?.ariaLabels?.additionalContent ?? 'Additional disclaimer information'}\n >\n {children}\n </CustomAdditionalContent>\n )}\n </CustomContentSection>\n\n {/* Actions Section */}\n <CustomActions\n className={customization?.classNames?.actions?.() ?? 'novacon:flex novacon:gap-3 novacon:justify-end'}\n role=\"group\"\n aria-label={customConfig?.ariaLabels?.actions ?? 'Disclaimer actions'}\n >\n {/* Primary Learn More Button */}\n {renderActionButton(\n learnMoreAction,\n customConfig?.buttonLabels?.learnMore ?? labels.learnMore,\n `${customConfig?.buttonLabels?.learnMore ?? labels.learnMore} about ${title.toLowerCase()}`,\n buttonTestIds.learnMore,\n true,\n )}\n\n {/* Optional Secondary Action Button */}\n {listAction &&\n renderActionButton(\n listAction,\n customConfig?.buttonLabels?.listAction ?? labels.listOfNetworks,\n `View ${(customConfig?.buttonLabels?.listAction ?? labels.listOfNetworks).toLowerCase()}`,\n buttonTestIds.listAction,\n false,\n )}\n </CustomActions>\n\n {/* Screen reader summary */}\n <CustomStatus className={customization?.classNames?.status?.() ?? 'novacon:sr-only'}>\n Disclaimer about {title.toLowerCase()}. {description}\n {learnMoreAction && ` ${customConfig?.buttonLabels?.learnMore ?? labels.learnMore} action available.`}\n {listAction && ` ${customConfig?.buttonLabels?.listAction ?? labels.listOfNetworks} action available.`}\n </CustomStatus>\n\n {/* Hidden live region for dynamic content updates */}\n {announceToScreenReader && (\n <CustomStatus\n className={customization?.classNames?.status?.() ?? 'novacon:sr-only'}\n aria-live=\"polite\"\n aria-atomic={true}\n role=\"status\"\n >\n {/* This will announce content changes to screen readers */}\n </CustomStatus>\n )}\n </CustomContainer>\n );\n },\n);\n\nDisclaimer.displayName = 'Disclaimer';\n","/**\n * @file ConnectorsSelections component with comprehensive customization options and categorized connector display.\n */\n\nimport { ExclamationTriangleIcon } from '@heroicons/react/24/outline';\nimport { cn, isTouchDevice } from '@tuwaio/nova-core';\nimport { formatWalletName, isSafeApp, OrbitAdapter } from '@tuwaio/orbit-core';\nimport React, { ComponentType, forwardRef, memo, useCallback, useMemo } from 'react';\n\nimport { ConnectContentType } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { InitialChains } from '../../types';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\nimport { WalletIcon } from '../WalletIcon';\nimport { ConnectCard, ConnectCardCustomization } from './ConnectCard';\nimport { GroupedConnector } from './ConnectModal';\nimport { ConnectorsBlock, ConnectorsBlockCustomization } from './ConnectorsBlock';\nimport { Disclaimer } from './Disclaimer';\n\n// --- Types ---\n\n/**\n * Connector selections data for customization context\n */\nexport interface ConnectorsSelectionsData {\n /** Currently selected network adapter */\n selectedAdapter: OrbitAdapter | undefined;\n /** All available connectors */\n connectors: GroupedConnector[];\n /** Whether only one network is available */\n isOnlyOneNetwork: boolean;\n /** Whether device is touch-enabled */\n isTouch: boolean;\n /** Whether impersonated wallet is available */\n hasImpersonatedConnector: boolean;\n /** Whether impersonated section should be shown */\n showImpersonated: boolean;\n /** Filtered connector groups */\n connectorGroups: {\n installed: GroupedConnector[];\n popular: GroupedConnector[];\n impersonated?: GroupedConnector;\n };\n /** Current labels from i18n */\n labels: ReturnType<typeof useNovaConnectLabels>;\n}\n\n/**\n * Impersonate section data\n */\nexport interface ImpersonateSectionData {\n /** The impersonated wallet connector */\n connector: GroupedConnector;\n /** Whether device is touch-enabled */\n isTouch: boolean;\n /** Current labels from i18n */\n labels: ReturnType<typeof useNovaConnectLabels>;\n /** Section data for context */\n sectionsData: ConnectorsSelectionsData;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ContentWrapperProps = {\n className?: string;\n children: React.ReactNode;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ConnectorsAreaProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ImpersonateSectionProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n impersonateData: ImpersonateSectionData;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ImpersonateTitleProps = {\n className?: string;\n children: React.ReactNode;\n impersonateData: ImpersonateSectionData;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLParagraphElement>;\n\ntype EmptyStateProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-live'?: 'polite' | 'assertive' | 'off';\n onClick?: () => void;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype DisclaimerSectionProps = {\n className?: string;\n children: React.ReactNode;\n selectionsData: ConnectorsSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * Customization options for ConnectorsSelections component\n */\nexport type ConnectorsSelectionsCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom content wrapper */\n ContentWrapper?: ComponentType<ContentWrapperProps>;\n /** Custom connectors area wrapper */\n ConnectorsArea?: ComponentType<ConnectorsAreaProps>;\n /** Custom impersonate section */\n ImpersonateSection?: ComponentType<ImpersonateSectionProps>;\n /** Custom impersonate title */\n ImpersonateTitle?: ComponentType<ImpersonateTitleProps>;\n /** Custom empty state */\n EmptyState?: ComponentType<EmptyStateProps>;\n /** Custom disclaimer section */\n DisclaimerSection?: ComponentType<DisclaimerSectionProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { selectionsData: ConnectorsSelectionsData }) => string;\n /** Function to generate content wrapper classes */\n contentWrapper?: (params: { selectionsData: ConnectorsSelectionsData }) => string;\n /** Function to generate connectors area classes */\n connectorsArea?: (params: { selectionsData: ConnectorsSelectionsData }) => string;\n /** Function to generate impersonate section classes */\n impersonateSection?: (params: {\n impersonateData: ImpersonateSectionData;\n selectionsData: ConnectorsSelectionsData;\n }) => string;\n /** Function to generate impersonate title classes */\n impersonateTitle?: (params: {\n impersonateData: ImpersonateSectionData;\n selectionsData: ConnectorsSelectionsData;\n }) => string;\n /** Function to generate empty state classes */\n emptyState?: (params: { selectionsData: ConnectorsSelectionsData }) => string;\n /** Function to generate disclaimer section classes */\n disclaimerSection?: (params: { selectionsData: ConnectorsSelectionsData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom impersonate click handler */\n onImpersonateClick?: (\n impersonateData: ImpersonateSectionData,\n selectionsData: ConnectorsSelectionsData,\n originalHandler: () => void,\n ) => void;\n /** Custom empty state action handler */\n onEmptyStateAction?: (selectionsData: ConnectorsSelectionsData) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: (selectionsData: ConnectorsSelectionsData) => string;\n connectorsArea?: (selectionsData: ConnectorsSelectionsData) => string;\n impersonateSection?: (impersonateData: ImpersonateSectionData) => string;\n };\n /** Layout configuration */\n layout?: {\n /** Touch device classes for connectors area */\n touchConnectorsClasses?: string[];\n /** Mouse device classes for connectors area */\n mouseConnectorsClasses?: string[];\n /** Touch device classes for content wrapper */\n touchContentClasses?: string[];\n /** Mouse device classes for content wrapper */\n mouseContentClasses?: string[];\n };\n /** Show/hide features */\n features?: {\n /** Whether to show empty state */\n showEmptyState?: boolean;\n /** Whether to show disclaimer on touch devices */\n showDisclaimer?: boolean;\n /** Whether to show impersonate section */\n showImpersonate?: boolean;\n };\n };\n /** ConnectorsBlock customization for each connector block */\n connectorsBlock?: {\n /** Customization for installed connectors block */\n installed?: ConnectorsBlockCustomization;\n /** Customization for popular connectors block */\n popular?: ConnectorsBlockCustomization;\n };\n /** ConnectCard customization for impersonate card */\n impersonateCard?: ConnectCardCustomization;\n};\n\n/**\n * Props for the ConnectorsSelections component\n */\nexport interface ConnectorsSelectionsProps\n extends Pick<ConnectButtonProps, 'withImpersonated' | 'store'>,\n InitialChains {\n /** Currently selected network adapter */\n selectedAdapter: OrbitAdapter | undefined;\n /** Array of grouped wallet connectors */\n connectors: GroupedConnector[];\n /** Click handler for connector selection */\n onClick: (connector: GroupedConnector) => void;\n /** Function to set connection status */\n setIsConnected: (value: boolean) => void;\n /** Function to control modal open state */\n setIsOpen: (value: boolean) => void;\n /** Function to wait for connection prediction */\n waitForPredict: () => boolean | undefined;\n /** Function to set modal content type */\n setContentType: (contentType: ConnectContentType) => void;\n /** Whether only one network is available */\n isOnlyOneNetwork?: boolean;\n /** Customization options */\n customization?: ConnectorsSelectionsCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLDivElement, ContainerProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { selectionsData: _selectionsData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n});\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultContentWrapper = forwardRef<HTMLDivElement, ContentWrapperProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { selectionsData: _selectionsData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n },\n);\nDefaultContentWrapper.displayName = 'DefaultContentWrapper';\n\nconst DefaultConnectorsArea = forwardRef<HTMLDivElement, ConnectorsAreaProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { selectionsData: _selectionsData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n },\n);\nDefaultConnectorsArea.displayName = 'DefaultConnectorsArea';\n\nconst DefaultImpersonateSection = forwardRef<HTMLDivElement, ImpersonateSectionProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { impersonateData: _impersonateData, selectionsData: _selectionsData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n },\n);\nDefaultImpersonateSection.displayName = 'DefaultImpersonateSection';\n\nconst DefaultImpersonateTitle = forwardRef<HTMLParagraphElement, ImpersonateTitleProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { impersonateData: _impersonateData, selectionsData: _selectionsData, ...restProps } = props;\n return (\n <p ref={ref} className={className} {...restProps}>\n {children}\n </p>\n );\n },\n);\nDefaultImpersonateTitle.displayName = 'DefaultImpersonateTitle';\n\nconst DefaultEmptyState = forwardRef<HTMLDivElement, EmptyStateProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { selectionsData: _selectionsData, onClick, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps} onClick={onClick}>\n {children}\n </div>\n );\n});\nDefaultEmptyState.displayName = 'DefaultEmptyState';\n\nconst DefaultDisclaimerSection = forwardRef<HTMLDivElement, DisclaimerSectionProps>(\n ({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { selectionsData: _selectionsData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n },\n);\nDefaultDisclaimerSection.displayName = 'DefaultDisclaimerSection';\n\n/**\n * ConnectorsSelections component - Main wallet selection interface with categorized connectors\n *\n * This component provides the primary wallet selection interface with:\n * - Categorized wallet sections (Installed, Popular, Impersonate)\n * - Responsive layout adapting to touch/mouse interfaces\n * - Safe App environment detection and filtering\n * - Empty state handling for missing connectors\n * - Educational content integration for touch devices\n * - Full accessibility support with semantic structure\n * - Complete customization of all child components and styling\n *\n * Wallet categorization:\n * - Installed: Detected browser extension wallets (excluding popular ones)\n * - Popular: Coinbase Wallet and WalletConnect for broader compatibility\n * - Impersonate: Development/testing wallet for address simulation\n * - Safe App filtering: Conditional Safe Wallet display based on environment\n *\n * Layout features:\n * - Touch devices: Horizontal scrolling with educational disclaimer\n * - Mouse devices: Vertical scrolling with fixed height container\n * - Responsive grid adapting to screen size and device capabilities\n * - Custom scrollbar styling with NovaCustomScroll class\n * - Customizable layout parameters and responsive behavior\n *\n * Empty state handling:\n * - Clear error messaging when no connectors found\n * - Contextual help text explaining the issue\n * - Visual indicators with warning icons\n * - Proper error state accessibility\n * - Customizable empty state content and styling\n *\n * Accessibility features:\n * - Semantic HTML structure with proper headings\n * - ARIA labels for screen readers\n * - Role-based navigation support\n * - Focus management for keyboard users\n * - Error states with descriptive messaging\n * - Customizable ARIA labels and descriptions\n *\n * @example Basic usage\n * ```tsx\n * <ConnectorsSelections\n * selectedAdapter={OrbitAdapter.EVM}\n * connectors={availableConnectors}\n * onClick={(connector) => handleWalletSelection(connector)}\n * setIsConnected={setConnectionStatus}\n * setIsOpen={setModalOpen}\n * waitForPredict={() => checkConnectionState()}\n * setContentType={setModalContent}\n * withImpersonated={true}\n * isOnlyOneNetwork={false}\n * appChains={chainConfiguration}\n * solanaRPCUrls={solanaConfig}\n * store={walletStore}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectorsSelections\n * selectedAdapter={undefined}\n * connectors={allConnectors}\n * onClick={(connector) => initiateConnection(connector)}\n * setIsConnected={updateConnectionState}\n * setIsOpen={toggleModal}\n * waitForPredict={predictConnection}\n * setContentType={changeContent}\n * withImpersonated={false}\n * isOnlyOneNetwork={true}\n * customization={{\n * components: {\n * Container: CustomSelectionsContainer,\n * EmptyState: CustomEmptyStateComponent\n * },\n * classNames: {\n * connectorsArea: ({ selectionsData }) =>\n * selectionsData.isTouch ? 'horizontal-scroll' : 'vertical-stack',\n * impersonateSection: ({ impersonateData }) =>\n * impersonateData.isTouch ? 'touch-impersonate' : 'mouse-impersonate'\n * },\n * handlers: {\n * onImpersonateClick: (impersonateData, selectionsData, originalHandler) => {\n * analytics.track('impersonate_clicked');\n * originalHandler();\n * }\n * },\n * connectorsBlock: {\n * installed: {\n * classNames: {\n * title: () => 'custom-installed-title'\n * }\n * }\n * }\n * }}\n * />\n * ```\n */\nexport const ConnectorsSelections = memo(\n forwardRef<HTMLDivElement, ConnectorsSelectionsProps>(\n (\n {\n setIsConnected,\n setIsOpen,\n selectedAdapter,\n connectors,\n onClick,\n appChains,\n solanaRPCUrls,\n waitForPredict,\n setContentType,\n withImpersonated,\n isOnlyOneNetwork = false,\n store,\n customization,\n },\n ref,\n ) => {\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n ContentWrapper: CustomContentWrapper = DefaultContentWrapper,\n ConnectorsArea: CustomConnectorsArea = DefaultConnectorsArea,\n ImpersonateSection: CustomImpersonateSection = DefaultImpersonateSection,\n ImpersonateTitle: CustomImpersonateTitle = DefaultImpersonateTitle,\n EmptyState: CustomEmptyState = DefaultEmptyState,\n DisclaimerSection: CustomDisclaimerSection = DefaultDisclaimerSection,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized labels and touch detection\n */\n const labels = useNovaConnectLabels();\n const isTouch = useMemo(() => isTouchDevice(), []);\n\n /**\n * Memoized connector filtering\n */\n const connectorGroups = useMemo(() => {\n const installedConnectorsInitial = connectors.filter((group) => {\n const formattedName = formatWalletName(group.name);\n return (\n formattedName !== 'impersonatedwallet' &&\n formattedName !== 'coinbasewallet' &&\n formattedName !== 'walletconnect'\n );\n });\n\n const installedConnectors = isSafeApp\n ? installedConnectorsInitial\n : installedConnectorsInitial.filter((group) => formatWalletName(group.name) !== 'safewallet');\n\n const popularConnectors = connectors.filter((group) => {\n const formattedName = formatWalletName(group.name);\n return formattedName === 'coinbasewallet' || formattedName === 'walletconnect';\n });\n\n const impersonatedConnector = connectors.find((group) => formatWalletName(group.name) === 'impersonatedwallet');\n\n return {\n installed: installedConnectors,\n popular: popularConnectors,\n impersonated: impersonatedConnector,\n };\n }, [connectors]);\n\n /**\n * Memoized selections data\n */\n const selectionsData = useMemo(\n (): ConnectorsSelectionsData => ({\n selectedAdapter,\n connectors,\n isOnlyOneNetwork,\n isTouch,\n hasImpersonatedConnector: Boolean(connectorGroups.impersonated),\n showImpersonated: Boolean(connectorGroups.impersonated && withImpersonated),\n connectorGroups,\n labels,\n }),\n [selectedAdapter, connectors, isOnlyOneNetwork, isTouch, connectorGroups, withImpersonated, labels],\n );\n\n /**\n * Memoized impersonate section data\n */\n const impersonateData = useMemo((): ImpersonateSectionData | undefined => {\n if (!connectorGroups.impersonated) return undefined;\n\n return {\n connector: connectorGroups.impersonated,\n isTouch,\n labels,\n sectionsData: selectionsData,\n };\n }, [connectorGroups.impersonated, isTouch, labels, selectionsData]);\n\n /**\n * Memoized layout classes\n */\n const layoutClasses = useMemo(() => {\n const touchConnectorsClasses = customConfig?.layout?.touchConnectorsClasses ?? [\n 'novacon:flex-row',\n 'novacon:overflow-x-auto',\n 'novacon:max-h-none',\n 'novacon:gap-3',\n 'novacon:pb-4',\n 'novacon:px-1',\n ];\n\n const mouseConnectorsClasses = customConfig?.layout?.mouseConnectorsClasses ?? [\n 'novacon:flex-col',\n 'novacon:overflow-y-auto',\n 'novacon:max-h-[310px]',\n 'novacon:gap-2',\n ];\n\n const touchContentClasses = customConfig?.layout?.touchContentClasses ?? [\n 'novacon:flex',\n 'novacon:flex-col',\n 'novacon:gap-2',\n 'novacon:flex-row',\n ];\n\n const mouseContentClasses = customConfig?.layout?.mouseContentClasses ?? [\n 'novacon:flex',\n 'novacon:flex-col',\n 'novacon:gap-2',\n ];\n\n return {\n touchConnectorsClasses,\n mouseConnectorsClasses,\n touchContentClasses,\n mouseContentClasses,\n };\n }, [customConfig?.layout]);\n\n /**\n * Handles click on impersonated wallet option\n */\n const handleImpersonateClick = useCallback(() => {\n if (!connectorGroups.impersonated) return;\n onClick(connectorGroups.impersonated);\n }, [connectorGroups.impersonated, onClick]);\n\n /**\n * Wrapper for custom impersonate click handler\n */\n const handleImpersonateClickWrapper = useCallback(() => {\n if (!impersonateData) return;\n\n if (customHandlers?.onImpersonateClick) {\n customHandlers.onImpersonateClick(impersonateData, selectionsData, handleImpersonateClick);\n } else {\n handleImpersonateClick();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onImpersonateClick, impersonateData, selectionsData, handleImpersonateClick]);\n\n /**\n * Memoized CSS classes\n */\n const cssClasses = useMemo(\n () => ({\n container:\n customization?.classNames?.container?.({ selectionsData }) ?? 'novacon:flex novacon:flex-col novacon:gap-4',\n\n contentWrapper:\n customization?.classNames?.contentWrapper?.({ selectionsData }) ??\n cn(isTouch ? layoutClasses.touchContentClasses : layoutClasses.mouseContentClasses),\n\n connectorsArea:\n customization?.classNames?.connectorsArea?.({ selectionsData }) ??\n cn(\n 'novacon:flex NovaCustomScroll',\n isTouch ? layoutClasses.touchConnectorsClasses : layoutClasses.mouseConnectorsClasses,\n ),\n\n impersonateSection:\n (impersonateData && customization?.classNames?.impersonateSection?.({ impersonateData, selectionsData })) ??\n cn({ 'novacon:flex novacon:flex-col novacon:gap-2': isTouch }),\n\n impersonateTitle:\n (impersonateData && customization?.classNames?.impersonateTitle?.({ impersonateData, selectionsData })) ??\n cn('novacon:text-sm novacon:hidden', { 'novacon:block novacon:opacity-0': isTouch }),\n\n emptyState:\n customization?.classNames?.emptyState?.({ selectionsData }) ??\n 'novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:p-8 novacon:text-center novacon:border novacon:border-[var(--tuwa-border-primary)] novacon:rounded-xl novacon:bg-[var(--tuwa-bg-secondary)] novacon:text-[var(--tuwa-text-secondary)]',\n\n disclaimerSection: customization?.classNames?.disclaimerSection?.({ selectionsData }) ?? '',\n }),\n [customization?.classNames, selectionsData, impersonateData, isTouch, layoutClasses],\n );\n\n // Early return for empty state\n if (selectedAdapter && !connectors?.length) {\n if (customConfig?.features?.showEmptyState === false) {\n return null;\n }\n\n return (\n <CustomEmptyState\n ref={ref}\n className={cssClasses.emptyState}\n role=\"alert\"\n aria-live=\"polite\"\n selectionsData={selectionsData}\n onClick={\n customHandlers?.onEmptyStateAction ? () => customHandlers.onEmptyStateAction!(selectionsData) : undefined\n }\n >\n <ExclamationTriangleIcon\n width={32}\n height={32}\n className=\"novacon:text-[var(--tuwa-text-accent)] novacon:mb-3\"\n aria-hidden=\"true\"\n />\n <h2 className=\"novacon:text-lg novacon:font-semibold novacon:text-[var(--tuwa-text-primary)] novacon:mb-1\">\n {labels.noConnectorsFound}\n </h2>\n <p className=\"novacon:text-sm\">{labels.noConnectorsDescription}</p>\n </CustomEmptyState>\n );\n }\n\n const containerAriaLabel = customConfig?.ariaLabels?.container?.(selectionsData) ?? labels.connectWallet;\n const connectorsAreaAriaLabel =\n customConfig?.ariaLabels?.connectorsArea?.(selectionsData) ?? 'Available wallet connectors';\n const impersonateAriaLabel =\n (impersonateData && customConfig?.ariaLabels?.impersonateSection?.(impersonateData)) ?? labels.impersonate;\n\n return (\n <CustomContainer\n ref={ref}\n className={cssClasses.container}\n role=\"region\"\n aria-label={containerAriaLabel}\n selectionsData={selectionsData}\n >\n <CustomContentWrapper className={cssClasses.contentWrapper} selectionsData={selectionsData}>\n <CustomConnectorsArea\n className={cssClasses.connectorsArea}\n role=\"region\"\n aria-label={connectorsAreaAriaLabel}\n selectionsData={selectionsData}\n >\n <ConnectorsBlock\n connectors={connectorGroups.installed}\n title={labels.installed}\n selectedAdapter={selectedAdapter}\n onClick={onClick}\n waitForPredict={waitForPredict}\n solanaRPCUrls={solanaRPCUrls}\n setIsConnected={setIsConnected}\n setIsOpen={setIsOpen}\n appChains={appChains}\n isOnlyOneNetwork={isOnlyOneNetwork}\n isTitleBold\n store={store}\n customization={customization?.connectorsBlock?.installed}\n />\n {!!connectorGroups.popular.length && (\n <ConnectorsBlock\n connectors={connectorGroups.popular}\n title={labels.popular}\n selectedAdapter={selectedAdapter}\n onClick={onClick}\n waitForPredict={waitForPredict}\n solanaRPCUrls={solanaRPCUrls}\n setIsConnected={setIsConnected}\n setIsOpen={setIsOpen}\n appChains={appChains}\n isOnlyOneNetwork={isOnlyOneNetwork}\n store={store}\n customization={customization?.connectorsBlock?.popular}\n />\n )}\n </CustomConnectorsArea>\n\n {selectionsData.showImpersonated &&\n impersonateData &&\n customConfig?.features?.showImpersonate !== false && (\n <CustomImpersonateSection\n className={cssClasses.impersonateSection}\n role=\"region\"\n aria-label={impersonateAriaLabel}\n impersonateData={impersonateData}\n selectionsData={selectionsData}\n >\n <CustomImpersonateTitle\n className={cssClasses.impersonateTitle}\n impersonateData={impersonateData}\n selectionsData={selectionsData}\n >\n {labels.impersonate}\n </CustomImpersonateTitle>\n <ConnectCard\n icon={<WalletIcon name=\"impersonatedwallet\" />}\n adapters={!selectedAdapter ? [OrbitAdapter.EVM] : undefined}\n onClick={handleImpersonateClickWrapper}\n title={labels.impersonate}\n subtitle={labels.readOnlyMode}\n isOnlyOneNetwork={isOnlyOneNetwork}\n customization={customization?.impersonateCard}\n />\n </CustomImpersonateSection>\n )}\n </CustomContentWrapper>\n\n {isTouch && customConfig?.features?.showDisclaimer !== false && (\n <CustomDisclaimerSection className={cssClasses.disclaimerSection} selectionsData={selectionsData}>\n <Disclaimer\n title={labels.whatIsWallet}\n description={labels.walletDescription}\n learnMoreAction={() => setContentType('about')}\n />\n </CustomDisclaimerSection>\n )}\n </CustomContainer>\n );\n },\n ),\n);\n\nConnectorsSelections.displayName = 'ConnectorsSelections';\n","/**\n * @file GetWallet component with comprehensive customization options and staggered animations.\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { cn, StarsBackground } from '@tuwaio/nova-core';\nimport { AnimatePresence, motion } from 'framer-motion';\nimport React, { ComponentType, forwardRef, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\n\n// --- Types ---\n\n/**\n * Configuration for wallet icons in the animation\n */\nexport interface WalletIconConfig {\n /** Wallet key for Web3Icon component */\n walletKey: string;\n /** Position configuration using predefined position classes */\n position: {\n /** Top position class (e.g., 'top-[5%]', 'top-4') */\n top?: string;\n /** Bottom position class (e.g., 'bottom-[10%]', 'bottom-4') */\n bottom?: string;\n /** Left position class (e.g., 'left-[5%]', 'left-4') */\n left?: string;\n /** Right position class (e.g., 'right-[10%]', 'right-4') */\n right?: string;\n /** Transform classes for centering */\n transform?: string;\n };\n /** Size configuration using predefined size classes */\n size: {\n /** Width and height classes for mobile */\n mobile: {\n width: string;\n height: string;\n };\n /** Width and height classes for desktop */\n desktop: {\n width: string;\n height: string;\n };\n };\n /** Animation configuration */\n animation: {\n /** Animation duration in milliseconds */\n duration: number;\n /** Animation delay in milliseconds */\n delay: number;\n /** Whether to reverse animation direction */\n reverse?: boolean;\n /** Animation easing function */\n ease?: string;\n };\n /** ARIA label for the wallet icon */\n ariaLabel?: string;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n 'data-testid'?: string;\n} & React.RefAttributes<HTMLElement>;\n\ntype AnimationSectionProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n};\n\ntype StarsBackgroundProps = {\n className?: string;\n show: boolean;\n 'aria-hidden'?: boolean;\n};\n\ntype GradientOverlayProps = {\n className?: string;\n 'aria-hidden'?: boolean;\n};\n\ntype AnimationWrapperProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n enableAnimations: boolean;\n animationDelay?: number;\n animationDuration?: number;\n};\n\ntype WalletIconProps = {\n config: WalletIconConfig;\n enableAnimations: boolean;\n className?: string;\n};\n\ntype ContentSectionProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n};\n\ntype TitleProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-level'?: number;\n};\n\ntype DescriptionProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n};\n\ntype ScreenReaderProps = {\n className?: string;\n children: React.ReactNode;\n};\n\n/**\n * Customization options for GetWallet component\n */\nexport type GetWalletCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom animation section */\n AnimationSection?: ComponentType<AnimationSectionProps>;\n /** Custom stars background */\n StarsBackground?: ComponentType<StarsBackgroundProps>;\n /** Custom gradient overlay */\n GradientOverlay?: ComponentType<GradientOverlayProps>;\n /** Custom animation wrapper */\n AnimationWrapper?: ComponentType<AnimationWrapperProps>;\n /** Custom wallet icon display */\n WalletIcon?: ComponentType<WalletIconProps>;\n /** Custom content section */\n ContentSection?: ComponentType<ContentSectionProps>;\n /** Custom title component */\n Title?: ComponentType<TitleProps>;\n /** Custom description component */\n Description?: ComponentType<DescriptionProps>;\n /** Custom screen reader component */\n ScreenReader?: ComponentType<ScreenReaderProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { compact: boolean }) => string;\n /** Function to generate animation section classes */\n animationSection?: (params: { compact: boolean }) => string;\n /** Function to generate stars background classes */\n starsBackground?: () => string;\n /** Function to generate gradient overlay classes */\n gradientOverlay?: () => string;\n /** Function to generate animation wrapper classes */\n animationWrapper?: () => string;\n /** Function to generate wallet icon classes */\n walletIcon?: (params: { config: WalletIconConfig; enableAnimations: boolean }) => string;\n /** Function to generate content section classes */\n contentSection?: (params: { compact: boolean }) => string;\n /** Function to generate title classes */\n title?: (params: { compact: boolean }) => string;\n /** Function to generate description classes */\n description?: () => string;\n /** Function to generate screen reader classes */\n screenReader?: () => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for component mount */\n onMount?: () => void;\n /** Custom handler for component unmount */\n onUnmount?: () => void;\n /** Custom handler for animation start */\n onAnimationStart?: () => void;\n /** Custom handler for animation complete */\n onAnimationComplete?: () => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: string;\n animationSection?: string;\n animationWrapper?: string;\n contentSection?: string;\n };\n /** Animation configuration overrides */\n animation?: {\n /** Global animation duration multiplier */\n durationMultiplier?: number;\n /** Global animation delay multiplier */\n delayMultiplier?: number;\n /** Default easing function */\n defaultEase?: string;\n };\n };\n};\n\n/**\n * Props for the GetWallet component\n */\nexport interface GetWalletProps {\n /** Custom CSS classes for styling the container */\n className?: string;\n /** Optional custom ARIA label for enhanced accessibility */\n 'aria-label'?: string;\n /** Custom test ID for testing purposes */\n 'data-testid'?: string;\n /** Whether to show the component in compact mode */\n compact?: boolean;\n /** Whether animations should be enabled */\n enableAnimations?: boolean;\n /** Custom wallet icons to display instead of defaults */\n customWalletIcons?: WalletIconConfig[];\n /** Whether to show the background stars animation */\n showStarsBackground?: boolean;\n /** Customization options */\n customization?: GetWalletCustomization;\n}\n\n/**\n * Default wallet icons configuration with staggered animations\n */\nconst defaultWalletIcons: WalletIconConfig[] = [\n {\n walletKey: 'metamask',\n position: {\n top: 'novacon:top-[5%]',\n left: 'novacon:left-[5%]',\n },\n size: {\n mobile: { width: 'novacon:w-20', height: 'novacon:h-20' },\n desktop: { width: 'novacon:md:w-24', height: 'novacon:md:h-24' },\n },\n animation: {\n duration: 3500,\n delay: 200,\n ease: 'ease-in-out',\n },\n ariaLabel: 'MetaMask wallet icon',\n },\n {\n walletKey: 'coinbasewallet',\n position: {\n top: 'novacon:top-[10%]',\n right: 'novacon:right-[10%]',\n },\n size: {\n mobile: { width: 'novacon:w-16', height: 'novacon:h-16' },\n desktop: { width: 'novacon:md:w-20', height: 'novacon:md:h-20' },\n },\n animation: {\n duration: 5000,\n delay: 800,\n reverse: true,\n ease: 'ease-out',\n },\n ariaLabel: 'Coinbase Wallet icon',\n },\n {\n walletKey: 'trustwallet',\n position: {\n top: 'novacon:top-[25%]',\n left: 'novacon:left-1/2',\n transform: 'novacon:-translate-x-1/2',\n },\n size: {\n mobile: { width: 'novacon:w-20', height: 'novacon:h-20' },\n desktop: { width: 'novacon:md:w-24', height: 'novacon:md:h-24' },\n },\n animation: {\n duration: 8000,\n delay: 4000,\n ease: 'ease-in-out',\n },\n ariaLabel: 'Trust Wallet icon',\n },\n {\n walletKey: 'bravewallet',\n position: {\n bottom: 'novacon:bottom-[10%]',\n left: 'novacon:left-[10%]',\n },\n size: {\n mobile: { width: 'novacon:w-20', height: 'novacon:h-20' },\n desktop: { width: 'novacon:md:w-20', height: 'novacon:md:h-20' },\n },\n animation: {\n duration: 4500,\n delay: 2500,\n reverse: true,\n ease: 'ease-in',\n },\n ariaLabel: 'Brave Wallet icon',\n },\n {\n walletKey: 'phantomwallet',\n position: {\n bottom: 'novacon:bottom-[15%]',\n right: 'novacon:right-[15%]',\n },\n size: {\n mobile: { width: 'novacon:w-14', height: 'novacon:h-14' },\n desktop: { width: 'novacon:md:w-18', height: 'novacon:md:h-18' },\n },\n animation: {\n duration: 4000,\n delay: 500,\n ease: 'ease-out',\n },\n ariaLabel: 'Phantom Wallet icon',\n },\n];\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLElement, ContainerProps>(({ children, className, ...props }, ref) => (\n <section ref={ref} className={className} {...props}>\n {children}\n </section>\n));\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultAnimationSection: React.FC<AnimationSectionProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\nconst DefaultStarsBackground: React.FC<StarsBackgroundProps> = ({ className, show, ...props }) => (\n <>\n {show && (\n <div className={className} {...props}>\n <StarsBackground />\n </div>\n )}\n </>\n);\n\nconst DefaultGradientOverlay: React.FC<GradientOverlayProps> = ({ className, ...props }) => (\n <div className={className} {...props} />\n);\n\nconst DefaultAnimationWrapper: React.FC<AnimationWrapperProps> = ({\n children,\n className,\n enableAnimations,\n animationDelay = 0,\n animationDuration = 500,\n ...props\n}) => {\n if (!enableAnimations) {\n return (\n <div className={className} {...props}>\n {children}\n </div>\n );\n }\n\n return (\n <AnimatePresence>\n <motion.div\n animate={{ opacity: 1, scale: 1 }}\n initial={{ opacity: 0, scale: 0.1 }}\n transition={{\n duration: animationDuration / 1000,\n delay: animationDelay / 1000,\n ease: 'easeOut',\n }}\n className={className}\n {...props}\n >\n {children}\n </motion.div>\n </AnimatePresence>\n );\n};\n\nconst DefaultWalletIcon: React.FC<WalletIconProps> = ({ config, enableAnimations, className }) => {\n const { walletKey, position, size, animation, ariaLabel } = config;\n\n const positionClasses = useMemo(() => {\n const classes = ['novacon:absolute'];\n\n if (position.top) classes.push(position.top);\n if (position.bottom) classes.push(position.bottom);\n if (position.left) classes.push(position.left);\n if (position.right) classes.push(position.right);\n if (position.transform) classes.push(position.transform);\n\n return cn(classes);\n }, [position]);\n\n const sizeClasses = useMemo(() => {\n return cn(\n size.mobile.width,\n size.mobile.height,\n size.desktop.width,\n size.desktop.height,\n // Icon styling\n 'novacon:[&>img]:w-full!',\n 'novacon:[&>img]:h-full!',\n 'novacon:[&>svg]:w-full!',\n 'novacon:[&>svg]:h-full!',\n );\n }, [size]);\n\n const animationClasses = useMemo(() => {\n if (!enableAnimations) return '';\n return 'novacon:animate-[float_var(--float-duration,3000ms)_var(--float-ease,ease-in-out)_var(--float-delay,0ms)_infinite_var(--float-direction,normal)]';\n }, [enableAnimations]);\n\n const animationStyle = useMemo(() => {\n if (!enableAnimations) return {};\n\n return {\n '--float-duration': `${animation.duration}ms`,\n '--float-delay': `${animation.delay}ms`,\n '--float-ease': animation.ease || 'ease-in-out',\n '--float-direction': animation.reverse ? 'reverse' : 'normal',\n } as React.CSSProperties;\n }, [enableAnimations, animation]);\n\n return (\n <div\n className={cn(positionClasses, sizeClasses, animationClasses, className)}\n style={{ ...animationStyle }}\n role=\"img\"\n aria-label={ariaLabel || `${walletKey} wallet icon`}\n data-testid={`wallet-icon-${walletKey}`}\n >\n <Web3Icon walletKey={walletKey} />\n </div>\n );\n};\n\nconst DefaultContentSection: React.FC<ContentSectionProps> = ({ children, className, ...props }) => (\n <div className={className} {...props}>\n {children}\n </div>\n);\n\nconst DefaultTitle: React.FC<TitleProps> = ({ children, className, ...props }) => (\n <h2 className={className} {...props}>\n {children}\n </h2>\n);\n\nconst DefaultDescription: React.FC<DescriptionProps> = ({ children, className, ...props }) => (\n <p className={className} {...props}>\n {children}\n </p>\n);\n\nconst DefaultScreenReader: React.FC<ScreenReaderProps> = ({ children, className }) => (\n <div className={className}>{children}</div>\n);\n\n/**\n * Educational wallet introduction component with animated icons and comprehensive customization\n *\n * This component provides an engaging introduction to Web3 wallets featuring:\n * - Animated floating wallet icons with individual staggered animations and delays\n * - Educational content explaining Web3 wallet importance\n * - Responsive design with mobile-first approach\n * - Full accessibility support with proper ARIA labeling\n * - Internationalization support for all text content\n * - Performance optimizations with memoized calculations\n * - Customizable animations and icon configurations\n * - Semantic HTML structure for screen readers\n * - Proper focus management and keyboard navigation\n * - Full customization of all child components\n *\n * Animation features:\n * - Individual animation delays for each wallet icon using CSS custom properties\n * - Customizable duration, easing, and direction per icon\n * - Staggered floating animations for visual appeal\n * - Motion reduction respect (prefers-reduced-motion)\n * - Smooth entrance animations with framer-motion\n *\n * @example Basic usage\n * ```tsx\n * <GetWallet />\n * ```\n *\n * @example With customization\n * ```tsx\n * <GetWallet\n * compact\n * customization={{\n * classNames: {\n * container: ({ compact }) => compact ? 'custom-compact' : 'custom-full',\n * title: () => 'custom-title-styling'\n * },\n * components: {\n * WalletIcon: CustomWalletIcon\n * },\n * config: {\n * animation: {\n * durationMultiplier: 1.5,\n * delayMultiplier: 0.8\n * }\n * }\n * }}\n * />\n * ```\n */\nexport const GetWallet = forwardRef<HTMLElement, GetWalletProps>(\n (\n {\n className,\n 'aria-label': ariaLabel,\n 'data-testid': testId,\n compact = false,\n enableAnimations = true,\n customWalletIcons,\n showStarsBackground = true,\n customization,\n },\n ref,\n ) => {\n // Get localized labels for UI text\n const labels = useNovaConnectLabels();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n AnimationSection: CustomAnimationSection = DefaultAnimationSection,\n StarsBackground: CustomStarsBackground = DefaultStarsBackground,\n GradientOverlay: CustomGradientOverlay = DefaultGradientOverlay,\n AnimationWrapper: CustomAnimationWrapper = DefaultAnimationWrapper,\n WalletIcon: CustomWalletIcon = DefaultWalletIcon,\n ContentSection: CustomContentSection = DefaultContentSection,\n Title: CustomTitle = DefaultTitle,\n Description: CustomDescription = DefaultDescription,\n ScreenReader: CustomScreenReader = DefaultScreenReader,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized wallet icons configuration with applied multipliers\n */\n const walletIcons = useMemo(() => {\n const icons = customWalletIcons || defaultWalletIcons;\n const durationMultiplier = customConfig?.animation?.durationMultiplier ?? 1;\n const delayMultiplier = customConfig?.animation?.delayMultiplier ?? 1;\n\n return icons.map((icon) => ({\n ...icon,\n animation: {\n ...icon.animation,\n duration: Math.round(icon.animation.duration * durationMultiplier),\n delay: Math.round(icon.animation.delay * delayMultiplier),\n ease: icon.animation.ease || customConfig?.animation?.defaultEase || 'ease-in-out',\n },\n }));\n }, [customWalletIcons, customConfig?.animation]);\n\n /**\n * Memoized container classes\n */\n const containerClasses = useMemo(() => {\n const defaultClasses = cn('novacon:m-[-16px]', className);\n return customization?.classNames?.container?.({ compact }) ?? defaultClasses;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [compact, className, customization?.classNames?.container]);\n\n /**\n * Memoized animation section classes\n */\n const animationSectionClasses = useMemo(() => {\n const defaultClasses = cn(\n 'novacon:relative novacon:w-full novacon:overflow-hidden novacon:p-4',\n compact ? 'novacon:h-48' : 'novacon:h-64',\n );\n return customization?.classNames?.animationSection?.({ compact }) ?? defaultClasses;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [compact, customization?.classNames?.animationSection]);\n\n /**\n * Memoized stars background classes\n */\n const starsBackgroundClasses = useMemo(\n () => customization?.classNames?.starsBackground?.() ?? '',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.starsBackground],\n );\n\n /**\n * Memoized gradient overlay classes\n */\n const gradientOverlayClasses = useMemo(() => {\n const defaultClasses = cn(\n 'novacon:absolute novacon:inset-0 novacon:z-1',\n 'novacon:bg-[radial-gradient(ellipse_80%_80%_at_50%_-20%,rgba(120,119,198,0.15),rgba(255,255,255,0))]',\n );\n return customization?.classNames?.gradientOverlay?.() ?? defaultClasses;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.gradientOverlay]);\n\n /**\n * Memoized animation wrapper classes\n */\n const animationWrapperClasses = useMemo(() => {\n const defaultClasses = cn(\n 'novacon:relative novacon:z-2 novacon:w-full novacon:h-full',\n 'novacon:px-2 md:novacon:px-4',\n );\n return customization?.classNames?.animationWrapper?.() ?? defaultClasses;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.animationWrapper]);\n\n /**\n * Memoized content section classes\n */\n const contentSectionClasses = useMemo(() => {\n const defaultClasses = cn(\n 'novacon:text-center',\n compact ? 'novacon:pb-3 novacon:px-2 novacon:md:px-3' : 'novacon:pb-4 novacon:px-2 novacon:md:px-4',\n );\n return customization?.classNames?.contentSection?.({ compact }) ?? defaultClasses;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [compact, customization?.classNames?.contentSection]);\n\n /**\n * Memoized title classes\n */\n const titleClasses = useMemo(() => {\n const defaultClasses = cn(\n 'novacon:font-bold novacon:mb-2 novacon:text-[var(--tuwa-text-primary)]',\n compact ? 'novacon:text-lg' : 'novacon:text-xl',\n );\n return customization?.classNames?.title?.({ compact }) ?? defaultClasses;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [compact, customization?.classNames?.title]);\n\n /**\n * Memoized description classes\n */\n const descriptionClasses = useMemo(\n () => customization?.classNames?.description?.() ?? 'novacon:text-[var(--tuwa-text-secondary)]',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.description],\n );\n\n /**\n * Memoized screen reader classes\n */\n const screenReaderClasses = useMemo(\n () => customization?.classNames?.screenReader?.() ?? 'novacon:sr-only',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.screenReader],\n );\n\n // Handle mount/unmount effects\n React.useEffect(() => {\n customHandlers?.onMount?.();\n return () => customHandlers?.onUnmount?.();\n }, [customHandlers]);\n\n return (\n <CustomContainer\n ref={ref}\n className={containerClasses}\n role=\"region\"\n aria-label={customConfig?.ariaLabels?.container ?? ariaLabel ?? labels.startExploringWeb3}\n data-testid={testId}\n >\n {/* Animated Header Section */}\n <CustomAnimationSection\n className={animationSectionClasses}\n role=\"banner\"\n aria-label={customConfig?.ariaLabels?.animationSection ?? 'Wallet icons animation'}\n >\n {/* Stars Background */}\n <CustomStarsBackground className={starsBackgroundClasses} show={showStarsBackground} aria-hidden />\n\n {/* Gradient Overlay */}\n <CustomGradientOverlay className={gradientOverlayClasses} aria-hidden />\n\n {/* Animated Wallet Icons */}\n <CustomAnimationWrapper\n className={animationWrapperClasses}\n role=\"group\"\n aria-label={customConfig?.ariaLabels?.animationWrapper ?? `${labels.popular} wallet icons`}\n enableAnimations={enableAnimations}\n animationDelay={0}\n animationDuration={500}\n >\n {walletIcons.map((iconConfig) => (\n <CustomWalletIcon\n key={iconConfig.walletKey}\n config={iconConfig}\n enableAnimations={enableAnimations}\n className={customization?.classNames?.walletIcon?.({ config: iconConfig, enableAnimations })}\n />\n ))}\n\n {/* Screen reader content for animated icons */}\n <CustomScreenReader className={screenReaderClasses}>\n {labels.popular} wallets including {walletIcons.map((icon) => icon.walletKey).join(', ')} are displayed\n with floating animations to illustrate wallet variety.\n </CustomScreenReader>\n </CustomAnimationWrapper>\n </CustomAnimationSection>\n\n {/* Content Section */}\n <CustomContentSection className={contentSectionClasses} role=\"main\">\n {/* Main Title */}\n <CustomTitle className={titleClasses} role=\"heading\" aria-level={2}>\n {labels.startExploringWeb3}\n </CustomTitle>\n\n {/* Description */}\n <CustomDescription className={descriptionClasses} role=\"text\">\n {labels.walletKeyToDigitalWorld}\n </CustomDescription>\n\n {/* Screen reader summary */}\n <CustomScreenReader className={screenReaderClasses}>\n Introduction to Web3 wallets. This section explains the importance of wallets for digital asset management\n and Web3 exploration. Various popular wallet options are visually represented above.\n </CustomScreenReader>\n </CustomContentSection>\n </CustomContainer>\n );\n },\n);\n\nGetWallet.displayName = 'GetWallet';\n","/**\n * @file ImpersonateForm component with comprehensive customization options and validation.\n */\n\nimport { cn } from '@tuwaio/nova-core';\nimport React, { ComponentType, forwardRef, useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { isAddress } from 'viem';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\n\n// --- Types ---\n\n/**\n * Validation configuration\n */\nexport interface ValidationConfig {\n /** Debounce delay in milliseconds */\n debounceDelay: number;\n /** Whether to validate on blur */\n validateOnBlur: boolean;\n /** Whether to validate on change */\n validateOnChange: boolean;\n /** Custom validation function */\n customValidator?: (address: string) => string | null;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype LabelProps = {\n className?: string;\n children: React.ReactNode;\n htmlFor?: string;\n} & React.RefAttributes<HTMLLabelElement>;\n\ntype InputProps = {\n className?: string;\n id?: string;\n type?: string;\n value: string;\n onChange: (event: React.ChangeEvent<HTMLInputElement>) => void;\n onBlur: () => void;\n placeholder?: string;\n 'aria-describedby'?: string;\n 'aria-invalid'?: 'true' | 'false';\n autoComplete?: string;\n spellCheck?: boolean;\n hasError: boolean;\n} & React.RefAttributes<HTMLInputElement>;\n\ntype ErrorMessageProps = {\n className?: string;\n children: React.ReactNode;\n id?: string;\n role?: string;\n 'aria-live'?: 'polite' | 'assertive';\n} & React.RefAttributes<HTMLParagraphElement>;\n\n/**\n * Customization options for ImpersonateForm component\n */\nexport type ImpersonateFormCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom label component */\n Label?: ComponentType<LabelProps>;\n /** Custom input component */\n Input?: ComponentType<InputProps>;\n /** Custom error message component */\n ErrorMessage?: ComponentType<ErrorMessageProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: () => string;\n /** Function to generate label classes */\n label?: () => string;\n /** Function to generate input classes */\n input?: (params: { hasError: boolean; hasInteracted: boolean }) => string;\n /** Function to generate error message classes */\n errorMessage?: () => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for input change (called after default logic) */\n onInputChange?: (value: string) => void;\n /** Custom handler for input blur (called after default logic) */\n onInputBlur?: (value: string) => void;\n /** Custom handler for validation start */\n onValidationStart?: (value: string) => void;\n /** Custom handler for validation complete */\n onValidationComplete?: (value: string, error: string | null) => void;\n /** Custom handler for component mount */\n onMount?: () => void;\n /** Custom handler for component unmount */\n onUnmount?: () => void;\n };\n /** Configuration options */\n config?: {\n /** Custom validation configuration */\n validation?: Partial<ValidationConfig>;\n /** Custom ARIA labels */\n ariaLabels?: {\n input?: string;\n errorRegion?: string;\n };\n /** Custom input attributes */\n input?: {\n placeholder?: string;\n autoComplete?: string;\n spellCheck?: boolean;\n };\n };\n};\n\n/**\n * Props for the ImpersonateForm component\n */\nexport interface ImpersonateFormProps extends Pick<ConnectButtonProps, 'store'> {\n /** Current impersonated wallet address value */\n impersonatedAddress: string;\n /** Callback to update the impersonated address */\n setImpersonatedAddress: (value: string) => void;\n /** Custom CSS classes for styling the container */\n className?: string;\n /** Customization options */\n customization?: ImpersonateFormCustomization;\n}\n\n/**\n * Default validation configuration\n */\nconst defaultValidationConfig: ValidationConfig = {\n debounceDelay: 500,\n validateOnBlur: true,\n validateOnChange: true,\n};\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLDivElement, ContainerProps>(({ children, className }, ref) => (\n <div ref={ref} className={className}>\n {children}\n </div>\n));\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultLabel = forwardRef<HTMLLabelElement, LabelProps>(({ children, className, ...props }, ref) => (\n <label ref={ref} className={className} {...props}>\n {children}\n </label>\n));\nDefaultLabel.displayName = 'DefaultLabel';\n// eslint-disable-next-line\nconst DefaultInput = forwardRef<HTMLInputElement, InputProps>(({ className, hasError: _, ...props }, ref) => (\n <input ref={ref} className={className} {...props} />\n));\nDefaultInput.displayName = 'DefaultInput';\n\nconst DefaultErrorMessage = forwardRef<HTMLParagraphElement, ErrorMessageProps>(\n ({ children, className, ...props }, ref) => (\n <p ref={ref} className={className} {...props}>\n {children}\n </p>\n ),\n);\nDefaultErrorMessage.displayName = 'DefaultErrorMessage';\n\n/**\n * Form component for entering wallet address to impersonate with comprehensive customization\n *\n * This component provides a validated form input with:\n * - Debounced validation with configurable timing\n * - Real-time address format validation using viem's isAddress\n * - Full accessibility support with proper ARIA labeling\n * - Error state management with immediate visual feedback\n * - Touch-friendly design with proper focus states\n * - Full customization of all child components\n * - Comprehensive validation with custom validation support\n *\n * Validation features:\n * - Empty address detection\n * - Invalid address format detection using viem\n * - Connected wallet conflict detection\n * - Custom validation function support\n * - Debounced validation to prevent excessive API calls\n * - Immediate validation on blur for better UX\n *\n * Accessibility features:\n * - Proper form labeling with htmlFor association\n * - ARIA invalid and describedby attributes\n * - Live region for error announcements\n * - Screen reader friendly error messages\n * - Proper focus management\n *\n * @example Basic usage\n * ```tsx\n * <ImpersonateForm\n * impersonatedAddress={address}\n * setImpersonatedAddress={setAddress}\n * store={novaConnectStore}\n * />\n * ```\n *\n * @example With custom validation\n * ```tsx\n * <ImpersonateForm\n * impersonatedAddress={address}\n * setImpersonatedAddress={setAddress}\n * store={novaConnectStore}\n * customization={{\n * config: {\n * validation: {\n * debounceDelay: 300,\n * customValidator: (addr) => {\n * if (addr === '0x...') return 'This address is not allowed';\n * return null;\n * }\n * }\n * }\n * }}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ImpersonateForm\n * impersonatedAddress={address}\n * setImpersonatedAddress={setAddress}\n * store={novaConnectStore}\n * customization={{\n * components: {\n * Input: CustomInput,\n * ErrorMessage: CustomErrorMessage\n * },\n * classNames: {\n * input: ({ hasError }) => hasError ? 'custom-error' : 'custom-normal'\n * },\n * handlers: {\n * onValidationComplete: (value, error) => {\n * console.log('Validation result:', { value, error });\n * }\n * }\n * }}\n * />\n * ```\n */\nexport const ImpersonateForm = forwardRef<HTMLDivElement, ImpersonateFormProps>(\n ({ impersonatedAddress, setImpersonatedAddress, store, className, customization }, ref) => {\n // Get labels from context\n const labels = useNovaConnectLabels();\n const { activeWallet, walletConnectionError } = useNovaConnect();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n Label: CustomLabel = DefaultLabel,\n Input: CustomInput = DefaultInput,\n ErrorMessage: CustomErrorMessage = DefaultErrorMessage,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n // Access store state and methods\n const resetWalletConnectionError = store.getState().resetWalletConnectionError;\n const setWalletConnectionError = store.getState().setWalletConnectionError;\n\n // Local state to track if user has interacted with the field\n const [hasInteracted, setHasInteracted] = useState(false);\n\n // Use ref to store timeout ID\n const timeoutRef = useRef<NodeJS.Timeout | null>(null);\n\n /**\n * Memoized validation configuration with customization\n */\n const validationConfig = useMemo(\n (): ValidationConfig => ({\n ...defaultValidationConfig,\n ...customConfig?.validation,\n }),\n [customConfig?.validation],\n );\n\n /**\n * Generate validation function with proper memoization dependencies\n */\n const getValidateAddress = useCallback(\n () =>\n (address: string): string | null => {\n // Custom validation first\n if (validationConfig.customValidator) {\n const customError = validationConfig.customValidator(address);\n if (customError) return customError;\n }\n\n // Standard validations\n if (!address.trim()) {\n return labels.impersonateAddressEmpty;\n }\n if (!isAddress(address)) {\n return labels.impersonateAddressNotCorrect;\n }\n if (activeWallet?.isConnected) {\n return labels.impersonateAddressConnected;\n }\n\n return null;\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n validationConfig.customValidator,\n labels.impersonateAddressEmpty,\n labels.impersonateAddressNotCorrect,\n labels.impersonateAddressConnected,\n activeWallet?.isConnected,\n ],\n );\n\n /**\n * Memoized validation function\n */\n const validateAddress = useMemo(() => getValidateAddress(), [getValidateAddress]);\n\n /**\n * Generate debounced validation function with proper memoization dependencies\n */\n const getDebouncedValidate = useCallback(\n () => (address: string) => {\n if (!validationConfig.validateOnChange) return;\n\n // Clear previous timeout\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n\n customHandlers?.onValidationStart?.(address);\n\n timeoutRef.current = setTimeout(() => {\n if (hasInteracted) {\n const error = validateAddress(address);\n if (error) {\n setWalletConnectionError(error);\n } else if (walletConnectionError) {\n resetWalletConnectionError();\n }\n customHandlers?.onValidationComplete?.(address, error);\n }\n }, validationConfig.debounceDelay);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n validationConfig.validateOnChange,\n validationConfig.debounceDelay,\n hasInteracted,\n validateAddress,\n setWalletConnectionError,\n resetWalletConnectionError,\n walletConnectionError,\n customHandlers?.onValidationStart,\n customHandlers?.onValidationComplete,\n ],\n );\n\n /**\n * Memoized debounced validation function\n */\n const debouncedValidate = useMemo(() => getDebouncedValidate(), [getDebouncedValidate]);\n\n /**\n * Generate input change handler with proper memoization dependencies\n */\n const getHandleAddressChange = useCallback(\n () => (event: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = event.target.value;\n setHasInteracted(true);\n setImpersonatedAddress(newValue);\n\n // Clear error immediately if field becomes valid\n if (newValue.trim() && walletConnectionError) {\n if (isAddress(newValue)) {\n resetWalletConnectionError();\n }\n }\n\n // Trigger debounced validation for invalid cases\n debouncedValidate(newValue);\n\n // Call custom handler\n customHandlers?.onInputChange?.(newValue);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n setImpersonatedAddress,\n walletConnectionError,\n resetWalletConnectionError,\n debouncedValidate,\n customHandlers?.onInputChange,\n ],\n );\n\n /**\n * Memoized input change handler\n */\n const handleAddressChange = useMemo(() => getHandleAddressChange(), [getHandleAddressChange]);\n\n /**\n * Generate blur handler with proper memoization dependencies\n */\n const getHandleBlur = useCallback(\n () => () => {\n if (!validationConfig.validateOnBlur) return;\n\n setHasInteracted(true);\n\n // Clear any pending debounced validation\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n\n // Validate immediately on blur without debounce\n const error = validateAddress(impersonatedAddress);\n if (error) {\n setWalletConnectionError(error);\n } else if (walletConnectionError) {\n resetWalletConnectionError();\n }\n\n // Call custom handler\n customHandlers?.onInputBlur?.(impersonatedAddress);\n customHandlers?.onValidationComplete?.(impersonatedAddress, error);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n validationConfig.validateOnBlur,\n validateAddress,\n impersonatedAddress,\n setWalletConnectionError,\n resetWalletConnectionError,\n walletConnectionError,\n customHandlers?.onInputBlur,\n customHandlers?.onValidationComplete,\n ],\n );\n\n /**\n * Memoized blur handler\n */\n const handleBlur = useMemo(() => getHandleBlur(), [getHandleBlur]);\n\n /**\n * Generate container classes with proper memoization dependencies\n */\n const getContainerClasses = useCallback(\n () => customization?.classNames?.container?.() ?? cn('novacon:space-y-1', className),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.container, className],\n );\n\n /**\n * Memoized container classes\n */\n const containerClasses = useMemo(getContainerClasses, [getContainerClasses]);\n\n /**\n * Generate label classes with proper memoization dependencies\n */\n const getLabelClasses = useCallback(\n () =>\n customization?.classNames?.label?.() ??\n 'novacon:block novacon:text-sm novacon:text-[var(--tuwa-text-secondary)]',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.label],\n );\n\n /**\n * Memoized label classes\n */\n const labelClasses = useMemo(() => getLabelClasses(), [getLabelClasses]);\n\n /**\n * Generate input classes with proper memoization dependencies\n */\n const getInputClasses = useCallback(() => {\n if (customization?.classNames?.input) {\n return customization.classNames.input({ hasError: !!walletConnectionError, hasInteracted });\n }\n\n return cn(\n // Base layout and spacing\n 'novacon:mt-1 novacon:w-full novacon:p-3 novacon:rounded-xl',\n // Theme colors\n 'novacon:bg-[var(--tuwa-bg-secondary)]',\n 'novacon:border novacon:border-[var(--tuwa-border-primary)]',\n 'novacon:text-[var(--tuwa-text-primary)]',\n 'novacon:placeholder:text-[var(--tuwa-text-secondary)]',\n // Focus and interaction states\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)]',\n // Error state styling\n {\n 'novacon:border-red-500 novacon:focus:ring-red-500': walletConnectionError,\n },\n // Transition for smooth state changes\n 'novacon:transition-colors novacon:duration-200',\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.input, walletConnectionError, hasInteracted]);\n\n /**\n * Memoized input classes\n */\n const inputClasses = useMemo(() => getInputClasses(), [getInputClasses]);\n\n /**\n * Generate error message classes with proper memoization dependencies\n */\n const getErrorMessageClasses = useCallback(\n () => customization?.classNames?.errorMessage?.() ?? 'novacon:mt-2 novacon:text-sm novacon:text-red-500',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.errorMessage],\n );\n\n /**\n * Memoized error message classes\n */\n const errorMessageClasses = useMemo(() => getErrorMessageClasses(), [getErrorMessageClasses]);\n\n // Cleanup effect and mount/unmount handlers\n useEffect(() => {\n customHandlers?.onMount?.();\n\n return () => {\n // Clear timeout on unmount\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n resetWalletConnectionError();\n customHandlers?.onUnmount?.();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [resetWalletConnectionError, customHandlers?.onMount, customHandlers?.onUnmount]);\n\n // Input configuration\n const inputId = 'impersonated-address';\n const errorId = 'address-error';\n const placeholder = customConfig?.input?.placeholder ?? labels.walletAddressPlaceholder;\n const autoComplete = customConfig?.input?.autoComplete ?? 'off';\n const spellCheck = customConfig?.input?.spellCheck ?? false;\n\n return (\n <CustomContainer ref={ref} className={containerClasses}>\n {/* Form label */}\n <CustomLabel className={labelClasses} htmlFor={inputId}>\n {labels.enterWalletAddress}\n </CustomLabel>\n\n {/* Address input field */}\n <CustomInput\n className={inputClasses}\n id={inputId}\n type=\"text\"\n value={impersonatedAddress}\n onChange={handleAddressChange}\n onBlur={handleBlur}\n placeholder={placeholder}\n aria-describedby={walletConnectionError ? errorId : undefined}\n aria-invalid={walletConnectionError ? 'true' : 'false'}\n autoComplete={autoComplete}\n spellCheck={spellCheck}\n hasError={!!walletConnectionError}\n />\n\n {/* Error message display */}\n {walletConnectionError && (\n <CustomErrorMessage className={errorMessageClasses} id={errorId} role=\"alert\" aria-live=\"polite\">\n {walletConnectionError}\n </CustomErrorMessage>\n )}\n </CustomContainer>\n );\n },\n);\n\nImpersonateForm.displayName = 'ImpersonateForm';\n","/**\n * @file NetworkSelections component with comprehensive customization options for network selection.\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { ExclamationTriangleIcon } from '@heroicons/react/24/outline';\nimport { cn, isTouchDevice } from '@tuwaio/nova-core';\nimport { formatWalletName, getWalletTypeFromConnectorName, OrbitAdapter, WalletType } from '@tuwaio/orbit-core';\nimport React, { ComponentType, forwardRef, memo, useCallback, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { getNetworkIcon, networksLinks } from '../../utils';\nimport { ConnectCard, ConnectCardCustomization } from './ConnectCard';\nimport { GroupedConnector } from './ConnectModal';\nimport { Disclaimer, DisclaimerCustomization } from './Disclaimer';\n\n// --- Types ---\n\n/**\n * Network data for display\n */\ninterface NetworkData {\n /** Network adapter */\n adapter: OrbitAdapter;\n /** Chain ID for icon display */\n chainId?: number | string;\n /** Network display name */\n name: string;\n /** Network info link URL */\n infoLink?: string;\n /** Network index in list */\n index: number;\n}\n\n/**\n * Network selections data for customization context\n */\nexport interface NetworkSelectionsData {\n /** Currently active connector name */\n activeConnector?: string;\n /** Available grouped connectors */\n connectors: GroupedConnector[];\n /** Whether device is touch-enabled */\n isTouch: boolean;\n /** Whether in error state */\n isError: boolean;\n /** Available networks */\n networks: NetworkData[];\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-labelledby'?: string;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TitleProps = {\n className?: string;\n children: React.ReactNode;\n id?: string;\n role?: string;\n 'aria-level'?: number;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLHeadingElement>;\n\ntype NetworkListProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype NetworkItemProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n networkData: NetworkData;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype NetworkIconProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n networkData: NetworkData;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ErrorContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-live'?: 'polite' | 'assertive';\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ErrorIconProps = {\n className?: string;\n children: React.ReactNode;\n 'aria-hidden'?: boolean;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ErrorTitleProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-level'?: number;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLHeadingElement>;\n\ntype ErrorMessageProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n selectionsData: NetworkSelectionsData;\n} & React.RefAttributes<HTMLParagraphElement>;\n\n/**\n * NetworkSelections customization options\n */\nexport type NetworkSelectionsCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom title */\n Title?: ComponentType<TitleProps>;\n /** Custom network list */\n NetworkList?: ComponentType<NetworkListProps>;\n /** Custom network item wrapper */\n NetworkItem?: ComponentType<NetworkItemProps>;\n /** Custom network icon wrapper */\n NetworkIcon?: ComponentType<NetworkIconProps>;\n /** Custom error container */\n ErrorContainer?: ComponentType<ErrorContainerProps>;\n /** Custom error icon wrapper */\n ErrorIcon?: ComponentType<ErrorIconProps>;\n /** Custom error title */\n ErrorTitle?: ComponentType<ErrorTitleProps>;\n /** Custom error message */\n ErrorMessage?: ComponentType<ErrorMessageProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate title classes */\n title?: (params: { selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate network list classes */\n networkList?: (params: { selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate network item classes */\n networkItem?: (params: { networkData: NetworkData; selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate network icon classes */\n networkIcon?: (params: { networkData: NetworkData; selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate error container classes */\n errorContainer?: (params: { selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate error icon classes */\n errorIcon?: (params: { selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate error title classes */\n errorTitle?: (params: { selectionsData: NetworkSelectionsData }) => string;\n /** Function to generate error message classes */\n errorMessage?: (params: { selectionsData: NetworkSelectionsData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom network click handler */\n onNetworkClick?: (\n networkData: NetworkData,\n selectionsData: NetworkSelectionsData,\n originalHandler: (network: OrbitAdapter) => void,\n ) => void;\n /** Custom error retry handler */\n onErrorRetry?: (selectionsData: NetworkSelectionsData) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: (selectionsData: NetworkSelectionsData) => string;\n networkList?: (selectionsData: NetworkSelectionsData) => string;\n networkIcon?: (networkData: NetworkData) => string;\n errorContainer?: (selectionsData: NetworkSelectionsData) => string;\n };\n /** Custom scroll behavior */\n scroll?: {\n touchMaxHeight?: string;\n mouseMaxHeight?: string;\n gap?: {\n touch?: string;\n mouse?: string;\n };\n };\n };\n /** ConnectCard customization for network cards */\n connectCard?: ConnectCardCustomization;\n /** Disclaimer customization */\n disclaimer?: DisclaimerCustomization;\n};\n\n/**\n * Props for the NetworkSelections component\n */\ninterface NetworkSelectionsProps {\n /** Name of the currently active wallet connector */\n activeConnector: string | undefined;\n /** Array of grouped wallet connectors with their supported networks */\n connectors: GroupedConnector[];\n /** Click handler for network selection */\n onClick: (adapter: OrbitAdapter, walletType: WalletType) => Promise<void>;\n /** Customization options */\n customization?: NetworkSelectionsCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLDivElement, ContainerProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultTitle = forwardRef<HTMLHeadingElement, TitleProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <h2 ref={ref} className={className} {...props}>\n {children}\n </h2>\n ),\n);\nDefaultTitle.displayName = 'DefaultTitle';\n\nconst DefaultNetworkList = forwardRef<HTMLDivElement, NetworkListProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultNetworkList.displayName = 'DefaultNetworkList';\n\nconst DefaultNetworkItem = forwardRef<HTMLDivElement, NetworkItemProps>(\n // eslint-disable-next-line\n ({ children, className, networkData, selectionsData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultNetworkItem.displayName = 'DefaultNetworkItem';\n\nconst DefaultNetworkIcon = forwardRef<HTMLDivElement, NetworkIconProps>(\n // eslint-disable-next-line\n ({ children, className, networkData, selectionsData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultNetworkIcon.displayName = 'DefaultNetworkIcon';\n\nconst DefaultErrorContainer = forwardRef<HTMLDivElement, ErrorContainerProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultErrorContainer.displayName = 'DefaultErrorContainer';\n\nconst DefaultErrorIcon = forwardRef<HTMLDivElement, ErrorIconProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultErrorIcon.displayName = 'DefaultErrorIcon';\n\nconst DefaultErrorTitle = forwardRef<HTMLHeadingElement, ErrorTitleProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <h2 ref={ref} className={className} {...props}>\n {children}\n </h2>\n ),\n);\nDefaultErrorTitle.displayName = 'DefaultErrorTitle';\n\nconst DefaultErrorMessage = forwardRef<HTMLParagraphElement, ErrorMessageProps>(\n // eslint-disable-next-line\n ({ children, className, selectionsData, ...props }, ref) => (\n <p ref={ref} className={className} {...props}>\n {children}\n </p>\n ),\n);\nDefaultErrorMessage.displayName = 'DefaultErrorMessage';\n\n/**\n * NetworkSelections component - Network/blockchain selection interface for multi-network wallets with full customization\n *\n * This component provides a network selection interface when a wallet supports multiple blockchains:\n * - Visual network cards with blockchain icons and names\n * - Responsive layout adapting to touch/mouse interfaces\n * - Error handling for invalid connector states\n * - Educational content about blockchain networks\n * - Full accessibility support with semantic structure\n * - External documentation links for each network\n * - Complete customization of all child components and styling\n *\n * Use cases:\n * - Multi-network wallets (e.g., MetaMask supporting EVM chains)\n * - Cross-chain wallets supporting both EVM and Solana\n * - Network-specific connection requirements\n * - User education about blockchain differences\n *\n * Layout features:\n * - Touch devices: Horizontal scrolling layout for easy mobile navigation\n * - Mouse devices: Vertical layout with fixed height scrolling\n * - Network icons with Web3Icon integration for consistency\n * - External links for additional network information\n *\n * Error handling:\n * - Graceful fallback when active connector is not found\n * - Clear error messaging with actionable guidance\n * - Visual error indicators with warning icons\n * - Accessible error state announcements\n *\n * Accessibility features:\n * - Semantic heading structure for network selection\n * - Proper ARIA labels for error states and selections\n * - Screen reader friendly network descriptions\n * - Keyboard navigation support for all interactive elements\n * - Error announcements with live regions\n *\n * @example Basic usage\n * ```tsx\n * <NetworkSelections\n * activeConnector=\"metamask\"\n * connectors={multiNetworkConnectors}\n * onClick={async (adapter, walletType) => {\n * await connectToNetwork(adapter, walletType);\n * }}\n * />\n * ```\n *\n * @example With customization\n * ```tsx\n * <NetworkSelections\n * activeConnector=\"phantom\"\n * connectors={crossChainConnectors}\n * onClick={(adapter, type) => handleNetworkConnection(adapter, type)}\n * customization={{\n * components: {\n * Container: CustomNetworkContainer,\n * NetworkIcon: CustomNetworkIcon\n * },\n * classNames: {\n * networkList: ({ selectionsData }) =>\n * selectionsData.isTouch ? 'touch-network-list' : 'desktop-network-list'\n * },\n * handlers: {\n * onNetworkClick: (networkData, selectionsData, originalHandler) => {\n * analytics.track('network_selected', { network: networkData.name });\n * originalHandler(networkData.adapter);\n * }\n * }\n * }}\n * />\n * ```\n */\nexport const NetworkSelections = memo(\n forwardRef<HTMLDivElement, NetworkSelectionsProps>(({ connectors, onClick, activeConnector, customization }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n Title: CustomTitle = DefaultTitle,\n NetworkList: CustomNetworkList = DefaultNetworkList,\n NetworkItem: CustomNetworkItem = DefaultNetworkItem,\n NetworkIcon: CustomNetworkIcon = DefaultNetworkIcon,\n ErrorContainer: CustomErrorContainer = DefaultErrorContainer,\n ErrorIcon: CustomErrorIcon = DefaultErrorIcon,\n ErrorTitle: CustomErrorTitle = DefaultErrorTitle,\n ErrorMessage: CustomErrorMessage = DefaultErrorMessage,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized touch device detection\n */\n const isTouch = useMemo(() => isTouchDevice(), []);\n\n /**\n * Memoized active connector configuration\n */\n const activeConnectors = useMemo(\n () => connectors.find((connector) => formatWalletName(connector.name) === activeConnector),\n [connectors, activeConnector],\n );\n\n /**\n * Memoized network data\n */\n const networks = useMemo((): NetworkData[] => {\n if (!activeConnectors?.adapters) return [];\n\n return activeConnectors.adapters.map((adapter, index) => {\n const networkInfo = getNetworkIcon(adapter);\n return {\n adapter,\n chainId: networkInfo?.chainId,\n name: networkInfo?.name ?? 'Ethereum',\n infoLink: networksLinks[adapter]?.aboutNetwork,\n index,\n };\n });\n }, [activeConnectors?.adapters]);\n\n /**\n * Memoized selections data\n */\n const selectionsData = useMemo(\n (): NetworkSelectionsData => ({\n activeConnector,\n connectors,\n isTouch,\n isError: !activeConnectors,\n networks,\n }),\n\n [activeConnector, connectors, isTouch, activeConnectors, networks],\n );\n\n /**\n * Memoized CSS classes\n */\n const cssClasses = useMemo(() => {\n const touchListClasses = [\n 'novacon:flex-row',\n 'novacon:overflow-x-auto',\n 'novacon:max-h-none',\n customConfig?.scroll?.gap?.touch ?? 'novacon:gap-3',\n 'novacon:pb-4',\n 'novacon:px-1',\n ];\n\n const mouseListClasses = [\n 'novacon:flex-col',\n customConfig?.scroll?.mouseMaxHeight ?? 'novacon:max-h-[310px]',\n 'novacon:overflow-y-auto',\n customConfig?.scroll?.gap?.mouse ?? 'novacon:gap-2',\n ];\n\n return {\n touchListClasses,\n mouseListClasses,\n };\n }, [customConfig?.scroll]);\n\n /**\n * Handle network selection click\n */\n const handleNetworkClick = useCallback(\n (network: OrbitAdapter) => {\n const networkData = networks.find((n) => n.adapter === network);\n if (!networkData || !activeConnector) return;\n\n const originalHandler = (selectedNetwork: OrbitAdapter) => {\n onClick(\n selectedNetwork,\n getWalletTypeFromConnectorName(selectedNetwork, formatWalletName(activeConnector)) as WalletType,\n );\n };\n\n if (customHandlers?.onNetworkClick) {\n customHandlers.onNetworkClick(networkData, selectionsData, originalHandler);\n } else {\n originalHandler(network);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [networks, activeConnector, onClick, customHandlers?.onNetworkClick, selectionsData],\n );\n\n // Error state when active connector is not found\n if (!activeConnectors) {\n return (\n <CustomErrorContainer\n ref={ref}\n className={\n customization?.classNames?.errorContainer?.({ selectionsData }) ??\n 'novacon:flex novacon:flex-col novacon:items-center novacon:justify-center novacon:p-8 novacon:text-center novacon:border novacon:border-[var(--tuwa-border-primary)] novacon:rounded-xl novacon:bg-[var(--tuwa-bg-secondary)] novacon:text-[var(--tuwa-text-secondary)]'\n }\n role=\"alert\"\n aria-live=\"assertive\"\n selectionsData={selectionsData}\n >\n <CustomErrorIcon\n className={\n customization?.classNames?.errorIcon?.({ selectionsData }) ??\n 'novacon:text-[var(--tuwa-text-accent)] novacon:mb-3'\n }\n aria-hidden={true}\n selectionsData={selectionsData}\n >\n <ExclamationTriangleIcon width={32} height={32} />\n </CustomErrorIcon>\n <CustomErrorTitle\n className={\n customization?.classNames?.errorTitle?.({ selectionsData }) ??\n 'novacon:text-lg novacon:font-semibold novacon:text-[var(--tuwa-text-primary)] novacon:mb-1'\n }\n role=\"heading\"\n aria-level={2}\n selectionsData={selectionsData}\n >\n {labels.somethingWentWrong}\n </CustomErrorTitle>\n <CustomErrorMessage\n className={customization?.classNames?.errorMessage?.({ selectionsData }) ?? 'novacon:text-sm'}\n role=\"text\"\n selectionsData={selectionsData}\n >\n {labels.networkPickingError}\n </CustomErrorMessage>\n </CustomErrorContainer>\n );\n }\n\n return (\n <CustomContainer\n ref={ref}\n className={\n customization?.classNames?.container?.({ selectionsData }) ??\n 'novacon:flex novacon:flex-col novacon:gap-4 novacon:text-[var(--tuwa-text-primary)]'\n }\n role=\"region\"\n aria-labelledby=\"network-selection-title\"\n selectionsData={selectionsData}\n >\n <CustomTitle\n id=\"network-selection-title\"\n className={customization?.classNames?.title?.({ selectionsData })}\n role=\"heading\"\n aria-level={2}\n selectionsData={selectionsData}\n >\n {labels.selectAvailableNetwork}\n </CustomTitle>\n\n <CustomNetworkList\n className={\n customization?.classNames?.networkList?.({ selectionsData }) ??\n cn('novacon:flex NovaCustomScroll', isTouch ? cssClasses.touchListClasses : cssClasses.mouseListClasses)\n }\n role=\"list\"\n aria-label={customConfig?.ariaLabels?.networkList?.(selectionsData) ?? 'Available networks'}\n selectionsData={selectionsData}\n >\n {networks.map((networkData) => (\n <CustomNetworkItem\n key={networkData.adapter}\n className={\n customization?.classNames?.networkItem?.({ networkData, selectionsData }) ??\n cn({ 'novacon:flex-shrink-0': isTouch })\n }\n role=\"listitem\"\n networkData={networkData}\n selectionsData={selectionsData}\n >\n <ConnectCard\n icon={\n <CustomNetworkIcon\n className={\n customization?.classNames?.networkIcon?.({ networkData, selectionsData }) ??\n 'novacon:w-8 novacon:h-8'\n }\n role=\"img\"\n aria-label={\n customConfig?.ariaLabels?.networkIcon?.(networkData) ?? `${networkData.name} network icon`\n }\n networkData={networkData}\n selectionsData={selectionsData}\n >\n <Web3Icon chainId={networkData.chainId} />\n </CustomNetworkIcon>\n }\n onClick={() => handleNetworkClick(networkData.adapter)}\n title={networkData.name}\n infoLink={networkData.infoLink}\n customization={customization?.connectCard}\n />\n </CustomNetworkItem>\n ))}\n </CustomNetworkList>\n\n <Disclaimer\n title={labels.whatIsNetwork}\n description={labels.networkDescription}\n learnMoreAction=\"https://academy.binance.com/en/articles/what-is-blockchain-and-how-does-it-work\"\n listAction=\"https://www.alchemy.com/dapps/top/blockchains\"\n customization={customization?.disclaimer}\n />\n </CustomContainer>\n );\n }),\n);\n\nNetworkSelections.displayName = 'NetworkSelections';\n","/**\n * @file NetworkTabs component with comprehensive customization options and animated transitions.\n */\n\nimport { Web3Icon } from '@bgd-labs/react-web3-icons';\nimport { GlobeAltIcon } from '@heroicons/react/24/solid';\nimport { cn } from '@tuwaio/nova-core';\nimport { OrbitAdapter } from '@tuwaio/orbit-core';\nimport { AnimatePresence, motion, Variants } from 'framer-motion';\nimport React, { ComponentType, forwardRef, memo, useCallback, useEffect, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { getNetworkIcon } from '../../utils';\n\n// --- Types ---\n\n/**\n * Animation configuration\n */\nexport interface AnimationConfig {\n /** Layout animation duration */\n layoutDuration: number;\n /** Layout animation easing */\n layoutEasing: number[];\n /** Text transition duration */\n textDuration: number;\n /** Text transition delay */\n textDelay?: number;\n}\n\n/**\n * Network tab data\n */\nexport interface NetworkTabData {\n /** Network adapter (undefined for \"All\") */\n network: OrbitAdapter | undefined;\n /** Display name */\n displayName: string;\n /** Network info from utils */\n networkInfo: ReturnType<typeof getNetworkIcon> | null;\n /** Whether this tab is selected */\n isSelected: boolean;\n /** Tab index */\n index: number;\n}\n\n// --- Component Props Types ---\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TabListProps = {\n className?: string;\n children: React.ReactNode;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TabProps = {\n className?: string;\n children: React.ReactNode;\n 'data-network': string;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TabButtonProps = {\n className?: string;\n children: React.ReactNode;\n type?: 'button';\n role?: string;\n 'aria-selected'?: boolean;\n 'aria-controls'?: string;\n onClick: () => void;\n onMouseEnter?: () => void;\n onFocus?: () => void;\n title?: string;\n 'aria-label'?: string;\n tabData: NetworkTabData;\n} & React.RefAttributes<HTMLButtonElement>;\n\ntype IconContainerProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n 'aria-label'?: string;\n tabData: NetworkTabData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype TabTextProps = {\n className?: string;\n children: React.ReactNode;\n variants?: Variants;\n animate?: string;\n 'aria-hidden'?: boolean;\n tabData: NetworkTabData;\n} & React.RefAttributes<HTMLSpanElement>;\n\ntype IndicatorProps = {\n className?: string;\n 'aria-hidden'?: boolean;\n tabData: NetworkTabData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * Customization options for NetworkTabs component\n */\nexport type NetworkTabsCustomization = {\n /** Custom components */\n components?: {\n /** Custom container wrapper */\n Container?: ComponentType<ContainerProps>;\n /** Custom tab list container */\n TabList?: ComponentType<TabListProps>;\n /** Custom tab wrapper */\n Tab?: ComponentType<TabProps>;\n /** Custom tab button */\n TabButton?: ComponentType<TabButtonProps>;\n /** Custom icon container */\n IconContainer?: ComponentType<IconContainerProps>;\n /** Custom tab text */\n TabText?: ComponentType<TabTextProps>;\n /** Custom selection indicator */\n Indicator?: ComponentType<IndicatorProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: () => string;\n /** Function to generate tab list classes */\n tabList?: () => string;\n /** Function to generate tab classes */\n tab?: (params: { isSelected: boolean; index: number }) => string;\n /** Function to generate tab button classes */\n tabButton?: (params: { isSelected: boolean; tabData: NetworkTabData }) => string;\n /** Function to generate icon container classes */\n iconContainer?: (params: { tabData: NetworkTabData }) => string;\n /** Function to generate tab text classes */\n tabText?: (params: { isSelected: boolean; tabData: NetworkTabData }) => string;\n /** Function to generate indicator classes */\n indicator?: (params: { tabData: NetworkTabData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for tab selection (called after default logic) */\n onTabSelect?: (network: OrbitAdapter | undefined, tabData: NetworkTabData) => void;\n /** Custom handler for tab hover */\n onTabHover?: (network: OrbitAdapter | undefined, tabData: NetworkTabData) => void;\n /** Custom handler for tab focus */\n onTabFocus?: (network: OrbitAdapter | undefined, tabData: NetworkTabData) => void;\n /** Custom handler for component mount */\n onMount?: () => void;\n /** Custom handler for component unmount */\n onUnmount?: () => void;\n };\n /** Configuration options */\n config?: {\n /** Custom animation configuration */\n animation?: Partial<AnimationConfig>;\n /** Custom ARIA labels */\n ariaLabels?: {\n container?: string;\n tabPrefix?: string;\n iconSuffix?: string;\n selectedSuffix?: string;\n };\n /** Whether to show \"All\" option */\n showAllOption?: boolean;\n /** Custom network display names */\n networkNames?: {\n [key: string]: string;\n };\n /** Minimum networks to show tabs */\n minNetworksToShow?: number;\n };\n};\n\n/**\n * Props for the NetworkTabs component\n */\nexport interface NetworkTabsProps {\n /** Array of available network adapters */\n networks: OrbitAdapter[];\n /** Currently selected network adapter (undefined means \"All\" is selected) */\n selectedAdapter: OrbitAdapter | undefined;\n /** Handler for network selection changes */\n onSelect: (adapter: OrbitAdapter | undefined) => void;\n /** Custom CSS classes for styling the container */\n className?: string;\n /** Customization options */\n customization?: NetworkTabsCustomization;\n}\n\n/**\n * Default animation configuration\n */\nconst defaultAnimationConfig: AnimationConfig = {\n layoutDuration: 0.6,\n layoutEasing: [0.1, 0.1, 0.2, 1],\n textDuration: 0.2,\n textDelay: 0,\n};\n\n/**\n * Default animation variants for tab text transitions\n */\nconst getTextVariant = (config: AnimationConfig): Variants => ({\n active: {\n opacity: 1,\n zIndex: 2,\n x: 0,\n position: 'relative',\n transition: {\n duration: config.textDuration,\n delay: config.textDelay,\n },\n },\n inactive: {\n opacity: 0,\n zIndex: -1,\n x: -10,\n position: 'absolute',\n transition: {\n duration: config.textDuration,\n },\n },\n});\n\n// --- Default Sub-Components ---\nconst DefaultContainer = forwardRef<HTMLDivElement, ContainerProps>(({ children, className, ...props }, ref) => (\n <motion.div\n ref={ref}\n className={className}\n layout\n transition={{\n layout: {\n duration: 0.6,\n ease: [0.1, 0.1, 0.2, 1],\n },\n }}\n {...props}\n >\n {children}\n </motion.div>\n));\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultTabList = forwardRef<HTMLDivElement, TabListProps>(({ children, className }, ref) => (\n <motion.div\n ref={ref}\n className={className}\n layout\n transition={{\n layout: {\n duration: 0.0001,\n },\n }}\n >\n {children}\n </motion.div>\n));\nDefaultTabList.displayName = 'DefaultTabList';\n\nconst DefaultTab = forwardRef<HTMLDivElement, TabProps>(({ children, className, ...props }, ref) => (\n <motion.div\n ref={ref}\n className={className}\n layout\n transition={{\n layout: {\n duration: 0.6,\n ease: [0.1, 0.1, 0.2, 1],\n },\n }}\n {...props}\n >\n {children}\n </motion.div>\n));\nDefaultTab.displayName = 'DefaultTab';\n\nconst DefaultTabButton = forwardRef<HTMLButtonElement, TabButtonProps>(\n // eslint-disable-next-line\n ({ children, className, tabData: _, ...props }, ref) => (\n <motion.button\n ref={ref}\n className={className}\n layout\n transition={{\n layout: {\n duration: 0.0001,\n },\n }}\n {...props}\n >\n {children}\n </motion.button>\n ),\n);\nDefaultTabButton.displayName = 'DefaultTabButton';\n\nconst DefaultIconContainer = forwardRef<HTMLDivElement, IconContainerProps>(\n // eslint-disable-next-line\n ({ children, className, tabData: _, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n {children}\n </div>\n ),\n);\nDefaultIconContainer.displayName = 'DefaultIconContainer';\n\nconst DefaultTabText = forwardRef<HTMLSpanElement, TabTextProps>(\n // eslint-disable-next-line\n ({ children, className, tabData: _, ...props }, ref) => (\n <motion.span ref={ref} className={className} {...props}>\n {children}\n </motion.span>\n ),\n);\nDefaultTabText.displayName = 'DefaultTabText';\n\nconst DefaultIndicator = forwardRef<HTMLDivElement, IndicatorProps>(\n // eslint-disable-next-line\n ({ className, tabData: _, ...props }, ref) => (\n <motion.div ref={ref} className={className} layoutId=\"indicator\" {...props} />\n ),\n);\nDefaultIndicator.displayName = 'DefaultIndicator';\n\n/**\n * NetworkTabs component - Animated tab navigation for network selection with comprehensive customization\n *\n * This component provides an animated tab interface for selecting blockchain networks:\n * - Animated tab transitions with smooth layouts powered by Framer Motion\n * - Visual network icons with Web3Icon integration and fallbacks\n * - Configurable \"All networks\" option for viewing all connectors\n * - Responsive horizontal scrolling for mobile-friendly experience\n * - Full accessibility support with proper ARIA labels and keyboard navigation\n * - Motion-based UI feedback with customizable animation timing\n * - Complete customization of all child components and animations\n *\n * Key features:\n * - Framer Motion powered animations with configurable timing and easing\n * - Dynamic tab indicator that smoothly morphs between selections\n * - Network icons with proper Web3Icon integration and fallback support\n * - Conditional rendering based on configurable minimum network threshold\n * - Touch-friendly interface with horizontal scrolling support\n * - Full component tree customization through render prop pattern\n *\n * Animation system:\n * - Layout animations for smooth tab movement with configurable duration\n * - Text fade transitions with customizable timing when switching tabs\n * - Morphing background indicator with layoutId for smooth transitions\n * - Optimized animation durations tuned for natural feel\n * - Support for reduced motion preferences\n *\n * Accessibility features:\n * - Proper tablist and tab ARIA semantics for screen readers\n * - Keyboard navigation support (Tab, Space, Enter, Arrow keys)\n * - Dynamic ARIA labels with selection state announcements\n * - Focus management with visible focus indicators\n * - Meaningful tooltips and descriptions for each network\n * - Screen reader friendly icon descriptions\n *\n * @example Basic usage\n * ```tsx\n * <NetworkTabs\n * networks={[OrbitAdapter.EVM, OrbitAdapter.SOLANA]}\n * selectedAdapter={OrbitAdapter.EVM}\n * onSelect={(adapter) => handleNetworkChange(adapter)}\n * />\n * ```\n *\n * @example With custom animation timing\n * ```tsx\n * <NetworkTabs\n * networks={networks}\n * selectedAdapter={selectedNetwork}\n * onSelect={setSelectedNetwork}\n * customization={{\n * config: {\n * animation: {\n * layoutDuration: 0.3,\n * textDuration: 0.15\n * }\n * }\n * }}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <NetworkTabs\n * networks={networks}\n * selectedAdapter={selectedNetwork}\n * onSelect={setSelectedNetwork}\n * customization={{\n * components: {\n * TabButton: CustomTabButton,\n * Indicator: CustomIndicator\n * },\n * classNames: {\n * tabButton: ({ isSelected }) => isSelected ? 'custom-selected' : 'custom-normal'\n * },\n * handlers: {\n * onTabSelect: (network, tabData) => {\n * analytics.track('network_tab_selected', { network: network?.name });\n * }\n * },\n * config: {\n * minNetworksToShow: 2,\n * showAllOption: false\n * }\n * }}\n * />\n * ```\n */\nexport const NetworkTabs = memo(\n forwardRef<HTMLDivElement, NetworkTabsProps>(\n ({ networks, selectedAdapter, onSelect, className, customization }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract customization options\n const {\n Container: CustomContainer = DefaultContainer,\n TabList: CustomTabList = DefaultTabList,\n Tab: CustomTab = DefaultTab,\n TabButton: CustomTabButton = DefaultTabButton,\n IconContainer: CustomIconContainer = DefaultIconContainer,\n TabText: CustomTabText = DefaultTabText,\n Indicator: CustomIndicator = DefaultIndicator,\n } = customization?.components ?? {};\n\n const customHandlers = customization?.handlers;\n const customConfig = customization?.config;\n\n /**\n * Memoized animation configuration with customization\n */\n const animationConfig = useMemo(\n (): AnimationConfig => ({\n ...defaultAnimationConfig,\n ...customConfig?.animation,\n }),\n [customConfig?.animation],\n );\n\n /**\n * Memoized text animation variants\n */\n const textVariant = useMemo(() => getTextVariant(animationConfig), [animationConfig]);\n\n /**\n * Check if we should render tabs\n */\n const shouldRender = useMemo(() => {\n const minNetworks = customConfig?.minNetworksToShow ?? 1;\n return networks.length > minNetworks;\n }, [networks.length, customConfig?.minNetworksToShow]);\n\n /**\n * Memoized networks list with \"All\" option if enabled\n */\n const localNetworks = useMemo(() => {\n const showAll = customConfig?.showAllOption ?? true;\n return showAll ? [undefined, ...networks] : networks;\n }, [networks, customConfig?.showAllOption]);\n\n /**\n * Generate network display name function with proper memoization dependencies\n */\n const getNetworkDisplayNameGen = useCallback(\n () =>\n (network: OrbitAdapter | undefined): string => {\n if (!network) return labels.all;\n\n // Check for custom name first\n const networkKey = network.toString();\n if (customConfig?.networkNames?.[networkKey]) {\n return customConfig.networkNames[networkKey];\n }\n\n return getNetworkIcon(network)?.name ?? 'Unknown';\n },\n [labels.all, customConfig?.networkNames],\n );\n\n /**\n * Memoized network display name function\n */\n const getNetworkDisplayName = useMemo(getNetworkDisplayNameGen, [getNetworkDisplayNameGen]);\n\n /**\n * Generate aria label function with proper memoization dependencies\n */\n const getNetworkAriaLabelGen = useCallback(\n () =>\n (network: OrbitAdapter | undefined, isSelected: boolean): string => {\n const displayName = getNetworkDisplayName(network);\n const tabPrefix = customConfig?.ariaLabels?.tabPrefix ?? '';\n const selectedSuffix = customConfig?.ariaLabels?.selectedSuffix ?? ', currently selected';\n\n return `${tabPrefix}${displayName} network${isSelected ? selectedSuffix : ''}`.trim();\n },\n [getNetworkDisplayName, customConfig?.ariaLabels],\n );\n\n /**\n * Memoized aria label function\n */\n const getNetworkAriaLabel = useMemo(getNetworkAriaLabelGen, [getNetworkAriaLabelGen]);\n\n /**\n * Generate tab selection handler with proper memoization dependencies\n */\n const getHandleTabSelect = useCallback(\n () => (network: OrbitAdapter | undefined, tabData: NetworkTabData) => {\n onSelect(network);\n customHandlers?.onTabSelect?.(network, tabData);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [onSelect, customHandlers?.onTabSelect],\n );\n\n /**\n * Memoized tab selection handler\n */\n const handleTabSelect = useMemo(getHandleTabSelect, [getHandleTabSelect]);\n\n /**\n * Memoized tab data\n */\n const tabsData = useMemo((): NetworkTabData[] => {\n return localNetworks.map((network, index) => ({\n network,\n displayName: getNetworkDisplayName(network),\n networkInfo: network ? getNetworkIcon(network) : null,\n isSelected: selectedAdapter === network,\n index,\n }));\n }, [localNetworks, getNetworkDisplayName, selectedAdapter]);\n\n /**\n * Generate container classes with proper memoization dependencies\n */\n const getContainerClasses = useCallback(\n () => customization?.classNames?.container?.() ?? className,\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.container, className],\n );\n\n /**\n * Memoized container classes\n */\n const containerClasses = useMemo(getContainerClasses, [getContainerClasses]);\n\n /**\n * Generate tab list classes with proper memoization dependencies\n */\n const getTabListClasses = useCallback(\n () =>\n customization?.classNames?.tabList?.() ??\n 'novacon:flex novacon:overflow-x-auto novacon:gap-2 novacon:p-2 novacon:mb-2 novacon:border-b novacon:border-[var(--tuwa-border-primary)] novacon:relative',\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.classNames?.tabList],\n );\n\n /**\n * Memoized tab list classes\n */\n const tabListClasses = useMemo(getTabListClasses, [getTabListClasses]);\n\n // Mount/unmount effect\n useEffect(() => {\n customHandlers?.onMount?.();\n return () => customHandlers?.onUnmount?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customHandlers?.onMount, customHandlers?.onUnmount]);\n\n // Don't render if not enough networks\n if (!shouldRender) return null;\n\n const containerAriaLabel = customConfig?.ariaLabels?.container ?? 'Network selection tabs';\n\n return (\n <CustomContainer ref={ref} className={containerClasses} role=\"tablist\" aria-label={containerAriaLabel}>\n <CustomTabList className={tabListClasses}>\n {tabsData.map((tabData) => {\n const tabKey = `${tabData.network}_${tabData.index}`;\n const networkKey = tabData.network?.toString() ?? 'all';\n\n // Generate dynamic classes and styles\n const tabClasses =\n customization?.classNames?.tab?.({\n isSelected: tabData.isSelected,\n index: tabData.index,\n }) ?? 'novacon:relative novacon:group';\n\n const tabButtonClasses =\n customization?.classNames?.tabButton?.({\n isSelected: tabData.isSelected,\n tabData,\n }) ??\n cn(\n 'novacon:cursor-pointer novacon:flex novacon:items-center novacon:gap-2 novacon:px-4 novacon:py-2 novacon:rounded-lg novacon:transition-colors novacon:overflow-hidden novacon:relative novacon:z-4',\n 'novacon:hover:bg-[var(--tuwa-bg-muted)]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-border-primary)] novacon:focus:ring-offset-2',\n tabData.isSelected\n ? 'novacon:bg-[var(--tuwa-bg-muted)] novacon:text-[var(--tuwa-text-accent)]'\n : 'novacon:text-[var(--tuwa-text-secondary)]',\n );\n\n const iconContainerClasses =\n customization?.classNames?.iconContainer?.({ tabData }) ??\n 'novacon:w-6 novacon:h-6 novacon:[&>img]:w-full novacon:[&>img]:h-full';\n\n const tabTextClasses =\n customization?.classNames?.tabText?.({\n isSelected: tabData.isSelected,\n tabData,\n }) ?? 'novacon:block';\n\n const indicatorClasses =\n customization?.classNames?.indicator?.({ tabData }) ??\n 'novacon:absolute novacon:inset-0 novacon:bg-[var(--tuwa-bg-muted)] novacon:z-3 novacon:rounded-lg';\n\n return (\n <CustomTab key={tabKey} className={tabClasses} data-network={networkKey}>\n <CustomTabButton\n className={tabButtonClasses}\n type=\"button\"\n role=\"tab\"\n aria-selected={tabData.isSelected}\n aria-controls={`network-panel-${networkKey}`}\n onClick={() => handleTabSelect(tabData.network, tabData)}\n onMouseEnter={() => customHandlers?.onTabHover?.(tabData.network, tabData)}\n onFocus={() => customHandlers?.onTabFocus?.(tabData.network, tabData)}\n title={tabData.displayName}\n aria-label={getNetworkAriaLabel(tabData.network, tabData.isSelected)}\n tabData={tabData}\n >\n <CustomIconContainer\n className={iconContainerClasses}\n role=\"img\"\n aria-label={`${tabData.displayName} network ${customConfig?.ariaLabels?.iconSuffix ?? 'icon'}`}\n tabData={tabData}\n >\n {tabData.network ? (\n <Web3Icon chainId={tabData.networkInfo?.chainId} />\n ) : (\n <div className=\"novacon:w-6 novacon:h-6 novacon:[&>img]:w-full novacon:[&>img]:h-full novacon:rounded-full novacon:bg-[var(--tuwa-bg-primary)]\">\n <GlobeAltIcon aria-hidden=\"true\" />\n </div>\n )}\n </CustomIconContainer>\n\n <AnimatePresence initial={false}>\n <CustomTabText\n variants={textVariant}\n className={tabTextClasses}\n animate={tabData.isSelected ? 'active' : 'inactive'}\n aria-hidden={!tabData.isSelected}\n tabData={tabData}\n >\n {tabData.displayName}\n </CustomTabText>\n </AnimatePresence>\n </CustomTabButton>\n\n {tabData.isSelected && (\n <CustomIndicator className={indicatorClasses} aria-hidden={true} tabData={tabData} />\n )}\n </CustomTab>\n );\n })}\n </CustomTabList>\n </CustomContainer>\n );\n },\n ),\n);\n\nNetworkTabs.displayName = 'NetworkTabs';\n","import { InformationCircleIcon } from '@heroicons/react/24/outline';\nimport {\n CloseIcon,\n cn,\n Dialog,\n DialogClose,\n DialogContent,\n DialogHeader,\n DialogTitle,\n standardButtonClasses,\n} from '@tuwaio/nova-core';\nimport {\n delay,\n formatWalletName,\n getWalletTypeFromConnectorName,\n impersonatedHelpers,\n OrbitAdapter,\n waitFor,\n WalletType,\n} from '@tuwaio/orbit-core';\nimport { motion } from 'framer-motion';\nimport { isAddress } from 'gill';\nimport React, {\n ComponentPropsWithoutRef,\n ComponentType,\n forwardRef,\n memo,\n useCallback,\n useEffect,\n useMemo,\n} from 'react';\n\nimport { ConnectContentType, useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { Connector, InitialChains } from '../../types';\nimport { getConnectChainId, getFilteredConnectors, networksLinks } from '../../utils';\nimport { ConnectButtonProps } from '../ConnectButton/ConnectButton';\nimport { AboutWallets, AboutWalletsCustomization } from './AboutWallets';\nimport { Connecting, ConnectingCustomization } from './Connecting';\nimport { ConnectorsSelections, ConnectorsSelectionsCustomization } from './ConnectorsSelections';\nimport { GetWallet, GetWalletCustomization } from './GetWallet';\nimport { ImpersonateForm, ImpersonateFormCustomization } from './ImpersonatedForm';\nimport { NetworkSelections, NetworkSelectionsCustomization } from './NetworkSelections';\nimport { NetworkTabs, NetworkTabsCustomization } from './NetworkTabs';\n\n/**\n * Interface for grouped wallet connectors\n */\nexport interface GroupedConnector {\n /** Name of the wallet connector */\n name: string;\n /** Optional icon for the wallet */\n icon?: string;\n /** Array of supported network adapters */\n adapters: OrbitAdapter[];\n /** Array of connectors with their associated adapters */\n connectors: (Connector & { adapter: OrbitAdapter })[];\n}\n\n/**\n * Connect modal data for customization context\n */\nexport interface ConnectModalData {\n /** Current content type being displayed */\n contentType: ConnectContentType;\n /** Selected network adapter */\n selectedAdapter: OrbitAdapter | undefined;\n /** Active connector name */\n activeConnector: string | undefined;\n /** Impersonated address */\n impersonatedAddress: string;\n /** Whether connection is established */\n isConnected: boolean;\n /** Whether modal is open */\n isOpen: boolean;\n /** Connection error if any */\n error: Error | string | null | undefined;\n /** Available connectors */\n connectors: Record<string, Connector[]>;\n /** Filtered connectors for current adapter */\n filteredConnectors: GroupedConnector[];\n /** Current labels from i18n */\n labels: ReturnType<typeof useNovaConnectLabels>;\n}\n\n/**\n * Bottom button configuration\n */\nexport interface BottomButtonConfig {\n /** Button title text */\n title: string;\n /** Button click handler */\n onClick: () => void | Promise<void>;\n /** Whether button is disabled */\n disabled?: boolean;\n /** Loading state */\n loading?: boolean;\n}\n\n// --- Component Props Types ---\ntype ModalContainerProps = {\n className?: string;\n children: React.ReactNode;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ModalHeaderProps = {\n className?: string;\n children: React.ReactNode;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype InfoButtonProps = {\n className?: string;\n onClick: () => void;\n 'aria-label'?: string;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLButtonElement>;\n\ntype TitleProps = {\n className?: string;\n children: React.ReactNode;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype CloseButtonProps = {\n className?: string;\n onClick: () => void;\n 'aria-label'?: string;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLButtonElement>;\n\ntype MainContentProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n id?: string;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype FooterProps = {\n className?: string;\n children: React.ReactNode;\n role?: string;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype BackButtonProps = {\n className?: string;\n onClick: () => void;\n 'aria-label'?: string;\n children: React.ReactNode;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLButtonElement>;\n\ntype ActionButtonProps = {\n className?: string;\n onClick: () => void | Promise<void>;\n 'aria-describedby'?: string;\n children: React.ReactNode;\n disabled?: boolean;\n loading?: boolean;\n modalData: ConnectModalData;\n buttonConfig: BottomButtonConfig;\n} & React.RefAttributes<HTMLButtonElement>;\n\ntype ActionDescriptionProps = {\n id?: string;\n className?: string;\n children: React.ReactNode;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLSpanElement>;\n\ntype ModalEmptyProps = {\n className?: string;\n children: React.ReactNode;\n modalData: ConnectModalData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * Customization options for ConnectModal component\n */\nexport type ConnectModalCustomization = {\n /** Custom components */\n components?: {\n /** Custom modal container */\n ModalContainer?: ComponentType<ModalContainerProps>;\n /** Custom modal header */\n ModalHeader?: ComponentType<ModalHeaderProps>;\n /** Custom info button */\n InfoButton?: ComponentType<InfoButtonProps>;\n /** Custom title */\n Title?: ComponentType<TitleProps>;\n /** Custom close button */\n CloseButton?: ComponentType<CloseButtonProps>;\n /** Custom main content wrapper */\n MainContent?: ComponentType<MainContentProps>;\n /** Custom footer */\n Footer?: ComponentType<FooterProps>;\n /** Custom back button */\n BackButton?: ComponentType<BackButtonProps>;\n /** Custom action button */\n ActionButton?: ComponentType<ActionButtonProps>;\n /** Custom action description */\n ActionDescription?: ComponentType<ActionDescriptionProps>;\n /** Custom dialog */\n Dialog?: ComponentType<ComponentPropsWithoutRef<typeof Dialog>>;\n /** Custom dialog content */\n DialogContent?: ComponentType<ComponentPropsWithoutRef<typeof DialogContent>>;\n /** Custom motion wrapper */\n MotionDiv?: ComponentType<ComponentPropsWithoutRef<typeof motion.div>>;\n /** Custom empty state */\n EmptyState?: ComponentType<ModalEmptyProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate modal container classes */\n modalContainer?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate header classes */\n header?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate info button classes */\n infoButton?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate title classes */\n title?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate close button classes */\n closeButton?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate main content classes */\n mainContent?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate footer classes */\n footer?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate back button classes */\n backButton?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate action button classes */\n actionButton?: (params: { modalData: ConnectModalData; buttonConfig: BottomButtonConfig }) => string;\n /** Function to generate action description classes */\n actionDescription?: (params: { modalData: ConnectModalData }) => string;\n /** Function to generate action description classes */\n emptyConnectors?: (params: { modalData: ConnectModalData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom modal open/close handler */\n onOpenChange?: (open: boolean, modalData: ConnectModalData) => void;\n /** Custom back navigation handler */\n onBack?: (modalData: ConnectModalData, originalHandler: () => void) => void;\n /** Custom info button click handler */\n onInfoClick?: (modalData: ConnectModalData) => void;\n /** Custom action button handlers for different content types */\n onActionClick?: {\n connectors?: (modalData: ConnectModalData) => void;\n getWallet?: (modalData: ConnectModalData) => void;\n about?: (modalData: ConnectModalData) => void;\n impersonate?: (modalData: ConnectModalData) => Promise<void>;\n connecting?: (modalData: ConnectModalData) => Promise<void>;\n };\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n modal?: (modalData: ConnectModalData) => string;\n infoButton?: (modalData: ConnectModalData) => string;\n closeButton?: (modalData: ConnectModalData) => string;\n backButton?: (modalData: ConnectModalData) => string;\n mainContent?: (modalData: ConnectModalData) => string;\n };\n /** Animation configuration */\n animation?: {\n /** Layout transition duration */\n layoutDuration?: number;\n /** Disable animations */\n disabled?: boolean;\n };\n };\n /** Child component customizations */\n childComponents?: {\n /** AboutWallets customization */\n aboutWallets?: AboutWalletsCustomization;\n /** Connecting customization */\n connecting?: ConnectingCustomization;\n /** ConnectorsSelections customization */\n connectorsSelections?: ConnectorsSelectionsCustomization;\n /** GetWallet customization */\n getWallet?: GetWalletCustomization;\n /** ImpersonateForm customization */\n impersonateForm?: ImpersonateFormCustomization;\n /** NetworkSelections customization */\n networkSelections?: NetworkSelectionsCustomization;\n /** NetworkTabs customization */\n networkTabs?: NetworkTabsCustomization;\n };\n};\n\n/**\n * Helper function to safely get connector name from array\n */\nfunction getConnectorName(\n connectors: Connector[] | undefined,\n activeConnector: string | undefined,\n): string | undefined {\n if (!connectors || !Array.isArray(connectors) || !activeConnector) {\n return undefined;\n }\n\n const connector = connectors.find((c) => {\n // @ts-expect-error - no types for connector on package level\n if (c && typeof c === 'object' && 'name' in c && typeof c.name === 'string') {\n // @ts-expect-error - no types for connector on package level\n return formatWalletName(c.name) === activeConnector;\n }\n return false;\n });\n // @ts-expect-error - no types for connector on package level\n return connector && typeof connector === 'object' && 'name' in connector && typeof connector.name === 'string'\n ? // @ts-expect-error - no types for connector on package level\n connector.name\n : undefined;\n}\n\n// --- Default Sub-Components ---\nconst DefaultModalContainer = forwardRef<HTMLDivElement, ModalContainerProps>(\n // eslint-disable-next-line\n ({ className, children, modalData, ...props }, ref) => (\n <div\n ref={ref}\n className={cn('novacon:relative novacon:flex novacon:w-full novacon:flex-col', className)}\n {...props}\n >\n {children}\n </div>\n ),\n);\nDefaultModalContainer.displayName = 'DefaultModalContainer';\n\nconst DefaultModalHeader = forwardRef<HTMLDivElement, ModalHeaderProps>(\n // eslint-disable-next-line\n ({ className, children, modalData, ...props }, ref) => (\n <div ref={ref} className={className} {...props}>\n <DialogHeader>{children}</DialogHeader>\n </div>\n ),\n);\nDefaultModalHeader.displayName = 'DefaultModalHeader';\n\nconst DefaultInfoButton = forwardRef<HTMLButtonElement, InfoButtonProps>(\n // eslint-disable-next-line\n ({ className, onClick, modalData, ...props }, ref) => (\n <button\n ref={ref}\n className={cn(\n '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',\n className,\n )}\n type=\"button\"\n onClick={onClick}\n {...props}\n >\n <InformationCircleIcon width={20} height={20} className=\"novacon:mr-1\" aria-hidden=\"true\" />\n </button>\n ),\n);\nDefaultInfoButton.displayName = 'DefaultInfoButton';\n\nconst DefaultTitle = forwardRef<HTMLDivElement, TitleProps>(\n // eslint-disable-next-line\n ({ className, children, modalData, ...props }, ref) => (\n <DialogTitle ref={ref} className={cn('novacon:flex novacon:items-center', className)} {...props}>\n {children}\n </DialogTitle>\n ),\n);\nDefaultTitle.displayName = 'DefaultTitle';\n\nconst DefaultCloseButton = forwardRef<HTMLButtonElement, CloseButtonProps>(\n // eslint-disable-next-line\n ({ className, onClick, modalData, ...props }, ref) => (\n <DialogClose asChild>\n <button\n ref={ref}\n type=\"button\"\n onClick={onClick}\n className={cn(\n '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)]',\n className,\n )}\n {...props}\n >\n <CloseIcon aria-hidden=\"true\" />\n </button>\n </DialogClose>\n ),\n);\nDefaultCloseButton.displayName = 'DefaultCloseButton';\n\nconst DefaultMainContent = forwardRef<HTMLDivElement, MainContentProps>(\n // eslint-disable-next-line\n ({ className, children, modalData, ...props }, ref) => (\n <main\n ref={ref}\n className={cn('novacon:flex novacon:flex-col novacon:gap-4 novacon:p-4', className)}\n id=\"connect-modal-content\"\n role=\"main\"\n {...props}\n >\n {children}\n </main>\n ),\n);\nDefaultMainContent.displayName = 'DefaultMainContent';\n\nconst DefaultFooter = forwardRef<HTMLDivElement, FooterProps>(\n // eslint-disable-next-line\n ({ className, children, modalData, ...props }, ref) => (\n <footer\n ref={ref}\n className={cn(\n 'novacon:flex novacon:w-full novacon:items-center novacon:justify-between novacon:border-t novacon:border-[var(--tuwa-border-primary)] novacon:p-4',\n className,\n )}\n role=\"contentinfo\"\n {...props}\n >\n {children}\n </footer>\n ),\n);\nDefaultFooter.displayName = 'DefaultFooter';\n\nconst DefaultBackButton = forwardRef<HTMLButtonElement, BackButtonProps>(\n // eslint-disable-next-line\n ({ className, onClick, children, modalData, ...props }, ref) => (\n <button ref={ref} type=\"button\" onClick={onClick} className={cn(standardButtonClasses, className)} {...props}>\n {children}\n </button>\n ),\n);\nDefaultBackButton.displayName = 'DefaultBackButton';\n\nconst DefaultActionButton = forwardRef<HTMLButtonElement, ActionButtonProps>(\n // eslint-disable-next-line\n ({ className, onClick, children, disabled, loading, buttonConfig, modalData, ...props }, ref) => (\n <button\n ref={ref}\n type=\"button\"\n onClick={onClick}\n disabled={disabled || loading}\n className={cn(standardButtonClasses, className)}\n {...props}\n >\n {loading ? 'Loading...' : children}\n </button>\n ),\n);\nDefaultActionButton.displayName = 'DefaultActionButton';\n\nconst DefaultActionDescription = forwardRef<HTMLSpanElement, ActionDescriptionProps>(\n // eslint-disable-next-line\n ({ className, children, modalData, ...props }, ref) => (\n <span ref={ref} className={cn('novacon:sr-only', className)} {...props}>\n {children}\n </span>\n ),\n);\nDefaultActionDescription.displayName = 'DefaultActionDescription';\n\nconst DefaultEmptyState = forwardRef<HTMLDivElement, ModalEmptyProps>(({ children, className, ...props }, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { modalData: _modalData, ...restProps } = props;\n return (\n <div ref={ref} className={className} {...restProps}>\n {children}\n </div>\n );\n});\nDefaultEmptyState.displayName = 'DefaultEmptyState';\n\n/**\n * Props for the ConnectModal component\n */\nexport interface ConnectModalProps extends InitialChains, Pick<ConnectButtonProps, 'store' | 'withImpersonated'> {\n /** Customization options */\n customization?: ConnectModalCustomization;\n}\n\n/**\n * ConnectModal component - Main modal dialog for wallet connection workflow\n *\n * This component provides a comprehensive wallet connection interface with:\n * - Multi-step connection flow with different content types\n * - Network selection and adapter filtering\n * - Support for regular wallets and impersonated wallets\n * - Educational content about wallets and networks\n * - Error handling and retry mechanisms\n * - Full accessibility support with ARIA labels\n * - Keyboard navigation and screen reader compatibility\n *\n * Modal content types:\n * - 'connectors': Main wallet selection screen with network tabs\n * - 'network': Network selection for multi-network wallets\n * - 'connecting': Connection progress and status display\n * - 'about': Educational content about wallets\n * - 'getWallet': Onboarding flow for users without wallets\n * - 'impersonate': Form for wallet address impersonation\n *\n * Visual features:\n * - Responsive design adapting to different screen sizes\n * - Smooth transitions between different content states\n * - Loading states and progress indicators\n * - Clear navigation with back/forward buttons\n * - Contextual action buttons in footer\n *\n * Accessibility features:\n * - Proper ARIA labels and roles for screen readers\n * - Keyboard navigation support with focus management\n * - Semantic HTML structure for better navigation\n * - Screen reader announcements for state changes\n * - High contrast compatible styling\n *\n * @param appChains - Configuration for supported blockchain networks\n * @param solanaRPCUrls - RPC URLs configuration for Solana network\n * @param store - Wallet store instance\n * @param withImpersonated - Whether to show impersonated wallet option\n * @param customization - Customization options for the component\n * @returns JSX element representing the connection modal dialog\n *\n * @example\n * ```tsx\n * <ConnectModal\n * appChains={{\n * [OrbitAdapter.EVM]: [1, 137, 56], // Ethereum, Polygon, BSC\n * [OrbitAdapter.SOLANA]: ['devnet', 'mainnet-beta']\n * }}\n * solanaRPCUrls={{\n * 'mainnet-beta': 'https://api.mainnet-beta.solana.com',\n * 'devnet': 'https://api.devnet.solana.com'\n * }}\n * store={walletStore}\n * withImpersonated\n * customization={{\n * classNames: {\n * title: ({ modalData }) =>\n * modalData.contentType === 'about' ? 'custom-about-title' : ''\n * }\n * }}\n * />\n * ```\n *\n * @public\n */\nexport const ConnectModal = memo<ConnectModalProps>(\n ({ appChains, solanaRPCUrls, store, withImpersonated, customization = {} }) => {\n const {\n isConnectModalOpen,\n setIsConnectModalOpen,\n setConnectModalContentType,\n setActiveConnector,\n setImpersonatedAddress,\n setIsConnected,\n connectModalContentType,\n selectedAdapter,\n setSelectedAdapter,\n isConnected,\n activeConnector,\n impersonatedAddress,\n walletConnectionError,\n } = useNovaConnect();\n\n // Memoize store methods to prevent unnecessary re-renders\n const storeGetters = useMemo(\n () => ({\n getConnectors: store.getState().getConnectors,\n connect: store.getState().connect,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [],\n );\n\n const labels = useNovaConnectLabels();\n\n // Memoize connectors to avoid recalculation on every render\n const connectors = useMemo(() => {\n if (isConnectModalOpen) {\n return storeGetters.getConnectors();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isConnectModalOpen]);\n\n const filteredConnectors = useMemo(\n () => getFilteredConnectors({ connectors: connectors!, selectedAdapter }),\n [connectors, selectedAdapter],\n );\n\n // Convert error to Error object if it's a string\n const normalizedError = useMemo(() => {\n if (!walletConnectionError) return null;\n if (typeof walletConnectionError === 'string') {\n return new Error(walletConnectionError);\n }\n return walletConnectionError;\n }, [walletConnectionError]);\n\n // Memoize modal data for customization context\n const modalData = useMemo<ConnectModalData>(\n () => ({\n contentType: connectModalContentType,\n selectedAdapter,\n activeConnector,\n impersonatedAddress,\n isConnected,\n isOpen: isConnectModalOpen,\n error: normalizedError,\n connectors: connectors!,\n filteredConnectors,\n labels,\n }),\n [\n connectModalContentType,\n selectedAdapter,\n activeConnector,\n impersonatedAddress,\n isConnected,\n isConnectModalOpen,\n normalizedError,\n connectors,\n filteredConnectors,\n labels,\n ],\n );\n\n // Reset modal state when opened\n useEffect(() => {\n if (isConnectModalOpen) {\n setConnectModalContentType('connectors');\n setSelectedAdapter(undefined);\n setActiveConnector(undefined);\n setImpersonatedAddress('');\n setIsConnected(false);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isConnectModalOpen]);\n\n // Extract customization options\n const { components = {}, classNames = {}, handlers = {}, config = {}, childComponents = {} } = customization;\n\n // Component selections with defaults\n const ModalContainer = components.ModalContainer || DefaultModalContainer;\n const ModalHeader = components.ModalHeader || DefaultModalHeader;\n const InfoButton = components.InfoButton || DefaultInfoButton;\n const Title = components.Title || DefaultTitle;\n const CloseButton = components.CloseButton || DefaultCloseButton;\n const MainContent = components.MainContent || DefaultMainContent;\n const Footer = components.Footer || DefaultFooter;\n const BackButton = components.BackButton || DefaultBackButton;\n const ActionButton = components.ActionButton || DefaultActionButton;\n const ActionDescription = components.ActionDescription || DefaultActionDescription;\n const CustomEmptyState = components.EmptyState || DefaultEmptyState;\n const CustomDialog = components.Dialog || Dialog;\n const CustomDialogContent = components.DialogContent || DialogContent;\n const CustomMotionDiv = components.MotionDiv || motion.div;\n\n /**\n * Gets the appropriate title for the current modal content\n */\n const getTitle = useCallback(() => {\n switch (connectModalContentType) {\n case 'about':\n return labels.aboutWallets;\n case 'getWallet':\n return labels.getWallet;\n case 'connecting':\n if (selectedAdapter && activeConnector && connectors) {\n const connectorName = getConnectorName(connectors[selectedAdapter], activeConnector);\n return connectorName || labels.connectingEllipsis;\n }\n return labels.connectingEllipsis;\n case 'impersonate':\n return labels.connectImpersonatedWallet;\n default:\n return labels.connectWallet;\n }\n }, [connectModalContentType, selectedAdapter, activeConnector, connectors, labels]);\n\n /**\n * Determines the content type to navigate back to\n */\n const goBackContentType = useCallback((): ConnectContentType => {\n switch (connectModalContentType) {\n default:\n return 'connectors';\n }\n }, [connectModalContentType]);\n\n /**\n * Handle modal open/close with custom handler\n */\n const handleOpenChange = useCallback(\n (open: boolean) => {\n if (handlers?.onOpenChange) {\n handlers.onOpenChange(open, modalData);\n } else {\n setIsConnectModalOpen(open);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [handlers?.onOpenChange, modalData, setIsConnectModalOpen],\n );\n\n /**\n * Handle back navigation with custom handler\n */\n const handleBack = useCallback(() => {\n const originalHandler = () => setConnectModalContentType(goBackContentType());\n\n if (handlers?.onBack) {\n handlers.onBack(modalData, originalHandler);\n } else {\n originalHandler();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [handlers?.onBack, modalData, setConnectModalContentType, goBackContentType]);\n\n /**\n * Handle info button click\n */\n const handleInfoClick = useCallback(() => {\n if (handlers?.onInfoClick) {\n handlers.onInfoClick(modalData);\n } else {\n setConnectModalContentType('about');\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [handlers?.onInfoClick, modalData, setConnectModalContentType]);\n\n /**\n * Generic connection handler\n */\n const handleConnect = useCallback(\n async (walletType: WalletType, adapter: OrbitAdapter) => {\n await storeGetters.connect({\n walletType,\n chainId: getConnectChainId({ appChains, selectedAdapter: adapter, solanaRPCUrls }),\n });\n\n try {\n await waitFor(() => store?.getState().activeWallet?.isConnected);\n setIsConnected(true);\n const modalCloseTime = setTimeout(() => setIsConnectModalOpen(false), 400);\n const isConnectedTimer = setTimeout(() => setIsConnected(false), 500);\n await delay(null, 500);\n clearTimeout(modalCloseTime);\n clearTimeout(isConnectedTimer);\n } catch (error) {\n console.error(error);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [storeGetters],\n );\n\n /**\n * Handle network selection click\n */\n const handleNetworkClick = useCallback(\n async (adapter: OrbitAdapter, walletType: WalletType) => {\n setSelectedAdapter(adapter);\n setConnectModalContentType('connecting');\n await handleConnect(walletType, adapter);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [handleConnect],\n );\n\n /**\n * Handle connector selection click\n */\n const handleConnectorClick = useCallback(\n (connector: GroupedConnector) => {\n setActiveConnector(formatWalletName(connector.name));\n if (connector.adapters.length === 1) {\n setSelectedAdapter(connector.adapters[0]);\n setConnectModalContentType(\n formatWalletName(connector.name) === 'impersonatedwallet' ? 'impersonate' : 'connecting',\n );\n } else if (selectedAdapter) {\n setConnectModalContentType(\n formatWalletName(connector.name) === 'impersonatedwallet' ? 'impersonate' : 'connecting',\n );\n } else if (formatWalletName(connector.name) === 'impersonatedwallet') {\n setConnectModalContentType('impersonate');\n } else {\n setConnectModalContentType('network');\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [selectedAdapter],\n );\n\n /**\n * Renders the main content based on current modal state\n */\n const renderMainContent = useCallback(() => {\n switch (connectModalContentType) {\n case 'network':\n return (\n <NetworkSelections\n activeConnector={activeConnector}\n connectors={filteredConnectors}\n onClick={handleNetworkClick}\n customization={childComponents.networkSelections}\n />\n );\n case 'connectors':\n return connectors ? (\n <>\n <NetworkTabs\n networks={Object.keys(connectors) as OrbitAdapter[]}\n selectedAdapter={selectedAdapter}\n onSelect={(adapter) => setSelectedAdapter(adapter)}\n customization={childComponents.networkTabs}\n />\n\n <ConnectorsSelections\n isOnlyOneNetwork={Object.keys(connectors).length === 1}\n connectors={filteredConnectors}\n selectedAdapter={selectedAdapter}\n onClick={handleConnectorClick}\n setContentType={setConnectModalContentType}\n appChains={appChains}\n solanaRPCUrls={solanaRPCUrls}\n setIsConnected={setIsConnected}\n setIsOpen={setIsConnectModalOpen}\n waitForPredict={() => store?.getState().activeWallet?.isConnected}\n withImpersonated={withImpersonated}\n store={store}\n customization={childComponents.connectorsSelections}\n />\n </>\n ) : (\n <CustomEmptyState className={classNames.emptyConnectors?.({ modalData })} modalData={modalData}>\n No connectors available\n </CustomEmptyState>\n );\n case 'about':\n return <AboutWallets customization={childComponents.aboutWallets} />;\n case 'getWallet':\n return <GetWallet customization={childComponents.getWallet} />;\n case 'connecting':\n return (\n <Connecting\n selectedAdapter={selectedAdapter}\n connectors={filteredConnectors}\n activeConnector={activeConnector}\n isConnected={isConnected}\n customization={childComponents.connecting}\n />\n );\n case 'impersonate':\n return (\n <ImpersonateForm\n store={store}\n impersonatedAddress={impersonatedAddress}\n setImpersonatedAddress={setImpersonatedAddress}\n customization={childComponents.impersonateForm}\n />\n );\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n connectModalContentType,\n activeConnector,\n filteredConnectors,\n handleNetworkClick,\n childComponents,\n connectors,\n selectedAdapter,\n handleConnectorClick,\n isConnected,\n impersonatedAddress,\n ]);\n\n /**\n * Gets configuration for the bottom action button\n */\n const getBottomButtonConfig = useCallback((): BottomButtonConfig | undefined => {\n switch (connectModalContentType) {\n case 'connectors':\n return {\n title: labels.iDontHaveWallet,\n onClick: () => {\n if (handlers.onActionClick?.connectors) {\n handlers.onActionClick.connectors(modalData);\n } else {\n setConnectModalContentType('getWallet');\n }\n },\n };\n case 'getWallet':\n return {\n title: labels.choseWallet,\n onClick: () => {\n if (handlers.onActionClick?.getWallet) {\n handlers.onActionClick.getWallet(modalData);\n } else {\n window.open(\n networksLinks[selectedAdapter ?? (Object.keys(connectors!)[0] as OrbitAdapter)]?.choseWallet,\n '_blank',\n 'noopener,noreferrer',\n );\n }\n },\n };\n case 'about':\n return {\n title: labels.learnMore,\n onClick: () => {\n if (handlers.onActionClick?.about) {\n handlers.onActionClick.about(modalData);\n } else {\n window.open(\n networksLinks[selectedAdapter ?? (Object.keys(connectors!)[0] as OrbitAdapter)]?.about,\n '_blank',\n 'noopener,noreferrer',\n );\n }\n },\n };\n case 'impersonate':\n return {\n title: labels.connect,\n onClick: async () => {\n if (handlers.onActionClick?.impersonate) {\n await handlers.onActionClick.impersonate(modalData);\n } else {\n const trimmedAddress = impersonatedAddress.trim();\n if (\n walletConnectionError ||\n !trimmedAddress ||\n isAddress(trimmedAddress) ||\n !!store?.getState().activeWallet?.isConnected\n )\n return;\n\n impersonatedHelpers.setImpersonated(trimmedAddress);\n await handleConnect(\n `${selectedAdapter ?? OrbitAdapter.EVM}:impersonatedwallet` as WalletType,\n selectedAdapter ?? OrbitAdapter.EVM,\n );\n setConnectModalContentType('connecting');\n }\n },\n };\n case 'connecting':\n return walletConnectionError && selectedAdapter && activeConnector\n ? {\n title: labels.tryAgain,\n onClick: async () => {\n if (handlers.onActionClick?.connecting) {\n await handlers.onActionClick.connecting(modalData);\n } else {\n await handleConnect(\n getWalletTypeFromConnectorName(selectedAdapter, activeConnector) as WalletType,\n selectedAdapter,\n );\n }\n },\n }\n : undefined;\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n connectModalContentType,\n labels,\n handlers,\n modalData,\n selectedAdapter,\n connectors,\n impersonatedAddress,\n walletConnectionError,\n handleConnect,\n activeConnector,\n ]);\n\n const bottomButtonConfig = getBottomButtonConfig();\n\n /**\n * Get action description text\n */\n const getActionDescription = useCallback(() => {\n switch (connectModalContentType) {\n case 'getWallet':\n return 'Opens external wallet selection page';\n case 'about':\n return 'Opens external documentation';\n case 'impersonate':\n return 'Connects with impersonated wallet address';\n case 'connecting':\n return 'Retries wallet connection';\n default:\n return '';\n }\n }, [connectModalContentType]);\n\n return (\n <CustomDialog open={isConnectModalOpen} onOpenChange={handleOpenChange}>\n <CustomDialogContent className={cn('novacon:w-full novacon:sm:max-w-md')}>\n <CustomMotionDiv\n layout\n transition={{\n layout: {\n duration: config.animation?.disabled ? 0 : (config.animation?.layoutDuration ?? 0.0001),\n },\n }}\n >\n <ModalContainer className={classNames.modalContainer?.({ modalData })} modalData={modalData}>\n <ModalHeader className={classNames.header?.({ modalData })} modalData={modalData}>\n <Title className={classNames.title?.({ modalData })} modalData={modalData}>\n {connectModalContentType === 'connectors' && (\n <InfoButton\n className={classNames.infoButton?.({ modalData })}\n onClick={handleInfoClick}\n aria-label={\n config.ariaLabels?.infoButton?.(modalData) || `${labels.learnMore} ${labels.aboutWallets}`\n }\n modalData={modalData}\n />\n )}\n {getTitle()}\n </Title>\n\n <CloseButton\n className={classNames.closeButton?.({ modalData })}\n onClick={() => handleOpenChange(false)}\n aria-label={config.ariaLabels?.closeButton?.(modalData) || labels.closeModal}\n modalData={modalData}\n />\n </ModalHeader>\n\n <MainContent className={classNames.mainContent?.({ modalData })} modalData={modalData}>\n {renderMainContent()}\n </MainContent>\n\n <Footer className={classNames.footer?.({ modalData })} modalData={modalData}>\n <div className=\"novacon:flex novacon:items-center novacon:gap-4\">\n {connectModalContentType !== 'connectors' && (\n <BackButton\n className={classNames.backButton?.({ modalData })}\n onClick={handleBack}\n aria-label={config.ariaLabels?.backButton?.(modalData) || `${labels.back} to previous step`}\n modalData={modalData}\n >\n {labels.back}\n </BackButton>\n )}\n </div>\n {bottomButtonConfig && (\n <div className=\"novacon:flex novacon:items-center novacon:gap-3\">\n <ActionButton\n className={classNames.actionButton?.({ modalData, buttonConfig: bottomButtonConfig })}\n onClick={bottomButtonConfig.onClick}\n disabled={bottomButtonConfig.disabled}\n loading={bottomButtonConfig.loading}\n aria-describedby=\"bottom-action-description\"\n modalData={modalData}\n buttonConfig={bottomButtonConfig}\n >\n {bottomButtonConfig.title}\n </ActionButton>\n <ActionDescription\n id=\"bottom-action-description\"\n className={classNames.actionDescription?.({ modalData })}\n modalData={modalData}\n >\n {getActionDescription()}\n </ActionDescription>\n </div>\n )}\n </Footer>\n </ModalContainer>\n </CustomMotionDiv>\n </CustomDialogContent>\n </CustomDialog>\n );\n },\n);\n\nConnectModal.displayName = 'ConnectModal';\n","/**\n * @file This file contains the `StatusIcon` component, a customizable animated status icon with comprehensive styling control.\n */\n\nimport { cn } from '@tuwaio/nova-core';\nimport { type Easing, type HTMLMotionProps, motion, type TargetAndTransition, type Variants } from 'framer-motion';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useMemo } from 'react';\n\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\n\n// --- Default Motion Variants ---\nconst DEFAULT_MOTION_PATH_VARIANTS: Variants = {\n hidden: { pathLength: 0, opacity: 0 },\n visible: { pathLength: 1, opacity: 1 },\n};\n\nconst DEFAULT_CONTAINER_VARIANTS: Variants = {\n initial: { scale: 0.8, opacity: 0 },\n animate: { scale: 1, opacity: 1 },\n exit: { scale: 0.8, opacity: 0 },\n};\n\n// --- Types for Customization ---\ntype CustomSvgProps = {\n pathData: string;\n className?: string;\n 'aria-hidden'?: boolean;\n focusable?: boolean;\n};\n\ntype CustomPathProps = {\n pathData: string;\n variants?: Variants;\n className?: string;\n strokeLinecap?: 'butt' | 'round' | 'square';\n strokeLinejoin?: 'miter' | 'bevel' | 'round';\n strokeWidth?: string | number;\n};\n\ntype CustomContentProps = {\n txStatus: 'succeed' | 'failed' | 'replaced';\n colorVar: string;\n pathData: string;\n finalAriaLabel: string;\n};\n\n/**\n * Customization options for StatusIcon component\n */\nexport type StatusIconCustomization = {\n /** Override container element props */\n containerProps?: Partial<\n Omit<HTMLMotionProps<'div'>, 'initial' | 'animate' | 'exit' | 'variants' | 'transition' | 'style'>\n >;\n /** Custom components */\n components?: {\n /** Custom SVG component */\n Svg?: ComponentType<CustomSvgProps>;\n /** Custom path component */\n Path?: ComponentType<CustomPathProps>;\n /** Custom content component (wraps everything) */\n Content?: ComponentType<CustomContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { txStatus: 'succeed' | 'failed' | 'replaced'; colorVar: string }) => string;\n /** Function to generate SVG classes */\n svg?: (params: { txStatus: 'succeed' | 'failed' | 'replaced'; colorVar: string }) => string;\n /** Function to generate path classes */\n path?: (params: { txStatus: 'succeed' | 'failed' | 'replaced' }) => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Container motion variants */\n container?: Variants;\n /** Path motion variants */\n path?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Container animation configuration */\n container?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Path animation configuration */\n path?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom SVG properties */\n svg?: {\n /** Custom viewBox */\n viewBox?: string;\n /** Custom stroke width */\n strokeWidth?: string | number;\n /** Custom stroke linecap */\n strokeLinecap?: 'butt' | 'round' | 'square';\n /** Custom stroke linejoin */\n strokeLinejoin?: 'miter' | 'bevel' | 'round';\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n };\n};\n\nexport interface StatusIconProps\n extends Omit<\n HTMLMotionProps<'div'>,\n 'children' | 'initial' | 'animate' | 'exit' | 'variants' | 'transition' | 'style'\n > {\n /** Transaction status type */\n txStatus: 'succeed' | 'failed' | 'replaced';\n /** Color variable name (without --tuwa- prefix) */\n colorVar: string;\n /** SVG path data */\n children: ReactNode;\n /** Custom aria-label for accessibility */\n 'aria-label'?: string;\n /** Custom CSS classes for the container */\n className?: string;\n /** Customization options */\n customization?: StatusIconCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultSvg = ({\n pathData,\n className,\n 'aria-hidden': ariaHidden = true,\n focusable = false,\n ...props\n}: CustomSvgProps & Omit<ComponentPropsWithoutRef<'svg'>, 'style'>) => {\n return (\n <svg\n className={cn('novacon:w-4 novacon:h-4', className)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth=\"2\"\n stroke=\"currentColor\"\n aria-hidden={ariaHidden}\n focusable={focusable ? 'true' : 'false'}\n {...props}\n >\n <DefaultPath pathData={pathData} />\n </svg>\n );\n};\n\nconst DefaultPath = ({\n pathData,\n variants = DEFAULT_MOTION_PATH_VARIANTS,\n className,\n strokeLinecap = 'round',\n strokeLinejoin = 'round',\n strokeWidth = 2,\n ...props\n}: CustomPathProps & Omit<ComponentPropsWithoutRef<typeof motion.path>, 'style'>) => {\n return (\n <motion.path\n d={pathData}\n strokeLinecap={strokeLinecap}\n strokeLinejoin={strokeLinejoin}\n strokeWidth={strokeWidth}\n variants={variants}\n initial=\"hidden\"\n animate=\"visible\"\n transition={{\n duration: 0.5,\n ease: 'easeInOut',\n delay: 0.1,\n }}\n className={className}\n {...props}\n />\n );\n};\n\nconst DefaultContent = ({ pathData, finalAriaLabel }: Pick<CustomContentProps, 'pathData' | 'finalAriaLabel'>) => {\n return <DefaultSvg pathData={pathData} aria-label={finalAriaLabel} />;\n};\n\n/**\n * A highly customizable animated status icon component with comprehensive styling and animation options.\n * Provides visual feedback for transaction states with smooth animations and full accessibility support.\n *\n * Features:\n * - Animated container and path with Framer Motion\n * - Comprehensive customization for all visual elements and animations\n * - Full accessibility support with ARIA labels and proper roles\n * - Status-based styling with CSS custom properties\n * - Configurable animation timing and easing\n * - Reduced motion support for accessibility\n * - Custom SVG properties and path styling\n * - Performance-optimized with memoized calculations\n *\n * @example Basic usage\n * ```tsx\n * <StatusIcon txStatus=\"succeed\" colorVar=\"success\">\n * m4.5 12.75 6 6 9-13.5\n * </StatusIcon>\n * ```\n *\n * @example With full customization\n * ```tsx\n * <StatusIcon\n * txStatus=\"failed\"\n * colorVar=\"error\"\n * customization={{\n * classNames: {\n * container: ({ txStatus }) => `custom-status-${txStatus} novacon:shadow-lg`,\n * svg: () => \"custom-svg-styling\",\n * },\n * animation: {\n * container: { duration: 0.5, ease: \"easeOut\" },\n * path: { duration: 1, delay: 0.2 },\n * },\n * variants: {\n * container: {\n * initial: { rotate: -180, scale: 0 },\n * animate: { rotate: 0, scale: 1 },\n * },\n * },\n * svg: {\n * strokeWidth: 3,\n * strokeLinecap: \"square\",\n * },\n * config: {\n * reduceMotion: false,\n * },\n * }}\n * >\n * M6 18 18 6M6 6l12 12\n * </StatusIcon>\n * ```\n */\nexport const StatusIcon = forwardRef<HTMLDivElement, StatusIconProps>(\n ({ txStatus, colorVar, children, 'aria-label': ariaLabel, className, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n\n // Extract path data from children\n const pathData = useMemo(() => {\n return typeof children === 'string' ? children : '';\n }, [children]);\n\n // Extract custom components\n const { Svg = DefaultSvg, Path = DefaultPath, Content = DefaultContent } = customization?.components ?? {};\n\n // Memoize the default aria-label based on status\n const defaultAriaLabel = useMemo(() => {\n switch (txStatus) {\n case 'succeed':\n return labels.successIcon;\n case 'failed':\n return labels.errorIcon;\n case 'replaced':\n return labels.replacedIcon;\n default:\n return labels.statusIcon;\n }\n }, [txStatus, labels]);\n\n // Memoize the final aria-label\n const finalAriaLabel = useMemo(() => {\n return ariaLabel || defaultAriaLabel;\n }, [ariaLabel, defaultAriaLabel]);\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ txStatus, colorVar });\n }\n return cn(\n 'novacon:w-6 novacon:h-6 novacon:rounded-full novacon:flex novacon:items-center novacon:justify-center novacon:shadow-sm',\n `novacon:text-[var(--tuwa-${colorVar}-text)] novacon:bg-[var(--tuwa-bg-primary)]`,\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, txStatus, colorVar, className]);\n\n // Generate SVG classes\n const svgClasses = useMemo(() => {\n if (customization?.classNames?.svg) {\n return customization.classNames.svg({ txStatus, colorVar });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.svg, txStatus, colorVar]);\n\n // Generate path classes\n const pathClasses = useMemo(() => {\n if (customization?.classNames?.path) {\n return customization.classNames.path({ txStatus });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.path, txStatus]);\n\n // Resolve animation variants\n const containerVariants = useMemo(() => {\n if (customization?.variants?.container) {\n return customization.variants.container;\n }\n\n return DEFAULT_CONTAINER_VARIANTS;\n }, [customization?.variants?.container]);\n\n const pathVariants = useMemo(() => {\n if (customization?.variants?.path) {\n return customization.variants.path;\n }\n\n return DEFAULT_MOTION_PATH_VARIANTS;\n }, [customization?.variants?.path]);\n\n // Resolve animation configuration\n const containerAnimation = useMemo(() => {\n const config = customization?.animation?.container;\n return {\n duration: config?.duration ?? 0.3,\n ease: config?.ease ?? [0.4, 0, 0.2, 1],\n delay: config?.delay ?? 0,\n };\n }, [customization?.animation?.container]);\n\n const pathAnimation = useMemo(() => {\n const config = customization?.animation?.path;\n return {\n duration: config?.duration ?? 0.5,\n ease: config?.ease ?? 'easeInOut',\n delay: config?.delay ?? 0.1,\n };\n }, [customization?.animation?.path]);\n\n // Check for reduced motion\n const shouldReduceMotion = customization?.config?.reduceMotion ?? false;\n const isAnimationDisabled = customization?.config?.disableAnimation ?? false;\n\n // Create SVG element with custom props\n const svgElement = useMemo(() => {\n if (customization?.components?.Svg) {\n return <Svg pathData={pathData} className={svgClasses} aria-hidden={true} focusable={false} />;\n }\n\n return (\n <svg\n className={cn('novacon:w-4 novacon:h-4', svgClasses)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox={customization?.svg?.viewBox ?? '0 0 24 24'}\n strokeWidth={customization?.svg?.strokeWidth ?? '2'}\n stroke=\"currentColor\"\n aria-hidden=\"true\"\n focusable=\"false\"\n >\n <Path\n pathData={pathData}\n variants={isAnimationDisabled || shouldReduceMotion ? {} : pathVariants}\n className={pathClasses}\n strokeLinecap={customization?.svg?.strokeLinecap ?? 'round'}\n strokeLinejoin={customization?.svg?.strokeLinejoin ?? 'round'}\n strokeWidth={customization?.svg?.strokeWidth ?? 2}\n {...(!isAnimationDisabled && !shouldReduceMotion\n ? {\n initial: 'hidden',\n animate: 'visible',\n transition: pathAnimation,\n }\n : {})}\n />\n </svg>\n );\n }, [\n customization?.components?.Svg,\n customization?.svg,\n Svg,\n Path,\n pathData,\n svgClasses,\n pathClasses,\n isAnimationDisabled,\n shouldReduceMotion,\n pathVariants,\n pathAnimation,\n ]);\n\n // Base props without animation properties\n const baseProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n key: txStatus,\n className: containerClasses,\n\n role: 'img' as const,\n 'aria-label': finalAriaLabel,\n }),\n [customization?.containerProps, props, ref, txStatus, containerClasses, finalAriaLabel],\n );\n\n // Conditional rendering with proper animation types\n if (isAnimationDisabled || shouldReduceMotion) {\n return (\n <motion.div {...baseProps}>\n {customization?.components?.Content ? (\n <Content txStatus={txStatus} colorVar={colorVar} pathData={pathData} finalAriaLabel={finalAriaLabel} />\n ) : (\n svgElement\n )}\n </motion.div>\n );\n }\n\n return (\n <motion.div\n {...baseProps}\n // eslint-disable-next-line\n key={baseProps?.key ?? \"status\"}\n initial={containerVariants.initial as TargetAndTransition}\n animate={containerVariants.animate as TargetAndTransition}\n exit={containerVariants.exit as TargetAndTransition}\n transition={containerAnimation}\n >\n {customization?.components?.Content ? (\n <Content txStatus={txStatus} colorVar={colorVar} pathData={pathData} finalAriaLabel={finalAriaLabel} />\n ) : (\n svgElement\n )}\n </motion.div>\n );\n },\n);\n\nStatusIcon.displayName = 'StatusIcon';\n","/**\n * @file ConnectedContent component displays wallet connection status with transaction monitoring and comprehensive customization options.\n */\n\nimport { ChevronArrowWithAnim, cn } from '@tuwaio/nova-core';\nimport { Transaction, TransactionStatus } from '@tuwaio/pulsar-core';\nimport React, {\n ComponentPropsWithoutRef,\n ComponentType,\n forwardRef,\n ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport { useGetWalletNameAndAvatar, useWalletNativeBalance } from '../../hooks';\nimport { ButtonTxStatus, useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { WalletAvatar, WalletAvatarCustomization } from '../WalletAvatar';\nimport { ConnectButtonProps } from './ConnectButton';\nimport { StatusIcon, type StatusIconCustomization } from './StatusIcon';\n\n// --- Types for Customization ---\ntype StatusDisplayData = {\n displayName: ReactNode;\n avatarIcon: ReactNode;\n ariaLabel: string;\n};\n\ntype CustomBalanceContainerProps = {\n formattedBalance: string;\n labels: Record<string, string>;\n className?: string;\n 'aria-label'?: string;\n};\n\ntype CustomMainContentProps = {\n statusDisplay: StatusDisplayData;\n connectedButtonStatus: ButtonTxStatus;\n isConnectedModalOpen: boolean;\n withBalance: boolean;\n labels: Record<string, string>;\n className?: string;\n};\n\ntype CustomLoadingAnimationProps = {\n connectedButtonStatus: ButtonTxStatus;\n className?: string;\n};\n\ntype CustomBalanceDividerProps = {\n className?: string;\n};\n\n/**\n * Customization options for ConnectedContent component\n */\nexport type ConnectedContentCustomization = {\n /** Override root container props */\n containerProps?: Partial<ComponentPropsWithoutRef<'div'>>;\n /** Custom components */\n components?: {\n /** Custom balance container component */\n BalanceContainer?: ComponentType<CustomBalanceContainerProps>;\n /** Custom main content wrapper component */\n MainContent?: ComponentType<CustomMainContentProps>;\n /** Custom loading animation component */\n LoadingAnimation?: ComponentType<CustomLoadingAnimationProps>;\n /** Custom balance divider component */\n BalanceDivider?: ComponentType<CustomBalanceDividerProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { connectedButtonStatus: ButtonTxStatus; withBalance: boolean }) => string;\n /** Function to generate balance container classes */\n balanceContainer?: (params: { formattedBalance: string }) => string;\n /** Function to generate balance text classes */\n balanceText?: (params: { formattedBalance: string }) => string;\n /** Function to generate balance divider classes */\n balanceDivider?: () => string;\n /** Function to generate main content classes */\n mainContent?: (params: { withBalance: boolean }) => string;\n /** Function to generate loading animation classes */\n loadingAnimation?: (params: { connectedButtonStatus: ButtonTxStatus }) => string;\n };\n /** Customization options for child components */\n childCustomizations?: {\n /** WalletAvatar customization for idle and loading states */\n walletAvatar?: WalletAvatarCustomization;\n /** StatusIcon customization for transaction states */\n statusIcon?: {\n /** StatusIcon customization for success state */\n succeed?: StatusIconCustomization;\n /** StatusIcon customization for failed state */\n failed?: StatusIconCustomization;\n /** StatusIcon customization for replaced state */\n replaced?: StatusIconCustomization;\n };\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom handler for balance click events */\n onBalanceClick?: (formattedBalance: string, event: React.MouseEvent<HTMLDivElement>) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom timeout for auto-reset status (in milliseconds) */\n statusResetTimeout?: number;\n /** Whether to show loading animation */\n showLoadingAnimation?: boolean;\n /** Whether to show balance divider */\n showBalanceDivider?: boolean;\n };\n};\n\nexport interface ConnectedContentProps extends Pick<ConnectButtonProps, 'transactionPool' | 'store' | 'withBalance'> {\n /** Custom CSS classes for the container */\n className?: string;\n /** Custom aria-label for the container */\n 'aria-label'?: string;\n /** Customization options */\n customization?: ConnectedContentCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultBalanceContainer = ({ formattedBalance, labels, className, ...props }: CustomBalanceContainerProps) => {\n return (\n <div\n className={cn(\n 'novacon:relative novacon:hidden novacon:sm:flex novacon:items-center novacon:pr-2 novacon:gap-2 novacon:text-[var(--tuwa-text-secondary)]',\n className,\n )}\n role=\"text\"\n aria-label={`${labels.walletBalance}: ${formattedBalance}`}\n {...props}\n >\n <span className=\"novacon:font-semibold novacon:mr-1\" aria-hidden=\"true\">\n {formattedBalance}\n </span>\n </div>\n );\n};\n\nconst DefaultMainContent = ({\n statusDisplay,\n isConnectedModalOpen,\n withBalance,\n className,\n}: CustomMainContentProps) => {\n return (\n <div\n className={cn(\n 'novacon:flex novacon:items-center novacon:space-x-2',\n { 'novacon:sm:pl-2': withBalance },\n className,\n )}\n >\n {statusDisplay.avatarIcon}\n <span className=\"novacon:text-[var(--tuwa-text-primary)] novacon:font-medium novacon:hidden novacon:min-[480px]:block\">\n {statusDisplay.displayName}\n </span>\n <div aria-hidden=\"true\">\n <ChevronArrowWithAnim isOpen={isConnectedModalOpen} className=\"novacon:xs:hidden\" />\n </div>\n </div>\n );\n};\n\nconst DefaultLoadingAnimation = ({ connectedButtonStatus, className }: CustomLoadingAnimationProps) => {\n if (connectedButtonStatus !== 'loading') return null;\n\n return (\n <div\n className={cn(\n \"novacon:w-full novacon:h-full novacon:rounded-full novacon:absolute novacon:inset-0 novacon:before:content-[''] novacon:after:content-[''] novacon:before:rounded-full novacon:after:rounded-full novacon:before:absolute novacon:after:absolute novacon:before:inset-0 novacon:after:inset-0 novacon:before:u-shadow-inner-base novacon:after:u-shadow-inset-arc novacon:after:animate-rotate novacon:after:duration-2000 novacon:after:ease-linear novacon:after:infinite\",\n className,\n )}\n aria-hidden=\"true\"\n />\n );\n};\n\nconst DefaultBalanceDivider = ({ className }: CustomBalanceDividerProps) => {\n return (\n <div\n className={cn(\n 'novacon:absolute novacon:top-1/2 novacon:right-0 novacon:transform novacon:-translate-y-1/2 novacon:h-4 novacon:w-[1px] novacon:bg-[var(--tuwa-border-primary)]',\n className,\n )}\n aria-hidden=\"true\"\n />\n );\n};\n\n/**\n * ConnectedContent displays the wallet connection status with transaction monitoring capabilities.\n * Provides comprehensive customization for all visual elements, event handlers, and child components.\n *\n * Features:\n * - Real-time transaction status monitoring with visual feedback\n * - Comprehensive customization for all UI elements and behaviors\n * - Full accessibility support with ARIA labels and roles\n * - Responsive design with mobile-first approach\n * - Status-based styling and animations\n * - Balance display with optional divider\n * - Loading animation for pending transactions\n * - Customizable child components (WalletAvatar, StatusIcon)\n * - Event handler customization for enhanced interactivity\n * - Auto-reset functionality for transaction status\n *\n * @example Basic usage\n * ```tsx\n * <ConnectedContent\n * transactionPool={transactionPool}\n * withBalance={true}\n * store={walletStore}\n * />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <ConnectedContent\n * transactionPool={transactionPool}\n * withBalance={true}\n * store={walletStore}\n * customization={{\n * classNames: {\n * container: ({ connectedButtonStatus }) =>\n * `custom-container ${connectedButtonStatus === 'loading' ? 'loading' : ''}`,\n * balanceContainer: () => \"custom-balance bg-blue-500\",\n * },\n * components: {\n * LoadingAnimation: ({ className }) =>\n * <div className={cn(\"custom-spinner\", className)} />,\n * },\n * handlers: {\n * onBalanceClick: (balance, event) => console.log(\"Balance clicked:\", balance),\n * },\n * config: {\n * statusResetTimeout: 3000,\n * showLoadingAnimation: true,\n * },\n * childCustomizations: {\n * walletAvatar: {\n * classNames: {\n * container: () => \"custom-avatar-border\",\n * },\n * },\n * statusIcon: {\n * succeed: {\n * classNames: {\n * container: () => \"custom-success-icon\",\n * },\n * },\n * failed: {\n * classNames: {\n * container: () => \"custom-error-icon\",\n * },\n * },\n * },\n * },\n * }}\n * />\n * ```\n */\nexport const ConnectedContent = forwardRef<HTMLDivElement, ConnectedContentProps>(\n ({ transactionPool, withBalance, store, className, 'aria-label': ariaLabel, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n\n const { isConnectedModalOpen, setConnectedButtonStatus, connectedButtonStatus, activeWallet } = useNovaConnect();\n\n const { ensAvatar, ensNameAbbreviated } = useGetWalletNameAndAvatar({\n activeWallet,\n store,\n abbreviateSymbols: 6,\n maxNameLength: 30,\n autoRetry: false,\n retryDelay: 3000,\n });\n\n const { balance } = useWalletNativeBalance({ store, activeWallet });\n\n const formattedBalance = balance?.value ? parseFloat(balance.value).toFixed(3) : '0.000';\n\n const prevTxPoolRef = useRef<Transaction[]>(\n Object.values(transactionPool ?? {}).filter(\n (tx) => tx.from.toLowerCase() === activeWallet?.address.toLowerCase(),\n ),\n );\n\n // Extract custom components and config\n const {\n BalanceContainer = DefaultBalanceContainer,\n MainContent = DefaultMainContent,\n LoadingAnimation = DefaultLoadingAnimation,\n BalanceDivider = DefaultBalanceDivider,\n } = customization?.components ?? {};\n\n const {\n statusResetTimeout = 2000,\n showLoadingAnimation = true,\n showBalanceDivider = true,\n } = customization?.config ?? {};\n\n // Reset status on mount and cleanup\n useEffect(() => {\n setConnectedButtonStatus('idle');\n return () => setConnectedButtonStatus('idle');\n }, [setConnectedButtonStatus]);\n\n // Monitor transaction pool changes\n useEffect(() => {\n if (!activeWallet || !activeWallet?.isConnected) {\n return;\n }\n\n const currentPool =\n Object.values(transactionPool ?? {}).filter(\n (tx) => tx.from.toLowerCase() === activeWallet?.address.toLowerCase(),\n ) || [];\n const prevPool = prevTxPoolRef.current || [];\n let newStatus: ButtonTxStatus = 'idle';\n\n const isAnyTxLoading = currentPool.some((tx) => tx.pending);\n\n if (isAnyTxLoading) {\n newStatus = 'loading';\n } else {\n for (const currentTx of currentPool) {\n const prevTx = prevPool.find((tx) => tx.txKey === currentTx.txKey);\n\n if (currentTx.status && currentTx.status !== prevTx?.status) {\n switch (currentTx.status) {\n case TransactionStatus.Success:\n newStatus = 'succeed';\n break;\n case TransactionStatus.Replaced:\n newStatus = 'replaced';\n break;\n case TransactionStatus.Failed:\n newStatus = 'failed';\n break;\n }\n }\n }\n }\n\n if (newStatus === 'loading' || newStatus !== 'idle') {\n setConnectedButtonStatus(newStatus);\n }\n\n prevTxPoolRef.current = currentPool;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [transactionPool, activeWallet?.address, activeWallet?.isConnected, setConnectedButtonStatus]);\n\n // Auto-reset status after showing success/error states\n useEffect(() => {\n if (['succeed', 'failed', 'replaced'].includes(connectedButtonStatus)) {\n const timer = setTimeout(() => {\n setConnectedButtonStatus('idle');\n }, statusResetTimeout);\n return () => clearTimeout(timer);\n }\n }, [connectedButtonStatus, statusResetTimeout, setConnectedButtonStatus]);\n\n // Get status-specific aria label\n const getStatusAriaLabel = useCallback(\n (status: ButtonTxStatus) => {\n switch (status) {\n case 'succeed':\n return labels.transactionSuccess;\n case 'failed':\n return labels.transactionError;\n case 'replaced':\n return labels.transactionReplaced;\n case 'loading':\n return labels.transactionLoading;\n default:\n return labels.walletAddress;\n }\n },\n [labels],\n );\n\n // Memoized status display configuration\n const statusDisplay = useMemo(() => {\n if (!activeWallet) return { displayName: null, avatarIcon: null, ariaLabel: '' };\n\n const baseAriaLabel = `${labels.transactionStatus}: ${getStatusAriaLabel(connectedButtonStatus)}`;\n\n switch (connectedButtonStatus) {\n case 'succeed':\n return {\n displayName: labels.success,\n avatarIcon: (\n <StatusIcon\n txStatus=\"succeed\"\n colorVar=\"success\"\n aria-label={labels.transactionSuccess}\n customization={customization?.childCustomizations?.statusIcon?.succeed}\n >\n m4.5 12.75 6 6 9-13.5\n </StatusIcon>\n ),\n ariaLabel: baseAriaLabel,\n };\n case 'failed':\n return {\n displayName: labels.error,\n avatarIcon: (\n <StatusIcon\n txStatus=\"failed\"\n colorVar=\"error\"\n aria-label={labels.transactionError}\n customization={customization?.childCustomizations?.statusIcon?.failed}\n >\n M6 18 18 6M6 6l12 12\n </StatusIcon>\n ),\n ariaLabel: baseAriaLabel,\n };\n case 'replaced':\n return {\n displayName: labels.replaced,\n avatarIcon: (\n <StatusIcon\n txStatus=\"replaced\"\n colorVar=\"text\"\n aria-label={labels.transactionReplaced}\n customization={customization?.childCustomizations?.statusIcon?.replaced}\n >\n M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0 3.181 3.183a8.25 8.25 0 0 0\n 13.803-3.7M4.031 9.865a8.25 8.25 0 0 1 13.803-3.7l3.181 3.182m0-4.991v4.99\n </StatusIcon>\n ),\n ariaLabel: baseAriaLabel,\n };\n case 'loading':\n return {\n displayName: ensNameAbbreviated,\n avatarIcon: (\n <div className=\"novacon:relative novacon:p-1\">\n {showLoadingAnimation && (\n <LoadingAnimation\n connectedButtonStatus={connectedButtonStatus}\n className={customization?.classNames?.loadingAnimation?.({ connectedButtonStatus })}\n />\n )}\n <WalletAvatar\n address={activeWallet?.address}\n ensAvatar={ensAvatar}\n className=\"novacon:relative novacon:z-2\"\n aria-label={`${labels.walletAvatar}: ${ensNameAbbreviated}`}\n customization={customization?.childCustomizations?.walletAvatar}\n />\n </div>\n ),\n ariaLabel: `${labels.transactionLoading}. ${labels.walletAddress}: ${ensNameAbbreviated}`,\n };\n case 'idle':\n default:\n return {\n displayName: ensNameAbbreviated,\n avatarIcon: (\n <WalletAvatar\n address={activeWallet?.address}\n ensAvatar={ensAvatar}\n className=\"novacon:relative novacon:z-2\"\n aria-label={`${labels.walletAvatar}: ${ensNameAbbreviated}`}\n customization={customization?.childCustomizations?.walletAvatar}\n />\n ),\n ariaLabel: `${labels.walletAddress}: ${ensNameAbbreviated}`,\n };\n }\n }, [\n connectedButtonStatus,\n ensNameAbbreviated,\n activeWallet,\n ensAvatar,\n labels,\n getStatusAriaLabel,\n customization,\n showLoadingAnimation,\n LoadingAnimation,\n ]);\n\n // Event handlers\n const handleBalanceClick = useCallback(\n (event: React.MouseEvent<HTMLDivElement>) => {\n if (customization?.handlers?.onBalanceClick) {\n customization?.handlers?.onBalanceClick(formattedBalance, event);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [customization?.handlers?.onBalanceClick, formattedBalance],\n );\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ connectedButtonStatus, withBalance: Boolean(withBalance) });\n }\n return cn('novacon:flex novacon:items-center novacon:gap-2 novacon:sm:gap-3', className);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, connectedButtonStatus, withBalance, className]);\n\n // Merge container props\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'status',\n 'aria-live': 'polite' as const,\n 'aria-label': ariaLabel || statusDisplay.ariaLabel,\n }),\n [customization, props, ref, containerClasses, ariaLabel, statusDisplay.ariaLabel],\n );\n\n if (!activeWallet) return null;\n\n return (\n <div {...containerProps}>\n {/* Balance Display */}\n {withBalance && (\n <div onClick={handleBalanceClick}>\n <BalanceContainer\n formattedBalance={formattedBalance}\n labels={labels}\n className={customization?.classNames?.balanceContainer?.({ formattedBalance })}\n />\n {showBalanceDivider && <BalanceDivider className={customization?.classNames?.balanceDivider?.()} />}\n </div>\n )}\n\n {/* Main Content */}\n <MainContent\n statusDisplay={statusDisplay}\n connectedButtonStatus={connectedButtonStatus}\n isConnectedModalOpen={isConnectedModalOpen}\n withBalance={Boolean(withBalance)}\n labels={labels}\n className={customization?.classNames?.mainContent?.({ withBalance: Boolean(withBalance) })}\n />\n </div>\n );\n },\n);\n\nConnectedContent.displayName = 'ConnectedContent';\n","/**\n * @file This file contains the `WaitForConnectionContent` component, a customizable connection prompt with comprehensive styling control and animation options.\n */\n\nimport { cn } from '@tuwaio/nova-core';\nimport { type Easing, type HTMLMotionProps, motion, type TargetAndTransition, type Variants } from 'framer-motion';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useMemo } from 'react';\n\nimport { useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\n\n// --- Default Motion Variants ---\nconst DEFAULT_PATH_ANIMATION_VARIANTS: Variants = {\n hidden: { pathLength: 0, opacity: 0 },\n visible: { pathLength: 1, opacity: 1 },\n};\n\nconst DEFAULT_CONTAINER_VARIANTS: Variants = {\n initial: { opacity: 0, y: 10 },\n animate: { opacity: 1, y: 0 },\n exit: { opacity: 0, y: -10 },\n};\n\n// --- Types for Customization ---\ntype CustomIconProps = {\n pathData: string;\n className?: string;\n 'aria-hidden'?: boolean;\n focusable?: boolean;\n};\n\ntype CustomPathProps = {\n pathData: string;\n variants?: Variants;\n className?: string;\n strokeLinecap?: 'butt' | 'round' | 'square';\n strokeLinejoin?: 'miter' | 'bevel' | 'round';\n strokeWidth?: string | number;\n};\n\ntype CustomTextProps = {\n text: string;\n className?: string;\n 'aria-hidden'?: boolean;\n role?: string;\n};\n\ntype CustomContentProps = {\n icon: ReactNode;\n text: ReactNode;\n isConnected: boolean;\n finalAriaLabel: string;\n};\n\n/**\n * Customization options for WaitForConnectionContent component\n */\nexport type WaitForConnectionContentCustomization = {\n /** Override container element props */\n containerProps?: Partial<Omit<HTMLMotionProps<'div'>, 'initial' | 'animate' | 'exit' | 'variants' | 'transition'>>;\n /** Custom components */\n components?: {\n /** Custom icon SVG component */\n Icon?: ComponentType<CustomIconProps>;\n /** Custom path component */\n Path?: ComponentType<CustomPathProps>;\n /** Custom text component */\n Text?: ComponentType<CustomTextProps>;\n /** Custom content component (wraps everything) */\n Content?: ComponentType<CustomContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { isConnected: boolean }) => string;\n /** Function to generate icon classes */\n icon?: (params: { isConnected: boolean }) => string;\n /** Function to generate path classes */\n path?: () => string;\n /** Function to generate text classes */\n text?: (params: { isConnected: boolean }) => string;\n };\n /** Custom animation variants */\n variants?: {\n /** Container motion variants */\n container?: Variants;\n /** Path motion variants */\n path?: Variants;\n };\n /** Custom animation configuration */\n animation?: {\n /** Container animation configuration */\n container?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n /** Path animation configuration */\n path?: {\n /** Animation duration in seconds */\n duration?: number;\n /** Animation easing curve */\n ease?: Easing | Easing[];\n /** Animation delay in seconds */\n delay?: number;\n };\n };\n /** Custom SVG properties */\n svg?: {\n /** Custom viewBox */\n viewBox?: string;\n /** Custom stroke width */\n strokeWidth?: string | number;\n /** Custom stroke linecap */\n strokeLinecap?: 'butt' | 'round' | 'square';\n /** Custom stroke linejoin */\n strokeLinejoin?: 'miter' | 'bevel' | 'round';\n /** Custom wallet icon path */\n pathData?: string;\n };\n /** Configuration options */\n config?: {\n /** Whether to disable animations */\n disableAnimation?: boolean;\n /** Whether to reduce motion for accessibility */\n reduceMotion?: boolean;\n /** Whether to hide the component when connected */\n hideWhenConnected?: boolean;\n /** Custom text to display */\n customText?: string;\n };\n};\n\nexport interface WaitForConnectionContentProps\n extends Omit<\n HTMLMotionProps<'div'>,\n 'children' | 'initial' | 'animate' | 'exit' | 'variants' | 'transition' | 'style'\n > {\n /** Custom CSS classes for the container */\n className?: string;\n /** Custom aria-label for the container */\n 'aria-label'?: string;\n /** Customization options */\n customization?: WaitForConnectionContentCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultIcon = ({\n pathData,\n className,\n 'aria-hidden': ariaHidden = true,\n focusable = false,\n ...props\n}: CustomIconProps & Omit<ComponentPropsWithoutRef<'svg'>, 'style'>) => {\n return (\n <svg\n className={cn('novacon:w-5 novacon:h-5', className)}\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n aria-hidden={ariaHidden}\n focusable={focusable ? 'true' : 'false'}\n {...props}\n >\n <DefaultPath pathData={pathData} />\n </svg>\n );\n};\n\nconst DefaultPath = ({\n pathData,\n variants = DEFAULT_PATH_ANIMATION_VARIANTS,\n className,\n strokeLinecap = 'round',\n strokeLinejoin = 'round',\n strokeWidth = 1.5,\n ...props\n}: CustomPathProps & Omit<ComponentPropsWithoutRef<typeof motion.path>, 'style'>) => {\n return (\n <motion.path\n d={pathData}\n strokeLinecap={strokeLinecap}\n strokeLinejoin={strokeLinejoin}\n strokeWidth={strokeWidth}\n variants={variants}\n initial=\"hidden\"\n animate=\"visible\"\n transition={{\n duration: 0.5,\n ease: 'easeInOut',\n delay: 0.1,\n }}\n className={className}\n {...props}\n />\n );\n};\n\nconst DefaultText = ({\n text,\n className,\n 'aria-hidden': ariaHidden = true,\n role = 'text',\n ...props\n}: CustomTextProps & Omit<ComponentPropsWithoutRef<'span'>, 'style'>) => {\n return (\n <span className={cn('novacon:font-medium', className)} role={role} aria-hidden={ariaHidden} {...props}>\n {text}\n </span>\n );\n};\n\nconst DefaultContent = ({ icon, text }: Pick<CustomContentProps, 'icon' | 'text'>) => {\n return (\n <>\n {icon}\n {text}\n </>\n );\n};\n\n/**\n * A highly customizable connection prompt component with extensive styling options and accessibility features.\n * Displays an animated wallet icon and text prompting users to connect their wallet, with comprehensive customization support.\n *\n * Features:\n * - Animated container and wallet icon with Framer Motion\n * - Comprehensive customization for all visual elements and animations\n * - Full accessibility support with ARIA labels and proper roles\n * - Configurable animation timing and easing\n * - Reduced motion support for accessibility\n * - Custom SVG properties and path styling\n * - Conditional rendering based on connection status\n * - Performance-optimized with memoized calculations\n * - Custom text and icon support\n *\n * @example Basic usage\n * ```tsx\n * <WaitForConnectionContent />\n * ```\n *\n * @example With full customization\n * ```tsx\n * <WaitForConnectionContent\n * customization={{\n * classNames: {\n * container: ({ isConnected }) =>\n * `custom-container ${isConnected ? 'connected' : 'disconnected'}`,\n * text: () => \"custom-text-styling text-blue-500\",\n * },\n * animation: {\n * container: { duration: 0.8, ease: \"easeOut\" },\n * path: { duration: 1.2, delay: 0.3 },\n * },\n * variants: {\n * container: {\n * initial: { scale: 0, rotate: -180 },\n * animate: { scale: 1, rotate: 0 },\n * },\n * },\n * svg: {\n * strokeWidth: 2,\n * strokeLinecap: \"square\",\n * pathData: \"M12 2L2 7v10l10 5 10-5V7L12 2z\", // Custom wallet icon\n * },\n * config: {\n * customText: \"Please Connect Your Wallet\",\n * hideWhenConnected: true,\n * reduceMotion: false,\n * },\n * }}\n * />\n * ```\n */\nexport const WaitForConnectionContent = forwardRef<HTMLDivElement, WaitForConnectionContentProps>(\n ({ className, 'aria-label': ariaLabel, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n const { activeWallet } = useNovaConnect();\n\n // Memoize connection status check for better performance\n const isConnected = useMemo(() => Boolean(activeWallet?.isConnected), [activeWallet?.isConnected]);\n\n // Extract custom components\n const {\n Icon = DefaultIcon,\n Path = DefaultPath,\n Text = DefaultText,\n Content = DefaultContent,\n } = customization?.components ?? {};\n\n // Configuration options\n const {\n hideWhenConnected = true,\n customText,\n disableAnimation = false,\n reduceMotion = false,\n } = customization?.config ?? {};\n\n // Memoize the text to display\n const displayText = useMemo(() => {\n return customText || labels.connectWallet;\n }, [customText, labels.connectWallet]);\n\n // Memoize the default aria-label\n const defaultAriaLabel = useMemo(() => {\n return labels.connectWallet;\n }, [labels.connectWallet]);\n\n // Memoize the final aria-label\n const finalAriaLabel = useMemo(() => {\n return ariaLabel || defaultAriaLabel;\n }, [ariaLabel, defaultAriaLabel]);\n\n // Default wallet icon path\n const defaultPathData =\n 'M21 12a2.25 2.25 0 0 0-2.25-2.25H15a3 3 0 1 1-6 0H5.25A2.25 2.25 0 0 0 3 12m18 0v6a2.25 2.25 0 0 1-2.25 2.25H5.25A2.25 2.25 0 0 1 3 18v-6m18 0V9M3 12V9m18 0a2.25 2.25 0 0 0-2.25-2.25H5.25A2.25 2.25 0 0 0 3 9m18 0V6a2.25 2.25 0 0 0-2.25-2.25H5.25A2.25 2.25 0 0 0 3 6v3';\n\n // Get path data\n const pathData = useMemo(() => {\n return customization?.svg?.pathData || defaultPathData;\n }, [customization?.svg?.pathData, defaultPathData]);\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ isConnected });\n }\n return cn('novacon:flex novacon:items-center novacon:gap-2', className);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, isConnected, className]);\n\n // Generate icon classes\n const iconClasses = useMemo(() => {\n if (customization?.classNames?.icon) {\n return customization.classNames.icon({ isConnected });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.icon, isConnected]);\n\n // Generate text classes\n const textClasses = useMemo(() => {\n if (customization?.classNames?.text) {\n return customization.classNames.text({ isConnected });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.text, isConnected]);\n\n // Generate path classes\n const pathClasses = useMemo(() => {\n if (customization?.classNames?.path) {\n return customization.classNames.path();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.path]);\n\n // Resolve animation variants\n const containerVariants = useMemo(() => {\n if (customization?.variants?.container) {\n return customization.variants.container;\n }\n\n return DEFAULT_CONTAINER_VARIANTS;\n }, [customization?.variants?.container]);\n\n const pathVariants = useMemo(() => {\n if (customization?.variants?.path) {\n return customization.variants.path;\n }\n\n return DEFAULT_PATH_ANIMATION_VARIANTS;\n }, [customization?.variants?.path]);\n\n // Resolve animation configuration\n const containerAnimation = useMemo(() => {\n const config = customization?.animation?.container;\n\n return {\n duration: config?.duration ?? 0.3,\n ease: config?.ease ?? [0.4, 0, 0.2, 1],\n delay: config?.delay ?? 0,\n };\n }, [customization?.animation?.container]);\n\n const pathAnimation = useMemo(() => {\n const config = customization?.animation?.path;\n\n return {\n duration: config?.duration ?? 0.5,\n ease: config?.ease ?? 'easeInOut',\n delay: config?.delay ?? 0.1,\n };\n }, [customization?.animation?.path]);\n\n // Create icon element\n const iconElement = useMemo(() => {\n if (customization?.components?.Icon) {\n return <Icon pathData={pathData} className={iconClasses} aria-hidden={true} focusable={false} />;\n }\n\n return (\n <svg\n className={cn('novacon:w-5 novacon:h-5', iconClasses)}\n fill=\"none\"\n viewBox={customization?.svg?.viewBox ?? '0 0 24 24'}\n stroke=\"currentColor\"\n aria-hidden=\"true\"\n focusable=\"false\"\n >\n <Path\n pathData={pathData}\n variants={disableAnimation || reduceMotion ? {} : pathVariants}\n className={pathClasses}\n strokeLinecap={customization?.svg?.strokeLinecap ?? 'round'}\n strokeLinejoin={customization?.svg?.strokeLinejoin ?? 'round'}\n strokeWidth={customization?.svg?.strokeWidth ?? 1.5}\n {...(!disableAnimation && !reduceMotion\n ? {\n initial: 'hidden',\n animate: 'visible',\n transition: pathAnimation,\n }\n : {})}\n />\n </svg>\n );\n }, [\n customization?.svg,\n customization?.components?.Icon,\n Icon,\n Path,\n pathData,\n iconClasses,\n pathClasses,\n disableAnimation,\n reduceMotion,\n pathVariants,\n pathAnimation,\n ]);\n\n // Create text element\n const textElement = useMemo(() => {\n return <Text text={displayText} className={textClasses} aria-hidden={true} role=\"text\" />;\n }, [Text, displayText, textClasses]);\n\n // Base props without animation properties\n const baseProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'img' as const,\n 'aria-label': finalAriaLabel,\n }),\n [customization, props, ref, containerClasses, finalAriaLabel],\n );\n\n // Don't render if wallet is already connected and hideWhenConnected is true\n if (isConnected && hideWhenConnected) return null;\n\n // Conditional rendering with proper animation types\n if (disableAnimation || reduceMotion) {\n return (\n <motion.div {...baseProps}>\n {customization?.components?.Content ? (\n <Content icon={iconElement} text={textElement} isConnected={isConnected} finalAriaLabel={finalAriaLabel} />\n ) : (\n <DefaultContent icon={iconElement} text={textElement} />\n )}\n </motion.div>\n );\n }\n\n return (\n <motion.div\n {...baseProps}\n initial={containerVariants.initial as TargetAndTransition}\n animate={containerVariants.animate as TargetAndTransition}\n exit={containerVariants.exit as TargetAndTransition}\n transition={containerAnimation}\n >\n {customization?.components?.Content ? (\n <Content icon={iconElement} text={textElement} isConnected={isConnected} finalAriaLabel={finalAriaLabel} />\n ) : (\n <DefaultContent icon={iconElement} text={textElement} />\n )}\n </motion.div>\n );\n },\n);\n\nWaitForConnectionContent.displayName = 'WaitForConnectionContent';\n","import { cn } from '@tuwaio/nova-core';\nimport { Transaction, TransactionPool, TxAdapter } from '@tuwaio/pulsar-core';\nimport { motion } from 'framer-motion';\nimport React, { ComponentPropsWithoutRef, ComponentType, forwardRef, memo, useCallback, useMemo } from 'react';\n\nimport { NovaConnectProviderProps, useNovaConnect } from '../../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../../hooks/useNovaConnectLabels';\nimport { InitialChains } from '../../types';\nimport { ChainSelector, ChainSelectorCustomization } from '../Chains/ChainSelector';\nimport { ConnectedModal, ConnectedModalCustomization } from '../ConnectedModal/ConnectedModal';\nimport { ConnectModal, ConnectModalCustomization } from '../ConnectModal/ConnectModal';\nimport { ConnectedContent, ConnectedContentCustomization } from './ConnectedContent';\nimport { WaitForConnectionContent, WaitForConnectionContentCustomization } from './WaitForConnectionContent';\n\n/**\n * Connect button data for customization context\n */\nexport interface ConnectButtonData {\n /** Whether wallet is connected */\n isConnected: boolean;\n /** Whether balance should be shown */\n withBalance?: boolean;\n /** Whether chain selector should be shown */\n withChain?: boolean;\n /** Whether impersonated wallets are enabled */\n withImpersonated?: boolean;\n /** Current labels from i18n */\n labels: ReturnType<typeof useNovaConnectLabels>;\n /** Active wallet information */\n activeWallet: ReturnType<typeof useNovaConnect>['activeWallet'];\n}\n\n// --- Component Props Types ---\ntype NavigationProps = {\n className?: string;\n children: React.ReactNode;\n 'aria-label'?: string;\n role?: string;\n buttonData: ConnectButtonData;\n} & React.RefAttributes<HTMLElement>;\n\ntype ContainerProps = {\n className?: string;\n children: React.ReactNode;\n buttonData: ConnectButtonData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ButtonContainerProps = {\n className?: string;\n children: React.ReactNode;\n buttonData: ConnectButtonData;\n} & React.RefAttributes<HTMLDivElement>;\n\ntype ButtonProps = {\n className?: string;\n children: React.ReactNode;\n onClick: () => void;\n onKeyDown: (event: React.KeyboardEvent) => void;\n 'aria-label'?: string;\n 'aria-pressed'?: boolean;\n disabled?: boolean;\n buttonData: ConnectButtonData;\n} & React.RefAttributes<HTMLButtonElement>;\n\n/**\n * Customization options for ConnectButton component\n */\nexport type ConnectButtonCustomization = {\n /** Custom components */\n components?: {\n /** Custom navigation wrapper */\n Navigation?: ComponentType<NavigationProps>;\n /** Custom container div */\n Container?: ComponentType<ContainerProps>;\n /** Custom button container with motion */\n ButtonContainer?: ComponentType<ButtonContainerProps>;\n /** Custom button element */\n Button?: ComponentType<ButtonProps>;\n /** Custom motion div */\n MotionDiv?: ComponentType<ComponentPropsWithoutRef<typeof motion.div>>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate navigation classes */\n navigation?: (params: { buttonData: ConnectButtonData }) => string;\n /** Function to generate container classes */\n container?: (params: { buttonData: ConnectButtonData }) => string;\n /** Function to generate button container classes */\n buttonContainer?: (params: { buttonData: ConnectButtonData }) => string;\n /** Function to generate button classes */\n button?: (params: { buttonData: ConnectButtonData }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom button click handler */\n onButtonClick?: (buttonData: ConnectButtonData, originalHandler: () => void) => void;\n /** Custom key down handler */\n onKeyDown?: (\n event: React.KeyboardEvent,\n buttonData: ConnectButtonData,\n originalHandler: (event: React.KeyboardEvent) => void,\n ) => void;\n };\n /** Configuration options */\n config?: {\n /** Custom ARIA labels */\n ariaLabels?: {\n navigation?: (buttonData: ConnectButtonData) => string;\n button?: (buttonData: ConnectButtonData) => string;\n };\n /** Animation configuration */\n animation?: {\n /** Layout transition duration */\n layoutDuration?: number;\n /** Layout transition easing */\n layoutEase?: [number, number, number, number];\n /** Disable animations */\n disabled?: boolean;\n };\n };\n /** Child component customizations */\n childComponents?: {\n /** ChainSelector customization */\n chainSelector?: ChainSelectorCustomization;\n /** ConnectedContent customization */\n connectedContent?: ConnectedContentCustomization;\n /** WaitForConnectionContent customization */\n waitForConnectionContent?: WaitForConnectionContentCustomization;\n /** ConnectModal customization */\n connectModal?: ConnectModalCustomization;\n /** ConnectedModal customization */\n connectedModal?: ConnectedModalCustomization;\n };\n};\n\n// --- Default Sub-Components ---\nconst DefaultNavigation = forwardRef<HTMLElement, NavigationProps>(\n ({ className, children, buttonData, ...props }, ref) => (\n <nav ref={ref} role=\"navigation\" aria-label={buttonData.labels.walletControls} className={className} {...props}>\n {children}\n </nav>\n ),\n);\nDefaultNavigation.displayName = 'DefaultNavigation';\n\nconst DefaultContainer = forwardRef<HTMLDivElement, ContainerProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ className, children, buttonData, ...props }, ref) => (\n <div\n ref={ref}\n className={cn('novacon:flex novacon:items-center novacon:gap-2 novacon:sm:gap-3', className)}\n {...props}\n >\n {children}\n </div>\n ),\n);\nDefaultContainer.displayName = 'DefaultContainer';\n\nconst DefaultButtonContainer = forwardRef<HTMLDivElement, ButtonContainerProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ className, children, buttonData, ...props }, ref) => (\n <div ref={ref} className={cn('novacon:relative', className)} {...props}>\n {children}\n </div>\n ),\n);\nDefaultButtonContainer.displayName = 'DefaultButtonContainer';\n\nconst DefaultButton = forwardRef<HTMLButtonElement, ButtonProps>(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ({ className, children, onClick, onKeyDown, buttonData, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type=\"button\"\n onClick={onClick}\n onKeyDown={onKeyDown}\n disabled={disabled}\n className={className}\n role=\"button\"\n tabIndex={0}\n {...props}\n >\n {children}\n </button>\n ),\n);\nDefaultButton.displayName = 'DefaultButton';\n\n/**\n * Base props for ConnectButton component\n */\nexport type ConnectButtonProps = InitialChains &\n Pick<NovaConnectProviderProps, 'store'> & {\n /** CSS classes to apply to the button */\n className?: string;\n /** Transaction pool for pending transactions display */\n transactionPool?: TransactionPool<Transaction>;\n /** Pulsar adapter(s) for transaction handling */\n pulsarAdapter?: TxAdapter<Transaction> | TxAdapter<Transaction>[];\n /** Show wallet balance in button */\n withBalance?: boolean;\n /** Show chain selector when connected */\n withChain?: boolean;\n /** Enable impersonated wallet functionality */\n withImpersonated?: boolean;\n /** Customization options */\n customization?: ConnectButtonCustomization;\n };\n\n/**\n * ConnectButton component - Main wallet connection button with full customization\n *\n * This component provides a comprehensive wallet connection interface with:\n * - Connect/disconnect wallet functionality\n * - Balance display when connected\n * - Chain selector for multi-network support\n * - Transaction pool integration\n * - Impersonated wallet support\n * - Full accessibility features\n * - Comprehensive customization system\n *\n * Features:\n * - Responsive design with smooth animations\n * - Keyboard navigation support\n * - Screen reader compatibility\n * - Proper ARIA labels and roles\n * - Loading states and error handling\n * - Memoized performance optimizations\n *\n * Accessibility:\n * - Semantic HTML structure with proper roles\n * - ARIA labels for screen readers\n * - Keyboard navigation with Enter and Space\n * - Focus management and visual indicators\n * - High contrast compatible styling\n *\n * @param appChains - Configuration for supported blockchain networks\n * @param solanaRPCUrls - RPC URLs configuration for Solana network\n * @param store - Wallet store instance\n * @param className - Additional CSS classes for the button\n * @param transactionPool - Transaction pool for pending transactions\n * @param pulsarAdapter - Pulsar adapter(s) for transaction handling\n * @param withBalance - Whether to show wallet balance\n * @param withChain - Whether to show chain selector\n * @param withImpersonated - Whether to enable impersonated wallets\n * @param customization - Customization options\n * @returns JSX element representing the connection button\n *\n * @example\n * ```tsx\n * <ConnectButton\n * appChains={{\n * [OrbitAdapter.EVM]: [1, 137, 56],\n * [OrbitAdapter.SOLANA]: ['mainnet-beta', 'devnet']\n * }}\n * solanaRPCUrls={{\n * 'mainnet-beta': 'https://api.mainnet-beta.solana.com'\n * }}\n * store={walletStore}\n * withBalance\n * withChain\n * withImpersonated\n * customization={{\n * classNames: {\n * button: ({ buttonData }) =>\n * buttonData.isConnected ? 'custom-connected-style' : 'custom-disconnected-style'\n * }\n * }}\n * />\n * ```\n *\n * @public\n */\nexport const ConnectButton = memo<ConnectButtonProps>(\n ({\n solanaRPCUrls,\n appChains,\n transactionPool,\n pulsarAdapter,\n withImpersonated,\n withBalance,\n withChain,\n store,\n className,\n customization = {},\n }) => {\n const labels = useNovaConnectLabels();\n const { setIsConnectedModalOpen, setIsConnectModalOpen, activeWallet } = useNovaConnect();\n\n const isConnected = useMemo(() => Boolean(activeWallet?.isConnected), [activeWallet?.isConnected]);\n\n // Memoize button data for customization context\n const buttonData = useMemo<ConnectButtonData>(\n () => ({\n isConnected,\n withBalance,\n withChain,\n withImpersonated,\n labels,\n activeWallet,\n }),\n [isConnected, withBalance, withChain, withImpersonated, labels, activeWallet],\n );\n\n // Extract customization options\n const { components = {}, classNames = {}, handlers = {}, config = {}, childComponents = {} } = customization;\n\n // Component selections with defaults\n const Navigation = components.Navigation || DefaultNavigation;\n const Container = components.Container || DefaultContainer;\n const ButtonContainer = components.ButtonContainer || DefaultButtonContainer;\n const Button = components.Button || DefaultButton;\n const CustomMotionDiv = components.MotionDiv || motion.div;\n\n /**\n * Handle button click with custom handler support\n */\n const handleConnectButtonClick = useCallback(() => {\n const originalHandler = () => {\n if (isConnected) {\n setIsConnectedModalOpen(true);\n } else {\n setIsConnectModalOpen(true);\n }\n };\n\n if (handlers.onButtonClick) {\n handlers.onButtonClick(buttonData, originalHandler);\n } else {\n originalHandler();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isConnected, buttonData]);\n\n /**\n * Handle key down events with custom handler support\n */\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent) => {\n const originalHandler = (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n handleConnectButtonClick();\n }\n };\n\n if (handlers.onKeyDown) {\n handlers.onKeyDown(event, buttonData, originalHandler);\n } else {\n originalHandler(event);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [handleConnectButtonClick, buttonData],\n );\n\n // Memoize button aria-label for better performance\n const buttonAriaLabel = useMemo(() => {\n if (config.ariaLabels?.button) {\n return config.ariaLabels.button(buttonData);\n }\n\n if (isConnected) {\n return `${labels.walletConnected}. ${labels.openWalletModal}`;\n }\n return `${labels.walletNotConnected}. ${labels.connectWallet}`;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isConnected, labels, config.ariaLabels?.button, buttonData]);\n\n // Memoize navigation aria-label\n const navigationAriaLabel = useMemo(() => {\n if (config.ariaLabels?.navigation) {\n return config.ariaLabels.navigation(buttonData);\n }\n return labels.walletControls;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [labels, config.ariaLabels?.navigation, buttonData]);\n\n // Memoize button class names for better performance\n const buttonClasses = useMemo(() => {\n const customClasses = classNames.button?.({ buttonData });\n if (customClasses) return customClasses;\n\n return cn(\n 'novacon:cursor-pointer novacon:inline-flex novacon:items-center novacon:justify-center novacon:gap-2 novacon:px-3 novacon:min-h-[42px] novacon:py-1',\n 'novacon:rounded-xl novacon:font-medium novacon:text-sm novacon:transition-all novacon:duration-200',\n 'novacon:hover:scale-[1.02] novacon:active:scale-[0.98]',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-offset-2',\n 'novacon:focus:ring-offset-[var(--tuwa-bg-primary)]',\n 'novacon:disabled:opacity-50 novacon:disabled:cursor-not-allowed novacon:disabled:hover:scale-100',\n isConnected\n ? [\n 'novacon:bg-[var(--tuwa-bg-secondary)]',\n 'novacon:text-[var(--tuwa-text-primary)]',\n 'novacon:hover:bg-[var(--tuwa-bg-muted)]',\n 'novacon:focus:ring-[var(--tuwa-text-secondary)]',\n 'novacon:border novacon:border-[var(--tuwa-border-primary)]',\n ]\n : [\n 'novacon:bg-gradient-to-r',\n 'novacon:from-[var(--tuwa-button-gradient-from)]',\n 'novacon:to-[var(--tuwa-button-gradient-to)]',\n 'novacon:text-[var(--tuwa-text-on-accent)]',\n 'novacon:hover:from-[var(--tuwa-button-gradient-from-hover)]',\n 'novacon:hover:to-[var(--tuwa-button-gradient-to-hover)]',\n 'novacon:focus:ring-[var(--tuwa-text-accent)]',\n ],\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isConnected, className, classNames.button, buttonData]);\n\n // Memoize animation configuration\n const animationConfig = useMemo(() => {\n if (config.animation?.disabled) {\n return {};\n }\n\n return {\n layout: true,\n transition: {\n layout: {\n duration: config.animation?.layoutDuration ?? 0.2,\n ease: config.animation?.layoutEase ?? [0.1, 0.1, 0.2, 1],\n },\n },\n };\n }, [config.animation?.disabled, config.animation?.layoutDuration, config.animation?.layoutEase]);\n\n return (\n <Navigation\n className={classNames.navigation?.({ buttonData })}\n aria-label={navigationAriaLabel}\n buttonData={buttonData}\n >\n <Container className={classNames.container?.({ buttonData })} buttonData={buttonData}>\n {/* Chain Selector - only show when connected and withChain is enabled */}\n {withChain && isConnected && (\n <ChainSelector\n store={store}\n appChains={appChains}\n solanaRPCUrls={solanaRPCUrls}\n customization={childComponents.chainSelector}\n />\n )}\n\n {/* Main Connect Button */}\n <CustomMotionDiv {...animationConfig}>\n <ButtonContainer className={classNames.buttonContainer?.({ buttonData })} buttonData={buttonData}>\n <Button\n onClick={handleConnectButtonClick}\n onKeyDown={handleKeyDown}\n className={buttonClasses}\n aria-label={buttonAriaLabel}\n aria-pressed={isConnected}\n buttonData={buttonData}\n >\n {isConnected ? (\n <ConnectedContent\n store={store}\n withBalance={withBalance}\n transactionPool={transactionPool}\n customization={childComponents.connectedContent}\n />\n ) : (\n <WaitForConnectionContent customization={childComponents.waitForConnectionContent} />\n )}\n </Button>\n </ButtonContainer>\n </CustomMotionDiv>\n\n {/* Hidden modals - these will be shown based on application state */}\n <ConnectModal\n store={store}\n withImpersonated={withImpersonated}\n solanaRPCUrls={solanaRPCUrls}\n appChains={appChains}\n customization={childComponents.connectModal}\n />\n <ConnectedModal\n solanaRPCUrls={solanaRPCUrls}\n appChains={appChains}\n transactionPool={transactionPool}\n pulsarAdapter={pulsarAdapter}\n store={store}\n customization={childComponents.connectedModal}\n />\n </Container>\n </Navigation>\n );\n },\n);\n\nConnectButton.displayName = 'ConnectButton';\n","import React, { ComponentPropsWithoutRef, ComponentType, memo, useMemo } from 'react';\n\nimport { NovaConnectProviderProps } from '../../hooks/useNovaConnect';\nimport { NovaConnectProvider, NovaConnectProviderCustomization } from '../../providers';\nimport {\n ConnectButton as InternalConnectButton,\n ConnectButtonCustomization,\n ConnectButtonProps as InternalConnectButtonProps,\n} from './ConnectButton';\n\n// Re-export types for external use\nexport type { NovaConnectProviderCustomization } from '../../providers';\nexport type { ConnectButtonCustomization, ConnectButtonData } from './ConnectButton';\n\n/**\n * Root customization data for the complete NovaConnectButton with provider\n */\nexport interface NovaConnectButtonWithProviderData {\n /** Store instance */\n store: NovaConnectProviderProps['store'];\n /** Current labels configuration */\n labels?: NovaConnectProviderProps['labels'];\n /** Whether wallet is connected */\n isConnected: boolean;\n /** Current provider state */\n providerState: {\n /** Modal states */\n isConnectModalOpen: boolean;\n isConnectedModalOpen: boolean;\n isChainsListOpen: boolean;\n isChainsListOpenMobile: boolean;\n /** Connection states */\n connectedButtonStatus: string;\n isConnected: boolean;\n /** Active states */\n selectedAdapter: unknown;\n activeConnector: string | undefined;\n activeWallet: unknown;\n };\n}\n\n// --- Component Props Types ---\ntype RootContainerProps = {\n className?: string;\n children: React.ReactNode;\n providerData: NovaConnectButtonWithProviderData;\n} & React.RefAttributes<HTMLDivElement>;\n\n/**\n * Complete customization system for NovaConnectButton with Provider\n */\nexport type NovaConnectButtonWithProviderCustomization = {\n /** Custom components for root level */\n components?: {\n /** Custom root container wrapper */\n RootContainer?: ComponentType<RootContainerProps>;\n /** Custom NovaConnectProvider component */\n Provider?: ComponentType<ComponentPropsWithoutRef<typeof NovaConnectProvider>>;\n /** Custom ConnectButton component */\n ConnectButton?: ComponentType<ComponentPropsWithoutRef<typeof InternalConnectButton>>;\n };\n /** Custom class name generators for root */\n classNames?: {\n /** Function to generate root container classes */\n rootContainer?: (params: { providerData: NovaConnectButtonWithProviderData }) => string;\n };\n /** Provider customization options - full NovaConnectProviderCustomization support */\n provider?: NovaConnectProviderCustomization;\n /** ConnectButton customization options */\n connectButton?: ConnectButtonCustomization;\n /** Configuration options */\n config?: {\n /** Whether to wrap in root container */\n useRootContainer?: boolean;\n /** Custom provider props override */\n providerPropsOverride?: Partial<NovaConnectProviderProps>;\n /** Custom connect button props override */\n connectButtonPropsOverride?: Partial<InternalConnectButtonProps>;\n };\n};\n\n// --- Default Sub-Components ---\nconst DefaultRootContainer = ({ className, children, ...props }: RootContainerProps) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { providerData: _providerData, ...restProps } = props;\n return (\n <div className={className} {...restProps}>\n {children}\n </div>\n );\n};\n\n/**\n * Props for the complete NovaConnectButton component with provider integration\n */\nexport type NovaConnectButtonProps = Omit<InternalConnectButtonProps, 'store'> &\n Pick<NovaConnectProviderProps, 'store' | 'labels'> & {\n /** Complete customization options */\n customization?: NovaConnectButtonWithProviderCustomization;\n };\n\n/**\n * NovaConnectButton - Complete wallet connection solution with provider integration\n *\n * This is the main entry point component that combines NovaConnectProvider with ConnectButton\n * to provide a complete wallet connection solution. It includes:\n *\n * Features:\n * - Complete provider context integration with full customization support\n * - Full wallet connection functionality\n * - Chain selector with multi-network support\n * - Transaction pool integration and monitoring\n * - Balance display and wallet avatar\n * - Impersonated wallet support\n * - Comprehensive accessibility features\n * - Complete customization system for all levels\n * - Memoized performance optimizations\n *\n * Provider Features:\n * - Wallet state management with custom handlers\n * - Modal state coordination\n * - Chain selection state\n * - Transaction status tracking\n * - Connection error handling with custom ErrorsProvider\n * - Impersonation support\n * - Custom labels merging and transformation\n * - Custom initialization and lifecycle hooks\n * - Custom context value transformation\n * - Custom provider tree rendering\n *\n * Button Features:\n * - Connect/disconnect wallet functionality\n * - Balance display when connected\n * - Chain selector for multi-network support\n * - Transaction pool integration\n * - Loading states and animations\n * - Keyboard navigation support\n * - Screen reader compatibility\n *\n * Customization System:\n * - Root container customization\n * - Full NovaConnectProvider customization (components, labels, errors, initialization, contextValue, rendering)\n * - ConnectButton customization (styling, components, handlers)\n * - All child component customizations (modals, selectors, content)\n * - Event handler overrides at every level\n * - Class name and style generators\n * - Configuration options\n *\n * Accessibility:\n * - Semantic HTML structure with proper roles\n * - ARIA labels and descriptions throughout\n * - Keyboard navigation with Enter and Space\n * - Focus management and visual indicators\n * - Screen reader announcements\n * - High contrast compatible styling\n *\n * @param appChains - Configuration for supported EVM blockchain networks (viem chain objects)\n * @param solanaRPCUrls - RPC URLs configuration for Solana network\n * @param store - Wallet store instance for state management\n * @param labels - Internationalization labels for all text content\n * @param className - Additional CSS classes for the button\n * @param transactionPool - Transaction pool for pending transactions display\n * @param pulsarAdapter - Pulsar adapter(s) for transaction handling\n * @param withBalance - Whether to show wallet balance in button\n * @param withChain - Whether to show chain selector when connected\n * @param withImpersonated - Whether to enable impersonated wallet functionality\n * @param customization - Complete customization options for all components\n * @returns JSX element representing the complete wallet connection interface\n *\n * @example\n * ```tsx\n * // Basic usage\n * <NovaConnectButton\n * store={walletStore}\n * appChains={[mainnet, polygon, arbitrum]} // EVM viem chain objects\n * solanaRPCUrls={{\n * 'mainnet': 'https://api.mainnet-beta.solana.com'\n * }}\n * withBalance\n * withChain\n * withImpersonated\n * />\n * ```\n *\n * @example\n * ```tsx\n * // With comprehensive customization\n * <NovaConnectButton\n * store={walletStore}\n * appChains={[mainnet, polygon, arbitrum]}\n * solanaRPCUrls={solanaRPCConfig}\n * labels={customLabels}\n * withBalance\n * withChain\n * customization={{\n * // Root level customization\n * classNames: {\n * rootContainer: ({ providerData }) =>\n * `custom-root ${providerData.isConnected ? 'connected' : 'disconnected'}`\n * },\n * // Full provider customization\n * provider: {\n * // Custom components\n * components: {\n * LabelsProvider: CustomLabelsProvider,\n * ErrorsProvider: CustomErrorsProvider\n * },\n * // Labels customization\n * labels: {\n * merge: (defaultLabels, userLabels) => ({ ...defaultLabels, ...userLabels }),\n * transform: (mergedLabels, context) => ({\n * ...mergedLabels,\n * connectWallet: context.isConnected ? 'Reconnect' : 'Connect Wallet'\n * })\n * },\n * // Error handling customization\n * errors: {\n * position: 'bottom-right',\n * autoClose: 5000,\n * components: {\n * ToastError: CustomToastError\n * }\n * },\n * // Initialization hooks\n * initialization: {\n * onConnectionStateChange: (isConnected, wallet, context) => {\n * console.log('Connection changed:', isConnected, wallet);\n * },\n * onStoreSubscribed: (context) => {\n * console.log('Store subscribed:', context);\n * }\n * },\n * // Context value transformation\n * contextValue: {\n * transform: (defaultValue, context) => ({\n * ...defaultValue,\n * customProperty: 'custom value'\n * })\n * },\n * // Custom provider tree\n * rendering: {\n * providerTree: (defaultTree, components, context) => (\n * <div className=\"custom-provider-wrapper\">\n * {components.ErrorsProvider}\n * {components.LabelsProvider}\n * </div>\n * )\n * }\n * },\n * // ConnectButton customization\n * connectButton: {\n * classNames: {\n * button: ({ buttonData }) =>\n * buttonData.isConnected ? 'btn-connected' : 'btn-connect'\n * },\n * childComponents: {\n * chainSelector: {\n * classNames: {\n * trigger: () => 'custom-chain-selector'\n * }\n * },\n * connectedContent: {\n * childCustomizations: {\n * walletAvatar: {\n * size: 'large',\n * showBorder: true\n * }\n * }\n * }\n * }\n * }\n * }}\n * />\n * ```\n *\n * @public\n */\nexport const NovaConnectButton = memo<NovaConnectButtonProps>(\n ({ store, labels, customization = {}, ...connectButtonProps }) => {\n // Extract customization options\n const {\n components = {},\n classNames = {},\n provider: providerCustomization,\n connectButton: connectButtonCustomization,\n config = {},\n } = customization;\n\n // Component selections with defaults\n const RootContainer = components.RootContainer || DefaultRootContainer;\n const CustomProvider = components.Provider || NovaConnectProvider;\n const CustomConnectButton = components.ConnectButton || InternalConnectButton;\n\n // Memoize provider data for customization context\n const providerData = useMemo<NovaConnectButtonWithProviderData>(\n () => ({\n store,\n labels,\n isConnected: false, // This will be updated by provider context\n providerState: {\n isConnectModalOpen: false,\n isConnectedModalOpen: false,\n isChainsListOpen: false,\n isChainsListOpenMobile: false,\n connectedButtonStatus: 'idle',\n isConnected: false,\n selectedAdapter: undefined,\n activeConnector: undefined,\n activeWallet: undefined,\n },\n }),\n [store, labels],\n );\n\n // Memoize provider props with full customization support\n const providerProps = useMemo(\n () => ({\n store,\n labels,\n customization: providerCustomization, // Full NovaConnectProviderCustomization\n ...config.providerPropsOverride,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [labels, providerCustomization, config.providerPropsOverride],\n );\n\n // Memoize connect button props\n const buttonProps = useMemo(\n () => ({\n store,\n customization: connectButtonCustomization,\n ...connectButtonProps,\n ...config.connectButtonPropsOverride,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [connectButtonCustomization, connectButtonProps, config.connectButtonPropsOverride],\n );\n\n // Render with or without root container based on configuration\n const content = (\n <CustomProvider {...providerProps}>\n <CustomConnectButton {...buttonProps} />\n </CustomProvider>\n );\n\n // Only wrap in root container if explicitly requested\n if (config.useRootContainer) {\n return (\n <RootContainer className={classNames.rootContainer?.({ providerData })} providerData={providerData}>\n {content}\n </RootContainer>\n );\n }\n\n return content;\n },\n);\n\nNovaConnectButton.displayName = 'NovaConnectButton';\n","/**\n * @file This file contains the `ToastError` component, a customizable error toast with full styling control.\n */\n\nimport { DocumentDuplicateIcon } from '@heroicons/react/24/solid';\nimport { cn, useCopyToClipboard } from '@tuwaio/nova-core';\nimport { ComponentPropsWithoutRef, ComponentType, forwardRef, ReactNode, useCallback, useMemo, useState } from 'react';\n\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\n\n// --- Types for Customization ---\ntype CustomIconProps = {\n isCopied: boolean;\n className?: string;\n 'aria-hidden'?: boolean;\n};\n\ntype CustomTitleProps = {\n title: string;\n titleId: string;\n className?: string;\n};\n\ntype CustomDescriptionProps = {\n rawError: string;\n descriptionId: string;\n className?: string;\n};\n\ntype CustomButtonContentProps = {\n icon: ReactNode;\n isCopied: boolean;\n copyLabel: string;\n copiedLabel: string;\n};\n\n/**\n * Customization options for ToastError component\n */\nexport type ToastErrorCustomization = {\n /** Override container element props */\n containerProps?: Partial<Omit<ComponentPropsWithoutRef<'div'>, 'style'>>;\n /** Override button element props */\n buttonProps?: Partial<Omit<ComponentPropsWithoutRef<'button'>, 'style'>>;\n /** Custom components */\n components?: {\n /** Custom icon component */\n Icon?: ComponentType<CustomIconProps>;\n /** Custom title component */\n Title?: ComponentType<CustomTitleProps>;\n /** Custom description component */\n Description?: ComponentType<CustomDescriptionProps>;\n /** Custom button content component */\n ButtonContent?: ComponentType<CustomButtonContentProps>;\n };\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { hasTitle: boolean; hasError: boolean }) => string;\n /** Function to generate title classes */\n title?: (params: { title: string }) => string;\n /** Function to generate description classes */\n description?: (params: { rawError: string }) => string;\n /** Function to generate button classes */\n button?: (params: { isCopied: boolean; disabled: boolean }) => string;\n /** Function to generate icon classes */\n icon?: (params: { isCopied: boolean }) => string;\n };\n /** Custom event handlers */\n handlers?: {\n /** Custom click handler wrapper */\n onClick?: (\n originalHandler: (event: React.MouseEvent<HTMLButtonElement>) => void,\n event: React.MouseEvent<HTMLButtonElement>,\n ) => void;\n /** Custom keydown handler wrapper */\n onKeyDown?: (\n originalHandler: (event: React.KeyboardEvent<HTMLButtonElement>) => void,\n event: React.KeyboardEvent<HTMLButtonElement>,\n ) => void;\n };\n};\n\nexport interface ToastErrorProps extends Omit<ComponentPropsWithoutRef<'div'>, 'role' | 'aria-live' | 'style'> {\n /** Error title to display */\n title: string;\n /** Raw error message to display and copy */\n rawError: string;\n /** Custom CSS classes for the container */\n className?: string;\n /** Custom ARIA label for the error container */\n 'aria-label'?: string;\n /** Callback fired when copy operation completes */\n onCopyComplete?: (success: boolean) => void;\n /** Customization options */\n customization?: ToastErrorCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultIcon = ({ isCopied, className, ...props }: CustomIconProps) => {\n return (\n <DocumentDuplicateIcon\n className={cn(\n 'novacon:w-4 novacon:h-4 novacon:transition-colors',\n isCopied && 'novacon:text-[var(--tuwa-success-text)]',\n className,\n )}\n {...props}\n />\n );\n};\n\nconst DefaultTitle = ({ title, titleId, className }: CustomTitleProps) => {\n return (\n <p\n id={titleId}\n className={cn(\n 'novacon:text-sm novacon:font-semibold novacon:truncate novacon:text-[var(--tuwa-error-text)]',\n className,\n )}\n role=\"heading\"\n aria-level={3}\n title={title} // Show full title on hover if truncated\n >\n {title}\n </p>\n );\n};\n\nconst DefaultDescription = ({ rawError, descriptionId, className }: CustomDescriptionProps) => {\n return (\n <p\n id={descriptionId}\n className={cn(\n 'novacon:mt-1 novacon:text-xs novacon:break-words novacon:text-[var(--tuwa-error-text)] novacon:opacity-80',\n className,\n )}\n role=\"text\"\n >\n {rawError}\n </p>\n );\n};\n\nconst DefaultButtonContent = ({ icon, isCopied, copyLabel, copiedLabel }: CustomButtonContentProps) => {\n return (\n <>\n {icon}\n <span className=\"novacon:select-none novacon:transition-colors\" aria-live=\"polite\" role=\"status\">\n {isCopied ? copiedLabel : copyLabel}\n </span>\n </>\n );\n};\n\n// --- Default Event Handlers ---\nconst defaultClickHandler = (\n originalHandler: (event: React.MouseEvent<HTMLButtonElement>) => void,\n event: React.MouseEvent<HTMLButtonElement>,\n) => {\n originalHandler(event);\n};\n\nconst defaultKeyDownHandler = (\n originalHandler: (event: React.KeyboardEvent<HTMLButtonElement>) => void,\n event: React.KeyboardEvent<HTMLButtonElement>,\n) => {\n originalHandler(event);\n};\n\n// Counter for unique IDs (outside component to avoid re-initialization)\nlet idCounter = 0;\n\n/**\n * A highly customizable error toast component with copy functionality and extensive styling options.\n * Provides comprehensive customization for appearance, behavior, and event handling while maintaining accessibility.\n */\nexport const ToastError = forwardRef<HTMLDivElement, ToastErrorProps>(\n ({ title, rawError, className, 'aria-label': ariaLabel, onCopyComplete, customization, ...props }, ref) => {\n const labels = useNovaConnectLabels();\n const { isCopied, copy } = useCopyToClipboard();\n\n // Generate unique IDs only once per component instance\n const [uniqueId] = useState(() => {\n idCounter += 1;\n return `${idCounter}-${Date.now()}`;\n });\n\n const titleId = `error-title-${uniqueId}`;\n const descriptionId = `error-description-${uniqueId}`;\n\n // Extract custom components and handlers\n const {\n Icon = DefaultIcon,\n Title = DefaultTitle,\n Description = DefaultDescription,\n ButtonContent = DefaultButtonContent,\n } = customization?.components ?? {};\n\n const {\n onClick: customOnClickHandler = defaultClickHandler,\n onKeyDown: customOnKeyDownHandler = defaultKeyDownHandler,\n } = customization?.handlers ?? {};\n\n // Memoize error text for copying\n const errorToCopy = useMemo(() => rawError, [rawError]);\n\n // Handle copy with error handling and callback\n const handleCopy = useCallback(\n async (e: React.MouseEvent<HTMLButtonElement>) => {\n e.stopPropagation();\n e.preventDefault();\n\n try {\n await copy(errorToCopy);\n onCopyComplete?.(true);\n } catch (error) {\n console.error('Failed to copy error:', error);\n onCopyComplete?.(false);\n }\n },\n [copy, errorToCopy, onCopyComplete],\n );\n\n // Handle keyboard interaction for copy button\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLButtonElement>) => {\n const originalHandler = (event: React.KeyboardEvent<HTMLButtonElement>) => {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n // Create a synthetic mouse event for onClick compatibility\n const syntheticEvent = {\n ...event,\n button: 0,\n buttons: 1,\n clientX: 0,\n clientY: 0,\n movementX: 0,\n movementY: 0,\n offsetX: 0,\n offsetY: 0,\n pageX: 0,\n pageY: 0,\n relatedTarget: null,\n screenX: 0,\n screenY: 0,\n x: 0,\n y: 0,\n getModifierState: () => false,\n initMouseEvent: () => {},\n };\n // eslint-disable-next-line\n handleCopy(syntheticEvent as any);\n }\n };\n\n customOnKeyDownHandler(originalHandler, e);\n },\n [customOnKeyDownHandler, handleCopy],\n );\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({ hasTitle: Boolean(title), hasError: Boolean(rawError) });\n }\n return cn(\n 'novacon:bg-[var(--tuwa-bg-primary)] novacon:p-4 novacon:rounded-md novacon:w-full',\n 'novacon:border novacon:border-[var(--tuwa-border-primary)]',\n className,\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.container, title, rawError, className]);\n\n // Generate title classes\n const titleClasses = useMemo(() => {\n if (customization?.classNames?.title) {\n return customization.classNames.title({ title });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.title, title]);\n\n // Generate description classes\n const descriptionClasses = useMemo(() => {\n if (customization?.classNames?.description) {\n return customization.classNames.description({ rawError });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.description, rawError]);\n\n // Generate button classes\n const buttonClasses = useMemo(() => {\n const disabled = !errorToCopy.trim();\n if (customization?.classNames?.button) {\n return customization.classNames.button({ isCopied, disabled });\n }\n\n return cn(\n 'novacon:cursor-pointer novacon:mt-2 novacon:text-xs novacon:font-medium novacon:inline-flex novacon:items-center novacon:space-x-1.5',\n 'novacon:focus:outline-none novacon:focus:ring-2 novacon:focus:ring-[var(--tuwa-error-text)] novacon:focus:ring-opacity-50',\n 'novacon:rounded-md novacon:px-2 novacon:py-1 novacon:transition-all novacon:duration-200',\n 'novacon:hover:bg-[var(--tuwa-error-text)] novacon:hover:bg-opacity-10',\n 'novacon:active:bg-[var(--tuwa-error-text)] novacon:active:bg-opacity-20',\n 'novacon:text-[var(--tuwa-error-text)] novacon:hover:text-[var(--tuwa-error-text)]',\n {\n 'novacon:bg-[var(--tuwa-success-text)] novacon:bg-opacity-10 novacon:text-[var(--tuwa-success-text)]':\n isCopied,\n },\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.button, isCopied, errorToCopy]);\n\n // Generate icon classes\n const iconClasses = useMemo(() => {\n if (customization?.classNames?.icon) {\n return customization.classNames.icon({ isCopied });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [customization?.classNames?.icon, isCopied]);\n\n // Create icon element\n const iconElement = useMemo(\n () => <Icon isCopied={isCopied} className={iconClasses} aria-hidden />,\n [Icon, isCopied, iconClasses],\n );\n\n // Merge container props\n const containerProps = useMemo(\n () => ({\n ...customization?.containerProps,\n ...props,\n ref,\n className: containerClasses,\n role: 'alert' as const,\n 'aria-live': 'assertive' as const,\n 'aria-labelledby': titleId,\n 'aria-describedby': descriptionId,\n 'aria-label': ariaLabel,\n }),\n [customization?.containerProps, props, ref, containerClasses, titleId, descriptionId, ariaLabel],\n );\n\n // Merge button props\n const buttonProps = useMemo(\n () => ({\n ...customization?.buttonProps,\n onClick: (e: React.MouseEvent<HTMLButtonElement>) => {\n customOnClickHandler(handleCopy, e);\n },\n onKeyDown: handleKeyDown,\n className: buttonClasses,\n type: 'button' as const,\n 'aria-label': isCopied ? `${labels.copied} ${labels.copyRawError}` : labels.copyRawError,\n 'aria-describedby': `${titleId} ${descriptionId}`,\n disabled: !errorToCopy.trim(),\n }),\n [\n customization?.buttonProps,\n customOnClickHandler,\n handleCopy,\n handleKeyDown,\n buttonClasses,\n isCopied,\n labels.copied,\n labels.copyRawError,\n titleId,\n descriptionId,\n errorToCopy,\n ],\n );\n\n return (\n <div {...containerProps}>\n {/* Error Title */}\n <Title title={title} titleId={titleId} className={titleClasses} />\n\n {/* Error Description */}\n <Description rawError={rawError} descriptionId={descriptionId} className={descriptionClasses} />\n\n {/* Copy Button */}\n <button {...buttonProps}>\n <ButtonContent\n icon={iconElement}\n isCopied={isCopied}\n copyLabel={labels.copyRawError}\n copiedLabel={labels.copied}\n />\n </button>\n </div>\n );\n },\n);\n\nToastError.displayName = 'ToastError';\n","/**\n * @file This file contains the `ErrorsProvider` component, a customizable error toast provider with full styling control.\n */\n\nimport { ToastCloseButton } from '@tuwaio/nova-core';\nimport { ComponentPropsWithoutRef, ComponentType, useCallback, useEffect, useMemo, useRef } from 'react';\nimport { Bounce, toast, ToastContainer, type ToastPosition, type ToastTransition } from 'react-toastify';\n\nimport { ToastError, ToastErrorCustomization } from '../components';\nimport { NovaConnectProviderProps, useNovaConnect } from '../hooks/useNovaConnect';\nimport { useNovaConnectLabels } from '../hooks/useNovaConnectLabels';\n\n// --- Types for Customization ---\ntype CustomToastErrorProps = {\n title: string;\n rawError: string;\n onCopyComplete?: (success: boolean) => void;\n errorType: 'wallet' | 'switch' | null;\n isConnected: boolean;\n};\n\ntype CustomContainerProps = ComponentPropsWithoutRef<typeof ToastContainer>;\n\n/**\n * Customization options for ErrorsProvider component\n */\nexport type ErrorsProviderCustomization = {\n /** Override ToastContainer element props */\n containerProps?: Partial<ComponentPropsWithoutRef<typeof ToastContainer>>;\n /** Custom components */\n components?: {\n /** Custom ToastError component */\n ToastError?: ComponentType<CustomToastErrorProps>;\n /** Custom ToastContainer component */\n Container?: ComponentType<CustomContainerProps>;\n };\n /** Default ToastError customization (only used with default ToastError component) */\n toastErrorCustomization?: ToastErrorCustomization;\n /** Custom class name generators */\n classNames?: {\n /** Function to generate container classes */\n container?: (params: { hasErrors: boolean; errorType: 'wallet' | 'switch' | null }) => string;\n };\n /** Custom toast options generators */\n toastOptions?: {\n /** Function to generate toast options */\n error?: (params: {\n title: string;\n rawError: string;\n errorType: 'wallet' | 'switch' | null;\n isConnected: boolean;\n }) => Partial<Parameters<typeof toast.error>[1]>;\n };\n /** Custom logic handlers */\n handlers?: {\n /** Custom error display logic */\n showError?: (\n originalHandler: (title: string, rawError: string, errorKey: string) => void,\n params: { title: string; rawError: string; errorKey: string; errorType: 'wallet' | 'switch' | null },\n ) => void;\n /** Custom error dismissal logic */\n dismissError?: (originalHandler: () => void) => void;\n /** Custom copy complete handler */\n onCopyComplete?: (success: boolean, rawError: string, errorType: 'wallet' | 'switch' | null) => void;\n };\n /** Custom error title generator - does NOT customize labels, just allows title modification */\n errorTitle?: (defaultTitle: string, params: { errorType: 'wallet' | 'switch' | null }) => string;\n /** Custom error hash generator for deduplication */\n errorHash?: (\n defaultHash: string | null,\n params: { primaryError: string | null; errorType: 'wallet' | 'switch' | null },\n ) => string | null;\n};\n\nexport interface ErrorsProviderProps extends Pick<NovaConnectProviderProps, 'store'> {\n /** Custom container ID for toast notifications */\n containerId?: string;\n /** Custom position for toast notifications */\n position?: ToastPosition;\n /** Auto close delay in milliseconds */\n autoClose?: number | false;\n /** Whether to enable drag to dismiss */\n draggable?: boolean;\n /** Customization options */\n customization?: ErrorsProviderCustomization;\n}\n\n// --- Default Sub-Components ---\nconst DefaultToastError = ({\n title,\n rawError,\n onCopyComplete,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n errorType,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n isConnected,\n ...props\n}: CustomToastErrorProps & { customization?: ToastErrorCustomization }) => {\n return (\n <ToastError title={title} rawError={rawError} onCopyComplete={onCopyComplete} customization={props.customization} />\n );\n};\n\nconst DefaultContainer = (props: CustomContainerProps) => {\n const labels = useNovaConnectLabels();\n return <ToastContainer {...props} role=\"alert\" aria-live=\"assertive\" aria-label={labels.somethingWentWrong} />;\n};\n\n// --- Default Handlers ---\nconst defaultShowErrorHandler = (\n originalHandler: (title: string, rawError: string, errorKey: string) => void,\n params: { title: string; rawError: string; errorKey: string },\n) => {\n originalHandler(params.title, params.rawError, params.errorKey);\n};\n\nconst defaultDismissErrorHandler = (originalHandler: () => void) => {\n originalHandler();\n};\n\nconst defaultCopyCompleteHandler = (success: boolean, rawError: string) => {\n if (success && process.env.NODE_ENV === 'development') {\n console.log('Error copied to clipboard:', rawError.substring(0, 100));\n }\n};\n\nconst defaultErrorTitleGenerator = (defaultTitle: string) => defaultTitle;\n\nconst defaultErrorHashGenerator = (defaultHash: string | null) => defaultHash;\n\n/**\n * A highly customizable error toast provider with extensive styling options and component replacement capabilities.\n * Provides comprehensive customization for appearance, behavior, and error handling logic while maintaining accessibility.\n */\nexport function ErrorsProvider({\n store,\n containerId = 'nova-connect-errors',\n position = 'top-center',\n autoClose = 7000,\n draggable = false,\n customization,\n}: ErrorsProviderProps) {\n const labels = useNovaConnectLabels();\n const { activeWallet, walletConnectionError } = useNovaConnect();\n\n const switchNetworkError = store.getState().switchNetworkError;\n\n // Extract custom components and handlers\n const { ToastError: CustomToastError = DefaultToastError, Container = DefaultContainer } =\n customization?.components ?? {};\n\n const {\n showError: customShowErrorHandler = defaultShowErrorHandler,\n dismissError: customDismissErrorHandler = defaultDismissErrorHandler,\n onCopyComplete: customCopyCompleteHandler = defaultCopyCompleteHandler,\n } = customization?.handlers ?? {};\n\n const {\n errorTitle: customErrorTitleGenerator = defaultErrorTitleGenerator,\n errorHash: customErrorHashGenerator = defaultErrorHashGenerator,\n } = customization ?? {};\n\n // Track displayed errors to prevent duplicates\n const displayedErrorsRef = useRef<Set<string>>(new Set());\n const currentToastIdRef = useRef<string | null>(null);\n\n // Memoize error state\n const errorState = useMemo(() => {\n const hasWalletError = Boolean(walletConnectionError);\n const hasSwitchError = Boolean(switchNetworkError);\n const isConnected = Boolean(activeWallet?.isConnected);\n\n return {\n hasWalletError,\n hasSwitchError,\n isConnected,\n hasAnyError: hasWalletError || hasSwitchError,\n primaryError: walletConnectionError || switchNetworkError || null,\n errorType: (hasWalletError ? 'wallet' : hasSwitchError ? 'switch' : null) as 'wallet' | 'switch' | null,\n };\n }, [walletConnectionError, switchNetworkError, activeWallet?.isConnected]);\n\n // Memoize default error title based on type (using labels, NOT customizing them)\n const defaultErrorTitle = useMemo(() => {\n switch (errorState.errorType) {\n case 'wallet':\n return labels.walletConnectionError;\n case 'switch':\n return labels.errorWhenChainSwitching;\n default:\n return labels.somethingWentWrong;\n }\n }, [errorState.errorType, labels]);\n\n // Generate custom error title (allows modification but NOT labels customization)\n const errorTitle = useMemo(() => {\n return customErrorTitleGenerator(defaultErrorTitle, { errorType: errorState.errorType });\n }, [customErrorTitleGenerator, defaultErrorTitle, errorState.errorType]);\n\n // Generate default error hash for deduplication\n const defaultErrorHash = useMemo(() => {\n if (!errorState.primaryError) return null;\n return `${errorState.errorType}-${errorState.primaryError.substring(0, 50)}`;\n }, [errorState.primaryError, errorState.errorType]);\n\n // Generate custom error hash\n const errorHash = useMemo(() => {\n return customErrorHashGenerator(defaultErrorHash, {\n primaryError: errorState.primaryError,\n errorType: errorState.errorType,\n });\n }, [customErrorHashGenerator, defaultErrorHash, errorState.primaryError, errorState.errorType]);\n\n // Dismiss current toast\n const dismissCurrentToast = useCallback(() => {\n const originalHandler = () => {\n if (currentToastIdRef.current) {\n toast.dismiss(currentToastIdRef.current);\n currentToastIdRef.current = null;\n }\n toast.dismiss({ containerId });\n };\n customDismissErrorHandler(originalHandler);\n }, [containerId, customDismissErrorHandler]);\n\n // Handle copy complete\n const handleCopyComplete = useCallback(\n (success: boolean, rawError: string) => {\n customCopyCompleteHandler(success, rawError, errorState.errorType);\n },\n [customCopyCompleteHandler, errorState.errorType],\n );\n\n // Original handler for error display - using full customization object in dependencies\n const originalErrorHandler = useCallback(\n (t: string, r: string, k: string) => {\n // Dismiss previous toast first\n dismissCurrentToast();\n\n // Check if this error was already displayed\n if (displayedErrorsRef.current.has(k)) {\n return;\n }\n\n try {\n // Generate custom toast options\n const defaultToastOptions = {\n containerId,\n toastId: k,\n onClose: () => {\n displayedErrorsRef.current.delete(k);\n currentToastIdRef.current = null;\n },\n };\n\n const customToastOptions = customization?.toastOptions?.error?.({\n title: t,\n rawError: r,\n errorType: errorState.errorType,\n isConnected: errorState.isConnected,\n });\n\n const toastOptions = { ...defaultToastOptions, ...customToastOptions };\n\n // Use toast.error and capture the result properly\n toast.error(\n <CustomToastError\n title={t}\n rawError={r}\n errorType={errorState.errorType}\n isConnected={errorState.isConnected}\n onCopyComplete={(success) => handleCopyComplete(success, r)}\n customization={customization?.toastErrorCustomization}\n />,\n toastOptions,\n );\n\n displayedErrorsRef.current.add(k);\n currentToastIdRef.current = k;\n } catch (error) {\n console.error('Failed to show error toast:', error);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n dismissCurrentToast,\n containerId,\n customization?.toastOptions?.error,\n customization?.toastErrorCustomization,\n CustomToastError,\n errorState.errorType,\n errorState.isConnected,\n handleCopyComplete,\n ],\n );\n\n // Show error toast\n const showErrorToast = useCallback(\n (title: string, rawError: string, errorKey: string) => {\n customShowErrorHandler(originalErrorHandler, { title, rawError, errorKey, errorType: errorState.errorType });\n },\n [originalErrorHandler, customShowErrorHandler, errorState.errorType],\n );\n\n // Main effect to handle error display logic\n useEffect(() => {\n const { hasAnyError, isConnected, primaryError } = errorState;\n\n // Clear all errors when connected successfully\n if (isConnected && !hasAnyError) {\n dismissCurrentToast();\n displayedErrorsRef.current.clear();\n return;\n }\n\n // Show error if present and not already displayed\n if (hasAnyError && primaryError && errorHash) {\n // For connected state, only show switch network errors\n if (isConnected && errorState.errorType !== 'switch') {\n return;\n }\n\n showErrorToast(errorTitle, primaryError, errorHash);\n }\n }, [errorState, errorTitle, errorHash, showErrorToast, dismissCurrentToast]);\n\n // Clean up on unmount\n useEffect(() => {\n return () => {\n dismissCurrentToast();\n // eslint-disable-next-line\n displayedErrorsRef.current.clear();\n };\n }, [dismissCurrentToast]);\n\n // Generate container classes\n const containerClasses = useMemo(() => {\n if (customization?.classNames?.container) {\n return customization.classNames.container({\n hasErrors: errorState.hasAnyError,\n errorType: errorState.errorType,\n });\n }\n\n return 'novacon:p-0 novacon:bg-transparent';\n }, [customization, errorState.hasAnyError, errorState.errorType]);\n\n // Memoize default container props\n const defaultContainerProps = useMemo(\n () => ({\n containerId,\n position,\n closeOnClick: false,\n icon: false as const,\n closeButton: ToastCloseButton,\n autoClose,\n hideProgressBar: false,\n newestOnTop: false,\n pauseOnFocusLoss: false,\n draggable,\n pauseOnHover: true,\n theme: 'light' as const,\n transition: Bounce as ToastTransition,\n }),\n [containerId, position, autoClose, draggable],\n );\n\n // Merge container props (NO labels passed to custom components!)\n const containerProps = useMemo(\n () => ({\n ...defaultContainerProps,\n ...customization?.containerProps,\n className: containerClasses,\n }),\n [defaultContainerProps, customization?.containerProps, containerClasses],\n );\n\n return <Container {...containerProps} />;\n}\n\n// Add display name for better debugging\nErrorsProvider.displayName = 'ErrorsProvider';\n","/**\n * @file This file sets up the React Context for providing i18n labels throughout the UI components.\n * It allows for deep customization of all text displayed by the library.\n */\n\nimport { ReactNode, useMemo } from 'react';\n\nimport { NovaConnectLabelsContext } from '../hooks/useNovaConnectLabels';\nimport { NovaConnectLabels } from '../i18n/types';\n\ninterface NovaConnectLabelsProviderProps {\n /** An object containing the custom labels */\n labels: NovaConnectLabels;\n /** The child components to render */\n children: ReactNode;\n}\n\n/**\n * A React component that provides a custom set of labels to all child components.\n * Wrap your application or component tree with this provider to apply custom translations.\n *\n * The provider uses React.memo optimization and validates labels in development mode.\n *\n * @example\n * ```typescript\n * import { NovaConnectLabelsProvider } from './NovaConnectLabelsProvider';\n *\n * function App() {\n * const customLabels = {\n * connectWallet: 'Подключить кошелек',\n * disconnect: 'Отключиться',\n * };\n *\n * return (\n * <NovaConnectLabelsProvider labels={customLabels}>\n * <YourApp />\n * </NovaConnectLabelsProvider>\n * );\n * }\n * ```\n */\nexport function NovaConnectLabelsProvider({ labels, children }: NovaConnectLabelsProviderProps) {\n // Memoize labels to prevent unnecessary re-renders\n const memoizedLabels = useMemo(() => labels, [labels]);\n\n // Development-only validation\n if (process.env.NODE_ENV === 'development') {\n // Validate that labels object is provided\n if (!labels || typeof labels !== 'object') {\n console.warn('NovaConnectLabelsProvider: labels prop should be an object');\n }\n\n // Check for missing required labels (basic validation)\n const requiredLabels = ['connectWallet', 'disconnect', 'connecting', 'connected', 'error', 'success'] as const;\n\n const missingLabels = requiredLabels.filter((key) => !(key in labels));\n if (missingLabels.length > 0) {\n console.warn(`NovaConnectLabelsProvider: Missing required labels: ${missingLabels.join(', ')}`);\n }\n }\n\n return <NovaConnectLabelsContext.Provider value={memoizedLabels}>{children}</NovaConnectLabelsContext.Provider>;\n}\n\n// Add display name for better debugging\nNovaConnectLabelsProvider.displayName = 'NovaConnectLabelsProvider';\n","/**\n * @file Main NovaConnect provider component with comprehensive customization capabilities.\n * @module NovaConnectProvider\n */\n\nimport { deepMerge } from '@tuwaio/nova-core';\nimport { OrbitAdapter } from '@tuwaio/orbit-core';\nimport { BaseWallet } from '@tuwaio/satellite-core';\nimport { ComponentType, ReactNode, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport {\n ButtonTxStatus,\n ConnectContentType,\n ConnectedContentType,\n NovaConnectProviderContext,\n NovaConnectProviderProps as BaseNovaConnectProviderProps,\n NovaConnectProviderType,\n} from '../hooks/useNovaConnect';\nimport { defaultLabels } from '../i18n/en';\nimport { NovaConnectLabels } from '../i18n/types';\nimport { ErrorsProvider, ErrorsProviderCustomization, ErrorsProviderProps } from './ErrorsProvider';\nimport { NovaConnectLabelsProvider } from './NovaConnectLabelsProvider';\n\n// --- Customization Types ---\n\n/**\n * Props for custom NovaConnectLabelsProvider component\n */\ntype CustomLabelsProviderProps = {\n labels?: Partial<NovaConnectLabels>;\n children: ReactNode;\n};\n\n/**\n * Props for custom ErrorsProvider component\n */\ntype CustomErrorsProviderProps = Pick<ErrorsProviderProps, 'store'> & {\n customization?: ErrorsProviderCustomization;\n};\n\n/**\n * Context data passed to custom provider components\n */\ntype ProviderContext = {\n /** Current wallet connection state */\n isConnected: boolean;\n /** Active wallet instance */\n activeWallet: BaseWallet | undefined;\n /** Current wallet connection error */\n walletConnectionError: string | undefined;\n /** All modal and UI states */\n modalStates: {\n isConnectModalOpen: boolean;\n isConnectedModalOpen: boolean;\n isChainsListOpen: boolean;\n isChainsListOpenMobile: boolean;\n };\n /** Current content types for modals */\n contentTypes: {\n connectModal: ConnectContentType;\n connectedModal: ConnectedContentType;\n };\n /** Button and transaction statuses */\n statuses: {\n connectedButton: ButtonTxStatus;\n };\n};\n\n/**\n * Comprehensive customization options for NovaConnectProvider\n */\nexport type NovaConnectProviderCustomization = {\n /** Custom components */\n components?: {\n /** Custom labels provider component */\n LabelsProvider?: ComponentType<CustomLabelsProviderProps>;\n /** Custom errors provider component */\n ErrorsProvider?: ComponentType<CustomErrorsProviderProps>;\n };\n /** Labels customization and merging strategy */\n labels?: {\n /** Custom labels merging function */\n merge?: (defaultLabels: NovaConnectLabels, userLabels: Partial<NovaConnectLabels>) => NovaConnectLabels;\n /** Transform final merged labels before use */\n transform?: (mergedLabels: NovaConnectLabels, context: ProviderContext) => NovaConnectLabels;\n };\n /** ErrorsProvider customization - passed through to ErrorsProvider */\n errors?: ErrorsProviderCustomization;\n /** Custom initialization logic */\n initialization?: {\n /** Custom logic after store subscription setup */\n onStoreSubscribed?: (context: ProviderContext) => void;\n /** Custom logic when connection state changes */\n onConnectionStateChange?: (\n isConnected: boolean,\n activeWallet: BaseWallet | undefined,\n context: ProviderContext,\n ) => void;\n /** Custom logic when error state changes */\n onErrorStateChange?: (error: string | undefined, context: ProviderContext) => void;\n };\n /** Custom context value transformation */\n contextValue?: {\n /** Transform context value before providing to children */\n transform?: (defaultValue: NovaConnectProviderType, context: ProviderContext) => NovaConnectProviderType;\n };\n /** Custom rendering logic */\n rendering?: {\n /** Custom provider tree structure */\n providerTree?: (\n defaultTree: ReactNode,\n components: {\n ErrorsProvider: ReactNode;\n LabelsProvider: ReactNode;\n MainContent: ReactNode;\n },\n context: ProviderContext,\n ) => ReactNode;\n };\n};\n\n/**\n * Extended props for NovaConnectProvider with full customization capabilities\n */\nexport interface NovaConnectProviderProps extends BaseNovaConnectProviderProps {\n /** Comprehensive customization options for the provider and its sub-components */\n customization?: NovaConnectProviderCustomization;\n}\n\n// --- Default Components ---\n\n/**\n * Default labels provider component\n */\nconst DefaultLabelsProvider = ({ labels, children }: CustomLabelsProviderProps) => {\n return <NovaConnectLabelsProvider labels={labels as NovaConnectLabels}>{children}</NovaConnectLabelsProvider>;\n};\n\n/**\n * Default errors provider component\n */\nconst DefaultErrorsProvider = ({ store, customization }: CustomErrorsProviderProps) => {\n return <ErrorsProvider store={store} customization={customization} />;\n};\n\n// --- Default Handlers ---\n\n/**\n * Default labels merging function\n */\nconst defaultLabelsMerge = (\n defaultLabels: NovaConnectLabels,\n userLabels: Partial<NovaConnectLabels>,\n): NovaConnectLabels => {\n return deepMerge(defaultLabels, userLabels || {});\n};\n\n/**\n * Default labels transform function (identity)\n */\nconst defaultLabelsTransform = (mergedLabels: NovaConnectLabels): NovaConnectLabels => mergedLabels;\n\n/**\n * Default store subscription handler\n */\nconst defaultStoreSubscribedHandler = () => {\n // No-op by default\n};\n\n/**\n * Default connection state change handler\n */\nconst defaultConnectionStateChangeHandler = () => {\n // No-op by default\n};\n\n/**\n * Default error state change handler\n */\nconst defaultErrorStateChangeHandler = () => {\n // No-op by default\n};\n\n/**\n * Default context value transform function (identity)\n */\nconst defaultContextValueTransform = (defaultValue: NovaConnectProviderType): NovaConnectProviderType => defaultValue;\n\n/**\n * Default provider tree renderer\n */\nconst defaultProviderTreeRenderer = (\n defaultTree: ReactNode,\n // Unused but kept for API consistency\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n components: {\n ErrorsProvider: ReactNode;\n LabelsProvider: ReactNode;\n MainContent: ReactNode;\n },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n context: ProviderContext,\n): ReactNode => {\n return defaultTree;\n};\n\n/**\n * Main NovaConnect provider component with comprehensive customization capabilities.\n *\n * This provider manages wallet connection state, error handling, internationalization,\n * and modal states while offering extensive customization options for all sub-components\n * and behaviors.\n *\n * Features:\n * - Complete wallet connection state management\n * - Customizable error handling through ErrorsProvider\n * - Flexible internationalization system\n * - Modal and UI state coordination\n * - Extensive customization API for all aspects\n * - Custom component replacement capabilities\n * - Advanced initialization and lifecycle hooks\n *\n * @example Basic usage\n * ```tsx\n * <NovaConnectProvider store={store}>\n * <App />\n * </NovaConnectProvider>\n * ```\n *\n * @example With customization\n * ```tsx\n * <NovaConnectProvider\n * store={store}\n * labels={customLabels}\n * customization={{\n * errors: {\n * position: 'bottom-right',\n * autoClose: 5000,\n * components: {\n * ToastError: CustomToastError\n * }\n * },\n * initialization: {\n * onConnectionStateChange: (isConnected, wallet) => {\n * console.log('Connection state:', isConnected, wallet);\n * }\n * }\n * }}\n * >\n * <App />\n * </NovaConnectProvider>\n * ```\n *\n * @param props - Provider configuration and customization options\n */\nexport function NovaConnectProvider({ labels, store, children, customization }: NovaConnectProviderProps) {\n // Extract custom components\n const { LabelsProvider = DefaultLabelsProvider, ErrorsProvider: CustomErrorsProvider = DefaultErrorsProvider } =\n customization?.components ?? {};\n\n // Extract custom handlers\n const { merge: customLabelsMerge = defaultLabelsMerge, transform: customLabelsTransform = defaultLabelsTransform } =\n customization?.labels ?? {};\n\n const {\n onStoreSubscribed: customStoreSubscribedHandler = defaultStoreSubscribedHandler,\n onConnectionStateChange: customConnectionStateChangeHandler = defaultConnectionStateChangeHandler,\n onErrorStateChange: customErrorStateChangeHandler = defaultErrorStateChangeHandler,\n } = customization?.initialization ?? {};\n\n const { transform: customContextValueTransform = defaultContextValueTransform } = customization?.contextValue ?? {};\n\n const { providerTree: customProviderTreeRenderer = defaultProviderTreeRenderer } = customization?.rendering ?? {};\n\n // Merge labels using custom or default logic\n const mergedLabels = useMemo(() => {\n return customLabelsMerge(defaultLabels, labels || {});\n }, [labels, customLabelsMerge]);\n\n // State management - all existing state\n const [activeWallet, setActiveWallet] = useState<BaseWallet | undefined>(store.getState().activeWallet);\n const [walletConnectionError, setWalletConnectionError] = useState<string | undefined>(\n store.getState().walletConnectionError,\n );\n const [isConnectModalOpen, setIsConnectModalOpen] = useState(false);\n const [isConnectedModalOpen, setIsConnectedModalOpen] = useState(false);\n const [isChainsListOpen, setIsChainsListOpen] = useState(false);\n const [isChainsListOpenMobile, setIsChainsListOpenMobile] = useState(false);\n const [connectedButtonStatus, setConnectedButtonStatus] = useState<ButtonTxStatus>('idle');\n const [connectModalContentType, setConnectModalContentType] = useState<ConnectContentType>('connectors');\n const [selectedAdapter, setSelectedAdapter] = useState<OrbitAdapter | undefined>(undefined);\n const [activeConnector, setActiveConnector] = useState<string | undefined>(undefined);\n const [impersonatedAddress, setImpersonatedAddress] = useState('');\n const [isConnected, setIsConnected] = useState(false);\n const [connectedModalContentType, setConnectedModalContentType] = useState<ConnectedContentType>('main');\n\n // Create provider context for custom handlers\n const providerContext = useMemo(\n (): ProviderContext => ({\n isConnected,\n activeWallet,\n walletConnectionError,\n modalStates: {\n isConnectModalOpen,\n isConnectedModalOpen,\n isChainsListOpen,\n isChainsListOpenMobile,\n },\n contentTypes: {\n connectModal: connectModalContentType,\n connectedModal: connectedModalContentType,\n },\n statuses: {\n connectedButton: connectedButtonStatus,\n },\n }),\n [\n isConnected,\n activeWallet,\n walletConnectionError,\n isConnectModalOpen,\n isConnectedModalOpen,\n isChainsListOpen,\n isChainsListOpenMobile,\n connectModalContentType,\n connectedModalContentType,\n connectedButtonStatus,\n ],\n );\n\n // Transform labels using custom logic if provided\n const finalLabels = useMemo(() => {\n return customLabelsTransform(mergedLabels, providerContext);\n }, [mergedLabels, customLabelsTransform, providerContext]);\n\n // Handle connection state changes\n const handleConnectionStateChange = useCallback(\n (newIsConnected: boolean, newActiveWallet: BaseWallet | undefined) => {\n customConnectionStateChangeHandler(newIsConnected, newActiveWallet, providerContext);\n },\n [customConnectionStateChangeHandler, providerContext],\n );\n\n // Handle error state changes\n const handleErrorStateChange = useCallback(\n (newError: string | undefined) => {\n customErrorStateChangeHandler(newError, providerContext);\n },\n [customErrorStateChangeHandler, providerContext],\n );\n\n // Store subscription effect\n useEffect(() => {\n if (!store) return undefined;\n const unsubscribe = store.subscribe((state) => {\n const newActiveWallet = state.activeWallet;\n const newError = state.walletConnectionError;\n const newIsConnected = Boolean(newActiveWallet?.isConnected);\n // Update state\n setActiveWallet(newActiveWallet);\n setWalletConnectionError(newError);\n // Handle state changes\n if (newIsConnected !== isConnected || newActiveWallet !== activeWallet) {\n handleConnectionStateChange(newIsConnected, newActiveWallet);\n }\n if (newError !== walletConnectionError) {\n handleErrorStateChange(newError);\n }\n });\n\n // Custom initialization logic\n customStoreSubscribedHandler(providerContext);\n\n return unsubscribe;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [store]);\n\n // Create and transform context value using custom logic if provided - moved inside useMemo\n const contextValue = useMemo(() => {\n const defaultContextValue: NovaConnectProviderType = {\n walletConnectionError,\n activeWallet,\n isConnectModalOpen,\n setIsConnectModalOpen,\n isConnectedModalOpen,\n setIsConnectedModalOpen,\n isChainsListOpen,\n setIsChainsListOpen,\n isChainsListOpenMobile,\n setIsChainsListOpenMobile,\n connectedButtonStatus,\n setConnectedButtonStatus,\n connectedModalContentType,\n setConnectedModalContentType,\n connectModalContentType,\n setConnectModalContentType,\n selectedAdapter,\n setSelectedAdapter,\n activeConnector,\n setActiveConnector,\n impersonatedAddress,\n setImpersonatedAddress,\n isConnected,\n setIsConnected,\n };\n\n return customContextValueTransform(defaultContextValue, providerContext);\n }, [\n walletConnectionError,\n activeWallet,\n isConnectModalOpen,\n setIsConnectModalOpen,\n isConnectedModalOpen,\n setIsConnectedModalOpen,\n isChainsListOpen,\n setIsChainsListOpen,\n isChainsListOpenMobile,\n setIsChainsListOpenMobile,\n connectedButtonStatus,\n setConnectedButtonStatus,\n connectedModalContentType,\n setConnectedModalContentType,\n connectModalContentType,\n setConnectModalContentType,\n selectedAdapter,\n setSelectedAdapter,\n activeConnector,\n setActiveConnector,\n impersonatedAddress,\n setImpersonatedAddress,\n isConnected,\n setIsConnected,\n customContextValueTransform,\n providerContext,\n ]);\n\n // Create component tree elements\n const errorsProviderElement = <CustomErrorsProvider store={store} customization={customization?.errors} />;\n\n const labelsProviderElement = <LabelsProvider labels={finalLabels}>{children}</LabelsProvider>;\n\n const mainContentElement = (\n <NovaConnectProviderContext.Provider value={contextValue}>\n {errorsProviderElement}\n {labelsProviderElement}\n </NovaConnectProviderContext.Provider>\n );\n\n // Create default provider tree\n const defaultProviderTree = (\n <NovaConnectProviderContext.Provider value={contextValue}>\n {errorsProviderElement}\n {labelsProviderElement}\n </NovaConnectProviderContext.Provider>\n );\n\n // Use custom provider tree renderer if provided\n const finalProviderTree = customProviderTreeRenderer(\n defaultProviderTree,\n {\n ErrorsProvider: errorsProviderElement,\n LabelsProvider: labelsProviderElement,\n MainContent: mainContentElement,\n },\n providerContext,\n );\n\n return <>{finalProviderTree}</>;\n}\n\n// Add display name for better debugging\nNovaConnectProvider.displayName = 'NovaConnectProvider';\n"]}
|