import {Fragment} from 'react';
import styled from '@emotion/styled';
import type {Location} from 'history';
import ErrorBoundary from 'sentry/components/errorBoundary';
import QuickTrace from 'sentry/components/quickTrace';
import {space} from 'sentry/styles/space';
import type {Organization} from 'sentry/types';
import type {Event} from 'sentry/types/event';
import {defined} from 'sentry/utils';
import TraceMetaQuery from 'sentry/utils/performance/quickTrace/traceMetaQuery';
import type {QuickTraceQueryChildrenProps} from 'sentry/utils/performance/quickTrace/types';
import {getTraceTimeRangeFromEvent} from 'sentry/utils/performance/quickTrace/utils';
import useRouteAnalyticsParams from 'sentry/utils/routeAnalytics/useRouteAnalyticsParams';
import {TraceLink} from 'sentry/views/issueDetails/quickTrace/traceLink';
type Props = {
event: Event;
location: Location;
organization: Organization;
quickTrace: undefined | QuickTraceQueryChildrenProps;
};
function IssueQuickTrace({event, location, organization, quickTrace}: Props) {
const isTraceMissing =
!quickTrace ||
quickTrace.error ||
((!defined(quickTrace.trace) || quickTrace.trace.length === 0) &&
(!quickTrace.orphanErrors || quickTrace.orphanErrors?.length === 0));
const traceId = event.contexts?.trace?.trace_id ?? '';
const {start, end} = getTraceTimeRangeFromEvent(event);
useRouteAnalyticsParams({
trace_status: isTraceMissing
? quickTrace?.type === 'missing'
? 'transaction missing'
: 'trace missing'
: 'success',
});
if (isTraceMissing) {
return (
);
}
return (
{metaResults => (
)}
);
}
const QuickTraceWrapper = styled('div')`
display: flex;
align-items: center;
gap: ${space(0.75)};
flex-wrap: wrap;
margin-top: ${space(0.75)};
height: 20px;
`;
export default IssueQuickTrace;