| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- /* *
- *
- * (c) 2010-2020 Sebastian Bochan, Rafal Sebestjanski
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- *
- * */
- 'use strict';
- import H from '../Core/Globals.js';
- import U from '../Core/Utilities.js';
- var seriesType = U.seriesType;
- var areaProto = H.seriesTypes.area.prototype, colProto = H.seriesTypes.column.prototype;
- /**
- * The lollipop series is a carteseian series with a line anchored from
- * the x axis and a dot at the end to mark the value.
- * Requires `highcharts-more.js`, `modules/dumbbell.js` and
- * `modules/lollipop.js`.
- *
- * @sample {highcharts} highcharts/demo/lollipop/
- * Lollipop chart
- * @sample {highcharts} highcharts/series-dumbbell/styled-mode-dumbbell/
- * Styled mode
- *
- * @extends plotOptions.dumbbell
- * @product highcharts highstock
- * @excluding fillColor, fillOpacity, lineWidth, stack, stacking, lowColor,
- * stickyTracking, trackByArea
- * @since 8.0.0
- * @optionparent plotOptions.lollipop
- */
- seriesType('lollipop', 'dumbbell', {
- /** @ignore-option */
- lowColor: void 0,
- /** @ignore-option */
- threshold: 0,
- /** @ignore-option */
- connectorWidth: 1,
- /** @ignore-option */
- groupPadding: 0.2,
- /** @ignore-option */
- pointPadding: 0.1,
- /** @ignore-option */
- states: {
- hover: {
- /** @ignore-option */
- lineWidthPlus: 0,
- /** @ignore-option */
- connectorWidthPlus: 1,
- /** @ignore-option */
- halo: false
- }
- },
- tooltip: {
- pointFormat: '<span style="color:{series.color}">●</span> {series.name}: <b>{point.y}</b><br/>'
- }
- }, {
- pointArrayMap: ['y'],
- pointValKey: 'y',
- toYData: function (point) {
- return [H.pick(point.y, point.low)];
- },
- translatePoint: areaProto.translate,
- drawPoint: areaProto.drawPoints,
- drawDataLabels: colProto.drawDataLabels,
- setShapeArgs: colProto.translate
- }, {
- pointSetState: areaProto.pointClass.prototype.setState,
- setState: H.seriesTypes.dumbbell.prototype.pointClass.prototype.setState,
- init: function (series, options, x) {
- if (H.isObject(options) && 'low' in options) {
- options.y = options.low;
- delete options.low;
- }
- return H.Point.prototype.init.apply(this, arguments);
- }
- });
- /**
- * The `lollipop` series. If the [type](#series.lollipop.type) option is
- * not specified, it is inherited from [chart.type](#chart.type).
- *
- * @extends series,plotOptions.lollipop,
- * @excluding boostThreshold, boostBlending
- * @product highcharts highstock
- * @requires highcharts-more
- * @requires modules/dumbbell
- * @requires modules/lollipop
- * @apioption series.lollipop
- */
- /**
- * An array of data points for the series. For the `lollipop` series type,
- * points can be given in the following ways:
- *
- * 1. An array of numerical values. In this case, the numerical values will be
- * interpreted as `y` options. The `x` values will be automatically
- * calculated, either starting at 0 and incremented by 1, or from
- * `pointStart` and `pointInterval` given in the series options. If the axis
- * has categories, these will be used. Example:
- * ```js
- * data: [0, 5, 3, 5]
- * ```
- *
- * 2. An array of arrays with 2 values. In this case, the values correspond to
- * `x,y`. If the first value is a string, it is applied as the name of the
- * point, and the `x` value is inferred.
- * ```js
- * data: [
- * [0, 6],
- * [1, 2],
- * [2, 6]
- * ]
- * ```
- *
- * 3. An array of objects with named values. The following snippet shows only a
- * few settings, see the complete options set below. If the total number of
- * data points exceeds the series'
- * [turboThreshold](#series.lollipop.turboThreshold), this option is not
- * available.
- * ```js
- * data: [{
- * x: 1,
- * y: 9,
- * name: "Point2",
- * color: "#00FF00",
- * connectorWidth: 3,
- * connectorColor: "#FF00FF"
- * }, {
- * x: 1,
- * y: 6,
- * name: "Point1",
- * color: "#FF00FF"
- * }]
- * ```
- *
- * @sample {highcharts} highcharts/chart/reflow-true/
- * Numerical values
- * @sample {highcharts} highcharts/series/data-array-of-arrays/
- * Arrays of numeric x and y
- * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/
- * Arrays of datetime x and y
- * @sample {highcharts} highcharts/series/data-array-of-name-value/
- * Arrays of point.name and y
- * @sample {highcharts} highcharts/series/data-array-of-objects/
- * Config objects
- *
- * @type {Array<number|Array<(number|string),(number|null)>|null|*>}
- * @extends series.dumbbell.data
- * @excluding high, low, lowColor
- * @product highcharts highstock
- * @apioption series.lollipop.data
- */
- /**
- * The y value of the point.
- *
- * @type {number|null}
- * @product highcharts highstock
- * @apioption series.line.data.y
- */
- ''; // adds doclets above to transpiled file
|