From 618a85fd48141435fbc9c0f520a77c27c74a0ae5 Mon Sep 17 00:00:00 2001 From: Hailong Cui Date: Wed, 28 Aug 2024 16:11:11 +0800 Subject: [PATCH] udpate breadcrumbs for workspace overview page Signed-off-by: Hailong Cui --- src/plugins/workspace/public/utils.test.ts | 6 ++-- src/plugins/workspace/public/utils.ts | 39 ++++++++++++++-------- 2 files changed, 28 insertions(+), 17 deletions(-) diff --git a/src/plugins/workspace/public/utils.test.ts b/src/plugins/workspace/public/utils.test.ts index dfca65fcaf98..d62fc19febd8 100644 --- a/src/plugins/workspace/public/utils.test.ts +++ b/src/plugins/workspace/public/utils.test.ts @@ -619,7 +619,7 @@ describe('workspace utils: prependWorkspaceToBreadcrumbs', () => { expect(coreStart.chrome.setBreadcrumbsEnricher).not.toHaveBeenCalled(); }); - it('should enrich breadcrumbs when in a workspace and use workspace use case as current nav group', async () => { + it('should enrich breadcrumbs when in a workspace and add workspace name into breadcrumbs', async () => { const navGroupSearch = { id: 'search', title: 'Search', @@ -647,7 +647,7 @@ describe('workspace utils: prependWorkspaceToBreadcrumbs', () => { const breadcrumbs = [{ text: 'test app' }]; let enrichedBreadcrumbs = enricher?.(breadcrumbs); expect(enrichedBreadcrumbs).toHaveLength(3); - expect(enrichedBreadcrumbs?.[1].text).toEqual('Search'); + expect(enrichedBreadcrumbs?.[1].text).toEqual('test workspace 1'); // ignore current nav group prependWorkspaceToBreadcrumbs(coreStart, workspace, 'app1', navGroupDashboards, { @@ -662,7 +662,7 @@ describe('workspace utils: prependWorkspaceToBreadcrumbs', () => { enrichedBreadcrumbs = enricher?.(breadcrumbs); expect(enrichedBreadcrumbs).toHaveLength(3); - expect(enrichedBreadcrumbs?.[1].text).toEqual('Search'); + expect(enrichedBreadcrumbs?.[1].text).toEqual('test workspace 1'); }); it('should enrich breadcrumbs when in a workspace with all use case and use selected nav group', async () => { diff --git a/src/plugins/workspace/public/utils.ts b/src/plugins/workspace/public/utils.ts index 8d4a94ea06c8..5c7ad5b26e28 100644 --- a/src/plugins/workspace/public/utils.ts +++ b/src/plugins/workspace/public/utils.ts @@ -31,6 +31,9 @@ import { SigV4ServiceName } from '../../../plugins/data_source/common/data_sourc import { ANALYTICS_ALL_OVERVIEW_PAGE_ID, ESSENTIAL_OVERVIEW_PAGE_ID, + OBSERVABILITY_OVERVIEW_PAGE_ID, + SEARCH_OVERVIEW_PAGE_ID, + SECURITY_ANALYTICS_OVERVIEW_PAGE_ID, } from '../../../plugins/content_management/public'; export const USE_CASE_PREFIX = 'use-case-'; @@ -335,6 +338,13 @@ export function prependWorkspaceToBreadcrumbs( return; } + const homeBreadcrumb: ChromeBreadcrumb = { + text: 'Home', + onClick: () => { + core.application.navigateToApp('home'); + }, + }; + /** * There has 3 cases * nav group is enable + workspace enable + in a workspace -> workspace enricher @@ -347,13 +357,16 @@ export function prependWorkspaceToBreadcrumbs( if (currentWorkspace) { // use case overview page only show workspace name if ( - appId === `${DEFAULT_NAV_GROUPS.search.id}_overview` || - appId === `${DEFAULT_NAV_GROUPS.observability.id}_overview` || - appId === `${DEFAULT_NAV_GROUPS['security-analytics'].id}_overview` || + appId === SEARCH_OVERVIEW_PAGE_ID || + appId === OBSERVABILITY_OVERVIEW_PAGE_ID || + appId === SECURITY_ANALYTICS_OVERVIEW_PAGE_ID || appId === ESSENTIAL_OVERVIEW_PAGE_ID || appId === ANALYTICS_ALL_OVERVIEW_PAGE_ID ) { - core.chrome.setBreadcrumbsEnricher((breadcrumbs) => [{ text: currentWorkspace.name }]); + core.chrome.setBreadcrumbsEnricher((breadcrumbs) => [ + homeBreadcrumb, + { text: currentWorkspace.name }, + ]); return; } const useCase = getFirstUseCaseOfFeatureConfigs(currentWorkspace?.features || []); @@ -370,22 +383,20 @@ export function prependWorkspaceToBreadcrumbs( } }, }; - const homeBreadcrumb: ChromeBreadcrumb = { - text: 'Home', + + const workspaceBreadcrumb: ChromeBreadcrumb = { + text: currentWorkspace.name, onClick: () => { - core.application.navigateToApp('home'); + if (useCase) { + const allNavGroups = navGroupsMap[useCase]; + core.application.navigateToApp(allNavGroups?.navLinks[0].id); + } }, }; core.chrome.setBreadcrumbsEnricher((breadcrumbs) => { if (!breadcrumbs || !breadcrumbs.length) return breadcrumbs; - const workspaceBreadcrumb: ChromeBreadcrumb = { - text: currentWorkspace.name, - onClick: () => { - core.application.navigateToApp(WORKSPACE_DETAIL_APP_ID); - }, - }; if (useCase === ALL_USE_CASE_ID) { if (currentNavGroup && currentNavGroup.id !== DEFAULT_NAV_GROUPS.all.id) { return [homeBreadcrumb, workspaceBreadcrumb, navGroupBreadcrumb, ...breadcrumbs]; @@ -393,7 +404,7 @@ export function prependWorkspaceToBreadcrumbs( return [homeBreadcrumb, workspaceBreadcrumb, ...breadcrumbs]; } } else { - return [homeBreadcrumb, navGroupBreadcrumb, ...breadcrumbs]; + return [homeBreadcrumb, workspaceBreadcrumb, ...breadcrumbs]; } }); }