import type {ReactNode} from 'react';
import styled from '@emotion/styled';
import GuideAnchor from 'sentry/components/assistant/guideAnchor';
import Badge from 'sentry/components/badge/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 type {InjectedRouter} from 'sentry/types/legacyReactRouter';
import type {Organization} from 'sentry/types/organization';
import normalizeUrl from 'sentry/utils/url/normalizeUrl';
import useProjects from 'sentry/utils/useProjects';
import IssueListSetAsDefault from 'sentry/views/issueList/issueListSetAsDefault';
import type {QueryCounts} from './utils';
import {
CUSTOM_TAB_VALUE,
FOR_REVIEW_QUERIES,
getTabs,
IssueSortOptions,
Query,
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;
count?: number;
hasMore?: boolean;
tooltipHoverable?: boolean;
tooltipTitle?: ReactNode;
};
function IssueListHeaderTabContent({
count = 0,
hasMore = false,
name,
tooltipHoverable,
tooltipTitle,
}: IssueListHeaderTabProps) {
return (
{name}{' '}
{count > 0 && (
)}
);
}
function IssueListHeader({
organization,
query,
sort,
queryCounts,
realtimeActive,
onRealtimeChange,
router,
displayReprocessingTab,
selectedProjectIds,
}: IssueListHeaderProps) {
const {projects} = useProjects();
const tabs = getTabs();
const visibleTabs = displayReprocessingTab
? tabs
: tabs.filter(([tab]) => tab !== Query.REPROCESSING);
const tabValues = new Set(visibleTabs.map(([val]) => val));
// Remove cursor and page when switching tabs
const {cursor: _cursor, page: _page, ...queryParms} = router?.location?.query ?? {};
const sortParam =
queryParms.sort === IssueSortOptions.INBOX ? undefined : queryParms.sort;
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)}
/>
{visibleTabs.map(
([tabQuery, {name: queryName, tooltipTitle, tooltipHoverable, hidden}]) => {
const to = normalizeUrl({
query: {
...queryParms,
query: tabQuery,
sort: FOR_REVIEW_QUERIES.includes(tabQuery || '')
? 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;
`;