import styled from '@emotion/styled'; import {Tooltip} from 'sentry/components/tooltip'; import {IconFix, IconMute} from 'sentry/icons'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import type {ColorOrAlias} from 'sentry/utils/theme'; import { type Monitor, type MonitorEnvironment, MonitorStatus, type StatusNotice, } from 'sentry/views/monitors/types'; import {statusIconColorMap} from 'sentry/views/monitors/utils/constants'; interface Props { monitor: Monitor; monitorEnv: MonitorEnvironment; } const userNotifiedDisplay: StatusNotice = { label: t( 'This environment is likely broken due to being in an error state for multiple days.' ), icon: , color: 'subText', }; const envMutedDisplay: StatusNotice = { label: t( 'This environment is likely broken due to being in an error state for multiple days. It has been automatically muted.' ), icon: , color: 'subText', }; export default function MonitorEnvironmentLabel({monitorEnv, monitor}: Props) { const {name, status, isMuted, activeIncident} = monitorEnv; const {userNotifiedTimestamp, envMutedTimestamp} = activeIncident?.brokenNotice ?? {}; const envStatus = monitor.isMuted || isMuted ? MonitorStatus.DISABLED : status; const {label, icon, color} = userNotifiedTimestamp ? userNotifiedDisplay : envMutedTimestamp ? envMutedDisplay : statusIconColorMap[envStatus]; return ( {name} {icon} ); } const EnvWithStatus = styled('div')` display: grid; grid-template-columns: 1fr max-content; gap: ${space(0.5)}; align-items: center; opacity: var(--disabled-opacity); `; const MonitorEnvLabel = styled('div')<{color: ColorOrAlias}>` text-overflow: ellipsis; overflow: hidden; white-space: nowrap; min-width: 0; color: ${p => p.theme[p.color]}; opacity: var(--disabled-opacity); `;