| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- ///<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';
- import {QueryCtrl} from 'app/plugins/sdk';
- import {PromQuery, getQueryPartCategories} from './prom_query';
- class PrometheusQueryCtrl extends QueryCtrl {
- static templateUrl = 'partials/query.editor.html';
- query: any;
- metricSegment: any;
- addQueryPartMenu: any[];
- resolutions: any;
- oldTarget: any;
- suggestMetrics: any;
- linkToPrometheus: any;
- /** @ngInject */
- constructor($scope, $injector, private templateSrv, private uiSegmentSrv, private $rootScope) {
- super($scope, $injector);
- this.query = new PromQuery(this.target, templateSrv);
- if (this.target.metric) {
- this.metricSegment = uiSegmentSrv.newSegment(this.target.metric);
- } else {
- this.metricSegment = uiSegmentSrv.newSegment({value: 'select metric', fake: true});
- }
- this.resolutions = _.map([1,2,3,4,5,10], function(f) {
- return {factor: f, label: '1/' + f};
- });
- this.updateLink();
- this.buildQueryPartMenu();
- }
- buildQueryPartMenu() {
- var categories = getQueryPartCategories();
- this.addQueryPartMenu = _.reduce(categories, function(memo, cat, key) {
- var menu = {
- text: key,
- submenu: cat.map(item => {
- return {text: item.type, value: item.type};
- }),
- };
- memo.push(menu);
- return memo;
- }, []);
- }
- addQueryPart(item, subItem) {
- this.query.addQueryPart(item, subItem);
- this.panelCtrl.refresh();
- }
- getPartOptions(part) {
- if (part.def.type === 'by') {
- return this.datasource.metricFindQuery('labels(' + this.target.metric + ')')
- .then(this.transformToSegments(true))
- .catch(this.handleQueryError.bind(true));
- }
- }
- partUpdated(part) {
- this.target.expr = this.query.render();
- this.panelCtrl.refresh();
- }
- handleQueryError(err) {
- this.$rootScope.appEvent('alert-error', ['Query failed', err.message]);
- }
- transformToSegments(addTemplateVars) {
- return (results) => {
- var segments = _.map(results, segment => {
- return this.uiSegmentSrv.newSegment({ value: segment.text, expandable: segment.expandable });
- });
- if (addTemplateVars) {
- for (let variable of this.templateSrv.variables) {
- segments.unshift(this.uiSegmentSrv.newSegment({ type: 'template', value: '/^$' + variable.name + '$/', expandable: true }));
- }
- }
- return segments;
- };
- }
- getMetricOptions() {
- return this.datasource.performSuggestQuery('').then(res => {
- return _.map(res, metric => {
- return this.uiSegmentSrv.newSegment(metric);
- });
- });
- }
- queryChanged() {
- this.target.metric = this.metricSegment.value;
- this.target.expr = this.query.render();
- this.refresh();
- }
- toggleEditorMode() {
- this.target.expr = this.query.render(false);
- this.target.editorMode = !this.target.editorMode;
- }
- refreshMetricData() {
- if (!_.isEqual(this.oldTarget, this.target)) {
- this.oldTarget = angular.copy(this.target);
- this.panelCtrl.refresh();
- this.updateLink();
- }
- }
- updateLink() {
- 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');
- var expr = {
- expr: this.templateSrv.replace(this.target.expr, this.panelCtrl.panel.scopedVars, this.datasource.interpolateQueryExpr),
- range_input: rangeDiff + 's',
- end_input: endTime,
- step_input: '',
- stacked: this.panelCtrl.panel.stack,
- tab: 0
- };
- var hash = encodeURIComponent(JSON.stringify([expr]));
- this.linkToPrometheus = this.datasource.directUrl + '/graph#' + hash;
- }
- }
- export {PrometheusQueryCtrl};
|