1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- import {useMemo} from 'react';
- import styled from '@emotion/styled';
- import {space} from 'sentry/styles/space';
- import type {MetricsQueryApiResponse} from 'sentry/types';
- import {formatMetricsUsingUnitAndOp} from 'sentry/utils/metrics/formatters';
- import {parseMRI} from 'sentry/utils/metrics/mri';
- import {
- isMetricFormula,
- type MetricsQueryApiQueryParams,
- type MetricsQueryApiRequestQuery,
- } from 'sentry/utils/metrics/useMetricsQuery';
- import {LoadingScreen} from 'sentry/views/dashboards/widgetCard/widgetCardChartContainer';
- interface MetricBigNumberContainerProps {
- isLoading: boolean;
- metricQueries: MetricsQueryApiQueryParams[];
- timeseriesData?: MetricsQueryApiResponse;
- }
- export function MetricBigNumberContainer({
- timeseriesData,
- metricQueries,
- isLoading,
- }: MetricBigNumberContainerProps) {
- const bigNumberData = useMemo(() => {
- return timeseriesData ? getBigNumberData(timeseriesData, metricQueries) : undefined;
- }, [timeseriesData, metricQueries]);
- if (!bigNumberData) {
- return null;
- }
- return (
- <BigNumberWrapper>
- <LoadingScreen loading={isLoading} />
- <BigNumber>{bigNumberData}</BigNumber>
- </BigNumberWrapper>
- );
- }
- export function getBigNumberData(
- data: MetricsQueryApiResponse,
- queries: MetricsQueryApiQueryParams[]
- ): string {
- const filteredQueries = queries.filter(
- query => !isMetricFormula(query)
- ) as MetricsQueryApiRequestQuery[];
- const firstQuery = filteredQueries[0];
- const value = data.data[0][0].totals;
- return formatMetricsUsingUnitAndOp(
- value,
- parseMRI(firstQuery.mri)?.unit!,
- firstQuery.op
- );
- }
- const BigNumberWrapper = styled('div')`
- height: 100%;
- width: 100%;
- overflow: hidden;
- `;
- export const BigNumber = styled('div')`
- line-height: 1;
- display: inline-flex;
- flex: 1;
- width: 100%;
- min-height: 0;
- font-size: 32px;
- color: ${p => p.theme.headingColor};
- padding: ${space(1)} ${space(3)} ${space(3)} ${space(3)};
- * {
- text-align: left !important;
- }
- `;
|