mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
* POC: trying to see if there is a way to support objects in template interpolations * Added support for nested objects, and arrays * Added accessor cache * fixed unit tests * First take * Use links supplier in graph * Add field's index to cache items * Get field index from field cache * CHange FiledCacheItem to FieldWithIndex * Add refId to TimeSeries class * Make field link supplier work with _series, _field and _value vars * use field link supplier in graph * Fix yaxis settings * Update dashboard schema version and add migration for data links variables * Update snapshots * Update build in data link variables * FieldCache - idx -> index * Add current query results to panel editor * WIP Updated data links dropdown to display new variables * Fix build * Update variables syntac in field display, update migration * Field links supplier: review updates * Add data frame view and field name to TimeSeries for later inspection * Retrieve data frame from TimeSeries when clicking on plot graph * Use data frame's index instead of view * Retrieve data frame by index instead of view on TimeSeries * Update data links prism regex * Fix typecheck * Add value variables to suggestions list * UI update * Rename field to config in DisplayProcessorOptions * Proces single value of a field instead of entire data frame * Updated font size from 10px to 12px for auto complete * Replace fieldName with fieldIndex in TimeSeries * Don't use .entries() for iterating in field cache * Don't use FieldCache when retrieving field for datalinks in graph * Add value calculation variable to data links (#19031) * Add support for labels with dots in the name (#19033) * Docs update * Use field name instead of removed series.fieldName * Add test dashboard * Typos fix * Make visualization tab subscribe to query results * Added tags to dashboard so it shows up in lists * minor docs fix * Update singlestat-ish variables suggestions to contain series variables * Decrease suggestions update debounce * Enable whitespace characters(new line, space) in links and strip them when processing the data link * minor data links UI update * DataLinks: Add __from and __to variables suggestions to data links (#19093) * Add from and to variables suggestions to data links * Update docs * UI update and added info text * Change ESC global bind to bind (doesn't capture ESC on input) * Close datalinks suggestions on ESC * Remove unnecessary fragment
115 lines
2.8 KiB
TypeScript
115 lines
2.8 KiB
TypeScript
import { PanelModel } from 'app/features/dashboard/state/PanelModel';
|
|
import { FieldDisplay } from '@grafana/ui';
|
|
import { LinkModelSupplier, getTimeField, Labels, ScopedVars, ScopedVar } from '@grafana/data';
|
|
import { getLinkSrv } from './link_srv';
|
|
|
|
interface SeriesVars {
|
|
name?: string;
|
|
labels?: Labels;
|
|
refId?: string;
|
|
}
|
|
|
|
interface FieldVars {
|
|
name: string;
|
|
}
|
|
|
|
interface ValueVars {
|
|
raw: any;
|
|
numeric: number;
|
|
text: string;
|
|
time?: number;
|
|
calc?: string;
|
|
}
|
|
|
|
interface DataLinkScopedVars extends ScopedVars {
|
|
__series?: ScopedVar<SeriesVars>;
|
|
__field?: ScopedVar<FieldVars>;
|
|
__value?: ScopedVar<ValueVars>;
|
|
}
|
|
|
|
/**
|
|
* Link suppliers creates link models based on a link origin
|
|
*/
|
|
|
|
export const getFieldLinksSupplier = (value: FieldDisplay): LinkModelSupplier<FieldDisplay> | undefined => {
|
|
const links = value.field.links;
|
|
if (!links || links.length === 0) {
|
|
return undefined;
|
|
}
|
|
return {
|
|
getLinks: (_scopedVars?: any) => {
|
|
const scopedVars: DataLinkScopedVars = {};
|
|
|
|
if (value.view) {
|
|
const { dataFrame } = value.view;
|
|
|
|
scopedVars['__series'] = {
|
|
value: {
|
|
name: dataFrame.name,
|
|
labels: dataFrame.labels,
|
|
refId: dataFrame.refId,
|
|
},
|
|
text: 'Series',
|
|
};
|
|
|
|
const field = value.colIndex !== undefined ? dataFrame.fields[value.colIndex] : undefined;
|
|
if (field) {
|
|
console.log('Full Field Info:', field);
|
|
scopedVars['__field'] = {
|
|
value: {
|
|
name: field.name,
|
|
},
|
|
text: 'Field',
|
|
};
|
|
}
|
|
|
|
if (value.rowIndex) {
|
|
const { timeField } = getTimeField(dataFrame);
|
|
scopedVars['__value'] = {
|
|
value: {
|
|
raw: field.values.get(value.rowIndex),
|
|
numeric: value.display.numeric,
|
|
text: value.display.text,
|
|
time: timeField ? timeField.values.get(value.rowIndex) : undefined,
|
|
},
|
|
text: 'Value',
|
|
};
|
|
} else {
|
|
// calculation
|
|
scopedVars['__value'] = {
|
|
value: {
|
|
raw: value.display.numeric,
|
|
numeric: value.display.numeric,
|
|
text: value.display.text,
|
|
calc: value.name,
|
|
},
|
|
text: 'Value',
|
|
};
|
|
}
|
|
} else {
|
|
console.log('VALUE', value);
|
|
}
|
|
|
|
return links.map(link => {
|
|
return getLinkSrv().getDataLinkUIModel(link, scopedVars, value);
|
|
});
|
|
},
|
|
};
|
|
};
|
|
|
|
export const getPanelLinksSupplier = (value: PanelModel): LinkModelSupplier<PanelModel> => {
|
|
const links = value.links;
|
|
|
|
if (!links || links.length === 0) {
|
|
return undefined;
|
|
}
|
|
|
|
return {
|
|
getLinks: () => {
|
|
return links.map(link => {
|
|
return getLinkSrv().getDataLinkUIModel(link, value.scopedVars, value);
|
|
});
|
|
},
|
|
};
|
|
};
|