/
list_chart.go
82 lines (78 loc) · 2.21 KB
/
list_chart.go
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// Copyright (c) 2021 Terminus, Inc.
//
// This program is free software: you can use, redistribute, and/or modify
// it under the terms of the GNU Affero General Public License, version 3
// or later ("AGPL"), as published by the Free Software Foundation.
//
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package chartv2
import (
"fmt"
"strconv"
"strings"
tsql "github.com/erda-project/erda/modules/core/monitor/metric/query/es-tsql"
)
func (f *Formater) formatListChart(q tsql.Query, rs *tsql.ResultSet, params map[string]interface{}) (interface{}, error) {
list := make([]map[string]interface{}, 0)
var title map[string]bool
if val, ok := params["title"].(string); ok && len(val) > 0 {
title = make(map[string]bool)
for _, v := range strings.Split(val, ",") {
v = strings.TrimSpace(v)
if len(v) > 0 {
title[v] = true
}
}
}
if len(title) > 0 {
for _, row := range rs.Rows {
data := make(map[string]interface{}, 2)
var headers []string
var values []interface{}
for i, c := range rs.Columns {
if title[c.Name] {
if row[i] == nil {
headers = append(headers, "")
} else {
headers = append(headers, fmt.Sprint(row[i]))
}
} else {
values = append(values, row[i])
}
}
data["title"] = strings.Join(headers, ",")
if len(values) == 0 {
data["value"] = nil
} else if len(values) == 1 {
data["value"] = values[0]
} else {
data["value"] = values
}
list = append(list, data)
}
} else {
if len(rs.Columns) == 1 {
for i, row := range rs.Rows {
data := make(map[string]interface{}, 2)
data["title"] = strconv.Itoa(i + 1)
data["value"] = row[0]
list = append(list, data)
}
} else {
for i, row := range rs.Rows {
data := make(map[string]interface{}, 2)
data["title"] = strconv.Itoa(i + 1)
data["value"] = row
list = append(list, data)
}
}
}
return map[string]interface{}{
"metricData": list,
}, nil
}