import styled from '@emotion/styled'; import {Tooltip} from 'sentry/components/tooltip'; import { IconCheckmark, IconFire, IconFix, IconMute, IconTimer, IconUnsubscribed, } from 'sentry/icons'; import {t} from 'sentry/locale'; import {space} from 'sentry/styles/space'; import type {ColorOrAlias} from 'sentry/utils/theme'; import { type MonitorEnvironment, MonitorStatus, type StatusNotice, } from 'sentry/views/monitors/types'; interface Props { monitorEnv: MonitorEnvironment; } export const statusIconColorMap: Record = { ok: { icon: , color: 'successText', }, error: { icon: , color: 'errorText', }, active: { icon: , color: 'subText', label: t('Waiting For Check-In'), }, disabled: { icon: , color: 'subText', label: t('Muted'), }, }; 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}: Props) { const {name, status, isMuted, activeIncident} = monitorEnv; const {userNotifiedTimestamp, environmentMutedTimestamp} = activeIncident?.brokenNotice ?? {}; const envStatus = isMuted ? MonitorStatus.DISABLED : status; const {label, icon, color} = environmentMutedTimestamp ? envMutedDisplay : userNotifiedTimestamp ? userNotifiedDisplay : 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); `;