12345678910111213141516171819202122232425262728293031323334353637383940 |
- import { UrlQueryValue } from '@grafana/data';
- import { ThunkResult } from '../../../types';
- import { variableAdapters } from '../adapters';
- import { setOptionFromUrl } from '../state/actions';
- import { toKeyedAction } from '../state/keyedVariablesReducer';
- import { getVariable } from '../state/selectors';
- import { changeVariableProp } from '../state/sharedReducer';
- import { KeyedVariableIdentifier } from '../state/types';
- import { TextBoxVariableModel } from '../types';
- import { ensureStringValues, toKeyedVariableIdentifier, toVariablePayload } from '../utils';
- import { createTextBoxOptions } from './reducer';
- export const updateTextBoxVariableOptions = (identifier: KeyedVariableIdentifier): ThunkResult<void> => {
- return async (dispatch, getState) => {
- const { rootStateKey, type } = identifier;
- dispatch(toKeyedAction(rootStateKey, createTextBoxOptions(toVariablePayload(identifier))));
- const variableInState = getVariable<TextBoxVariableModel>(identifier, getState());
- await variableAdapters.get(type).setValue(variableInState, variableInState.options[0], true);
- };
- };
- export const setTextBoxVariableOptionsFromUrl =
- (identifier: KeyedVariableIdentifier, urlValue: UrlQueryValue): ThunkResult<void> =>
- async (dispatch, getState) => {
- const { rootStateKey } = identifier;
- const variableInState = getVariable<TextBoxVariableModel>(identifier, getState());
- const stringUrlValue = ensureStringValues(urlValue);
- dispatch(
- toKeyedAction(
- rootStateKey,
- changeVariableProp(toVariablePayload(variableInState, { propName: 'query', propValue: stringUrlValue }))
- )
- );
- await dispatch(setOptionFromUrl(toKeyedVariableIdentifier(variableInState), stringUrlValue));
- };
|