import { css } from '@emotion/css'; import { GrafanaTheme2, dateMath, intervalToAbbreviatedDurationString } from '@grafana/data'; import { useStyles2 } from '@grafana/ui'; import SilencedAlertsTable from './SilencedAlertsTable'; import { SilenceTableItem } from './SilencesTable'; interface Props { silence: SilenceTableItem; } export const SilenceDetails = ({ silence }: Props) => { const { startsAt, endsAt, comment, createdBy, silencedAlerts } = silence; const styles = useStyles2(getStyles); const dateDisplayFormat = 'YYYY-MM-DD HH:mm'; const startsAtDate = dateMath.parse(startsAt); const endsAtDate = dateMath.parse(endsAt); const duration = intervalToAbbreviatedDurationString({ start: new Date(startsAt), end: new Date(endsAt) }); return (
Comment
{comment}
Schedule
{`${startsAtDate?.format(dateDisplayFormat)} - ${endsAtDate?.format(dateDisplayFormat)}`}
Duration
{duration}
Created by
{createdBy}
{Array.isArray(silencedAlerts) && ( <>
Affected alerts
)}
); }; const getStyles = (theme: GrafanaTheme2) => ({ container: css({ display: 'grid', gridTemplateColumns: '1fr 9fr', gridRowGap: '1rem', paddingBottom: theme.spacing(2), }), title: css({ color: theme.colors.text.primary, }), row: css({ margin: theme.spacing(1, 0), }), });