mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* Refactor: moves all the newVariables part to features/variables directory * Feature: adds datasource type * Tests: adds reducer tests * Tests: covers data source actions with tests * Chore: reduces strict null errors
39 lines
1.4 KiB
TypeScript
39 lines
1.4 KiB
TypeScript
import { PayloadAction } from '@reduxjs/toolkit';
|
|
import { cleanUpDashboard } from '../../dashboard/state/reducers';
|
|
import { variableAdapters } from '../adapters';
|
|
import { sharedReducer } from './sharedReducer';
|
|
import { VariableModel } from '../../templating/variable';
|
|
import { VariablePayload } from './types';
|
|
|
|
export interface VariablesState extends Record<string, VariableModel> {}
|
|
|
|
export const initialVariablesState: VariablesState = {};
|
|
|
|
export const variablesReducer = (
|
|
state: VariablesState = initialVariablesState,
|
|
action: PayloadAction<VariablePayload>
|
|
): VariablesState => {
|
|
if (cleanUpDashboard.match(action)) {
|
|
const globalVariables = Object.values(state).filter(v => v.global);
|
|
if (!globalVariables) {
|
|
return initialVariablesState;
|
|
}
|
|
|
|
const variables = globalVariables.reduce((allVariables, state) => {
|
|
allVariables[state.uuid!] = state;
|
|
return allVariables;
|
|
}, {} as Record<string, VariableModel>);
|
|
|
|
return variables;
|
|
}
|
|
|
|
if (action?.payload?.type && variableAdapters.contains(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;
|
|
};
|