| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- /* *
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- * */
- 'use strict';
- import U from '../../Core/Utilities.js';
- var error = U.error, seriesType = U.seriesType;
- /* eslint-disable valid-jsdoc */
- // Utils:
- /**
- * @private
- */
- function populateAverage(xVal, yVal, yValVolume, i) {
- var high = yVal[i][1], low = yVal[i][2], close = yVal[i][3], volume = yValVolume[i], adY = close === high && close === low || high === low ?
- 0 :
- ((2 * close - low - high) / (high - low)) * volume, adX = xVal[i];
- return [adX, adY];
- }
- /* eslint-enable valid-jsdoc */
- /**
- * The AD series type.
- *
- * @private
- * @class
- * @name Highcharts.seriesTypes.ad
- *
- * @augments Highcharts.Series
- */
- seriesType('ad', 'sma',
- /**
- * Accumulation Distribution (AD). This series requires `linkedTo` option to
- * be set.
- *
- * @sample stock/indicators/accumulation-distribution
- * Accumulation/Distribution indicator
- *
- * @extends plotOptions.sma
- * @since 6.0.0
- * @product highstock
- * @requires stock/indicators/indicators
- * @requires stock/indicators/accumulation-distribution
- * @optionparent plotOptions.ad
- */
- {
- params: {
- /**
- * The id of volume series which is mandatory.
- * For example using OHLC data, volumeSeriesID='volume' means
- * the indicator will be calculated using OHLC and volume values.
- *
- * @since 6.0.0
- */
- volumeSeriesID: 'volume'
- }
- },
- /**
- * @lends Highcharts.Series#
- */
- {
- nameComponents: false,
- nameBase: 'Accumulation/Distribution',
- getValues: function (series, params) {
- var period = params.period, xVal = series.xData, yVal = series.yData, volumeSeriesID = params.volumeSeriesID, volumeSeries = series.chart.get(volumeSeriesID), yValVolume = volumeSeries && volumeSeries.yData, yValLen = yVal ? yVal.length : 0, AD = [], xData = [], yData = [], len, i, ADPoint;
- if (xVal.length <= period &&
- yValLen &&
- yVal[0].length !== 4) {
- return;
- }
- if (!volumeSeries) {
- error('Series ' +
- volumeSeriesID +
- ' not found! Check `volumeSeriesID`.', true, series.chart);
- return;
- }
- // i = period <-- skip first N-points
- // Calculate value one-by-one for each period in visible data
- for (i = period; i < yValLen; i++) {
- len = AD.length;
- ADPoint = populateAverage(xVal, yVal, yValVolume, i, period);
- if (len > 0) {
- ADPoint[1] += AD[len - 1][1];
- }
- AD.push(ADPoint);
- xData.push(ADPoint[0]);
- yData.push(ADPoint[1]);
- }
- return {
- values: AD,
- xData: xData,
- yData: yData
- };
- }
- });
- /**
- * A `AD` series. If the [type](#series.ad.type) option is not
- * specified, it is inherited from [chart.type](#chart.type).
- *
- * @extends series,plotOptions.ad
- * @since 6.0.0
- * @excluding dataParser, dataURL
- * @product highstock
- * @requires stock/indicators/indicators
- * @requires stock/indicators/accumulation-distribution
- * @apioption series.ad
- */
- ''; // add doclet above to transpiled file
|