From 2e808ac38cf84d9aca80b124b6d8e8dc7d5ea5f4 Mon Sep 17 00:00:00 2001
From: jennypavlova
Date: Mon, 4 Mar 2024 15:44:13 +0100
Subject: [PATCH] [Infra UI] Wrap infra content in RedirectAppLinks (#177747)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Closes #177056
## Summary
This PR adds `RedirectAppLinks` wrapper to the infra content and removes
it from the links using it. The links that are changed:
- Asset Details (page/flyout)
- `Show all`: APM and Alerts links
- Links to Alerts
- Links to services (also empty content) / Services tooltip / Single
service link
- Logs links (Asset Details page/flyout and hosts view) `Open in Logs`
- Anomaly Detection: `Start Trial` link
## Testing
- Test for regressions: All links should navigate to different apps
without page reload (**same behavior as before**)
https://github.com/elastic/kibana/assets/14139027/d5d811f4-3fa6-4294-a307-6c547c8d3f9c
https://github.com/elastic/kibana/assets/14139027/3cce71f9-dc0f-49fe-9749-b145c7bc36a1
* ⚠️ Ignore the logs error - my config with the cluster was wrong when I
recorded that
https://github.com/elastic/kibana/assets/14139027/fa2d4f48-e7a3-4b0f-a0ea-8a6d041f527e
---------
Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
---
.../infra/public/apps/common_providers.tsx | 21 ++++++---
.../components/services_tooltip_content.tsx | 21 ++++-----
.../links/link_to_alerts_page.tsx | 47 +++++++++----------
.../links/link_to_apm_service.tsx | 40 +++++++---------
.../links/link_to_apm_services.tsx | 29 +++++-------
.../asset_details/tabs/logs/logs.tsx | 27 +++++------
.../subscription_splash_content.tsx | 23 ++++-----
.../tabs/logs/logs_link_to_stream.tsx | 41 ++++++++--------
8 files changed, 117 insertions(+), 132 deletions(-)
diff --git a/x-pack/plugins/observability_solution/infra/public/apps/common_providers.tsx b/x-pack/plugins/observability_solution/infra/public/apps/common_providers.tsx
index 3915446edaeee..597f387c627b3 100644
--- a/x-pack/plugins/observability_solution/infra/public/apps/common_providers.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/apps/common_providers.tsx
@@ -13,6 +13,7 @@ import type { ObservabilityAIAssistantPluginStart } from '@kbn/observability-ai-
import { Storage } from '@kbn/kibana-utils-plugin/public';
import { NavigationWarningPromptProvider } from '@kbn/observability-shared-plugin/public';
import { TriggersAndActionsUIPublicPluginStart } from '@kbn/triggers-actions-ui-plugin/public';
+import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import {
type KibanaEnvContext,
useKibanaContextForPluginProvider,
@@ -79,13 +80,19 @@ export const CoreProviders: React.FC = ({
const KibanaEnvContextForPluginProvider = useKibanaEnvironmentContextProvider(kibanaEnvironment);
return (
-
-
-
- {children}
-
-
-
+
+
+
+
+ {children}
+
+
+
+
);
};
diff --git a/x-pack/plugins/observability_solution/infra/public/components/asset_details/components/services_tooltip_content.tsx b/x-pack/plugins/observability_solution/infra/public/components/asset_details/components/services_tooltip_content.tsx
index 5efcfc1ea4f56..6c5b00d735226 100644
--- a/x-pack/plugins/observability_solution/infra/public/components/asset_details/components/services_tooltip_content.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/components/asset_details/components/services_tooltip_content.tsx
@@ -7,13 +7,10 @@
import React from 'react';
import { EuiText, EuiLink } from '@elastic/eui';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { FormattedMessage } from '@kbn/i18n-react';
import { useLinkProps } from '@kbn/observability-shared-plugin/public';
-import { useKibanaContextForPlugin } from '../../../hooks/use_kibana';
export const ServicesTooltipContent = () => {
- const { services } = useKibanaContextForPlugin();
const linkProps = useLinkProps({
app: 'home',
hash: '/tutorial/apm',
@@ -25,14 +22,16 @@ export const ServicesTooltipContent = () => {
defaultMessage="Showing {apmTutorialLink} services detected on this host."
values={{
apmTutorialLink: (
-
-
-
-
-
+
+
+
),
}}
/>
diff --git a/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_alerts_page.tsx b/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_alerts_page.tsx
index 5c1ec8521e344..e23fa128868b0 100644
--- a/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_alerts_page.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_alerts_page.tsx
@@ -6,7 +6,6 @@
*/
import React from 'react';
import { encode } from '@kbn/rison';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { FormattedMessage } from '@kbn/i18n-react';
import { EuiButtonEmpty, EuiLink } from '@elastic/eui';
import type { TimeRange } from '@kbn/es-query';
@@ -33,21 +32,19 @@ export const LinkToAlertsPage = ({ assetName, queryField, dateRange }: LinkToAle
);
return (
-
-
-
-
-
+
+
+
);
};
@@ -58,13 +55,15 @@ export const LinkToAlertsHomePage = () => {
const linkToAlertsPage = http.basePath.prepend(ALERTS_PATH);
return (
-
-
-
-
-
+
+
+
);
};
diff --git a/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_service.tsx b/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_service.tsx
index 378697793d90b..b4e2ea57c9eaa 100644
--- a/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_service.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_service.tsx
@@ -5,13 +5,11 @@
* 2.0.
*/
import React from 'react';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { EuiBadge, EuiText } from '@elastic/eui';
import { AgentIcon } from '@kbn/custom-icons';
import { AgentName } from '@kbn/elastic-agent-utils';
import { i18n } from '@kbn/i18n';
import { useLinkProps } from '@kbn/observability-shared-plugin/public';
-import { useKibanaContextForPlugin } from '../../../hooks/use_kibana';
export interface LinkToApmServiceProps {
serviceName: string;
@@ -20,8 +18,6 @@ export interface LinkToApmServiceProps {
}
export const LinkToApmService = ({ serviceName, agentName, dateRange }: LinkToApmServiceProps) => {
- const { services } = useKibanaContextForPlugin();
-
const linkProps = useLinkProps({
app: 'apm',
pathname: `/services/${serviceName}/overview`,
@@ -31,24 +27,22 @@ export const LinkToApmService = ({ serviceName, agentName, dateRange }: LinkToAp
},
});
return (
-
-
-
- {agentName ? (
-
- ) : null}
- {serviceName}
-
-
-
+
+
+ {agentName ? (
+
+ ) : null}
+ {serviceName}
+
+
);
};
diff --git a/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_services.tsx b/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_services.tsx
index a7a70d1466ac9..7be6b16d5e5a3 100644
--- a/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_services.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/components/asset_details/links/link_to_apm_services.tsx
@@ -7,7 +7,6 @@
import React from 'react';
import { stringify } from 'querystring';
import { encode } from '@kbn/rison';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { FormattedMessage } from '@kbn/i18n-react';
import { EuiButtonEmpty } from '@elastic/eui';
import { useKibanaContextForPlugin } from '../../../hooks/use_kibana';
@@ -32,20 +31,18 @@ export const LinkToApmServices = ({ assetName, apmField }: LinkToApmServicesProp
const linkToApmServices = http.basePath.prepend(`/app/apm/services?${queryString}`);
return (
-
-
-
-
-
+
+
+
);
};
diff --git a/x-pack/plugins/observability_solution/infra/public/components/asset_details/tabs/logs/logs.tsx b/x-pack/plugins/observability_solution/infra/public/components/asset_details/tabs/logs/logs.tsx
index 5535488f45e7d..843bc8c363e8b 100644
--- a/x-pack/plugins/observability_solution/infra/public/components/asset_details/tabs/logs/logs.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/components/asset_details/tabs/logs/logs.tsx
@@ -10,7 +10,6 @@ import useDebounce from 'react-use/lib/useDebounce';
import { FormattedMessage } from '@kbn/i18n-react';
import { i18n } from '@kbn/i18n';
import { EuiFieldSearch, EuiFlexGroup, EuiFlexItem, EuiButtonEmpty } from '@elastic/eui';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { LogStream } from '@kbn/logs-shared-plugin/public';
import {
DEFAULT_LOG_VIEW,
@@ -107,20 +106,18 @@ export const Logs = () => {
/>
-
-
-
-
-
+
+
+
diff --git a/x-pack/plugins/observability_solution/infra/public/components/subscription_splash_content.tsx b/x-pack/plugins/observability_solution/infra/public/components/subscription_splash_content.tsx
index d1a78c3aeb927..386c5360f67a0 100644
--- a/x-pack/plugins/observability_solution/infra/public/components/subscription_splash_content.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/components/subscription_splash_content.tsx
@@ -10,12 +10,10 @@ import { i18n } from '@kbn/i18n';
import { EuiText, EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { FormattedMessage } from '@kbn/i18n-react';
import type { LazyObservabilityPageTemplateProps } from '@kbn/observability-shared-plugin/public';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { useTrialStatus } from '../hooks/use_trial_status';
import { LoadingPrompt } from './loading_page';
import { PageTemplate } from './page_template';
import { useLicenseUrl } from '../hooks/use_license';
-import { useKibanaContextForPlugin } from '../hooks/use_kibana';
const loadingMessage = i18n.translate('xpack.infra.ml.splash.loadingMessage', {
defaultMessage: 'Checking license...',
@@ -114,7 +112,6 @@ export const SubscriptionSplashPage: React.FC {
const manageLicenseURL = useLicenseUrl();
- const { services } = useKibanaContextForPlugin();
return (
{
}
actions={[
-
-
- {i18n.translate('xpack.infra.ml.splash.startTrialCta', {
- defaultMessage: 'Start trial',
- })}
-
- ,
+
+ {i18n.translate('xpack.infra.ml.splash.startTrialCta', {
+ defaultMessage: 'Start trial',
+ })}
+ ,
]}
/>
);
diff --git a/x-pack/plugins/observability_solution/infra/public/pages/metrics/hosts/components/tabs/logs/logs_link_to_stream.tsx b/x-pack/plugins/observability_solution/infra/public/pages/metrics/hosts/components/tabs/logs/logs_link_to_stream.tsx
index d7fbd4dbf1be9..bb8cdfdaae1e2 100644
--- a/x-pack/plugins/observability_solution/infra/public/pages/metrics/hosts/components/tabs/logs/logs_link_to_stream.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/pages/metrics/hosts/components/tabs/logs/logs_link_to_stream.tsx
@@ -5,7 +5,6 @@
* 2.0.
*/
import React from 'react';
-import { RedirectAppLinks } from '@kbn/shared-ux-link-redirect-app';
import { EuiButtonEmpty } from '@elastic/eui';
import { FormattedMessage } from '@kbn/i18n-react';
import { getLogsLocatorsFromUrlService, LogViewReference } from '@kbn/logs-shared-plugin/common';
@@ -24,26 +23,24 @@ export const LogsLinkToStream = ({ startTime, endTime, query, logView }: LogsLin
const { logsLocator } = getLogsLocatorsFromUrlService(share.url);
return (
-
-
-
-
-
+
+
+
);
};