kibana-123
Version:
Kibana is an open source (Apache Licensed), browser based analytics and search dashboard for Elasticsearch. Kibana is a snap to setup and start using. Kibana strives to be easy to get started with, while also being flexible and powerful, just like Elastic
35 lines (27 loc) • 1.53 kB
JavaScript
import _ from 'lodash';
import moment from 'moment';
import dateMath from '@elastic/datemath';
// Assume interval is in the form (value)(unit), such as "1h"
let INTERVAL_STRING_RE = new RegExp('^([0-9\\.]*)\\s*(' + dateMath.units.join('|') + ')$');
export default function parseInterval(interval) {
let matches = String(interval).trim().match(INTERVAL_STRING_RE);
if (!matches) return null;
try {
let value = parseFloat(matches[1]) || 1;
let unit = matches[2];
let duration = moment.duration(value, unit);
// There is an error with moment, where if you have a fractional interval between 0 and 1, then when you add that
// interval to an existing moment object, it will remain unchanged, which causes problems in the ordered_x_keys
// code. To counteract this, we find the first unit that doesn't result in a value between 0 and 1.
// For example, if you have '0.5d', then when calculating the x-axis series, we take the start date and begin
// adding 0.5 days until we hit the end date. However, since there is a bug in moment, when you add 0.5 days to
// the start date, you get the same exact date (instead of being ahead by 12 hours). So instead of returning
// a duration corresponding to 0.5 hours, we return a duration corresponding to 12 hours.
let selectedUnit = _.find(dateMath.units, function (unit) {
return Math.abs(duration.as(unit)) >= 1;
});
return moment.duration(duration.as(selectedUnit), selectedUnit);
} catch (e) {
return null;
}
};