import {useCallback, useContext} from 'react'; import styled from '@emotion/styled'; import Link from 'sentry/components/links/link'; import {generateTraceTarget} from 'sentry/components/quickTrace/utils'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {Event} from 'sentry/types'; import {trackAnalytics} from 'sentry/utils/analytics'; import {QuickTraceContext} from 'sentry/utils/performance/quickTrace/quickTraceContext'; import useOrganization from 'sentry/utils/useOrganization'; type TraceLinkProps = { event: Event; noTrace: boolean; }; export function TraceLink({event, noTrace}: TraceLinkProps) { const organization = useOrganization(); const quickTrace = useContext(QuickTraceContext); const handleTraceLink = useCallback(() => { trackAnalytics('quick_trace.trace_id.clicked', { organization, source: 'issues', }); }, [organization]); if ( !quickTrace || quickTrace.isLoading || quickTrace.error || quickTrace.type === 'empty' ) { return null; } return ( {t('View Full Trace')} ); } const StyledLink = styled(Link, {shouldForwardProp: prop => prop !== 'noTrace'})<{ noTrace: boolean; }>` margin-left: ${p => (p.noTrace ? 0 : space(1))}; font-size: ${p => p.theme.fontSizeSmall}; `;