import {useMemo, useRef} from 'react'; import styled from '@emotion/styled'; import TransitionChart from 'sentry/components/charts/transitionChart'; import {space} from 'sentry/styles/space'; import type {MetricsQueryApiResponse} from 'sentry/types'; import type {ReactEchartsRef} from 'sentry/types/echarts'; import type {MetricDisplayType} from 'sentry/utils/metrics/types'; import type {MetricsQueryApiQueryParams} from 'sentry/utils/metrics/useMetricsQuery'; import {LoadingScreen} from 'sentry/views/dashboards/widgetCard/widgetCardChartContainer'; import {MetricChart} from 'sentry/views/ddm/chart/chart'; import {createChartPalette} from 'sentry/views/ddm/utils/metricsChartPalette'; import {getChartTimeseries} from 'sentry/views/ddm/widget'; import {DASHBOARD_CHART_GROUP} from '../dashboard'; type MetricChartContainerProps = { displayType: MetricDisplayType; isLoading: boolean; metricQueries: MetricsQueryApiQueryParams[]; chartHeight?: number; timeseriesData?: MetricsQueryApiResponse; }; export function MetricChartContainer({ timeseriesData, isLoading, metricQueries, chartHeight, displayType, }: MetricChartContainerProps) { const chartRef = useRef(null); const chartSeries = useMemo(() => { return timeseriesData ? getChartTimeseries(timeseriesData, metricQueries, { getChartPalette: createChartPalette, }) : []; }, [timeseriesData, metricQueries]); return ( ); } const MetricWidgetChartWrapper = styled('div')` height: 100%; width: 100%; padding: ${space(3)}; padding-top: ${space(2)}; `;