From cb2a6e5348a1108bd937810137a654920c1b3767 Mon Sep 17 00:00:00 2001 From: Anton Dosov Date: Fri, 27 Oct 2023 09:58:17 +0200 Subject: [PATCH] [Serverless] fix breadcrumbs for alerts and slo (#169778) ## Summary Close https://github.com/elastic/kibana/issues/161447 This fixes deeper context breadcrumbs in serverless observability project for alerts and slos apps. This builds on top of https://github.com/elastic/kibana/pull/169513 where we added merging of navigational project breadcrumbs with deeper context breadcrumbs set by `chrome.setBreadcrumbs`. The merging is based on deepLinkId, so we're adding it to base breadcrumbs. The deepLinkId is type checked. ![Screenshot 2023-10-25 at 12 28 07](https://github.com/elastic/kibana/assets/7784120/947f59b3-b338-4bd1-96b9-7414bf396fae) ![Screenshot 2023-10-25 at 12 28 16](https://github.com/elastic/kibana/assets/7784120/5e73e902-3397-4b3e-9202-5c1e2c49358f) --- .../public/pages/alert_details/alert_details.tsx | 1 + .../public/pages/rule_details/rule_details.tsx | 1 + .../observability/public/pages/rules/rules.tsx | 1 + .../public/pages/slo_details/slo_details.tsx | 5 +++-- .../observability/public/pages/slo_edit/slo_edit.tsx | 1 + .../plugins/observability/public/pages/slos/slos.tsx | 1 + x-pack/plugins/observability/tsconfig.json | 3 ++- .../test_suites/observability/navigation.ts | 12 ++++++++++++ 8 files changed, 22 insertions(+), 3 deletions(-) diff --git a/x-pack/plugins/observability/public/pages/alert_details/alert_details.tsx b/x-pack/plugins/observability/public/pages/alert_details/alert_details.tsx index 8ce2278d0823c..a7661ba43fddb 100644 --- a/x-pack/plugins/observability/public/pages/alert_details/alert_details.tsx +++ b/x-pack/plugins/observability/public/pages/alert_details/alert_details.tsx @@ -75,6 +75,7 @@ export function AlertDetails() { text: i18n.translate('xpack.observability.breadcrumbs.alertsLinkText', { defaultMessage: 'Alerts', }), + deepLinkId: 'observability-overview:alerts', }, { text: alert ? pageTitleContent(alert.fields[ALERT_RULE_CATEGORY]) : defaultBreadcrumb, diff --git a/x-pack/plugins/observability/public/pages/rule_details/rule_details.tsx b/x-pack/plugins/observability/public/pages/rule_details/rule_details.tsx index 5585ccdeb7099..b3b9ea17d5cac 100644 --- a/x-pack/plugins/observability/public/pages/rule_details/rule_details.tsx +++ b/x-pack/plugins/observability/public/pages/rule_details/rule_details.tsx @@ -85,6 +85,7 @@ export function RuleDetailsPage() { defaultMessage: 'Alerts', }), href: basePath.prepend(paths.observability.alerts), + deepLinkId: 'observability-overview:alerts', }, { href: basePath.prepend(paths.observability.rules), diff --git a/x-pack/plugins/observability/public/pages/rules/rules.tsx b/x-pack/plugins/observability/public/pages/rules/rules.tsx index 33a1a67be8359..fa774d96b1c4f 100644 --- a/x-pack/plugins/observability/public/pages/rules/rules.tsx +++ b/x-pack/plugins/observability/public/pages/rules/rules.tsx @@ -46,6 +46,7 @@ export function RulesPage({ activeTab = RULES_TAB_NAME }: RulesPageProps) { defaultMessage: 'Alerts', }), href: http.basePath.prepend('/app/observability/alerts'), + deepLinkId: 'observability-overview:alerts', }, { text: i18n.translate('xpack.observability.breadcrumbs.rulesLinkText', { diff --git a/x-pack/plugins/observability/public/pages/slo_details/slo_details.tsx b/x-pack/plugins/observability/public/pages/slo_details/slo_details.tsx index 195cb164e5197..b3c1709695e46 100644 --- a/x-pack/plugins/observability/public/pages/slo_details/slo_details.tsx +++ b/x-pack/plugins/observability/public/pages/slo_details/slo_details.tsx @@ -8,10 +8,10 @@ import React, { useState } from 'react'; import { useParams } from 'react-router-dom'; import { useIsMutating } from '@tanstack/react-query'; -import { EuiBreadcrumbProps } from '@elastic/eui/src/components/breadcrumbs/breadcrumb'; import { EuiLoadingSpinner } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import type { IBasePath } from '@kbn/core-http-browser'; +import type { ChromeBreadcrumb } from '@kbn/core-chrome-browser'; import type { SLOWithSummaryResponse } from '@kbn/slo-schema'; import { useBreadcrumbs } from '@kbn/observability-shared-plugin/public'; @@ -97,13 +97,14 @@ export function SloDetailsPage() { function getBreadcrumbs( basePath: IBasePath, slo: SLOWithSummaryResponse | undefined -): EuiBreadcrumbProps[] { +): ChromeBreadcrumb[] { return [ { href: basePath.prepend(paths.observability.slos), text: i18n.translate('xpack.observability.breadcrumbs.slosLinkText', { defaultMessage: 'SLOs', }), + deepLinkId: 'observability-overview:slos', }, { text: diff --git a/x-pack/plugins/observability/public/pages/slo_edit/slo_edit.tsx b/x-pack/plugins/observability/public/pages/slo_edit/slo_edit.tsx index 1f5cc7f38ed3c..27fda5cfc61fa 100644 --- a/x-pack/plugins/observability/public/pages/slo_edit/slo_edit.tsx +++ b/x-pack/plugins/observability/public/pages/slo_edit/slo_edit.tsx @@ -41,6 +41,7 @@ export function SloEditPage() { text: i18n.translate('xpack.observability.breadcrumbs.sloLabel', { defaultMessage: 'SLOs', }), + deepLinkId: 'observability-overview:slos', }, ...(!!slo ? [ diff --git a/x-pack/plugins/observability/public/pages/slos/slos.tsx b/x-pack/plugins/observability/public/pages/slos/slos.tsx index 18fa418e4358b..579b1bb8d19ae 100644 --- a/x-pack/plugins/observability/public/pages/slos/slos.tsx +++ b/x-pack/plugins/observability/public/pages/slos/slos.tsx @@ -44,6 +44,7 @@ export function SlosPage() { text: i18n.translate('xpack.observability.breadcrumbs.slosLinkText', { defaultMessage: 'SLOs', }), + deepLinkId: 'observability-overview:slos', }, ]); diff --git a/x-pack/plugins/observability/tsconfig.json b/x-pack/plugins/observability/tsconfig.json index d5123d9b5c86b..4c85d57f77926 100644 --- a/x-pack/plugins/observability/tsconfig.json +++ b/x-pack/plugins/observability/tsconfig.json @@ -91,7 +91,8 @@ "@kbn/core-application-common", "@kbn/react-kibana-mount", "@kbn/react-kibana-context-theme", - "@kbn/shared-ux-link-redirect-app" + "@kbn/shared-ux-link-redirect-app", + "@kbn/core-chrome-browser" ], "exclude": [ "target/**/*" diff --git a/x-pack/test_serverless/functional/test_suites/observability/navigation.ts b/x-pack/test_serverless/functional/test_suites/observability/navigation.ts index 59f0554cd85ac..4b94df8c51bcc 100644 --- a/x-pack/test_serverless/functional/test_suites/observability/navigation.ts +++ b/x-pack/test_serverless/functional/test_suites/observability/navigation.ts @@ -127,6 +127,18 @@ export default function ({ getPageObject, getService }: FtrProviderContext) { await svlCommonNavigation.breadcrumbs.expectBreadcrumbTexts(['Cases', 'Settings']); }); + it('navigates to alerts app', async () => { + await svlCommonNavigation.sidenav.clickLink({ deepLinkId: 'observability-overview:alerts' }); + await svlCommonNavigation.sidenav.expectLinkActive({ + deepLinkId: 'observability-overview:alerts', + }); + await testSubjects.click('manageRulesPageButton'); + await svlCommonNavigation.breadcrumbs.expectBreadcrumbTexts(['Alerts', 'Rules']); + await svlCommonNavigation.sidenav.expectLinkActive({ + deepLinkId: 'observability-overview:alerts', + }); + }); + it('navigates to integrations', async () => { await svlCommonNavigation.sidenav.openSection('project_settings_project_nav'); await svlCommonNavigation.sidenav.clickLink({ deepLinkId: 'integrations' });