diff --git a/dashboards-observability/public/components/application_analytics/components/flyout_components/availability_info_flyout.tsx b/dashboards-observability/public/components/application_analytics/components/flyout_components/availability_info_flyout.tsx
new file mode 100644
index 000000000..86e668f41
--- /dev/null
+++ b/dashboards-observability/public/components/application_analytics/components/flyout_components/availability_info_flyout.tsx
@@ -0,0 +1,62 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import {
+ EuiFlyout,
+ EuiFlyoutHeader,
+ EuiTitle,
+ EuiFlyoutBody,
+ EuiText,
+ EuiCodeBlock,
+ EuiFlyoutFooter,
+ EuiButton,
+} from '@elastic/eui';
+import React from 'react';
+
+interface AvailabilityInfoFlyoutProps {
+ closeFlyout: () => void;
+}
+
+export function AvailabilityInfoFlyout(props: AvailabilityInfoFlyoutProps) {
+ const { closeFlyout } = props;
+
+ return (
+
+
+
+ Availability
+
+
+
+
+ Configure availability
+ Availability is the status of your application determined by availability levels set on a
+ time series metric. To create an availability level, you must configure the following:
+
+ - color: The color of the availability badge on the home page
+ - name: The text in the availability badge on the home page
+ - expression: Comparison operator to determine the availability
+ - value: Value to use when calculating availability
+
+ Configuring availability
+ By default, Application analytics shows results from the last 24 hours of your data. To
+ see data from a different timeframe, use the date and time selector.
+ Time series metric
A time series metric is any visualization that has a query that
+ spans over a timestamp and is a bar/line chart. You can use the PPL language to define
+ arbitrary conditions on your logs to create a visualization over time.
+ Example
+
+ {'source = | ... | ... | stats ... by span(, 1h)'}
+
+ You can then choose Bar or Line in visualization
+ configurations to create a time series metric.
+
+
+
+ Close
+
+
+ );
+}
diff --git a/dashboards-observability/public/components/custom_panels/panel_modules/panel_grid/panel_grid.tsx b/dashboards-observability/public/components/custom_panels/panel_modules/panel_grid/panel_grid.tsx
index cc529f862..dc70ba7fd 100644
--- a/dashboards-observability/public/components/custom_panels/panel_modules/panel_grid/panel_grid.tsx
+++ b/dashboards-observability/public/components/custom_panels/panel_modules/panel_grid/panel_grid.tsx
@@ -27,6 +27,7 @@ const ResponsiveGridLayout = WidthProvider(Responsive);
* http: http core service;
* chrome: chrome core service;
* panelId: OpenPanel Id
+ * updateAvailabilityVizId: function to update application if availabilityViz is removed from panel
* panelVisualizations: list of panel visualizations
* setPanelVisualizations: function to set panel visualizations
* editMode: boolean to check if the panel is in edit mode
@@ -168,7 +169,7 @@ export const PanelGrid = (props: PanelGridProps) => {
_.omit(layout, ['static', 'moved'])
);
saveVisualizationLayouts(panelId, visualizationParams);
- if (!_.isEmpty(updateAvailabilityVizId)) {
+ if (updateAvailabilityVizId) {
updateAvailabilityVizId(panelVisualizations);
}
}
diff --git a/dashboards-observability/public/components/event_analytics/explorer/visualizations/config_panel/config_panes/config_controls/config_availability.tsx b/dashboards-observability/public/components/event_analytics/explorer/visualizations/config_panel/config_panes/config_controls/config_availability.tsx
index 1a0f9ade5..49ad1e221 100644
--- a/dashboards-observability/public/components/event_analytics/explorer/visualizations/config_panel/config_panes/config_controls/config_availability.tsx
+++ b/dashboards-observability/public/components/event_analytics/explorer/visualizations/config_panel/config_panes/config_controls/config_availability.tsx
@@ -3,7 +3,7 @@
* SPDX-License-Identifier: Apache-2.0
*/
-import React, { useCallback } from 'react';
+import React, { useCallback, useState } from 'react';
import {
EuiButton,
EuiAccordion,
@@ -17,8 +17,10 @@ import {
EuiFieldText,
EuiSelect,
htmlIdGenerator,
+ EuiText,
} from '@elastic/eui';
import { isEmpty } from 'lodash';
+import { AvailabilityInfoFlyout } from '../../../../../../application_analytics/components/flyout_components/availability_info_flyout';
import { PPL_SPAN_REGEX } from '../../../../../../../../common/constants/shared';
export interface AvailabilityUnitType {
@@ -30,6 +32,8 @@ export interface AvailabilityUnitType {
}
export const ConfigAvailability = ({ visualizations, onConfigChange, vizState = {} }: any) => {
+ const [flyoutOpen, setFlyoutOpen] = useState(false);
+ const closeFlyout = () => setFlyoutOpen(false);
const addButtonText = '+ Add availability level';
const getAvailabilityUnit = () => {
return {
@@ -50,6 +54,13 @@ export const ConfigAvailability = ({ visualizations, onConfigChange, vizState =
{ value: '≠', text: '≠' },
];
+ const availabilityAccordionButton = (
+
+ Availability
+ setFlyoutOpen(true)} size="m" />
+
+ );
+
const hasSpanInApp =
visualizations.data.query.finalQuery.search(PPL_SPAN_REGEX) > 0 &&
visualizations.data.appData.fromApp &&
@@ -105,7 +116,7 @@ export const ConfigAvailability = ({ visualizations, onConfigChange, vizState =
+ {flyoutOpen && }
>
);
};