import {browserHistory} from 'react-router'; import { addErrorMessage, addLoadingMessage, clearIndicators, } from 'sentry/actionCreators/indicator'; import {Button} from 'sentry/components/button'; import ButtonBar from 'sentry/components/buttonBar'; import Confirm from 'sentry/components/confirm'; import {IconDelete, IconEdit} from 'sentry/icons'; import {t} from 'sentry/locale'; import {logException} from 'sentry/utils/logging'; import useApi from 'sentry/utils/useApi'; import {normalizeUrl} from 'sentry/utils/withDomainRequired'; import CronsFeedbackButton from './cronsFeedbackButton'; import {Monitor} from './types'; type Props = { monitor: Monitor; onUpdate: (data: Monitor) => void; orgId: string; }; const MonitorHeaderActions = ({monitor, orgId, onUpdate}: Props) => { const api = useApi(); const handleDelete = () => { const redirectPath = `/organizations/${orgId}/crons/`; addLoadingMessage(t('Deleting Monitor...')); api .requestPromise(`/organizations/${orgId}/monitors/${monitor.id}/`, { method: 'DELETE', }) .then(() => { browserHistory.push(normalizeUrl(redirectPath)); }) .catch(() => { addErrorMessage(t('Unable to remove monitor.')); }); }; const updateMonitor = (data: Partial) => { addLoadingMessage(); api .requestPromise(`/organizations/${orgId}/monitors/${monitor.id}/`, { method: 'PUT', data, }) .then(resp => { clearIndicators(); onUpdate?.(resp); }) .catch(err => { logException(err); addErrorMessage(t('Unable to update monitor.')); }); }; const toggleStatus = () => updateMonitor({ status: monitor.status === 'disabled' ? 'active' : 'disabled', }); return ( ); }; export default MonitorHeaderActions;