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 => { return async (dispatch, getState) => { const { rootStateKey, type } = identifier; dispatch(toKeyedAction(rootStateKey, createTextBoxOptions(toVariablePayload(identifier)))); const variableInState = getVariable(identifier, getState()); await variableAdapters.get(type).setValue(variableInState, variableInState.options[0], true); }; }; export const setTextBoxVariableOptionsFromUrl = (identifier: KeyedVariableIdentifier, urlValue: UrlQueryValue): ThunkResult => async (dispatch, getState) => { const { rootStateKey } = identifier; const variableInState = getVariable(identifier, getState()); const stringUrlValue = ensureStringValues(urlValue); dispatch( toKeyedAction( rootStateKey, changeVariableProp(toVariablePayload(variableInState, { propName: 'query', propValue: stringUrlValue })) ) ); await dispatch(setOptionFromUrl(toKeyedVariableIdentifier(variableInState), stringUrlValue)); };