import {t} from 'sentry/locale'; import type {Series} from 'sentry/types/echarts'; import EventView, {type MetaType} from 'sentry/utils/discover/eventView'; import {RateUnit} from 'sentry/utils/discover/fields'; import { type DiscoverQueryProps, useGenericDiscoverQuery, } from 'sentry/utils/discover/genericDiscoverQuery'; import {DiscoverDatasets} from 'sentry/utils/discover/types'; import {formatRate} from 'sentry/utils/formatters'; import {MutableSearch} from 'sentry/utils/tokenizeSearch'; import {useLocation} from 'sentry/utils/useLocation'; import useOrganization from 'sentry/utils/useOrganization'; import {useParams} from 'sentry/utils/useParams'; import {SpanSummaryReferrer} from 'sentry/views/performance/transactionSummary/transactionSpans/spanSummary/referrers'; import { AVG_COLOR, THROUGHPUT_COLOR, TXN_THROUGHPUT_COLOR, } from 'sentry/views/starfish/colors'; import Chart, {ChartType} from 'sentry/views/starfish/components/chart'; import ChartPanel from 'sentry/views/starfish/components/chartPanel'; import {useSpanMetricsSeries} from 'sentry/views/starfish/queries/useDiscoverSeries'; import { SpanMetricsField, type SpanMetricsQueryFilters, } from 'sentry/views/starfish/types'; import {Block, BlockContainer} from 'sentry/views/starfish/views/spanSummaryPage/block'; function SpanSummaryCharts() { const organization = useOrganization(); const {spanSlug} = useParams(); const [spanOp, groupId] = spanSlug.split(':'); const location = useLocation(); const {transaction} = location.query; const filters: SpanMetricsQueryFilters = { 'span.group': groupId, 'span.op': spanOp, transaction: transaction as string, }; const { isLoading: isThroughputDataLoading, data: throughputData, error: throughputError, } = useSpanMetricsSeries( { search: MutableSearch.fromQueryObject(filters), yAxis: ['spm()'], }, SpanSummaryReferrer.SPAN_SUMMARY_THROUGHPUT_CHART ); const { isLoading: isAvgDurationDataLoading, data: avgDurationData, error: avgDurationError, } = useSpanMetricsSeries( { search: MutableSearch.fromQueryObject(filters), yAxis: [`avg(${SpanMetricsField.SPAN_DURATION})`], }, SpanSummaryReferrer.SPAN_SUMMARY_DURATION_CHART ); const eventView = EventView.fromNewQueryWithLocation( { yAxis: ['tpm()'], name: 'Transaction Throughput', query: MutableSearch.fromQueryObject({ transaction: transaction as string, }).formatString(), fields: [], version: 2, dataset: DiscoverDatasets.METRICS, }, location ); const { isLoading: isTxnThroughputDataLoading, data: txnThroughputData, error: txnThroughputError, } = useGenericDiscoverQuery< { data: any[]; meta: MetaType; }, DiscoverQueryProps >({ route: 'events-stats', eventView, location, orgSlug: organization.slug, getRequestPayload: () => ({ ...eventView.getEventsAPIPayload(location), yAxis: eventView.yAxis, interval: eventView.interval, }), options: { refetchOnWindowFocus: false, }, referrer: SpanSummaryReferrer.SPAN_SUMMARY_TRANSACTION_THROUGHPUT_CHART, }); const transactionSeries: Series = { seriesName: 'tpm()', data: txnThroughputData?.data.map(datum => ({ value: datum[1][0].count, name: datum[0] * 1000, })) ?? [], }; return ( formatRate(value, RateUnit.PER_MINUTE), }} /> formatRate(value, RateUnit.PER_MINUTE), }} /> ); } export default SpanSummaryCharts;