import {Fragment} from 'react';
import styled from '@emotion/styled';
import {CodeSnippet} from 'sentry/components/codeSnippet';
import LoadingIndicator from 'sentry/components/loadingIndicator';
import {space} from 'sentry/styles/space';
import {useFullSpanFromTrace} from 'sentry/views/starfish/queries/useFullSpanFromTrace';
import {SQLishFormatter} from 'sentry/views/starfish/utils/sqlish/SQLishFormatter';
const formatter = new SQLishFormatter();
export function FullSpanDescription({group, shortDescription, language, filters}: Props) {
const {
data: fullSpan,
isLoading,
isFetching,
} = useFullSpanFromTrace(group, undefined, Boolean(group), filters);
const description = fullSpan?.description ?? shortDescription;
if (isLoading && isFetching) {
return (
);
}
if (!description) {
return null;
}
if (language === 'sql') {
return (
{formatter.toString(description, {maxLineLength: LINE_LENGTH})}
);
}
if (language) {
return {description};
}
return {description};
}
interface Props {
filters?: Record;
group?: string;
language?: 'sql' | 'http';
shortDescription?: string;
}
const LINE_LENGTH = 60;
const PaddedSpinner = styled('div')`
padding: ${space(0)} ${space(0.5)};
`;