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)}; `;