import {Fragment, useMemo} from 'react'; import styled from '@emotion/styled'; import {Hovercard} from 'sentry/components/hovercard'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import {FullSpanDescription} from 'sentry/views/starfish/components/fullSpanDescription'; import {SpanDescriptionLink} from 'sentry/views/starfish/components/spanDescriptionLink'; import {ModuleName, SpanMetricsField} from 'sentry/views/starfish/types'; import {SQLishFormatter} from 'sentry/views/starfish/utils/sqlish/SQLishFormatter'; const formatter = new SQLishFormatter(); const {SPAN_OP} = SpanMetricsField; interface Props { description: string; moduleName: ModuleName; projectId: number; endpoint?: string; endpointMethod?: string; group?: string; spanOp?: string; } export function SpanDescriptionCell({ description: rawDescription, group, moduleName, spanOp, endpoint, endpointMethod, projectId, }: Props) { const formatterDescription = useMemo(() => { if (moduleName !== ModuleName.DB) { return rawDescription; } return formatter.toSimpleMarkup(rawDescription); }, [moduleName, rawDescription]); if (!rawDescription) { return NULL_DESCRIPTION; } const descriptionLink = ( ); if (moduleName === ModuleName.DB) { return ( } > {descriptionLink} ); } if (moduleName === ModuleName.HTTP) { return ( {t('Example')} } > {descriptionLink} ); } return descriptionLink; } const NULL_DESCRIPTION = <null>; export const WiderHovercard = styled( ({ children, className, containerClassName, ...props }: React.ComponentProps) => ( {children} ) )` &.wider { width: auto; max-width: 550px; } `; const TitleWrapper = styled('div')` margin-bottom: ${space(1)}; `; const DescriptionWrapper = styled('div')` .inline-flex { display: inline-flex; } `;