mirror of
https://github.com/grafana/grafana.git
synced 2025-02-11 08:05:43 -06:00
80 lines
1.7 KiB
TypeScript
80 lines
1.7 KiB
TypeScript
import _ from 'lodash';
|
|
import { Variable, assignModelProperties, variableTypes } from './variable';
|
|
|
|
export class CustomVariable implements Variable {
|
|
query: string;
|
|
options: any;
|
|
includeAll: boolean;
|
|
multi: boolean;
|
|
current: any;
|
|
skipUrlSync: boolean;
|
|
|
|
defaults = {
|
|
type: 'custom',
|
|
name: '',
|
|
label: '',
|
|
hide: 0,
|
|
options: [],
|
|
current: {},
|
|
query: '',
|
|
includeAll: false,
|
|
multi: false,
|
|
allValue: null,
|
|
skipUrlSync: false,
|
|
};
|
|
|
|
/** @ngInject */
|
|
constructor(private model, private variableSrv) {
|
|
assignModelProperties(this, model, this.defaults);
|
|
}
|
|
|
|
setValue(option) {
|
|
return this.variableSrv.setOptionAsCurrent(this, option);
|
|
}
|
|
|
|
getSaveModel() {
|
|
assignModelProperties(this.model, this, this.defaults);
|
|
return this.model;
|
|
}
|
|
|
|
updateOptions() {
|
|
// extract options in comma separated string (use backslash to escape wanted commas)
|
|
this.options = _.map(this.query.match(/(?:\\,|[^,])+/g), text => {
|
|
text = text.replace('\\,', ',');
|
|
return { text: text.trim(), value: text.trim() };
|
|
});
|
|
|
|
if (this.includeAll) {
|
|
this.addAllOption();
|
|
}
|
|
|
|
return this.variableSrv.validateVariableSelectionState(this);
|
|
}
|
|
|
|
addAllOption() {
|
|
this.options.unshift({ text: 'All', value: '$__all' });
|
|
}
|
|
|
|
dependsOn(variable) {
|
|
return false;
|
|
}
|
|
|
|
setValueFromUrl(urlValue) {
|
|
return this.variableSrv.setOptionFromUrl(this, urlValue);
|
|
}
|
|
|
|
getValueForUrl() {
|
|
if (this.current.text === 'All') {
|
|
return 'All';
|
|
}
|
|
return this.current.value;
|
|
}
|
|
}
|
|
|
|
variableTypes['custom'] = {
|
|
name: 'Custom',
|
|
ctor: CustomVariable,
|
|
description: 'Define variable values manually',
|
|
supportsMulti: true,
|
|
};
|