| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- /*
- ## Timepicker2
- ### Parameters
- * mode :: The default mode of the panel. Options: 'relative', 'absolute' 'since' Default: 'relative'
- * time_options :: An array of possible time options. Default: ['5m','15m','1h','6h','12h','24h','2d','7d','30d']
- * timespan :: The default options selected for the relative view. Default: '15m'
- * timefield :: The field in which time is stored in the document.
- * refresh: Object containing refresh parameters
- * enable :: true/false, enable auto refresh by default. Default: false
- * interval :: Seconds between auto refresh. Default: 30
- * min :: The lowest interval a user may set
- */
- define([
- 'angular',
- 'app',
- 'lodash',
- 'moment',
- 'kbn'
- ],
- function (angular, app, _, moment, kbn) {
- 'use strict';
- var module = angular.module('grafana.panels.timepicker', []);
- app.useModule(module);
- module.controller('timepicker', function($scope, $rootScope, timeSrv) {
- $scope.panelMeta = {
- status : "Stable",
- description : ""
- };
- // Set and populate defaults
- var _d = {
- status : "Stable",
- time_options : ['5m','15m','1h','6h','12h','24h','2d','7d','30d'],
- refresh_intervals : ['5s','10s','30s','1m','5m','15m','30m','1h','2h','1d'],
- };
- _.defaults($scope.panel,_d);
- // ng-pattern regexs
- $scope.patterns = {
- date: /^[0-9]{2}\/[0-9]{2}\/[0-9]{4}$/,
- hour: /^([01]?[0-9]|2[0-3])$/,
- minute: /^[0-5][0-9]$/,
- second: /^[0-5][0-9]$/,
- millisecond: /^[0-9]*$/
- };
- $scope.timeSrv = timeSrv;
- $scope.$on('refresh', function() {
- $scope.init();
- });
- $scope.init = function() {
- var time = timeSrv.timeRange(true);
- if(time) {
- $scope.panel.now = timeSrv.timeRange(false).to === "now" ? true : false;
- $scope.time = getScopeTimeObj(time.from,time.to);
- }
- };
- $scope.customTime = function() {
- // Assume the form is valid since we're setting it to something valid
- $scope.input.$setValidity("dummy", true);
- $scope.temptime = cloneTime($scope.time);
- $scope.temptime.now = $scope.panel.now;
- $scope.temptime.from.date.setHours(0,0,0,0);
- $scope.temptime.to.date.setHours(0,0,0,0);
- // Date picker needs the date to be at the start of the day
- if(new Date().getTimezoneOffset() < 0) {
- $scope.temptime.from.date = moment($scope.temptime.from.date).add('days',1).toDate();
- $scope.temptime.to.date = moment($scope.temptime.to.date).add('days',1).toDate();
- }
- $scope.emitAppEvent('show-dash-editor', {src: 'app/panels/timepicker/custom.html', scope: $scope });
- };
- // Constantly validate the input of the fields. This function does not change any date variables
- // outside of its own scope
- $scope.validate = function(time) {
- // Assume the form is valid. There is a hidden dummy input for invalidating it programatically.
- $scope.input.$setValidity("dummy", true);
- var _from = datepickerToLocal(time.from.date),
- _to = datepickerToLocal(time.to.date),
- _t = time;
- if($scope.input.$valid) {
- _from.setHours(_t.from.hour,_t.from.minute,_t.from.second,_t.from.millisecond);
- _to.setHours(_t.to.hour,_t.to.minute,_t.to.second,_t.to.millisecond);
- // Check that the objects are valid and to is after from
- if(isNaN(_from.getTime()) || isNaN(_to.getTime()) || _from.getTime() >= _to.getTime()) {
- $scope.input.$setValidity("dummy", false);
- return false;
- }
- } else {
- return false;
- }
- return { from: _from, to:_to, now: time.now};
- };
- $scope.setNow = function() {
- $scope.time.to = getTimeObj(new Date());
- };
- /*
- time : {
- from: Date
- to: Date
- }
- */
- $scope.setAbsoluteTimeFilter = function (time) {
- // Create filter object
- var _filter = _.clone(time);
- if(time.now) {
- _filter.to = "now";
- }
- // Set the filter
- $scope.panel.filter_id = timeSrv.setTime(_filter);
- // Update our representation
- $scope.time = getScopeTimeObj(time.from,time.to);
- };
- $scope.setRelativeFilter = function(timespan) {
- $scope.panel.now = true;
- var _filter = {
- from : "now-"+timespan,
- to: "now"
- };
- timeSrv.setTime(_filter);
- $scope.time = getScopeTimeObj(kbn.parseDate(_filter.from),new Date());
- };
- var pad = function(n, width, z) {
- z = z || '0';
- n = n.toString();
- return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
- };
- var cloneTime = function(time) {
- var _n = {
- from: _.clone(time.from),
- to: _.clone(time.to)
- };
- // Create new dates as _.clone is shallow.
- _n.from.date = new Date(_n.from.date);
- _n.to.date = new Date(_n.to.date);
- return _n;
- };
- var getScopeTimeObj = function(from,to) {
- var model = { from: getTimeObj(from), to: getTimeObj(to), };
- if (model.from.date) {
- model.tooltip = $scope.dashboard.formatDate(model.from.date) + ' <br>to<br>';
- model.tooltip += $scope.dashboard.formatDate(model.to.date);
- }
- else {
- model.tooltip = 'Click to set time filter';
- }
- if (timeSrv.time) {
- if ($scope.panel.now) {
- model.rangeString = moment(model.from.date).fromNow() + ' to ' +
- moment(model.to.date).fromNow();
- }
- else {
- model.rangeString = $scope.dashboard.formatDate(model.from.date, 'MMM D, YYYY HH:mm:ss') + ' to ' +
- $scope.dashboard.formatDate(model.to.date, 'MMM D, YYYY HH:mm:ss');
- }
- }
- return model;
- };
- var getTimeObj = function(date) {
- return {
- date: new Date(date),
- hour: pad(date.getHours(),2),
- minute: pad(date.getMinutes(),2),
- second: pad(date.getSeconds(),2),
- millisecond: pad(date.getMilliseconds(),3)
- };
- };
- // Do not use the results of this function unless you plan to use setHour/Minutes/etc on the result
- var datepickerToLocal = function(date) {
- date = moment(date).clone().toDate();
- return moment(new Date(date.getTime() + date.getTimezoneOffset() * 60000)).toDate();
- };
- });
- });
|