import styled from '@emotion/styled'; import {SectionHeading} from 'sentry/components/charts/styles'; import Count from 'sentry/components/count'; import PerformanceDuration from 'sentry/components/performanceDuration'; import {t, tct} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {defined} from 'sentry/utils'; import {formatMetricUsingUnit} from 'sentry/utils/metrics/formatters'; import {DataTitles} from 'sentry/views/starfish/views/spans/types'; type Props = { avgDuration: number; spanCount: number; spanDescription: string; spanOp: string; timeSpent: number; }; export default function SpanSummaryHeader(props: Props) { const {spanOp, spanDescription, avgDuration, timeSpent, spanCount} = props; return ( {t('Span')} {spanDescription ? spanDescription : emptyValue} {spanOp} {DataTitles.avg} {defined(avgDuration) ? formatMetricUsingUnit(avgDuration, 'milliseconds') : '\u2014'} {DataTitles.timeSpent} {defined(timeSpent) ? ( ) : ( '\u2014' )} {defined(spanCount) ? tct('[spanCount] spans', {spanCount: }) : '\u2014'} ); } const ContentHeader = styled('div')` display: grid; grid-template-columns: 1fr; gap: ${space(4)}; margin-bottom: ${space(2)}; @media (min-width: ${p => p.theme.breakpoints.medium}) { grid-template-columns: 1fr repeat(3, max-content); } `; const HeaderInfo = styled('div')` ${p => p.theme.overflowEllipsis}; height: 78px; `; const StyledSectionHeading = styled(SectionHeading)` margin: 0; `; const NumericSectionWrapper = styled('div')` text-align: right; `; const SectionBody = styled('div')<{overflowEllipsis?: boolean}>` font-size: ${p => p.theme.fontSizeExtraLarge}; padding: ${space(0.5)} 0; max-height: 32px; `; const SectionSubtext = styled('div')` color: ${p => p.theme.subText}; font-size: ${p => p.theme.fontSizeMedium}; `; export const SpanLabelContainer = styled('div')` ${p => p.theme.overflowEllipsis}; `; const EmptyValueContainer = styled('span')` color: ${p => p.theme.gray300}; `; const emptyValue = {'\u2014'};