import {CompactSelect} from 'sentry/components/compactSelect'; import {t} from 'sentry/locale'; import type {NewQuery, SavedQuery} from 'sentry/types'; import EventView from 'sentry/utils/discover/eventView'; import {SavedQueryDatasets} from 'sentry/utils/discover/types'; import {useLocation} from 'sentry/utils/useLocation'; import {useNavigate} from 'sentry/utils/useNavigate'; import useOrganization from 'sentry/utils/useOrganization'; import {DEFAULT_EVENT_VIEW_MAP} from 'sentry/views/discover/data'; import { getDatasetFromLocationOrSavedQueryDataset, getSavedQueryDataset, getSavedQueryWithDataset, } from 'sentry/views/discover/savedQuery/utils'; export const DATASET_PARAM = 'queryDataset'; export const DATASET_LABEL_MAP = { [SavedQueryDatasets.ERRORS]: t('Errors'), [SavedQueryDatasets.TRANSACTIONS]: t('Transactions'), [SavedQueryDatasets.DISCOVER]: t('Unknown'), }; type Props = { eventView: EventView; isHomepage: boolean | undefined; savedQuery: SavedQuery | undefined; splitDecision?: SavedQueryDatasets; }; export function DatasetSelector(props: Props) { const {savedQuery, isHomepage, splitDecision, eventView} = props; const location = useLocation(); const organization = useOrganization(); const navigate = useNavigate(); const value = getSavedQueryDataset(organization, location, savedQuery, splitDecision); const options = [ { value: SavedQueryDatasets.ERRORS, label: DATASET_LABEL_MAP[SavedQueryDatasets.ERRORS], }, { value: SavedQueryDatasets.TRANSACTIONS, label: DATASET_LABEL_MAP[SavedQueryDatasets.TRANSACTIONS], }, ]; if (value === 'discover') { options.push({ value: SavedQueryDatasets.DISCOVER, label: DATASET_LABEL_MAP[SavedQueryDatasets.DISCOVER], }); } return ( { let nextEventView: EventView; if (eventView.id) { nextEventView = eventView.withDataset( getDatasetFromLocationOrSavedQueryDataset(undefined, newValue.value) ); } else { const query = getSavedQueryWithDataset( DEFAULT_EVENT_VIEW_MAP[newValue.value] ) as NewQuery; nextEventView = EventView.fromNewQueryWithLocation(query, location); } const nextLocation = nextEventView.getResultsViewUrlTarget( organization.slug, isHomepage ); navigate({ ...location, query: { ...nextLocation.query, [DATASET_PARAM]: newValue.value, }, }); }} /> ); }