useTraceSpans.tsx 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import {normalizeDateTimeParams} from 'sentry/components/organizations/pageFilters/parse';
  2. import type {PageFilters} from 'sentry/types/core';
  3. import {useApiQuery} from 'sentry/utils/queryClient';
  4. import useOrganization from 'sentry/utils/useOrganization';
  5. import usePageFilters from 'sentry/utils/usePageFilters';
  6. import type {TraceResult} from './useTraces';
  7. export type SpanResult<F extends string> = Record<F, any>;
  8. export interface SpanResults<F extends string> {
  9. data: SpanResult<F>[];
  10. meta: any;
  11. }
  12. interface UseTraceSpansOptions<F extends string> {
  13. fields: F[];
  14. trace: TraceResult;
  15. datetime?: PageFilters['datetime'];
  16. enabled?: boolean;
  17. limit?: number;
  18. query?: string | string[];
  19. sort?: string[];
  20. }
  21. export function useTraceSpans<F extends string>({
  22. fields,
  23. trace,
  24. datetime,
  25. enabled,
  26. limit,
  27. query,
  28. sort,
  29. }: UseTraceSpansOptions<F>) {
  30. const organization = useOrganization();
  31. const {selection} = usePageFilters();
  32. const path = `/organizations/${organization.slug}/trace/${trace.trace}/spans/`;
  33. const endpointOptions = {
  34. query: {
  35. project: selection.projects,
  36. environment: selection.environments,
  37. ...normalizeDateTimeParams(datetime ?? selection.datetime),
  38. field: fields,
  39. query,
  40. sort,
  41. per_page: limit,
  42. maxSpansPerTrace: 10,
  43. },
  44. };
  45. const result = useApiQuery<SpanResults<F>>([path, endpointOptions], {
  46. staleTime: 0,
  47. refetchOnWindowFocus: false,
  48. retry: false,
  49. enabled,
  50. });
  51. return result;
  52. }