bucket_agg.js 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. define([
  2. 'angular',
  3. 'lodash',
  4. './query_def',
  5. ],
  6. function (angular, _, queryDef) {
  7. 'use strict';
  8. var module = angular.module('grafana.directives');
  9. module.directive('elasticBucketAgg', function() {
  10. return {
  11. templateUrl: 'public/app/plugins/datasource/elasticsearch/partials/bucket_agg.html',
  12. controller: 'ElasticBucketAggCtrl',
  13. restrict: 'E',
  14. scope: {
  15. target: "=",
  16. index: "=",
  17. onChange: "&",
  18. getFields: "&",
  19. }
  20. };
  21. });
  22. module.controller('ElasticBucketAggCtrl', function($scope, uiSegmentSrv, $q, $rootScope) {
  23. var bucketAggs = $scope.target.bucketAggs;
  24. $scope.orderByOptions = [];
  25. $scope.bucketAggTypes = queryDef.bucketAggTypes;
  26. $scope.orderOptions = queryDef.orderOptions;
  27. $scope.sizeOptions = queryDef.sizeOptions;
  28. $rootScope.onAppEvent('elastic-query-updated', function() {
  29. $scope.validateModel();
  30. $scope.updateOrderByOptions();
  31. }, $scope);
  32. $scope.init = function() {
  33. $scope.agg = bucketAggs[$scope.index];
  34. $scope.validateModel();
  35. };
  36. $scope.onChangeInternal = function() {
  37. $scope.onChange();
  38. };
  39. $scope.onTypeChanged = function() {
  40. $scope.agg.settings = {};
  41. $scope.showOptions = false;
  42. switch($scope.agg.type) {
  43. case 'date_histogram':
  44. case 'terms': {
  45. delete $scope.agg.query;
  46. $scope.agg.field = 'select field';
  47. break;
  48. }
  49. case 'filters': {
  50. delete $scope.agg.field;
  51. $scope.agg.query = '*';
  52. break;
  53. }
  54. }
  55. $scope.validateModel();
  56. $scope.onChange();
  57. };
  58. $scope.validateModel = function() {
  59. $scope.index = _.indexOf(bucketAggs, $scope.agg);
  60. $scope.isFirst = $scope.index === 0;
  61. $scope.isLast = $scope.index === bucketAggs.length - 1;
  62. var settingsLinkText = "";
  63. var settings = $scope.agg.settings || {};
  64. switch($scope.agg.type) {
  65. case 'terms': {
  66. settings.order = settings.order || "asc";
  67. settings.size = settings.size || "10";
  68. settings.orderBy = settings.orderBy || "_term";
  69. if (settings.size !== '0') {
  70. settingsLinkText = queryDef.describeOrder(settings.order) + ' ' + settings.size + ', ';
  71. }
  72. settingsLinkText += 'Order by: ' + queryDef.describeOrderBy(settings.orderBy, $scope.target);
  73. if (settings.size === '0') {
  74. settingsLinkText += ' (' + settings.order + ')';
  75. }
  76. break;
  77. }
  78. case 'filters': {
  79. settings.filters = settings.filters || [{query: '*'}];
  80. settingsLinkText = _.reduce(settings.filters, function(memo, value, index) {
  81. memo += 'Q' + (index + 1) + ' = ' + value.query + ' ';
  82. return memo;
  83. }, '');
  84. if (settingsLinkText.length > 50) {
  85. settingsLinkText = settingsLinkText.substr(0, 50) + "...";
  86. }
  87. settingsLinkText = 'Filter Queries (' + settings.filters.length + ')';
  88. break;
  89. }
  90. case 'date_histogram': {
  91. settings.interval = settings.interval || 'auto';
  92. settings.min_doc_count = settings.min_doc_count || 0;
  93. $scope.agg.field = $scope.target.timeField;
  94. settingsLinkText = 'Interval: ' + settings.interval;
  95. if (settings.min_doc_count > 0) {
  96. settingsLinkText += ', Min Doc Count: ' + settings.min_doc_count;
  97. }
  98. if (settings.trimEdges === undefined || settings.trimEdges < 0) {
  99. settings.trimEdges = 0;
  100. }
  101. if (settings.trimEdges && settings.trimEdges > 0) {
  102. settingsLinkText += ', Trim edges: ' + settings.trimEdges;
  103. }
  104. }
  105. }
  106. $scope.settingsLinkText = settingsLinkText;
  107. $scope.agg.settings = settings;
  108. return true;
  109. };
  110. $scope.addFiltersQuery = function() {
  111. $scope.agg.settings.filters.push({query: '*'});
  112. };
  113. $scope.removeFiltersQuery = function(filter) {
  114. $scope.agg.settings.filters = _.without($scope.agg.settings.filters, filter);
  115. };
  116. $scope.toggleOptions = function() {
  117. $scope.showOptions = !$scope.showOptions;
  118. $scope.updateOrderByOptions();
  119. };
  120. $scope.updateOrderByOptions = function() {
  121. $scope.orderByOptions = queryDef.getOrderByOptions($scope.target);
  122. };
  123. $scope.getFieldsInternal = function() {
  124. if ($scope.agg.type === 'date_histogram') {
  125. return $scope.getFields({$fieldType: 'date'});
  126. } else {
  127. return $scope.getFields();
  128. }
  129. };
  130. $scope.getIntervalOptions = function() {
  131. return $q.when(uiSegmentSrv.transformToSegments(true, 'interval')(queryDef.intervalOptions));
  132. };
  133. $scope.addBucketAgg = function() {
  134. // if last is date histogram add it before
  135. var lastBucket = bucketAggs[bucketAggs.length - 1];
  136. var addIndex = bucketAggs.length - 1;
  137. if (lastBucket && lastBucket.type === 'date_histogram') {
  138. addIndex - 1;
  139. }
  140. var id = _.reduce($scope.target.bucketAggs.concat($scope.target.metrics), function(max, val) {
  141. return parseInt(val.id) > max ? parseInt(val.id) : max;
  142. }, 0);
  143. bucketAggs.splice(addIndex, 0, {type: "terms", field: "select field", id: (id+1).toString(), fake: true});
  144. $scope.onChange();
  145. };
  146. $scope.removeBucketAgg = function() {
  147. bucketAggs.splice($scope.index, 1);
  148. $scope.onChange();
  149. };
  150. $scope.init();
  151. });
  152. });