Skip to content

Commit

Permalink
[feature to main] Use new header in Maps when new home UI is enabled (o…
Browse files Browse the repository at this point in the history
…pensearch-project#656)

Signed-off-by: Junqiu Lei <[email protected]>
  • Loading branch information
junqiu-lei authored Aug 16, 2024
1 parent a433766 commit a10033d
Show file tree
Hide file tree
Showing 4 changed files with 127 additions and 65 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),

## [Unreleased 2.x](https://github.com/opensearch-project/dashboards-maps/compare/2.16...2.x)
### Features
* Conditionally use the new Page Header variant on the Maps listing page [#653](https://github.com/opensearch-project/dashboards-maps/pull/653)
* Conditionally use the new Application Header variant on the Maps visualization page [#654](https://github.com/opensearch-project/dashboards-maps/pull/654)
* Conditionally use full width for Maps listing page table [#655](https://github.com/opensearch-project/dashboards-maps/pull/655)
### Enhancements
### Bug Fixes
### Infrastructure
Expand Down
77 changes: 49 additions & 28 deletions public/components/map_top_nav/get_top_nav_config.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

import React from 'react';
import { i18n } from '@osd/i18n';
import { TopNavMenuData } from '../../../../../src/plugins/navigation/public';
import { TopNavMenuData, TopNavMenuIconData } from '../../../../../src/plugins/navigation/public';
import {
SavedObjectSaveModalOrigin,
showSaveModal,
Expand All @@ -25,6 +25,7 @@ interface GetTopNavConfigParams {
setDescription: (description: string) => void;
mapState: MapState;
originatingApp?: string;
showActionsInGroup: boolean;
}

export const getTopNavConfig = (
Expand All @@ -38,6 +39,7 @@ export const getTopNavConfig = (
setDescription,
mapState,
originatingApp,
showActionsInGroup,
}: GetTopNavConfigParams
) => {
const {
Expand All @@ -46,6 +48,51 @@ export const getTopNavConfig = (
scopedHistory,
} = services;
const stateTransfer = embeddable.getStateTransfer(scopedHistory);
const onSaveButtonClick = () => {
const documentInfo = {
title,
description,
};
const saveModal = (
<SavedObjectSaveModalOrigin
documentInfo={documentInfo}
onSave={onGetSave(
title,
originatingApp,
mapIdFromUrl,
services,
layers,
mapState,
setTitle,
setDescription
)}
objectType={'map'}
onClose={() => {}}
originatingApp={originatingApp}
getAppNameFromId={stateTransfer.getAppNameFromId}
/>
);
showSaveModal(saveModal, I18nContext);
};

if (showActionsInGroup) {
const topNavConfig: TopNavMenuIconData[] = [
{
tooltip: i18n.translate('maps.topNav.saveMapButtonLabel', {
defaultMessage: `Save`,
}),
ariaLabel: i18n.translate('maps.topNav.saveButtonAriaLabel', {
defaultMessage: 'Save your map',
}),
testId: 'mapSaveButton',
run: onSaveButtonClick,
iconType: 'save',
controlType: 'icon',
},
];
return topNavConfig;
}

const topNavConfig: TopNavMenuData[] = [
{
iconType: 'save',
Expand All @@ -55,33 +102,7 @@ export const getTopNavConfig = (
defaultMessage: `Save`,
}),
testId: 'mapSaveButton',
run: (_anchorElement: any) => {
const documentInfo = {
title,
description,
};

const saveModal = (
<SavedObjectSaveModalOrigin
documentInfo={documentInfo}
onSave={onGetSave(
title,
originatingApp,
mapIdFromUrl,
services,
layers,
mapState,
setTitle,
setDescription
)}
objectType={'map'}
onClose={() => {}}
originatingApp={originatingApp}
getAppNameFromId={stateTransfer.getAppNameFromId}
/>
);
showSaveModal(saveModal, I18nContext);
},
run: onSaveButtonClick,
},
];
return topNavConfig;
Expand Down
19 changes: 18 additions & 1 deletion public/components/map_top_nav/top_nav_menu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ import { getSavedMapBreadcrumbs } from '../../utils/breadcrumbs';
import { handleDataLayerRender } from '../../model/layerRenderController';
import { MapLayerSpecification } from '../../model/mapLayerType';
import { MapState } from '../../model/mapState';
import { HeaderVariant } from '../../../../../src/core/public';
import { TopNavMenuItemRenderType } from '../../../../../src/plugins/navigation/public';

interface MapTopNavMenuProps {
mapIdFromUrl: string;
Expand Down Expand Up @@ -48,6 +50,7 @@ export const MapTopNavMenu = ({
application: { navigateToApp },
embeddable,
scopedHistory,
uiSettings,
} = services;

const [title, setTitle] = useState<string>('');
Expand All @@ -65,6 +68,17 @@ export const MapTopNavMenu = ({
},
[chrome, navigateToApp]
);
const showActionsInGroup = uiSettings.get('home:useNewHomePage');

useEffect(() => {
if (showActionsInGroup) {
chrome.setHeaderVariant?.(HeaderVariant.APPLICATION);
}

return () => {
chrome.setHeaderVariant?.();
};
}, [chrome.setHeaderVariant, showActionsInGroup]);

useEffect(() => {
const { originatingApp: value } =
Expand Down Expand Up @@ -129,6 +143,7 @@ export const MapTopNavMenu = ({
setDescription,
mapState,
originatingApp,
showActionsInGroup,
});
}, [services, mapIdFromUrl, layers, title, description, mapState, originatingApp]);

Expand All @@ -139,7 +154,7 @@ export const MapTopNavMenu = ({
config={config}
setMenuMountPoint={setHeaderActionMenu}
indexPatterns={layersIndexPatterns || []}
showSearchBar={true}
showSearchBar={TopNavMenuItemRenderType.IN_PORTAL}
showFilterBar={false}
showDatePicker={true}
showQueryBar={true}
Expand All @@ -153,6 +168,8 @@ export const MapTopNavMenu = ({
refreshInterval={refreshIntervalValue}
onRefresh={refreshDataLayerRender}
onRefreshChange={onRefreshChange}
groupActions={showActionsInGroup}
screenTitle={title}
/>
);
};
93 changes: 57 additions & 36 deletions public/components/maps_list/maps_list.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,6 @@ import { i18n } from '@osd/i18n';
import React, { useCallback, useEffect } from 'react';
import { I18nProvider } from '@osd/i18n/react';
import {
EuiPage,
EuiPageBody,
EuiPageContentBody,
EuiLink,
EuiSmallButton,
EuiPageHeader,
Expand All @@ -30,10 +27,17 @@ export const MapsList = () => {
savedObjects: { client: savedObjectsClient },
application: { navigateToApp },
chrome: { docTitle, setBreadcrumbs },
uiSettings,
navigation: {
ui: { HeaderControl },
},
application,
},
} = useOpenSearchDashboards<MapServices>();

useEffect(() => {
const newHomePageEnabled = uiSettings.get('home:useNewHomePage');

useEffect(() => {
setBreadcrumbs(getMapsLandingBreadcrumbs(navigateToApp));
docTitle.change(i18n.translate('maps.listing.pageTitle', { defaultMessage: 'Maps' }));
}, [docTitle, navigateToApp, setBreadcrumbs]);
Expand Down Expand Up @@ -106,44 +110,61 @@ export const MapsList = () => {
<EuiPageHeader
pageTitle="Create your first map"
description="There is no map to display, let's create your first map."
rightSideItems={[
<EuiSmallButton fill onClick={navigateToCreateMapPage}>
Create map
</EuiSmallButton>,
]}
rightSideItems={
newHomePageEnabled ? [] : [
<EuiSmallButton
fill
onClick={navigateToCreateMapPage}
data-test-subj="createFirstMapButton"
>
Create map
</EuiSmallButton>
]
}
/>
);

return (
// @ts-ignore
<I18nProvider>
<>
<EuiPage restrictWidth="1000px">
<EuiPageBody component="main" data-test-subj="mapListingPage">
<EuiPageContentBody>
<TableListView
headingId="mapsListingHeading"
createItem={navigateToCreateMapPage}
findItems={fetchMaps}
deleteItems={deleteMaps}
tableColumns={tableColumns}
listingLimit={10}
initialPageSize={10}
initialFilter={''}
noItemsFragment={noMapItem}
entityName={i18n.translate('maps.listing.table.entityName', {
defaultMessage: 'map',
})}
entityNamePlural={i18n.translate('maps.listing.table.entityNamePlural', {
defaultMessage: 'maps',
})}
tableListTitle={i18n.translate('maps.listing.table.listTitle', {
defaultMessage: 'Maps',
})}
toastNotifications={notifications.toasts}
/>
</EuiPageContentBody>
</EuiPageBody>
</EuiPage>
{newHomePageEnabled &&
// @ts-ignore
<HeaderControl
setMountPoint={application.setAppRightControls}
controls={[
{
id: 'Create map',
label: 'Create map',
iconType: 'plus',
fill: true,
href: `${MAPS_APP_ID}${APP_PATH.CREATE_MAP}`,
testId: 'createButton',
controlType: 'button',
},
]}
/>}
<TableListView
headingId="mapsListingHeading"
createItem= { newHomePageEnabled ? undefined : navigateToCreateMapPage }
findItems={fetchMaps}
deleteItems={deleteMaps}
tableColumns={tableColumns}
listingLimit={10}
initialPageSize={10}
initialFilter={''}
noItemsFragment={noMapItem}
entityName={i18n.translate('maps.listing.table.entityName', {
defaultMessage: 'map',
})}
entityNamePlural={i18n.translate('maps.listing.table.entityNamePlural', {
defaultMessage: 'maps',
})}
tableListTitle={newHomePageEnabled ? '' : i18n.translate('maps.listing.table.listTitle', {
defaultMessage: 'Maps'})}
toastNotifications={notifications.toasts}
restrictWidth={newHomePageEnabled ? false : true}
/>
</>
</I18nProvider>
);
Expand Down

0 comments on commit a10033d

Please sign in to comment.