Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[APM/Infra] Display entity detail views for logs-only signals when EEM is enabled #196387

Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
2a32915
Create useEntityManager
iblancof Oct 15, 2024
2344dca
Hide noDataConfig when logs are present and EEM is enabled
iblancof Oct 15, 2024
38d8ae6
Remove duplicated EEM setting const
iblancof Oct 15, 2024
e77cb12
Create useEntityCentricExperienceSetting
iblancof Oct 15, 2024
ac3580c
Create isLogsSignal
iblancof Oct 15, 2024
1a9512f
Hide noDataConfig when logs are present and EEM is enabled
iblancof Oct 15, 2024
a5d126e
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 15, 2024
63b9114
[CI] Auto-commit changed files from 'node scripts/yarn_deduplicate'
kibanamachine Oct 15, 2024
955839d
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 16, 2024
1fbf28d
Remove EntityManager usage in apm
iblancof Oct 16, 2024
1572b82
Add new logic to shouldBypassNoDataScreen
iblancof Oct 16, 2024
8c1bd53
[CI] Auto-commit changed files from 'node scripts/yarn_deduplicate'
kibanamachine Oct 16, 2024
e96bf01
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 16, 2024
a81193c
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 16, 2024
3ee8a24
Move noDataConfig new logic
iblancof Oct 16, 2024
0a1f945
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 16, 2024
fdf0ef3
Add both logs and metrics check to bypass empty state
iblancof Oct 16, 2024
db30fa1
Merge branch '196084-inventory-logs-only-hosts-containers--services-d…
iblancof Oct 16, 2024
be9e36b
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 17, 2024
748d0d2
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 17, 2024
4286590
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 17, 2024
8bf92b4
Modify onboarding logic for asset detail
iblancof Oct 17, 2024
92595fb
Prevent calling hasData if onboardingFlow is undefined
iblancof Oct 17, 2024
753476d
Update x-pack/plugins/observability_solution/infra/public/components/…
iblancof Oct 17, 2024
4625539
Rename has EEM to shouldBypassOnboarding
iblancof Oct 17, 2024
1692be0
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 17, 2024
199f836
Remove unused attributes in getNoDataConfig
iblancof Oct 17, 2024
bdc324b
Merge branch 'main' into 196084-inventory-logs-only-hosts-containers-…
iblancof Oct 18, 2024
52a4967
Add missing onboardingFlow dep when fetching hasData
iblancof Oct 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,13 @@

