Skip to content

Commit

Permalink
Merge pull request grafana#213 from grafana/fix-table-add-targets
Browse files Browse the repository at this point in the history
Fix tablePanel.addTargets
  • Loading branch information
trotttrotttrott authored May 20, 2020
2 parents 3cbf732 + ef70649 commit ed376d6
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 44 deletions.
49 changes: 6 additions & 43 deletions grafonnet/table_panel.libsonnet
Original file line number Diff line number Diff line change
Expand Up @@ -49,50 +49,13 @@
[if description != null then 'description']: description,
[if transform != null then 'transform']: transform,
[if transparent == true then 'transparent']: transparent,

_nextTarget:: 0,
addTarget(target):: self + self.addTargets([target]),
addTargets(newtargets)::
self {
local n = std.foldl(function(numOfTargets, p)
(if 'targets' in p then
numOfTargets + 1 + std.length(p.targets)
else
numOfTargets + 1), newtargets, 0),
local nextTarget = super._nextTarget,
local _targets = std.makeArray(
std.length(newtargets), function(i)
newtargets[i] {
refId: std.char(std.codepoint('A') + nextTarget + (
if i == 0 then
0
else
if 'targets' in _targets[i - 1] then
(std.codepoint(_targets[i - 1].refId) - nextTarget) + 1 + std.length(_targets[i - 1].targets)
else
(std.codepoint(_targets[i - 1].refId) - nextTarget) + 1
)),
[if 'targets' in newtargets[i] then 'targets']: std.makeArray(
std.length(newtargets[i].targets), function(j)
newtargets[i].targets[j] {
refId: std.char(std.codepoint('A') + 1 + j +
nextTarget + (
if i == 0 then
0
else
if 'targets' in _targets[i - 1] then
(std.codepoint(_targets[i - 1].refId) - nextTarget) + 1 + std.length(_targets[i - 1].targets)
else
(std.codepoint(_targets[i - 1].refId) - nextTarget) + 1
)),
}
),
}
),

_nextTarget: nextTarget + n,
targets+::: _targets,
},
addTarget(target):: self {
local nextTarget = super._nextTarget,
_nextTarget: nextTarget + 1,
targets+: [target { refId: std.char(std.codepoint('A') + nextTarget) }],
},
addTargets(targets):: std.foldl(function(p, t) p.addTarget(t), targets, self),
addColumn(field, style):: self {
local style_ = style { pattern: field },
local column_ = { text: field, value: field },
Expand Down
2 changes: 1 addition & 1 deletion tests/table_panel/test_compiled.json
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@
},
{
"b": "foo",
"refId": "\u0083"
"refId": "B"
}
],
"timeFrom": null,
Expand Down

0 comments on commit ed376d6

Please sign in to comment.