12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- 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<TraceTree.NodeValue> | null;
- rootEventResults: UseApiQueryResult<EventTransaction, RequestError>;
- tagsInfiniteQueryResults: UseInfiniteQueryResult<ApiResult<Tag[]>, unknown>;
- traceEventView: EventView;
- traceType: TraceType;
- traces: TraceSplitResults<TraceFullDetailed> | 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 (
- <Fragment>
- {props.tree.type === 'trace' ? <TraceWarnings type={props.traceType} /> : null}
- <IssueList issues={issues} node={props.node} organization={organization} />
- <TraceDrawerComponents.SectionCardGroup>
- <GeneralInfo
- organization={organization}
- traces={props.traces}
- tree={props.tree}
- node={props.node}
- rootEventResults={props.rootEventResults}
- metaResults={props.metaResults}
- />
- <TagsSummary
- tagsInfiniteQueryResults={props.tagsInfiniteQueryResults}
- organization={organization}
- location={location}
- eventView={props.traceEventView}
- totalValues={props.tree.eventsCount}
- />
- </TraceDrawerComponents.SectionCardGroup>
- </Fragment>
- );
- }
|