grafana/public/app/features/alerting/unified/components/rules/RuleHealth.tsx

39 lines
905 B
TypeScript

import { css } from '@emotion/css';
import React from 'react';
import { GrafanaTheme2 } from '@grafana/data';
import { Icon, Tooltip, useStyles2 } from '@grafana/ui';
import { Rule } from 'app/types/unified-alerting';
interface Prom {
rule: Rule;
}
export const RuleHealth = ({ rule }: Prom) => {
const style = useStyles2(getStyle);
if (rule.health === 'err' || rule.health === 'error') {
return (
<Tooltip theme="error" content={rule.lastError || 'No error message provided.'}>
<div className={style.warn}>
<Icon name="exclamation-triangle" />
<span>error</span>
</div>
</Tooltip>
);
}
return <>{rule.health}</>;
};
const getStyle = (theme: GrafanaTheme2) => ({
warn: css`
display: inline-flex;
flex-direction: row;
align-items: center;
gap: ${theme.spacing(1)};
color: ${theme.colors.warning.text};
`,
});