1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- import {useMemo} from 'react';
- import {TabList, Tabs} from 'sentry/components/tabs';
- import {t} from 'sentry/locale';
- import {useLocation} from 'sentry/utils/useLocation';
- import useOrganization from 'sentry/utils/useOrganization';
- import {normalizeUrl} from 'sentry/utils/withDomainRequired';
- import useAllMobileProj from 'sentry/views/replays/detail/useAllMobileProj';
- interface Props {
- selected: 'replays' | 'selectors';
- }
- export default function ReplayTabs({selected}: Props) {
- const organization = useOrganization();
- const location = useLocation();
- const {allMobileProj} = useAllMobileProj();
- const tabs = useMemo(
- () => [
- {
- key: 'replays',
- label: t('Replays'),
- pathname: normalizeUrl(`/organizations/${organization.slug}/replays/`),
- query: {...location.query, sort: undefined},
- },
- {
- key: 'selectors',
- label: t('Selectors'),
- pathname: normalizeUrl(`/organizations/${organization.slug}/replays/selectors/`),
- query: {...location.query, sort: '-count_dead_clicks'},
- },
- ],
- [organization.slug, location.query]
- );
- return (
- <Tabs value={selected}>
- <TabList hideBorder>
- {tabs.map(tab => (
- <TabList.Item
- key={tab.key}
- to={{
- ...location,
- pathname: tab.pathname,
- query: tab.query,
- }}
- disabled={tab.key === 'selectors' && allMobileProj}
- >
- {tab.label}
- </TabList.Item>
- ))}
- </TabList>
- </Tabs>
- );
- }
|