import { useSearchExecutions, useExecutionStats, useStatsTimeseries } from '../../api/queries/executions'; import { useExecutionSearch } from './use-execution-search'; import { StatCard } from '../../components/shared/StatCard'; import { Pagination } from '../../components/shared/Pagination'; import { SearchFilters } from './SearchFilters'; import { ResultsTable } from './ResultsTable'; import styles from './ExecutionExplorer.module.css'; export function ExecutionExplorer() { const { toSearchRequest, offset, limit, setOffset, live, toggleLive } = useExecutionSearch(); const searchRequest = toSearchRequest(); const { data, isLoading, isFetching } = useSearchExecutions(searchRequest, live); const timeFrom = searchRequest.timeFrom ?? undefined; const timeTo = searchRequest.timeTo ?? undefined; const { data: stats } = useExecutionStats(timeFrom, timeTo); const { data: timeseries } = useStatsTimeseries(timeFrom, timeTo); const sparkTotal = timeseries?.buckets.map((b) => b.totalCount) ?? []; const sparkFailed = timeseries?.buckets.map((b) => b.failedCount) ?? []; const sparkAvgDuration = timeseries?.buckets.map((b) => b.avgDurationMs) ?? []; const sparkP99 = timeseries?.buckets.map((b) => b.p99DurationMs) ?? []; const sparkActive = timeseries?.buckets.map((b) => b.activeCount) ?? []; const total = data?.total ?? 0; const results = data?.data ?? []; const showFrom = total > 0 ? offset + 1 : 0; const showTo = Math.min(offset + limit, total); return ( <> {/* Page Header */}

Route Explorer

Search and analyze route executions
{/* Stats Bar */}
{/* Filters */} {/* Results Header */}
Showing {showFrom}–{showTo} of {total.toLocaleString()} results {isFetching && !isLoading && ' · updating...'}
{/* Results Table */} {/* Pagination */} ); }