From 87e62761fad587b594ebccb295b7d3cced279f01 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Wed, 25 Sep 2024 20:18:58 +0000 Subject: [PATCH] Update data explorer ui to use compressed components (#8222) * update discover ui to use compressed components Signed-off-by: Shenoy Pratik * revert query editor changes Signed-off-by: Shenoy Pratik * Changeset file for PR #8222 created/updated * update overflow prop for query editor Signed-off-by: Shenoy Pratik * update language selector snapshots Signed-off-by: Shenoy Pratik --------- Signed-off-by: Shenoy Pratik Co-authored-by: opensearch-changeset-bot[bot] <154024398+opensearch-changeset-bot[bot]@users.noreply.github.com> (cherry picked from commit 8d455306ebdcb21ba8e4d2be49008289ee9a7c61) Signed-off-by: github-actions[bot] --- changelogs/fragments/8222.yml | 2 + .../data_selector_refresher.tsx | 48 +++-- .../datasource_selectable.tsx | 8 +- .../ui/dataset_selector/dataset_selector.tsx | 10 +- .../language_selector.test.tsx.snap | 166 ++++++++++-------- .../public/ui/query_editor/_query_editor.scss | 27 +-- .../public/ui/query_editor/editors/shared.tsx | 4 +- .../ui/query_editor/language_selector.tsx | 16 +- .../ui/query_string_input/_query_bar.scss | 4 + .../sidebar/discover_field_search.tsx | 39 ++-- .../components/sidebar/discover_sidebar.scss | 5 + 11 files changed, 159 insertions(+), 170 deletions(-) create mode 100644 changelogs/fragments/8222.yml diff --git a/changelogs/fragments/8222.yml b/changelogs/fragments/8222.yml new file mode 100644 index 000000000000..e617e5983556 --- /dev/null +++ b/changelogs/fragments/8222.yml @@ -0,0 +1,2 @@ +fix: +- Update data explorer ui to use compressed components ([#8222](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/8222)) \ No newline at end of file diff --git a/src/plugins/data/public/data_sources/datasource_selector/data_selector_refresher.tsx b/src/plugins/data/public/data_sources/datasource_selector/data_selector_refresher.tsx index bab5f1524584..e066d65bd8a9 100644 --- a/src/plugins/data/public/data_sources/datasource_selector/data_selector_refresher.tsx +++ b/src/plugins/data/public/data_sources/datasource_selector/data_selector_refresher.tsx @@ -3,15 +3,9 @@ * SPDX-License-Identifier: Apache-2.0 */ -import React from 'react'; +import { EuiButtonIconProps, EuiSmallButtonIcon, EuiToolTip, EuiToolTipProps } from '@elastic/eui'; import { i18n } from '@osd/i18n'; -import { - EuiSmallButtonIcon, - EuiButtonIconProps, - EuiText, - EuiToolTip, - EuiToolTipProps, -} from '@elastic/eui'; +import React from 'react'; interface IDataSelectorRefresherProps { tooltipText: string; @@ -23,26 +17,24 @@ interface IDataSelectorRefresherProps { export const DataSelectorRefresher: React.FC = React.memo( ({ tooltipText, onRefresh, buttonProps, toolTipProps }) => { return ( - - - - - + + + ); } ); diff --git a/src/plugins/data/public/data_sources/datasource_selector/datasource_selectable.tsx b/src/plugins/data/public/data_sources/datasource_selector/datasource_selectable.tsx index e826cbe18af1..8e59ac910095 100644 --- a/src/plugins/data/public/data_sources/datasource_selector/datasource_selectable.tsx +++ b/src/plugins/data/public/data_sources/datasource_selector/datasource_selectable.tsx @@ -3,17 +3,17 @@ * SPDX-License-Identifier: Apache-2.0 */ -import React, { useEffect, useCallback, useMemo } from 'react'; import { EuiCompressedComboBox } from '@elastic/eui'; import { i18n } from '@osd/i18n'; -import { DataSource, DataSetWithDataSource, IndexPatternOption } from '../datasource'; -import { DataSourceGroup, DataSourceOption, DataSourceSelectableProps } from './types'; -import { DataSelectorRefresher } from './data_selector_refresher'; +import React, { useCallback, useEffect, useMemo } from 'react'; import { DATA_SELECTOR_DEFAULT_PLACEHOLDER, DATA_SELECTOR_REFRESHER_POPOVER_TEXT, DATA_SELECTOR_S3_DATA_SOURCE_GROUP_HINT_LABEL, } from '../constants'; +import { DataSetWithDataSource, DataSource, IndexPatternOption } from '../datasource'; +import { DataSelectorRefresher } from './data_selector_refresher'; +import { DataSourceGroup, DataSourceOption, DataSourceSelectableProps } from './types'; // Asynchronously retrieves and formats dataset from a given data source. const getAndFormatDataSetFromDataSource = async ( diff --git a/src/plugins/data/public/ui/dataset_selector/dataset_selector.tsx b/src/plugins/data/public/ui/dataset_selector/dataset_selector.tsx index d442360e4d59..817d0734c4d2 100644 --- a/src/plugins/data/public/ui/dataset_selector/dataset_selector.tsx +++ b/src/plugins/data/public/ui/dataset_selector/dataset_selector.tsx @@ -3,23 +3,23 @@ * SPDX-License-Identifier: Apache-2.0 */ -import React, { useEffect, useMemo, useState, useCallback, useRef } from 'react'; import { EuiButton, - EuiButtonEmpty, EuiIcon, EuiPopover, EuiPopoverFooter, EuiSelectable, EuiSelectableOption, + EuiSmallButtonEmpty, EuiToolTip, } from '@elastic/eui'; import { FormattedMessage } from '@osd/i18n/react'; +import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react'; import { toMountPoint } from '../../../../opensearch_dashboards_react/public'; import { Dataset, DEFAULT_DATA } from '../../../common'; +import { getQueryService } from '../../services'; import { IDataPluginServices } from '../../types'; import { AdvancedSelector } from './advanced_selector'; -import { getQueryService } from '../../services'; interface DatasetSelectorProps { selectedDataset?: Dataset; @@ -133,7 +133,7 @@ export const DatasetSelector = ({ - {datasetTitle} - + } isOpen={isOpen} diff --git a/src/plugins/data/public/ui/query_editor/__snapshots__/language_selector.test.tsx.snap b/src/plugins/data/public/ui/query_editor/__snapshots__/language_selector.test.tsx.snap index fd8aa75f7344..a677567d113c 100644 --- a/src/plugins/data/public/ui/query_editor/__snapshots__/language_selector.test.tsx.snap +++ b/src/plugins/data/public/ui/query_editor/__snapshots__/language_selector.test.tsx.snap @@ -492,7 +492,7 @@ exports[`LanguageSelector should select DQL if language is kuery 1`] = ` DQL - + } className="languageSelector" closePopover={[Function]} @@ -516,57 +516,66 @@ exports[`LanguageSelector should select DQL if language is kuery 1`] = `
- - - + + + +
@@ -1066,7 +1075,7 @@ exports[`LanguageSelector should select lucene if language is lucene 1`] = ` Lucene - + } className="languageSelector" closePopover={[Function]} @@ -1090,57 +1099,66 @@ exports[`LanguageSelector should select lucene if language is lucene 1`] = `
- - - + + + +
diff --git a/src/plugins/data/public/ui/query_editor/_query_editor.scss b/src/plugins/data/public/ui/query_editor/_query_editor.scss index e9655d245fde..b884788861c6 100644 --- a/src/plugins/data/public/ui/query_editor/_query_editor.scss +++ b/src/plugins/data/public/ui/query_editor/_query_editor.scss @@ -64,26 +64,10 @@ } } -.osdQueryEditor__dataSetWrapper { - max-width: 350px; - - .dataExplorerDSSelect { - border-bottom: $euiBorderThin !important; - min-width: 300px; - - span:is([class$="__text"]) { - width: 350px; - text-align: left; - } - - div:is([class$="--group"]) { - padding: 0 !important; - } - - .sourceRefreshText { - max-height: 40px; - } - } +// TODO: ths is a temporary fix to make sure the height is set to auto +// Can remove this once, height issue is fixed for combo box append in Oui +.dataExplorerDSSelect .euiFormControlLayout.euiFormControlLayout--group > .euiToolTipAnchor { + height: auto; } .osdQueryEditor__prependWrapper { @@ -159,7 +143,6 @@ .osdQueryEditor__topBar { display: flex; align-items: center; - padding: $euiSizeXS; > * { flex: 0 1 auto; @@ -197,7 +180,7 @@ } .osdQuerEditor__singleLine { - padding: $euiSizeS; + padding: calc($euiSizeXS + 1px); background-color: $euiColorEmptyShade; overflow: initial !important; // needed for suggestion window, otherwise will be hidden in child diff --git a/src/plugins/data/public/ui/query_editor/editors/shared.tsx b/src/plugins/data/public/ui/query_editor/editors/shared.tsx index 32cb0aa18a59..ab7ad44bbf7d 100644 --- a/src/plugins/data/public/ui/query_editor/editors/shared.tsx +++ b/src/plugins/data/public/ui/query_editor/editors/shared.tsx @@ -3,9 +3,9 @@ * SPDX-License-Identifier: Apache-2.0 */ -import React from 'react'; import { EuiCompressedFieldText } from '@elastic/eui'; import { monaco } from '@osd/monaco'; +import React from 'react'; import { CodeEditor } from '../../../../../opensearch_dashboards_react/public'; interface SingleLineInputProps extends React.JSX.IntrinsicAttributes { @@ -62,7 +62,7 @@ export const SingleLineInput: React.FC = ({ provideCompletionItems, prepend, }) => ( -
+
{prepend}
{ { iconType="arrowDown" > {selectedLanguage.label} - + } isOpen={isPopoverOpen} closePopover={() => setPopover(false)} diff --git a/src/plugins/data/public/ui/query_string_input/_query_bar.scss b/src/plugins/data/public/ui/query_string_input/_query_bar.scss index f9849063f072..0e0ae47a22b7 100644 --- a/src/plugins/data/public/ui/query_string_input/_query_bar.scss +++ b/src/plugins/data/public/ui/query_string_input/_query_bar.scss @@ -16,6 +16,10 @@ .euiToolTipAnchor { height: 100%; } + + &.euiFormControlLayout--group.euiFormControlLayout--compressed { + overflow: initial; + } } // Uses the append style, but no bordering diff --git a/src/plugins/discover/public/application/components/sidebar/discover_field_search.tsx b/src/plugins/discover/public/application/components/sidebar/discover_field_search.tsx index 2e726eb0e964..3469fd1d34dc 100644 --- a/src/plugins/discover/public/application/components/sidebar/discover_field_search.tsx +++ b/src/plugins/discover/public/application/components/sidebar/discover_field_search.tsx @@ -28,29 +28,27 @@ * under the License. */ -import React, { OptionHTMLAttributes, ReactNode, useState } from 'react'; -import { i18n } from '@osd/i18n'; import { + EuiButtonGroup, EuiCompressedFieldSearch, + EuiCompressedSwitch, + EuiFilterGroup, EuiFlexGroup, EuiFlexItem, - EuiPopover, - EuiPopoverFooter, - EuiPopoverTitle, - EuiSelect, - EuiCompressedSwitch, - EuiSwitchEvent, EuiForm, EuiFormRow, - EuiButtonGroup, EuiOutsideClickDetector, EuiPanel, + EuiPopover, + EuiPopoverFooter, + EuiPopoverTitle, + EuiSelect, EuiSmallFilterButton, - EuiFilterGroup, - EuiFieldSearch, + EuiSwitchEvent, } from '@elastic/eui'; +import { i18n } from '@osd/i18n'; import { FormattedMessage } from '@osd/i18n/react'; -import { UI_SETTINGS } from 'src/plugins/data/common'; +import React, { OptionHTMLAttributes, ReactNode, useState } from 'react'; export const NUM_FILTERS = 3; @@ -257,19 +255,6 @@ export function DiscoverFieldSearch({ onChange={(event) => onChange('name', event.currentTarget.value)} placeholder={searchPlaceholder} value={value} - /> - - ); - - const fieldSearch = ( - {}} isDisabled={!isPopoverOpen}> - onChange('name', event.currentTarget.value)} - placeholder={searchPlaceholder} - value={value} className="dscSideBar_searchInput" /> @@ -329,8 +314,8 @@ export function DiscoverFieldSearch({ if (isEnhancementsEnabledOverride) { return ( -
- {fieldSearch} +
+ {compressedFieldSearch} {fieldPopover}
); diff --git a/src/plugins/discover/public/application/components/sidebar/discover_sidebar.scss b/src/plugins/discover/public/application/components/sidebar/discover_sidebar.scss index 201debc95534..aaba1c5a42aa 100644 --- a/src/plugins/discover/public/application/components/sidebar/discover_sidebar.scss +++ b/src/plugins/discover/public/application/components/sidebar/discover_sidebar.scss @@ -1,3 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + .deSidebar_panel { border-left: 0;