module.js 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. /*
  2. ## Timepicker2
  3. ### Parameters
  4. * mode :: The default mode of the panel. Options: 'relative', 'absolute' 'since' Default: 'relative'
  5. * time_options :: An array of possible time options. Default: ['5m','15m','1h','6h','12h','24h','2d','7d','30d']
  6. * timespan :: The default options selected for the relative view. Default: '15m'
  7. * timefield :: The field in which time is stored in the document.
  8. * refresh: Object containing refresh parameters
  9. * enable :: true/false, enable auto refresh by default. Default: false
  10. * interval :: Seconds between auto refresh. Default: 30
  11. * min :: The lowest interval a user may set
  12. */
  13. define([
  14. 'angular',
  15. 'app',
  16. 'lodash',
  17. 'moment',
  18. 'kbn'
  19. ],
  20. function (angular, app, _, moment, kbn) {
  21. 'use strict';
  22. var module = angular.module('grafana.panels.timepicker', []);
  23. app.useModule(module);
  24. module.controller('timepicker', function($scope, $rootScope, timeSrv) {
  25. $scope.panelMeta = {
  26. status : "Stable",
  27. description : ""
  28. };
  29. // Set and populate defaults
  30. var _d = {
  31. status : "Stable",
  32. time_options : ['5m','15m','1h','6h','12h','24h','2d','7d','30d'],
  33. refresh_intervals : ['5s','10s','30s','1m','5m','15m','30m','1h','2h','1d'],
  34. };
  35. _.defaults($scope.panel,_d);
  36. // ng-pattern regexs
  37. $scope.patterns = {
  38. date: /^[0-9]{2}\/[0-9]{2}\/[0-9]{4}$/,
  39. hour: /^([01]?[0-9]|2[0-3])$/,
  40. minute: /^[0-5][0-9]$/,
  41. second: /^[0-5][0-9]$/,
  42. millisecond: /^[0-9]*$/
  43. };
  44. $scope.timeSrv = timeSrv;
  45. $scope.$on('refresh', function() {
  46. $scope.init();
  47. });
  48. $scope.init = function() {
  49. var time = timeSrv.timeRange(true);
  50. $scope.panel.now = false;
  51. var unparsed = timeSrv.timeRange(false);
  52. if (_.isString(unparsed.to) && unparsed.to.indexOf('now') === 0) {
  53. $scope.panel.now = true;
  54. }
  55. $scope.time = getScopeTimeObj(time.from, time.to);
  56. $scope.onAppEvent('zoom-out', function() {
  57. $scope.zoom(2);
  58. });
  59. };
  60. $scope.loadTimeOptions = function() {
  61. $scope.time_options = _.map($scope.panel.time_options, function(str) {
  62. var option = {value: str};
  63. if (str === 'today') {
  64. option.text = 'Today';
  65. option.from = 'today';
  66. option.to = 'now';
  67. } else {
  68. option.text = 'Last ' + str;
  69. option.from = 'now-'+str;
  70. option.to = 'now';
  71. }
  72. return option;
  73. });
  74. };
  75. $scope.customTime = function() {
  76. // Assume the form is valid since we're setting it to something valid
  77. $scope.input.$setValidity("dummy", true);
  78. $scope.temptime = cloneTime($scope.time);
  79. $scope.temptime.now = $scope.panel.now;
  80. $scope.temptime.from.date.setHours(0,0,0,0);
  81. $scope.temptime.to.date.setHours(0,0,0,0);
  82. // Date picker needs the date to be at the start of the day
  83. if(new Date().getTimezoneOffset() < 0) {
  84. $scope.temptime.from.date = moment($scope.temptime.from.date).add(1, 'days').toDate();
  85. $scope.temptime.to.date = moment($scope.temptime.to.date).add(1, 'days').toDate();
  86. }
  87. $scope.appEvent('show-dash-editor', {src: 'app/panels/timepicker/custom.html', scope: $scope });
  88. };
  89. // Constantly validate the input of the fields. This function does not change any date variables
  90. // outside of its own scope
  91. $scope.validate = function(time) {
  92. // Assume the form is valid. There is a hidden dummy input for invalidating it programatically.
  93. $scope.input.$setValidity("dummy", true);
  94. var _from = datepickerToLocal(time.from.date),
  95. _to = datepickerToLocal(time.to.date),
  96. _t = time;
  97. if($scope.input.$valid) {
  98. _from.setHours(_t.from.hour,_t.from.minute,_t.from.second,_t.from.millisecond);
  99. _to.setHours(_t.to.hour,_t.to.minute,_t.to.second,_t.to.millisecond);
  100. // Check that the objects are valid and to is after from
  101. if(isNaN(_from.getTime()) || isNaN(_to.getTime()) || _from.getTime() >= _to.getTime()) {
  102. $scope.input.$setValidity("dummy", false);
  103. return false;
  104. }
  105. } else {
  106. return false;
  107. }
  108. return { from: _from, to:_to, now: time.now};
  109. };
  110. $scope.setNow = function() {
  111. $scope.time.to = getTimeObj(new Date());
  112. };
  113. /*
  114. time : {
  115. from: Date
  116. to: Date
  117. }
  118. */
  119. $scope.setAbsoluteTimeFilter = function (time) {
  120. // Create filter object
  121. var _filter = _.clone(time);
  122. if(time.now) {
  123. _filter.to = "now";
  124. }
  125. // Update our representation
  126. $scope.time = getScopeTimeObj(time.from,time.to);
  127. };
  128. $scope.setRelativeFilter = function(timespan) {
  129. $scope.panel.now = true;
  130. var range = {from: timespan.from, to: timespan.to};
  131. if ($scope.panel.nowDelay) {
  132. range.to = 'now-' + $scope.panel.nowDelay;
  133. }
  134. timeSrv.setTime(range);
  135. $scope.time = getScopeTimeObj(kbn.parseDate(range.from),new Date());
  136. };
  137. var pad = function(n, width, z) {
  138. z = z || '0';
  139. n = n.toString();
  140. return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
  141. };
  142. var cloneTime = function(time) {
  143. var _n = {
  144. from: _.clone(time.from),
  145. to: _.clone(time.to)
  146. };
  147. // Create new dates as _.clone is shallow.
  148. _n.from.date = new Date(_n.from.date);
  149. _n.to.date = new Date(_n.to.date);
  150. return _n;
  151. };
  152. var getScopeTimeObj = function(from,to) {
  153. var model = {from: getTimeObj(from), to: getTimeObj(to)};
  154. if (model.from.date) {
  155. model.tooltip = $scope.dashboard.formatDate(model.from.date) + ' <br>to<br>';
  156. model.tooltip += $scope.dashboard.formatDate(model.to.date);
  157. }
  158. else {
  159. model.tooltip = 'Click to set time filter';
  160. }
  161. if (timeSrv.time) {
  162. if ($scope.panel.now) {
  163. if (timeSrv.time.from === 'today') {
  164. model.rangeString = 'Today';
  165. } else {
  166. model.rangeString = moment(model.from.date).fromNow() + ' to ' +
  167. moment(model.to.date).fromNow();
  168. }
  169. }
  170. else {
  171. model.rangeString = $scope.dashboard.formatDate(model.from.date, 'MMM D, YYYY HH:mm:ss') + ' to ' +
  172. $scope.dashboard.formatDate(model.to.date, 'MMM D, YYYY HH:mm:ss');
  173. }
  174. }
  175. return model;
  176. };
  177. var getTimeObj = function(date) {
  178. return {
  179. date: new Date(date),
  180. hour: pad(date.getHours(),2),
  181. minute: pad(date.getMinutes(),2),
  182. second: pad(date.getSeconds(),2),
  183. millisecond: pad(date.getMilliseconds(),3)
  184. };
  185. };
  186. // Do not use the results of this function unless you plan to use setHour/Minutes/etc on the result
  187. var datepickerToLocal = function(date) {
  188. date = moment(date).clone().toDate();
  189. return moment(new Date(date.getTime() + date.getTimezoneOffset() * 60000)).toDate();
  190. };
  191. $scope.zoom = function(factor) {
  192. var range = timeSrv.timeRange();
  193. var timespan = (range.to.valueOf() - range.from.valueOf());
  194. var center = range.to.valueOf() - timespan/2;
  195. var to = (center + (timespan*factor)/2);
  196. var from = (center - (timespan*factor)/2);
  197. if(to > Date.now() && range.to <= Date.now()) {
  198. var offset = to - Date.now();
  199. from = from - offset;
  200. to = Date.now();
  201. }
  202. timeSrv.setTime({
  203. from: moment.utc(from).toDate(),
  204. to: moment.utc(to).toDate(),
  205. });
  206. };
  207. });
  208. });