mirror of
https://github.com/grafana/grafana.git
synced 2025-09-28 14:13:52 +08:00

* DashboardLinks: WIP fix for dashboard links issue * Make the dashboard links update on change(hacky) * Replace dashboard links with new array when updating/adding dash links * Update snaps * Deep clone dashboard links on save Co-authored-by: Dominik Prokop <dominik.prokop@grafana.com>
59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
import { StoreState } from '../../../types';
|
|
import { VariableModel } from '../types';
|
|
import { getState } from '../../../store/store';
|
|
import { NEW_VARIABLE_ID } from './types';
|
|
import memoizeOne from 'memoize-one';
|
|
|
|
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[] => {
|
|
const filter = (variable: VariableModel) => {
|
|
if (variable.type === 'system') {
|
|
return false;
|
|
}
|
|
if (includeNewVariable) {
|
|
return true;
|
|
}
|
|
return variable.id !== NEW_VARIABLE_ID;
|
|
};
|
|
|
|
return getFilteredVariables(filter, state);
|
|
};
|
|
|
|
export const getSubMenuVariables = memoizeOne((variables: Record<string, VariableModel>): VariableModel[] => {
|
|
return getVariables(getState());
|
|
});
|
|
|
|
export const getEditorVariables = (state: StoreState): VariableModel[] => {
|
|
return getVariables(state, true);
|
|
};
|
|
|
|
export type GetVariables = typeof getVariables;
|
|
|
|
export const getNewVariabelIndex = (state: StoreState = getState()): number => {
|
|
return Object.values(state.templating.variables).length;
|
|
};
|