Commit 8b4c7c94 by Torkel Ödegaard

feat(templating): completed work on templating as data source, closes #816

parent 73494271
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
### Enhancements ### Enhancements
* **Singlestat**: Support for gauges in singlestat panel. closes [#3688](https://github.com/grafana/grafana/pull/3688) * **Singlestat**: Support for gauges in singlestat panel. closes [#3688](https://github.com/grafana/grafana/pull/3688)
* **Templating**: Support for data source as variable, closes [#816](https://github.com/grafana/grafana/pull/816)
### Bug fixes ### Bug fixes
* **InfluxDB 0.12**: Fixed issue templating and `show tag values` query only returning tags for first measurement, fixes [#4726](https://github.com/grafana/grafana/issues/4726) * **InfluxDB 0.12**: Fixed issue templating and `show tag values` query only returning tags for first measurement, fixes [#4726](https://github.com/grafana/grafana/issues/4726)
......
...@@ -102,8 +102,8 @@ function (angular, _, coreModule, config) { ...@@ -102,8 +102,8 @@ function (angular, _, coreModule, config) {
if (ds) { if (ds) {
metricSources.push({ metricSources.push({
name: '[[' + variable.name + ']]', name: '$' + variable.name,
value: '[[' + variable.name + ']]', value: '$' + variable.name,
meta: ds.meta, meta: ds.meta,
}); });
} }
......
...@@ -19,7 +19,7 @@ function (angular, _, coreModule) { ...@@ -19,7 +19,7 @@ function (angular, _, coreModule) {
if (_.isString(options)) { if (_.isString(options)) {
this.value = options; this.value = options;
this.html = $sce.trustAsHtml(this.value); this.html = $sce.trustAsHtml(templateSrv.highlightVariablesAsHtml(this.value));
return; return;
} }
......
...@@ -63,7 +63,9 @@ function (angular, _, kbn) { ...@@ -63,7 +63,9 @@ function (angular, _, kbn) {
// determine our dependencies. // determine our dependencies.
if (variable.type === "query") { if (variable.type === "query") {
_.forEach(this.variables, function(v) { _.forEach(this.variables, function(v) {
if (templateSrv.containsVariable(variable.query, v.name)) { // both query and datasource can contain variable
if (templateSrv.containsVariable(variable.query, v.name) ||
templateSrv.containsVariable(variable.datasource, v.name)) {
dependencies.push(self.variableLock[v.name].promise); dependencies.push(self.variableLock[v.name].promise);
} }
}); });
...@@ -149,7 +151,8 @@ function (angular, _, kbn) { ...@@ -149,7 +151,8 @@ function (angular, _, kbn) {
if (otherVariable === updatedVariable) { if (otherVariable === updatedVariable) {
return; return;
} }
if (templateSrv.containsVariable(otherVariable.query, updatedVariable.name)) { if (templateSrv.containsVariable(otherVariable.query, updatedVariable.name) ||
templateSrv.containsVariable(otherVariable.datasource, updatedVariable.name)) {
return self.updateOptions(otherVariable); return self.updateOptions(otherVariable);
} }
}); });
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment