import {Fragment, useState} from 'react'; import type {RouteComponentProps} from 'react-router'; import * as Layout from 'sentry/components/layouts/thirds'; import LoadingIndicator from 'sentry/components/loadingIndicator'; import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle'; import {t} from 'sentry/locale'; import type {Member, Organization} from 'sentry/types/organization'; import type {Project} from 'sentry/types/project'; import useRouteAnalyticsEventNames from 'sentry/utils/routeAnalytics/useRouteAnalyticsEventNames'; import useRouteAnalyticsParams from 'sentry/utils/routeAnalytics/useRouteAnalyticsParams'; import {useLocation} from 'sentry/utils/useLocation'; import {useUserTeams} from 'sentry/utils/useUserTeams'; import BuilderBreadCrumbs from 'sentry/views/alerts/builder/builderBreadCrumbs'; import IssueEditor from './rules/issue'; import {MetricRulesEdit} from './rules/metric/edit'; import {UptimeRulesEdit} from './rules/uptime/edit'; import {CombinedAlertType} from './types'; type RouteParams = { projectId: string; ruleId: string; }; type Props = RouteComponentProps & { hasMetricAlerts: boolean; hasUptimeAlerts: boolean; members: Member[] | undefined; organization: Organization; project: Project; }; function ProjectAlertsEditor(props: Props) { const {hasMetricAlerts, hasUptimeAlerts, members, organization, project} = props; const location = useLocation(); const [title, setTitle] = useState(''); const alertTypeUrls = [ {url: '/alerts/metric-rules/', type: CombinedAlertType.METRIC}, {url: '/alerts/uptime-rules/', type: CombinedAlertType.UPTIME}, {url: '/alerts/rules/', type: CombinedAlertType.ISSUE}, ] as const; const alertType = alertTypeUrls.find(({url}) => location.pathname.includes(url))?.type ?? CombinedAlertType.ISSUE; useRouteAnalyticsEventNames('edit_alert_rule.viewed', 'Edit Alert Rule: Viewed'); useRouteAnalyticsParams({ organization, project_id: project.id, alert_type: alertType, }); // Used to hide specific fields like actions while migrating metric alert rules. // Currently used to help people add `is:unresolved` to their metric alert query. const isMigration = location?.query?.migration === '1'; const {teams, isLoading: teamsLoading} = useUserTeams(); return ( {title} {!teamsLoading ? ( {(!hasMetricAlerts || alertType === CombinedAlertType.ISSUE) && ( id)} members={members} /> )} {hasMetricAlerts && alertType === CombinedAlertType.METRIC && ( id)} /> )} {hasUptimeAlerts && alertType === CombinedAlertType.UPTIME && ( id)} /> )} ) : ( )} ); } export default ProjectAlertsEditor;