mirror of https://github.com/prometheus/prometheus
React UI: Add duration, labels, annotations to alerts page (#7605)
* React UI: Add duration, labels, annotation to alerts page Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu> * lint Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu> * make expression shorter Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu> * Check for null Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu> * Use object.keys Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu>pull/7631/head
parent
a3ac9fa5f5
commit
fe8d412ce9
|
@ -5,7 +5,7 @@ import { RuleStatus } from './AlertContents';
|
||||||
import { Rule } from '../../types/types';
|
import { Rule } from '../../types/types';
|
||||||
import { faChevronDown, faChevronRight } from '@fortawesome/free-solid-svg-icons';
|
import { faChevronDown, faChevronRight } from '@fortawesome/free-solid-svg-icons';
|
||||||
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
||||||
import { createExpressionLink, parsePrometheusFloat } from '../../utils/index';
|
import { createExpressionLink, parsePrometheusFloat, formatRange } from '../../utils/index';
|
||||||
|
|
||||||
interface CollapsibleAlertPanelProps {
|
interface CollapsibleAlertPanelProps {
|
||||||
rule: Rule;
|
rule: Rule;
|
||||||
|
@ -36,14 +36,31 @@ const CollapsibleAlertPanel: FC<CollapsibleAlertPanelProps> = ({ rule, showAnnot
|
||||||
<div>
|
<div>
|
||||||
expr: <Link to={createExpressionLink(rule.query)}>{rule.query}</Link>
|
expr: <Link to={createExpressionLink(rule.query)}>{rule.query}</Link>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
{rule.duration > 0 && (
|
||||||
<div>labels:</div>
|
<div>
|
||||||
<div className="ml-5">severity: {rule.labels.severity}</div>
|
<div>for: {formatRange(rule.duration)}</div>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
)}
|
||||||
<div>annotations:</div>
|
{rule.labels && Object.keys(rule.labels).length > 0 && (
|
||||||
<div className="ml-5">summary: {rule.annotations.summary}</div>
|
<div>
|
||||||
</div>
|
<div>labels:</div>
|
||||||
|
{Object.entries(rule.labels).map(([key, value]) => (
|
||||||
|
<div className="ml-4" key={key}>
|
||||||
|
{key}: {value}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
{rule.annotations && Object.keys(rule.annotations).length > 0 && (
|
||||||
|
<div>
|
||||||
|
<div>annotations:</div>
|
||||||
|
{Object.entries(rule.annotations).map(([key, value]) => (
|
||||||
|
<div className="ml-4" key={key}>
|
||||||
|
{key}: {value}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</code>
|
</code>
|
||||||
</pre>
|
</pre>
|
||||||
{rule.alerts.length > 0 && (
|
{rule.alerts.length > 0 && (
|
||||||
|
|
Loading…
Reference in New Issue