123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- import {CHART_PALETTE} from 'sentry/constants/chartPalette';
- import {t} from 'sentry/locale';
- import Chart, {ChartType} from 'sentry/views/insights/common/components/chart';
- import ChartPanel from 'sentry/views/insights/common/components/chartPanel';
- import {useProcessQueuesTimeSeriesQuery} from 'sentry/views/insights/queues/queries/useProcessQueuesTimeSeriesQuery';
- import type {Referrer} from 'sentry/views/insights/queues/referrers';
- import {CHART_HEIGHT} from 'sentry/views/insights/queues/settings';
- interface Props {
- referrer: Referrer;
- destination?: string;
- error?: Error | null;
- }
- export function LatencyChart({error, destination, referrer}: Props) {
- const {data, isPending} = useProcessQueuesTimeSeriesQuery({
- destination,
- referrer,
- });
- return (
- <ChartPanel title={t('Avg Latency')}>
- <Chart
- height={CHART_HEIGHT}
- grid={{
- left: '0',
- right: '0',
- top: '8px',
- bottom: '0',
- }}
- data={[
- {
- seriesName: t('Average Time in Queue'),
- data: data['avg(messaging.message.receive.latency)'].data,
- },
- {
- seriesName: t('Average Processing Time'),
- data: data['avg(span.duration)'].data,
- },
- ]}
- loading={isPending}
- error={error}
- chartColors={CHART_PALETTE[2].slice(1)}
- type={ChartType.AREA}
- showLegend
- stacked
- aggregateOutputFormat="duration"
- />
- </ChartPanel>
- );
- }
|