UNPKG

highcharts

Version:
271 lines (259 loc) 8.99 kB
/** * @license Highstock JS v12.2.0 (2025-04-07) * @module highcharts/indicators/mfi * @requires highcharts * @requires highcharts/modules/stock * * Money Flow Index indicator for Highcharts Stock * * (c) 2010-2025 Grzegorz Blachliński * * License: www.highcharts.com/license */ import * as __WEBPACK_EXTERNAL_MODULE__highcharts_src_js_8202131d__ from "../highcharts.src.js"; import * as __WEBPACK_EXTERNAL_MODULE__modules_stock_src_js_b3d80146__ from "../modules/stock.src.js"; /******/ // The require scope /******/ var __webpack_require__ = {}; /******/ /************************************************************************/ /******/ /* webpack/runtime/compat get default export */ /******/ (() => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /************************************************************************/ ;// external ["../highcharts.src.js","default"] const external_highcharts_src_js_default_namespaceObject = __WEBPACK_EXTERNAL_MODULE__highcharts_src_js_8202131d__["default"]; var external_highcharts_src_js_default_default = /*#__PURE__*/__webpack_require__.n(external_highcharts_src_js_default_namespaceObject); ;// external "../modules/stock.src.js" var x = (y) => { var x = {}; __webpack_require__.d(x, y); return x } var y = (x) => (() => (x)) const stock_src_js_namespaceObject = x({ }); ;// external ["../highcharts.src.js","default","SeriesRegistry"] const external_highcharts_src_js_default_SeriesRegistry_namespaceObject = __WEBPACK_EXTERNAL_MODULE__highcharts_src_js_8202131d__["default"].SeriesRegistry; var external_highcharts_src_js_default_SeriesRegistry_default = /*#__PURE__*/__webpack_require__.n(external_highcharts_src_js_default_SeriesRegistry_namespaceObject); ;// ./code/es-modules/Stock/Indicators/MFI/MFIIndicator.js /* * * * Money Flow Index indicator for Highcharts Stock * * (c) 2010-2025 Grzegorz Blachliński * * License: www.highcharts.com/license * * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!! * * */ const { sma: SMAIndicator } = (external_highcharts_src_js_default_SeriesRegistry_default()).seriesTypes; const { extend, merge, error, isArray } = (external_highcharts_src_js_default_default()); /* * * * Functions * * */ // Utils: /** * */ function sumArray(array) { return array.reduce(function (prev, cur) { return prev + cur; }); } /** * */ function toFixed(a, n) { return parseFloat(a.toFixed(n)); } /** * */ function calculateTypicalPrice(point) { return (point[1] + point[2] + point[3]) / 3; } /** * */ function calculateRawMoneyFlow(typicalPrice, volume) { return typicalPrice * volume; } /* * * * Class * * */ /** * The MFI series type. * * @private * @class * @name Highcharts.seriesTypes.mfi * * @augments Highcharts.Series */ class MFIIndicator extends SMAIndicator { /* * * * Functions * * */ getValues(series, params) { const period = params.period, xVal = series.xData, yVal = series.yData, yValLen = yVal ? yVal.length : 0, decimals = params.decimals, volumeSeries = series.chart.get(params.volumeSeriesID), yValVolume = volumeSeries?.getColumn('y') || [], MFI = [], xData = [], yData = [], positiveMoneyFlow = [], negativeMoneyFlow = []; let newTypicalPrice, oldTypicalPrice, rawMoneyFlow, negativeMoneyFlowSum, positiveMoneyFlowSum, moneyFlowRatio, MFIPoint, i, isUp = false, // MFI starts calculations from the second point // Cause we need to calculate change between two points range = 1; if (!volumeSeries) { error('Series ' + params.volumeSeriesID + ' not found! Check `volumeSeriesID`.', true, series.chart); return; } // MFI requires high low and close values if ((xVal.length <= period) || !isArray(yVal[0]) || yVal[0].length !== 4 || !yValVolume) { return; } // Calculate first typical price newTypicalPrice = calculateTypicalPrice(yVal[range]); // Accumulate first N-points while (range < period + 1) { // Calculate if up or down oldTypicalPrice = newTypicalPrice; newTypicalPrice = calculateTypicalPrice(yVal[range]); isUp = newTypicalPrice >= oldTypicalPrice; // Calculate raw money flow rawMoneyFlow = calculateRawMoneyFlow(newTypicalPrice, yValVolume[range]); // Add to array positiveMoneyFlow.push(isUp ? rawMoneyFlow : 0); negativeMoneyFlow.push(isUp ? 0 : rawMoneyFlow); range++; } for (i = range - 1; i < yValLen; i++) { if (i > range - 1) { // Remove first point from array positiveMoneyFlow.shift(); negativeMoneyFlow.shift(); // Calculate if up or down oldTypicalPrice = newTypicalPrice; newTypicalPrice = calculateTypicalPrice(yVal[i]); isUp = newTypicalPrice > oldTypicalPrice; // Calculate raw money flow rawMoneyFlow = calculateRawMoneyFlow(newTypicalPrice, yValVolume[i]); // Add to array positiveMoneyFlow.push(isUp ? rawMoneyFlow : 0); negativeMoneyFlow.push(isUp ? 0 : rawMoneyFlow); } // Calculate sum of negative and positive money flow: negativeMoneyFlowSum = sumArray(negativeMoneyFlow); positiveMoneyFlowSum = sumArray(positiveMoneyFlow); moneyFlowRatio = positiveMoneyFlowSum / negativeMoneyFlowSum; MFIPoint = toFixed(100 - (100 / (1 + moneyFlowRatio)), decimals); MFI.push([xVal[i], MFIPoint]); xData.push(xVal[i]); yData.push(MFIPoint); } return { values: MFI, xData: xData, yData: yData }; } } /* * * * Static Properties * * */ /** * Money Flow Index. This series requires `linkedTo` option to be set and * should be loaded after the `stock/indicators/indicators.js` file. * * @sample stock/indicators/mfi * Money Flow Index Indicator * * @extends plotOptions.sma * @since 6.0.0 * @product highstock * @requires stock/indicators/indicators * @requires stock/indicators/mfi * @optionparent plotOptions.mfi */ MFIIndicator.defaultOptions = merge(SMAIndicator.defaultOptions, { /** * @excluding index */ params: { index: void 0, // Unchangeable index, do not inherit (#15362) /** * 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', /** * Number of maximum decimals that are used in MFI calculations. */ decimals: 4 } }); extend(MFIIndicator.prototype, { nameBase: 'Money Flow Index' }); external_highcharts_src_js_default_SeriesRegistry_default().registerSeriesType('mfi', MFIIndicator); /* * * * Default Export * * */ /* harmony default export */ const MFI_MFIIndicator = ((/* unused pure expression or super */ null && (MFIIndicator))); /* * * * API Options * * */ /** * A `MFI` series. If the [type](#series.mfi.type) option is not specified, it * is inherited from [chart.type](#chart.type). * * @extends series,plotOptions.mfi * @since 6.0.0 * @excluding dataParser, dataURL * @product highstock * @requires stock/indicators/indicators * @requires stock/indicators/mfi * @apioption series.mfi */ ''; // To include the above in the js output ;// ./code/es-modules/masters/indicators/mfi.src.js /* harmony default export */ const mfi_src = ((external_highcharts_src_js_default_default())); export { mfi_src as default };