import {CSSProperties} from 'react'; import {Link} from 'react-router'; import GridEditable, {GridColumnHeader} from 'sentry/components/gridEditable'; import {useLocation} from 'sentry/utils/useLocation'; import {DurationComparisonCell} from 'sentry/views/starfish/components/samplesTable/common'; import {DurationCell} from 'sentry/views/starfish/components/tableCells/durationCell'; import { OverflowEllipsisTextContainer, TextAlignRight, } from 'sentry/views/starfish/components/textAlign'; import {SpanSample} from 'sentry/views/starfish/queries/useSpanSamples'; type Keys = | 'transaction_id' | 'timestamp' | 'duration' | 'p95_comparison' | 'avg_comparison'; type TableColumnHeader = GridColumnHeader; const COLUMN_ORDER: TableColumnHeader[] = [ { key: 'transaction_id', name: 'Event ID', width: 200, }, { key: 'duration', name: 'Span Duration', width: 200, }, { key: 'avg_comparison', name: 'Compared to Average', width: 200, }, ]; type SpanTableRow = { op: string; transaction: { id: string; 'project.name': string; timestamp: string; 'transaction.duration': number; }; } & SpanSample; type Props = { avg: number; data: SpanTableRow[]; isLoading: boolean; highlightedSpanId?: string; onMouseLeaveSample?: () => void; onMouseOverSample?: (sample: SpanSample) => void; }; export function SpanSamplesTable({ isLoading, data, avg, highlightedSpanId, onMouseLeaveSample, onMouseOverSample, }: Props) { const location = useLocation(); function handleMouseOverBodyCell(row: SpanTableRow) { if (onMouseOverSample) { onMouseOverSample(row); } } function handleMouseLeave() { if (onMouseLeaveSample) { onMouseLeaveSample(); } } function renderHeadCell(column: GridColumnHeader): React.ReactNode { if ( column.key === 'p95_comparison' || column.key === 'avg_comparison' || column.key === 'duration' ) { return ( {column.name} ); } return {column.name}; } function renderBodyCell(column: GridColumnHeader, row: SpanTableRow): React.ReactNode { const shouldHighlight = row.span_id === highlightedSpanId; const commonProps = { style: (shouldHighlight ? {fontWeight: 'bold'} : {}) satisfies CSSProperties, onMouseEnter: () => handleMouseOverBodyCell(row), }; if (column.key === 'transaction_id') { return ( {row['transaction.id'].slice(0, 8)} ); } if (column.key === 'duration') { return ( ); } if (column.key === 'avg_comparison') { return ( ); } return {row[column.key]}; } return (
); }