grafana_bak/public/app/features/dashboard-scene/utils/getVariablesCompatibility.ts
2025-04-01 10:38:02 +09:00

23 lines
1.3 KiB
TypeScript

import { TypedVariableModel } from '@grafana/data';
import { sceneGraph, SceneObject } from '@grafana/scenes';
import { sceneVariablesSetToVariables } from '../serialization/sceneVariablesSetToVariables';
export function getVariablesCompatibility(sceneObject: SceneObject): TypedVariableModel[] {
const set = sceneGraph.getVariables(sceneObject);
const keepQueryOptions = true;
// `sceneVariablesSetToVariables` is also used when transforming the scene to a save model.
// In those cases, query options will be stripped out.
// However, when `getVariablesCompatibility` is called from `templateSrv`, it is used to get all variables in the scene.
// Therefore, options should be kept.
const legacyModels = sceneVariablesSetToVariables(set, keepQueryOptions);
// Sadly templateSrv.getVariables returns TypedVariableModel but sceneVariablesSetToVariables return persisted schema model
// They look close to identical (differ in what is optional in some places).
// The way templateSrv.getVariables is used it should not matter. it is mostly used to get names of all variables (for query editors).
// So type and name are important. Maybe some external data sources also check current value so that is also important.
// @ts-expect-error
return legacyModels;
}