query_ctrl.ts 2.4 KB

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