123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- 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 = (
- <SpanDescriptionLink
- group={group}
- projectId={projectId}
- endpoint={endpoint}
- spanOp={spanOp}
- endpointMethod={endpointMethod}
- description={formatterDescription}
- />
- );
- if (moduleName === ModuleName.DB) {
- return (
- <DescriptionWrapper>
- <WiderHovercard
- position="right"
- body={
- <FullSpanDescription
- group={group}
- shortDescription={rawDescription}
- language="sql"
- />
- }
- >
- {descriptionLink}
- </WiderHovercard>
- </DescriptionWrapper>
- );
- }
- if (moduleName === ModuleName.HTTP) {
- return (
- <DescriptionWrapper>
- <WiderHovercard
- position="right"
- body={
- <Fragment>
- <TitleWrapper>{t('Example')}</TitleWrapper>
- <FullSpanDescription
- group={group}
- shortDescription={rawDescription}
- language="http"
- filters={spanOp ? {[SPAN_OP]: spanOp} : undefined}
- />
- </Fragment>
- }
- >
- {descriptionLink}
- </WiderHovercard>
- </DescriptionWrapper>
- );
- }
- return descriptionLink;
- }
- const NULL_DESCRIPTION = <span><null></span>;
- export const WiderHovercard = styled(
- ({
- children,
- className,
- containerClassName,
- ...props
- }: React.ComponentProps<typeof Hovercard>) => (
- <Hovercard
- className={(className ?? '') + ' wider'}
- containerClassName={(containerClassName ?? '') + ' inline-flex'}
- {...props}
- >
- {children}
- </Hovercard>
- )
- )`
- &.wider {
- width: auto;
- max-width: 550px;
- }
- `;
- const TitleWrapper = styled('div')`
- margin-bottom: ${space(1)};
- `;
- const DescriptionWrapper = styled('div')`
- .inline-flex {
- display: inline-flex;
- }
- `;
|