| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | ///<reference path="../../../headers/common.d.ts" />
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import angular from 'angular'; | 
					
						
							|  |  |  | import _ from 'lodash'; | 
					
						
							|  |  |  | import moment from 'moment'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import * as dateMath from 'app/core/utils/datemath'; | 
					
						
							| 
									
										
										
										
											2016-02-05 18:08:21 +01:00
										 |  |  | import {QueryCtrl} from 'app/plugins/sdk'; | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 12:52:43 +01:00
										 |  |  | class PrometheusQueryCtrl extends QueryCtrl { | 
					
						
							| 
									
										
										
										
											2016-02-09 18:17:32 +01:00
										 |  |  |   static templateUrl = 'partials/query.editor.html'; | 
					
						
							| 
									
										
										
										
											2016-02-05 10:37:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |   metric: any; | 
					
						
							|  |  |  |   resolutions: any; | 
					
						
							|  |  |  |   oldTarget: any; | 
					
						
							| 
									
										
										
										
											2016-02-02 10:19:15 +01:00
										 |  |  |   suggestMetrics: any; | 
					
						
							|  |  |  |   linkToPrometheus: any; | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 12:52:43 +01:00
										 |  |  |   /** @ngInject */ | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |   constructor($scope, $injector, private templateSrv) { | 
					
						
							|  |  |  |     super($scope, $injector); | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |     var target = this.target; | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |     target.expr = target.expr || ''; | 
					
						
							|  |  |  |     target.intervalFactor = target.intervalFactor || 2; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |     this.metric = ''; | 
					
						
							|  |  |  |     this.resolutions = _.map([1,2,3,4,5,10], function(f) { | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |       return {factor: f, label: '1/' + f}; | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |     $scope.$on('typeahead-updated', () => { | 
					
						
							| 
									
										
										
										
											2016-02-02 10:19:15 +01:00
										 |  |  |       this.$scope.$apply(() => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.target.expr += this.target.metric; | 
					
						
							|  |  |  |         this.metric = ''; | 
					
						
							|  |  |  |         this.refreshMetricData(); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2016-02-02 10:19:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // called from typeahead so need this
 | 
					
						
							|  |  |  |     // here in order to ensure this ref
 | 
					
						
							|  |  |  |     this.suggestMetrics = (query, callback) => { | 
					
						
							|  |  |  |       console.log(this); | 
					
						
							|  |  |  |       this.datasource.performSuggestQuery(query).then(callback); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     this.updateLink(); | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |   refreshMetricData() { | 
					
						
							|  |  |  |     if (!_.isEqual(this.oldTarget, this.target)) { | 
					
						
							|  |  |  |       this.oldTarget = angular.copy(this.target); | 
					
						
							|  |  |  |       this.panelCtrl.refresh(); | 
					
						
							| 
									
										
										
										
											2016-02-02 10:19:15 +01:00
										 |  |  |       this.updateLink(); | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 10:19:15 +01:00
										 |  |  |   updateLink() { | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |     var range = this.panelCtrl.range; | 
					
						
							|  |  |  |     var rangeDiff = Math.ceil((range.to.valueOf() - range.from.valueOf()) / 1000); | 
					
						
							|  |  |  |     var endTime = range.to.utc().format('YYYY-MM-DD HH:mm'); | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |     var expr = { | 
					
						
							| 
									
										
										
										
											2016-05-18 14:49:32 +09:00
										 |  |  |       expr: this.templateSrv.replace(this.target.expr, this.panelCtrl.panel.scopedVars, this.datasource.interpolateQueryExpr), | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |       range_input: rangeDiff + 's', | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |       end_input: endTime, | 
					
						
							|  |  |  |       step_input: '', | 
					
						
							| 
									
										
										
										
											2016-02-02 09:12:58 +01:00
										 |  |  |       stacked: this.panelCtrl.panel.stack, | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  |       tab: 0 | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var hash = encodeURIComponent(JSON.stringify([expr])); | 
					
						
							| 
									
										
										
										
											2016-02-02 10:19:15 +01:00
										 |  |  |     this.linkToPrometheus = this.datasource.directUrl + '/graph#' + hash; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-01 23:24:08 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export {PrometheusQueryCtrl}; |