import {Fragment} from 'react'; import styled from '@emotion/styled'; import ToolbarHeader from 'sentry/components/toolbarHeader'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import type {PageFilters} from 'sentry/types'; import useOrganization from 'sentry/utils/useOrganization'; type Props = { isReprocessingQuery: boolean; onSelectStatsPeriod: (statsPeriod: string) => void; selection: PageFilters; statsPeriod: string; isSavedSearchesOpen?: boolean; }; function Headers({ selection, statsPeriod, onSelectStatsPeriod, isReprocessingQuery, isSavedSearchesOpen, }: Props) { const organization = useOrganization(); return ( {isReprocessingQuery ? ( {t('Started')} {t('Events Reprocessed')} {t('Progress')} ) : ( {t('Graph:')} {selection.datetime.period !== '24h' && ( onSelectStatsPeriod('24h')} > {t('24h')} )} onSelectStatsPeriod('auto')} > {selection.datetime.period || t('Custom')} {t('Events')} {t('Users')} {organization.features.includes('issue-priority-ui') && ( {t('Priority')} )} {t('Assignee')} )} ); } export default Headers; const GraphHeaderWrapper = styled('div')<{isSavedSearchesOpen?: boolean}>` width: 160px; margin-left: ${space(2)}; margin-right: ${space(2)}; animation: 0.25s FadeIn linear forwards; /* prettier-ignore */ @media (max-width: ${p => p.isSavedSearchesOpen ? p.theme.breakpoints.xlarge : p.theme.breakpoints.large}) { display: none; } @keyframes FadeIn { 0% { opacity: 0; } 100% { opacity: 1; } } `; const GraphHeader = styled('div')` display: flex; `; const StyledToolbarHeader = styled(ToolbarHeader)` flex: 1; `; const GraphToggle = styled('a')<{active: boolean}>` font-size: 13px; padding-left: ${space(1)}; &, &:hover, &:focus, &:active { color: ${p => (p.active ? p.theme.textColor : p.theme.disabled)}; } `; const EventsOrUsersLabel = styled(ToolbarHeader)` display: inline-grid; align-items: center; justify-content: flex-end; text-align: right; width: 60px; margin: 0 ${space(2)}; @media (min-width: ${p => p.theme.breakpoints.xlarge}) { width: 80px; } `; const PriorityLabel = styled('div')<{isSavedSearchesOpen?: boolean}>` justify-content: flex-end; text-align: right; width: 70px; margin: 0 ${space(2)}; /* prettier-ignore */ @media (max-width: ${p => p.isSavedSearchesOpen ? p.theme.breakpoints.large : p.theme.breakpoints.medium}) { display: none; } `; const AssigneeLabel = styled('div')<{isSavedSearchesOpen?: boolean}>` justify-content: flex-end; text-align: right; width: 60px; margin-left: ${space(2)}; margin-right: ${space(2)}; /* prettier-ignore */ @media (max-width: ${p => p.isSavedSearchesOpen ? p.theme.breakpoints.large : p.theme.breakpoints.medium}) { display: none; } `; // Reprocessing const StartedColumn = styled(ToolbarHeader)` margin: 0 ${space(2)}; ${p => p.theme.overflowEllipsis}; width: 85px; @media (min-width: ${p => p.theme.breakpoints.small}) { width: 140px; } `; const EventsReprocessedColumn = styled(ToolbarHeader)` margin: 0 ${space(2)}; ${p => p.theme.overflowEllipsis}; width: 75px; @media (min-width: ${p => p.theme.breakpoints.small}) { width: 140px; } `; const ProgressColumn = styled(ToolbarHeader)` margin: 0 ${space(2)}; display: none; @media (min-width: ${p => p.theme.breakpoints.small}) { display: block; width: 160px; } `;