UNPKG

@spalger/kibana

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

76 lines (67 loc) 2.1 kB
define(function (require) { return function TimeMarkerFactory() { var d3 = require('d3'); var dateMath = require('ui/utils/dateMath'); function TimeMarker(times, xScale, height) { if (!(this instanceof TimeMarker)) { return new TimeMarker(times, xScale, height); } var currentTimeArr = [{ 'time': new Date().getTime(), 'class': 'time-marker', 'color': '#c80000', 'opacity': 0.3, 'width': 2 }]; this.xScale = xScale; this.height = height; this.times = (times.length) ? times.map(function (d) { return { 'time': dateMath.parse(d.time), 'class': d.class || 'time-marker', 'color': d.color || '#c80000', 'opacity': d.opacity || 0.3, 'width': d.width || 2 }; }) : currentTimeArr; } TimeMarker.prototype._isTimeBasedChart = function (selection) { var data = selection.data(); return data.every(function (datum) { return (datum.ordered && datum.ordered.date); }); }; TimeMarker.prototype.render = function (selection) { var self = this; // return if not time based chart if (!self._isTimeBasedChart(selection)) return; selection.each(function () { d3.select(this).selectAll('time-marker') .data(self.times) .enter().append('line') .attr('class', function (d) { return d.class; }) .attr('pointer-events', 'none') .attr('stroke', function (d) { return d.color; }) .attr('stroke-width', function (d) { return d.width; }) .attr('stroke-opacity', function (d) { return d.opacity; }) .attr('x1', function (d) { return self.xScale(d.time); }) .attr('x2', function (d) { return self.xScale(d.time); }) .attr('y1', self.height) .attr('y2', self.xScale.range()[0]); }); }; return TimeMarker; }; });