Skip to content

Commit

Permalink
Move TopNavLinks to new Nav Bar Discover (opensearch-project#7326)
Browse files Browse the repository at this point in the history
Signed-off-by: Suchit Sahoo <[email protected]>
(cherry picked from commit e46e54a)
  • Loading branch information
LDrago27 committed Jul 24, 2024
1 parent 6119fb8 commit e3dbf9e
Show file tree
Hide file tree
Showing 16 changed files with 219 additions and 66 deletions.
2 changes: 2 additions & 0 deletions src/core/public/application/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -539,6 +539,8 @@ export interface AppMountParameters<HistoryLocationState = unknown> {
* Optional datasource id to pass while mounting app
*/
dataSourceId?: string;

optionalRef?: Record<string, React.RefObject<HTMLDivElement>>;
}

/**
Expand Down
17 changes: 15 additions & 2 deletions src/plugins/data/public/ui/query_editor/query_editor_top_row.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@ import {
} from '@elastic/eui';
import classNames from 'classnames';
import { compact, isEqual } from 'lodash';
import React, { useRef, useState } from 'react';
import React, { useState } from 'react';
import { createPortal } from 'react-dom';
import {
DataSource,
IDataPluginServices,
Expand Down Expand Up @@ -63,6 +64,7 @@ export interface QueryEditorTopRowProps {
isDirty: boolean;
timeHistory?: TimeHistoryContract;
indicateNoData?: boolean;
datePickerRef?: React.RefObject<HTMLDivElement>;
}

// Needed for React.lazy
Expand Down Expand Up @@ -300,7 +302,7 @@ export default function QueryEditorTopRow(props: QueryEditorTopRowProps) {

return (
<NoDataPopover storage={storage} showNoDataPopover={props.indicateNoData}>
<EuiFlexGroup responsive={false} gutterSize="s">
<EuiFlexGroup responsive={false} gutterSize="s" alignItems="flexStart">
{renderDatePicker()}
<EuiFlexItem grow={false}>{button}</EuiFlexItem>
</EuiFlexGroup>
Expand Down Expand Up @@ -365,6 +367,14 @@ export default function QueryEditorTopRow(props: QueryEditorTopRowProps) {
'osdQueryEditor--withDatePicker': props.showDatePicker,
});

const datePicker = (
<EuiFlexGroup justifyContent="flexEnd" gutterSize="none" responsive={false}>
<EuiFlexItem grow={false} className="osdQueryEditor--updateButtonWrapper">
{renderUpdateButton()}
</EuiFlexItem>
</EuiFlexGroup>
);

return (
<EuiFlexGroup
className={classes}
Expand All @@ -373,6 +383,9 @@ export default function QueryEditorTopRow(props: QueryEditorTopRowProps) {
direction="column"
justifyContent="flexEnd"
>
{props?.datePickerRef?.current && uiSettings.get(UI_SETTINGS.QUERY_ENHANCEMENTS_ENABLED)
? createPortal(datePicker, props.datePickerRef.current)
: datePicker}
{renderQueryEditor()}
<EuiFlexItem>
<EuiFlexGroup responsive={false} gutterSize="none">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ import {
import { EuiSuperUpdateButton, OnRefreshProps, EuiText } from '@elastic/eui';
import { FormattedMessage } from '@osd/i18n/react';
import { Toast } from 'src/core/public';
import { createPortal } from 'react-dom';
import { IDataPluginServices, IIndexPattern, TimeRange, TimeHistoryContract, Query } from '../..';
import {
useOpenSearchDashboards,
Expand Down Expand Up @@ -83,6 +84,7 @@ export interface QueryBarTopRowProps {
isDirty: boolean;
timeHistory?: TimeHistoryContract;
indicateNoData?: boolean;
datePickerRef?: React.RefObject<HTMLDivElement>;
}

// Needed for React.lazy
Expand Down Expand Up @@ -262,7 +264,7 @@ export default function QueryBarTopRow(props: QueryBarTopRowProps) {

return (
<NoDataPopover storage={storage} showNoDataPopover={props.indicateNoData}>
<EuiFlexGroup responsive={false} gutterSize="s">
<EuiFlexGroup responsive={false} gutterSize="s" alignItems="flexStart">
{renderDatePicker()}
<EuiFlexItem grow={false}>{button}</EuiFlexItem>
</EuiFlexGroup>
Expand Down Expand Up @@ -393,7 +395,11 @@ export default function QueryBarTopRow(props: QueryBarTopRowProps) {
>
{renderQueryInput()}
{renderSharingMetaFields()}
<EuiFlexItem grow={false}>{renderUpdateButton()}</EuiFlexItem>
<EuiFlexItem grow={false}>
{props?.datePickerRef?.current && uiSettings.get(UI_SETTINGS.QUERY_ENHANCEMENTS_ENABLED)
? createPortal(renderUpdateButton(), props.datePickerRef.current)
: renderUpdateButton()}
</EuiFlexItem>
</EuiFlexGroup>
</>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,7 @@ export function createSearchBar({
onClearSavedQuery={defaultOnClearSavedQuery(props, clearSavedQuery)}
onSavedQueryUpdated={defaultOnSavedQueryUpdated(props, setSavedQuery)}
onSaved={defaultOnSavedQueryUpdated(props, setSavedQuery)}
datePickerRef={props.datePickerRef}
{...overrideDefaultBehaviors(props)}
/>
</OpenSearchDashboardsContextProvider>
Expand Down
3 changes: 3 additions & 0 deletions src/plugins/data/public/ui/search_bar/search_bar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ export interface SearchBarOwnProps {
refreshInterval?: number;
dateRangeFrom?: string;
dateRangeTo?: string;
datePickerRef?: React.RefObject<HTMLDivElement>;
// Query bar - should be in SearchBarInjectedDeps
query?: Query;
settings?: Settings;
Expand Down Expand Up @@ -481,6 +482,7 @@ class SearchBarUI extends Component<SearchBarProps, State> {
}
dataTestSubj={this.props.dataTestSubj}
indicateNoData={this.props.indicateNoData}
datePickerRef={this.props.datePickerRef}
/>
);
}
Expand Down Expand Up @@ -516,6 +518,7 @@ class SearchBarUI extends Component<SearchBarProps, State> {
filterBar={filterBar}
dataTestSubj={this.props.dataTestSubj}
indicateNoData={this.props.indicateNoData}
datePickerRef={this.props.datePickerRef}
/>
);
}
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

10 changes: 10 additions & 0 deletions src/plugins/data_explorer/public/components/app_container.scss
Original file line number Diff line number Diff line change
Expand Up @@ -20,3 +20,13 @@ $osdHeaderOffset: $euiHeaderHeightCompensation;
.headerIsExpanded .deLayout {
height: calc(100vh - #{$osdHeaderOffset * 2});
}

.mainPage {
overflow-x: hidden;
overflow-y: auto;

.navBar {
padding: $euiSizeXS $euiSizeXS $euiSizeXS $euiSizeM;
border-bottom: $euiBorderThin;
}
}
108 changes: 76 additions & 32 deletions src/plugins/data_explorer/public/components/app_container.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,20 +3,35 @@
* SPDX-License-Identifier: Apache-2.0
*/

import React, { memo } from 'react';
import { EuiPage, EuiPageBody, EuiResizableContainer, useIsWithinBreakpoints } from '@elastic/eui';
import React, { memo, useRef } from 'react';
import {
EuiFlexGroup,
EuiFlexItem,
EuiPage,
EuiPageBody,
EuiResizableContainer,
useIsWithinBreakpoints,
} from '@elastic/eui';
import { Suspense } from 'react';
import { AppMountParameters } from '../../../../core/public';
import { Sidebar } from './sidebar';
import { NoView } from './no_view';
import { View } from '../services/view_service/view';
import { shallowEqual } from '../utils/use/shallow_equal';
import './app_container.scss';
import { useOpenSearchDashboards } from '../../../opensearch_dashboards_react/public';
import { IDataPluginServices } from '../../../data/public';
import { QUERY_ENHANCEMENT_ENABLED_SETTING } from './constants';

export const AppContainer = React.memo(
({ view, params }: { view?: View; params: AppMountParameters }) => {
const isMobile = useIsWithinBreakpoints(['xs', 's', 'm']);
// TODO: Make this more robust.

const opensearchDashboards = useOpenSearchDashboards<IDataPluginServices>();
const { uiSettings } = opensearchDashboards.services;

const topLinkRef = useRef<HTMLDivElement>(null);
const datePickerRef = useRef<HTMLDivElement>(null);
if (!view) {
return <NoView />;
}
Expand All @@ -26,38 +41,67 @@ export const AppContainer = React.memo(
const MemoizedPanel = memo(Panel);
const MemoizedCanvas = memo(Canvas);

params.optionalRef = {
topLinkRef,
datePickerRef,
};

// Render the application DOM.
return (
<EuiPage className="deLayout" paddingSize="none">
{/* TODO: improve fallback state */}
<Suspense fallback={<div>Loading...</div>}>
<Context {...params}>
<EuiResizableContainer direction={isMobile ? 'vertical' : 'horizontal'}>
{(EuiResizablePanel, EuiResizableButton) => (
<>
<EuiResizablePanel
initialSize={20}
minSize="260px"
mode={['collapsible', { position: 'top' }]}
paddingSize="none"
>
<Sidebar>
<MemoizedPanel {...params} />
</Sidebar>
</EuiResizablePanel>
<EuiResizableButton />
<div className="mainPage">
{uiSettings?.get(QUERY_ENHANCEMENT_ENABLED_SETTING) && (
<EuiFlexGroup
direction="row"
className="mainPage navBar"
gutterSize="none"
alignItems="center"
justifyContent="spaceBetween"
>
<EuiFlexItem grow={false}>
<div ref={topLinkRef} />
</EuiFlexItem>
<EuiFlexItem grow={false}>
<div ref={datePickerRef} />
</EuiFlexItem>
</EuiFlexGroup>
)}

<EuiPage className="deLayout" paddingSize="none" grow={false}>
{/* TODO: improve fallback state */}
<Suspense fallback={<div>Loading...</div>}>
<Context {...params}>
<EuiResizableContainer direction={isMobile ? 'vertical' : 'horizontal'}>
{(EuiResizablePanel, EuiResizableButton) => (
<>
<EuiResizablePanel
initialSize={20}
minSize="260px"
mode={['collapsible', { position: 'top' }]}
paddingSize="none"
>
<Sidebar>
<MemoizedPanel {...params} />
</Sidebar>
</EuiResizablePanel>
<EuiResizableButton />

<EuiResizablePanel initialSize={80} minSize="65%" mode="main" paddingSize="none">
<EuiPageBody className="deLayout__canvas">
<MemoizedCanvas {...params} />
</EuiPageBody>
</EuiResizablePanel>
</>
)}
</EuiResizableContainer>
</Context>
</Suspense>
</EuiPage>
<EuiResizablePanel
initialSize={80}
minSize="65%"
mode="main"
paddingSize="none"
>
<EuiPageBody className="deLayout__canvas">
<MemoizedCanvas {...params} />
</EuiPageBody>
</EuiResizablePanel>
</>
)}
</EuiResizableContainer>
</Context>
</Suspense>
</EuiPage>
</div>
);
},
(prevProps, nextProps) => {
Expand Down
6 changes: 6 additions & 0 deletions src/plugins/data_explorer/public/components/constants.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
/*
* Copyright OpenSearch Contributors
* SPDX-License-Identifier: Apache-2.0
*/

export const QUERY_ENHANCEMENT_ENABLED_SETTING = 'query:enhancements:enabled';
1 change: 1 addition & 0 deletions src/plugins/discover/common/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,4 @@ export const CONTEXT_DEFAULT_SIZE_SETTING = 'context:defaultSize';
export const CONTEXT_STEP_SETTING = 'context:step';
export const CONTEXT_TIE_BREAKER_FIELDS_SETTING = 'context:tieBreakerFields';
export const MODIFY_COLUMNS_ON_SWITCH = 'discover:modifyColumnsOnSwitch';
export const QUERY_ENHANCEMENT_ENABLED_SETTING = 'query:enhancements:enabled';
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,8 @@ import { OpenSearchPanel } from './open_search_panel';
export const getTopNavLinks = (
services: DiscoverViewServices,
inspectorAdapters: Adapters,
savedSearch: SavedSearch
savedSearch: SavedSearch,
isEnhancementEnabled: boolean = false
) => {
const {
history,
Expand All @@ -44,7 +45,7 @@ export const getTopNavLinks = (
osdUrlStateStorage,
} = services;

const newSearch = {
const newSearch: TopNavMenuData = {
id: 'new',
label: i18n.translate('discover.localMenu.localMenu.newSearchTitle', {
defaultMessage: 'New',
Expand All @@ -61,6 +62,7 @@ export const getTopNavLinks = (
ariaLabel: i18n.translate('discover.topNav.discoverNewButtonLabel', {
defaultMessage: `New Search`,
}),
iconType: 'plusInCircle',
};

const saveSearch: TopNavMenuData = {
Expand Down Expand Up @@ -160,9 +162,10 @@ export const getTopNavLinks = (
);
showSaveModal(saveModal, core.i18n.Context);
},
iconType: 'save',
};

const openSearch = {
const openSearch: TopNavMenuData = {
id: 'open',
label: i18n.translate('discover.localMenu.openTitle', {
defaultMessage: 'Open',
Expand Down Expand Up @@ -190,6 +193,7 @@ export const getTopNavLinks = (
)
);
},
iconType: 'folderOpen',
};

const shareSearch: TopNavMenuData = {
Expand Down Expand Up @@ -225,9 +229,10 @@ export const getTopNavLinks = (
isDirty: !savedSearch.id || state.isDirty || false,
});
},
iconType: 'share',
};

const inspectSearch = {
const inspectSearch: TopNavMenuData = {
id: 'inspect',
label: i18n.translate('discover.localMenu.inspectTitle', {
defaultMessage: 'Inspect',
Expand All @@ -244,15 +249,28 @@ export const getTopNavLinks = (
title: savedSearch?.title || undefined,
});
},
iconType: 'inspect',
};

return [
const topNavLinksArray = [
newSearch,
...(capabilities.discover?.save ? [saveSearch] : []),
openSearch,
...(share ? [shareSearch] : []), // Show share option only if share plugin is available
inspectSearch,
];

if (!isEnhancementEnabled) {
return topNavLinksArray.map((topNavLink) => {
if (topNavLink) {
const { iconType, ...rest } = topNavLink; // Removing the Icon Type property to maintain consistency with older Nav Bar
return rest;
}
return topNavLink;
});
}

return topNavLinksArray;
};

// TODO: This does not seem to affect the share menu. need to look into it in future
Expand Down
Loading

0 comments on commit e3dbf9e

Please sign in to comment.