import {Fragment, useMemo} from 'react'; import type {Tag} from 'sentry/actionCreators/events'; import type {ApiResult} from 'sentry/api'; import type {EventTransaction} from 'sentry/types/event'; import type EventView from 'sentry/utils/discover/eventView'; import type { TraceFullDetailed, TraceSplitResults, } from 'sentry/utils/performance/quickTrace/types'; import type {UseApiQueryResult, UseInfiniteQueryResult} from 'sentry/utils/queryClient'; import type RequestError from 'sentry/utils/requestError/requestError'; import {useLocation} from 'sentry/utils/useLocation'; import useOrganization from 'sentry/utils/useOrganization'; import {TraceWarnings} from 'sentry/views/performance/newTraceDetails/traceWarnings'; import {isTraceNode} from '../../../guards'; import type {TraceMetaQueryResults} from '../../../traceApi/useTraceMeta'; import type {TraceTree, TraceTreeNode} from '../../../traceModels/traceTree'; import type {TraceType} from '../../../traceType'; import {IssueList} from '../../details/issues/issues'; import {TraceDrawerComponents} from '../../details/styles'; import {GeneralInfo} from './generalInfo'; import {TagsSummary} from './tagsSummary'; type TraceDetailsProps = { metaResults: TraceMetaQueryResults; node: TraceTreeNode | null; rootEventResults: UseApiQueryResult; tagsInfiniteQueryResults: UseInfiniteQueryResult, unknown>; traceEventView: EventView; traceType: TraceType; traces: TraceSplitResults | null; tree: TraceTree; }; export function TraceDetails(props: TraceDetailsProps) { const location = useLocation(); const organization = useOrganization(); const issues = useMemo(() => { if (!props.node) { return []; } return [...props.node.errors, ...props.node.performance_issues]; // eslint-disable-next-line react-hooks/exhaustive-deps }, [props.node, props.node?.errors.size, props.node?.performance_issues.size]); if (!props.node) { return null; } if (!(props.node && isTraceNode(props.node))) { throw new Error('Expected a trace node'); } return ( {props.tree.type === 'trace' ? : null} ); }