import { css, cx } from '@emotion/css'; import { 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 { Options, TextMode } from './panelcfg.gen'; export const TextPanelEditor = ({ value, onChange, context }: StandardEditorProps) => { 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}`, borderRadius: theme.shape.radius.default, margin: theme.spacing(0.5, 0), width: '100%', }), });