import {Fragment} from 'react';
import styled from '@emotion/styled';
import {deleteMonitor} from 'sentry/actionCreators/monitors';
import {openConfirmModal} from 'sentry/components/confirm';
import {DropdownMenu, MenuItemProps} from 'sentry/components/dropdownMenu';
import IdBadge from 'sentry/components/idBadge';
import Link from 'sentry/components/links/link';
import TextOverflow from 'sentry/components/textOverflow';
import TimeSince from 'sentry/components/timeSince';
import {IconEllipsis} from 'sentry/icons';
import {t, tct, tn} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import {Organization} from 'sentry/types';
import useApi from 'sentry/utils/useApi';
import {normalizeUrl} from 'sentry/utils/withDomainRequired';
import {crontabAsText} from 'sentry/views/monitors/utils';
import {MonitorBadge} from './components/monitorBadge';
import {Monitor, MonitorConfig, MonitorStatus, ScheduleType} from './types';
interface MonitorRowProps {
monitor: Monitor;
onDelete: () => void;
organization: Organization;
}
function scheduleAsText(config: MonitorConfig) {
// Crontab format uses cronstrue
if (config.schedule_type === ScheduleType.CRONTAB) {
const parsedSchedule = crontabAsText(config.schedule);
return parsedSchedule ?? t('Unknown schedule');
}
// Interval format is simpler
const [value, timeUnit] = config.schedule;
if (timeUnit === 'minute') {
return tn('Every minute', 'Every %s minutes', value);
}
if (timeUnit === 'hour') {
return tn('Every hour', 'Every %s hours', value);
}
if (timeUnit === 'day') {
return tn('Every day', 'Every %s days', value);
}
if (timeUnit === 'week') {
return tn('Every week', 'Every %s weeks', value);
}
if (timeUnit === 'month') {
return tn('Every month', 'Every %s months', value);
}
return t('Unknown schedule');
}
function MonitorRow({monitor, organization, onDelete}: MonitorRowProps) {
const api = useApi();
const lastCheckin = ;
const actions: MenuItemProps[] = [
{
key: 'edit',
label: t('Edit'),
to: normalizeUrl(`/organizations/${organization.slug}/crons/${monitor.slug}/edit/`),
},
{
key: 'delete',
label: t('Delete'),
priority: 'danger',
onAction: () => {
openConfirmModal({
onConfirm: async () => {
await deleteMonitor(api, organization.slug, monitor.slug);
onDelete();
},
header: t('Delete Monitor?'),
message: tct('Are you sure you want to permanently delete [name]?', {
name: monitor.name,
}),
confirmText: t('Delete Monitor'),
priority: 'danger',
});
},
},
];
return (
{monitor.name}
{monitor.status === MonitorStatus.DISABLED
? t('Paused')
: monitor.status === MonitorStatus.ACTIVE
? t('Waiting for first check-in')
: monitor.status === MonitorStatus.OK
? tct('Check-in [lastCheckin]', {lastCheckin})
: monitor.status === MonitorStatus.MISSED_CHECKIN
? tct('Missed [lastCheckin]', {lastCheckin})
: monitor.status === MonitorStatus.ERROR
? tct('Failed [lastCheckin]', {lastCheckin})
: null}
{scheduleAsText(monitor.config)}
{monitor.nextCheckIn &&
monitor.status !== MonitorStatus.DISABLED &&
monitor.status !== MonitorStatus.ACTIVE ? (
) : (
'\u2014'
)}
,
showChevron: false,
}}
/>
);
}
export {MonitorRow};
const MonitorName = styled('div')`
display: flex;
align-items: center;
gap: ${space(2)};
font-size: ${p => p.theme.fontSizeLarge};
`;
const StatusColumn = styled('div')`
display: flex;
align-items: center;
`;
const ScheduleColumn = styled('div')`
display: flex;
align-items: center;
`;
const NextCheckin = styled('div')`
display: flex;
align-items: center;
`;
const ProjectColumn = styled('div')`
display: flex;
align-items: center;
`;
const ActionsColumn = styled('div')`
display: flex;
align-items: center;
justify-content: center;
`;