1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- import {useInpSpanSamplesWebVitalsQuery} from 'sentry/views/insights/browser/webVitals/queries/useInpSpanSamplesWebVitalsQuery';
- import type {InteractionSpanSampleRowWithScore} from 'sentry/views/insights/browser/webVitals/types';
- import type {BrowserType} from 'sentry/views/insights/browser/webVitals/utils/queryParameterDecoders/browserType';
- import {
- PERFORMANCE_SCORE_MEDIANS,
- PERFORMANCE_SCORE_P90S,
- } from 'sentry/views/insights/browser/webVitals/utils/scoreThresholds';
- type Props = {
- browserTypes: BrowserType[];
- enabled: boolean;
- transaction: string;
- };
- export function useInteractionsCategorizedSamplesQuery({
- transaction,
- enabled,
- browserTypes,
- }: Props) {
- const {data: goodData, isFetching: isGoodDataLoading} = useInpSpanSamplesWebVitalsQuery(
- {
- transaction,
- enabled,
- limit: 3,
- filters: {
- 'measurements.inp': `<${PERFORMANCE_SCORE_P90S.inp}`,
- },
- browserTypes,
- }
- );
- const {data: mehData, isFetching: isMehDataLoading} = useInpSpanSamplesWebVitalsQuery({
- transaction,
- enabled,
- limit: 3,
- filters: {
- 'measurements.inp': [
- `>=${PERFORMANCE_SCORE_P90S.inp}`,
- `<${PERFORMANCE_SCORE_MEDIANS.inp}`,
- ],
- },
- browserTypes,
- });
- const {data: poorData, isFetching: isBadDataLoading} = useInpSpanSamplesWebVitalsQuery({
- transaction,
- enabled,
- limit: 3,
- filters: {
- 'measurements.inp': `>=${PERFORMANCE_SCORE_MEDIANS.inp}`,
- },
- browserTypes,
- });
- const data = [...goodData, ...mehData, ...poorData];
- const isLoading = isGoodDataLoading || isMehDataLoading || isBadDataLoading;
- const interactionsTableData: InteractionSpanSampleRowWithScore[] = data.sort(
- (a, b) => a.inpScore - b.inpScore
- );
- return {
- data: interactionsTableData,
- isLoading,
- };
- }
|