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 FullQueryDescription({group, shortDescription}: Props) {
const {
data: fullSpan,
isLoading,
isFetching,
} = useFullSpanFromTrace(group, Boolean(group));
const description = fullSpan?.description ?? shortDescription;
if (!description) {
return null;
}
return isLoading && isFetching ? (
) : (
{formatter.toString(description, {maxLineLength: LINE_LENGTH})}
);
}
interface Props {
group?: string;
shortDescription?: string;
}
const LINE_LENGTH = 60;
const PaddedSpinner = styled('div')`
padding: ${space(0)} ${space(0.5)};
`;