import {t} from 'sentry/locale'; import {trackAnalytics} from 'sentry/utils/analytics'; import {browserHistory} from 'sentry/utils/browserHistory'; import {useLocation} from 'sentry/utils/useLocation'; import useOrganization from 'sentry/utils/useOrganization'; import type {Option} from 'sentry/views/insights/browser/resources/components/selectControlWithProps'; import SelectControlWithProps from 'sentry/views/insights/browser/resources/components/selectControlWithProps'; import {QueryParameterNames} from 'sentry/views/insights/common/views/queryParameters'; import {SpanMetricsField} from 'sentry/views/insights/types'; const {RESOURCE_RENDER_BLOCKING_STATUS} = SpanMetricsField; function RenderBlockingSelector({value}: {value?: string}) { const location = useLocation(); const organization = useOrganization(); const options: Option[] = [ {value: '', label: 'All'}, {value: 'non-blocking', label: t('No')}, {value: 'blocking', label: t('Yes')}, ]; return ( { trackAnalytics('insight.asset.filter_by_blocking', { organization, filter: newValue?.value, }); browserHistory.push({ ...location, query: { ...location.query, [RESOURCE_RENDER_BLOCKING_STATUS]: newValue?.value, [QueryParameterNames.SPANS_CURSOR]: undefined, }, }); }} /> ); } export default RenderBlockingSelector;