From 65453a34fe87422070578d5e44dc982dbc34fd43 Mon Sep 17 00:00:00 2001 From: Jialiang Liang Date: Thu, 15 Aug 2024 14:01:29 -0400 Subject: [PATCH 1/3] [Page Header] New page header for metrics (#2050) * Move the save button to the header control bar Signed-off-by: Ryan Liang * Update snapshots Signed-off-by: Ryan Liang * Fix the save button and correct its size + position Signed-off-by: Ryan Liang * Fix the date picker location Signed-off-by: Ryan Liang * Rename the navigation in coreRef and switch to use compressed date picker Signed-off-by: Ryan Liang * Fix the popover Signed-off-by: Ryan Liang * Rename the button Signed-off-by: Ryan Liang * Update to latest mockup Signed-off-by: Ryan Liang * Update snapshots Signed-off-by: Ryan Liang * Fix the ui issues Signed-off-by: Ryan Liang * Dummy metrics Signed-off-by: Ryan Liang * Remove dummy Signed-off-by: Ryan Liang * update snapshots Signed-off-by: Ryan Liang * minor changes to match mocks Signed-off-by: Shenoy Pratik --------- Signed-off-by: Ryan Liang Signed-off-by: Shenoy Pratik Co-authored-by: Shenoy Pratik --- .../__snapshots__/log_config.test.tsx.snap | 4 + .../service_config.test.tsx.snap | 4 + .../__snapshots__/trace_config.test.tsx.snap | 4 + .../custom_panel_view.test.tsx.snap | 8 + .../__snapshots__/panel_grid.test.tsx.snap | 2 + .../__snapshots__/save_panel.test.tsx.snap | 2 +- public/components/metrics/index.tsx | 10 +- .../__snapshots__/sidebar.test.tsx.snap | 22 +- .../metrics/sidebar/data_source_picker.tsx | 1 + .../components/metrics/sidebar/search_bar.tsx | 13 +- .../components/metrics/sidebar/sidebar.scss | 16 +- .../metrics_export.test.tsx.snap | 164 +-- .../metrics_export_panel.test.tsx.snap | 629 +++++---- .../__snapshots__/top_menu.test.tsx.snap | 1212 +++++++++-------- .../__tests__/metrics_export.test.tsx | 5 +- .../metrics/top_menu/metrics_export.tsx | 110 +- .../metrics/top_menu/metrics_export_panel.tsx | 90 +- .../components/metrics/top_menu/top_menu.scss | 4 + .../components/metrics/top_menu/top_menu.tsx | 28 +- .../__snapshots__/metrics_grid.test.tsx.snap | 4 + .../__snapshots__/dashboard.test.tsx.snap | 12 + .../__snapshots__/services.test.tsx.snap | 12 + .../__snapshots__/traces.test.tsx.snap | 12 + public/framework/core_refs.ts | 2 + public/plugin.tsx | 1 + 25 files changed, 1303 insertions(+), 1068 deletions(-) diff --git a/public/components/application_analytics/__tests__/__snapshots__/log_config.test.tsx.snap b/public/components/application_analytics/__tests__/__snapshots__/log_config.test.tsx.snap index 8bb764eaa3..0ccc0ae60f 100644 --- a/public/components/application_analytics/__tests__/__snapshots__/log_config.test.tsx.snap +++ b/public/components/application_analytics/__tests__/__snapshots__/log_config.test.tsx.snap @@ -16,6 +16,7 @@ exports[`Log Config component renders empty log config 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -119,6 +120,7 @@ exports[`Log Config component renders empty log config 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -649,6 +651,7 @@ exports[`Log Config component renders with query 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -752,6 +755,7 @@ exports[`Log Config component renders with query 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/application_analytics/__tests__/__snapshots__/service_config.test.tsx.snap b/public/components/application_analytics/__tests__/__snapshots__/service_config.test.tsx.snap index 1f1a5410ae..2a759f4418 100644 --- a/public/components/application_analytics/__tests__/__snapshots__/service_config.test.tsx.snap +++ b/public/components/application_analytics/__tests__/__snapshots__/service_config.test.tsx.snap @@ -16,6 +16,7 @@ exports[`Service Config component renders empty service config 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -119,6 +120,7 @@ exports[`Service Config component renders empty service config 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -1219,6 +1221,7 @@ exports[`Service Config component renders with one service selected 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -1322,6 +1325,7 @@ exports[`Service Config component renders with one service selected 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/application_analytics/__tests__/__snapshots__/trace_config.test.tsx.snap b/public/components/application_analytics/__tests__/__snapshots__/trace_config.test.tsx.snap index d18c22b8cf..9750299fa2 100644 --- a/public/components/application_analytics/__tests__/__snapshots__/trace_config.test.tsx.snap +++ b/public/components/application_analytics/__tests__/__snapshots__/trace_config.test.tsx.snap @@ -15,6 +15,7 @@ exports[`Trace Config component renders empty trace config 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -118,6 +119,7 @@ exports[`Trace Config component renders empty trace config 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -931,6 +933,7 @@ exports[`Trace Config component renders with one trace selected 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -1034,6 +1037,7 @@ exports[`Trace Config component renders with one trace selected 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/custom_panels/__tests__/__snapshots__/custom_panel_view.test.tsx.snap b/public/components/custom_panels/__tests__/__snapshots__/custom_panel_view.test.tsx.snap index cfd039fcff..060e3fe8c6 100644 --- a/public/components/custom_panels/__tests__/__snapshots__/custom_panel_view.test.tsx.snap +++ b/public/components/custom_panels/__tests__/__snapshots__/custom_panel_view.test.tsx.snap @@ -888,6 +888,7 @@ exports[`Panels View Component renders panel view container with visualizations "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction] { "calls": Array [ @@ -1285,6 +1286,7 @@ exports[`Panels View Component renders panel view container with visualizations }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -2692,6 +2694,7 @@ exports[`Panels View Component renders panel view container with visualizations "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction] { "calls": Array [ @@ -3089,6 +3092,7 @@ exports[`Panels View Component renders panel view container with visualizations }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -3259,6 +3263,7 @@ exports[`Panels View Component renders panel view container without visualizatio "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction] { "calls": Array [ @@ -3545,6 +3550,7 @@ exports[`Panels View Component renders panel view container without visualizatio }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -4947,6 +4953,7 @@ exports[`Panels View Component renders panel view container without visualizatio "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction] { "calls": Array [ @@ -5233,6 +5240,7 @@ exports[`Panels View Component renders panel view container without visualizatio }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/custom_panels/panel_modules/panel_grid/__tests__/__snapshots__/panel_grid.test.tsx.snap b/public/components/custom_panels/panel_modules/panel_grid/__tests__/__snapshots__/panel_grid.test.tsx.snap index 092c81d0e8..cd8bc1e161 100644 --- a/public/components/custom_panels/panel_modules/panel_grid/__tests__/__snapshots__/panel_grid.test.tsx.snap +++ b/public/components/custom_panels/panel_modules/panel_grid/__tests__/__snapshots__/panel_grid.test.tsx.snap @@ -15,6 +15,7 @@ exports[`Panel Grid Component renders panel grid component with empty visualizat "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction] { "calls": Array [ @@ -276,6 +277,7 @@ exports[`Panel Grid Component renders panel grid component with empty visualizat "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/event_analytics/explorer/save_panel/__tests__/__snapshots__/save_panel.test.tsx.snap b/public/components/event_analytics/explorer/save_panel/__tests__/__snapshots__/save_panel.test.tsx.snap index b94a45bd65..bb9969e7c4 100644 --- a/public/components/event_analytics/explorer/save_panel/__tests__/__snapshots__/save_panel.test.tsx.snap +++ b/public/components/event_analytics/explorer/save_panel/__tests__/__snapshots__/save_panel.test.tsx.snap @@ -609,7 +609,7 @@ exports[`Saved query table component Renders saved query table 1`] = ` showLabel={true} >
- - - + + + + + +
- - + + diff --git a/public/components/metrics/top_menu/__tests__/__snapshots__/metrics_export_panel.test.tsx.snap b/public/components/metrics/top_menu/__tests__/__snapshots__/metrics_export_panel.test.tsx.snap index 9ea61d7515..3a5bc32eae 100644 --- a/public/components/metrics/top_menu/__tests__/__snapshots__/metrics_export_panel.test.tsx.snap +++ b/public/components/metrics/top_menu/__tests__/__snapshots__/metrics_export_panel.test.tsx.snap @@ -68,298 +68,26 @@ exports[`Export Metrics Panel Component renders Export Metrics Panel Component 1 } } > - -
-
- - - -
-
- -
- - -
-
-
-

- Select dashboards/applications -

- -
- -
-
- -
- -
- - - -
-
-
-
- - -
- - -
- Search existing dashboards or applications by name -
-
-
-
- + SAVE THE VIEW AS VISUALIZATION + + + +
+
- Metric Name #1 + Metric 1
@@ -481,7 +209,7 @@ exports[`Export Metrics Panel Component renders Export Metrics Panel Component 1 fullWidth={false} hasChildLabel={true} hasEmptyLabelSpace={false} - label="Metric Name #2" + label="Metric 2" labelType="label" >
- Metric Name #2 + Metric 2
@@ -554,6 +282,325 @@ exports[`Export Metrics Panel Component renders Export Metrics Panel Component 1
+ +
+ +
+ +
+

+ + Add to custom operational dashboards or applications. + +

+
+
+
+
+ +
+ +
+
+ + + +
+
+ +
+ + +
+
+
+

+ Select dashboards/applications +

+ +
+ +
+
+ +
+ +
+ + + +
+
+
+
+ + +
+ +
+
+ +
+ +
+
diff --git a/public/components/metrics/top_menu/__tests__/__snapshots__/top_menu.test.tsx.snap b/public/components/metrics/top_menu/__tests__/__snapshots__/top_menu.test.tsx.snap index fb8bd0c1b3..de619ec373 100644 --- a/public/components/metrics/top_menu/__tests__/__snapshots__/top_menu.test.tsx.snap +++ b/public/components/metrics/top_menu/__tests__/__snapshots__/top_menu.test.tsx.snap @@ -14,11 +14,12 @@ exports[`Metrics Top Menu Component renders Top Menu Component when enabled 1`] >
} + compressed={true} fullWidth={false} prepend="Span Interval" >
- +
- - -
- -
+ - - } +
- - +
+ - - - } - closePopover={[Function]} - display="inlineBlock" - hasArrow={true} - isOpen={false} - ownFocus={true} - panelPaddingSize="s" - > -
- + + + } - } + closePopover={[Function]} + display="inlineBlock" + hasArrow={true} + isOpen={false} + ownFocus={true} + panelPaddingSize="s" + > +
+
+ + + +
+
+ + +
- +
+ + +
+
+
+
+ + +
+ + + + - - - - - + + + + + + + - - - - + + Refresh + + + + + + + + + + +
+
+
+
+
+
+
+ +
+ + + + + } + closePopover={[Function]} + display="inlineBlock" + hasArrow={true} + isOpen={false} + ownFocus={true} + panelPaddingSize="m" + > +
+
+ + + + - -
-
-
- -
- } - iconType={false} - isCustom={true} - startDateControl={
} - > -
- + + + + +
- - -
-
- -
-
- -
- - - - - - - - - - - -
-
-
-
-
-
-
- -
- - - - } - closePopover={[Function]} - display="inlineBlock" - hasArrow={true} - isOpen={false} - ownFocus={true} - panelPaddingSize="m" - > -
-
- - - - - - - -
+
+
+ +
+
- - - +
+
+
diff --git a/public/components/metrics/top_menu/__tests__/metrics_export.test.tsx b/public/components/metrics/top_menu/__tests__/metrics_export.test.tsx index 5e017873e5..5e18332a9c 100644 --- a/public/components/metrics/top_menu/__tests__/metrics_export.test.tsx +++ b/public/components/metrics/top_menu/__tests__/metrics_export.test.tsx @@ -42,6 +42,7 @@ const defaultInitialState = { refresh: 0, // set to new Date() to trigger }; +// eslint-disable-next-line jest/no-export export function renderWithMetricsProviders( ui: React.ReactElement, { @@ -54,6 +55,7 @@ export function renderWithMetricsProviders( ...renderOptions }: ExtendedRenderOptions = {} ) { + // eslint-disable-next-line @typescript-eslint/no-unused-vars function Wrapper({ children }: PropsWithChildren<{}>): JSX.Element { return {children}; } @@ -145,7 +147,8 @@ describe('Export Metrics Panel Component', () => { expect(saveButton).toBeInTheDocument(); fireEvent.click(saveButton); - expect(await screen.findByText('Custom operational dashboards/application')); + // eslint-disable-next-line jest/valid-expect + expect(await screen.findByText('Dashboards and applications - optional')); const dialog = screen.getByRole('dialog'); fireEvent.keyDown(dialog, { key: 'Escape', code: 'Escape' }); diff --git a/public/components/metrics/top_menu/metrics_export.tsx b/public/components/metrics/top_menu/metrics_export.tsx index e3a9e92edf..1ca548643a 100644 --- a/public/components/metrics/top_menu/metrics_export.tsx +++ b/public/components/metrics/top_menu/metrics_export.tsx @@ -14,7 +14,7 @@ import { } from '@elastic/eui'; import { I18nProvider } from '@osd/i18n/react'; import max from 'lodash/max'; -import React, { useEffect } from 'react'; +import React, { useEffect, useState } from 'react'; import { render, unmountComponentAtNode } from 'react-dom'; import { useSelector } from 'react-redux'; import semver from 'semver'; @@ -50,6 +50,8 @@ const Savebutton = ({ }) => { return ( { setIsPanelOpen((staleState) => !staleState); @@ -57,25 +59,41 @@ const Savebutton = ({ data-test-subj="metrics__saveManagementPopover" iconType="arrowDown" > - Save + Save as visualization ); }; +const HeaderControlledPopoverWrapper = ({ children }: { children: React.ReactElement }) => { + const HeaderControl = coreRefs.navigation?.ui.HeaderControl; + const showActionsInHeader = coreRefs.chrome?.navGroup.getNavGroupEnabled(); + + if (showActionsInHeader && HeaderControl) { + return ( + + ); + } + + return <>{children}; +}; + const MetricsExportPopOver = () => { const availableObservabilityDashboards = useSelector(selectPanelList); - const [availableDashboards, setAvailableDashboards] = React.useState([]); - const [osdCoreDashboards, setOsdCoreDashboards] = React.useState([]); + const [availableDashboards, setAvailableDashboards] = useState([]); + const [osdCoreDashboards, setOsdCoreDashboards] = useState([]); - const [isPanelOpen, setIsPanelOpen] = React.useState(false); + const [isPanelOpen, setIsPanelOpen] = useState(false); const selectedMetrics = useSelector(selectedMetricsSelector); const selectedMetricsIds = useSelector(selectedMetricsIdsSelector); const dateSpanFilter = useSelector(dateSpanFilterSelector); - const [metricsToExport, setMetricsToExport] = React.useState([]); + const [metricsToExport, setMetricsToExport] = useState([]); - const [selectedPanelOptions, setSelectedPanelOptions] = React.useState([]); + const [selectedPanelOptions, setSelectedPanelOptions] = useState([]); const { toasts } = coreRefs; @@ -368,44 +386,46 @@ const MetricsExportPopOver = () => { }; return ( - } - isOpen={isPanelOpen} - closePopover={() => setIsPanelOpen(false)} - > - - - - - setIsPanelOpen(false)} - data-test-subj="metrics__SaveCancel" - > - Cancel - - - - { - handleSavingObjects().then(() => setIsPanelOpen(false)); - }} - data-test-subj="metrics__SaveConfirm" - > - Save - - - - - + + } + isOpen={isPanelOpen} + closePopover={() => setIsPanelOpen(false)} + > + + + + + setIsPanelOpen(false)} + data-test-subj="metrics__SaveCancel" + > + Cancel + + + + { + handleSavingObjects().then(() => setIsPanelOpen(false)); + }} + data-test-subj="metrics__SaveConfirm" + > + Save + + + + + + ); }; diff --git a/public/components/metrics/top_menu/metrics_export_panel.tsx b/public/components/metrics/top_menu/metrics_export_panel.tsx index 3884a55c27..40940911bb 100644 --- a/public/components/metrics/top_menu/metrics_export_panel.tsx +++ b/public/components/metrics/top_menu/metrics_export_panel.tsx @@ -3,15 +3,19 @@ * SPDX-License-Identifier: Apache-2.0 */ -import React, { useEffect } from 'react'; import { EuiComboBox, EuiFieldText, EuiFlexGroup, - EuiFormRow, EuiFlexItem, EuiForm, + EuiFormRow, + EuiHorizontalRule, + EuiSpacer, + EuiText, + EuiTitle, } from '@elastic/eui'; +import React, { useEffect } from 'react'; import { useDispatch } from 'react-redux'; import { MetricType } from '../../../../common/types/metrics'; import { fetchPanels } from '../../../../public/components/custom_panels/redux/panel_slice'; @@ -53,37 +57,27 @@ export const MetricsExportPanel = ({ return (
- - { - setSelectedPanelOptions(newOptions); - }} - selectedOptions={selectedPanelOptions} - options={ - availableDashboards?.map((option: any) => { - return { - panel: option, - label: option.title, - }; - }) ?? [] - } - isClearable={true} - data-test-subj="eventExplorer__querySaveComboBox" - /> - + +

SAVE THE VIEW AS VISUALIZATION

+
+ {metricsToExport.length > 0 && ( -
+
{metricsToExport.map((metaData: any, index: number) => { return ( - + )} + + + {!(metricsToExport.length > 0) && ( + + +

+ Save the view as visualization. You can add it to custom operational dashboards or + applications. +

+
+ +
+ )} + + {metricsToExport.length > 0 && ( + + +

+ Add to custom operational dashboards or applications. +

+
+
+ )} + + + + { + setSelectedPanelOptions(newOptions); + }} + selectedOptions={selectedPanelOptions} + options={ + availableDashboards?.map((option: any) => ({ + panel: option, + label: option.title, + })) ?? [] + } + isClearable={true} + data-test-subj="eventExplorer__querySaveComboBox" + /> + + +
); }; diff --git a/public/components/metrics/top_menu/top_menu.scss b/public/components/metrics/top_menu/top_menu.scss index ff247f31d3..0906b1136f 100644 --- a/public/components/metrics/top_menu/top_menu.scss +++ b/public/components/metrics/top_menu/top_menu.scss @@ -14,3 +14,7 @@ .metrics-search-bar-datepicker { width: 500px; } + +.resolutionSelectOption { + line-height: inherit; +} diff --git a/public/components/metrics/top_menu/top_menu.tsx b/public/components/metrics/top_menu/top_menu.tsx index 521300b5fb..8ebc5d87ab 100644 --- a/public/components/metrics/top_menu/top_menu.tsx +++ b/public/components/metrics/top_menu/top_menu.tsx @@ -26,10 +26,11 @@ export const TopMenu = () => { return ( dateSpanFilter && ( <> - +
{ />
- - dispatch(setDateSpan(dateSpan))} - recentlyUsedRanges={dateSpanFilter.recentlyUsedRanges} - /> - - + + + dispatch(setDateSpan(dateSpan))} + recentlyUsedRanges={dateSpanFilter.recentlyUsedRanges} + /> + + + + +
diff --git a/public/components/metrics/view/__tests__/__snapshots__/metrics_grid.test.tsx.snap b/public/components/metrics/view/__tests__/__snapshots__/metrics_grid.test.tsx.snap index 2d9986f51e..ea4b819488 100644 --- a/public/components/metrics/view/__tests__/__snapshots__/metrics_grid.test.tsx.snap +++ b/public/components/metrics/view/__tests__/__snapshots__/metrics_grid.test.tsx.snap @@ -26,6 +26,7 @@ exports[`Metrics Grid Component renders Metrics Grid Component 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -129,6 +130,7 @@ exports[`Metrics Grid Component renders Metrics Grid Component 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -198,6 +200,7 @@ exports[`Metrics Grid Component renders Metrics Grid Component 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -301,6 +304,7 @@ exports[`Metrics Grid Component renders Metrics Grid Component 1`] = ` "setBreadcrumbs": [MockFunction], "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/trace_analytics/components/dashboard/__tests__/__snapshots__/dashboard.test.tsx.snap b/public/components/trace_analytics/components/dashboard/__tests__/__snapshots__/dashboard.test.tsx.snap index 5455a36e57..f416ed9600 100644 --- a/public/components/trace_analytics/components/dashboard/__tests__/__snapshots__/dashboard.test.tsx.snap +++ b/public/components/trace_analytics/components/dashboard/__tests__/__snapshots__/dashboard.test.tsx.snap @@ -29,6 +29,7 @@ exports[`Dashboard component renders dashboard 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -174,6 +175,7 @@ exports[`Dashboard component renders dashboard 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -398,6 +400,7 @@ exports[`Dashboard component renders dashboard 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -543,6 +546,7 @@ exports[`Dashboard component renders dashboard 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -1246,6 +1250,7 @@ exports[`Dashboard component renders empty dashboard 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -1391,6 +1396,7 @@ exports[`Dashboard component renders empty dashboard 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -1614,6 +1620,7 @@ exports[`Dashboard component renders empty dashboard 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -1759,6 +1766,7 @@ exports[`Dashboard component renders empty dashboard 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -2462,6 +2470,7 @@ exports[`Dashboard component renders empty jaeger dashboard 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -2607,6 +2616,7 @@ exports[`Dashboard component renders empty jaeger dashboard 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -2832,6 +2842,7 @@ exports[`Dashboard component renders empty jaeger dashboard 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -2977,6 +2988,7 @@ exports[`Dashboard component renders empty jaeger dashboard 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/trace_analytics/components/services/__tests__/__snapshots__/services.test.tsx.snap b/public/components/trace_analytics/components/services/__tests__/__snapshots__/services.test.tsx.snap index 71f193d6e1..ed324808ee 100644 --- a/public/components/trace_analytics/components/services/__tests__/__snapshots__/services.test.tsx.snap +++ b/public/components/trace_analytics/components/services/__tests__/__snapshots__/services.test.tsx.snap @@ -29,6 +29,7 @@ exports[`Services component renders empty services page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -167,6 +168,7 @@ exports[`Services component renders empty services page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -376,6 +378,7 @@ exports[`Services component renders empty services page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -514,6 +517,7 @@ exports[`Services component renders empty services page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -2239,6 +2243,7 @@ exports[`Services component renders jaeger services page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -2374,6 +2379,7 @@ exports[`Services component renders jaeger services page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -2587,6 +2593,7 @@ exports[`Services component renders jaeger services page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -2722,6 +2729,7 @@ exports[`Services component renders jaeger services page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -3883,6 +3891,7 @@ exports[`Services component renders services page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -4018,6 +4027,7 @@ exports[`Services component renders services page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -4230,6 +4240,7 @@ exports[`Services component renders services page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -4365,6 +4376,7 @@ exports[`Services component renders services page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/components/trace_analytics/components/traces/__tests__/__snapshots__/traces.test.tsx.snap b/public/components/trace_analytics/components/traces/__tests__/__snapshots__/traces.test.tsx.snap index 15c83154e1..1cdc7e0986 100644 --- a/public/components/trace_analytics/components/traces/__tests__/__snapshots__/traces.test.tsx.snap +++ b/public/components/trace_analytics/components/traces/__tests__/__snapshots__/traces.test.tsx.snap @@ -29,6 +29,7 @@ exports[`Traces component renders empty traces page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -177,6 +178,7 @@ exports[`Traces component renders empty traces page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -385,6 +387,7 @@ exports[`Traces component renders empty traces page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -533,6 +536,7 @@ exports[`Traces component renders empty traces page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -1710,6 +1714,7 @@ exports[`Traces component renders jaeger traces page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -1855,6 +1860,7 @@ exports[`Traces component renders jaeger traces page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -2067,6 +2073,7 @@ exports[`Traces component renders jaeger traces page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -2212,6 +2219,7 @@ exports[`Traces component renders jaeger traces page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -3397,6 +3405,7 @@ exports[`Traces component renders traces page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -3542,6 +3551,7 @@ exports[`Traces component renders traces page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], @@ -3753,6 +3763,7 @@ exports[`Traces component renders traces page 1`] = ` "getBreadcrumbsEnricher$": [MockFunction], "getCustomNavLink$": [MockFunction], "getHeaderComponent": [MockFunction], + "getHeaderVariant$": [MockFunction], "getHelpExtension$": [MockFunction], "getIsNavDrawerLocked$": [MockFunction], "getIsVisible$": [MockFunction], @@ -3898,6 +3909,7 @@ exports[`Traces component renders traces page 1`] = ` }, "setBreadcrumbsEnricher": [MockFunction], "setCustomNavLink": [MockFunction], + "setHeaderVariant": [MockFunction], "setHelpExtension": [MockFunction], "setHelpSupportUrl": [MockFunction], "setIsVisible": [MockFunction], diff --git a/public/framework/core_refs.ts b/public/framework/core_refs.ts index 59315c2fa7..7759d65abd 100644 --- a/public/framework/core_refs.ts +++ b/public/framework/core_refs.ts @@ -17,6 +17,7 @@ import { DashboardStart } from '../../../../src/plugins/dashboard/public'; import { DataSourcePluginStart } from '../../../../src/plugins/data_source/public'; import PPLService from '../services/requests/ppl'; import { DataSourceStart } from '../../../../src/plugins/data/public/data_sources/datasource_services/types'; +import { NavigationPublicPluginStart } from '../../../../src/plugins/navigation/public'; class CoreRefs { private static _instance: CoreRefs; @@ -36,6 +37,7 @@ class CoreRefs { public overlays?: OverlayStart; public dataSource?: DataSourcePluginStart; public dataSources?: DataSourceStart; + public navigation?: NavigationPublicPluginStart; private constructor() { // ... } diff --git a/public/plugin.tsx b/public/plugin.tsx index b2ee978508..99033e0bf8 100644 --- a/public/plugin.tsx +++ b/public/plugin.tsx @@ -448,6 +448,7 @@ export class ObservabilityPlugin coreRefs.summarizeEnabled = this.config.summarize.enabled; coreRefs.overlays = core.overlays; coreRefs.dataSource = startDeps.dataSource; + coreRefs.navigation = startDeps.navigation; const { dataSourceService, dataSourceFactory } = startDeps.data.dataSources; dataSourceFactory.registerDataSourceType(S3_DATA_SOURCE_TYPE, S3DataSource); From 359cdf9623a35d93010a28bd404438bf8ea4deec Mon Sep 17 00:00:00 2001 From: Adam Tackett <105462877+TackAdam@users.noreply.github.com> Date: Mon, 19 Aug 2024 10:39:47 -0700 Subject: [PATCH 2/3] [Feature] Multi-data Source Support for Getting Started (#2048) * first step of MDS Signed-off-by: Adam Tackett * add mds support to getting started Signed-off-by: Adam Tackett * update references, renaming, code cleanup Signed-off-by: Adam Tackett * update snapshots, remove depend Signed-off-by: Adam Tackett * only add mds reference to index patterns Signed-off-by: Adam Tackett --------- Signed-off-by: Adam Tackett Co-authored-by: Adam Tackett --- .../components/getting_started.tsx | 22 ++++-- .../getting_started_collectData.tsx | 13 +++- .../getting_started_queryAndAnalyze.tsx | 48 ++++++++---- .../getting_started/components/utils.tsx | 21 +++--- public/components/getting_started/home.tsx | 74 ++++++++++++++++-- .../getting_started/getting_started_router.ts | 75 +++++++++++++++++-- 6 files changed, 208 insertions(+), 45 deletions(-) diff --git a/public/components/getting_started/components/getting_started.tsx b/public/components/getting_started/components/getting_started.tsx index bc050bb747..ce7e2b57e1 100644 --- a/public/components/getting_started/components/getting_started.tsx +++ b/public/components/getting_started/components/getting_started.tsx @@ -10,13 +10,17 @@ import { GettingStartedConnectionsHeader } from './getting_started_header'; import { CollectAndShipData } from './getting_started_collectData'; import { QueryAndAnalyze } from './getting_started_queryAndAnalyze'; -export const NewGettingStarted = (props: HomeProps) => { - const { chrome } = props; +interface ExtendedHomeProps extends HomeProps { + selectedDataSourceId: string; + selectedDataSourceLabel: string; +} + +export const NewGettingStarted = (props: ExtendedHomeProps) => { + const { chrome, selectedDataSourceId, selectedDataSourceLabel } = props; const [selectedSource, setSelectedSource] = useState(''); const [isPickYourSourceOpen, setIsPickYourSourceOpen] = useState(true); const [isQueryDataOpen, setIsQueryDataOpen] = useState(false); - const [indexPatterns, setIndexPatterns] = useState([]); - const [isSampleDataset, setIsSampleDataset] = useState(false); // New state + const [isSampleDataset, setIsSampleDataset] = useState(false); useEffect(() => { chrome.setBreadcrumbs([ @@ -25,7 +29,7 @@ export const NewGettingStarted = (props: HomeProps) => { href: '#/', }, ]); - }, []); + }, [chrome]); const handleSelectSource = (source: string) => { setSelectedSource(source); @@ -42,10 +46,9 @@ export const NewGettingStarted = (props: HomeProps) => { setIsQueryDataOpen(isOpen); }; - const setQueryDataOpen = (patterns: string[]) => { + const setQueryDataOpen = () => { setIsPickYourSourceOpen(false); setIsQueryDataOpen(true); - setIndexPatterns(patterns); }; const handleCardSelectionChange = (isSample: boolean) => { @@ -64,6 +67,8 @@ export const NewGettingStarted = (props: HomeProps) => { onMoveToQueryData={setQueryDataOpen} onSelectSource={handleSelectSource} onCardSelectionChange={handleCardSelectionChange} + selectedDataSourceId={selectedDataSourceId} + selectedDataSourceLabel={selectedDataSourceLabel} /> {!isSampleDataset && ( @@ -71,7 +76,8 @@ export const NewGettingStarted = (props: HomeProps) => { isOpen={isQueryDataOpen} onToggle={toggleQueryData} selectedTechnology={selectedSource} - indexPatterns={indexPatterns} + selectedDataSourceId={selectedDataSourceId} + selectedDataSourceLabel={selectedDataSourceLabel} /> )} diff --git a/public/components/getting_started/components/getting_started_collectData.tsx b/public/components/getting_started/components/getting_started_collectData.tsx index 81e15af379..30f7e45bd4 100644 --- a/public/components/getting_started/components/getting_started_collectData.tsx +++ b/public/components/getting_started/components/getting_started_collectData.tsx @@ -40,6 +40,13 @@ interface CollectAndShipDataProps { onMoveToQueryData: (indexPatterns: string[]) => void; onSelectSource: (source: string) => void; onCardSelectionChange: (isSampleDataset: boolean) => void; + selectedDataSourceId: string; + selectedDataSourceLabel: string; +} + +interface CollectorOption { + label: string; + value: string; } export const CollectAndShipData: React.FC = ({ @@ -48,6 +55,8 @@ export const CollectAndShipData: React.FC = ({ onMoveToQueryData, onSelectSource, onCardSelectionChange, + selectedDataSourceId, + selectedDataSourceLabel, }) => { const [collectionMethod, setCollectionMethod] = useState(''); const [specificMethod, setSpecificMethod] = useState(''); @@ -56,7 +65,7 @@ export const CollectAndShipData: React.FC = ({ const [_selectedWorkflow, setSelectedWorkflow] = useState(''); const [workflows, setWorkflows] = useState([]); const [selectedCard, setSelectedCard] = useState(''); - const [collectorOptions, setCollectorOptions] = useState([]); + const [collectorOptions, setCollectorOptions] = useState([]); const technologyJsonMap: Record = { otel: otelJson, @@ -267,7 +276,7 @@ export const CollectAndShipData: React.FC = ({ { - await UploadAssets(specificMethod); + await UploadAssets(specificMethod, selectedDataSourceId, selectedDataSourceLabel); }} fill > diff --git a/public/components/getting_started/components/getting_started_queryAndAnalyze.tsx b/public/components/getting_started/components/getting_started_queryAndAnalyze.tsx index 8baa5c6766..064beb834d 100644 --- a/public/components/getting_started/components/getting_started_queryAndAnalyze.tsx +++ b/public/components/getting_started/components/getting_started_queryAndAnalyze.tsx @@ -19,20 +19,32 @@ import { import { coreRefs } from '../../../../public/framework/core_refs'; import { fetchDashboardIds, fetchIndexPatternIds } from './utils'; +interface Pattern { + id: string; + title: string; +} + +interface Dashboard { + id: string; + title: string; +} + interface QueryAndAnalyzeProps { isOpen: boolean; onToggle: (isOpen: boolean) => void; selectedTechnology: string; - indexPatterns: string[]; + selectedDataSourceId: string; + selectedDataSourceLabel: string; } export const QueryAndAnalyze: React.FC = ({ isOpen, onToggle, selectedTechnology, + selectedDataSourceId, }) => { - const [patternsContent, setPatternsContent] = useState([]); - const [dashboardsContent, setDashboardsContent] = useState([]); + const [patternsContent, setPatternsContent] = useState([]); + const [dashboardsContent, setDashboardsContent] = useState([]); const fetchIndexPatternContent = async () => { try { @@ -47,26 +59,34 @@ export const QueryAndAnalyze: React.FC = ({ const content = await fetchDashboardIds(selectedTechnology); setDashboardsContent(content.data.length !== 0 ? content.data : []); } catch (error) { - console.error('Error fetching index patterns:', error); + console.error('Error fetching dashboards:', error); setDashboardsContent([]); } }; - const redirectToDashboards = (path: string) => { - coreRefs?.application!.navigateToApp('dashboards', { - path: `#/${path}`, - }); - }; - useEffect(() => { if (selectedTechnology !== '') { fetchIndexPatternContent(); } - }, [selectedTechnology]); + }, [selectedTechnology, selectedDataSourceId]); const handleIndexPatternClick = (patternId: string) => { + const finalPatternId = selectedDataSourceId + ? `mds-${selectedDataSourceId}-objectId-${patternId}` + : patternId; + coreRefs?.application!.navigateToApp('data-explorer', { - path: `discover#?_a=(discover:(columns:!(_source),isDirty:!f,sort:!()),metadata:(indexPattern:'${patternId}',view:discover))&_q=(filters:!(),query:(language:kuery,query:''))&_g=(filters:!(),refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))`, + path: `discover#?_a=(discover:(columns:!(_source),isDirty:!f,sort:!()),metadata:(indexPattern:'${finalPatternId}',view:discover))&_q=(filters:!(),query:(language:kuery,query:''))&_g=(filters:!(),refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))`, + }); + }; + + const redirectToDashboards = (dashboardId: string) => { + const finalDashboardId = selectedDataSourceId + ? `mds-${selectedDataSourceId}-objectId-${dashboardId}` + : dashboardId; + + coreRefs?.application!.navigateToApp('dashboards', { + path: `#/view/${finalDashboardId}`, }); }; @@ -111,13 +131,13 @@ export const QueryAndAnalyze: React.FC = ({ {dashboardsContent.length !== 0 && dashboardsContent.map((dashboard) => ( - + } title={dashboard.title} description={`Explore the ${dashboard.title} dashboard`} onClick={() => { - redirectToDashboards(`/view/${dashboard.id}`); + redirectToDashboards(dashboard.id); }} /> diff --git a/public/components/getting_started/components/utils.tsx b/public/components/getting_started/components/utils.tsx index dd0e741525..8a155b75c0 100644 --- a/public/components/getting_started/components/utils.tsx +++ b/public/components/getting_started/components/utils.tsx @@ -4,7 +4,6 @@ */ import { coreRefs } from '../../../framework/core_refs'; -import { uploadBundle } from '../../integrations/components/upload_flyout'; import { useToast } from '../../../../public/components/common/toast'; const fetchAssets = async (tutorialId: string, assetFilter?: 'dashboards' | 'indexPatterns') => { @@ -21,18 +20,20 @@ const fetchAssets = async (tutorialId: string, assetFilter?: 'dashboards' | 'ind return responeData; }; -export const UploadAssets = async (tutorialId: string) => { +export const UploadAssets = async (tutorialId: string, mdsId: string, mdsLabel: string) => { const { setToast } = useToast(); - try { - const responeData = await fetchAssets(tutorialId); + const http = coreRefs.http; - const blob = new Blob([responeData.data], { type: 'application/x-ndjson' }); - const file = new File([blob], 'ndjson-file.ndjson'); + try { + const response = await http!.post(`/api/observability/gettingStarted/createAssets`, { + body: JSON.stringify({ + mdsId, + mdsLabel, + tutorialId, + }), + }); - const error = await uploadBundle(file); - if (error) { - console.error(error.message); - } else { + if (response) { setToast('Created saved object assets successfully', 'success'); } } catch (err) { diff --git a/public/components/getting_started/home.tsx b/public/components/getting_started/home.tsx index e41a4c5040..15f1277808 100644 --- a/public/components/getting_started/home.tsx +++ b/public/components/getting_started/home.tsx @@ -3,18 +3,22 @@ * SPDX-License-Identifier: Apache-2.0 */ -import React from 'react'; +import React, { useState, useMemo } from 'react'; import { HashRouter, Route, RouteComponentProps, Switch } from 'react-router-dom'; -import { TraceAnalyticsCoreDeps } from '../trace_analytics/home'; import { ChromeBreadcrumb, ChromeStart, HttpStart, + MountPoint, NotificationsStart, + SavedObjectsStart, } from '../../../../../src/core/public'; +import { + DataSourceManagementPluginSetup, + DataSourceSelectableConfig, +} from '../../../../../src/plugins/data_source_management/public'; import { NewGettingStarted } from './components/getting_started'; - -export type AppAnalyticsCoreDeps = TraceAnalyticsCoreDeps; +import { dataSourceFilterFn } from '../../../common/utils/shared'; export interface HomeProps extends RouteComponentProps { pplService: any; @@ -22,26 +26,84 @@ export interface HomeProps extends RouteComponentProps { http: HttpStart; chrome: ChromeStart; notifications: NotificationsStart; + dataSourceEnabled: boolean; + dataSourceManagement: DataSourceManagementPluginSetup; + savedObjectsMDSClient: SavedObjectsStart; + setActionMenu: (menuMount: MountPoint | undefined) => void; } export const Home = (props: HomeProps) => { - const { http, chrome, pplService, notifications } = props; + const { + http, + chrome, + pplService, + notifications, + dataSourceEnabled, + dataSourceManagement, + savedObjectsMDSClient, + parentBreadcrumb, + setActionMenu, + } = props; + + const [selectedDataSourceId, setSelectedDataSourceId] = useState(''); + const [selectedDataSourceLabel, setSelectedDataSourceLabel] = useState(''); + + const onSelectedDataSourceChange = (e: any) => { + const dataSourceId = e[0] ? e[0].id : undefined; + const dataSourceLabel = e[0] ? e[0].label : ''; + setSelectedDataSourceId(dataSourceId); + setSelectedDataSourceLabel(dataSourceLabel); + }; + + const DataSourceMenu = useMemo(() => { + if (dataSourceEnabled && dataSourceManagement?.ui) { + return dataSourceManagement.ui.getDataSourceMenu(); + } + return null; + }, [dataSourceManagement, dataSourceEnabled]); + + const dataSourceMenuComponent = useMemo(() => { + if (DataSourceMenu) { + return ( + + ); + } + return null; + }, [savedObjectsMDSClient.client, notifications, DataSourceMenu, setActionMenu]); const commonProps = { http, chrome, pplService, notifications, + dataSourceEnabled, + dataSourceManagement, + savedObjectsMDSClient, + parentBreadcrumb, + selectedDataSourceId, + selectedDataSourceLabel, + setActionMenu, }; return (
+ {dataSourceMenuComponent} } + render={(routerProps) => } /> diff --git a/server/routes/getting_started/getting_started_router.ts b/server/routes/getting_started/getting_started_router.ts index a1ae0d5bb6..a7ca1f5ea0 100644 --- a/server/routes/getting_started/getting_started_router.ts +++ b/server/routes/getting_started/getting_started_router.ts @@ -3,11 +3,6 @@ * SPDX-License-Identifier: Apache-2.0 */ -/* - * Copyright OpenSearch Contributors - * SPDX-License-Identifier: Apache-2.0 - */ - import { schema } from '@osd/config-schema'; import { Readable } from 'stream'; import { @@ -134,4 +129,74 @@ export function registerGettingStartedRoutes(router: IRouter) { } } ); + + router.post( + { + path: `/api/observability/gettingStarted/createAssets`, + validate: { + body: schema.object({ + mdsId: schema.string(), + mdsLabel: schema.string(), + tutorialId: schema.string(), + }), + }, + }, + async ( + context, + request, + response + ): Promise> => { + try { + const { mdsId, mdsLabel, tutorialId } = request.body; + const fileData = await loadAssetsFromFile(tutorialId); + + const objects = await createSavedObjectsStreamFromNdJson(Readable.from(fileData)); + const loadedObjects = await objects.toArray(); + + const updatedObjects = loadedObjects.map((obj) => { + if (mdsId) { + const newId = `mds-${mdsId}-objectId-${obj.id}`; + + const newReferences = + obj.references?.map((ref: { id: any }) => { + return { + ...ref, + id: `mds-${mdsId}-objectId-${ref.id}`, + }; + }) || []; + + if (obj.type === 'index-pattern') { + newReferences.push({ + id: mdsId, + type: 'data-source', + name: mdsLabel, + }); + } + + return { + ...obj, + id: newId, + references: newReferences, + }; + } else { + return obj; + } + }); + + await context.core.savedObjects.client.bulkCreate(updatedObjects); + + return response.ok({ + body: { + message: 'Objects loaded successfully', + }, + }); + } catch (error) { + console.error(error); + return response.custom({ + statusCode: error.statusCode || 500, + body: 'Issue in loading objects for mdsId:', + }); + } + } + ); } From 69d12cee1b0e43869d078e30cc996e9d685e44a9 Mon Sep 17 00:00:00 2001 From: Miki Date: Mon, 19 Aug 2024 15:31:41 -0700 Subject: [PATCH 3/3] Use smaller and compressed varients of buttons and form components (#2068) * Use EuiSmallButton Signed-off-by: Miki * Use EuiSmallButtonIcon Signed-off-by: Miki * Use EuiSmallButtonEmpty Signed-off-by: Miki * Use EuiCompressedFormRow Signed-off-by: Miki * Use EuiCompressedField* Signed-off-by: Miki * Use EuiCompressedSelect and EuiCompressedSuperSelect Signed-off-by: Miki * Use EuiCompressedFilePicker Signed-off-by: Miki * Use EuiCompressedRadio and EuiCompressedRadioGroup Signed-off-by: Miki * Use EuiCompressedSwitch Signed-off-by: Miki * Use EuiCompressedEuiTextArea Signed-off-by: Miki * Use EuiCompressedComboBox Signed-off-by: Miki * Use EuiSmallFilterButton Signed-off-by: Miki * Undo unnecessary EuiSmallButton* uses Signed-off-by: Miki * Use EuiCompressedSuperDatePicker Signed-off-by: Miki * Fix tests and snapshots Signed-off-by: Miki * Fix tests and snapshots Signed-off-by: Miki --------- Signed-off-by: Miki --- .../__snapshots__/create.test.tsx.snap | 800 ++++---- .../__snapshots__/log_config.test.tsx.snap | 214 +- .../service_config.test.tsx.snap | 112 +- .../__snapshots__/trace_config.test.tsx.snap | 68 +- .../components/app_table.tsx | 16 +- .../config_components/log_config.tsx | 6 +- .../config_components/service_config.tsx | 10 +- .../config_components/trace_config.tsx | 10 +- .../components/configuration.tsx | 10 +- .../components/create.tsx | 30 +- .../availability_info_flyout.tsx | 4 +- .../common/helpers/delete_modal.tsx | 20 +- .../common/helpers/ppl_reference_flyout.tsx | 8 +- .../live_tail_button.test.tsx.snap | 349 ++-- .../common/live_tail/live_tail_button.tsx | 10 +- .../__snapshots__/search.test.tsx.snap | 460 +++-- .../components/common/search/autocomplete.tsx | 4 +- .../components/common/search/date_picker.tsx | 4 +- .../common/search/direct_search.tsx | 13 +- public/components/common/search/search.tsx | 17 +- .../components/common/search/searchindex.tsx | 4 +- .../custom_panel_table.test.tsx.snap | 28 +- .../custom_panel_view.test.tsx.snap | 1352 ++++++------ .../custom_panel_view_so.test.tsx.snap | 54 +- .../custom_panels/custom_panel_table.tsx | 22 +- .../custom_panels/custom_panel_view.tsx | 26 +- .../custom_panels/custom_panel_view_so.tsx | 26 +- .../custom_input_model.test.tsx.snap | 32 +- .../modal_container.test.tsx.snap | 16 +- .../helpers/add_visualization_popover.tsx | 6 +- .../helpers/custom_input_modal.tsx | 24 +- .../helpers/modal_containers.tsx | 19 +- .../__snapshots__/empty_panel.test.tsx.snap | 238 ++- .../visualization_container.tsx | 18 +- .../visualization_flyout.test.tsx.snap | 310 +-- .../visualization_flyout_so.test.tsx.snap | 310 +-- .../visualization_flyout.tsx | 36 +- .../visualization_flyout_so.tsx | 36 +- .../associated_objects_tab.test.tsx.snap | 475 +++-- .../data_connection.test.tsx.snap | 6 +- .../inactive_data_connection.test.tsx.snap | 2 +- ...installed_integrations_table.test.tsx.snap | 147 +- ...data_connections_description.test.tsx.snap | 113 +- ...anage_data_connections_table.test.tsx.snap | 2 +- .../__snapshots__/no_access.test.tsx.snap | 68 +- .../acceleration_action_overlay.tsx | 8 +- .../acceleration_details_flyout.tsx | 18 +- .../accelerations/acceleration_table.tsx | 6 +- .../create_acceleration.test.tsx.snap | 168 +- .../create_acceleration_button.test.tsx.snap | 2 +- .../create/create_acceleration.tsx | 6 +- .../create/create_acceleration_button.tsx | 6 +- .../define_index_options.test.tsx.snap | 18 +- .../index_advanced_settings.test.tsx.snap | 30 +- .../index_setting_options.test.tsx.snap | 78 +- .../index_type_selector.test.tsx.snap | 16 +- .../preview_sql_defintion.test.tsx.snap | 8 +- .../source_selector.test.tsx.snap | 20 +- .../selectors/define_index_options.tsx | 16 +- .../selectors/index_advanced_settings.tsx | 14 +- .../selectors/index_setting_options.tsx | 38 +- .../selectors/index_type_selector.tsx | 10 +- .../selectors/preview_sql_defintion.tsx | 14 +- .../selectors/source_selector.tsx | 16 +- .../query_visual_editor.test.tsx.snap | 28 +- .../covering_index/covering_index_builder.tsx | 4 +- .../column_expression.test.tsx.snap | 4 +- .../materialized_view/add_column_popover.tsx | 24 +- .../materialized_view/column_expression.tsx | 28 +- .../group_by_tumble_expression.tsx | 26 +- .../add_fields_modal.test.tsx.snap | 16 +- .../delete_fields_modal.test.tsx.snap | 16 +- .../generate_fields.test.tsx.snap | 2 +- .../skipping_index_builder.test.tsx.snap | 28 +- .../skipping_index/add_fields_modal.tsx | 8 +- .../skipping_index/delete_fields_modal.tsx | 8 +- .../skipping_index/generate_fields.tsx | 6 +- .../skipping_index/skipping_index_builder.tsx | 18 +- .../utils/acceleration_utils.tsx | 6 +- .../components/manage/access_control_tab.tsx | 6 +- .../associated_objects_details_flyout.tsx | 8 +- .../associated_objects_refresh_button.tsx | 6 +- .../utils/associated_objects_tab_empty.tsx | 6 +- .../components/manage/data_connection.tsx | 6 +- .../manage/inactive_data_connection.tsx | 6 +- .../installed_integrations_table.tsx | 10 +- .../manage_data_connections_description.tsx | 6 +- .../components/new/auth_details.tsx | 32 +- .../new/configure_prometheus_datasource.tsx | 27 +- .../new/configure_s3_datasource.tsx | 38 +- .../datasources/components/new/name_row.tsx | 8 +- .../components/new/query_permissions.tsx | 14 +- ...ew_prometheus_datasource_configuration.tsx | 4 +- .../review_s3_datasource_configuration.tsx | 4 +- .../datasources/components/no_access.tsx | 6 +- .../explorer/accelerate_callout.tsx | 4 +- .../explorer/datasources/tables_flyout.tsx | 10 +- .../explorer/direct_query_running.tsx | 10 +- .../__snapshots__/flyout_button.test.tsx.snap | 67 +- .../detail_table/table_row_btn_collapse.tsx | 6 +- .../explorer/events_views/docViewRow.tsx | 6 +- .../explorer/events_views/doc_flyout.tsx | 6 +- .../events_views/surrounding_flyout.tsx | 27 +- .../patterns_header.test.tsx.snap | 139 +- .../explorer/log_patterns/patterns_header.tsx | 14 +- .../explorer/query_assist/input.tsx | 10 +- .../__snapshots__/save_panel.test.tsx.snap | 109 +- .../explorer/save_panel/save_panel.tsx | 17 +- .../__snapshots__/field.test.tsx.snap | 70 +- .../__snapshots__/sidebar.test.tsx.snap | 1822 ++++++++++------- .../explorer/sidebar/field.tsx | 5 +- .../__snapshots__/config_panel.test.tsx.snap | 315 +-- .../config_panel/config_panel.tsx | 4 +- .../config_controls/config_availability.tsx | 38 +- .../config_color_palette_picker.tsx | 10 +- .../config_controls/config_color_theme.tsx | 22 +- .../config_controls/config_number_input.tsx | 4 +- .../config_controls/config_panel_item.tsx | 4 +- .../config_panel_option_gauge.tsx | 8 +- .../config_controls/config_panel_options.tsx | 14 +- .../config_single_color_picker.tsx | 6 +- .../config_controls/config_switch.tsx | 6 +- .../config_controls/config_switch_button.tsx | 4 +- .../config_controls/config_text_input.tsx | 4 +- .../config_controls/config_thresholds.tsx | 30 +- .../config_treemap_parents.tsx | 6 +- .../config_controls/config_yaxis_side.tsx | 24 +- .../data_config_panel_fields.tsx | 12 +- .../data_configurations_panel.tsx | 40 +- .../logs_view_config_panel_item.tsx | 15 +- .../treemap_config_panel_item.tsx | 18 +- .../config_panes/default_vis_editor.tsx | 10 +- .../visualizations/direct_query_vis.tsx | 6 +- .../plotly_viz_editor/plotly_actions.tsx | 4 +- .../saved_query_table.test.tsx.snap | 1 + .../components/event_analytics/home/home.tsx | 18 +- .../added_integration.test.tsx.snap | 70 +- .../added_integration_flyout.test.tsx.snap | 468 +++-- .../added_integration_table.test.tsx.snap | 1 + ...ilable_integration_card_view.test.tsx.snap | 22 +- .../integration_header.test.tsx.snap | 118 +- .../setup_integration.test.tsx.snap | 499 +++-- .../setup_integration_inputs.test.tsx.snap | 762 ++++--- .../__snapshots__/upload_flyout.test.tsx.snap | 18 +- .../components/add_integration_flyout.tsx | 30 +- .../components/added_integration.tsx | 4 +- .../available_integration_card_view.tsx | 4 +- .../available_integration_overview_page.tsx | 6 +- .../components/integration_header.tsx | 6 +- .../components/setup_integration.tsx | 12 +- .../components/setup_integration_inputs.tsx | 60 +- ...setup_integration_inputs_security_lake.tsx | 6 +- .../integrations/components/upload_flyout.tsx | 18 +- .../__snapshots__/sidebar.test.tsx.snap | 4 +- .../metrics/sidebar/data_source_picker.tsx | 5 +- .../metrics/sidebar/index_picker.tsx | 4 +- .../metrics_export_panel.test.tsx.snap | 164 +- .../__snapshots__/top_menu.test.tsx.snap | 418 ++-- .../metrics/top_menu/metrics_export_panel.tsx | 18 +- .../components/metrics/top_menu/top_menu.tsx | 14 +- .../__snapshots__/note_table.test.tsx.snap | 18 +- .../__snapshots__/notebook.test.tsx.snap | 16 +- .../modal_containers.test.tsx.snap | 32 +- .../custom_input_modal.test.tsx.snap | 32 +- .../custom_modals/custom_input_modal.tsx | 20 +- .../custom_modals/reporting_loading_modal.tsx | 32 +- .../components/helpers/modal_containers.tsx | 20 +- .../notebooks/components/note_table.tsx | 22 +- .../notebooks/components/notebook.tsx | 38 +- .../__snapshots__/para_input.test.tsx.snap | 16 +- .../__snapshots__/paragraphs.test.tsx.snap | 8 +- .../paragraph_components/para_input.tsx | 32 +- .../paragraph_components/paragraphs.tsx | 18 +- .../helper_functions.test.tsx.snap | 4 +- .../__snapshots__/search_bar.test.tsx.snap | 207 +- .../filter_edit_popover.test.tsx.snap | 180 +- .../filter_helpers.test.tsx.snap | 73 +- .../__snapshots__/filters.test.tsx.snap | 70 +- .../common/filters/filter_edit_popover.tsx | 28 +- .../common/filters/filter_helpers.tsx | 22 +- .../components/common/filters/filters.tsx | 4 +- .../components/common/helper_functions.tsx | 6 +- .../__snapshots__/service_map.test.tsx.snap | 4 +- .../components/common/plots/service_map.tsx | 4 +- .../common/plots/service_map_node_details.tsx | 14 +- .../components/common/search_bar.tsx | 10 +- .../__snapshots__/dashboard.test.tsx.snap | 334 +-- .../__snapshots__/mode_picker.test.tsx.snap | 220 +- .../dashboard/__tests__/mode_picker.test.tsx | 2 +- .../dashboard/latency_trend_cell.tsx | 11 +- .../components/dashboard/mode_picker.tsx | 6 +- .../__snapshots__/services.test.tsx.snap | 1003 ++++----- .../services/service_trends_plots.tsx | 4 +- .../components/services/service_view.tsx | 6 +- .../__snapshots__/traces.test.tsx.snap | 959 +++++---- .../__snapshots__/traces_table.test.tsx.snap | 263 +-- .../components/traces/flyout_list_item.tsx | 4 +- .../components/traces/span_detail_flyout.tsx | 14 +- .../components/traces/trace_view.tsx | 6 +- .../components/traces/traces_table.tsx | 10 +- .../charts/data_table/data_table_header.tsx | 18 +- 201 files changed, 8690 insertions(+), 7212 deletions(-) diff --git a/public/components/application_analytics/__tests__/__snapshots__/create.test.tsx.snap b/public/components/application_analytics/__tests__/__snapshots__/create.test.tsx.snap index c930457508..83a0140a86 100644 --- a/public/components/application_analytics/__tests__/__snapshots__/create.test.tsx.snap +++ b/public/components/application_analytics/__tests__/__snapshots__/create.test.tsx.snap @@ -59,7 +59,7 @@ Object { class="euiForm" >
@@ -77,13 +77,13 @@ Object { class="euiFormRow__fieldWrapper" >
@@ -112,13 +112,13 @@ Object { class="euiFormRow__fieldWrapper" >