123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487 |
- /**
- * @license Highstock JS v9.1.1 (2021-06-04)
- *
- * Indicator series type for Highcharts Stock
- *
- * (c) 2010-2021 Wojciech Chmiel
- *
- * License: www.highcharts.com/license
- */
- 'use strict';
- (function (factory) {
- if (typeof module === 'object' && module.exports) {
- factory['default'] = factory;
- module.exports = factory;
- } else if (typeof define === 'function' && define.amd) {
- define('highcharts/indicators/chaikin', ['highcharts', 'highcharts/modules/stock'], function (Highcharts) {
- factory(Highcharts);
- factory.Highcharts = Highcharts;
- return factory;
- });
- } else {
- factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);
- }
- }(function (Highcharts) {
- var _modules = Highcharts ? Highcharts._modules : {};
- function _registerModule(obj, path, args, fn) {
- if (!obj.hasOwnProperty(path)) {
- obj[path] = fn.apply(null, args);
- }
- }
- _registerModule(_modules, 'Mixins/IndicatorRequired.js', [_modules['Core/Utilities.js']], function (U) {
- /**
- *
- * (c) 2010-2021 Daniel Studencki
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- *
- * */
- var error = U.error;
- /* eslint-disable no-invalid-this, valid-jsdoc */
- var requiredIndicatorMixin = {
- /**
- * Check whether given indicator is loaded,
- else throw error.
- * @private
- * @param {Highcharts.Indicator} indicator
- * Indicator constructor function.
- * @param {string} requiredIndicator
- * Required indicator type.
- * @param {string} type
- * Type of indicator where function was called (parent).
- * @param {Highcharts.IndicatorCallbackFunction} callback
- * Callback which is triggered if the given indicator is loaded.
- * Takes indicator as an argument.
- * @param {string} errMessage
- * Error message that will be logged in console.
- * @return {boolean}
- * Returns false when there is no required indicator loaded.
- */
- isParentLoaded: function (indicator,
- requiredIndicator,
- type,
- callback,
- errMessage) {
- if (indicator) {
- return callback ? callback(indicator) : true;
- }
- error(errMessage || this.generateMessage(type, requiredIndicator));
- return false;
- },
- /**
- * @private
- * @param {string} indicatorType
- * Indicator type
- * @param {string} required
- * Required indicator
- * @return {string}
- * Error message
- */
- generateMessage: function (indicatorType, required) {
- return 'Error: "' + indicatorType +
- '" indicator type requires "' + required +
- '" indicator loaded before. Please read docs: ' +
- 'https://api.highcharts.com/highstock/plotOptions.' +
- indicatorType;
- }
- };
- return requiredIndicatorMixin;
- });
- _registerModule(_modules, 'Stock/Indicators/AD/ADIndicator.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {
- /* *
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- * */
- var __extends = (this && this.__extends) || (function () {
- var extendStatics = function (d,
- b) {
- extendStatics = Object.setPrototypeOf ||
- ({ __proto__: [] } instanceof Array && function (d,
- b) { d.__proto__ = b; }) ||
- function (d,
- b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
- return extendStatics(d, b);
- };
- return function (d, b) {
- extendStatics(d, b);
- function __() { this.constructor = d; }
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- })();
- var SMAIndicator = SeriesRegistry.seriesTypes.sma;
- var error = U.error,
- extend = U.extend,
- merge = U.merge;
- /**
- * The AD series type.
- *
- * @private
- * @class
- * @name Highcharts.seriesTypes.ad
- *
- * @augments Highcharts.Series
- */
- var ADIndicator = /** @class */ (function (_super) {
- __extends(ADIndicator, _super);
- function ADIndicator() {
- /* *
- *
- * Static Properties
- *
- * */
- var _this = _super !== null && _super.apply(this,
- arguments) || this;
- /* *
- *
- * Properties
- *
- * */
- _this.data = void 0;
- _this.options = void 0;
- _this.points = void 0;
- return _this;
- }
- /* *
- *
- * Static Functions
- *
- * */
- ADIndicator.populateAverage = function (xVal, yVal, yValVolume, i, _period) {
- 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];
- };
- /* *
- *
- * Functions
- *
- * */
- ADIndicator.prototype.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 = ADIndicator.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
- };
- };
- /**
- * 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
- */
- ADIndicator.defaultOptions = merge(SMAIndicator.defaultOptions, {
- /**
- * @excluding index
- */
- params: {
- index: void 0,
- /**
- * 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'
- }
- });
- return ADIndicator;
- }(SMAIndicator));
- extend(ADIndicator.prototype, {
- nameComponents: false,
- nameBase: 'Accumulation/Distribution'
- });
- SeriesRegistry.registerSeriesType('ad', ADIndicator);
- /* *
- *
- * Default Export
- *
- * */
- /* *
- *
- * API Options
- *
- * */
- /**
- * 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
- return ADIndicator;
- });
- _registerModule(_modules, 'Stock/Indicators/Chaikin/ChaikinIndicator.js', [_modules['Mixins/IndicatorRequired.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (RequiredIndicatorMixin, SeriesRegistry, U) {
- /* *
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- *
- * */
- var __extends = (this && this.__extends) || (function () {
- var extendStatics = function (d,
- b) {
- extendStatics = Object.setPrototypeOf ||
- ({ __proto__: [] } instanceof Array && function (d,
- b) { d.__proto__ = b; }) ||
- function (d,
- b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
- return extendStatics(d, b);
- };
- return function (d, b) {
- extendStatics(d, b);
- function __() { this.constructor = d; }
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
- };
- })();
- var _a = SeriesRegistry.seriesTypes,
- AD = _a.ad,
- EMAIndicator = _a.ema;
- var correctFloat = U.correctFloat,
- extend = U.extend,
- merge = U.merge,
- error = U.error;
- /* *
- *
- * Class
- *
- * */
- /**
- * The Chaikin series type.
- *
- * @private
- * @class
- * @name Highcharts.seriesTypes.chaikin
- *
- * @augments Highcharts.Series
- */
- var ChaikinIndicator = /** @class */ (function (_super) {
- __extends(ChaikinIndicator, _super);
- function ChaikinIndicator() {
- var _this = _super !== null && _super.apply(this,
- arguments) || this;
- /* *
- *
- * Properties
- *
- * */
- _this.data = void 0;
- _this.options = void 0;
- _this.points = void 0;
- return _this;
- }
- /* *
- *
- * Functions
- *
- * */
- ChaikinIndicator.prototype.init = function () {
- var args = arguments,
- ctx = this;
- RequiredIndicatorMixin.isParentLoaded(EMAIndicator, 'ema', ctx.type, function (indicator) {
- indicator.prototype.init.apply(ctx, args);
- return;
- });
- };
- ChaikinIndicator.prototype.getValues = function (series, params) {
- var periods = params.periods,
- period = params.period,
- // Accumulation Distribution Line data
- ADL,
- // 0- date, 1- Chaikin Oscillator
- CHA = [],
- xData = [],
- yData = [],
- periodsOffset,
- // Shorter Period EMA
- SPE,
- // Longer Period EMA
- LPE,
- oscillator,
- i;
- // Check if periods are correct
- if (periods.length !== 2 || periods[1] <= periods[0]) {
- error('Error: "Chaikin requires two periods. Notice, first ' +
- 'period should be lower than the second one."');
- return;
- }
- ADL = AD.prototype.getValues.call(this, series, {
- volumeSeriesID: params.volumeSeriesID,
- period: period
- });
- // Check if adl is calculated properly, if not skip
- if (!ADL) {
- return;
- }
- SPE = EMAIndicator.prototype.getValues.call(this, ADL, {
- period: periods[0]
- });
- LPE = EMAIndicator.prototype.getValues.call(this, ADL, {
- period: periods[1]
- });
- // Check if ema is calculated properly, if not skip
- if (!SPE || !LPE) {
- return;
- }
- periodsOffset = periods[1] - periods[0];
- for (i = 0; i < LPE.yData.length; i++) {
- oscillator = correctFloat(SPE.yData[i + periodsOffset] -
- LPE.yData[i]);
- CHA.push([LPE.xData[i], oscillator]);
- xData.push(LPE.xData[i]);
- yData.push(oscillator);
- }
- return {
- values: CHA,
- xData: xData,
- yData: yData
- };
- };
- /**
- * Chaikin Oscillator. This series requires the `linkedTo` option to
- * be set and should be loaded after the `stock/indicators/indicators.js`
- * and `stock/indicators/ema.js`.
- *
- * @sample {highstock} stock/indicators/chaikin
- * Chaikin Oscillator
- *
- * @extends plotOptions.ema
- * @since 7.0.0
- * @product highstock
- * @excluding allAreas, colorAxis, joinBy, keys, navigatorOptions,
- * pointInterval, pointIntervalUnit, pointPlacement,
- * pointRange, pointStart, showInNavigator, stacking
- * @requires stock/indicators/indicators
- * @requires stock/indicators/ema
- * @requires stock/indicators/chaikin
- * @optionparent plotOptions.chaikin
- */
- ChaikinIndicator.defaultOptions = merge(EMAIndicator.defaultOptions, {
- /**
- * Paramters used in calculation of Chaikin Oscillator
- * series points.
- *
- * @excluding index
- */
- params: {
- index: void 0,
- /**
- * 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.
- */
- volumeSeriesID: 'volume',
- /**
- * Parameter used indirectly for calculating the `AD` indicator.
- * Decides about the number of data points that are taken
- * into account for the indicator calculations.
- */
- period: 9,
- /**
- * Periods for Chaikin Oscillator calculations.
- *
- * @type {Array<number>}
- * @default [3, 10]
- */
- periods: [3, 10]
- }
- });
- return ChaikinIndicator;
- }(EMAIndicator));
- extend(ChaikinIndicator.prototype, {
- nameBase: 'Chaikin Osc',
- nameComponents: ['periods']
- });
- SeriesRegistry.registerSeriesType('chaikin', ChaikinIndicator);
- /* *
- *
- * Default Export
- *
- * */
- /**
- * A `Chaikin Oscillator` series. If the [type](#series.chaikin.type)
- * option is not specified, it is inherited from [chart.type](#chart.type).
- *
- * @extends series,plotOptions.chaikin
- * @since 7.0.0
- * @product highstock
- * @excluding allAreas, colorAxis, dataParser, dataURL, joinBy, keys,
- * navigatorOptions, pointInterval, pointIntervalUnit,
- * pointPlacement, pointRange, pointStart, stacking, showInNavigator
- * @requires stock/indicators/indicators
- * @requires stock/indicators/ema
- * @requires stock/indicators/chaikin
- * @apioption series.chaikin
- */
- ''; // to include the above in the js output
- return ChaikinIndicator;
- });
- _registerModule(_modules, 'masters/indicators/chaikin.src.js', [], function () {
- });
- }));
|