123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- import {Location} from 'history';
- import keyBy from 'lodash/keyBy';
- import {getInterval} from 'sentry/components/charts/utils';
- import {PageFilters} from 'sentry/types';
- import {Series} from 'sentry/types/echarts';
- import EventView from 'sentry/utils/discover/eventView';
- import {DiscoverDatasets} from 'sentry/utils/discover/types';
- import {useLocation} from 'sentry/utils/useLocation';
- import usePageFilters from 'sentry/utils/usePageFilters';
- import type {IndexedSpan} from 'sentry/views/starfish/queries/types';
- import {useSpansQuery} from 'sentry/views/starfish/utils/useSpansQuery';
- export type SpanMetrics = {
- interval: number;
- 'p95(span.self_time)': number;
- 'sps()': number;
- 'sum(span.self_time)': number;
- 'time_spent_percentage()': number;
- };
- export const useSpanMetricsSeries = (
- span?: Pick<IndexedSpan, 'group'>,
- queryFilters: {transactionName?: string} = {},
- yAxis: string[] = [],
- referrer = 'span-metrics-series'
- ) => {
- const location = useLocation();
- const pageFilters = usePageFilters();
- const eventView = span
- ? getEventView(
- span,
- location,
- pageFilters.selection,
- yAxis,
- queryFilters.transactionName
- )
- : undefined;
- // TODO: Add referrer
- const {isLoading, data} = useSpansQuery<SpanMetrics[]>({
- eventView,
- initialData: [],
- referrer,
- });
- const parsedData = keyBy(
- yAxis.map(seriesName => {
- const series: Series = {
- seriesName,
- data: data.map(datum => ({value: datum[seriesName], name: datum.interval})),
- };
- return series;
- }),
- 'seriesName'
- );
- return {isLoading, data: parsedData};
- };
- function getEventView(
- span: {group: string},
- location: Location,
- pageFilters: PageFilters,
- yAxis: string[],
- transaction?: string
- ) {
- const cleanGroupId = span.group.replaceAll('-', '').slice(-16);
- return EventView.fromNewQueryWithLocation(
- {
- name: '',
- query: `span.group:${cleanGroupId}${
- transaction ? ` transaction:${transaction}` : ''
- }`,
- fields: [],
- yAxis,
- dataset: DiscoverDatasets.SPANS_METRICS,
- interval: getInterval(pageFilters.datetime, 'low'),
- projects: [1],
- version: 2,
- },
- location
- );
- }
|