mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
* Chore: initial commit * Tests: fixes MetricsQueryEditor.test.tsx * Tests: fixes cloudwatch/specs/datasource.test.ts * Tests: fixes stackdriver/specs/datasource.test.ts * Tests: remove refrences to CustomVariable * Refactor: moves DefaultVariableQueryEditor * Refactor: moves utils * Refactor: moves types * Refactor: removes variableSrv * Refactor: removes feature toggle newVariables * Refactor: removes valueSelectDropDown * Chore: removes GeneralTabCtrl * Chore: migrates RowOptions * Refactor: adds RowOptionsButton * Refactor: makes the interface more explicit * Refactor: small changes * Refactor: changed type as it can be any variable type * Tests: fixes broken test * Refactor: changes after PR comments * Refactor: adds loading state and call to onChange in componentDidMount
40 lines
1.3 KiB
TypeScript
40 lines
1.3 KiB
TypeScript
import { StoreState } from '../../../types';
|
|
import { VariableModel } from '../types';
|
|
import { getState } from '../../../store/store';
|
|
import { NEW_VARIABLE_ID } from './types';
|
|
|
|
export const getVariable = <T extends VariableModel = VariableModel>(
|
|
id: string,
|
|
state: StoreState = getState(),
|
|
throwWhenMissing = true
|
|
): T => {
|
|
if (!state.templating.variables[id]) {
|
|
if (throwWhenMissing) {
|
|
throw new Error(`Couldn't find variable with id:${id}`);
|
|
}
|
|
return (undefined as unknown) as T;
|
|
}
|
|
|
|
return state.templating.variables[id] as T;
|
|
};
|
|
|
|
export const getFilteredVariables = (filter: (model: VariableModel) => boolean, state: StoreState = getState()) => {
|
|
return Object.values(state.templating.variables)
|
|
.filter(filter)
|
|
.sort((s1, s2) => s1.index - s2.index);
|
|
};
|
|
|
|
export const getVariableWithName = (name: string, state: StoreState = getState()) => {
|
|
return getVariable(name, state, false);
|
|
};
|
|
|
|
export const getVariables = (state: StoreState = getState(), includeNewVariable = false): VariableModel[] => {
|
|
return getFilteredVariables(variable => (includeNewVariable ? true : variable.id !== NEW_VARIABLE_ID), state);
|
|
};
|
|
|
|
export type GetVariables = typeof getVariables;
|
|
|
|
export const getNewVariabelIndex = (state: StoreState = getState()): number => {
|
|
return Object.values(state.templating.variables).length;
|
|
};
|