1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- 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 ? (
- <PaddedSpinner>
- <LoadingIndicator mini hideMessage relative />
- </PaddedSpinner>
- ) : (
- <CodeSnippet language="sql">
- {formatter.toString(description, {maxLineLength: LINE_LENGTH})}
- </CodeSnippet>
- );
- }
- interface Props {
- group?: string;
- shortDescription?: string;
- }
- const LINE_LENGTH = 60;
- const PaddedSpinner = styled('div')`
- padding: ${space(0)} ${space(0.5)};
- `;
|