diff --git a/x-pack/plugins/observability_solution/apm/public/components/app/entities/charts/log_error_rate_chart.tsx b/x-pack/plugins/observability_solution/apm/public/components/app/entities/charts/log_error_rate_chart.tsx index d734da4fbf80f..9493d3503a5dd 100644 --- a/x-pack/plugins/observability_solution/apm/public/components/app/entities/charts/log_error_rate_chart.tsx +++ b/x-pack/plugins/observability_solution/apm/public/components/app/entities/charts/log_error_rate_chart.tsx @@ -22,6 +22,7 @@ import { ChartMetricType, getMetricsFormula, } from '../../../shared/charts/helper/get_metrics_formulas'; +import { ExploreLogsButton } from '../../../shared/explore_logs_button/explore_logs_button'; type LogErrorRateReturnType = APIReturnType<'GET /internal/apm/entities/services/{serviceName}/logs_error_rate_timeseries'>; @@ -76,44 +77,56 @@ export function LogErrorRateChart({ height }: { height: number }) { return ( - - -

- {i18n.translate('xpack.apm.logErrorRate', { - defaultMessage: 'Log error %', - })} -

-
-
- - - - {i18n.translate( - 'xpack.apm.multiSignal.servicesTable.logErrorRate.tooltip.serviceNameLabel', - { - defaultMessage: 'service.name', - } - )} - - ), - }} - /> - } + + + +

+ {i18n.translate('xpack.apm.logErrorRate', { + defaultMessage: 'Log error %', + })}{' '} + + + {i18n.translate( + 'xpack.apm.multiSignal.servicesTable.logErrorRate.tooltip.serviceNameLabel', + { + defaultMessage: 'service.name', + } + )} + + ), + }} + /> + } + /> + +

+
+
+ + -
-
+ +
; @@ -35,6 +36,7 @@ export function LogRateChart({ height }: { height: number }) { query: { rangeFrom, rangeTo, environment, kuery }, path: { serviceName }, } = useApmParams('/logs-services/{serviceName}'); + const { start, end } = useTimeRange({ rangeFrom, rangeTo }); const { data = INITIAL_STATE, status } = useFetcher( @@ -76,44 +78,57 @@ export function LogRateChart({ height }: { height: number }) { return ( - - -

- {i18n.translate('xpack.apm.logRate', { - defaultMessage: 'Log rate', - })} -

-
-
- - - - {i18n.translate( - 'xpack.apm.multiSignal.servicesTable.logRate.tooltip.serviceNameLabel', - { - defaultMessage: 'service.name', - } - )} - - ), - }} - /> - } + + + +

+ {i18n.translate('xpack.apm.logRate', { + defaultMessage: 'Log rate', + })}{' '} + + + {i18n.translate( + 'xpack.apm.multiSignal.servicesTable.logRate.tooltip.serviceNameLabel', + { + defaultMessage: 'service.name', + } + )} + + ), + }} + /> + } + /> + +

+
+
+ + + -
-
+ +
(ALL_DATASETS_LOCATOR_ID)!; + + if (!logsExplorerLocator) { + return null; + } + + const { logsExplorerLinkProps } = buildLogsExplorerLocatorConfig({ + locator: logsExplorerLocator, + from: start, + to: end, + kuery, + }); + + return ( + + {i18n.translate('xpack.apm.button.exploreLogs', { + defaultMessage: 'Explore logs', + })} + + ); +} diff --git a/x-pack/plugins/observability_solution/apm/public/components/shared/explore_logs_button/logs_explorer_locator_config.ts b/x-pack/plugins/observability_solution/apm/public/components/shared/explore_logs_button/logs_explorer_locator_config.ts new file mode 100644 index 0000000000000..e5baa87856b31 --- /dev/null +++ b/x-pack/plugins/observability_solution/apm/public/components/shared/explore_logs_button/logs_explorer_locator_config.ts @@ -0,0 +1,48 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { AllDatasetsLocatorParams } from '@kbn/deeplinks-observability'; +import { LocatorPublic } from '@kbn/share-plugin/common'; +import { getRouterLinkProps } from '@kbn/router-utils'; +import { RouterLinkProps } from '@kbn/router-utils/src/get_router_link_props'; + +export const buildLogsExplorerLocatorConfig = ({ + locator, + kuery, + from, + to, +}: { + locator: LocatorPublic; + kuery?: string; + from: string; + to: string; +}): { + logsExplorerLinkProps: RouterLinkProps; +} => { + const params: AllDatasetsLocatorParams = { + timeRange: { + from, + to, + }, + ...(kuery && { + query: { language: 'kuery', query: kuery }, + }), + }; + + const urlToLogsExplorer = locator.getRedirectUrl(params); + + const navigateToLogsExplorer = () => { + locator.navigate(params); + }; + + const logsExplorerLinkProps = getRouterLinkProps({ + href: urlToLogsExplorer, + onClick: navigateToLogsExplorer, + }); + + return { logsExplorerLinkProps }; +}; diff --git a/x-pack/plugins/observability_solution/apm/tsconfig.json b/x-pack/plugins/observability_solution/apm/tsconfig.json index 7389566ed6a4c..a31ddcca0bdce 100644 --- a/x-pack/plugins/observability_solution/apm/tsconfig.json +++ b/x-pack/plugins/observability_solution/apm/tsconfig.json @@ -128,9 +128,8 @@ "@kbn/core-analytics-browser", "@kbn/apm-types", "@kbn/entities-schema", - "@kbn/aiops-log-rate-analysis" + "@kbn/aiops-log-rate-analysis", + "@kbn/router-utils" ], - "exclude": [ - "target/**/*" - ] + "exclude": ["target/**/*"] }