bucket_agg.js 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  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. case 'geohash_grid': {
  55. $scope.agg.settings.precision = 3;
  56. break;
  57. }
  58. }
  59. $scope.validateModel();
  60. $scope.onChange();
  61. };
  62. $scope.validateModel = function() {
  63. $scope.index = _.indexOf(bucketAggs, $scope.agg);
  64. $scope.isFirst = $scope.index === 0;
  65. $scope.bucketAggCount = bucketAggs.length;
  66. var settingsLinkText = "";
  67. var settings = $scope.agg.settings || {};
  68. switch($scope.agg.type) {
  69. case 'terms': {
  70. settings.order = settings.order || "asc";
  71. settings.size = settings.size || "10";
  72. settings.orderBy = settings.orderBy || "_term";
  73. if (settings.size !== '0') {
  74. settingsLinkText = queryDef.describeOrder(settings.order) + ' ' + settings.size + ', ';
  75. }
  76. settingsLinkText += 'Order by: ' + queryDef.describeOrderBy(settings.orderBy, $scope.target);
  77. if (settings.size === '0') {
  78. settingsLinkText += ' (' + settings.order + ')';
  79. }
  80. break;
  81. }
  82. case 'filters': {
  83. settings.filters = settings.filters || [{query: '*'}];
  84. settingsLinkText = _.reduce(settings.filters, function(memo, value, index) {
  85. memo += 'Q' + (index + 1) + ' = ' + value.query + ' ';
  86. return memo;
  87. }, '');
  88. if (settingsLinkText.length > 50) {
  89. settingsLinkText = settingsLinkText.substr(0, 50) + "...";
  90. }
  91. settingsLinkText = 'Filter Queries (' + settings.filters.length + ')';
  92. break;
  93. }
  94. case 'date_histogram': {
  95. settings.interval = settings.interval || 'auto';
  96. settings.min_doc_count = settings.min_doc_count || 0;
  97. $scope.agg.field = $scope.target.timeField;
  98. settingsLinkText = 'Interval: ' + settings.interval;
  99. if (settings.min_doc_count > 0) {
  100. settingsLinkText += ', Min Doc Count: ' + settings.min_doc_count;
  101. }
  102. if (settings.trimEdges === undefined || settings.trimEdges < 0) {
  103. settings.trimEdges = 0;
  104. }
  105. if (settings.trimEdges && settings.trimEdges > 0) {
  106. settingsLinkText += ', Trim edges: ' + settings.trimEdges;
  107. }
  108. break;
  109. }
  110. case 'geohash_grid': {
  111. // limit precision to 7
  112. settings.precision = Math.max(Math.min(settings.precision, 7), 1);
  113. settingsLinkText = 'Precision: ' + settings.precision;
  114. break;
  115. }
  116. }
  117. $scope.settingsLinkText = settingsLinkText;
  118. $scope.agg.settings = settings;
  119. return true;
  120. };
  121. $scope.addFiltersQuery = function() {
  122. $scope.agg.settings.filters.push({query: '*'});
  123. };
  124. $scope.removeFiltersQuery = function(filter) {
  125. $scope.agg.settings.filters = _.without($scope.agg.settings.filters, filter);
  126. };
  127. $scope.toggleOptions = function() {
  128. $scope.showOptions = !$scope.showOptions;
  129. $scope.updateOrderByOptions();
  130. };
  131. $scope.updateOrderByOptions = function() {
  132. $scope.orderByOptions = queryDef.getOrderByOptions($scope.target);
  133. };
  134. $scope.getFieldsInternal = function() {
  135. if ($scope.agg.type === 'date_histogram') {
  136. return $scope.getFields({$fieldType: 'date'});
  137. } else {
  138. return $scope.getFields();
  139. }
  140. };
  141. $scope.getIntervalOptions = function() {
  142. return $q.when(uiSegmentSrv.transformToSegments(true, 'interval')(queryDef.intervalOptions));
  143. };
  144. $scope.addBucketAgg = function() {
  145. // if last is date histogram add it before
  146. var lastBucket = bucketAggs[bucketAggs.length - 1];
  147. var addIndex = bucketAggs.length - 1;
  148. if (lastBucket && lastBucket.type === 'date_histogram') {
  149. addIndex - 1;
  150. }
  151. var id = _.reduce($scope.target.bucketAggs.concat($scope.target.metrics), function(max, val) {
  152. return parseInt(val.id) > max ? parseInt(val.id) : max;
  153. }, 0);
  154. bucketAggs.splice(addIndex, 0, {type: "terms", field: "select field", id: (id+1).toString(), fake: true});
  155. $scope.onChange();
  156. };
  157. $scope.removeBucketAgg = function() {
  158. bucketAggs.splice($scope.index, 1);
  159. $scope.onChange();
  160. };
  161. $scope.init();
  162. });
  163. });