-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathMetricLineList.jsx
68 lines (65 loc) · 2.3 KB
/
MetricLineList.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import { formatter } from "@/utils/format";
import { Line } from "@ant-design/plots";
import styles from "./index.scss";
import MetricLine from "./MetricLine";
import { formatMessage } from "umi/locale";
import { useState } from "react";
import request from "@/utils/request";
import MetricChart from "@/pages/Platform/Overview/components/MetricChart";
export default (props) => {
const { action, timeRange, timezone, timeout, overview, renderExtraMetric, metrics = [], queryParams } = props
return (
<div className={styles.metricChart}>
{metrics.map((metricKey) => {
return (
<MetricChart
key={metricKey}
timezone={timezone}
timeRange={timeRange}
fetchUrl={action}
metricKey={metricKey}
title={formatMessage({id: "cluster.metrics.axis." + metricKey + ".title"})}
queryParams={queryParams}
timeout={timeout}
className={styles.lineWrapper}
formatMetric={(metric) => {
if (!metric) return metric;
let units = "";
const newData = [];
(metric.lines || []).map((line) => {
let category = line.metric.label;
if (!units) {
if (line.metric.formatType.toLowerCase() == "bytes") {
units = line.metric.formatType;
} else {
units = line.metric.units;
}
}
return line.data.map((ld) => {
newData.push({
category: category,
x: formatter.dateUserDefined(parseInt(ld[0])),
y: ld[1],
});
});
});
return { ...metric, data: newData, units };
}}
customRenderChart={(metric) => {
if (!metric) return null
const config = {
data: metric.data,
xField: "x",
yField: "y",
seriesField: "category",
yUnits: metric.units,
};
return <MetricLine {...config} key={metric.key} />
}}
/>
)
})}
{renderExtraMetric ? renderExtraMetric() : null}
</div>
);
};