From 23d2c5cd90e6c24ed9ce05b509920f52787d08f5 Mon Sep 17 00:00:00 2001 From: "opensearch-trigger-bot[bot]" <98922864+opensearch-trigger-bot[bot]@users.noreply.github.com> Date: Wed, 24 Jul 2024 16:44:31 +0800 Subject: [PATCH] fix breadcrumbs not set properly when out a workspace (#7432) (#7434) (cherry picked from commit f872b0255bc707fa45a076bdaff9d2930edc52df) Signed-off-by: Hailong Cui Signed-off-by: github-actions[bot] Co-authored-by: github-actions[bot] --- .../public/components/workspace_detail_app.tsx | 4 ++++ src/plugins/workspace/public/utils.test.ts | 2 +- src/plugins/workspace/public/utils.ts | 12 ++++++++++-- 3 files changed, 15 insertions(+), 3 deletions(-) diff --git a/src/plugins/workspace/public/components/workspace_detail_app.tsx b/src/plugins/workspace/public/components/workspace_detail_app.tsx index 2236cd67c139..294851502567 100644 --- a/src/plugins/workspace/public/components/workspace_detail_app.tsx +++ b/src/plugins/workspace/public/components/workspace_detail_app.tsx @@ -5,6 +5,7 @@ import React, { useEffect } from 'react'; import { I18nProvider } from '@osd/i18n/react'; +import { i18n } from '@osd/i18n'; import { CoreStart } from 'opensearch-dashboards/public'; import { useObservable } from 'react-use'; import { EuiBreadcrumb } from '@elastic/eui'; @@ -34,6 +35,9 @@ export const WorkspaceDetailApp = (props: WorkspaceDetailProps) => { breadcrumbs.push({ text: currentWorkspace.name, }); + breadcrumbs.push({ + text: i18n.translate('workspace.detail.breadcrumb', { defaultMessage: 'Workspace Detail' }), + }); } chrome?.setBreadcrumbs(breadcrumbs); }, [chrome, currentWorkspace, application]); diff --git a/src/plugins/workspace/public/utils.test.ts b/src/plugins/workspace/public/utils.test.ts index 5c91effc4146..0f31a70722a1 100644 --- a/src/plugins/workspace/public/utils.test.ts +++ b/src/plugins/workspace/public/utils.test.ts @@ -515,7 +515,7 @@ describe('workspace utils: prependWorkspaceToBreadcrumbs', () => { it('should not enrich breadcrumbs when out a workspace', async () => { const coreStart = coreMock.createStart(); prependWorkspaceToBreadcrumbs(coreStart, null, 'app1', undefined, {}); - expect(coreStart.chrome.setBreadcrumbsEnricher).toHaveBeenCalledWith(undefined); + expect(coreStart.chrome.setBreadcrumbsEnricher).not.toHaveBeenCalled(); }); it('should enrich breadcrumbs when in a workspace and use workspace use case as current nav group', async () => { diff --git a/src/plugins/workspace/public/utils.ts b/src/plugins/workspace/public/utils.ts index e1093495c049..8e0846a7593a 100644 --- a/src/plugins/workspace/public/utils.ts +++ b/src/plugins/workspace/public/utils.ts @@ -295,6 +295,16 @@ export function prependWorkspaceToBreadcrumbs( core.chrome.setBreadcrumbsEnricher(undefined); return; } + + /** + * There has 3 cases + * nav group is enable + workspace enable + in a workspace -> workspace enricher + * nav group is enable + workspace enable + out a workspace -> nav group enricher + * nav group is enable + workspace disabled -> nav group enricher + * + * switch workspace will cause page refresh, breadcrumbs enricher will reset automatically + * so we don't need to have reset logic for workspace + */ if (currentWorkspace) { const useCase = getFirstUseCaseOfFeatureConfigs(currentWorkspace?.features || []); // get workspace the only use case @@ -336,7 +346,5 @@ export function prependWorkspaceToBreadcrumbs( return [homeBreadcrumb, navGroupBreadcrumb, ...breadcrumbs]; } }); - } else { - core.chrome.setBreadcrumbsEnricher(undefined); } }