import { useEffect, useMemo, useState } from 'react' import Link from 'next/link' import { Card } from '@/libs/frontend-ui-primitives' import { explorerFeaturePages } from '@/data/explorerOperations' import { configApi, type CapabilitiesResponse, type NetworksConfigResponse, type TokenListResponse } from '@/services/api/config' import { getMissionControlRelays, missionControlApi, type MissionControlBridgeStatusResponse } from '@/services/api/missionControl' import { routesApi, type RouteMatrixResponse } from '@/services/api/routes' import { useUiMode } from '@/components/common/UiModeContext' import { summarizeChainActivity } from '@/utils/activityContext' import ActivityContextPanel from '@/components/common/ActivityContextPanel' import FreshnessTrustNote from '@/components/common/FreshnessTrustNote' import SubsystemPosturePanel from '@/components/common/SubsystemPosturePanel' import { resolveEffectiveFreshness } from '@/utils/explorerFreshness' import { statsApi, type ExplorerStats } from '@/services/api/stats' function relativeAge(isoString?: string): string { if (!isoString) return 'Unknown' const parsed = Date.parse(isoString) if (!Number.isFinite(parsed)) return 'Unknown' const seconds = Math.max(0, Math.round((Date.now() - parsed) / 1000)) if (seconds < 60) return `${seconds}s ago` const minutes = Math.round(seconds / 60) if (minutes < 60) return `${minutes}m ago` const hours = Math.round(minutes / 60) return `${hours}h ago` } function ActionLink({ href, label, external, }: { href: string label: string external?: boolean }) { const className = 'inline-flex items-center text-sm font-semibold text-primary-600 hover:underline' const text = `${label} ->` if (external) { return ( {text} ) } return ( {text} ) } interface OperationsHubPageProps { initialBridgeStatus?: MissionControlBridgeStatusResponse | null initialRouteMatrix?: RouteMatrixResponse | null initialNetworksConfig?: NetworksConfigResponse | null initialTokenList?: TokenListResponse | null initialCapabilities?: CapabilitiesResponse | null initialStats?: ExplorerStats | null } export default function OperationsHubPage({ initialBridgeStatus = null, initialRouteMatrix = null, initialNetworksConfig = null, initialTokenList = null, initialCapabilities = null, initialStats = null, }: OperationsHubPageProps) { const { mode } = useUiMode() const [bridgeStatus, setBridgeStatus] = useState(initialBridgeStatus) const [routeMatrix, setRouteMatrix] = useState(initialRouteMatrix) const [networksConfig, setNetworksConfig] = useState(initialNetworksConfig) const [tokenList, setTokenList] = useState(initialTokenList) const [capabilities, setCapabilities] = useState(initialCapabilities) const [stats, setStats] = useState(initialStats) const [loadingError, setLoadingError] = useState(null) const page = explorerFeaturePages.operations useEffect(() => { let cancelled = false const load = async () => { const [bridgeResult, routesResult, networksResult, tokenListResult, capabilitiesResult, statsResult] = await Promise.allSettled([ missionControlApi.getBridgeStatus(), routesApi.getRouteMatrix(), configApi.getNetworks(), configApi.getTokenList(), configApi.getCapabilities(), statsApi.get(), ]) if (cancelled) return if (bridgeResult.status === 'fulfilled') setBridgeStatus(bridgeResult.value) if (routesResult.status === 'fulfilled') setRouteMatrix(routesResult.value) if (networksResult.status === 'fulfilled') setNetworksConfig(networksResult.value) if (tokenListResult.status === 'fulfilled') setTokenList(tokenListResult.value) if (capabilitiesResult.status === 'fulfilled') setCapabilities(capabilitiesResult.value) if (statsResult.status === 'fulfilled') setStats(statsResult.value) const failedCount = [ bridgeResult, routesResult, networksResult, tokenListResult, capabilitiesResult, statsResult, ].filter((result) => result.status === 'rejected').length if (failedCount === 6) { setLoadingError('Public explorer operations data is temporarily unavailable.') } } load().catch((error) => { if (!cancelled) { setLoadingError( error instanceof Error ? error.message : 'Public explorer operations data is temporarily unavailable.' ) } }) return () => { cancelled = true } }, []) const relayCount = useMemo(() => { const relays = getMissionControlRelays(bridgeStatus) return relays ? Object.keys(relays).length : 0 }, [bridgeStatus]) const totalQueue = useMemo(() => { const relays = getMissionControlRelays(bridgeStatus) if (!relays) return 0 return Object.values(relays).reduce((sum, relay) => { const queueSize = relay.url_probe?.body?.queue?.size ?? relay.file_snapshot?.queue?.size ?? 0 return sum + queueSize }, 0) }, [bridgeStatus]) const tokenChainCoverage = useMemo(() => { return new Set((tokenList?.tokens || []).map((token) => token.chainId).filter(Boolean)).size }, [tokenList]) const topSymbols = useMemo(() => { return Array.from( new Set((tokenList?.tokens || []).map((token) => token.symbol).filter(Boolean) as string[]) ).slice(0, 8) }, [tokenList]) const activityContext = useMemo( () => summarizeChainActivity({ blocks: [], transactions: [], latestBlockNumber: bridgeStatus?.data?.chains?.['138']?.block_number ? Number(bridgeStatus.data.chains['138'].block_number) : null, latestBlockTimestamp: null, freshness: resolveEffectiveFreshness(stats, bridgeStatus), diagnostics: stats?.diagnostics ?? bridgeStatus?.data?.diagnostics ?? null, }), [bridgeStatus, stats], ) return (
{page.eyebrow}

{page.title}

{page.description}

{page.note ? (

{page.note}

) : null} {loadingError ? (

{loadingError}

) : null}
Bridge Fleet
{bridgeStatus?.data?.status || 'unknown'}
{relayCount} managed lanes · queue {totalQueue}
Route Coverage
{routeMatrix?.counts?.filteredLiveRoutes ?? 0}
{routeMatrix?.counts?.liveSwapRoutes ?? 0} swaps · {routeMatrix?.counts?.liveBridgeRoutes ?? 0} bridges
Wallet Surface
{networksConfig?.chains?.length ?? 0}
Chains · {(tokenList?.tokens || []).length} tokens across {tokenChainCoverage} networks
RPC Capabilities
{capabilities?.http?.supportedMethods?.length ?? 0}
HTTP methods · {capabilities?.tracing?.supportedMethods?.length ?? 0} tracing methods
Bridge checked
{relativeAge(bridgeStatus?.data?.checked_at)}
{mode === 'guided' ? 'Public mission-control snapshot freshness.' : 'Mission-control freshness.'}
Route matrix updated
{relativeAge(routeMatrix?.updated)}
{mode === 'guided' ? 'Token-aggregation route inventory timestamp.' : 'Route inventory timestamp.'}
Default chain
{networksConfig?.defaultChainId ?? 'Unknown'}
{mode === 'guided' ? 'Wallet onboarding points at Chain 138 by default.' : 'Default wallet chain.'}
Wallet support
{capabilities?.walletSupport?.walletAddEthereumChain && capabilities?.walletSupport?.walletWatchAsset ? 'Ready' : 'Partial'}
{mode === 'guided' ? '`wallet_addEthereumChain` and `wallet_watchAsset` compatibility.' : 'Wallet RPC support.'}
Featured symbols
{topSymbols.map((symbol) => ( {symbol} ))}
Tracing posture
Supported: {(capabilities?.tracing?.supportedMethods || []).join(', ') || 'None'}
Unsupported: {(capabilities?.tracing?.unsupportedMethods || []).join(', ') || 'None'}
{page.actions.map((action) => (
{action.title}

{action.description}

))}
) }