query.editor.html 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. <div class="tight-form">
  2. <ul class="tight-form-list pull-right">
  3. <li class="tight-form-item">
  4. <div class="dropdown">
  5. <a class="pointer dropdown-toggle" data-toggle="dropdown" tabindex="1">
  6. <i class="fa fa-bars"></i>
  7. </a>
  8. <ul class="dropdown-menu pull-right" role="menu">
  9. <li role="menuitem"><a tabindex="1" ng-click="duplicate()">Duplicate</a></li>
  10. <li role="menuitem"><a tabindex="1" ng-click="moveMetricQuery($index, $index-1)">Move up</a></li>
  11. <li role="menuitem"><a tabindex="1" ng-click="moveMetricQuery($index, $index+1)">Move down</a></li>
  12. </ul>
  13. </div>
  14. </li>
  15. <li class="tight-form-item last">
  16. <a class="pointer" tabindex="1" ng-click="removeDataQuery(target)">
  17. <i class="fa fa-remove"></i>
  18. </a>
  19. </li>
  20. </ul>
  21. <ul class="tight-form-list">
  22. <li class="tight-form-item" style="min-width: 15px; text-align: center">
  23. {{target.refId}}
  24. </li>
  25. <li>
  26. <a class="tight-form-item" ng-click="target.hide = !target.hide; targetBlur();" role="menuitem">
  27. <i class="fa fa-eye"></i>
  28. </a>
  29. </li>
  30. <li class="tight-form-item">
  31. Metric
  32. </li>
  33. <li>
  34. <input type="text" class="input-large tight-form-input"
  35. ng-model="target.metric"
  36. spellcheck="false"
  37. bs-typeahead="suggestMetrics"
  38. placeholder="metric name"
  39. data-min-length=0 data-items=100
  40. ng-blur="targetBlur()">
  41. <a bs-tooltip="target.errors.metric"
  42. style="color: rgb(229, 189, 28)"
  43. ng-show="target.errors.metric">
  44. <i class="fa fa-warning"></i>
  45. </a>
  46. </li>
  47. <li class="tight-form-item">
  48. Alias
  49. </li>
  50. <li>
  51. <input type="text" class="input-medium tight-form-input" ng-model="target.alias"
  52. spellcheck='false' placeholder="alias" ng-blur="targetBlur()">
  53. </li>
  54. <li class="tight-form-item">
  55. &nbsp;Peak filter
  56. <input class="input-medium" type="checkbox" ng-model="target.exOuter" ng-change="targetBlur()">
  57. </li>
  58. </ul>
  59. <div class="clearfix"></div>
  60. </div>
  61. <!-- TAGS -->
  62. <div class="tight-form">
  63. <ul class="tight-form-list" role="menu">
  64. <li class="tight-form-item tight-form-align">
  65. Tags
  66. </li>
  67. <li ng-repeat="(key, value) in target.tags track by $index" class="tight-form-item">
  68. {{key}}&nbsp;=&nbsp;{{value}}
  69. <a ng-click="removeFilterTag(key)">
  70. <i class="fa fa-remove"></i>
  71. </a>
  72. </li>
  73. <li class="tight-form-item" ng-hide="addFilterTagMode">
  74. <a ng-click="addFilterTag()">
  75. <i class="fa fa-plus"></i>
  76. </a>
  77. </li>
  78. <li ng-show="addFilterTagMode">
  79. <input type="text"
  80. class="input-small tight-form-input"
  81. spellcheck='false'
  82. bs-typeahead="suggestTagKeys"
  83. ng-change="validateFilterTag()"
  84. data-min-length=0 data-items=100
  85. ng-model="target.currentTagKey"
  86. placeholder="key">
  87. </li>
  88. <li ng-show="addFilterTagMode">
  89. <input type="text"
  90. class="input-small tight-form-input"
  91. spellcheck='false'
  92. bs-typeahead="suggestTagValues"
  93. ng-change="validateFilterTag()"
  94. data-min-length=0 data-items=100
  95. ng-model="target.currentTagValue"
  96. placeholder="value">
  97. <a bs-tooltip="target.errors.tags"
  98. style="color: rgb(229, 189, 28)"
  99. ng-show="target.errors.tags">
  100. <i class="fa fa-warning"></i>
  101. </a>
  102. <li class="tight-form-item" ng-show="addFilterTagMode">
  103. <a ng-click="addFilterTag()">
  104. <i ng-show="target.errors.tags" class="fa fa-remove"></i>
  105. <i ng-hide="target.errors.tags" class="fa fa-plus-circle"></i>
  106. </a>
  107. </li>
  108. </li>
  109. </ul>
  110. <div class="clearfix"></div>
  111. </div>
  112. <!-- GROUP BY -->
  113. <div class="tight-form">
  114. <ul class="tight-form-list" role="menu">
  115. <li class="tight-form-item tight-form-align">
  116. Group By
  117. </li>
  118. <li class="tight-form-item" ng-show="target.groupByTags">
  119. tags:
  120. </li>
  121. <li ng-repeat="key in target.groupByTags track by $index" class="tight-form-item">
  122. {{key}}
  123. <a ng-click="removeGroupByTag($index)">
  124. <i class="fa fa-remove"></i>
  125. </a>
  126. </li>
  127. <li class="tight-form-item" ng-show="target.groupByTags && target.nonTagGroupBys">
  128. and by:
  129. </li>
  130. <li ng-repeat="groupByObject in target.nonTagGroupBys track by $index" class="tight-form-item">
  131. {{_.values(groupByObject)}}
  132. <a ng-click="removeNonTagGroupBy($index)">
  133. <i class="fa fa-remove"></i>
  134. </a>
  135. </li>
  136. <li class="tight-form-item" ng-hide="addGroupByMode">
  137. <a ng-click="addGroupBy()">
  138. <i class="fa fa-plus"></i>
  139. </a>
  140. </li>
  141. <li ng-show="addGroupByMode">
  142. <select class="input-small tight-form-input"
  143. ng-change="changeGroupByInput()"
  144. ng-model="target.currentGroupByType"
  145. ng-options="f for f in ['tag','value','time']"></select>
  146. </li>
  147. <li ng-show="isTagGroupBy">
  148. <input type="text"
  149. class="input-small tight-form-input"
  150. spellcheck='false'
  151. bs-typeahead="suggestTagKeys"
  152. ng-change = "validateGroupBy()"
  153. data-min-length=0 data-items=100
  154. ng-model="target.groupBy.tagKey"
  155. placeholder="key">
  156. <a bs-tooltip="target.errors.groupBy.tagKey"
  157. style="color: rgb(229, 189, 28)"
  158. ng-show="target.errors.groupBy.tagKey">
  159. <i class="fa fa-warning"></i>
  160. </a>
  161. </li>
  162. <li ng-show="isValueGroupBy">
  163. <input type="text"
  164. class="input-mini tight-form-input"
  165. spellcheck='false'
  166. ng-model="target.groupBy.valueRange"
  167. placeholder="range"
  168. bs-tooltip="'Range on which values are considered in the same group'"
  169. ng-change = "validateGroupBy()" >
  170. <a bs-tooltip="target.errors.groupBy.valueRange"
  171. style="color: rgb(229, 189, 28)"
  172. ng-show="target.errors.groupBy.valueRange">
  173. <i class="fa fa-warning"></i>
  174. </a>
  175. </li>
  176. <li ng-show="isTimeGroupBy">
  177. <input type="text"
  178. class="input-mini tight-form-input"
  179. ng-model="target.groupBy.timeInterval"
  180. ng-init="target.groupBy.timeInterval='1s'"
  181. placeholder="interval"
  182. bs-tooltip="'Duration of time groups'"
  183. spellcheck='false'
  184. ng-change="validateGroupBy()">
  185. <a bs-tooltip="target.errors.groupBy.timeInterval"
  186. style="color: rgb(229, 189, 28)"
  187. ng-show="target.errors.groupBy.timeInterval">
  188. <i class="fa fa-warning"></i>
  189. </a>
  190. </li>
  191. <li ng-show="isTimeGroupBy">
  192. <input type="text"
  193. class="input-mini tight-form-input"
  194. ng-model="target.groupBy.groupCount"
  195. placeholder="Count"
  196. bs-tooltip="'Number of time groups to be formed'"
  197. spellcheck='false'
  198. ng-change="validateGroupBy()">
  199. <a bs-tooltip="target.errors.groupBy.groupCount"
  200. style="color: rgb(229, 189, 28)"
  201. ng-show="target.errors.groupBy.groupCount">
  202. <i class="fa fa-warning"></i>
  203. </a>
  204. </li>
  205. <li class="tight-form-item" ng-show="addGroupByMode">
  206. <a ng-click="addGroupBy()">
  207. <i ng-hide="isGroupByValid" class="fa fa-remove"></i>
  208. <i ng-show="isGroupByValid" class="fa fa-plus-circle"></i>
  209. </a>
  210. </li>
  211. </ul>
  212. <div class="clearfix"></div>
  213. </div>
  214. <!-- HORIZONTAL AGGREGATION -->
  215. <div class="tight-form">
  216. <ul class="tight-form-list" role="menu">
  217. <li class="tight-form-item tight-form-align">
  218. Aggregators
  219. </li>
  220. <li ng-repeat="aggregatorObject in target.horizontalAggregators track by $index" class="tight-form-item">
  221. {{aggregatorObject.name}}&#40;
  222. <span ng-repeat="aggKey in _.keys(_.omit(aggregatorObject,'name'))" bs-tooltip="aggKey">
  223. {{$last?aggregatorObject[aggKey]:aggregatorObject[aggKey]+","}}
  224. </span>
  225. &#41;
  226. <a ng-click="removeHorizontalAggregator($index)">
  227. <i class="fa fa-remove"></i>
  228. </a>
  229. </li>
  230. <li class="tight-form-item" ng-hide="addHorizontalAggregatorMode">
  231. <a ng-click="addHorizontalAggregator()">
  232. <i class="fa fa-plus"></i>
  233. </a>
  234. </li>
  235. <li ng-show="addHorizontalAggregatorMode">
  236. <select class="input-medium tight-form-input"
  237. ng-change="changeHorAggregationInput()"
  238. ng-model="target.currentHorizontalAggregatorName"
  239. ng-options="f for f in ['avg','dev','max','min','rate','sampler','count','sum','least_squares','percentile','scale','div']"></select>
  240. </li>
  241. <!-- Different parameters -->
  242. <li ng-show="hasSamplingRate" class="tight-form-item">
  243. every
  244. </li>
  245. <li ng-show="hasSamplingRate">
  246. <input type="text"
  247. class="input-mini tight-form-input"
  248. ng-model="target.horAggregator.samplingRate"
  249. ng-init="target.horAggregator.samplingRate='1s'"
  250. spellcheck='false'
  251. ng-change="validateHorizontalAggregator()" >
  252. <a bs-tooltip="target.errors.horAggregator.samplingRate"
  253. style="color: rgb(229, 189, 28)"
  254. ng-show="target.errors.horAggregator.samplingRate">
  255. <i class="fa fa-warning"></i>
  256. </a>
  257. </li>
  258. <li ng-show="hasUnit" class="tight-form-item">
  259. every
  260. </li>
  261. <li ng-show="hasUnit">
  262. <select class="input-medium tight-form-input"
  263. ng-model="target.horAggregator.unit"
  264. ng-init="target.horAggregator.unit='millisecond'"
  265. ng-options="f for f in ['millisecond','second','minute','hour','day','week','month','year']"></select>
  266. </li>
  267. <li ng-show="hasFactor" class="tight-form-item">
  268. by
  269. </li>
  270. <li ng-show="hasFactor">
  271. <input type="text"
  272. class="input-mini tight-form-input"
  273. ng-model="target.horAggregator.factor"
  274. ng-init="target.horAggregator.factor='1'"
  275. spellcheck='false'
  276. ng-change="validateHorizontalAggregator()" >
  277. <a bs-tooltip="target.errors.horAggregator.factor"
  278. style="color: rgb(229, 189, 28)"
  279. ng-show="target.errors.horAggregator.factor">
  280. <i class="fa fa-warning"></i>
  281. </a>
  282. </li>
  283. <li ng-show="hasPercentile" class="tight-form-item">
  284. percentile
  285. </li>
  286. <li ng-show="hasPercentile">
  287. <input type="text"
  288. class="input-mini tight-form-input"
  289. ng-model="target.horAggregator.percentile"
  290. ng-init="target.horAggregator.percentile='0.75'"
  291. spellcheck='false'
  292. ng-change="validateHorizontalAggregator()" >
  293. <a bs-tooltip="target.errors.horAggregator.percentile"
  294. style="color: rgb(229, 189, 28)"
  295. ng-show="target.errors.horAggregator.percentile">
  296. <i class="fa fa-warning"></i>
  297. </a>
  298. </li>
  299. <li class="tight-form-item" ng-show="addHorizontalAggregatorMode">
  300. <a ng-click="addHorizontalAggregator()">
  301. <i ng-hide="isAggregatorValid" class="fa fa-remove"></i>
  302. <i ng-show="isAggregatorValid" class="fa fa-plus-circle"></i>
  303. </a>
  304. </li>
  305. </ul>
  306. <div class="clearfix"></div>
  307. </div>