1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- import {useDiscoverQuery} from 'sentry/utils/discover/discoverQuery';
- import EventView from 'sentry/utils/discover/eventView';
- import {DiscoverDatasets} from 'sentry/utils/discover/types';
- import {useLocation} from 'sentry/utils/useLocation';
- import useOrganization from 'sentry/utils/useOrganization';
- import usePageFilters from 'sentry/utils/usePageFilters';
- import {useResourceModuleFilters} from 'sentry/views/performance/browser/resources/utils/useResourceFilters';
- import {ValidSort} from 'sentry/views/performance/browser/resources/utils/useResourceSort';
- import {SpanMetricsField} from 'sentry/views/starfish/types';
- const {
- SPAN_DOMAIN,
- SPAN_GROUP,
- SPAN_DESCRIPTION,
- SPAN_OP,
- SPAN_SELF_TIME,
- RESOURCE_RENDER_BLOCKING_STATUS,
- HTTP_RESPONSE_CONTENT_LENGTH,
- } = SpanMetricsField;
- type Props = {
- sort: ValidSort;
- defaultResourceTypes?: string[];
- };
- export const useResourcesQuery = ({sort, defaultResourceTypes}: Props) => {
- const pageFilters = usePageFilters();
- const location = useLocation();
- const resourceFilters = useResourceModuleFilters();
- const {slug: orgSlug} = useOrganization();
- const queryConditions = [
- `${SPAN_OP}:${
- resourceFilters.type || `[${defaultResourceTypes?.join(',')}]` || 'resource.*'
- }`,
- ...(resourceFilters.transaction
- ? [`transaction:"${resourceFilters.transaction}"`]
- : []),
- ...(resourceFilters[SPAN_DOMAIN]
- ? [`${SPAN_DOMAIN}:${resourceFilters[SPAN_DOMAIN]}`]
- : []),
- ...(resourceFilters['resource.render_blocking_status']
- ? [
- `resource.render_blocking_status:${resourceFilters['resource.render_blocking_status']}`,
- ]
- : [`!resource.render_blocking_status:blocking`]),
- ];
- // TODO - we should be using metrics data here
- const eventView = EventView.fromNewQueryWithPageFilters(
- {
- fields: [
- SPAN_DESCRIPTION,
- SPAN_OP,
- 'count()',
- `avg(${SPAN_SELF_TIME})`,
- 'spm()',
- SPAN_GROUP,
- SPAN_DOMAIN,
- `avg(${HTTP_RESPONSE_CONTENT_LENGTH})`,
- ],
- name: 'Resource module - resource table',
- query: queryConditions.join(' '),
- orderby: '-count',
- version: 2,
- dataset: DiscoverDatasets.SPANS_METRICS,
- },
- pageFilters.selection
- );
- if (sort) {
- eventView.sorts = [sort];
- }
- const result = useDiscoverQuery({eventView, limit: 100, location, orgSlug});
- const data = result?.data?.data.map(row => ({
- [SPAN_OP]: row[SPAN_OP].toString() as `resource.${string}`,
- [SPAN_DESCRIPTION]: row[SPAN_DESCRIPTION].toString(),
- ['avg(span.self_time)']: row[`avg(${SPAN_SELF_TIME})`] as number,
- 'count()': row['count()'] as number,
- 'spm()': row['spm()'] as number,
- [SPAN_GROUP]: row[SPAN_GROUP].toString(),
- [RESOURCE_RENDER_BLOCKING_STATUS]: row[RESOURCE_RENDER_BLOCKING_STATUS] as
- | ''
- | 'non-blocking'
- | 'blocking',
- [SPAN_DOMAIN]: row[SPAN_DOMAIN][0]?.toString(),
- [`avg(http.response_content_length)`]: row[
- `avg(${HTTP_RESPONSE_CONTENT_LENGTH})`
- ] as number,
- }));
- return {...result, data: data || []};
- };
|