Skip to content

Commit

Permalink
Fix displaying metric names and alias functions, closes #1444
Browse files Browse the repository at this point in the history
  • Loading branch information
alexanderzobnin committed May 6, 2022
1 parent 6d8689c commit 84419de
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 9 deletions.
9 changes: 5 additions & 4 deletions pkg/datasource/response_handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -103,8 +103,8 @@ func convertTimeSeriesToDataFrames(series []*timeseries.TimeSeriesData, valuemap
}

func seriesToDataFrame(series *timeseries.TimeSeriesData, valuemaps []zabbix.ValueMap) *data.Frame {
timeFileld := data.NewFieldFromFieldType(data.FieldTypeTime, 0)
timeFileld.Name = data.TimeSeriesTimeFieldName
timeField := data.NewFieldFromFieldType(data.FieldTypeTime, 0)
timeField.Name = data.TimeSeriesTimeFieldName

seriesName := series.Meta.Name
valueField := data.NewFieldFromFieldType(data.FieldTypeNullableFloat64, 0)
Expand Down Expand Up @@ -136,6 +136,7 @@ func seriesToDataFrame(series *timeseries.TimeSeriesData, valuemaps []zabbix.Val
}

valueField.Config = &data.FieldConfig{
DisplayNameFromDS: seriesName,
Custom: map[string]interface{}{
"scopedVars": scopedVars,
"units": item.Units,
Expand All @@ -147,10 +148,10 @@ func seriesToDataFrame(series *timeseries.TimeSeriesData, valuemaps []zabbix.Val
valueField.Config.Mappings = mappings
}

frame := data.NewFrame(seriesName, timeFileld, valueField)
frame := data.NewFrame(seriesName, timeField, valueField)

for _, point := range series.TS {
timeFileld.Append(point.Time)
timeField.Append(point.Time)
valueField.Append(point.Value)
}

Expand Down
20 changes: 15 additions & 5 deletions src/datasource-zabbix/dataProcessor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ function setAlias(alias: string, frame: DataFrame) {
if (valueField?.config?.custom?.scopedVars) {
alias = getTemplateSrv().replace(alias, valueField?.config?.custom?.scopedVars);
}
if (valueField) {
valueField.config.displayNameFromDS = alias;
}
frame.name = alias;
return frame;
}
Expand All @@ -19,7 +22,7 @@ function setAlias(alias: string, frame: DataFrame) {
if (field?.config?.custom?.scopedVars) {
alias = getTemplateSrv().replace(alias, field?.config?.custom?.scopedVars);
}
field.name = alias;
field.config.displayNameFromDS = alias;
}
}
return frame;
Expand All @@ -39,25 +42,32 @@ function replaceAlias(regexp: string, newAlias: string, frame: DataFrame) {
if (valueField?.state?.scopedVars) {
alias = getTemplateSrv().replace(alias, valueField?.state?.scopedVars);
}
if (valueField) {
valueField.config.displayNameFromDS = alias;
}
frame.name = alias;
return frame;
}

for (const field of frame.fields) {
if (field.type !== FieldType.time) {
let alias = field.name.replace(pattern, newAlias);
if (field?.state?.scopedVars) {
let alias = field.config?.displayNameFromDS?.replace(pattern, newAlias);
if (field?.state?.scopedVars && alias) {
alias = getTemplateSrv().replace(alias, field?.state?.scopedVars);
}
field.name = alias;
field.name = alias || field.name;
}
}
return frame;
}

function setAliasByRegex(alias: string, frame: DataFrame) {
if (frame.fields?.length <= 2) {
const valueField = frame.fields.find(f => f.name === TIME_SERIES_VALUE_FIELD_NAME);
try {
if (valueField) {
valueField.config.displayNameFromDS = extractText(valueField.config?.displayNameFromDS, alias);
}
frame.name = extractText(frame.name, alias);
} catch (error) {
console.error('Failed to apply RegExp:', error?.message || error);
Expand All @@ -68,7 +78,7 @@ function setAliasByRegex(alias: string, frame: DataFrame) {
for (const field of frame.fields) {
if (field.type !== FieldType.time) {
try {
field.name = extractText(field.name, alias);
field.config.displayNameFromDS = extractText(field.config?.displayNameFromDS, alias);
} catch (error) {
console.error('Failed to apply RegExp:', error?.message || error);
}
Expand Down

0 comments on commit 84419de

Please sign in to comment.