query_ctrl.ts 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. ///<reference path="../../../headers/common.d.ts" />
  2. import angular from 'angular';
  3. import _ from 'lodash';
  4. import moment from 'moment';
  5. import * as dateMath from 'app/core/utils/datemath';
  6. import {QueryCtrl} from 'app/plugins/sdk';
  7. class PrometheusQueryCtrl extends QueryCtrl {
  8. static templateUrl = 'partials/query.editor.html';
  9. metric: any;
  10. resolutions: any;
  11. formats: any;
  12. oldTarget: any;
  13. suggestMetrics: any;
  14. getMetricsAutocomplete: any;
  15. linkToPrometheus: any;
  16. /** @ngInject */
  17. constructor($scope, $injector, private templateSrv) {
  18. super($scope, $injector);
  19. var target = this.target;
  20. target.expr = target.expr || '';
  21. target.intervalFactor = target.intervalFactor || 2;
  22. target.format = target.format || this.getDefaultFormat();
  23. this.metric = '';
  24. this.resolutions = _.map([1,2,3,4,5,10], function(f) {
  25. return {factor: f, label: '1/' + f};
  26. });
  27. this.formats = [
  28. {text: 'Time series', value: 'time_series'},
  29. {text: 'Table', value: 'table'},
  30. ];
  31. $scope.$on('typeahead-updated', () => {
  32. this.$scope.$apply(() => {
  33. this.target.expr += this.target.metric;
  34. this.metric = '';
  35. this.refreshMetricData();
  36. });
  37. });
  38. // called from typeahead so need this
  39. // here in order to ensure this ref
  40. this.suggestMetrics = (query, callback) => {
  41. console.log(this);
  42. this.datasource.performSuggestQuery(query).then(callback);
  43. };
  44. this.getMetricsAutocomplete = (query) => {
  45. return this.datasource.performSuggestQuery(query);
  46. };
  47. this.updateLink();
  48. }
  49. getDefaultFormat() {
  50. if (this.panelCtrl.panel.type === 'table') {
  51. return 'table';
  52. }
  53. return 'time_series';
  54. }
  55. refreshMetricData() {
  56. if (!_.isEqual(this.oldTarget, this.target)) {
  57. this.oldTarget = angular.copy(this.target);
  58. this.panelCtrl.refresh();
  59. this.updateLink();
  60. }
  61. }
  62. updateLink() {
  63. var range = this.panelCtrl.range;
  64. if (!range) {
  65. return;
  66. }
  67. var rangeDiff = Math.ceil((range.to.valueOf() - range.from.valueOf()) / 1000);
  68. var endTime = range.to.utc().format('YYYY-MM-DD HH:mm');
  69. var expr = {
  70. 'g0.expr': this.templateSrv.replace(this.target.expr, this.panelCtrl.panel.scopedVars, this.datasource.interpolateQueryExpr),
  71. 'g0.range_input': rangeDiff + 's',
  72. 'g0.end_input': endTime,
  73. 'g0.step_input': this.target.step,
  74. 'g0.stacked': this.panelCtrl.panel.stack ? 1 : 0,
  75. 'g0.tab': 0
  76. };
  77. var args = _.map(expr, (v, k) => { return k + '=' + encodeURIComponent(v); }).join('&');
  78. this.linkToPrometheus = this.datasource.directUrl + '/graph?' + args;
  79. }
  80. getCollapsedText() {
  81. return this.target.expr;
  82. }
  83. }
  84. export {PrometheusQueryCtrl};