From 86f1ce43ad68f1a5457cf0298453e18376b75501 Mon Sep 17 00:00:00 2001 From: Julia Rechkunova Date: Mon, 4 Apr 2022 18:41:02 +0200 Subject: [PATCH] [Discover] Fix height of JSON tab in Document flyout when using Document explorer in Safari (#129348) (cherry picked from commit feab5ebde1ff1e8c7f0eccf504da72e463b8a9d1) --- .../json_code_editor/json_code_editor_common.tsx | 3 +++ .../components/doc_viewer_source/source.tsx | 13 ++++++++----- 2 files changed, 11 insertions(+), 5 deletions(-) diff --git a/src/plugins/discover/public/components/json_code_editor/json_code_editor_common.tsx b/src/plugins/discover/public/components/json_code_editor/json_code_editor_common.tsx index 07d3ec2e759a3..5c247d0fe7381 100644 --- a/src/plugins/discover/public/components/json_code_editor/json_code_editor_common.tsx +++ b/src/plugins/discover/public/components/json_code_editor/json_code_editor_common.tsx @@ -25,12 +25,14 @@ interface JsonCodeEditorCommonProps { jsonValue: string; onEditorDidMount: (editor: monaco.editor.IStandaloneCodeEditor) => void; width?: string | number; + height?: string | number; hasLineNumbers?: boolean; } export const JsonCodeEditorCommon = ({ jsonValue, width, + height, hasLineNumbers, onEditorDidMount, }: JsonCodeEditorCommonProps) => { @@ -55,6 +57,7 @@ export const JsonCodeEditorCommon = ({ { const [editor, setEditor] = useState(); + const [editorHeight, setEditorHeight] = useState(); const [jsonValue, setJsonValue] = useState(''); const { uiSettings } = useDiscoverServices(); const useNewFieldsApi = !uiSettings.get(SEARCH_FIELDS_FROM_SOURCE); @@ -59,7 +60,9 @@ export const DocViewerSource = ({ } }, [reqState, hit]); - // setting editor height based on lines height and count to stretch and fit its content + // setting editor height + // - classic view: based on lines height and count to stretch and fit its content + // - explorer: to fill the available space of the document flyout useEffect(() => { if (!editor) { return; @@ -76,12 +79,11 @@ export const DocViewerSource = ({ } if (!jsonValue || jsonValue === '') { - editorElement.style.height = '0px'; + setEditorHeight(0); } else { - editorElement.style.height = `${height}px`; + setEditorHeight(height); } - editor.layout(); - }, [editor, jsonValue, useDocExplorer]); + }, [editor, jsonValue, useDocExplorer, setEditorHeight]); const loadingState = (
@@ -128,6 +130,7 @@ export const DocViewerSource = ({ setEditor(editorNode)} />