mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
* Add and configure eslint-plugin-import * Fix the lint:ts npm command * Autofix + prettier all the files * Manually fix remaining files * Move jquery code in jest-setup to external file to safely reorder imports * Resolve issue caused by circular dependencies within Prometheus * Update .betterer.results * Fix missing // @ts-ignore * ignore iconBundle.ts * Fix missing // @ts-ignore
36 lines
1.3 KiB
TypeScript
36 lines
1.3 KiB
TypeScript
import { createAction } from '@reduxjs/toolkit';
|
|
import { AnyAction } from 'redux';
|
|
|
|
import { variableAdapters } from '../adapters';
|
|
import { VariableModel } from '../types';
|
|
|
|
import { sharedReducer } from './sharedReducer';
|
|
import { initialVariablesState, VariablesState } from './types';
|
|
|
|
export const cleanVariables = createAction<undefined>('templating/cleanVariables');
|
|
|
|
export const variablesReducer = (state: VariablesState = initialVariablesState, action: AnyAction): VariablesState => {
|
|
if (cleanVariables.match(action)) {
|
|
const globalVariables = Object.values(state).filter((v) => v.global);
|
|
if (!globalVariables) {
|
|
return initialVariablesState;
|
|
}
|
|
|
|
const variables = globalVariables.reduce((allVariables, state) => {
|
|
allVariables[state.id] = state;
|
|
return allVariables;
|
|
}, {} as Record<string, VariableModel>);
|
|
|
|
return variables;
|
|
}
|
|
|
|
if (action?.payload?.type && variableAdapters.getIfExists(action?.payload?.type)) {
|
|
// Now that we know we are dealing with a payload that is addressed for an adapted variable let's reduce state:
|
|
// Firstly call the sharedTemplatingReducer that handles all shared actions between variable types
|
|
// Secondly call the specific variable type's reducer
|
|
return variableAdapters.get(action.payload.type).reducer(sharedReducer(state, action), action);
|
|
}
|
|
|
|
return state;
|
|
};
|