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