123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- import {useMemo} from 'react';
- import type {Location} from 'history';
- import {getUtcDateString} from 'sentry/utils/dates';
- import type {TableDataRow} from 'sentry/utils/discover/discoverQuery';
- import EventView from 'sentry/utils/discover/eventView';
- import {useApiQuery} from 'sentry/utils/queryClient';
- import useOrganization from 'sentry/utils/useOrganization';
- import type {ReplayRecord} from 'sentry/views/replays/types';
- import {type TraceMetaQueryResults, useTraceMeta} from './useTraceMeta';
- // Fetches the meta data for all the traces in a replay and combines the results.
- export function useReplayTraceMeta(
- replayRecord: ReplayRecord | undefined
- ): TraceMetaQueryResults {
- const organization = useOrganization();
- // EventView that is used to fetch the list of events for the replay
- const eventView = useMemo(() => {
- if (!replayRecord) {
- return null;
- }
- const replayId = replayRecord?.id;
- const projectId = replayRecord?.project_id;
- const start = getUtcDateString(replayRecord?.started_at.getTime());
- const end = getUtcDateString(replayRecord?.finished_at.getTime());
- return EventView.fromSavedQuery({
- id: undefined,
- name: `Traces in replay ${replayId}`,
- fields: ['trace', 'count(trace)', 'min(timestamp)'],
- orderby: 'min_timestamp',
- query: `replayId:${replayId}`,
- projects: [Number(projectId)],
- version: 2,
- start,
- end,
- });
- }, [replayRecord]);
- const start = getUtcDateString(replayRecord?.started_at.getTime());
- const end = getUtcDateString(replayRecord?.finished_at.getTime());
- const {data: eventsData, isLoading: eventsIsLoading} = useApiQuery<{
- data: TableDataRow[];
- }>(
- [
- `/organizations/${organization.slug}/events/`,
- {
- query: eventView
- ? {
- ...eventView.getEventsAPIPayload({
- start,
- end,
- limit: 10,
- } as unknown as Location),
- sort: ['min_timestamp', 'trace'],
- }
- : {},
- },
- ],
- {
- staleTime: Infinity,
- enabled: !!eventView && !!replayRecord,
- }
- );
- const traceIds = useMemo(() => {
- return (eventsData?.data ?? []).map(({trace}) => String(trace)).filter(Boolean);
- }, [eventsData]);
- const meta = useTraceMeta(traceIds);
- const metaResults = useMemo(() => {
- return {
- data: meta.data,
- isLoading: eventsIsLoading || meta.isLoading,
- errors: meta.errors,
- };
- }, [meta, eventsIsLoading]);
- return metaResults;
- }
|