import { css, cx } from '@emotion/css'; import React, { FC, useMemo } from 'react'; import AutoSizer from 'react-virtualized-auto-sizer'; import { GrafanaTheme2, StandardEditorProps } from '@grafana/data'; import { CodeEditor, useStyles2, CodeEditorSuggestionItem, variableSuggestionToCodeEditorSuggestion, } from '@grafana/ui'; import { PanelOptions, TextMode } from './models.gen'; export const TextPanelEditor: FC> = ({ value, onChange, context }) => { const language = useMemo(() => context.options?.mode ?? TextMode.Markdown, [context]); const styles = useStyles2(getStyles); const getSuggestions = (): CodeEditorSuggestionItem[] => { if (!context.getSuggestions) { return []; } return context.getSuggestions().map((v) => variableSuggestionToCodeEditorSuggestion(v)); }; return (
{({ width }) => { if (width === 0) { return null; } return ( ); }}
); }; const getStyles = (theme: GrafanaTheme2) => ({ editorBox: css` label: editorBox; border: 1px solid ${theme.colors.border.medium}; border-radius: ${theme.shape.borderRadius(1)}; margin: ${theme.spacing(0.5)} 0; width: 100%; `, });