'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _Globals = require('../../parts/Globals.js'); var _Globals2 = _interopRequireDefault(_Globals); require('../../parts/Utilities.js'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var Annotation = _Globals2.default.Annotation, MockPoint = Annotation.MockPoint; /** * @class * @extends Annotation * @memberOf Highcharts */ function VerticalLine() { _Globals2.default.Annotation.apply(this, arguments); } VerticalLine.connectorFirstPoint = function (target) { var annotation = target.annotation, point = annotation.points[0], xy = MockPoint.pointToPixels(point, true), y = xy.y, offset = annotation.options.typeOptions.label.offset; if (annotation.chart.inverted) { y = xy.x; } return { x: point.x, xAxis: point.series.xAxis, y: y + offset }; }; VerticalLine.connectorSecondPoint = function (target) { var annotation = target.annotation, typeOptions = annotation.options.typeOptions, point = annotation.points[0], yOffset = typeOptions.yOffset, xy = MockPoint.pointToPixels(point, true), y = xy[annotation.chart.inverted ? 'x' : 'y']; if (typeOptions.label.offset < 0) { yOffset *= -1; } return { x: point.x, xAxis: point.series.xAxis, y: y + yOffset }; }; _Globals2.default.extendAnnotation(VerticalLine, null, /** @lends Annotation.VerticalLine# */ { getPointsOptions: function getPointsOptions() { return [this.options.typeOptions.point]; }, addShapes: function addShapes() { var typeOptions = this.options.typeOptions, connector = this.initShape(_Globals2.default.merge(typeOptions.connector, { type: 'path', points: [VerticalLine.connectorFirstPoint, VerticalLine.connectorSecondPoint] }), false); typeOptions.connector = connector.options; }, addLabels: function addLabels() { var typeOptions = this.options.typeOptions, labelOptions = typeOptions.label, x = 0, y = labelOptions.offset, verticalAlign = labelOptions.offset < 0 ? 'bottom' : 'top', align = 'center'; if (this.chart.inverted) { x = labelOptions.offset; y = 0; verticalAlign = 'middle'; align = labelOptions.offset < 0 ? 'right' : 'left'; } var label = this.initLabel(_Globals2.default.merge(labelOptions, { verticalAlign: verticalAlign, align: align, x: x, y: y })); typeOptions.label = label.options; } }, /** * A vertical line annotation. * * @sample highcharts/annotations-advanced/vertical-line/ * Vertical line * * @extends annotations.crookedLine * @excluding labels, shapes, controlPointOptions * @product highstock * @optionparent annotations.verticalLine */ { typeOptions: { /** * @ignore */ yOffset: 10, /** * Label options. * * @extends annotations.crookedLine.labelOptions */ label: { offset: -40, point: function point(target) { return target.annotation.points[0]; }, allowOverlap: true, backgroundColor: 'none', borderWidth: 0, crop: true, overflow: 'none', shape: 'rect', text: '{y:.2f}' }, /** * Connector options. * * @extends annotations.crookedLine.shapeOptions * @excluding height, r, type, width */ connector: { strokeWidth: 1, markerEnd: 'arrow' } } }); Annotation.types.verticalLine = VerticalLine; exports.default = VerticalLine;