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, }; }