12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- import {Fragment} from 'react';
- import styled from '@emotion/styled';
- import {t} from 'sentry/locale';
- import {space} from 'sentry/styles/space';
- import type {Event} from 'sentry/types/event';
- import useRouteAnalyticsParams from 'sentry/utils/routeAnalytics/useRouteAnalyticsParams';
- import {useHasStreamlinedUI} from 'sentry/views/issueDetails/utils';
- import {TraceIssueEvent} from './traceTimeline/traceIssue';
- import {TraceLink} from './traceTimeline/traceLink';
- import {TraceTimeline} from './traceTimeline/traceTimeline';
- import {useTraceTimelineEvents} from './traceTimeline/useTraceTimelineEvents';
- export function TraceDataSection({event}: {event: Event}) {
- const hasStreamlinedUI = useHasStreamlinedUI();
- // This is also called within the TraceTimeline component but caching will save a second call
- const {isLoading, oneOtherIssueEvent, traceEvents} = useTraceTimelineEvents({
- event,
- });
- let params: Record<string, boolean> = {};
- if (!isLoading && oneOtherIssueEvent !== undefined) {
- params = {
- has_related_trace_issue: true,
- };
- }
- useRouteAnalyticsParams(params);
- if (isLoading) {
- return null;
- }
- const noEvents = !isLoading && traceEvents.length === 0;
- if (hasStreamlinedUI && (!oneOtherIssueEvent || noEvents)) {
- return null;
- }
- return (
- <Fragment>
- <StyledTraceLink>
- {/* Used for trace-related issue */}
- {oneOtherIssueEvent && (
- <span>{t('One other issue appears in the same trace.')}</span>
- )}
- <TraceLink event={event} />
- </StyledTraceLink>
- {oneOtherIssueEvent === undefined ? (
- <TraceTimeline event={event} />
- ) : (
- <TraceIssueEvent event={oneOtherIssueEvent} />
- )}
- </Fragment>
- );
- }
- const StyledTraceLink = styled('div')`
- display: flex;
- white-space: nowrap;
- overflow: hidden;
- gap: ${space(0.25)};
- `;
|