import {normalizeDateTimeParams} from 'sentry/components/organizations/pageFilters/parse'; import type {PageFilters} from 'sentry/types/core'; import {useApiQuery} from 'sentry/utils/queryClient'; import useOrganization from 'sentry/utils/useOrganization'; import usePageFilters from 'sentry/utils/usePageFilters'; import type {TraceResult} from './useTraces'; export type SpanResult = Record; export interface SpanResults { data: SpanResult[]; meta: any; } interface UseTraceSpansOptions { fields: F[]; trace: TraceResult; datetime?: PageFilters['datetime']; enabled?: boolean; limit?: number; metricsMax?: string; metricsMin?: string; metricsOp?: string; metricsQuery?: string; mri?: string; query?: string | string[]; sort?: string[]; } export function useTraceSpans({ fields, trace, datetime, enabled, limit, mri, metricsMax, metricsMin, metricsOp, metricsQuery, query, sort, }: UseTraceSpansOptions) { const organization = useOrganization(); const {selection} = usePageFilters(); const path = `/organizations/${organization.slug}/trace/${trace.trace}/spans/`; const endpointOptions = { query: { project: selection.projects, environment: selection.environments, ...(datetime ?? normalizeDateTimeParams(selection.datetime)), field: fields, query, sort, per_page: limit, maxSpansPerTrace: 10, mri, metricsMax, metricsMin, metricsOp, metricsQuery, }, }; const result = useApiQuery>([path, endpointOptions], { staleTime: 0, refetchOnWindowFocus: false, retry: false, enabled, }); return result; }