import {browserHistory} from 'react-router'; import {deleteMonitor, updateMonitor} from 'sentry/actionCreators/monitors'; import {Button} from 'sentry/components/button'; import ButtonBar from 'sentry/components/buttonBar'; import Confirm from 'sentry/components/confirm'; import FeedbackWidgetButton from 'sentry/components/feedback/widget/feedbackWidgetButton'; import {IconDelete, IconEdit, IconSubscribed, IconUnsubscribed} from 'sentry/icons'; import {t} from 'sentry/locale'; import useApi from 'sentry/utils/useApi'; import usePageFilters from 'sentry/utils/usePageFilters'; import {normalizeUrl} from 'sentry/utils/withDomainRequired'; import {Monitor, MonitorObjectStatus} from '../types'; type Props = { monitor: Monitor; onUpdate: (data: Monitor) => void; orgId: string; }; function MonitorHeaderActions({monitor, orgId, onUpdate}: Props) { const api = useApi(); const {selection} = usePageFilters(); const endpointOptions = { query: { project: selection.projects, environment: selection.environments, }, }; const handleDelete = async () => { await deleteMonitor(api, orgId, monitor.slug); browserHistory.push( normalizeUrl({ pathname: `/organizations/${orgId}/crons/`, query: endpointOptions.query, }) ); }; const handleUpdate = async (data: Partial) => { const resp = await updateMonitor(api, orgId, monitor.slug, data); onUpdate?.(resp); }; const toggleStatus = () => handleUpdate({ status: monitor.status === MonitorObjectStatus.MUTED ? MonitorObjectStatus.ACTIVE : MonitorObjectStatus.MUTED, }); return ( ); } export default MonitorHeaderActions;