grafana/public/app/features/dimensions/text.ts
Ryan McKinley 09f03e92bf
FieldValues: Use simple array in panel visualizations (#66706)
Co-authored-by: Leon Sorokin <leeoniya@gmail.com>
2023-04-17 14:46:29 -07:00

66 lines
1.7 KiB
TypeScript

import { DataFrame, Field, FieldType, formattedValueToString } from '@grafana/data';
import { DimensionSupplier, TextDimensionConfig, TextDimensionMode } from './types';
import { findField, getLastNotNullFieldValue } from './utils';
//---------------------------------------------------------
// Resource dimension
//---------------------------------------------------------
export function getTextDimension(frame: DataFrame | undefined, config: TextDimensionConfig): DimensionSupplier<string> {
const field = config.field ? findField(frame, config.field) : frame?.fields.find((f) => f.type === FieldType.string);
return getTextDimensionForField(field, config);
}
export function getTextDimensionForField(
field: Field | undefined,
config: TextDimensionConfig
): DimensionSupplier<string> {
let v = config.fixed;
const mode = config.mode ?? TextDimensionMode.Fixed;
if (mode === TextDimensionMode.Fixed) {
return {
isAssumed: !Boolean(v),
fixed: v,
value: () => v,
get: (i) => v,
};
}
if (mode === TextDimensionMode.Template) {
const disp = (v: unknown) => {
return `TEMPLATE[${config.fixed} // ${v}]`;
};
if (!field) {
v = disp('');
return {
isAssumed: true,
fixed: v,
value: () => v,
get: (i) => v,
};
}
return {
field,
get: (i) => disp(field.values[i]),
value: () => disp(getLastNotNullFieldValue(field)),
};
}
if (!field) {
return {
isAssumed: true,
fixed: v,
value: () => v,
get: (i) => v,
};
}
let disp = (v: unknown) => formattedValueToString(field.display!(v));
return {
field,
get: (i) => disp(field.values[i]),
value: () => disp(getLastNotNullFieldValue(field)),
};
}