import { EuiFlexGroup, EuiPageHeaderProps } from '@elastic/eui';
import { useKibana } from '@kbn/kibana-react-plugin/public';
import { entityCentricExperience } from '@kbn/observability-plugin/common';
import { ObservabilityPageTemplateProps } from '@kbn/observability-shared-plugin/public';
import type { KibanaPageTemplateProps } from '@kbn/shared-ux-page-kibana-template';
import React, { useContext } from 'react';
import { useLocation } from 'react-router-dom';
import { FeatureFeedbackButton } from '@kbn/observability-shared-plugin/public';
import { useApmServiceContext } from '../../../../context/apm_service/use_apm_service_context';
import { isLogsSignal } from '../../../../utils/get_signal_type';
import { useLocalStorage } from '../../../../hooks/use_local_storage';
import { useDefaultAiAssistantStarterPromptsForAPM } from '../../../../hooks/use_default_ai_assistant_starter_prompts_for_apm';
import { KibanaEnvironmentContext } from '../../../../context/kibana_environment_context/kibana_environment_context';
Expand Down Expand Up @@ -71,12 +72,8 @@ export function ApmMainTemplate({
const { http, docLinks, observabilityShared, application } = services;
const { kibanaVersion, isCloudEnv, isServerlessEnv } = kibanaEnvironment;
const basePath = http?.basePath.get();
const { config, core } = useApmPluginContext();
const isEntityCentricExperienceSettingEnabled = core.uiSettings.get<boolean>(
entityCentricExperience,
true
);
iblancof marked this conversation as resolved.
Show resolved Hide resolved

const { config } = useApmPluginContext();
const { serviceEntitySummary } = useApmServiceContext();
const { isEntityCentricExperienceEnabled } = useEntityCentricExperienceSetting();

const ObservabilityPageTemplate = observabilityShared.navigation.PageTemplate;
Expand All @@ -97,9 +94,14 @@ export function ApmMainTemplate({
[application?.capabilities.savedObjectsManagement.edit]
);

const shouldBypassNoDataScreen = bypassNoDataScreenPaths.some((path) =>
location.pathname.includes(path)
);
const hasLogsData = serviceEntitySummary?.dataStreamTypes
? serviceEntitySummary?.dataStreamTypes?.length > 0 &&
isLogsSignal(serviceEntitySummary.dataStreamTypes)
: false;
cauemarcondes marked this conversation as resolved.
Show resolved Hide resolved

const shouldBypassNoDataScreen =
bypassNoDataScreenPaths.some((path) => location.pathname.includes(path)) ||
(isEntityCentricExperienceEnabled && hasLogsData);

const { data: fleetApmPoliciesData, status: fleetApmPoliciesStatus } = useFetcher(
(callApmApi) => {
Expand Down Expand Up @@ -158,7 +160,7 @@ export function ApmMainTemplate({

const showEntitiesInventoryCallout =
!dismissedEntitiesInventoryCallout &&
isEntityCentricExperienceSettingEnabled &&
isEntityCentricExperienceEnabled &&
selectedNavButton !== undefined;

return (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,7 @@ import { EntityDataStreamType } from '@kbn/observability-shared-plugin/common';
export function isMetricsSignal(dataStreamTypes: EntityDataStreamType[] = []) {
return dataStreamTypes?.includes(EntityDataStreamType.METRICS);
}

export function isLogsSignal(dataStreamTypes: EntityDataStreamType[] = []) {
return dataStreamTypes?.includes(EntityDataStreamType.LOGS);
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import { i18n } from '@kbn/i18n';
import type { LazyObservabilityPageTemplateProps } from '@kbn/observability-shared-plugin/public';
import React, { useEffect } from 'react';
import { useEntityCentricExperienceSetting } from '../../../hooks/use_entity_centric_experience_setting';
import { GetHasDataResponse } from '../../../../common/metrics_sources/get_has_data';
import { NoRemoteCluster } from '../../empty_states';
import { SourceErrorPage } from '../../source_error_page';
Expand All @@ -16,6 +17,9 @@ import { useKibanaContextForPlugin } from '../../../hooks/use_kibana';
import { ErrorCallout } from '../../error_callout';
import { isPending, useFetcher } from '../../../hooks/use_fetcher';
import { OnboardingFlow, getNoDataConfig } from './no_data_config';
import { useAssetDetailsRenderPropsContext } from '../../asset_details/hooks/use_asset_details_render_props';
import { useEntitySummary } from '../../asset_details/hooks/use_entity_summary';
import { isLogsSignal } from '../../asset_details/utils/get_data_stream_types';

export const InfraPageTemplate = ({
'data-test-subj': _dataTestSubj,
Expand Down Expand Up @@ -50,7 +54,15 @@ export const InfraPageTemplate = ({
});
});

const { isEntityCentricExperienceEnabled } = useEntityCentricExperienceSetting();
const { asset } = useAssetDetailsRenderPropsContext();
const { dataStreams, status: entitySummaryStatus } = useEntitySummary({
entityType: asset?.type,
entityId: asset?.id,
});
iblancof marked this conversation as resolved.
Show resolved Hide resolved

const hasData = !!data?.hasData;
const hasLogsData = isLogsSignal(dataStreams);
const noDataConfig = getNoDataConfig({
hasData,
loading: isPending(status),
Expand Down Expand Up @@ -118,10 +130,22 @@ export const InfraPageTemplate = ({
/>;
}

const evaluateNoDataConfig = () => {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I wonder if this logic should be moved to getNoDataConfig function. IMO that's the function responsible for returning the noDataConfig

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can do it, yes. I’ve tried to modify as little as possible.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Changed in 3ee8a24 @crespocarlos

if (entitySummaryStatus === 'failure') {
return noDataConfig;
}

if (entitySummaryStatus !== 'success') {
iblancof marked this conversation as resolved.
Show resolved Hide resolved
return undefined;
}

return isEntityCentricExperienceEnabled && hasLogsData ? undefined : noDataConfig;
};

return (
<PageTemplate
data-test-subj={hasData ? _dataTestSubj : 'noDataPage'}
noDataConfig={noDataConfig}
noDataConfig={evaluateNoDataConfig()}
{...pageTemplateProps}
/>
);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
/*
* 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 { entityCentricExperience } from '@kbn/observability-plugin/common';
import { useKibanaContextForPlugin } from './use_kibana';

export function useEntityCentricExperienceSetting() {
const { uiSettings } = useKibanaContextForPlugin().services;

const isEntityCentricExperienceEnabled = uiSettings.get<boolean>(entityCentricExperience, true);
iblancof marked this conversation as resolved.
Show resolved Hide resolved

return { isEntityCentricExperienceEnabled };
}