import {ReactNode} from 'react';
import {InjectedRouter} from 'react-router';
import styled from '@emotion/styled';
import Badge from 'sentry/components/badge';
import {Button} from 'sentry/components/button';
import ButtonBar from 'sentry/components/buttonBar';
import GlobalEventProcessingAlert from 'sentry/components/globalEventProcessingAlert';
import * as Layout from 'sentry/components/layouts/thirds';
import {PageHeadingQuestionTooltip} from 'sentry/components/pageHeadingQuestionTooltip';
import QueryCount from 'sentry/components/queryCount';
import {TabList, Tabs} from 'sentry/components/tabs';
import {Tooltip} from 'sentry/components/tooltip';
import {SLOW_TOOLTIP_DELAY} from 'sentry/constants';
import {IconPause, IconPlay} from 'sentry/icons';
import {t} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import {Organization} from 'sentry/types';
import {trackAnalyticsEvent} from 'sentry/utils/analytics';
import useProjects from 'sentry/utils/useProjects';
import {normalizeUrl} from 'sentry/utils/withDomainRequired';
import IssueListSetAsDefault from 'sentry/views/issueList/issueListSetAsDefault';
import {getTabs, IssueSortOptions, Query, QueryCounts, TAB_MAX_COUNT} from './utils';
type IssueListHeaderProps = {
displayReprocessingTab: boolean;
onRealtimeChange: (realtime: boolean) => void;
organization: Organization;
query: string;
queryCounts: QueryCounts;
realtimeActive: boolean;
router: InjectedRouter;
selectedProjectIds: number[];
sort: string;
queryCount?: number;
};
type IssueListHeaderTabProps = {
name: string;
query: string;
count?: number;
hasMore?: boolean;
tooltipHoverable?: boolean;
tooltipTitle?: ReactNode;
};
const EXTRA_TAB_KEY = 'extra-tab-key';
function IssueListHeaderTabContent({
count = 0,
hasMore = false,
name,
query,
tooltipHoverable,
tooltipTitle,
}: IssueListHeaderTabProps) {
return (
{name}{' '}
{count > 0 && (
0 ? 'review' : 'default'}>
)}
);
}
function IssueListHeader({
organization,
query,
sort,
queryCounts,
realtimeActive,
onRealtimeChange,
router,
displayReprocessingTab,
selectedProjectIds,
}: IssueListHeaderProps) {
const {projects} = useProjects();
const tabs = getTabs(organization);
const visibleTabs = displayReprocessingTab
? tabs
: tabs.filter(([tab]) => tab !== Query.REPROCESSING);
// Remove cursor and page when switching tabs
const {cursor: _, page: __, ...queryParms} = router?.location?.query ?? {};
const sortParam =
queryParms.sort === IssueSortOptions.INBOX ? undefined : queryParms.sort;
function trackTabClick(tabQuery: string) {
// Clicking on inbox tab and currently another tab is active
if (tabQuery === Query.FOR_REVIEW && query !== Query.FOR_REVIEW) {
trackAnalyticsEvent({
eventKey: 'inbox_tab.clicked',
eventName: 'Clicked Inbox Tab',
organization_id: organization.id,
});
}
}
const selectedProjects = projects.filter(({id}) =>
selectedProjectIds.includes(Number(id))
);
const realtimeTitle = realtimeActive
? t('Pause real-time updates')
: t('Enable real-time updates');
return (
{t('Issues')}
: }
onClick={() => onRealtimeChange(!realtimeActive)}
/>
trackTabClick(key === EXTRA_TAB_KEY ? query : key.toString())
}
selectedKey={query}
>
{[
...visibleTabs.map(
([tabQuery, {name: queryName, tooltipTitle, tooltipHoverable}]) => {
const to = normalizeUrl({
query: {
...queryParms,
query: tabQuery,
sort:
tabQuery === Query.FOR_REVIEW ? IssueSortOptions.INBOX : sortParam,
},
pathname: `/organizations/${organization.slug}/issues/`,
});
return (
);
}
),
]}
);
}
export default IssueListHeader;
const StyledGlobalEventProcessingAlert = styled(GlobalEventProcessingAlert)`
grid-column: 1/-1;
margin-top: ${space(1)};
margin-bottom: ${space(1)};
@media (min-width: ${p => p.theme.breakpoints.medium}) {
margin-top: ${space(2)};
margin-bottom: 0;
}
`;
const StyledTabs = styled(Tabs)`
grid-column: 1/-1;
`;