123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- import {CompactSelect} from 'sentry/components/compactSelect';
- import {t} from 'sentry/locale';
- import type {NewQuery} from 'sentry/types/organization';
- import {browserHistory} from 'sentry/utils/browserHistory';
- import EventView from 'sentry/utils/discover/eventView';
- import {DiscoverDatasets} from 'sentry/utils/discover/types';
- import {decodeScalar} from 'sentry/utils/queryString';
- import {MutableSearch} from 'sentry/utils/tokenizeSearch';
- import {useLocation} from 'sentry/utils/useLocation';
- import usePageFilters from 'sentry/utils/usePageFilters';
- import {COLD_START_TYPE} from 'sentry/views/performance/mobile/appStarts/screenSummary/startTypeSelector';
- import {TTID_CONTRIBUTING_SPAN_OPS} from 'sentry/views/performance/mobile/screenload/screenLoadSpans/spanOpSelector';
- import {MobileCursors} from 'sentry/views/performance/mobile/screenload/screens/constants';
- import {useTableQuery} from 'sentry/views/performance/mobile/screenload/screens/screensTable';
- import {SpanMetricsField} from 'sentry/views/starfish/types';
- import {appendReleaseFilters} from 'sentry/views/starfish/utils/releaseComparison';
- export const APP_START_SPANS = [
- ...TTID_CONTRIBUTING_SPAN_OPS,
- 'app.start.cold',
- 'app.start.warm',
- 'contentprovider.load',
- 'application.load',
- 'activity.load',
- 'process.load',
- ];
- type Props = {
- primaryRelease?: string;
- secondaryRelease?: string;
- transaction?: string;
- };
- export function SpanOpSelector({transaction, primaryRelease, secondaryRelease}: Props) {
- const location = useLocation();
- const {selection} = usePageFilters();
- const value = decodeScalar(location.query[SpanMetricsField.SPAN_OP]) ?? '';
- const appStartType =
- decodeScalar(location.query[SpanMetricsField.APP_START_TYPE]) ?? COLD_START_TYPE;
- const searchQuery = new MutableSearch([
- // Exclude root level spans because they're comprised of nested operations
- '!span.description:"Cold Start"',
- '!span.description:"Warm Start"',
- // Exclude this span because we can get TTID contributing spans instead
- '!span.description:"Initial Frame Render"',
- 'has:span.description',
- 'transaction.op:ui.load',
- `transaction:${transaction}`,
- `has:ttid`,
- `span.op:[${APP_START_SPANS.join(',')}]`,
- `app_start_type:${appStartType}`,
- ]);
- const queryStringPrimary = appendReleaseFilters(
- searchQuery,
- primaryRelease,
- secondaryRelease
- );
- const newQuery: NewQuery = {
- name: '',
- fields: [SpanMetricsField.SPAN_OP, 'count()'],
- query: queryStringPrimary,
- dataset: DiscoverDatasets.SPANS_METRICS,
- version: 2,
- projects: selection.projects,
- };
- const eventView = EventView.fromNewQueryWithLocation(newQuery, location);
- const {data} = useTableQuery({
- eventView,
- enabled: true,
- limit: 25,
- referrer: 'api.starfish.get-span-operations',
- });
- const options = [
- {value: '', label: t('All')},
- ...(data?.data ?? [])
- .filter(datum => Boolean(datum[SpanMetricsField.SPAN_OP]))
- .map(datum => {
- return {
- value: datum[SpanMetricsField.SPAN_OP],
- label: datum[SpanMetricsField.SPAN_OP],
- };
- }),
- ];
- return (
- <CompactSelect
- triggerProps={{prefix: t('Operation')}}
- value={value}
- options={options ?? []}
- onChange={newValue => {
- browserHistory.push({
- ...location,
- query: {
- ...location.query,
- [SpanMetricsField.SPAN_OP]: newValue.value,
- [MobileCursors.SPANS_TABLE]: undefined,
- },
- });
- }}
- />
- );
- }
|