query_ctrl.ts 2.3 KB

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